Apps Home
|
Create an App
nptest backup
Author:
t1g3r01
Description
Source Code
Launch App
Current Users
Created by:
T1g3r01
var backgroundImage = 'a8627dbd-4f22-4962-8c19-2f94b8d04fe1'; var fontSize = 12; cb.onEnter(function(user) { var sUser = user['user']; var sGreetMsg = ''; }); cb.onTip(function(tip) { var TIP_NOTE_NOTICE_BACKGROUND = '#FFFF00'; //#FFFF00 - yellow; var sMsg = tip['message']; var sUser = '' + tip['from_user']; if (sMsg != '') { cb.sendNotice('(Tip-Note by ' + sUser + ': ' + sMsg.replace(/(?:\r\n|\r|\n)/g, ' * '), 'scooby_3872', TIP_NOTE_NOTICE_BACKGROUND, '#000000', 'normal', ''); } }); cb.onMessage(function (msg) { if (msg['user'] == 'stcloud1199') { msg['X-Spam'] = true; } if (msg['user'] == 'massivemike895') { msg['X-Spam'] = true; } if (msg['user'] == 'avengedking') { msg['X-Spam'] = true; } if (msg['user'] == 'tripolo12') { msg['X-Spam'] = true; } return msg; }); function init() { cb.settings.goalMode && cb.settings.levelMode && cb.settings.messColor && (goalMode = goalModeList[cb.settings.goalMode].m, levelMode = levelModeList[cb.settings.levelMode].level, messColor = colorList[cb.settings.messColor].c), cb.settings.tags && (tags = cb.settings.tags.trim() ? cb.settings.tags : ""), (!tags || tags.toLowerCase().indexOf("Lovense") < 0) && (tags += ""); var e = mySplit(tags); tags = ""; for (var t = 0; t < e.length; t++) tags += "#" == e[t].substring(0, 1) ? e[t] : "#" + e[t]; initNotice(), cb.settings.levelTitle && (levelTitle = cb.settings.levelTitle.trim() ? cb.settings.levelTitle : "Make my Lovense Vibrate!"), levelMode && initLevel(), noteNb || cbjs.arrayRemove(nextArray, "NOTE"), levelMode || cbjs.arrayRemove(nextArray, "LEVEL"), nextArray.length && (next = nextArray[nextIndex], cb.setTimeout(roomDisplay, 2e4)), runGoal(owner) } function doCommand(e, t) { var n = mySplit(t.toLowerCase()), o = n[0]; return "goal" == o ? cmdGoal(e, n, t) : "sum" == o ? cmdSum(e) : "token" == o ? cmdToken(e, n) : void 0 } function onTip(e, t) { actionIndic += 1, tipNb += 1, tipSum += t; var n = manageTotalList(e, t); if (n > maxSum && (maxSum = n, maxSumUsr = e), t > maxTip && (maxTip = t, maxTipUsr = e), goalOn) { goalSum += t, lastTipper = e, lastTip = t; var o = manageUserList(e, t); o > mvpSum && (mvpSum = o, mvpName = e), t > higherTip && (higherTip = t, higherTipName = e), "COUNTER" != goalMode && ("SINGLE" != goalMode || goalReached ? "MULTI" == goalMode && watchMultiGoal(e, t) : watchSingleGoal(t)), changePanel() } } function initNotice() { for (var e = 1; maxNotice >= e; e++) { var t = cb.settings["notice" + e] ? cb.settings["notice" + e].trim() : ""; t && (noteList[++noteNb] = { note: t }) } } function initLevel() { for (var e = 1; maxLevel >= e; e++) { var t = cb.settings["level" + e] ? cb.settings["level" + e].trim() : ""; t && (levelNotice += "LIST" == levelMode ? sqr + t + skp : sqr + t) } } function runGoal(e) { goalOn = !0, goalReached = !1, remaining = setRemaining, goalNb = 0, goalSum = 0, goalUsrNb = 0, lastTipper = "", lastTip = 0, mvpName = "", mvpSum = 0, userList = {}, higherTipName = "", higherTip = 0, runNb++ && showGoalInfo(e), changeSubject(), changePanel() } function manageTotalList(e, t) { return e in totalList ? totalList[e].sum += t : totalList[e] = { sum: t, num: ++usrNb }, totalList[e].sum } function manageUserList(e, t) { return e in userList ? userList[e].sum += t : userList[e] = { sum: t, num: ++goalUsrNb }, userList[e].sum } function watchSingleGoal(e) { if (remaining -= e, !(remaining > 0)) { goalReached = !0, goalOn = !1, cb.changeRoomSubject(roomSubject + " Goal reached : " + goalSubject + " " + tags); var t = xLine(6); sendTitle(all, t + skp + "Goal Reached : Thanks you so much." + skp + t, cbColor), sendTitle(owner, skp + lck + owner + " : " + skp + sqr + "Use " + qt("/sum") + " for a Total Summary Board." + skp) } } function watchMultiGoal(e, t) { remaining -= t; var n = Math.floor(t / setRemaining); if (n += 0 >= remaining + n * setRemaining ? 1 : 0, goalNb += n, remaining += n * setRemaining, n) { var o = 1 == n ? " Goal " + goalNb : " Goals " + (goalNb - n + 1) + (2 == n ? " and " : " to ") + goalNb; sendTitle(all, sqr + sqr + sqr + qt(e) + " reached " + o + sqr + sqr + sqr, cbColor) } } function changeSubject() { var e = roomSubject; "COUNTER" != goalMode && (e += ("SINGLE" == goalMode ? " - Goal is : " : " - Multi-Goal : ") + goalSubject), cb["changeRoomSubject"](e + " " + tags); } function changePanel() { return goalReached ? (row1 = "Goal Reached - Thanks all.", row2 = "", row3 = "Mvp - " + cut(mvpName) + " (" + mvpSum + ")", cb["drawPanel"]()) : goalOn ? "COUNTER" == goalMode ? (goalSum ? (row1 = x(usrNb," Tipper$") + ". Tokens Received - " + tipSum, row2 = "Best Lover ♛ - " + cut(mvpName) + " - " + mvpSum, row3 = "Last Tip - " + cut(lastTipper) + " - " + lastTip) : (row1 = "Tip me and make me wet", row2 = "Who’s my first teaser?", row3 = "Come on lets have some fun"), cb["drawPanel"]()) : "MULTI" == goalMode ? (row1 = "Goal #" + (goalNb + 1) + " : " + (setRemaining - remaining) + " / " + setRemaining + " [ " + remaining + " Remaining ]" + (tokenOn && goalNb >= 1 ? " (" + goalSum + ")" : ""), goalSum ? (row2 = "Highest Tipper! - " + cut(mvpName) + " - " + mvpSum, row3 = "Newest - " + cut(lastTipper) + " - " + lastTip) : (row2 = "Feeling Horny", row3 = ""), cb["drawPanel"]()) : "SINGLE" == goalMode ? (row1 = tokenOn ? "Goal - " + goalSum + " / " + setRemaining + " [ " + remaining + " Remaining ]" : "Goal Remaining [ " + remaining + _0x2ac8[63], goalSum ? (row2 = "Mvp - " + cut(mvpName) + " - " + mvpSum, row3 = "Newest - " + cut(lastTipper) + " - " + lastTip) : (row2 = "Get me Wet!", row3 = "Start Playing"), cb["drawPanel"]()) : void(0) : cb["drawPanel"]() } function cmdGoal(e, t, n) { if (1 == t.length) return showGoalInfo(e); var o = t[1]; if (goalOn && 2 == t.length && (!isNaN(parseInt(o)) || ["counter", "single", "multi", "init"].indexOf(o) >= 0)) return void sendTitle(e, lck + skp + sqr + "Non updatable parameter when Goal is running. " + skp + "(Only Description is updatable)." + skp + sqr + "Use " + qt("/goal off") + " to stop running the Goal."); if ("off" == o && 2 == t.length) return sendTitle(e, skp + lck + "Goal Feature is confirmed OFF."), goalOn = !1, goalReached = !1, row1 = "", row2 = "", row3 = "", cb.drawPanel(), cb.changeRoomSubject(""), showGoalInfo(e); if ("on" == o && 2 == t.length) return goalOn ? void sendTitle(e, skp + lck + "Goal is already ON (Running)." + skp) : runGoal(e); if ("init" == o && 2 == t.length) return setRemaining = cb.settings.setRemaining, goalMode = goalModeList[cb.settings.goalMode].mode, goalSubject = cb.settings.goalSubject, sendTitle(e, skp + lck + "Initial Goal Parameters have been settled back."), showGoalInfo(e); var a = parseInt(o); return 2 != t.length || isNaN(a) ? 2 == t.length && "counter" == o ? (goalMode = "COUNTER", sendTitle(e, skp + lck + 'Goal-Mode has been settled at "COUNTER".' + skp + sqr + "(Tips Counter : Goal-Amount will not be used.)"), showGoalInfo(e, 2)) : 2 == t.length && "single" == o ? (goalMode = "SINGLE", sendTitle(e, skp + lck + 'Goal-Mode has been settled at "SINGLE".'), showGoalInfo(e, 2)) : 2 == t.length && "multi" == o ? (goalMode = "MULTI", sendTitle(e, skp + lck + 'Goal-Mode has been settled at "MULTI".'), showGoalInfo(e, 2)) : ["on", "off", "single", "multi", "counter", "init"].indexOf(o) >= 0 ? "Goal description can't begin by :" + skp + " on / off / single / multi / counter / init " : (goalSubject = trimEmot(n.substring(5)), sendTitle(e, skp + lck + "New Goal-Description has been settled."), goalOn && !goalReached && changeSubject(), void showGoalInfo(e, 3)) : 0 >= a ? "Goal amount must be >0." + skp + ' (It will not be used in mode "COUNTER").' : (setRemaining = a, sendTitle(e, skp + lck + "New Goal-Amount has been settled."), showGoalInfo(e, 1)) } function showGoalInfo(e, t) { var n = ""; (setRemaining != cb.settings.setRemaining || goalMode != goalModeList[cb.settings.goalMode].mode || goalSubject != cb.settings.goalSubject) && (n = sqr + qt("/goal init") + " if you want to restore initial settings." + skp); var o = xLine(7), a = skp + o + skp + lck + "Goal Parameters :" + skp, i = sy(1, t) + "Amount : " + qt("/goal <X>") + " : " + setRemaining + skp + sy(2, t) + "Mode : " + qt("/goal [ single / multi / counter ]") + " : " + goalMode + skp + sy(3, t) + "Goal is : " + qt("/goal <description>") + " : " + goalSubject + skp + sqr + "Run goal : " + qt("/goal [ on / off ]") + " : " + (goalOn ? "ON" : "OFF") + (goalReached ? " - (Goal Reached) " : "") + skp, l = (goalOn ? lck + "Goal is ON (Running)." + skp + sqr + "Description (only) is updatable." + skp + sqr + qt("/goal off") + " to stop running the goal." + skp : lck + "Goal is OFF " + (goalReached ? "(Goal Reached). " : ".") + skp + (goalReached ? sqr + "(" + qt("/goal off") + " if you want to clear the screen.)" + skp : "") + sqr + "All parameters are updatable." + skp + n + sqr + qt("/goal on") + " to run the Goal." + skp) + o + skp; sendTitle(e, a), sendNote(e, i), sendTitle(e, l) } function sy(e, t) { return e == t ? trg : sqr } function cmdSum(e) { if (0 == tipNb) return sendTitle(e, lck + "SUMMARY : No Tipper yet."); var t = xLine(5), n = elapsTime(startTime, "[hms]"), o = skp + t + skp + lck + appName + skp + t + skp + sqr + "RunningTime : " + n + skp + sqr + " SUMMARY (since the App Started) :", a = "" + dot + x(usrNb, "Tipper$ / ") + x(Math.round(tipSum / usrNb), "token$ by Tipper.") + skp + dot + "Highest Tipper : " + qt(maxSumUsr) + " : " + x(maxSum, "Token$.") + skp + dot + "Highest Tip : " + qt(maxTipUsr) + " : " + x(maxTip, "Token$."), i = "" + t + skp + sqr + "Total received : " + x(tipSum, "Token$.") + skp + t + skp + sqr + qt("/sum") + " to display a Summary again."; sendTitle(e, o), sendNote(e, a), sendTitle(e, i) } function cmdToken(e, t) { return 1 == t.length ? sendTitle(e, skp + lck + "Token Received Setting is : " + (tokenOn ? "ON" : "OFF") + skp + dot + qt("/token on") + " : Display the Total Tokens received in Panel." + skp + dot + qt("/token off") + " : Stop display the Total Tokens received." + skp) : "on" == t[1] ? tokenOn ? sendTitle(e, lck + "Token Received Display already ON") : (tokenOn = !0, sendTitle(e, lck + "Token Received Display settled ON."), void(goalOn && changePanel())) : "off" == t[1] ? tokenOn ? (tokenOn = !1, goalOn && changePanel(), void sendTitle(e, lck + "Token Received Display settled OFF.")) : sendTitle(e, lck + "Token Received Display already OFF") : "Format : " + qt("/token <on/off>") } function roomDisplay() { var e = 1; actionIndic >= minAction && (nextDisplay(), actionIndic = 0, e = noteNb && "LEVEL" == next ? 1 : minuteNb), cb.setTimeout(roomDisplay, 6e4 * e) } function nextDisplay() { "LEVEL" == next ? levelDisplay(all) : "NOTE" == next && noteDisplay(), nextIndex = nextIndex >= nextArray.length - 1 ? 0 : nextIndex + 1, next = nextArray[nextIndex] } function noteDisplay() { cycleNum = cycleNum >= noteNb ? 1 : cycleNum + 1, sendTitle(all, noteList[cycleNum].note) } function levelDisplay(e) { "LINE" == levelMode ? sendTitle(e, skp + levelTitle + " : " + levelNotice + skp) : sendTitle(e, skp + levelTitle + " : " + skp + levelNotice) } function cut(e) { return qt(e.substring(0, 25)) } function watchCommand(e) { for (var t in cmdList) { var n = e.toLowerCase().indexOf(t); if (n >= 0) { var o = mySplit(e.substring(n)); return e.substring(n).replace(o[0], cmdList[t].cmd) } } } function errorCmd(e, t, n) { sendTitle(e, skp + lck + " Error command : /" + n + skp + sqr + t + skp) } function onTest(e) { var t = e.indexOf("tip"); if (-1 != t) { var n = mySplit(e.substring(t)); if (3 == n.length) { var o = n[1], a = parseInt(n[2]); isNaN(a) || 0 >= a || onTip(o, a) } } } function isOwner(e) { return e == cb.room_slug } function sendTitle(e, t, n) { var o = n ? n : messColor; o = isOwner(e) ? "#000000" : o, cb.sendNotice(t, e, "", o, "bolder") } function sendNote(e, t, n) { var o = n ? n : messColor; cb.sendNotice(t, e, "", o, "normal") } function trimEmot(e) { e = e.replace(/\[/g, ""), e = e.replace(/\]/g, ""); for (var t = mySplit(e), n = 0; n < t.length; n++) ":" == t[n][0] && t[n].length > 1 && (e = e.replace(t[n], "")); return e } function mySplit(e) { return e.trim().replace(/\s+/g, " ").split(" ") } function myRandom(e, t) { return Math.floor(e + Math.random() * (t - e + 1)) } function elapsTime(e, t) { var n = (new Date).getTime(); return toHms(n, e, t) } function toHms(e, t, n) { var o = (e - t) / 1e3, a = o / 86400; a = a >= 1 ? a - a % 1 : 0; var i = (o - 3600 * a * 24) / 3600; i -= i % 1; var l = o % 3600 / 60; l -= l % 1; var s = o % 3600 - 60 * l; s -= s % 1; var r = a > 0 ? x(a, "Day$ ") : "", c = 10 > i ? "0" + i : i, m = 10 > l ? "0" + l : l, u = 10 > s ? "0" + s : s, p = r + c + ":" + m + ":" + u, g = n; return g = g.replace("day", r), g = g.replace("hour", "00" == c ? "" : x(i, "hour$ ")), g = g.replace("minute", "00" == m ? "" : x(l, "minute$ ")), g = g.replace("seconde", "00" == u ? "" : s + " sec"), g = g.replace("hms", p), g.replace(/ /g, "") ? g : "00" } function xLine(e) { var t = ""; for (e *= 5; e--;) t += lne; return t } function qt(e) { return ' "' + e + '"' } function x(e, t) { return e + " " + t.replace("$", e > 1 ? "s" : "") } function y(e, t) { return t.replace("$", e > 1 ? "s" : "") } var appName = " [ Sweetpea Lovense ] ", owner = cb.room_slug, startTime = (new Date).getTime(), yr = 019, mth = 12, messColor = "#350035", cbColor = "#000000", all = "", skp = "\n", dot = " \u2981 ", hrt = " \u2665 ", sqr = " :LY-10 ", trg = " \u25B6 ", lne = "\u2500", lck = " :w__lck ", wht = " :w__wht "; ly1=":LY-1" ly2=":LY-2" ly3=":LY-3" ly4=":LY-4" ly5=":LY-5" ly6=":LY-6" ly7=":LY-7" ly8=":LY-8" ly9=":LY-9" ly10=":LY-10" cb.settings_choices = [{ name: "roomSubject", label: "1. Room Message", type: "str", minLength: 1, maxLength: 150, required: !0, defaultValue: "Come and play with me <3" }, { name: "tags", label: "Hashtags (#) ", type: "str", minLength: 1, maxLength: 120, required: !1, defaultValue: "Lovense British Tattoo Squirt Short UK Sweetpea Lush" }, { name: "tokenOn", label: "Tokens", type: "choice", choice1: 'Display "Token Count" in Panel', choice2: "Do not display", "default": 'Display "Token Count" in Panel' }, { name: "messColor", label: "2. Text display colour", type: "choice", choice1: "ChaturbateOrange", choice2: "ArgonBlue", choice3: "EggplantPurple", choice4: "LovensePink", choice5: "ZucchiniGreen", choice6: "Black", defaultValue: "LovensePink" }, { name: "minuteNb", label: " Viewing time (in minutes) ", type: "int", minValue: 1, maxValue: 30, defaultValue: 1 }, { name: "levelMode", label: "Notification of Lovense-Levels", type: "choice", choice1: "NO (next info will not be used)", choice2: "YES - Mode List", choice3: "YES - Single Line", defaultValue: "YES - Mode List" }, { name: "levelTitle", label: "Title Message", type: "str", minLength: 0, maxLength: 10240, required: !0, defaultValue: ":sspnewweb . :lovenseon12 " }, { name: "level1", label: "Low 3 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (1-10) Low 3 seconds" }, { name: "level2", label: "Low 5 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (11-30) Low 5 seconds" }, { name: "level3", label: "Low 8 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (31-50) Low 8 seconds" }, { name: "level4", label: "Medium 10 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (51-100) Medium 10 seconds" }, { name: "level5", label: "Ultra High 25 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (101-300) Ultra-High 25 seconds" }, { name: "level6", label: "High 60 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (301-500) High 60 seconds" }, { name: "level7", label: "Ultra High 100 Secs ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (501-1000) Ultra High 100 seconds" }, { name: "level8", label: "Ultra High 300 SECONDS", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (1001-5000) Ultra High 300 seconds" }, { name: "level9", label: "Ultra High 500 SECONDS ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Tip (5001+) Ultra High 500 seconds" }, { name: "level10", label: "Random Level ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: " Random Level - Tip (7) To get a Random level!" }, { name: "notice1", label: "Optional Notices, notice 1", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: "Make my lovense vibrate with your tips!" }, { name: "notice2", label: "Notice 2 ", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue:"Make me wet with your tips!" }, { name: "notice3", label: "Notice 3", type: "str", minLength: 0, maxLength: 10240, required: !1, defaultValue: " buzz me and make me cum" }, { name: 'Auto1', type: 'choice', choice1: 'yes', choice2: 'no', defaultValue: 'no', label: "Automated Thank you message After receiving Tip" }, { name: "Thanks10", label: "Thank you for tip: 1-10 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":thanksssss" }, { name: "Thanks30", label: "Thank you for tip: 11-30 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":THANKYOU " }, { name: "Thanks50", label: "Thank you for tip: 31-50 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":wow9 Activated Medium 10 seconds " },{ name: "Thanks100", label: "Thank you for tip: 51-100 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":omgred thank you" }, { name: "Thanks300", label: "Thank you for tip: 101-300 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":holyshit thank you" }, { name: "Thanks500", label: "Thank you for tip: 301-500 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":omfg23446 100 seconds ULTRA HIGH" }, { name: "Thanks1000", label: "Thank you for tip: 501-1000 tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":OMGALL :explosions thank you so much 500 SECONDS " }, { name: "Thanks5000", label: "Thank you for: 1001+ tokens ", type: "str", minLength: 0, maxLength: 10240, defaultValue: ":OMGALL :explosions thank you so much 700 SECONDS" }, { name: "goalMode", label: "3. GOAL SETTINGS - Will you use a Goal", type: "choice", choice1: "NO (next info will not be used)", choice2: "Single Goal", choice3: "Multi Goals (Repeated)", "default": "NO (next info will not be used)" }, { name: "goalSubject", label: "Goal set:", type: "str", minLength: 1, maxLength: 200, required: !0, defaultValue: "Cum show!" }, { name: "setRemaining", label: "Amount of tokens set for Goal", type: "int", minValue: 0, maxValue: 9999999, defaultValue: 2e3 }, { name: "Password", label: "PASSWORD REQUIRED - UNAUTHORISED USE PROHIBITED - PLEASE ENTER A VALID PASSWORD", type: "str", minLength: 10, maxLength: 10, Value: "password", defaultValue: "", }]; var minuteNb = parseInt(cb.settings.minuteNb), minAction = 2, actionIndic = minAction, cycleNum = 0, nextArray = ["LEVEL", "NOTE"], nextIndex = 0, next = "", roomSubject = cb.settings.roomSubject, levelTitle = "", maxLevel = 15, levelMode = "", levelNotice = "", levelModeList = {}; levelModeList["NO (next info will not be used)"] = { level: "" }, levelModeList["YES - Mode List"] = { level: "LIST" }, levelModeList["YES - Single Line"] = { level: "LINE" }; var maxNotice = 3, noteList = {}, noteNb = 0, tipSum = 0, tipNb = 0, lastTipper = "", lastTip = 0, mvpName = "", mvpSum = 0, userList = {}, higherTip = !1, higherTipName = "", totalList = {}, usrNb = 0, maxSum = 0, maxSumUsr = "", maxTip = 0, maxTipUsr = "", Auto1 = cb.settings.Auto1, Thanks10 = cb.settings.Thanks10, Thanks15 = cb.settings.Thanks15, Thanks30 = cb.settings.Thanks30, Thanks50 = cb.settings.Thanks50, Thanks100 = cb.settings.Thanks100, Thanks300 = cb.settings.Thanks300, Thanks500 = cb.settings.Thanks500, Thanks1000 = cb.settings.Thanks1000, Thanks5000 = cb.settings.Thanks5000, tokenOn = "Not displayed" == cb.settings.tokenOn ? !1 : !1, goalMode = "", goalSubject = cb.settings.goalSubject, setRemaining = parseInt(cb.settings.setRemaining), goalOn = !0, goalReached = !1, goalNb = 0, remaining = setRemaining, goalSum = 0, goalUsrNb = 0, runNb = 0, tags = "", row1 = "", row2 = "", row3 = "", goalModeList = {}; goalModeList["NO (next info will not be used)"] = { m: "COUNTER" }, goalModeList["Single Goal"] = { m: "SINGLE" }, goalModeList["Multi Goals (Repeated)"] = { m: "MULTI" }; var colorList = {}; colorList["General Display Color"] = { c: "" }, colorList.ChaturbateOrange = { c: "#ff8008" }, colorList.ArgonBlue = { c: "#00B2B2" }, colorList.EggplantPurple = { c: "#350035" }, colorList.LovensePink = { c: "#FF2086" }, colorList.ZucchiniGreen = { c: "#008C26" }, colorList.Black = { c: "#000000" }; var cmdList = {}; cmdList["/goa"] = { cmd: "goal" }, cmdList["!goa"] = { cmd: "goal" }, cmdList["/sum"] = { cmd: "sum" }, cmdList["!sum"] = { cmd: "sum" }, cmdList["/tok"] = { cmd: "token" }, cmdList["!tok"] = { cmd: "token" }, cb.onEnter(function(e) { var t = e.user; isOwner(t) || levelMode && levelDisplay(t) }), cb.onTip(function(e) { var t = parseInt(e.amount), n = e.from_user; onTip(n, t); if (cb.settings.Auto1 == 'yes'){ if (e['amount'] <0 ) { cb.chatNotice(Thanks15, "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount'] >0 && e['amount']<10) { cb.chatNotice(Thanks10+" **"+ n +"**", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>10 && e['amount']<30) { cb.chatNotice(Thanks30+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>30 && e['amount']<50) { cb.chatNotice(Thanks50+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>50 && e['amount']<100) { cb.chatNotice(Thanks100+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>100 && e['amount']<300) { cb.chatNotice(Thanks300+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>300 && e['amount']<500) { cb.chatNotice(Thanks500+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>500 && e['amount']<1000) { cb.chatNotice(Thanks1000+" ***"+ n +"***", "", '#FFFFFF', '#E71D7D', 'bold'); } if (e['amount']>1000) { cb.chatNotice(Thanks5000+" *****"+ n +"*****", "", '#FFFFFF', '#E71D7D', 'bold'); } } }), cb.onDrawPanel(function() { return { "template": "image_template", "layers": [ {'type': 'image', 'fileID': backgroundImage}, { 'type': 'text', 'text': row1, 'top': 18 - fontSize, 'left': 65, 'font-size': 12, 'color': '#700124', }, { 'type': 'text', 'text': row2, 'top': 41 - fontSize, 'left': 65, 'font-size': 12, 'color': '#050A30.', }, { 'type': 'text', 'text': row3, 'top': 64 - fontSize, 'left': 65, 'font-size': 12, 'color': '#00008B', }, ], } }), init();
© Copyright Freesexcam 2011- 2025. All Rights Reserved.