Customizable rice and themes for 4chan X.
// Generated by Grunt // ==UserScript== // @name OneeChan // @version 5.6.1 // @namespace OneeChan // @description Customizable rice and themes for 4chan X. // @minGMVer 1.15 // @minFFVer 26 // @license GPL-3.0; https://github.com/nebukazar/OneeChan/blob/master/LICENSE // @match *://boards.4chan.org/* // @grant GM_getValue // @grant GM_setValue // @grant GM_deleteValue // @grant GM_openInTab // @grant GM_listValues // @run-at document-start // @icon ###33fJZIZJp4dQqhPbjjB75sU0N85ieLiX4z37yOfTOHYQMxqjp3iSWjOOpVtkvCKu9AhZYfqDiW+tefF/PDYyOYAV1996iWWGqwcHy8KXSgUsy6kAaK6LYRmCQjFPSajJ5J+QHsoWMslkhtjTuRHbDtLWOp+FC64mn0+RTg/R1jyXXW9tIKj3UG9WEXDCHMu8SV19K/H6hkuBxyd1occee4xQuP4S18v6Urrlh2qnLeBLxYJpcYZTGeKRIFKq85H/9J4mQEDJLbD/4Fb2dG7A9VwaGqYTiVQjhEZeljhc6GPQcPF1wYn+o2jKXPXhm+6wN2zYMDGAVatWYZvOtFy+r7PsyxJjVID6UjG7rZpQVZSwYxJ0LJQ6m/hqRAFqEhcrx1Qml2Dv25s4fHQXpmFXaFYTAnXqOqEzMNAzralhanDp0qVnDeLAcOLE9jPiusLhU5rqaWysx9QFrfXxMWwyoWmFNg6kEAJNM8Zd292zH4BIuAalFEqpkRhUCCHIZTMkkj03npWFCsXMYCad2iTEOGUCimAgQH1zPQHHYMHMJnwpzzP3KkCgafp4ITSdo127icQaaGlbQDAUQ4y6zvNK+L515aQA1q9fD6R3mpaZA1nxYF8qssUi+YKLUpJofQ3Tmuu4fOEcXG/yEkIpqIk6jFaG77uYhjUuG5+yTL6QQfouQtOprpmKZdqn5fA8DN28cFIAV111FS1Tgy9Go8FNobDj+r6L9EvMn1rNr7/9ab7z9x+kZyCJZposu7qDUDDANZfMpqUugm0JSm6Rkuvi+R5S+fjSJxw0kVJW4kAqRW1NK77vjqHn0aillCMiK0b7n5Q+lmXNmAhARR0//tGa3HXXXX9EJdJfsE3zYYBQNMas981nzqIF7Ny5D8/1uOSyi+g/1sNdK69GSolS8MqON+nqS9A7mGXngRMIYRK0LYQ47QZKSuLxBvoHuiqBLKVfsUjZ90e55ahzpRSuJ42zAgB44YXnVcfiy19Glh4rFtxVpmPRdsEMdF2DcARQhGJRQhdGaZjWQj6bp5TLE6qLY0lFPp3Blz7HTw7TM5Ag4Bxi75EeUjl3VPZVE5KslD5jeGskU5+m5YmJewyA+++/n9WrVx8APnFZx9Jvmqbzb1JKPM+jpbl2jMkDkTCBSBiApplTEUIgpaS/qwfnwBGmtjTQ0T4LXRO8eeAYf3rlIP1DvZNmcF+6GILTrjOKJMrsxTsDWL16deV82oyLl9bUhRkYGmbnm2+zYtmVeL4/7ga6piE0DW8kqOunNFM/pZliLo9bcskMJ7FDIY4NOfx+7bqK+0xE1RVSVBLfLaIbZqXok1L1vSMAgC/ccz8n+5K1vieuaKoXbH5jLwEDpJqYNl/c8DpS+ixe1E4sFqlYyQ4GsAIO4aoorXNn8OMn9uJ5LtooVYoxTKTR1BCh52QOwyviK4mBQKHQNA0hVM87VqMA//3T1UTCsYt27349etdnPsLNK67gg8uuQMrxiUt6kq7D3fznQ7/jd394hmNdPZimgenYDCWS+CMWO36sm4OHugmHY2PpdhQCxzb5zUP3UROzQPnl0puy0jRdp1gq7nlHAM899xwA6XT2S+3zmrF7Fal0FiYwu/IVMuvzqRtu4hf/9AAX1s9m3/YePnPHN7n91q+w9s/r0YWOrmusfWEXjhMaX36M+m6ZBrZlsfCC5rIFLQfXdUfc1EA35N53dKHly5cDcOjw3pv+4Y7lHDrRzcypMyYsG1RJIfOSXLpI0DNpr50CCDq+9FWMsMlgMYHM+wjbYNNrR9E0ifQnT34aimImQyBgoVAYhkWpVByxgEZVVWD7ObnQsmXLLlAKZs1sJTw7drauHHyFny0hcy5uokhpIIs7lMfPuLg5H1mUDA8mKfkOdTFj0jgCMA2Bbepl+lflwzAtlFKYpqXcYnDvOQHIZf2FjmO+rWmCutrqs1VroIMesBCOhWZqCF0HAdL1aKwtF2aJ4TylYoGm2ugE1dFIlpaKObNaiTU20Ns3OJK5fWwrgFIKJxAa8GTBPycAbslrtCxzXXfPALZlTl7vWxqaraEFdIyQgVntYNU6GFUOesRGWAKhC7JFF0vLEAoEx3R5Y57pely//DJ+/ss/8rcdh1AoPN/DtoMoJXECwZ7+gYOlcwKgaRpK+Btfe6MTDGNyALpAD5sYUQMjbmLELcwaGzNuY0QN9ICBFtBwfUlbjY3nq5Ee43Q85XMFcvk8M2c0smfPEX6y5i8Yhl7JC44TQiAwLfPIunVPeucEwJP5Y1PaWg8/99Lf8m4+f/auyxQYMQMrbmHVWpg1Fma1iRmzMGImmq2DENTETCzbxLYDZSZSimBQ49k//QeHdv4f1bEqnnl2G5oQ5UysFEr6WFYAJxDEMLX###NhnIoDAfMFhOuEQvaeR//4wiW3fOx6kUplSCTTtLU2js+kQiAcge5op5U7mt8dg1jYIotFKFxDS7XithWXsXhxO8HqKj52+7c5enQA3dAnaEMUkWgN2Uyi85wBbNq0Obtp0+YssKS+7q6PA4/FYhEikRC9fQO0NNUjJ+vGJqgSauMhQvEYZhGWL27kyvmL+OvWTvZ3nWTzjkMc78+OE/7UzYpunlhVLZnc0eOT0+8E6+677y5PKj72ucd3de7v1bTy7Ke5qW5y4SdZ8aowF116IQtaIyxdOAVNN/jlM9v57bodHD2ZQSmF57uVVvLUAYpisYDjBFFaV9d5AVizZk3l/L4HfnTR4FDSBThP2RGaRrFQxOsdoJgvIpUikc0hhEZ5QFEWtJzg1BkHFItZPN/nt49/OnFeAE6tr993LxtfWd/7xNMv32VMaOazCC+ge/9htj23kdRQAqGVK/pcLs+06dMIhkJndMtiXJtZLOZxS0X+/OSmSac4Z5Vq02tbAXh63Us7PBX97tVXXHhWoXXDwC0UOXHgKLte3cbA8RMk/AgFo46k55Cxp6MiM1h27YfYsX0LqVRqpHfxJmz2hYBYtBZ088FNG7fnzymIJ1ubt+zn6XWv8OEPXVmJVqUUvpRIX1LM5dm/s5MTR45jWTbBQICT+gVII0IsVkVI1ys1VVV1mFQmWWE007IpFPI4duCM4UC5mTpycDgKDL1rAEop/eqrVvK1b/+MRx57kelTG0mmc3RMr6M+FiFaFaWUL+D5Hr4ZpRCeiRuIE7NDlYl0+YCLl8yguTWOYaqRmFJl9xGMKxp938c0LLq7ErF3FQOj/NH3PQ8hBDvePMRjf36Ftc9v4dlNnVRFwghfooRGv70Is3kpgXgbph0aM3lQSjFnXhPNrXEAYtEonl9CoZBKYhomUvmoMR9JPp+msW7OivcEACAYdMZMDO6558tcfeOnyJdKaAJOFsJUxRvQhBqnSaVgzrxm5sxtruw1NjaOmS0JoVFyi2ckSkEyNQDKuu49A9B0bd+psYem6fT1dSM0jZIPx5ICu24+ui7GtIynKs1p0+vGCA/Q2tZCLpcdw/1ClHvr0XuJZD+mYc/8yI132O8JgO95T5Y1W05qqWSSeFUtPcN57OZLCQRCEzY+jc1VtC+aMm7/oytv4OWNT2OURxGAwjIsPK80Jh8o5ZNIDkzTtdEu8C4ARKLB3+i6hhDg+5JDhw+QSiVJqmqOHd0/ro5QStHQWMWSS2dN0g9JmpqaePmVZ+h4/yIGB4fIZnN4nofvy5GarmyVROKkkLJw27mO8cetBx54gGfXvuT09w93Gro9/YablvHNb32DVzceIJ/PUldbXxmrnBI+Ggty5dXz0DQ###iLxSKHDx9m3rx5Y1/4uSVe3fwae3a/xe7dnRzv6iGbzZNJZyjkXaZPn3f0yb88PO2cAKxbt44VK8YFfvDee7/4i2uWLbv14ytv5uiR47z4/E5q4jUYxtjGJxx2uOq6BSOuJ9m+bQeBYIBsLsvcuXOIRCKTzodGr2KxiKHr/OQna3jqic1UxdSUx596tOuTn7yb3/9+zcQArr3ulnbQuPsfVy6YN3fupaZpLgqGgkv2btkdOvL6IbY8tZm5H5hP27VLyCYLVFXVYI+8ihKi7GJNrWFSiQx9fcMUCgWmTG0kHDG5ZMmF51yKnDhxgpaWFj5/11dZv3EbwWAAyzJ9x7K+tXHDH354y6338ugjD5UT2Q033ckzT/+aK5eu2jo0nF7s+z7DQxna29sB+N1P/5dtv3qVZCmJ7dhkdicYnNpPrKUe2wpUXkR0dx+lUCyQzbUQcILk8wXa39fCxZe877zqKM/zyGazfOX+77BlayehUPBU66m7rveDa669JfXoIw/9DED77OfuOyX899PZ/GLPc+lYMo/LL18MwBvrt7Dh4efpzfXRFG7AUx4SyZan1iKVJJ1OkMmkyGRSNDVPIRSMEgoL5l1Yx213Lj8v4VOpBOs3bGLhRSv4yMp7eOGlN9D08TyTTGfWfObOL08FMH71ywe587Nfbti95+A/+16R3Ttf4PvfvYdMJgNA77EeDF9nVtV0ujO9OIbN0dRxaq04h17fwcXXX0sulyWVHkboBf7ujmUEg/Z5/m9Ckk6nuX7FnWSzBWzbASFQ0p9kjqrYd/DYI8DlBsDevUc2Sgn79m7i1BubBx98EIC33trLUHEYX5METAcNjYZgHQeGDjHluEm+kKd94XRmzrkCxzHf1R8/Xn31Verrm3BLHo4TIJnopa/3AKViDqEJ2qYsJBypGVOlFoqlRZddsbLGuOqaT74/mcrOTAx1UyqVK9abb7759JR63gy2uJsJRgMM5ofRhKA73UdQOlxz+7Vcc+NFRCMR3u0aHh7mZH+Ke774PdLpIXpOvEWxkB1zzYF9rzH7gssJR6ordCylCoQjoTs0z/f/RQhNO9l38LSPJZOV84/f/gn0kEFPuo/B3DC9mX40oVE3q4GP3rKSrVu2vGvhU8k8D//8j9z/1e/R+eZfOXLwb+OEP7X2v72ZUqkwZi+Tyf3r/wPNYcrLkd3xFwAAAABJRU5ErkJggg== // ==/UserScript== (function() { var defaultConfig = { ":: Main Rice": ["header", ""], "Left Margin": [ 5, "Change the size of the left margin.", [{ name: "Large", value: 65 }, { name: "Medium", value: 25 }, { name: "Small", value: 5 }, { name: "None", value: 0 }, { name: "Custom", value: 999 }], true ], "Custom Left Margin": [ 0, "Left margin custom width (pixels).", "Left Margin", 999, true ], "Right Margin": [ 5, "Change the size of the right margin.", [{ name: "Large", value: 65 }, { name: "Medium", value: 25 }, { name: "Small", value: 5 }, { name: "None", value: 0 }, { name: "Custom", value: 999 }], true ], "Custom Right Margin": [ 0, "Right margin custom width (pixels).", "Right Margin", 999, true ], "Style Thread Stats": [false, "Makes thread stats stand out more. Disable 'Updater and Stats in Header' if using ccd0 4chan X."], "Rounded Corners": [false, "Styles replies, menus and Quick Reply to have subtly rounded corners."], "Underline All Links": [false, "Underlines all links in the page."], "Show Banner": [false, "Toggle visibility of banner.", null, true], "Reduce Banner Opacity": [false, "Reduce opacity of the banner for easier viewing.", "Show Banner", true, true], "Show Board Banners": [false, "Toggle visibility of board banners."], "Show Board Name": [true, "Toggle visibility of the board name."], "Show Reply to Thread Button": [false, "Toggle visibility of the Start a Thread / Reply to Thread button."], "Show Checkboxes": [false, "Hides checkboxes and deleteform to be replaced by 4chan X menus. Refresh to apply."], "Show Blotter": [true, "Toggle visibility of the 4chan news blotter."], "Show 4chan Ads": [false, "Opts into 4chan\'s banner ads.", null, true], "Show Top Ad": [true, "Show the top 4chan banner ad.", "Show 4chan Ads", true, true], "Show Middle Ad": [true, "Show the middle 4chan banner ad.", "Show 4chan Ads", true, true], "Show Bottom Ad": [true, "Show the bottom 4chan banner ad.", "Show 4chan Ads", true, true], "Reduce Ad Opacity": [false, "Reduce the opacity of ads until hover for easier viewing.", "Show 4chan Ads", true, true], "Show Navigation Links": [true, "Toggle visibility of the navigation links at the top and bottom of the threads.", null, true], "Show Top Links": [true, "Toggle visibility of the top navigation links.", "Show Navigation Links", true, true], "Show Bottom Links": [true, "Toggle visibility of the bottom navigation links.", "Show Navigation Links", true, true], "Show Previous/Next buttons": [false, "Shows previous / next buttons in paged navigation mode."], ":: Sidebar": ["header", ""], "Sidebar Position": [ 1, "Change the position of the sidebar or disable it altogether.", [{ name: "Right", value: 1 }, { name: "Left", value: 2 }, { name: "Disabled", value: 3 }], true ], "Disable In Catalog View": [false, "Disables the sidebar when viewing the catalog. Native catalog only!"], "SS-like Sidebar": [false, "Darkens the sidebar and adds a border like 4chan Style Script."], "Minimal Sidebar": [true, "Shrinks the sidebar and disables the banner."], ":: Quick Reply": ["header", ""], "Autohide Style": [ 1, "Changes how the quick reply is hidden. Enable Autohide QR in 4chan X.", [{ name: "Normal", value: 1 }, { name: "Vertical Tabbed", value: 2 }, { name: "Fade", value: 3 }] ], "Transparent QR": [false, "Reduces opacity of the QR box."], "Remove Background": [false, "Removes the QR background."], "Remove Controls": [false, "Removes the QR controls and checkbox."], "Expanding Form Inputs": [true, "Makes certain form elements expand on focus."], "Force QR to Sidebar Size": [false, "QR will no longer extend past the sidebar size."], ":: Mascots": ["header", ""], "Hide Mascots in Catalog": [true, "Hides the mascot when viewing the catalog."], "Mascots Overlap Posts": [false, "Mascots will render above posts and threads."], "Reduce Mascot Opacity": [true, "Reduces opacity of mascots until hover. Warning: Overrides pointer events."], "Grayscale Mascots": [false, "Desaturates mascots."], ":: Replies": ["header", ""], "Fit Width": [true, "Replies stretch to the width of the page."], "Show Reply Header": [true, "Shows reply header background and line border."], "Show Post Info On Hover": [false, "Shows post number and file info on hover only."], "Show File Info": [true, "Hides filename, dimensions and size info."], "Underline QuoteLinks": [false, "Underlines quotelinks only."], "Indent OP": [false, "Indents the OP instead of touching the screen."], "Allow Wrapping Around OP": [false, "Allow for replies to wrap around OP instead of being forced onto their own line."], "OP Background": [false, "Give OP a background similar to a reply."], "Recolor Even Replies": [false, "Makes every other post a darker color. If Quote Threading is enabled darkens every root reply."], "Reduce Thumbnail Opacity": [false, "Reduces opacity of thumbnails."], "Backlink Icons": [true, "Use icons for backlinks instead of text."], "Backlinks on Bottom": [false, "Move backlinks to the bottom right of replies."], "Borders": [ 2, "Changes which sides of replies have borders.", [{ name: "Normal (4chan default)", value: 1 }, { name: "On all sides", value: 2 }, { name: "None", value: 3 }] ], "Margin Between Replies": ['', "Change size of spacing in between replies.", [{ name: "Very Large", value: 15 }, { name: "Large", value: 8 }, { name: "Normal (4chan default)", value: '' }, { name: "Minimal", value: -2 }, { name: "None", value: -4 }, { name: "Overlapping Borders", value: -5 }]], "Post Message Margin": [ 2, "Change size of margin around post message.", [{ name: "Small", value: 1 }, { name: "Normal", value: 2 }, { name: "Large", value: 3 }] ], ":: Catalog": ["header", ""], "Justified Text": [true, "Justifies the teaser text of every thread to be more uniform."], "Show Background": [true, "Threads receive a matching background."], "Unified Thumbnail Size": [false, "Makes all thumbnails the same size regardless of aspect ratio."], ":: 4chan X Header": ["header", ""], "Show Header Background Gradient": [true, "Gives the header bar a gradient background."], "Show Header Shadow": [true, "Gives the header a drop shadow."], "Highlight Current Board": [true, "Gives the current board link a bottom highlight border."], ":: Highlighting": ["header", ""], "Highlight (OP) quotes": [false, "Highlights all (OP) mentions."], "Highlight (You) quotes": [false, "Highlights all posts quoting (You)"], "Post Decoration Style": [ 0, "Changes the highlight decoration of posts.", [{ name: "None", value: 0 }, { name: "Border", value: 1 }, { name: "Outline", value: 2 }, { name: "Separator", value: 3 }] ], "Post Decoration Width": [ 1, "Changes decoration width of highlighted posts.", [{ name: "Large", value: 6 }, { name: "Medium", value: 3 }, { name: "Small", value: 1 }, { name: "Custom", value: 999 }], true ], "Custom Decoration Width": [ 0, "Enter a custom width for the decoration (pixels).", "Post Decoration Width", 999, true ], "Post Highlight Style": [ "solid", "Changes style of post highlight.", [{ name: "Dashed", value: "dashed" }, { name: "Dotted", value: "dotted" }, { name: "Double", value: "double" }, { name: "Solid", value: "solid" }] ], ":: Fonts": ["header", ""], "Font Family": [ "sans-serif", "Set the default font family.", [{ name: "Default", value: "sans-serif" }, { name: "Monospace", value: "monospace" }, { name: "Ubuntu", value: "Ubuntu" }, { name: "Consolas", value: "Consolas" }, { name: "Droid Sans", value: "Droid Sans" }, { name: "Segoe UI", value: "Segoe UI" }, { name: "Calibri", value: "Calibri" }, { name: "Arial", value: "Arial" }, { name: "Lucida Grande", value: "Lucida Grande" }, { name: "Helvetica", value: "Helvetica" }] ], "Font Size": [13, "Set the general size of text (Pixels). Min: 10px, Max: 18px"], "Backlink Font Size": [9, "Set the font size of backlinks."], "Bitmap Font": [false, "Check this if you are using a bitmap font."], ":: Compatibility": ["header", ""], "Version Fix": [ 1, "Applies CSS fixes for different forks. Default is for seaweed/ccd0 forks. Make sure you enable QR and Persistent QR for maximum compatibility.", [{ name: "Default", value: 1 }, { name: "loadletter", value: 3 }], true ], "Themes": [], "Hidden Themes": [], "Selected Theme": 13, "NSFW Theme": 12, "Selected Mascots": [54], "Mascots": [], "Hidden Mascots": [] }, MAX_FONT_SIZE = 18, MIN_FONT_SIZE = 10, NAME = "OneeChan", NAMESPACE = "OneeChan.", VERSION = "5.6.1", CHANGELOG = "https://github.com/nebukazar/OneeChan/blob/master/CHANGELOG.md", inputImages = "iVBORw0KGgoAAAANSUhEUgAAAAgAAAAgCAYAAAAv8DnQAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAP9JREFUOMvV0CFLQ2EYxfHfrtdiURgbmCxOmFPBJgZZ0CQD0Q+goFkwabWIyWIWFgwmy7Qp7DPI3GD7ACZlYLNcy31ljG0aDHrSy3N43nOef6ZULBiifczEQ8wV7OAtGmBO4wgfOI2whsXUnMAJ8rhCJ8IxDpHDHpZwixqM5XPZBBtYxioauEgjRLjBI2bRxTneQ6EYCS4xiTu89DbONJrtP88hwnV64hm28YRqyPsFDkmSGKUYFubnsqignM7rqDWa7dcAqoLdnsXwrgZQ5QG/l8MVIxX1ZPar/lUyUOsv+aMzv+0Qw3OrM4VNrKfzB9yXioVu6LDVx+EA4/+Gwycw/Uz36O07WwAAAABJRU5ErkJggg==", fontListSWF = "https://ahod###ka.github.com/FontList.swf", themeInputs = [{ dName: "Reply Background", name: "mainColor", property: "background-color" }, { dName: "Reply Border", name: "brderColor", property: "border-color" }, { dName: "Input Background", name: "inputColor", property: "background-color" }, { dName: "Input Border", name: "inputbColor", property: "border-color" }, { dName: "Header Background", name: "headerBGColor", property: "background-color" }, { dName: "Header Text", name: "headerColor", property: "color" }, { dName: "Board Title", name: "boardColor", property: "color" }, { dName: "Body Background", name: "bgColor", property: "background-color" }, { dName: "Text", name: "textColor", property: "color" }, { dName: "Backlink", name: "blinkColor", property: "color" }, { dName: "Header Link", name: "headerLColor", property: "color" }, { dName: "Header Link Hover", name: "headerLHColor", property: "color" }, { dName: "Link", name: "linkColor", property: "color" }, { dName: "Link Hover", name: "linkHColor", property: "color" }, { dName: "Quotelinks", name: "qlColor", property: "color" }, { dName: "Name", name: "nameColor", property: "color" }, { dName: "Tripcode", name: "tripColor", property: "color" }, { dName: "Subject", name: "titleColor", property: "color" }, { dName: "Greentext", name: "quoteColor", property: "color" }, { dName: "Unread Line", name: "unreadColor", property: "color" }, { dName: "Highlighting", name: "postHLColor", property: "color" }, { dName: "Posts Quoting You", name: "quotesYouHLColor", property: "color" }, { dName: "Own Posts", name: "ownPostHLColor", property: "color" }, { dName: "Highlighted Threads", name: "threadHLColor", property: "color" }, { dName: "Highlighted Reply BG", name: "replybgHLColor", property: "background" }, { dName: "Reply Selection", name: "replyslctColor", property: "outline" }], $lib, $SS; if (!Array.isArray) Array.isArray = function(arg) { return Object.prototype.toString.call(arg) === "[object Array]"; }; Number.prototype.toHexStr = function() { var s = "", v; for (var i = 7; i >= 0; i--) { v = (this >>> (i * 4)) & 0xf; s += v.toString(16); } return s; }; /* STYLE SCRIPT LIBRARY */ /* More or less based off jQuery */ $lib = window.$ = function(selector, root) { return this instanceof $lib ? this.init(selector, root) : new $lib(selector, root); }; /* From 4chan X, unchainable */ /* https://github.com/seaweedchan/4chan-x/blob/master/LICENSE */ /* https://github.com/ccd0/4chan-x/blob/master/LICENSE */ $.asap = function(test, cb) { if (test()) { return cb(); } else { return setTimeout($.asap, 25, test, cb); } }; $lib.prototype = { constructor: $lib, elems: [], length: function() { return this.elems.length; }, /* CONSTRUCTOR */ init: function(selector, root) { if (selector == null || selector == undefined) return this; if (selector.constructor === $lib) return selector; else if (typeof selector === "string") { var root = root || document; var tagCheck = /^<(\w+)([^>]*)>(.*)$/.exec(selector); // No closing tag for root node. if (root.constructor === $lib) root = root.get(); if (tagCheck) { var tag = document.createElement(tagCheck[1]); if (tagCheck[2]) { var attribs, atRegEx = /(\w+)=((?:"(?:[^"]+)"|'(?:[^']+)'|(?:\w+)))/g; while ((attribs = atRegEx.exec(tagCheck[2])) != null) { var val = attribs[2]; if ((val[0] == '"' || val[0] === "'") && val[0] == val[val.length - 1]) val = val.substr(1, val.length - 2) tag.setAttribute(attribs[1], val); } } tag.innerHTML = tagCheck[3]; this.elems = [tag]; } else if (/^#[\w-]+$/.test(selector) && root == document) { var el; if ((el = document.getElementById(selector.substr(1))) != null) this.elems = [el]; } else { var r###lts = root.querySelectorAll(selector); this.elems = Array.prototype.slice.call(r###lts); } } else if (selector.nodeType) this.elems = [selector]; else if (Array.isArray(selector)) this.elems = Array.prototype.slice.call(selector); return this; }, /* DOM NODE RETRIEVAL */ clone: function() { var ret = []; this.each(function() { ret.push(this.cloneNode(true)); }); return new $lib(ret); }, elements: function() { if (!this.hasSingleEl()) return this; this.elems = Array.prototype.slice.call(this.elems[0].elements); return this; }, get: function(index) { if (index == undefined && this.elems.length === 1) return this.elems[0]; else if (index == undefined && !this.hasSingleEl()) return this.elems; return this.elems[index]; }, /* DOM MANIPULATION */ prepend: function(el) { if (el.constructor === $lib) el = el.get(); return this.each(function() { this.insertBefore(el, this.firstChild); }); }, append: function(el) { if (el.constructor === $lib) el = el.get(); return this.each(function() { this.appendChild(el); }); }, before: function(el) { if (el.constructor === $lib) el = el.get(); return this.each(function() { this.parentNode.insertBefore(el, this); }); }, after: function(el) { if (el.constructor === $lib) el = el.get(); return this.each(function() { if (this.nextSibling != null) this.parentNode.insertBefore(el, this.nextSibling); else if (this.parentNode != null) this.parentNode.appendChild(el); }); }, replace: function(el) { return this.each(function() { $(this).before(el).remove(); }); }, html: function(html) { if (html == undefined) return this.elems[0].innerHTML; return this.each(function() { this.innerHTML = html; }); }, text: function(text) { if (this.length() === 0) return; if (text == undefined) return this.elems[0].textContent; return this.each(function() { this.textContent = text; }); }, appendText: function(text) { return this.each(function() { this.textContent += text; }); }, attr: function(name, val) { if (val == undefined) if (!this.hasSingleEl()) return this; else return this.elems[0].getAttribute(name); else if (val === "") return this.each(function() { this.removeAttribute(name); }); return this.each(function() { this.setAttribute(name, val); }); }, disabled: function(bDisabled) { if (bDisabled == undefined) return this.elems[0].disabled; return this.each(function() { this.disabled = bDisabled; }); }, toggle: function(bHidden) { return this.each(function() { var $this = $(this); if (bHidden == undefined) bHidden = !($this.attr("disabled") === "true"); $this.attr("hidden", bHidden || ""); }); }, hide: function() { return this.toggle(true); }, show: function() { return this.toggle(false); }, val: function(val) { if (val == undefined) { var el = this.elems[0]; if (el == undefined) return false; switch (el.type) { case "checkbox": case "radio": return el.checked == true; default: if (/^\d+$/.test(el.value)) return parseInt(el.value); return el.value; } } return this.each(function() { switch (this.type) { case "checkbox": case "radio": this.checked = val; break; default: this.value = val; break; } }); }, checked: function(state) { return this.each(function() { this.checked = state; }); }, addClass: function(classNames) { return this.each(function() { classNames = classNames.split(" "); for (var j = 0, jMAX = classNames.length; j < jMAX; j++) if (!$(this).hasClass(classNames[j])) this.className += (this.className ? " " : "") + classNames[j]; }); }, hasClass: function(className) { if (!this.hasSingleEl() || this.elems[0].className == undefined) return false; var regx = new RegExp("\\b" + className + "\\b"); return regx.test(this.elems[0].className); }, removeClass: function(classNames) { return this.each(function() { classNames = classNames.split(" "); for (var j = 0, jMAX = classNames.length; j < jMAX; j++) if ($(this).hasClass(classNames[j])) { var cclassNames = this.className.split(" "); this.className = ""; for (var k = 0, kMAX = cclassNames.length; k < kMAX; k++) if (classNames[j] !== cclassNames[k]) this.className += (this.className ? " " : "") + cclassNames[k]; } }); }, toggleClass: function(classNames) { return this.each(function() { classNames = classNames.split(" "); for (var j = 0, jMAX = classNames.length; j < jMAX; j++) if (!$(this).hasClass(classNames[j])) $(this).addClass(classNames[j]); else $(this).removeClass(classNames[j]); }); }, optionClass: function(optionName, optionValue, className) { return this.each(function() { if ($SS.conf[optionName] === optionValue && !$(this).hasClass(className)) $(this).addClass(className); else if ($SS.conf[optionName] !== optionValue && $(this).hasClass(className)) $(this).removeClass(className); else return }); }, remove: function() { return this.each(function() { this.parentNode.removeChild(this); }); }, /* DOM TRAVERSING */ parent: function() { if (!this.hasSingleEl()) return this; return new $lib(this.elems[0].parentNode); }, children: function(selector) { if (!this.hasSingleEl()) return this; else if (selector == null) selector = "*"; return new $lib(selector, this.elems[0]); }, nextSibling: function(selector) { if (!this.hasSingleEl() ? true : this.elems[0].nextSibling == null) return new $lib(null); if (selector != undefined) { var t, m = new $lib(selector, this.elems[0].parentNode), s = this.elems[0].parentNode.childNodes; for (var i = s.length - 1; i >= 0; --i) { if (s[i] === this.elems[0] && t == undefined) // end and no matching siblings return new $lib(null); else if (s[i] === this.elems[0] && t != undefined) // end and matched sibling return new $lib(t); else if (m.elems.indexOf(s[i]) !== -1) // this element matches the selector t = s[i]; } } return new $lib(this.elems[0].nextSibling); }, previousSibling: function(selector) { if (!this.hasSingleEl() ? true : this.elems[0].previousSibling == null) return new $lib(null); if (selector != undefined) { var t, m = new $lib(selector, this.elems[0].parentNode), s = this.elems[0].parentNode.childNodes; for (var i = 0, MAX = s.length; i < MAX; ++i) { if (s[i] === this.elems[0] && t == undefined) return new $lib(null); else if (s[i] === this.elems[0] && t != undefined) return new $lib(t); else if (m.elems.indexOf(s[i]) !== -1) t = s[i]; } } return new $lib(this.elems[0].previousSibling); }, /* EVENT METHODS */ bind: function(type, listener) { return this.each(function() { this.addEventListener(type, listener, false); }); }, unbind: function(type, listener) { return this.each(function() { this.removeEventListener(type, listener, false); }); }, fire: function(evnt) { var ev = document.createEvent("HTMLEvents"); return this.each(function() { ev.initEvent(evnt, true, true); this.dispatchEvent(ev); }); }, blur: function() { return this.each(function() { this.blur(); }); }, click: function() { return this.each(function() { this.click(); }); }, scrollIntoView: function(alignWithTop) { return this.each(function() { this.scrollIntoView(alignWithTop); }); }, /* HELPER METHODS */ delay: function(func, time) { return this.each(function() { var $this = this; setTimeout(function() { func.call($this); }, time); }); }, each: function(func, args) { if (args != null && !Array.isArray(args)) args = [args]; for (var i = 0, MAX = this.elems.length; i < MAX; ++i) func.apply(this.elems[i], args || [i]); return this; }, exists: function() { return this.elems.length > 0; }, hasSingleEl: function() { return this.elems.length === 1; }, riceCheck: function() { return this.each(function() { var click = function(e) { e.preventDefault(); this.previousSibling.click(); }; if (this.isRiced) return; else if (this.nextSibling != undefined && this.nextSibling.className === "riceCheck") return $(this.nextSibling).bind("click", click); var titleAttr; if (this.hasAttribute("title")) titleAttr = $(this).attr("title"); else titleAttr = ""; var div = $("<div class=riceCheck title='" + titleAttr + "'>").bind("click", click); $(this).hide().after(div); return this.isRiced = true; }); }, jsColor: function() { return this.each(function() { this.color = new $SS.jscolor.color(this); }); } }; /* END STYLE SCRIPT LIBRARY */ /* STYLE SCRIPT CLASSES & METHODS */ $SS = { browser: {}, DOMLoaded: function(reload) { $SS.classes.init(); var div; if (reload !== true) { $SS.options.init(); $("#index-rev").riceCheck(); $(document).bind("QRDialogCreation", $SS.QRDialogCreationHandler) .bind("OpenSettings", $SS.NodeInsertionHandler) .bind("ThreadUpdate", $SS.NodeInsertionHandler); var MutationObserver = window.MutationObserver || window.WebKitMutationObserver; var observer = new MutationObserver(function(mutations) { var i, j, MAX, _MAX, nodes; for (i = 0, MAX = mutations.length; i < MAX; ++i) { nodes = mutations[i].addedNodes; for (j = 0, _MAX = nodes.length; j < _MAX; ++j) if (nodes[j].nodeType !== 3) $("input[type=checkbox]", nodes[j]).riceCheck(); } }); observer.observe(document, { childList: true, subtree: true }); if ((!(html = $("*[xmlns]")).exists()) && (!(ctxmenu = $("#ctxmenu-main").exists()))) if ((link = $("link[title][rel='stylesheet']")).exists()) link.each(function() { $(this).attr("href", ""); }); if ((div = $("#globalMessage *[style]")).exists()) div.each(function() { $(this).attr("style", ""); }); // 4chan ads being added with JS if (!$SS.conf["Show Top Ad"]) { $(".topad.center").remove(); $(".aboveMidAd.center").remove(); } else if (!$SS.conf["Show Middle Ad"]) { $(".middlead.center").remove(); } else if (!$SS.conf["Show Bottom Ad"]) { $(".bottomad.center").remove(); } // things that need to change after 4chan X loads. setTimeout(function() { if (!$SS.QRhandled && (div = $("#qr")).exists()) $SS.QRDialogCreationHandler({ target: div }); }); } $SS.insertMascot(); $SS.riceInputs.init(); }, init: function(reload) { if (!reload) { if (/^about:neterror/.test(document.documentURI)) return; localStorage["4chan-settings"] = "{ \"disableAll\" : true, \"dropDownNav\": false }"; var m_VERSION; $SS.browser.webkit = /AppleWebKit/.test(navigator.userAgent); $SS.browser.gecko = /Gecko\//.test(navigator.userAgent); $SS.location = $SS.getLocation(); if ((m_VERSION = $SS.Config.get("VERSION")) !== VERSION) { // Signal that OneeChan has updated var detail = { type: 'info', content: NAME + ' has been updated to version ' + VERSION + '.', lifetime: 15 }; if (typeof cloneInto === 'function') { detail = cloneInto(detail, document.defaultView); } var event = new CustomEvent('CreateNotification', { bubbles: true, detail: detail }); setTimeout(function() { document.dispatchEvent(event); }, 25); // Correct selected theme/mascot after updating // and the number defaults has changed. var ntMascots = $SS.Mascots.defaults.length, // new total ntThemes = $SS.Themes.defaults.length, otMascots = $SS.Config.get("Total Mascots"), // old total otThemes = $SS.Config.get("Total Themes"), sMascots = $SS.Config.get("Selected Mascots"), sTheme = $SS.Config.get("Selected Theme"); if (otMascots !== ntMascots && otMascots != undefined) { var mDiff = ntMascots - otMascots; for (var i = 0, MAX = sMascots.length; i < MAX; ++i) if (sMascots[i] < otMascots) break; else sMascots[i] += mDiff; $SS.Config.set("Selected Mascots", sMascots); } if (otThemes !== ntThemes && otThemes != undefined && sTheme >= otThemes) { sTheme += ntThemes - otThemes; $SS.Config.set("Selected Theme", sTheme); } $SS.Config.set("VERSION", VERSION); $SS.Config.set("Total Mascots", ntMascots); $SS.Config.set("Total Themes", ntThemes); } } $SS.Config.init(); $SS.Themes.init(); $SS.Mascots.init(); if (reload) { $SS.insertCSS(); $SS.DOMLoaded(true); } else { $.asap((function() { return $("link[rel=stylesheet]", document.head).exists(); }), $SS.insertCSS); if (/complete|interactive/.test(document.readyState)) $SS.DOMLoaded(); else $(document).bind("DOMContentLoaded", $SS.DOMLoaded); } }, /* STYLING & DOM */ insertCSS: function() { var css, reload = $("#ch4SS").exists(); if (reload || $("link[rel=stylesheet]", document.head).exists()) $(document).unbind("DOMNodeInserted", $SS.insertCSS); else return; css = ".mobile,#delform .mobile.center,.tab-select:not(:checked)+div,iframe[src='about:blank'],#absbot,#styleSelector,:root.show-ads.hide-top .topad.center,:root.show-ads.hide-middle .middlead.center,:root.show-ads.hide-bottom .bottomad.center,#delPassword,:root.show-file-info .file-info,:root.hide-prevnext .prev,:root.hide-prevnext .next,:root.hide-blotter #blotter,:root.hide-checkboxes #delform .post input[type=checkbox],:root.hide-checkboxes #delform .post .riceCheck,:root.hide-checkboxes #qp .post input[type=checkbox],:root.hide-checkboxes #qp .riceCheck,:root.hide-checkboxes .deleteform,:root.hide-board-name .boardTitle,:root.hide-board-name .boardSubtitle,:root.hide-banner #bannerCnt,:root.hide-button .qr-link-container,:root.reply-fit-width .sideArrows,:root.qr-controls #qr .close,:root.qr-controls #qr select[data-name=thread],:root.qr-controls.fade-qr #qr .move label,:root.qr-controls.vertical-qr #qr .move label input,#postForm,:root.hide-button #togglePostFormLink,.forwarded,hr:not(#unread-line),:root.hide-navlinkbot .navLinks.navLinksBot.desktop,:root.hide-navlinkbot .navLinks.navLinksBottom.mobilebtn,:root.hide-navlinktop #info,:root.hide-navlinktop .navLinks:not(.navLinksBottom):not(.navLinksBot),:root.hide-navlinks body>.desktop:not(.pagelist):not(.navLinksBottom),:root.hide-navlinks .navLinks.navLinksBot.desktop,:root.hide-navlinks .navLinks,.ad-plea,#mascot img[src=''],.exif:not([style]),[hidden]{display:none}:root.hide-board-banners .center{display:none!important}.stylechanger{visibility:hidden}.brackets-wrap.pass-link-container{visibility:visible}input:focus,textarea:focus,select,a{outline:0!important}#logo{background:url(https://i.imgur.com/DG9V9sI.png)!important}.party-hat{left:0;margin-top:-80px;position:absolute;pointer-events:none}.pu-img{vertical-align:middle;margin-top:-3px;margin-right:3px;display:inline-block;width:16px;height:16px;background:url(//s.4cdn.org/image/minileaf.gif)}.pu-lbl{color:" + $SS.theme.titleColor.hex + "!important;font-weight:700;font-size:12px}.n-pu{vertical-align:middle;display:inline-block;width:16px;height:16px;margin-top:-2px;background:url(//s.4cdn.org/image/minileaf.gif)}.sjis{font-size:16px;line-height:17px;white-space:pre;font-family:IPAMonaPGothic,Mona,'MS PGothic',monospace;overflow:auto;display:block;clear:left}.mu-s{font-weight:700}.mu-i{font-style:italic}.mu-r{color:#c41e3a}.mu-g{color:#00a550}.mu-b{color:#1d8dc4}div.post div.file .fileThumb{float:left;margin-left:13px;margin-right:20px;margin-bottom:10px}div.op.post div.file .fileThumb{margin-bottom:0}.fileText{margin-left:13px!important;margin-bottom:2px!important}.postContainer{display:block}.fixed.bottom-header.is_thread body{padding-bottom:0;padding-top:.5em}.fixed.bottom-header.is_index body{padding-bottom:4.5em;padding-top:.5em}.fixed.bottom-header.is_catalog body,.fixed.bottom-header.catalog-mode body{padding-bottom:3em;padding-top:.5em}.fixed.bottom-header body{padding-top:.5em}:root.is_index.bottom-header:not(.autohide) body{padding-bottom:5em!important}.fixed.top-header.is_index body{padding-bottom:2.5em;padding-top:" + (($SS.conf["Font Size"] <= 11) ? 3.2 : 3) + "em!important}.fixed.top-header.is_thread body{padding-bottom:0;padding-top:" + (($SS.conf["Font Size"] <= 11) ? 3.2 : 3) + "em!important}.fixed.top-header.is_catalog body,.fixed.top-header.catalog-mode body{padding-bottom:.5em;padding-top:" + (($SS.conf["Font Size"] <= 11) ? 3.2 : 3) + "em!important}.fixed.top-header.autohide body{padding-top:2em!important}.fixed.top-header body{padding-top:3em!important}div.post{margin:4px 0;overflow:hidden}:root:not(.reply-fit-width) #delform div.reply:not([hidden]){display:table!important}:root:not(.reply-fit-width) #delform .stub~div.reply:not([hidden]){display:none!important}table.flashListing{border-spacing:1px;margin-left:auto;margin-right:auto}div.pagelist div.pages{padding:4px}div.pagelist,div.pagelist>div{float:left}div.pagelist>div span{padding:4px;display:inline-block}.page-num{margin-right:auto!important}s{text-decoration:none!important}span.spoiler,s,s:not(:hover)>a,s:not(:hover)>.linkify{color:#000!important;background:none repeat scroll 0 0 #000!important}span.spoiler:hover,s:hover,span.spoiler:focus,s:focus{color:#fff!important}#globalMessage,.boardBanner{text-align:center}div.sideArrows{float:left;margin-right:2px;margin-top:0;margin-left:2px;opacity:.3}hr,#boardNavDesktopFoot{clear:both}table{border-spacing:1px;margin-left:auto;margin-right:auto}.center{text-align:center!important}.middlead,.topad{margin-bottom:20px!important}#qf-box{width:120px}span.hide-announcement{margin-left:3px;vertical-align:sub}.bottomCtrl.desktop{float:right}.fixed.bottom-header.is_index .bottomCtrl.desktop,.fixed.bottom-header.is_thread .bottomCtrl.desktop{float:right;margin-bottom:35px}.fixed.top-header.is_thread .bottomCtrl.desktop,.fixed.top-header.is_index .bottomCtrl.desktop{float:right;margin-bottom:8px}#navlinks{top:135px;right:10px}:root.isLight img[src*='//boards.4chan.org/js/jsMath/fonts/']{filter:invert(100%);-webkit-filter:invert(100%)}.centered-links:root #shortcuts{width:350px!important}#blotter{margin-bottom:10px;font-size:11px;width:auto}body{margin-left:" + $SS.conf["Margin Left"] + "px;margin-right:" + $SS.conf["Margin Right"] + "px;margin-top:0;margin-bottom:0}:root.show-ads .ad-cnt{margin-top:auto!important}.postInfo{padding:5px 13px;display:block!important}.summary{margin-left:2px}.expanded-image{position:relative}div.post{margin:4px 0}:root.force-indent .op{margin-left:-12px}:root.force-wrapping .op::after{clear:both;content:'';display:block}:root.op-background .postContainer.opContainer{margin-top:2px}.thread>.replyContainer,.threadContainer>.replyContainer{margin-bottom:" + $SS.conf["Margin Between Replies"] + "px!important}.inline{margin-left:13px!important}.postMessage>.inline{margin-left:0!important}.inline .op>.postInfo,#qp .op>.postInfo{min-width:600px}.postMessage{margin:" + $SS.conf["Margin Post Message"] + "!important}:root.reply-fit-width .reply.post{display:block!important}:root.reply-fit-width .stub~.reply.post{display:none!important}.hasInline .inline>.replyContainer:not(.expanded-image):not(.hasInline) .reply.post,:root.reply-fit-width .post.reply{overflow:hidden!important}:root.reply-fit-width .expanded-image>.post::after,:root.reply-fit-width .hasInline>.reply.post::after{clear:both!important;content:''!important;display:block!important}.threadContainer .hide-reply-button{margin-left:-12px!important}.stub{padding:2px}.stub>a.show-thread-button{margin-right:4px}:root.reply-hide .thread>.expanded-image>.reply,:root.reply-hide .thread>.hasInline>.reply{margin-left:12px!important}.threadContainer{margin-left:0!important;padding-left:20px!important}:root.reply-hide .thread>.threadContainer{margin-left:13px!important}:root.post-info .reply>.postInfo{box-shadow:inset rgba(0,0,0,.05) 0 -1px 2px;padding-top:2px!important}:root.backlink-bottom .post{position:relative;padding-bottom:2px}:root.backlink-bottom .container{position:absolute;bottom:2px;right:6px}.reply .menu-button i{position:relative;bottom:1px}:root.reply-fit-width .reply .container{padding-right:5px}.menu-button+.container:not(:empty){margin-left:4px!important}:root:not(.catalog-mode).reply-fit-width .post .menu-button{float:right;margin-left:0;position:relative;left:5px}:root.reply-fit-width .post .menu-button{opacity:0}:root.reply-fit-width .post:not(:hover) .menu-button{transition:opacity .3s ease-out 0s!important}:root.reply-fit-width .post:hover .menu-button{opacity:1;transition:opacity .3s ease-in .1s!important}.prettyprint{padding:5px!important;display:inline-block;max-height:400px;overflow-x:auto;max-width:100%;vertical-align:middle}input[type=checkbox],input[type=button],input[type=submit],.riceCheck{cursor:pointer}input[type=checkbox],.riceCheck{display:inline-block;height:10px!important;position:relative;width:10px!important;border-radius:2px!important;-webkit-appearance:none;-moz-appearance:none;margin:1px}input[type=checkbox]{display:none!important}.riceCheck{margin:0 2px -1px 0}input[type=checkbox]:checked::before,input[type=checkbox]:checked+.riceCheck::before{content:'';display:block;height:8px;margin:1px;width:8px}input[type=checkbox]:checked::before,input[type=checkbox]:checked+.riceCheck::before{background:" + $SS.theme.checkMark.get() + "!important}#header-bar{padding:4px 4px 5px!important}:root:not(.fixed) #header-bar{top:0;right:0;left:0;box-shadow:0 1px 2px rgba(0,0,0,.15);border-bottom:1px solid}:root.autohide body{padding-top:0!important;padding-bottom:0!important}:root:not(.fixed).right-sidebar #header-bar{right:300px}:root:not(.fixed).left-sidebar #header-bar{left:300px}:root:not(.fixed) .boardBanner{top:0}.center{margin:5px!important}#full-board-list>a,.navSmall>a{margin-left:2px}:root.fixed:not(.autohide):not(.bottom) #globalMessage{margin-bottom:20px!important}.globalMessage,h2,h3{margin:auto}#custom-board-list,#full-board-list,.shortcut{vertical-align:baseline!important}.qr-link{border-radius:3px;vertical-align:middle;padding:7px 12px 6px}hr{height:2px;width:600px;border:0!important}:root.reply-fit-width #unread-line{margin:auto;width:100%}#unread-line{margin-top:-3px!important;margin-bottom:-3px!important}:root:not(.autohide) #scroll-marker{pointer-events:none!important}.boardTitle{cursor:default;letter-spacing:-2px}#bannerCnt{border:0!important;margin:0 auto;width:300px;max-height:100px!important;max-width:100%}.boardBanner{width:300px;margin:auto}.boardBanner>img{border:0!important}:root.banner-opacity #bannerCnt{opacity:.5;transition:opacity .3s ease-out 0s}:root.banner-opacity #bannerCnt:hover{opacity:1!important;transition:opacity .3s ease-in 0s}.pages strong>a{border-radius:3px}.pages strong>a:hover{opacity:.7!important;transition:opacity .3s ease-in 0s}.pagelist{margin-left:18px;margin-bottom:15px}:root.reply-fit-width .pagelist{margin-left:0}.pages a{padding:5px 10px;margin-left:-1px}.next,.prev{border:0!important;position:relative}.next a,.prev a{position:relative;right:5px}.prev a::after{content:'<';position:inherit;top:4px;left:1px}.next a::after{content:'>';position:inherit;top:4px;right:2px}.pagelist button,.pagelist button:hover{background:none!important;border:0!important;box-shadow:none!important;height:20px;width:20px}.pagelist span{opacity:.2}table.flashListing{margin-top:20px;margin-bottom:20px}table.flashListing .highlightPost{background:rgb\(" + $SS.theme.mainColor.shiftRGB(-25) + ")!important}.flashListing td{padding-left:4px!important;padding-right:4px!important;text-align:center!important}#delform[action='https://sys.4chan.org/f/up.php'],#delform[action='https://sys.4chan.org/f/up.php'] .postblock{background:none!important;border:0!important;box-shadow:none!important}#mascot img,#mascotprev img{position:fixed;right:0;bottom:0}#mascot img{margin-bottom:" + $SS.mascot.offset + "px;margin-right:" + $SS.mascot.hoffset + "px;height:" + $SS.mascot.height + ";width:" + $SS.mascot.width + ";max-width:" + $SS.mascot.maxwidth + ";transform:" + $SS.mascot.flip + ";pointer-events:none}:root.left-sidebar #mascot img,:root.left-sidebar #mascotprev img{margin-left:" + $SS.mascot.hoffset + "px;margin-right:0!important}#mascotprev img{z-index:90!important}#mascot.previewing img{display:none}:root.fixed.bottom-header:not(.autohide) #mascot img,:root.fixed.bottom-header:not(.autohide) #mascotprev img{padding-bottom:26px}:root.left-sidebar #mascot img,:root.left-sidebar #mascotprev img{left:0;right:auto!important}:root.mascot-opacity #mascot img,:root.mascot-opacity #mascotprev img{opacity:.5;transition:opacity .3s ease-out 0s;pointer-events:auto!important}:root.mascot-opacity #mascot img:hover,:root.mascot-opacity #mascotprev img:hover{opacity:1!important;transition:opacity .3s ease-in 0s}:root.mascot-overlap #mascot img{z-index:-1}:root.ad-opacity .center img{opacity:.5;transition:opacity .3s ease-out 0s}:root.ad-opacity .center img:hover{opacity:1!important;transition:opacity .3s ease-in 0s}body.is_index div.navLinks{padding:5px 0}.navLinks.navLinksBot.desktop{margin-bottom:5px}#hoverUI{z-index:12!important}#search-box,#index-search{width:9%;transition:color .25s,border-color .25s,width .25s}#search-box:focus,#index-search:focus{width:12%;transition:color .25s,border-color .25s,width .25s}:root.thumb-opacity .fileThumb{opacity:.5;transition:opacity .3s ease-out 0s}:root.thumb-opacity .fileThumb:hover{opacity:1;transition:opacity .3s ease-in 0s}:root.info-on-hover .postContainer .fileText{opacity:0;height:0;transition:opacity .3s ease-out 0s;pointer-events:none}:root.info-on-hover .postContainer:hover .fileText{opacity:1;height:auto;transition:opacity .3s ease-in 0s;pointer-events:auto}select{-moz-appearance:none;-webkit-appearance:none}#delform{overflow-wrap:break-word;word-break:break-word;margin-bottom:15px}html,body,div.boardBanner,#menu,input:not(.jsColor),textarea,#qr-filename-container,#post-preview,.post-last,.pln,select,.captcha-root,.tegaki-label,.dd-menu ul,.boxbar{color:" + $SS.theme.textColor.hex + "!important}.nameBlock:not(.capcodeMod)>.name,.com,.post-author{color:" + $SS.theme.nameColor.hex + "!important}.nameBlock.capcodeMod{color:purple!important}.id_admin,.nameBlock.capcodeAdmin span.name{color:red!important}.nameBlock>.postertrip,.post-tripcode,.tag{color:" + $SS.theme.tripColor.hex + "!important}a,.typ,.atn,body.is_catalog .button,:root.catalog-mode .button,.options-button,.tegaki-tb-btn{color:" + $SS.theme.linkColor.hex + "!important}a.summary,.pages strong>a{color:" + $SS.theme.textColor.hex + "!important}#header-bar #notifications a{color:#fff!important}a:hover,body.is_catalog .button:hover,:root.catalog-mode .button:hover,.lit,#header-bar #notifications a:hover,.tegaki-tb-btn:hover{color:" + $SS.theme.linkHColor.hex + "!important}#header-bar,a.current{color:" + $SS.theme.headerColor.hex + "!important}#header-bar a:not(.current){color:" + $SS.theme.headerLColor.hex + "!important}#header-bar a:hover{color:" + $SS.theme.headerLHColor.hex + "!important}#custom-board-list .current{border-bottom:1px solid rgba(" + $SS.theme.linkColor.rgb + ",1)!important}#custom-board-list .current:hover{border-bottom:1px solid rgba(" + $SS.theme.linkHColor.rgb + ",1)!important}.postMessage>.quote,s:hover .quote,.str,.atv,.new,.catalog-thread>.comment>.quote{color:" + $SS.theme.quoteColor.hex + "!important}.subject,.replytitle,.teaser b,.post-subject,.option.header .option-title,.kwd{color:" + $SS.theme.titleColor.hex + "!important}.option.header{font-size:140%}.boardTitle{color:" + $SS.theme.boardColor.hex + "!important;text-shadow:none!important}.backlink{color:" + $SS.theme.blinkColor.hex + "!important}.quotelink{color:" + $SS.theme.qlColor.hex + "!important}.prettyprint,.catalog-code{background:none repeat scroll 0 0 rgba(" + $SS.theme.codeBackground + ")!important;border:1px solid rgba(" + $SS.theme.codeBorder + ")!important}.pun{color:rgba(" + $SS.theme.textColor.rgb + ",.4)!important}::-webkit-input-placeholder{color:rgba(" + $SS.theme.textColor.rgb + ",.4)!important}#qr .field::-moz-placeholder,::-moz-placeholder,#qr-no-file{color:rgba(" + $SS.theme.textColor.rgb + ",.4)!important}body{background:" + $SS.theme.bgImg.get() + $SS.theme.bgColor.hex + "!important}.reply,body.is_catalog .panel,:root.catalog-mode .panel,.dialog,.tab-label,#post-preview,#tegaki,.boxbar,:root.op-background .postContainer.opContainer,.flashListing tr:nth-of-type(2n+1),.dd-menu ul,:root.catalog-hover-expand .catalog-container:hover>.post{background:rgba(" + $SS.theme.mainColor.rgb + "," + $SS.theme.replyOp + ")!important}:root.recolor-even .thread>.replyContainer:nth-of-type(even):not(.hidden) .post{background:rgb\(" + $SS.theme.mainColor.shiftRGB(-10) + ")!important}:root:not(.header-gradient) #header-bar{background:rgba(" + $SS.theme.headerBGColor.rgb + "," + $SS.theme.navOp + ")!important}:root.header-gradient #header-bar{background:linear-gradient(rgb\(" + $SS.theme.headerBGColor.shiftRGB(15) + "),rgba(" + $SS.theme.headerBGColor.rgb + "," + $SS.theme.navOp + "))!important}:root.header-shadow #header-bar{box-shadow:none!important}:root:not(.fixed) #header-bar{background:none!important}.options-button,.qr-link,.pages.cataloglink,.pages strong>a{background:linear-gradient(rgb\(" + $SS.theme.mainColor.shiftRGB(15) + "),rgb(" + $SS.theme.mainColor.rgb + "))!important}.options-button:hover,.import-input:hover+.options-button,.pages strong>a:hover,.dd-menu li:hover{background:rgb\(" + $SS.theme.mainColor.shiftRGB(15) + ")}.focused.entry{background:rgb\(" + $SS.theme.mainColor.shiftRGB(10) + ")!important}.qr-link:hover,:root.vertical-qr #qr .move{background:rgb\(" + $SS.theme.mainColor.rgb + ")}input:not(.jsColor),textarea,.riceCheck,#qr-filename-container,select,.captcha-root{background:" + $SS.theme.inputColor.hex + "!important;transition:background .2s}input[type=checkbox],.riceCheck{background:rgb\(" + $SS.theme.inputColor.shiftRGB(25) + ")!important}input:not(.jsColor):hover,.riceCheck:hover,#qr-filename-container:hover,textarea:hover,select:hover,.captcha-root:hover{background:rgb(" + $SS.theme.inputColor.hover + ")!important;transition:background .2s}hr{background-image:linear-gradient(to left,rgba(" + $SS.theme.brderColor.rgb + ",0),rgb(" + $SS.theme.brderColor.rgb + "),rgba(" + $SS.theme.brderColor.rgb + ",0))}#unread-line{background-image:linear-gradient(to left,rgba(" + $SS.theme.unreadColor.rgb + ",0),rgb(" + $SS.theme.unreadColor.rgb + "),rgba(" + $SS.theme.unreadColor.rgb + ",0))}.inline{background:rgba\(" + $SS.theme.mainColor.shiftRGB(-16) + ",.8)!important}:root.post-info .reply>.postInfo{background:rgba\(" + $SS.theme.mainColor.shiftRGB(-16) + ",.2);border-bottom:1px solid rgb\(" + $SS.theme.mainColor.shiftRGB(4) + ")}.reply,:root.op-background .postContainer.opContainer,.dd-menu ul{border-width:0 1px 1px 0;border-style:solid}:root.borders-all .reply,:root.borders-all.op-background .postContainer.opContainer{border-width:1px!important}:root.borders-none .reply,:root.borders-none.op-background .postContainer.opContainer{border:0}#menu,.catalog-thumb{border-radius:0!important}:root.rounded-corners .reply,:root.rounded-corners.op-background .postContainer.opContainer,:root.rounded-corners .dialog:not(#header-bar),:root.rounded-corners .inline,:root.rounded-corners #thread-stats :root.rounded-corners #updater,:root.rounded-corners #menu,:root.rounded-corners .thumb,:root.rounded-corners .fileThumb img:not(.full-image),:root.rounded-corners .catalog-thumb,:root.rounded-corners .dd-menu ul,:root.rounded-corners.werkTyme .catalog-thread:not(:hover),:root.rounded-corners.werkTyme:not(.catalog-hover-expand) .catalog-thread,:root.rounded-corners.catalog-hover-expand .catalog-container:hover>.post,:root.rounded-corners.catalog-hover-expand .catalog-container:hover .catalog-reply{border-radius:3px!important}:root.post-info.rounded-corners .reply>.postInfo,:root.rounded-corners #qr,:root.rounded-corners:root.vertical-qr #qr>.move{border-radius:3px 3px 0 0!important}:root:not(.rounded-corners) #post-preview{border-radius:0!important}.reply,:root.op-background .postContainer.opContainer,.dialog,.entry,.inline,fieldset,#post-preview,.flashListing td:not(:last-of-type):not(.postblock),:root.vertical-qr #qr .move,#qr select,select{border-color:" + $SS.theme.brderColor.hex + "!important}.dd-menu li{border-bottom:" + $SS.theme.brderColor.hex + "!important}input,textarea,.riceCheck,#qr-filename-container,#search-box,#index-search,.captcha-img,:root.vertical-qr #qr .move,#qr select,select,#post-preview,.captcha-root,.dd-menu ul,:root.werkTyme .catalog-thread:not(:hover),:root.werkTyme:not(.catalog-hover-expand) .catalog-thread,:root.catalog-hover-expand .catalog-container:hover>.post,:root.catalog-hover-expand .catalog-container:hover .catalog-reply{border:1px solid " + $SS.theme.inputbColor.hex + "!important}.options-button,.qr-link,.pages.cataloglink,.pages strong>a{border-style:solid;border-width:1px;border-color:rgb\(" + $SS.theme.mainColor.shiftRGB(-15) + ") rgb\(" + $SS.theme.mainColor.shiftRGB(-15) + ") rgb\(" + $SS.theme.mainColor.shiftRGB(-30) + ")!important}a.quotelink.forwardlink,a.backlink.forwardlink{border-bottom:1px dashed}input:focus,textarea:focus,#qr-filename-container:focus,#qr-filename-container.focus,select:focus,.captcha-root:focus{border:1px solid " + $SS.theme.linkColor.hex + "!important}#search-box:hover,#index-search:hover,.captcha-img:hover{border-color:" + $SS.theme.linkColor.hex + "!important}#header-bar{border:0!important}.flashListing td:not(:last-of-type):not(.postblock){border-width:1px;border-style:solid}:root.header-highlight #custom-board-list .current:hover,:root.header-highlight #custom-board-list .current{border-bottom:0!important}.suboption-list>div:last-of-type{background:rgba(" + $SS.theme.mainColor.rgb + "," + $SS.theme.replyOp + ")!important}.suboption-list>div::before,.suboption-list::before{border-color:" + $SS.theme.brderColor.hex + "!important;left:.5em!important}#navlinks a{text-shadow:" + $SS.theme.mainColor.hex + " -1px -1px," + $SS.theme.mainColor.hex + " 1px -1px," + $SS.theme.mainColor.hex + " -1px 1px," + $SS.theme.mainColor.hex + " 1px 1px," + $SS.theme.mainColor.hex + " -1px 0," + $SS.theme.mainColor.hex + " 1px 0," + $SS.theme.mainColor.hex + " 0 -1px," + $SS.theme.mainColor.hex + " 0 1px,rgba(0,0,0,.6) 0 2px 4px,rgba(0,0,0,.6) 0 0 2px}.thumb{box-shadow:0 0 5px rgba(0,0,0,.25)}#qr,#thread-watcher{box-shadow:1px 1px 3px rgba(0,0,0,.1)!important}:root.style-stats #thread-stats,:root.style-stats #updater,:root.style-stats #stats{box-shadow:0 1px 2px rgba(0,0,0,.15);padding:3px 6px!important;border:1px solid}:root.mascot-grayscale #mascot img{filter:url('data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 height=%220%22 color-interpolation-filters=%22sRGB%22><filter id=%22grayscale%22><feColorMatrix id=%22color%22 type=%22saturate%22 values=%220%22 /></filter></svg>#grayscale');-webkit-filter:grayscale(100%)}.closed{margin-top:10px;color:red}#swf-embed-header.postblock{border:1px solid " + $SS.theme.brderColor.hex + "!important;background-color:rgba(" + $SS.theme.headerBGColor.rgb + "," + $SS.theme.navOp + ")!important;color:" + $SS.theme.linkColor.hex + "!important}#swf-embed-close{right:1px!important}.deleteform,.pages,.pagelist button,#full-board-list{font-size:0!important}.fileText,.summary{font-size:" + (($SS.conf["Font Size"] < 13) ? 10 : ($SS.conf["Font Size"] - 2)) + "px!important}.qr-link{font-size:14px!important}.tab-label,.options-button,.theme-preview,#oneechan-options input,#oneechan-options textarea,.hide-reply-button,.hide-thread-button{font-family:sans-serif!important;font-size:12px!important}.boardBanner .boardTitle{font-weight:400!important;font-size:" + (($SS.conf["Font Size"] < 13) ? 22 : 26) + "px!important}.prettyprint span{font-family:monospace!important;font-size:medium!important}#full-board-list,body>#header-bar,#full-board-list .fourchanx-link{font-size:" + (($SS.conf["Font Size"] < 1) ? 12 : ($SS.conf["Font Size"] - 1)) + "px!important}@media (min-width:1280px) and (max-width:1920px){#board-list{word-spacing:" + (($SS.conf["Font Size"] < 14) ? -1 : -2) + "px}}body,.prev span::after,.prev form::after,.next span::after,.next form::after,.pages a,#qr input.field,#qr:not(.sjis-preview) textarea.field,#qr span.field,#qr-file-button,#qr input[type=submit],#qr select[data-name=thread],#menu .entry,#boardList,#shortcuts,#index-search,#tegaki,select,input,div.next,form.pageSwitcherForm>input[type=submit]{font-family:" + $SS.formatFont($SS.conf["Font Family"]) + ";font-size:" + $SS.conf["Font Size"] + "px!important}#full-board-list a,#custom-board-list,a.qr-link{font-family:" + $SS.formatFont($SS.conf["Font Family"]) + "!important;font-size:" + $SS.conf["Font Size"] + "px!important}#qr .field::-moz-placeholder,::-moz-placeholder{font-family:" + $SS.formatFont($SS.conf["Font Family"]) + "!important;font-size:" + $SS.conf["Font Size"] + "px!important}#qr .field::webkit-input-placeholder,::webkit-input-placeholder{font-family:" + $SS.formatFont($SS.conf["Font Family"]) + "!important;font-size:" + $SS.conf["Font Size"] + "px!important}.backlink{font-size:" + $SS.conf["Backlink Font Size"] + "px!important}:root.info-on-hover .postNum{font-size:0!important}:root.info-on-hover .postContainer:hover .postNum{font-size:" + $SS.conf["Font Size"] + "px!important}#qr-file-button,#qr input[type=submit],#qr label,.captcha-counter{font-size:" + (($SS.conf["Font Size"] < 11) ? 8 : 10) + "px!important}#qr-file-button,#qr input[type=submit],#qr label,.captcha-counter{text-transform:uppercase}#qr label:not(.riceCheck){overflow:hidden;padding-bottom:2px}:root.underline-disabled a{text-decoration:none!important}.navLinks.navLinksBot.desktop a{text-decoration:underline}:root.underline-disabled .filtered{text-decoration:line-through!important}.deadlink.quotelink{text-decoration:none!important}:root.underline-quotes .deadlink.quotelink,:root.underline-quotes .quotelink,:root.underline-quotes .deadlink.backlink,:root.underline-quotes .backlink{text-decoration:underline!important}a.options-button,#oneechan-version a{text-decoration:none!important}.closed{text-align:center}.name,.subject,.option.header .option-title,a.current{font-weight:" + ($SS.conf["Bitmap Font"] ? 4 : 7) + "00!important}.qr-link{font-weight:400}.summary{font-style:" + ($SS.conf["Bitmap Font"] ? 'none' : 'italic') + "}#qr{box-shadow:none!important;border-radius:0!important;min-width:297px!important;box-shadow:none!important}#qr .close{padding:2px 3px 2px 4px!important}#qr .riceCheck,#qr input[type=checkbox]{margin:0 4px 1px!important;vertical-align:baseline;position:relative;top:3px}#qr-filename-container .riceCheck,#qr-filename-container input[type=checkbox]{margin:0 0 1px!important}#qr-file-button,#qr input[type=submit]{height:25px!important;margin:0!important}#qr-file-button,#qr-filename-container{margin-right:1px!important}#qr-spoiler-label+input[type=submit]{margin-top:1px!important}#qr>form>select{margin:1px 0!important}#qr select[data-name=thread]{margin:1px 0;max-width:133px;min-width:80px}#qr>form>div.persona>input:nth-child(4),#qr>form>div.persona>input:nth-child(5),#qr>form>div.persona>input:nth-child(6){margin-left:1px}:root.expand-inputs .persona{display:flex}:root.expand-inputs .persona .field{flex:1;width:0}:root.expand-inputs .persona .field:hover,:root.expand-inputs .persona .field:focus{flex:3}#qr:not(.has-captcha) textarea{min-height:190px!important}:root.ua-webkit #qr:not(.has-captcha) textarea{min-height:185px!important}:root.ua-webkit #qr.has-captcha textarea.field{height:8.6em;min-height:.6em!important}:root.qr-background #qr{background:transparent!important;border:0}:root.qr-opacity #qr{opacity:.9}.textarea{margin-top:1px;-webkit-margin-after:1px}:root.ua-gecko .textarea{margin-bottom:1px}.captcha-img{min-height:58px!important;margin-bottom:1px}:root.force-qr #qr{max-width:297px}:root.vertical-qr #qr>div>label>div{display:none}:root.vertical-qr #qr textarea{resize:vertical!important}:root.vertical-qr #qr{min-width:297px!important;top:auto!important;position:fixed;right:0!important;left:auto!important}:root.vertical-qr #qr .move{position:absolute;width:105px;cursor:default;padding:2px 0 2px 2px;text-align:center;bottom:88px}:root.vertical-qr #qr:hover .move{transition:opacity .42s linear}:root.vertical-qr #qr:hover .move,:root.vertical-qr #qr.focus .move{opacity:0!important}:root.vertical-qr.bottom-header #qr{bottom:28px!important}:root.vertical-qr.top-header #qr{bottom:0!important}:root.vertical-qr .captcha-img,:root.vertical-qr .captcha-img img{max-width:247px}:root.vertical-qr #qr form{display:block!important}:root.vertical-qr #qr .move #autohide,:root.vertical-qr #qr>div>select{display:none}:root.vertical-qr #qr:hover,:root.vertical-qr #qr.focus{transform:translateX(0%)!important}:root.vertical-qr #qr{transform:translateX(100%);transition:transform .3s ease-in-out .1s}:root.vertical-qr #qr .move{transform:rotate(-90deg);right:86%}:root.fade-qr #qr form{display:block!important}:root.fade-qr #qr.autohide:not(.focus):not(:hover){opacity:.2!important;transition:opacity .2s ease-in-out 1s}input[type=number]{-moz-appearance:textfield}::-webkit-inner-spin-button{-webkit-appearance:none}::-webkit-outer-spin-button{-webkit-appearance:none}" + ($SS.conf["Disable In Catalog View"] && $SS.location.catalog ? $SS.conf["Sidebar Position"] == 3 : ($SS.conf["Sidebar Position"] !== 3 ? " :root:not(.fixed) #header-bar{z-index:10}:root.left-sidebar body{padding-left:303px}:root.right-sidebar body{padding-right:303px}:root.left-sidebar:not(.mini-sidebar) .boardBanner,:root.right-sidebar:not(.mini-sidebar) .boardBanner{position:fixed}:root.left-sidebar:not(.mini-sidebar) .boardBanner{left:1px}:root.right-sidebar:not(.mini-sidebar) .boardBanner{right:1px}:root.fixed:not(.autohide):not(.bottom) .boardBanner{margin-top:-6px}:root.left-sidebar #qr{left:0!important;right:auto!important}:root.right-sidebar #qr{right:0!important;left:auto!important}.captcha-img,.captcha-img img{min-width:100%!important;height:56px!important}:root.vertical-qr:root.left-sidebar #qr{transform:translateX(-100%)}:root.vertical-qr:root.left-sidebar #qr .move{transform:rotate(90deg);transform-origin:bottom right;left:63.5%;bottom:46px}:root.ss-sidebar body::before{background:rgba\(" + $SS.theme.mainColor.shiftRGB(-18) + ",." + ($SS.theme.mainColor.isDark ? 9 : 2) + ");border-left:2px solid rgba(" + $SS.theme.mainColor.rgb + ",.9);box-shadow:inset " + $SS.theme.brderColor.hex + " 1px 0 0,inset " + $SS.theme.brderColor.hex + " -1px 0 0;content:'';height:100%;width:302px;position:fixed;top:0;right:0}:root.ss-sidebar.left-sidebar body::before{border-right:2px solid rgba(" + $SS.theme.mainColor.rgb + ",.9);border-left:0!important;left:0;right:auto!important}:root.mini-sidebar:root.left-sidebar body{padding-left:32px!important}:root.mini-sidebar:root.right-sidebar body{padding-right:32px!important}:root.mini-sidebar .boardSubtitle{display:none}:root.mini-sidebar:root.ss-sidebar body::before{width:31px!important}:root.mini-sidebar .boardTitle{top:72px!important;width:inherit!important;letter-spacing:-1px;position:fixed}:root.mini-sidebar:root.right-sidebar .boardTitle{right:32px;-webkit-transform-origin:top right;transform-origin:top right;-webkit-transform:rotate(-90deg);-moz-transform:rotate(-90deg)}:root.mini-sidebar:root.left-sidebar .boardTitle{left:32px;-webkit-transform-origin:top left;transform-origin:top left;-webkit-transform:rotate(90deg);-moz-transform:rotate(90deg)}" : "")) + " .closeIcon{background-image:none!important}.closeIcon::after{content:'x'}.watch-thread-link{margin-bottom:-7px;margin-right:2px;top:auto!important;bottom:4px!important;background-image:url(\"data:image/svg+xml," + $SS.theme.icons.star + "\")!important}:root.backlink-icon .backlink{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.backlink + "\")!important;font-size:0!important;padding:" + (($SS.conf["Font Size"] < 12) ? 5 : 6) + "px!important;margin-right:0!important;opacity:.6!important;position:relative;bottom:5px;left:2px}:root.backlink-icon .backlink.inlined{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.downArrow + "\")!important;font-size:0!important;padding:6px!important;margin-right:0!important;opacity:.6!important;position:relative;bottom:5px;left:3px}:root.backlink-icon .reply .backlink{bottom:" + (($SS.conf["Font Size"] < 12) ? 4 : 6) + "px!important}:root.backlink-icon .backlink:hover,:root.backlink-icon .backlink.inlined:hover{opacity:1!important}img[title=Closed],img[title=Sticky],img[title=Archived]{color:transparent!important;font-size:0!important;background-color:transparent!important;background-position:center!important;background-repeat:no-repeat;display:inline-block;height:0!important;padding-top:16px!important;text-indent:-9999px!important;vertical-align:bottom;width:16px!important}.closedIcon{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.threadClosed + "\")!important}.stickyIcon{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.threadPinned + "\")!important}.archivedIcon{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.threadArchived + "\")!important}.exlinksOptionsLink.entry{padding:0!important;min-width:0!important}:root.left-sidebar .exlinksOptionsLink.entry{left:2px!important}:root.right-sidebar .exlinksOptionsLink.entry{right:2px!important}:root.hl-border .post.reply,:root.op-background.hl-border .postContainer.opContainer{border-left:" + $SS.conf["Width Decoration"] + "px " + $SS.conf["Post Highlight Style"] + " rgba(" + $SS.theme.postHLColor.rgb + ",1)!important}:root.hl-border-down .post.reply,:root.op-background.hl-border-down .postContainer.opContainer{border-bottom:" + $SS.conf["Width Decoration"] + "px " + $SS.conf["Post Highlight Style"] + " rgba(" + $SS.theme.postHLColor.rgb + ",1)!important}:root.hl-outline .post.reply,:root.op-background.hl-outline .postContainer.opContainer{outline:" + $SS.conf["Width Decoration"] + "px " + $SS.conf["Post Highlight Style"] + " rgba(" + $SS.theme.postHLColor.rgb + ",1)}.filter-highlight .catalog-thumb{box-shadow:0 0 3px 3px rgba(" + $SS.theme.postHLColor.rgb + ",.5)!important}.filter-highlight.opContainer,.filter-highlight>.reply{box-shadow:5px 0 rgba(" + $SS.theme.postHLColor.rgb + ",.5) inset!important}.filter-highlight>div.sideArrows{color:rgba(" + $SS.theme.postHLColor.rgb + ",.5)!important}.qphl{outline:2px solid rgba(" + $SS.theme.linkColor.rgb + ",.5)!important}:root.highlight-you .quotesYou.opContainer,:root.highlight-you .quotesYou>.reply{border-left:" + $SS.conf["Width Decoration"] + "px solid rgba(" + $SS.theme.quotesYouHLColor.rgb + ",1)!important}:root.highlight-you .quotesYou>.sideArrows{color:rgba(" + $SS.theme.quotesYouHLColor.rgb + ",1)!important}:root.highlight-own .yourPost.opContainer,:root.highlight-own .yourPost>.reply{border-left:" + $SS.conf["Width Decoration"] + "px dashed rgba(" + $SS.theme.ownPostHLColor.rgb + ",1)!important}:root.highlight-own .yourPost>.sideArrows{color:rgba(" + $SS.theme.ownPostHLColor.rgb + ",1)!important}.reply:target{background:rgba(" + $SS.theme.replybgHLColor.rgb + ",.8)!important}.highlight{outline:2px solid rgba(" + $SS.theme.replyslctColor.rgb + ",1)!important}.catalog-thread.watched .catalog-thumb,.catalog-thread.watched .werkTyme-filename{border:2px solid rgba(" + $SS.theme.postHLColor.rgb + ",1)!important}.replies-quoting-you>.watcher-link{color:rgba(" + $SS.theme.quotesYouHLColor.rgb + ",1)!important}.replies-quoting-you>.watcher-link:hover{color:" + $SS.theme.linkHColor.hex + "!important}#watched-threads>.replies-quoting-you>a{color:rgba(" + $SS.theme.quotesYouHLColor.rgb + ",1)!important}#shortcuts>.shortcut>#watcher-link.disabled.replies-quoting-you{color:rgba(" + $SS.theme.quotesYouHLColor.rgb + ",.45)!important}#watched-threads>.replies-quoting-you>a:hover,#shortcuts>.shortcut>#watcher-link.disabled.replies-quoting-you:hover{color:" + $SS.theme.linkHColor.hex + "!important}:root.highlight-opQuotes .qmark-op{color:rgba(" + $SS.theme.postHLColor.rgb + ",1);font-weight:700}:root.highlight-youQuotes .qmark-you{color:rgba(" + $SS.theme.quotesYouHLColor.rgb + ",1);font-weight:700}.extended-small .teaser,.extended-large .teaser{margin-left:5px;margin-right:5px}div.thread{margin:2px 1px 0 0;clear:both;padding-bottom:10px}.pages.cataloglink{margin-left:12px;border-radius:3px}.pages.cataloglink a{color:" + $SS.theme.textColor.hex + "!important;font-weight:700}.pages.cataloglink a:hover{color:" + $SS.theme.textColor.hex + "!important;opacity:.7!important;transition:opacity .3s ease-in 0s}:root.catalog-justify .teaser,:root.catalog-justify .catalog-thread>.comment{text-align:justify!important}:root.catalog-background #threads div.thread,:root.catalog-background .catalog-thread{background:rgba(" + $SS.theme.mainColor.rgb + "," + $SS.theme.replyOp + ")!important}:root.rounded-corners.catalog-background #threads div.thread,:root.rounded-corners.catalog-background .catalog-thread{border-radius:3px!important}:root.catalog-background .teaser,:root.catalog-background .catalog-thread>.comment{margin:0 5px 5px}:root.catalog-background .thumb,:root.catalog-background img.catalog-thumb{margin-top:8px}:root.catalog-background .extended-large .thread{min-height:410px}:root.catalog-background .extended-small .thread{min-height:320px}:root.catalog-thumbsize .thumb,:root.catalog-thumbsize img.catalog-thumb{width:150px!important;height:150px!important}#add-theme,#oneechan-options{border:0!important;border-radius:3px!important;position:fixed;margin:auto}#oneechan-options{width:690px;text-align:left!important;height:532px;top:0;bottom:0;left:0;right:0;box-shadow:rgba(0,0,0,.6) 0 0 10px!important;padding:5px}.options-close,#options-container:not(.yui-skin-sam){padding:3px}#options-container:not(.yui-skin-sam){box-shadow:inset rgba(0,0,0,.3) 0 0 5px}.options-close{text-align:right!important;margin-right:auto;margin-left:auto}#add-mascot{height:225px;top:0;bottom:0;left:0;position:fixed;margin:auto;border:0!important;border-radius:3px!important;right:0;z-index:999!important;width:500px;text-align:right!important;padding:5px!important;box-shadow:0 1px 15px rgba(0,0,0,.3)!important}#add-theme{padding:20px!important;top:0;left:0;right:0;bottom:0;height:445px}:root.ua-webkit #add-theme{height:403px!important}#add-mascot .option-title,#add-theme .option-title{float:left;line-height:22px;padding-left:5px}#add-mascot>label,#add-theme>label{line-height:22px}#options-container:not(.yui-skin-sam){border-radius:5px}#options-container:not(.yui-skin-sam),.options-section{height:500px}.options-section{overflow-y:auto;overflow-x:hidden}#main-section .option{display:block;border-top:1px solid rgba(0,0,0,.1);height:22px;padding:0 6px;vertical-align:middle}#main-section>.option:nth-of-type(even){background:rgb\(" + $SS.theme.mainColor.shiftRGB(-5) + ")!important}#main-section .buttons-container+.option{border-top:0!important}.option-title{line-height:20px!important}#main-section .option:first-child{border-top:0!important}#main-section .option:last-child{border-bottom:0!important}#main-section input,#main-section select{float:right!important}#main-section input[type=checkbox],#main-section .riceCheck{float:left!important;margin-right:5px!important}select[name='Font Family']>option{max-width:150px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.suboption::before{border-bottom:1px solid rgba(0,0,0,.1);border-left:1px solid rgba(0,0,0,.1);content:'';display:inline-block;float:left;margin-right:2px;height:50%;width:6px}.suboption{padding-left:16px!important}.option.header{cursor:auto!important}.theme-preview{cursor:default}.theme-preview blockquote{margin:12px 40px!important}#themes-section .reply{padding:2px!important;position:relative;text-align:left;width:99.4%;border-radius:0!important}.theme-buttons-container{bottom:4px;right:2px;margin:0;opacity:0;position:absolute;z-index:3}.theme-preview:hover .theme-buttons-container{opacity:1}.theme-buttons-container>a{display:inline-block;margin:0 2px;padding:2px 5px;text-align:center;width:50px;border-radius:3px}.theme-preview .sfw-label{bottom:-5px;font-size:32px!important;margin:0!important;opacity:0;position:absolute;right:300px}.theme-preview.selected:not(.nsfw) .sfw-label,.theme-preview.nsfw:not(.selected) .sfw-label,.theme-preview.nsfw.selected .both{transition:opacity .3s,right .3s}.theme-preview.nsfw .notsafe{opacity:1;right:3px;z-index:1}.theme-preview.selected .safe{opacity:1;right:3px;z-index:1}.theme-preview.selected.nsfw .sfw-label:not(.both){opacity:0!important;right:300px!important;z-index:0!important}.theme-preview.selected.nsfw .both{opacity:1;right:3px;z-index:1}#add-theme{text-align:left!important;width:800px!important}#add-theme>label{display:inline-block;text-align:right;width:33.3%}#add-theme>label#customCSS{width:100%}#add-theme>label#customCSS>textarea{height:9.5em;resize:vertical;width:99%;max-height:25em}#add-theme>label>input[type=text],#add-theme>label>select{width:100px}#add-theme>div{margin-top:.6em;text-align:right}#mascot-section{text-align:center}.mascot-preview{background-position:center!important;background-repeat:no-repeat!important;background-size:contain!important;display:inline-block;height:257px;margin:2px;position:relative;width:210px;border-radius:10px;transition:all .1s}.mascot-preview:not(:hover) a:not(.mascot-name){opacity:0}.mascot-preview.selected{background-color:rgba(" + $SS.theme.linkColor.rgb + ",.6)!important;box-shadow:inset rgba(0,0,0,.15) 0 0 15px,rgba(" + $SS.theme.linkColor.rgb + ",.6) 0 0 2px}.mascot-preview a{color:#fff!important;padding:3px 8px;cursor:pointer;border-radius:2px;background:rgba(0,0,0,.6)}.mascot-preview a:hover{background:rgba(0,0,0,.8)}.mascot-link.edit{margin-left:1px}.mascot-buttons{position:absolute;left:0;right:0;bottom:10px}#mascot-buttons-container{padding:1px;margin-top:2px}.add-mascot-label{display:block}.mascot-input,.mascot-select{margin-top:1px!important;width:200px}.mascot-input.offset,.mascot-input.hoffset,.mascot-input.height,.mascot-input.maxwidth,.mascot-input.width{width:80px}.add-mascot-label>input[type=checkbox],.add-mascot-label>.riceCheck{margin-top:5px}#options-tabs{list-style:none;margin:0;padding:0;position:absolute;top:-24px;left:-1px}.tab-item{float:left;margin:0;padding:0}.tab-label{display:block;height:16px;margin:0 1px;padding:5px;text-align:center;width:75px;border-radius:3px 3px 0 0;transition:all .1s ease-in-out}.tab-label:not(.selected):not(:hover){opacity:.8}#overlay{z-index:99!important;background-color:rgba(0,0,0,.3)!important}#overlay2{background:rgba(0,0,0,.1)!important;position:fixed;top:0;left:0;height:100%;width:100%;text-align:center;z-index:125!important}#overlay2::before{content:'';display:inline-block;height:100%;vertical-align:middle}#overlay.previewing{display:none}#overlay.previewing~#overlay2{background-color:rgba(0,0,0,.1)!important}#add-mascot+#overlay2{z-index:800!important}.buttons-container{bottom:3px;left:5px;position:absolute}.buttons-container{margin:0}.options-button{display:inline-block;line-height:18px;margin:0 2px;min-width:40px;padding:2px 10px;text-align:center;cursor:pointer;border-radius:3px}.options-button-small{padding:2px 5px;min-width:30px}#import-link{line-height:22px;overflow:hidden;position:relative;float:left;height:24px!important;margin-top:-2px;padding-top:2px}#import-settings{position:relative;overflow:hidden;vertical-align:bottom}#import-settings>.import-input{left:0}.import-input{position:absolute;opacity:0;cursor:pointer}label.option>input[type=checkbox],label.option>.riceCheck{margin:4px 2px 0!important;vertical-align:bottom!important}span.option>select,.option>input[type=text]{width:125px}#oneechan-options input[type=text],#oneechan-options select{max-height:20px;margin-top:1px!important;padding:0 3px!important}#oneechan-options textarea{background:transparent!important;border:0!important;height:100%!important;width:100%!important;resize:none}#oneechan-version{opacity:.5;padding-right:5px;padding-left:40px;font-size:x-small}.link-delim{opacity:.4}" + ($SS.conf["Version Fix"] == 3 ? " .qphl{box-shadow:0 0 0 2px rgba(" + $SS.theme.linkColor.rgb + ",.7)!important;outline:0!important}#qr{max-width:355px}#recaptcha_widget{overflow:hidden}#recaptcha_table>tbody>tr:nth-child(1)>td:nth-child(3) #recaptcha_table>tbody>tr:nth-child(2)>td:nth-child(2){display:none!important}#qr>form>div:first-child>.field:not(#dump){width:29.54%!important}#qr textarea.field{min-width:99.5%!important}#qr input[type=submit]{height:24px!important;width:28%;margin-left:1px}#qr input[type=file]{margin:1px}#qr>form #spoilerLabel{text-transform:uppercase;font-size:10px;line-height:19px}.textarea{margin-bottom:1px;margin-top:1px}#qr:not(.has-captcha) textarea{min-height:115px!important}#qr .move:not(span){min-width:260px;padding:2px 2px!important;height:22px!important;line-height:19px!important;text-transform:uppercase;font-size:10px}#qr>form #spoilerLabel{bottom:4px;position:absolute;right:8px;z-index:2}#qr>form input[type=file]{float:right;width:98.6%}#qr .riceCheck,#qr input[type=checkbox]{float:left}:root.expand-inputs #qr>form>div:nth-child(1){display:flex}:root.expand-inputs #qr>form>div:nth-child(1) .field:not(#dump){flex:1;width:0}:root.expand-inputs #qr>form>div:nth-child(1) .field:not(#dump):hover,:root.expand-inputs #qr>form>div:nth-child(1) .field:not(#dump):focus{flex:3}#qr>form>div>.field{margin-left:1px}:root.qr-controls #qr .move .riceCheck,:root.qr-controls #qr .move .autohide{display:none!important}:root.vertical-qr #qr.autohide:not(:hover){width:260px!important}:root.vertical-qr #qr:not(.autohide){transform:translateX(0%)!important}:root.vertical-qr:root.right-sidebar #qr .move{right:81%!important}:root.vertical-qr:root.left-sidebar #qr .move{left:55%!important}:root.mini-sidebar:root.left-sidebar #qr .move{top:170px!important}:root.vertical-qr #qr{top:inherit!important;bottom:30px!important}.vertical-qr:root #qr .move{right:82%!important}:root.vertical-qr #qr .move:not(span){min-width:135px!important}.vertical-qr:root #qr{min-width:299px!important}:root.mini-sidebar:root.right-sidebar #qr .move{right:81%!important;top:85px!important}:root.mini-sidebar:root.left-sidebar #qr .move{left:55%!important;top:85px}:root.mini-sidebar #qr .move:not(span){min-width:135px!important}:root.mini-sidebar #qr label .riceCheck{display:block!important}#globalMessage{color:" + $SS.theme.textColor.hex + "!important}:root:not(.show-ads) .center{display:none!important}.hide_reply_button:not([hidden]){display:inherit!important}#togglePostFormLink{text-align:center}div.navLinks.desktop{margin-bottom:4px}.boardList{display:block;text-align:center}#navbotright,:root.hide-button form[name=post]>h1,#boardNavDesktopFoot .toggleCatalog,:root.show-file-info .fileText,#boardNavDesktopFoot #OneeChanLink{display:none}#navtopright{float:none}.pagelist{margin-bottom:15px}.navLinks.navLinksBot.desktop{margin-bottom:10px}.postInfo{padding:0 6px 2px}#boardNavDesktop{color:" + $SS.theme.headerColor.hex + "!important;margin-bottom:15px;text-align:center}#boardNavDesktopFoot{color:" + $SS.theme.headerColor.hex + "!important;margin-bottom:10px}.riceCheck{margin:0 3px -2px 4px!important}#navlinks{top:135px!important}#overlay{z-index:99}#ihover,#qp,#menu{z-index:5}#updater,#stats{z-index:11}:root.mascot-overlap #mascot img,#mascotprev img{z-index:4}.inline,#qp{padding:0}table.flashListing{margin-bottom:20px}.button{color:" + $SS.theme.linkColor.hex + "!important}.button:hover{color:" + $SS.theme.linkHColor.hex + "!important}.container{margin-left:-5px!important}:root:not(.reply-fit-width) .container{margin-right:10px}div.post{overflow:inherit}div.post div.file .fileThumb{margin-top:3px}#search-box{margin-bottom:1px}#imageType{margin-right:3px}body.is_catalog .panel{background-color:rgba(" + $SS.theme.mainColor.rgb + "," + $SS.theme.replyOp + ")!important}body.is_catalog .button{color:" + $SS.theme.linkColor.hex + "!important}body.is_catalog .button:hover{color:" + $SS.theme.linkHColor.hex + "!important}.hide_thread_button{margin-right:1px}:root.fixed-watcher #watcher{position:fixed!important}#watcher>.move{text-align:center;padding-bottom:5px}.favicon{height:0!important;background-color:transparent!important;background-position:center!important;background-repeat:no-repeat;display:inline-block;padding-top:16px!important;vertical-align:bottom;width:16px!important}.favicon[src$=ico]{background-image:url(\"data:image/svg+xml," + $SS.theme.icons.star + "\")!important}.favicon[src^=data]{opacity:.3;background-image:url(\"data:image/svg+xml," + $SS.theme.icons.star + "\")!important}.menu_button{height:0;overflow:hidden;padding-top:12px;opacity:.6;background-color:rgba(0,0,0,0);background-position:50% 50%;transform:rotate(90deg);background-image:url(\"data:image/svg+xml," + $SS.theme.icons.menuButton + "\")!important}.menu_button:hover{opacity:1;transition:opacity .3s ease-in .1s!important}:root.reply-fit-width .reply .container{padding-right:10px!important}:root.reply-fit-width .menu_button{float:right}:root.reply-fit-width .post .menu_button{opacity:0}:root.reply-fit-width .post:hover .menu_button{opacity:1;transition:opacity .1s ease-in .28s!important}:root.reply-fit-width div.hide_reply_button.stub>a.menu_button,:root.reply-fit-width div.hide_thread_button.hidden_thread>a.menu_button{float:none!important}" : "") + " " + $SS.theme.customCSS + ""; if (reload) $("#ch4SS").text(css); else $(document.head).append($("<style type='text/css' id=ch4SS>").text(css)); }, insertMascot: function() { if ($SS.conf["Hide Mascots in Catalog"] && $SS.location.catalog) { return; } else if ($SS.conf["Hide Mascots in Catalog"] && $(".catalog-mode").exists()) { return; } var createMascot = $("<div id=mascot><img src=" + ($SS.mascot.img.get() !== "none " ? $SS.mascot.img.get() : "") + ">"); if ((div = $("#mascot")).exists()) { div.replace(createMascot); } else { $(document.body).append(createMascot); } }, QRDialogCreationHandler: function(e) { var qr = e.target; $("input[type=checkbox]", qr).riceCheck(); $SS.QRhandled = true; }, NodeInsertionHandler: function(e) { var settings = e.target; $("input[type=checkbox]", settings).riceCheck(); }, /* CONFIG */ Config: { hasGM: typeof GM_deleteValue !== "undefined", init: function() { var parseVal = function(key, val) { if (/^(Selected|Hidden)+\s(Mascots|Themes?)+$/.test(key)) { if (key === "Selected Theme") return parseInt(val); else if (key === "NSFW Theme") return parseInt(val); else if (key === "Selected Mascots" && val === 0) return 0; for (var i = 0, MAX = val.length, ret = []; i < MAX; ++i) ret[i] = parseInt(val[i]); return ret; } return (Array.isArray(val) && typeof val[0] !== "object") ? val[0] : val; }; $SS.conf = []; $SS.exportOptions = {}; for (var key in defaultConfig) { $SS.conf[key] = parseVal(key, this.get(key)); if (!(/^(Hidden|Themes|Selected Mascots|::)/.test(key))) { $SS.exportOptions[key] = $SS.conf[key]; }; }; $SS.conf["Margin Left"] = $SS.conf["Left Margin"] !== 999 ? $SS.conf["Left Margin"] : $SS.conf["Custom Left Margin"]; $SS.conf["Margin Right"] = $SS.conf["Right Margin"] !== 999 ? $SS.conf["Right Margin"] : $SS.conf["Custom Right Margin"]; $SS.conf["Margin Post Message"] = $SS.conf["Post Message Margin"] === 1 ? "4px 16px" : ($SS.conf["Post Message Margin"] === 3 ? "20px 40px" : ""); $SS.conf["Width Decoration"] = $SS.conf["Post Decoration Width"] !== 999 ? $SS.conf["Post Decoration Width"] : $SS.conf["Custom Decoration Width"]; }, get: function(name) { var val = this.hasGM ? GM_getValue(NAMESPACE + name) : localStorage.getItem(NAMESPACE + name); if (val != undefined) return JSON.parse(val); return defaultConfig[name]; }, set: function(name, val) { name = NAMESPACE + name; if (typeof val !== "number") val = JSON.stringify(val); return this.hasGM ? GM_setValue(name, val) : localStorage.removeItem(name, val), localStorage.setItem(name, val); } }, /* OPTIONS */ options: { saveAndClose: false, init: function() { $(document).bind("keydown", $SS.options.keydown); /* seaweedchan */ var a = $("<span class='shortcut brackets-wrap'><a id='OneeChanLink' title='OneeChan Settings' class='fa fa-gears' href='javascript:;'>OneeChan</a></span>").bind("click", $SS.options.show); /* loadletter */ b = $("<span id='OneeChanLink'> [<a title='OneeChan Settings' href='javascript:;'>OneeChan</a>] </span>").bind("click", $SS.options.show); $.asap(function() { return $(".fourchan-x #shortcuts, .fourchan_x, .is_catalog").exists(); }, function() { $(".fourchan-x").exists() ? $(".shortcut.brackets-wrap:last-of-type").before(a) : $("#boardNavDesktop").append(b); }); }, show: function() { if ($("#overlay").exists()) $SS.options.close(); else { var overlay = $("<div id=overlay>").bind("click", $SS.options.close), tOptions = $("<div id='oneechan-options' class=dialog>").bind("click", function(e) { return e.stopPropagation(); }), optionsHTML = "<ul id=options-tabs>" + "<li class='tab-item'><label class='tab-label selected' for=main-select>Main</label></li>" + "<li class='tab-item'><label class='tab-label' for=themes-select>Themes</label></li>" + "<li class='tab-item'><label class='tab-label' for=mascots-select>Mascots</label></li>" + "</ul><div id=options-container><input type=radio class=tab-select name=tab-select id=main-select hidden checked><div id='main-section' class='options-section'>" + "<p class='buttons-container'>" + "<a class='options-button' title='Export your settings as JSON.' name=Export>Export</a><a class='options-button' id='import-settings'><input type=file class='import-input' riced=true accept='application/json'>Import</a><a class='options-button' title='Reset OneeChan settings.' name=resetSettings>Reset</a>" + "<span id=oneechan-version><span>OneeChan</span> v" + VERSION + "<span class=link-delim> | </span>" + "<a href='https://github.com/nebukazar/OneeChan/wiki' id=changelog-link target='_blank' title='Learn about OneeChan.'>Wiki</a><span class=link-delim> | </span>" + "<a href='https://github.com/nebukazar/OneeChan/blob/master/CHANGELOG.md' id=changelog-link target='_blank' title='Read the changelog.'>Changelog</a><span class=link-delim> | </span>" + "<a href='https://github.com/nebukazar/OneeChan/blob/master/CONTRIBUTING.md#reporting-bugs-and-suggestions' id=issues-link target='_blank' title='Report an issue.'>Issues</a></p>", key, val, des; for (key in defaultConfig) { if (/^(Selected|Hidden)+\s(Mascots|Themes?)+$/.test(key)) continue; val = $SS.conf[key]; des = defaultConfig[key][1]; if ((defaultConfig[key][4] === true) && (key === "Custom Left Margin")) { var pVal = $SS.conf[defaultConfig[key][2]]; id = defaultConfig[key][2].replace(/\s/g, "_") + defaultConfig[key][3]; optionsHTML += "<span class='option suboption " + id + "' title=\"" + des + "\"" + (pVal != defaultConfig[key][3] ? "hidden" : "") + "><span class='option-title'>" + key + "</span><input name='Custom Left Margin' type=text value=" + $SS.conf["Custom Left Margin"] + "px></span>"; } else if ((defaultConfig[key][4] === true) && (key === "Custom Right Margin")) { var pVal = $SS.conf[defaultConfig[key][2]]; id = defaultConfig[key][2].replace(/\s/g, "_") + defaultConfig[key][3]; optionsHTML += "<span class='option suboption " + id + "' title=\"" + des + "\"" + (pVal != defaultConfig[key][3] ? "hidden" : "") + "><span class='option-title'>" + key + "</span><input name='Custom Right Margin' type=text value=" + $SS.conf["Custom Right Margin"] + "px></span>"; } else if ((defaultConfig[key][4] === true) && (key === "Custom Decoration Width")) { var pVal = $SS.conf[defaultConfig[key][2]]; id = defaultConfig[key][2].replace(/\s/g, "_") + defaultConfig[key][3]; optionsHTML += "<span class='option suboption " + id + "' title=\"" + des + "\"" + (pVal != defaultConfig[key][3] ? "hidden" : "") + "><span class='option-title'>" + key + "</span><input name='Custom Decoration Width' type=text value=" + $SS.conf["Custom Decoration Width"] + "px></span>"; } else if (val === "header") { optionsHTML += "<label class='option header'><span class='option-title'>" + key + "</span></label>"; } else if (defaultConfig[key][4] === true) // sub-option { var pVal = $SS.conf[defaultConfig[key][2]]; id = defaultConfig[key][2].replace(/\s/g, "_") + defaultConfig[key][3]; optionsHTML += "<label class='option suboption " + id + "' title=\"" + des + "\"" + (pVal != defaultConfig[key][3] ? "hidden" : "") + "><span class='option-title'>" + key + "</span><input" + (val ? " checked" : "") + " name='" + key + "' type=checkbox></label>"; } else if (Array.isArray(defaultConfig[key][2])) // select { var opts = key === "Font Family" ? $SS.fontList || defaultConfig[key][2] : defaultConfig[key][2], cFonts = []; optionsHTML += "<label class=option title=\"" + des + "\"><span class='option-title'>" + key + (key === "Font Family" ? " (<a name=loadSysFonts title='Load fonts from system. Requires flash from external site to run.'>" + ($SS.fontList ? "loaded!" : "load") + "</a>)" : "") + "</span>" + "<select name='" + key + "'" + (defaultConfig[key][3] === true ? " has-suboption" : "") + ">"; for (var i = 0, MAX = opts.length; i < MAX; ++i) { var name, value; if (typeof opts[i] === "object") { name = opts[i].name; value = opts[i].value; } else name = value = opts[i]; if (key === "Font Family") cFonts.push(value); optionsHTML += "<option" + (key === "Font Family" ? " style=\"font-family:" + $SS.formatFont(value) + "!important\"" : "") + " value='" + value + "'" + (value == val ? " selected" : "") + ">" + name + "</option>"; } if (key === "Font Family" && cFonts.indexOf($SS.conf["Font Family"]) == -1) optionsHTML += "<option style=\"font-family:" + $SS.formatFont($SS.conf["Font Family"]) + "!important\" value='" + $SS.conf["Font Family"] + "' selected>" + $SS.conf["Font Family"] + "</option>"; optionsHTML += "</select></label>"; } else if (key === "Font Size") { optionsHTML += "<label class='option visible' title=\"" + des + "\"><span class='option-title'>" + key + "</span>" + "<input type=text name='Font Size' value=" + $SS.conf["Font Size"] + "px></label>"; } else if (key === "Backlink Font Size") { optionsHTML += "<label class='option visible' title=\"" + des + "\"><span class='option-title'>" + key + "</span>" + "<input type=text name='Backlink Font Size' value=" + $SS.conf["Backlink Font Size"] + "px></label>"; } else if (key === "Themes") { optionsHTML += "</div><input type=radio class=tab-select name=tab-select class=tab-select id=themes-select hidden><div id='themes-section' class='options-section'>"; } else if (key === "Mascots") { optionsHTML += "</div><input type=radio class=tab-select name=tab-select id=mascots-select hidden><div id='mascot-section' class='options-section'>"; } else // checkbox optionsHTML += "<label class=option title=\"" + des + "\"><span class='option-title'>" + key + "</span><input" + (val ? " checked" : "") + " name='" + key + "' " + (defaultConfig[key][3] === true ? " has-suboption" : "") + " type=checkbox></label>"; } optionsHTML += "</div></div><div class='options-close'><a class='options-button' name=save>Save</a><a class='options-button' name=cancel>Cancel</a></div>"; tOptions.html(optionsHTML); overlay.append(tOptions); $(".import-input", tOptions).bind("change", function() { var file = this.files[0], reader = new FileReader(), key, imported, val; if (this.files[0].name.match(/\.json$/) == null) { alert('Only JSON files are accepted!'); return; } else if (!confirm('Your current settings will be overwritten, are you sure?')) { return; } reader.onload = (function(tFile) { return function(e) { try { imported = JSON.parse(e.target.r###lt); } catch (err) { alert("Invalid settings file!"); return; } for (key in imported) { val = imported[key]; $SS.Config.set(key, val); } if (confirm('Import successful. Refresh now?')) { return window.location.reload(); } } })(file); reader.readAsText(file); }); $("a[name=Export]", tOptions).bind("click", function() { if ($("a[download]", tOptions).exists()) return; var exportalert = $("<a class='options-button' download='OneeChan v" + VERSION + " Settings.json' href='data:application/json," + encodeURIComponent(JSON.stringify($SS.exportOptions, null, 2)) + "'>Save me!").bind("click", $SS.options.close); return $(this).replace(exportalert); }); // Reset settings $("a[name=resetSettings]", tOptions).bind("click", function() { var confirmReset = confirm('Your current OneeChan settings will be wiped, are you sure?'); if (confirmReset) { if (typeof GM_deleteValue !== "undefined") { var keys = GM_listValues(); for (var i = 0, key = null; key = keys[i]; i++) { GM_deleteValue(key); } } else if ($SS.browser.webkit) { Object.keys(localStorage).forEach(function(key) { if (/^(?:OneeChan)/.test(key)) { localStorage.removeItem(key); } }) } alert('Your OneeChan settings have been reset. Reloading.'); return window.location.reload(); } else return; }); // options window $(".tab-label", tOptions).bind("click", function(e) { if ($(this).hasClass("selected")) return; $(".tab-label.selected").removeClass("selected"); $(this).addClass("selected"); }); $("[has-suboption]", tOptions).bind("change", function() { var id = this.name.replace(/\s/g, "_") + $(this).val(), sub = $("." + id); if (sub.exists()) sub.each(function() { $(this).show(); }); else $("[class*='" + this.name.replace(/\s/g, "_") + "']").each(function() { $(this).hide(); }); }); $("a[name=save]", tOptions).bind("click", function() { $SS.options.saveAndClose = true; $SS.options.save(); $SS.options.saveAndClose = false; }); $("a[name=cancel]", tOptions).bind("click", $SS.options.close); // main tab $("input[name='Font Size']", tOptions).bind("keydown", function(e) { var val = parseInt($(this).val()), bitmap = $(this).parent().nextSibling().children("input[name='Bitmap Font']").val(); if (e.keyCode === 38 && (val < MAX_FONT_SIZE || bitmap)) $(this).val(++val + "px"); else if (e.keyCode === 40 && (val > MIN_FONT_SIZE || bitmap)) $(this).val(--val + "px"); }); if (!$SS.fontList) $("a[name=loadSysFonts]", tOptions).bind("click", $SS.options.loadSystemFonts); // themes tab $SS.options.createThemesTab(tOptions); // mascots tab $SS.options.createMascotsTab(tOptions); return $(document.body).append(overlay); } }, createThemesTab: function(tOptions) { var themes = $("#themes-section", tOptions).html(""), p = $("<p class='buttons-container'>"); p.append($("<a class='options-button' name=addTheme title='Create a new theme.'>Create", tOptions).bind("click", $SS.options.showTheme)); p.append($("<a class='options-button' href='https://github.com/Nebukazar/OneeChan/wiki/Custom-Themes' title='Learn more about custom themes and download new ones.' target='_blank'>Custom Themes")); p.append($("<div id='import-link' title='Import a new theme (.json) file.'>").append($("<input type=file class='import-input' riced=true>") .bind("change", function() { var file = this.files[0], reader = new FileReader(), val, first, valid = true, theme, div, index, imported; reader.onload = (function(tFile) { return function(e) { try { theme = JSON.parse(e.target.r###lt); } catch (err) { alert("Invalid theme file!"); return; } /* Check if this is an OneeChan v5 file, do nothing if so */ if (theme["headerColor"] !== undefined) {} /* Old OneeChan */ else if (theme["navOp"] !== undefined) { theme.unreadColor = theme["jlinkColor"]; theme.headerColor = theme["textColor"]; theme.headerBGColor = theme["mainColor"]; theme.headerLColor = theme["linkColor"]; theme.headerLHColor = theme["linkHColor"]; theme.boardColor = theme["textColor"]; } /* 4chan Style Script */ else if (theme["timeColor"] !== undefined) { theme.replyOp = "1.0"; theme.navOp = "0.9"; theme.unreadColor = theme["jlinkColor"]; theme.headerColor = theme["textColor"]; theme.headerBGColor = theme["mainColor"]; theme.headerLColor = theme["linkColor"]; theme.headerLHColor = theme["linkHColor"]; theme.boardColor = theme["textColor"]; theme.bgImg = $SS.validImageURL(theme["bgImg"]) ? theme["bgImg"] : false; } /* Appchan X */ else if (theme["Theme"] !== undefined) { theme.name = theme["Theme"]; theme.authorName = theme["Author"]; theme.authorTrip = theme["Author Tripcode"]; theme.replyOp = "1.0"; theme.navOp = "0.9"; theme.bgImg = theme["Background Image"]; theme.mainColor = $SS.colorToHex(theme["Reply Background"]); theme.textColor = $SS.colorToHex(theme["Text"]); theme.linkColor = $SS.colorToHex(theme["Links"]); theme.linkHColor = $SS.colorToHex(theme["Hovered Links"]); theme.headerColor = $SS.colorToHex(theme["Text"]); theme.headerBGColor = $SS.colorToHex(theme["Navigation Background"]); theme.headerLColor = $SS.colorToHex(theme["Navigation Links"]); theme.headerLHColor = $SS.colorToHex(theme["Hovered Navigation Links"]); theme.boardColor = $SS.colorToHex(theme["Board Title"]); theme.brderColor = $SS.colorToHex(theme["Reply Border"]); theme.inputColor = $SS.colorToHex(theme["Input Background"]); theme.inputbColor = $SS.colorToHex(theme["Input Border"]); theme.bgColor = $SS.colorToHex(theme["Background Color"]); theme.blinkColor = $SS.colorToHex(theme["Backlinks"]); theme.unreadColor = $SS.colorToHex(theme["Links"]); theme.nameColor = $SS.colorToHex(theme["Names"]); theme.tripColor = $SS.colorToHex(theme["Tripcodes"]); theme.titleColor = $SS.colorToHex(theme["Subjects"]); theme.quoteColor = $SS.colorToHex(theme["Greentext"]); theme.qlColor = $SS.colorToHex(theme["Quotelinks"]); theme.replybgHLColor = $SS.colorToHex(theme["Highlighted Reply Background"]); theme.replyslctColor = $SS.colorToHex(theme["Highlighted Reply Background"]); theme.customCSS = theme["Custom CSS"]; } /* Can't be exported from the main scripts, so toss an error */ else { alert("Invalid theme file!"); return; } index = $SS.conf["Themes"].push(theme); theme = new $SS.Theme(--index); div = theme.preview(); $("#overlay #themes-section").append(div); div.fire("click").scrollIntoView(true); } })(file); reader.readAsText(file); })).append($("<span class='options-button'>Import"))); p.append($("<a class='options-button' name=restoreThemes title='Restore hidden default themes'>Restore", tOptions) .bind("click", function() { $SS.conf["Hidden Themes"] = []; $("#themes-section>div[hidden]").show(); }) ); if ($SS.conf["Hidden Themes"].length === 0) $("a[name=restoreThemes]", p).hide(); themes.append(p); for (var i = 0, MAX = $SS.conf["Themes"].length, tTheme; i < MAX; ++i) { tTheme = new $SS.Theme(i); themes.append(tTheme.preview()); } }, createMascotsTab: function(tOptions) { var mascots = $("#mascot-section", tOptions).html(""), p = $("<p class='buttons-container'>"); p.append($("<a class='options-button' name=addMascot title='Add a new mascot.'>Add", tOptions).bind("click", $SS.options.showMascot)); p.append($("<a class='options-button' href='http://appchan.booru.org/' title='Get more mascots. Possibly NSFW.' target='_blank'>More Mascots")); p.append($("<a class='options-button' name=restoreMascots title='Restore hidden default mascots'>Restore", tOptions) .bind("click", function() { $SS.conf["Hidden Mascots"] = []; $("#mascot-section>div[hidden]").show(); }) ); if ($SS.conf["Hidden Mascots"].length === 0) $("a[name=restoreMascots]", p).hide(); p.append($("<a class='options-button' name=selectAll>Select All", tOptions) .bind("click", function() { $("#mascot-section>div:not([hidden])").each(function() { $(this).addClass("selected") }); })); p.append($("<a class='options-button' name=selectNone>Select None", tOptions) .bind("click", function() { $("#mascot-section>div").each(function() { $(this).removeClass("selected") }); })); mascots.append(p); for (var i = 0, MAX = $SS.conf["Mascots"].length, tMascot; i < MAX; ++i) { tMascot = new $SS.Mascot(i); mascots.append(tMascot.preview()); } }, close: function() { return $("#overlay").remove(); }, keydown: function(e) { if (e.ctrlKey && e.keyCode === 112) { e.preventDefault(); e.stopPropagation(); $SS.options.show(); } }, loadSystemFonts: function(evt) { var loadFontBTN = $(evt.target), getFontMessage; $(document.head).append($('<script type="text/javascript">' + "function populateFontList(fontArr)" + "{" + "var fontList = [];" + "for (var key in fontArr)" + "fontList.push(fontArr[key]);" + "window.postMessage(fontList, '*');" + "}")); window.addEventListener("message", getFontMessage = function(e) { $SS.fontList = e.data; var fontSelect = $("<select name='Font Family'>"); for (var i = 0, MAX = $SS.fontList.length; i < MAX; ++i) { var name, value; name = value = $SS.fontList[i]; fontSelect.append($("<option" + " style=\"font-family:" + $SS.formatFont(value) + "!important\"" + " value='" + value + "'" + (value == $SS.conf["Font Family"] ? " selected=true" : "") + ">" + name)); } $("select[name='Font Family']").before(fontSelect).remove(); $("#fontListSWF").remove(); window.removeEventListener("message", getFontMessage); loadFontBTN.text("loaded!").unbind("click", $SS.options.loadSystemFonts); }, false); $(document.body).append($("<div id=fontListSWF hidden><object type='application/x-shockwave-flash'" + " data='" + fontListSWF + "'><param name=allowScriptAccess value=always></object>")); return loadFontBTN.text("loading..."); }, save: function() { var div = $("#oneechan-options"), themes = [], mascots = [], selectedMascots = [], nsfwTheme, selectedTheme; // Save main $("#oneechan-options input[name]:not(.tab-select), #oneechan-options select").each(function() { var name = $(this).attr("name"), val = $(this).val(); if (name === "Font Size") { val = parseInt(val); if (!$("input[name='Bitmap Font']", div).val()) val = Math.max(Math.min(val, MAX_FONT_SIZE), MIN_FONT_SIZE); } else if (name === "Custom Right Margin") { val = parseInt(val); } else if (name === "Custom Left Margin") { val = parseInt(val); } else if (name === "Custom Decoration Width") { val = parseInt(val); } else if (name === "Backlink Font Size") { val = parseInt(val); } $SS.Config.set($(this).attr("name"), val); }); // Save Themes $("#oneechan-options #themes-section>div").each(function(index) { var oldIndex = parseInt(this.id.substr(5)); if (!$SS.conf["Themes"][oldIndex].default) themes.push($SS.conf["Themes"][oldIndex]); }); selectedTheme = (selectedTheme = $("#oneechan-options #themes-section>div.selected")).exists() ? parseInt(selectedTheme.attr("id").substr(5)) : 0; nsfwTheme = (nsfwTheme = $("#oneechan-options #themes-section>div.nsfw")).exists() ? parseInt(nsfwTheme.attr("id").substr(5)) : 0; $SS.Config.set("Themes", themes); $SS.Config.set("Selected Theme", selectedTheme); $SS.Config.set("NSFW Theme", nsfwTheme); $SS.Config.set("Hidden Themes", $SS.conf["Hidden Themes"]); // Save Mascots $("#oneechan-options #mascot-section>div").each(function(index) { var oldIndex = parseInt(this.id.substr(6)); if ($(this).hasClass("selected")) selectedMascots.push(index); if (!$SS.conf["Mascots"][oldIndex].default) mascots.push($SS.conf["Mascots"][oldIndex]); }); $SS.Config.set("Mascots", mascots); $SS.Config.set("Selected Mascots", selectedMascots); $SS.Config.set("Hidden Mascots", $SS.conf["Hidden Mascots"]); if ($SS.options.saveAndClose) $SS.options.close(); return $SS.init(true); }, showTheme: function(tIndex) { var div, overlay; if (typeof tIndex === "number") { var bEdit = true, tEdit = $SS.conf["Themes"][tIndex], RPA, themeR, themePY, themePX, themeA; if (tEdit.bgImg && tEdit.bgRPA) { RPA = tEdit.bgRPA.split(" "); themeR = RPA[0]; themePY = RPA[1]; themePX = RPA[2]; themeA = RPA[3]; } } div = $("<div id='add-theme' class='dialog'>"); var innerHTML = "<label>" + "<span class='option-title'>Theme Name:</span><input type=text name=name value='" + (bEdit ? tEdit.name : "") + "'>" + "</label><label>" + "<span class='option-title'>Author Name:</span><input type=text name=authorName value='" + (bEdit ? (tEdit.authorName !== undefined ? tEdit.authorName : "") : "") + "'>" + "</label><label>" + "<span class='option-title'>Author Tripcode:</span><input type=text name=authorTrip value='" + (bEdit ? (tEdit.authorTrip !== undefined ? tEdit.authorTrip : "") : "") + "'>" + "</label><label>" + "<span class='option-title'>BG Image:</span><input type=text name=bgImg value=" + (bEdit ? ($SS.validImageURL(tEdit.bgImg) ? tEdit.bgImg + "" : ($SS.validBase64(tEdit.bgImg) ? tEdit.bgImg : "")) : "") + "></label><label>" + "<span class='option-title'>BG Repeat:</span><select name=bgR>" + "<option" + (bEdit && themeR === "no-repeat" ? " selected" : "") + ">no-repeat</option>" + "<option" + (bEdit && themeR === "repeat" ? " selected" : "") + ">repeat</option>" + "<option" + (bEdit && themeR === "repeat-x" ? " selected" : "") + ">repeat-x</option>" + "<option" + (bEdit && themeR === "repeat-y" ? " selected" : "") + ">repeat-y</option>" + "</select></label><label>" + "<span class='option-title'>BG Attachment:</span><select name=bgA>" + "<option" + (bEdit && themeA === "fixed" ? " selected" : "") + ">fixed</option>" + "<option" + (bEdit && themeA === "scroll" ? " selected" : "") + ">scroll</option>" + "</select></label><label>" + "<span class='option-title'>BG Position-X:</span><select name=bgPX>" + "<option" + (bEdit && themePX === "left" ? " selected" : "") + ">left</option>" + "<option" + (bEdit && themePX === "center" ? " selected" : "") + ">center</option>" + "<option" + (bEdit && themePX === "right" ? " selected" : "") + ">right</option>" + "</select></label><label>" + "<span class='option-title'>BG Position-Y:</span><select name=bgPY>" + "<option" + (bEdit && themePY === "top" ? " selected" : "") + ">top</option>" + "<option" + (bEdit && themePY === "center" ? " selected" : "") + ">center</option>" + "<option" + (bEdit && themePY === "bottom" ? " selected" : "") + ">bottom</option>" + "</select></label><label>" + "<span class='option-title'>Reply Opacity:</span><input type=text name=replyOp value='" + (bEdit ? tEdit.replyOp : "1.0") + "'></label><label>" + "<span class='option-title'>Header Opacity:</span><input type=text name=navOp value='" + (bEdit ? tEdit.navOp : "0.9") + "'>" + "</label>"; for (var i = 0, MAX = themeInputs.length; i < MAX; ++i) innerHTML += "<label><span class='option-title'>" + themeInputs[i].dName + ":</span>" + "<input type=text class=jsColor name=" + themeInputs[i].name + " value=" + (bEdit ? tEdit[themeInputs[i].name] : "") + "></label>"; innerHTML += "<label id=customCSS><span class='option-title'>Custom CSS:</span><textarea name=customCSS>" + (bEdit ? tEdit.customCSS || "" : "") + "</textarea>" + "</label><div>" + "<a class='options-button' name=export>Export</a>" + "<a class='options-button' name=" + (bEdit ? "edit" : "add") + ">Save</a><a class='options-button' name=cancel>Cancel</a></div>"; div.html(innerHTML); $(".jsColor", div).jsColor(); overlay = $("<div id=overlay2>").append(div); $("a[name=export]", div).bind("click", function() { var theme = $SS.options.addTheme(tIndex, true); if ($("a[download]", div).exists()) return; var exportalert = $("<a class='options-button'download='" + theme.name + ".json' href='data:application/json," + encodeURIComponent(JSON.stringify(theme)) + "'>Save me!"); return $(this).replace(exportalert); }); if (bEdit) { $("a[name=edit]", div).bind("click", function() { $SS.options.addTheme(tIndex); $("#overlay").removeClass("previewing"); }); $("#overlay").addClass("previewing"); } else { $("a[name=add]", div).bind("click", $SS.options.addTheme); $("#overlay").addClass("previewing"); } $("a[name=cancel]", div).bind("click", function() { $("#overlay").removeClass("previewing"); $("#overlay2").remove(); }); if (bEdit) $("input,textarea,select", div).bind("change", tEdit.mHandler = function() { tEdit.modified = true; $("input,textarea,select", $("#addTheme")).unbind("change", tEdit.mHandler); }); return $(document.body).append(overlay); }, addTheme: function(tIndex, exp) { var overlay = $("#overlay2"), tTheme = {}, makeRPA = function() { var RPA = []; RPA.push($("select[name=bgR]", overlay).val()); RPA.push($("select[name=bgPY]", overlay).val()); RPA.push($("select[name=bgPX]", overlay).val()); RPA.push($("select[name=bgA]", overlay).val()); return RPA.join(" "); }, bEdit = typeof tIndex === "number", tEdit = bEdit ? $SS.conf["Themes"][tIndex] : null, error = false, div; if (!exp && bEdit && !tEdit.modified) return overlay.remove(); $("input[type=text],textarea", overlay).each(function() { var val; if (this.name === "bgImg") { var b64 = $("input[name=customIMGB64]", overlay); val = b64.exists() ? decodeURIComponent(b64.val()) : this.value; if (val !== "" && !$SS.validImageURL(val) && !$SS.validBase64(val)) { error = true; return alert("Not a valid image URL/base64!"); } val = $SS.cleanBase64(val); } else if (this.name === "name") { val = this.value; if (bEdit && tEdit.default && tEdit.name === val) val += " [Modded]" } else val = this.value; if (val !== "") tTheme[this.name] = val; }); if (error) return; if (tTheme.bgImg) tTheme.bgRPA = makeRPA(); if (exp) return tTheme; if (bEdit && !tEdit.default) { $SS.conf["Themes"][tIndex] = tTheme; tTheme = new $SS.Theme(tIndex); div = $("#theme" + tIndex, $("#overlay")); div.replace(tTheme.preview()); } else { tTheme.author = "You"; tIndex = $SS.conf["Themes"].push(tTheme); tTheme = new $SS.Theme(--tIndex); div = tTheme.preview(); $("#overlay #themes-section").append(div); } div.fire("click").scrollIntoView(true); $("#overlay").removeClass("previewing"); return overlay.remove(); }, deleteTheme: function(tIndex) { if ($SS.conf["Themes"][tIndex].default && $SS.conf["Hidden Themes"].push(tIndex) === 1) $("#themes-section a[name=restoreThemes]").show(); return $SS.conf["Themes"][tIndex].default ? $("#theme" + tIndex).removeClass("selected").hide() : $("#theme" + tIndex).remove(); }, showMascot: function(mIndex) { var div, overlay, preview; if (typeof mIndex === "number") var bEdit = true, mEdit = $SS.conf["Mascots"][mIndex]; if (bEdit && $SS.validImageURL(mEdit.img)) { preview = $("<div id=mascotprev>").html((bEdit && ($SS.validImageURL(mEdit.img)) ? "<img src='" + mEdit.img + "' " + "style='width: " + (mEdit.width !== undefined ? mEdit.width : "auto") + " !important;" + (bEdit && (mEdit.maxwidth && mEdit.maxwidth !== undefined) ? "max-width: 300px !important;" : "") + " height: " + (mEdit.height !== undefined ? mEdit.height : "auto") + " !important; margin-bottom: " + (mEdit.offset !== undefined ? mEdit.offset : 0) + "px !important; margin-" + ($SS.conf["Sidebar Position"] === 2 ? "left" : "right") + ": " + (mEdit.hoffset !== undefined ? mEdit.hoffset : 0) + "px !important;" + (bEdit && (mEdit.flip && mEdit.flip !== undefined) ? "transform: scaleX(-1); -webkit-transform: scaleX(-1);" : "") + "'>" : "")); } else if (bEdit && $SS.validBase64(mEdit.img)) { preview = $("<div id=mascotprev>").html((bEdit && ($SS.validBase64(mEdit.img)) ? "<img src='data:image/png;base64," + mEdit.img + "' " + "style='width: " + (mEdit.width !== undefined ? mEdit.width : "auto") + " !important;" + (bEdit && (mEdit.maxwidth && mEdit.maxwidth !== undefined) ? "max-width: 300px !important;" : "") + " height: " + (mEdit.height !== undefined ? mEdit.height : "auto") + " !important; margin-bottom: " + (mEdit.offset !== undefined ? mEdit.offset : 0) + "px !important; margin-" + ($SS.conf["Sidebar Position"] === 2 ? "left" : "right") + ": " + (mEdit.hoffset !== undefined ? mEdit.hoffset : 0) + "px !important;" + (bEdit && (mEdit.flip && mEdit.flip !== undefined) ? "transform: scaleX(-1); -webkit-transform: scaleX(-1);" : "") + "'>" : "")); }; div = $("<div id='add-mascot' class='dialog'>").html("<label class='add-mascot-label' title='Set the name of the mascot'><span class='option-title'>Mascot Name:</span>" + "<input class='mascot-input mascot-name' type=text name=mName value='" + (bEdit && mEdit.name !== undefined ? mEdit.name : "Chinese Girl Cartoon") + "'></label>" + "<label class='add-mascot-label'><span class='option-title' title='URL of the mascot. HTTPS links are recommended.'>Image URL:</span><input class='mascot-input image' type=text name=customIMG value='" + (bEdit ? ($SS.validImageURL(mEdit.img) || $SS.validBase64(mEdit.img) ? mEdit.img + "'" : "'") : "'") + "></label>" + "<label class='add-mascot-label' title='Set the height. Use auto for the full size.'><span class='option-title'>Height:</span>" + "<input class='mascot-input height' type=text name=mHeight value='" + (bEdit && mEdit.height !== undefined ? mEdit.height : "auto") + "'></label>" + "<label class='add-mascot-label' title='Set the width. Use 300px to fit to sidebar, or auto for the original size.'><span class='option-title'>Width:</span>" + "<input class='mascot-input width' type=text name=mWidth value='" + (bEdit && mEdit.width !== undefined ? mEdit.width : "auto") + "'></label>" + "<label class='add-mascot-label' title='Downscale images greater than the sidebar (300px).'><span class='option-title' title='Downscale images greater than the sidebar (300px).'>Downscale only:</span>" + "<input type=checkbox name=mMWidth" + (bEdit && (mEdit.maxwidth && mEdit.maxwidth !== undefined) ? " checked" : "") + "></label>" + "<label class='add-mascot-label' title='Set the vertical offset. A negative number will push the image down.'><span class='option-title'>Vertical Offset:</span>" + "<input class='mascot-input offset' type=text name=mOffset value='" + (bEdit && mEdit.offset !== undefined ? mEdit.offset : 0) + "px'></label>" + "<label class='add-mascot-label' title='Set the horizontal offset. A positive number will push the image away from the side.'><span class='option-title'>Horizontal Offset:</span>" + "<input class='mascot-input hoffset' type=text name=mHOffset value='" + (bEdit && mEdit.hoffset !== undefined ? mEdit.hoffset : 0) + "px'></label>" + "<label class='add-mascot-label' title='Flip the mascot image horizontally.'><span class='option-title' title='Flip the mascot image horizontally.'>Flip Image:</span>" + "<input type=checkbox name=mFlip" + (bEdit && (mEdit.flip && mEdit.flip !== undefined) ? " checked" : "") + "></label>" + "<label class='add-mascot-label' title='List of boards to display this mascot on, seperated by commas. Example: a,c,g,v,jp'><span class='option-title'>Boards:</span>" + "<input class='mascot-input mascot-boards' type=text name=mBoards placeholder='Example: a,c,g,v,jp' value='" + (bEdit && mEdit.boards ? mEdit.boards : "") + "'></label>" + "<div id='mascot-buttons-container'>" + "<a class=options-button name=apply " + (bEdit ? "" : "hidden") + " title='Save and Preview'>Apply</a><a class='options-button' name=" + (bEdit ? "edit" : "add") + " title='Save and Close'>Save</a><a class='options-button' name=cancel title='Cancel'>Cancel</a></div></div>"); overlay = $("<div id=overlay2>"); $("input[type=checkbox]", div).riceCheck(); if (bEdit) { $("a[name=edit]", div).bind("click", function() { $SS.options.addMascot(mIndex); }); $("a[name=apply]", div).bind("click", function() { $SS.options.editMascot(mIndex); }); $(document.body).append(preview); $("#overlay").addClass("previewing"); $("#mascot").addClass("previewing"); } else $("a[name=add]", div).bind("click", $SS.options.addMascot); $("a[name=cancel]", div).bind("click", function() { div.remove(); overlay.remove(); preview.remove(); $("#mascot").removeClass("previewing"); $("#overlay").removeClass("previewing"); }); $(document.body).append(div); $(document.body).append(overlay); }, addMascot: function(mIndex) { var overlay = $("#overlay2"), mascotAdd = $("#add-mascot"), preview = $("#mascotprev"), bSetPos, cIMG, cOffset, cHOffset, cName, cWidth, cMWidth, cHeight, cFlip, tMascot, bDefault; cIMG = decodeURIComponent($("input[name=customIMGB64]", mascotAdd).val() || $("input[name=customIMG]", mascotAdd).val()); cOffset = parseInt($("input[name=mOffset]", mascotAdd).val()); cHOffset = parseInt($("input[name=mHOffset]", mascotAdd).val()); cName = $("input[name=mName]", mascotAdd).val(); cFlip = $("input[name=mFlip]", mascotAdd).val(); cWidth = $("input[name=mWidth]", mascotAdd).val(); cMWidth = $("input[name=mMWidth]", mascotAdd).val(); cHeight = $("input[name=mHeight]", mascotAdd).val(); cBoards = $("input[name=mBoards]", mascotAdd).val(); if (!$SS.validImageURL(cIMG) && !$SS.validBase64(cIMG)) return alert("Not a valid image URL/base64!"); cIMG = $SS.cleanBase64(cIMG); bDefault = $SS.conf["Mascots"][mIndex] != undefined && $SS.conf["Mascots"][mIndex].default; if (typeof mIndex === "number" && !bDefault) { $SS.conf["Mascots"][mIndex].img = cIMG; $SS.conf["Mascots"][mIndex].flip = cFlip; $SS.conf["Mascots"][mIndex].maxwidth = cMWidth; if (cBoards !== "") $SS.conf["Mascots"][mIndex].boards = cBoards; else delete $SS.conf["Mascots"][mIndex].boards; $SS.conf["Mascots"][mIndex].offset = cOffset; $SS.conf["Mascots"][mIndex].hoffset = cHOffset; $SS.conf["Mascots"][mIndex].name = cName; $SS.conf["Mascots"][mIndex].width = cWidth; $SS.conf["Mascots"][mIndex].maxwidth = cMWidth; $SS.conf["Mascots"][mIndex].height = cHeight; tMascot = new $SS.Image(cIMG); $("#mascot" + mIndex).attr("style", "background: url('" + tMascot.get() + "')"); } else { var tMascot = { img: cIMG, flip: cFlip, maxwidth: cMWidth, boards: (cBoards === "" ? undefined : cBoards) }; tMascot.offset = cOffset; tMascot.hoffset = cHOffset; tMascot.name = cName; tMascot.width = cWidth; tMascot.maxwidth = cMWidth; tMascot.height = cHeight; if (bDefault) $SS.options.deleteMascot(mIndex); mIndex = $SS.conf["Mascots"].push(tMascot); tMascot = new $SS.Mascot(--mIndex).preview(); $("#mascot-section").append(tMascot); tMascot.fire("click").scrollIntoView(true); } $("#overlay").removeClass("previewing"); $("#mascot").removeClass("previewing"); preview.remove(); mascotAdd.remove(); return overlay.remove(); }, editMascot: function(mIndex) { var overlay = $("#overlay2"), mascotAdd = $("#add-mascot"), preview = $("#mascotprev"), bSetPos, cIMG, cOffset, cHOffset, cName, cWidth, cMWidth, cHeight, cFlip, tMascot, bDefault; cIMG = decodeURIComponent($("input[name=customIMGB64]", mascotAdd).val() || $("input[name=customIMG]", mascotAdd).val()); cOffset = parseInt($("input[name=mOffset]", mascotAdd).val()); cHOffset = parseInt($("input[name=mHOffset]", mascotAdd).val()); cName = $("input[name=mName]", mascotAdd).val(); cFlip = $("input[name=mFlip]", mascotAdd).val(); cWidth = $("input[name=mWidth]", mascotAdd).val(); cMWidth = $("input[name=mMWidth]", mascotAdd).val(); cHeight = $("input[name=mHeight]", mascotAdd).val(); cBoards = $("input[name=mBoards]", mascotAdd).val(); if (!$SS.validImageURL(cIMG) && !$SS.validBase64(cIMG)) return alert("Not a valid image URL/base64!"); bDefault = $SS.conf["Mascots"][mIndex] != undefined && $SS.conf["Mascots"][mIndex]; if (typeof mIndex === "number" && !bDefault) { $SS.conf["Mascots"][mIndex].img = cIMG; $SS.conf["Mascots"][mIndex].flip = cFlip; $SS.conf["Mascots"][mIndex].maxwidth = cMWidth; if (cBoards !== "") $SS.conf["Mascots"][mIndex].boards = cBoards; else delete $SS.conf["Mascots"][mIndex].boards; $SS.conf["Mascots"][mIndex].offset = cOffset; $SS.conf["Mascots"][mIndex].hoffset = cHOffset; $SS.conf["Mascots"][mIndex].name = cName; $SS.conf["Mascots"][mIndex].width = cWidth; $SS.conf["Mascots"][mIndex].maxwidth = cMWidth; $SS.conf["Mascots"][mIndex].height = cHeight; tMascot = new $SS.Image(cIMG); $("#mascot" + mIndex).attr("style", "background: url('" + tMascot.get() + "')"); } else { var tMascot = { img: cIMG, flip: cFlip, maxwidth: cMWidth, boards: (cBoards === "" ? undefined : cBoards) }; tMascot.offset = cOffset; tMascot.hoffset = cHOffset; tMascot.name = cName; tMascot.width = cWidth; tMascot.maxwidth = cMWidth; tMascot.height = cHeight; if (bDefault) $SS.options.deleteMascot(mIndex); mIndex = $SS.conf["Mascots"].push(tMascot); tMascot = new $SS.Mascot(--mIndex).preview(); $("#mascot-section").append(tMascot); tMascot.fire("click").scrollIntoView(true); } preview.remove(); mascotAdd.remove(); overlay.remove(); return $SS.options.showMascot($SS.conf["Mascots"].length - 1); }, deleteMascot: function(mIndex) { if ($SS.conf["Mascots"][mIndex].default && $SS.conf["Hidden Mascots"].push(mIndex) === 1) $("#mascot-section a[name=restoreMascots]").show(); return $SS.conf["Mascots"][mIndex].default ? $("#mascot" + mIndex).removeClass("selected").hide() : $("#mascot" + mIndex).remove(); } }, /* THEMES */ Themes: { defaults: [{ name: "Vimyanized Dark", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "090d0f", mainColor: "0d1114", brderColor: "0b1316", inputColor: "090d0f", inputbColor: "0d1114", blinkColor: "4797cc", unreadColor: "4270b2", linkColor: "53bdb1", linkHColor: "3090b5", qlColor: "53bdb1", nameColor: "d63e34", quoteColor: "96c83b", textColor: "f8f8f8", tripColor: "d4b63c", titleColor: "b88cd1", headerColor: "f8f8f8", headerLColor: "53bdb1", headerLHColor: "3090b5", headerBGColor: "0d1114", boardColor: "f8f8f8", postHLColor: "d4b63c", quotesYouHLColor: "d4b63c", ownPostHLColor: "d4b63c", threadHLColor: "b88cd1", replybgHLColor: "090d10", replyslctColor: "d4b63c" }, { name: "Muted", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "ffffff", mainColor: "f5f2e9", brderColor: "dddddd", inputColor: "ffffff", inputbColor: "dddddd", blinkColor: "bc312a", unreadColor: "bc312a", linkColor: "bc312a", linkHColor: "8e2220", qlColor: "bc312a", nameColor: "2c64a0", quoteColor: "789922", textColor: "393735", tripColor: "cc6563", titleColor: "111111", headerColor: "393735", headerLColor: "bc312a", headerLHColor: "8e2220", headerBGColor: "f5f2e9", boardColor: "bc312a", postHLColor: "cc6563", quotesYouHLColor: "2c64a0", ownPostHLColor: "cc6563", threadHLColor: "111111", replybgHLColor: "d9d6cd", replyslctColor: "cc6563" }, { name: "Surf", //Inspired by Blue Tone authorName: "Nebukazar", authorTrip: "!/Am.NeBUqQ", "default": true, bgImg: false, replyOp: "1.0", navOp: "1.0", mainColor: "242424", brderColor: "242424", inputColor: "1b1b1b", inputbColor: "252525", headerBGColor: "242424", headerColor: "ffffff", boardColor: "ffffff", bgColor: "1b1b1b", textColor: "ffffff", blinkColor: "20548f", headerLColor: "20548f", headerLHColor: "ffffff", linkColor: "808080", linkHColor: "ffffff", qlColor: "808080", nameColor: "20548f", tripColor: "808080", titleColor: "808080", quoteColor: "07992d", unreadColor: "ffffff", postHLColor: "292929", quotesYouHLColor: "ffffff", ownPostHLColor: "ffffff", threadHLColor: "808080", replybgHLColor: "121212", replyslctColor: "ffffff" }, { name: "Stilig", authorName: "Myson", authorTrip: "!RiDeag.gG.", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", mainColor: "ffffff", brderColor: "ebebeb", inputColor: "ffffff", inputbColor: "dedede", headerBGColor: "3d444e", headerColor: "ffffff", boardColor: "999999", bgColor: "f2f2f2", textColor: "717171", blinkColor: "999999", unreadColor: "999999", headerLColor: "babcbe", headerLHColor: "999999", linkColor: "999999", linkHColor: "5f5f65", qlColor: "999999", nameColor: "49637d", tripColor: "5f5f65", titleColor: "7a7f88", quoteColor: "009933", postHLColor: "5f5f65", quotesYouHLColor: "ff4a3e", ownPostHLColor: "5f5f65", threadHLColor: "7a7f88", replybgHLColor: "e6e6e6", replyslctColor: "5f5f65", customCSS: ".reply, :root.op-background .postContainer.opContainer {box-shadow: -1px 1px 1px rgba(0,0,0,.08);}" }, { name: "Minimalistic Mayhem", authorName: "Mayhem", authorTrip: "!MayhemxaEo", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "191919", mainColor: "222222", brderColor: "292929", inputColor: "222222", inputbColor: "151515", blinkColor: "897399", unreadColor: "897399", linkColor: "897399", linkHColor: "c617e6", qlColor: "897399", nameColor: "a34443", quoteColor: "8ba446", textColor: "bbbbbb", tripColor: "96562c", titleColor: "987d3e", headerColor: "bbbbbb", headerLColor: "897399", headerLHColor: "c617e6", headerBGColor: "222222", boardColor: "bbbbbb", postHLColor: "96562c", quotesYouHLColor: "96562c", ownPostHLColor: "96562c", threadHLColor: "987d3e", replybgHLColor: "141414", replyslctColor: "96562c" }, { name: "Blackboard", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "0a0d1c", mainColor: "0c1021", brderColor: "0e1228", inputColor: "0c1021", inputbColor: "080b16", blinkColor: "54b12e", unreadColor: "8da6ce", linkColor: "fbde2d", linkHColor: "4b65cc", qlColor: "fbde2d", nameColor: "8da6ce", quoteColor: "9acf08", textColor: "f8f8f8", tripColor: "ff6400", titleColor: "ff6400", headerColor: "f8f8f8", headerLColor: "fbde2d", headerLHColor: "4b65cc", headerBGColor: "0c1021", boardColor: "f8f8f8", postHLColor: "ff6400", quotesYouHLColor: "ff6400", ownPostHLColor: "ff6400", threadHLColor: "ff6400", replybgHLColor: "080c1d", replyslctColor: "ff6400" }, { name: "Dark Flat", authorName: "ahod###ka", authorTrip: "!.pC/AHOKAg", "default": true, bgImg: "R0lGODlhAwADAIAAAB0dHRkZGSH5BADoAwAALAAAAAADAAMAAAIDDG5YADs=", bgRPA: "repeat top left fixed", replyOp: "1.0", navOp: "0.9", bgRPA: "repeat top left fixed", bgColor: "1C1D1E", mainColor: "232425", brderColor: "292a2b", inputColor: "18191a", inputbColor: "121314", blinkColor: "6f99b4", unreadColor: "ac9bb0", linkColor: "ac9bb0", linkHColor: "6f99b4", qlColor: "ac9bb0", nameColor: "a8c6d9", quoteColor: "b3c45e", textColor: "dddddd", tripColor: "d4c095", titleColor: "9390c9", headerColor: "dddddd", headerLColor: "ac9bb0", headerLHColor: "6f99b4", headerBGColor: "232425", boardColor: "dddddd", postHLColor: "d4c095", quotesYouHLColor: "d4c095", ownPostHLColor: "d4c095", threadHLColor: "9390c9", replybgHLColor: "171919", replyslctColor: "d4c095" }, { name: "Yukimura", authorName: "the real", authorTrip: "!eKISSUy3/c", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", mainColor: "1b1b1b", brderColor: "191919", inputColor: "1b1b1b", inputbColor: "1b1b1b", headerBGColor: "1b1b1b", headerColor: "e3c2b3", boardColor: "e3c2b3", bgColor: "171717", textColor: "e3c2b3", blinkColor: "5c433c", headerLColor: "e96a81", headerLHColor: "e96a81", linkColor: "e96a81", linkHColor: "e96a81", qlColor: "e96a81", nameColor: "e96a81", tripColor: "5c433c", titleColor: "5c433c", quoteColor: "b3c45e", unreadColor: "5c433c", postHLColor: "5c433c", quotesYouHLColor: "d63e34", ownPostHLColor: "5c433c", threadHLColor: "5c433c", replybgHLColor: "0d0d0d", replyslctColor: "5c433c" }, { name: "Photons + Odin", authorName: "John", authorTrip: "!Hu6tDS8lls", "default": true, bgImg: "R0lGODlhAwADAIAAAB0dHRkZGSH5BADoAwAALAAAAAADAAMAAAIDDG5YADs=", bgRPA: "repeat top left fixed", replyOp: "1.0", navOp: "0.9", mainColor: "1a1a1a", brderColor: "1f1f1f", inputColor: "18191a", inputbColor: "121314", headerBGColor: "1a1a1a", headerColor: "dddddd", boardColor: "dddddd", bgColor: "202020", textColor: "dddddd", blinkColor: "c72d41", headerLColor: "737f88", headerLHColor: "4f585d", linkColor: "737f88", linkHColor: "4f585d", qlColor: "737f88", nameColor: "0099bc", tripColor: "ff0085", titleColor: "ffa600", quoteColor: "85c600", unreadColor: "446a6d", postHLColor: "ff0085", quotesYouHLColor: "ff0085", ownPostHLColor: "ff0085", threadHLColor: "ffa600", replybgHLColor: "0d0d0d", replyslctColor: "ff0085" }, { name: "Photon", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "eeeeee", mainColor: "dddddd", brderColor: "c4c4c4", inputColor: "ffffff", inputbColor: "cccccc", blinkColor: "111111", unreadColor: "ff6600", linkColor: "ff6600", linkHColor: "ff3300", qlColor: "ff6600", nameColor: "004a99", quoteColor: "789922", textColor: "333333", tripColor: "ff3300", titleColor: "002244", headerColor: "333333", headerLColor: "ff6600", headerLHColor: "ff3300", headerBGColor: "dddddd", boardColor: "004a99", postHLColor: "ff3300", quotesYouHLColor: "004a99", ownPostHLColor: "ff3300", threadHLColor: "002244", replybgHLColor: "c4c4c4", replyslctColor: "ff3300" }, { name: "Original Minimalistic Mayhem", authorName: "Mayhem", authorTrip: "!MayhemxaEo", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "191919", mainColor: "333333", brderColor: "111111", inputColor: "222222", inputbColor: "151515", blinkColor: "559c7a", unreadColor: "559c7a", linkColor: "559c7a", linkHColor: "c7de1a", qlColor: "559c7a", nameColor: "2e88a6", quoteColor: "8ba446", textColor: "dddddd", tripColor: "8c5d2a", titleColor: "486273", headerColor: "dddddd", headerLColor: "559c7a", headerLHColor: "c7de1a", headerBGColor: "333333", boardColor: "dddddd", postHLColor: "8c5d2a", quotesYouHLColor: "8c5d2a", ownPostHLColor: "8c5d2a", threadHLColor: "486273", replybgHLColor: "25262a", replyslctColor: "8c5d2a" }, { name: "Tomorrow", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "1d1f21", mainColor: "282a2e", brderColor: "373b41", inputColor: "282a2e", inputbColor: "1d1f21", blinkColor: "5f89ac", unreadColor: "81a2be", linkColor: "81a2be", linkHColor: "cc6666", qlColor: "81a2be", nameColor: "81a2be", quoteColor: "b5bd68", textColor: "c5c8c6", tripColor: "8abeb7", titleColor: "b294bb", headerColor: "c5c8c6", headerLColor: "81a2be", headerLHColor: "cc6666", headerBGColor: "282a2e", boardColor: "c5c8c6", postHLColor: "8abeb7", quotesYouHLColor: "8abeb7", ownPostHLColor: "8abeb7", threadHLColor: "b294bb", replybgHLColor: "24262a", replyslctColor: "8abeb7", customCSS: "span.postNum.desktop > a {\ncolor: #c5c8c6 !important\n}\nspan.postNum.desktop > a:hover {\ncolor: #81a2be !important\n}" }, { name: "Yotsuba", authorName: "moot", authorTrip: "!Εр8рui8Vw2", "default": true, bgImg: "iVBORw0KGgoAAAANSUhEUgAAAAEAAADICAIAAACmkByiAAAAWElEQVR4AaWSwQ3AIAwDbfbfpdt0nKrPUp3QCfHgkfjsCMh47mskmU5HGvbmuuh9dVce8M4it/SfMZglGeZx/ccyu/Vsv4/N29f331AY5Bi3+hdo4A92+wXvCwR9mXztrAAAAABJRU5ErkJggg==", bgRPA: "repeat-x top center scroll", replyOp: "1.0", navOp: "0.9", bgColor: "ffffee", mainColor: "f0e0d6", brderColor: "d9bFb7", inputColor: "ffffff", inputbColor: "aaaaaa", blinkColor: "800000", unreadColor: "000080", linkColor: "0000ee", linkHColor: "dd0000", qlColor: "000080", nameColor: "117743", quoteColor: "789922", textColor: "800000", tripColor: "228854", titleColor: "cc1105", headerColor: "800000", headerLColor: "800000", headerLHColor: "dd0000", headerBGColor: "f0e0d6", boardColor: "800000", postHLColor: "228854", quotesYouHLColor: "dd0000", ownPostHLColor: "228854", threadHLColor: "dd0000", replybgHLColor: "d6bad0", replyslctColor: "228854", customCSS: "span.postNum.desktop > a {\ncolor: #800000 !important\n}\nspan.postNum.desktop > a:hover {\ncolor: #dd0000 !important\n}\n.menu-button {\ncolor: #800000 !important\n}" }, { name: "Yotsuba B", authorName: "moot", authorTrip: "!Εр8рui8Vw2", "default": true, bgImg: "iVBORw0KGgoAAAANSUhEUgAAAAEAAADICAIAAACmkByiAAAASUlEQVR4AcWRuQ0AIBDDzuy/HAVrMAM9slCorqAJziNgrj2qSg/cGhHnjPqDDPxOfYiebwFj+XobeLGI7p39fW1/Ib58d55Bwh3x9wRv6r75UwAAAABJRU5ErkJggg==", bgRPA: "repeat-x top center scroll", replyOp: "1.0", navOp: "0.9", bgColor: "eef2ff", mainColor: "d6daf0", brderColor: "b7c5d9", inputColor: "ffffff", inputbColor: "aaaaaa", blinkColor: "34345c", unreadColor: "34345C", linkColor: "34345c", linkHColor: "dd0000", qlColor: "dd0000", nameColor: "117743", quoteColor: "789922", textColor: "000000", tripColor: "228854", titleColor: "0f0c5d", headerColor: "34345c", headerLColor: "34345c", headerLHColor: "dd0000", headerBGColor: "d6daf0", boardColor: "af0a0f", postHLColor: "228854", quotesYouHLColor: "228854", ownPostHLColor: "228854", threadHLColor: "dd0000", replybgHLColor: "d6bad0", replyslctColor: "228854", customCSS: "span.postNum.desktop > a {\ncolor: #000000 !important\n}\nspan.postNum.desktop > a:hover {\ncolor: #dd0000 !important\n}" }, { name: "Yotsuba Purple", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "f8f3fe", mainColor: "eeddff", brderColor: "cab7d9", inputColor: "ffffff", inputbColor: "cab7d9", blinkColor: "000000", unreadColor: "962594", linkColor: "962594", linkHColor: "b22caa", qlColor: "b22caa", nameColor: "591177", quoteColor: "789922", textColor: "000000", tripColor: "b22caa", titleColor: "0f0c5d", headerColor: "000000", headerLColor: "962594", headerLHColor: "b22caa", headerBGColor: "eeddff", boardColor: "591177", postHLColor: "b22caa", quotesYouHLColor: "d63e34", ownPostHLColor: "b22caa", threadHLColor: "0f0c5d", replybgHLColor: "b7aac4", replyslctColor: "b22caa" }, { name: "安心院なじみ", authorName: "ahod###ka", authorTrip: "!.pC/AHOKAg", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "ffffff", mainColor: "efefef", brderColor: "d6d6d6", inputColor: "cccccc", inputbColor: "bbbbbb", blinkColor: "f5871f", unreadColor: "bf8040", linkColor: "bf8040", linkHColor: "bf8040", qlColor: "bf8040", nameColor: "2b80c2", quoteColor: "718c00", textColor: "4d4d4c", tripColor: "3e999f", titleColor: "4d4d4d", headerColor: "4d4d4c", headerLColor: "bf8040", headerLHColor: "bf8040", headerBGColor: "efefef", boardColor: "4d4d4c", postHLColor: "3e999f", quotesYouHLColor: "3e999f", ownPostHLColor: "3e999f", threadHLColor: "4d4d4d", replybgHLColor: "c7c7c7", replyslctColor: "3e999f" }, { name: "Solarized Dark", // http://ethanschoonover.com/solarized authorName: "ubuntufriend", authorTrip: "!UbuntuBReY!!iizPaxgtRk3", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "073642", mainColor: "032b36", brderColor: "133942", inputColor: "073642", inputbColor: "0d272e", blinkColor: "4f5f8f", unreadColor: "696fc0", linkColor: "696bba", linkHColor: "d33682", qlColor: "696bba", nameColor: "586e75", quoteColor: "859900", textColor: "93a1a1", tripColor: "2aa198", titleColor: "bec2c4", headerColor: "93a1a1", headerLColor: "696bba", headerLHColor: "d33682", headerBGColor: "032b36", boardColor: "93a1a1", postHLColor: "2aa198", quotesYouHLColor: "2aa198", ownPostHLColor: "2aa198", threadHLColor: "bec2c4", replybgHLColor: "073642", replyslctColor: "2aa198" }, { name: "4chan Rewired Modded", // Originally by !K.WeEabo0o, modded by ahoka authorName: "ahod###ka", authorTrip: "!.pC/AHOKAg", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "f4f4f4", mainColor: "efefef", brderColor: "d4d4d4", inputColor: "e4e4e4", inputbColor: "cccccc", blinkColor: "bf7f3f", unreadColor: "bf7f3f", linkColor: "bf7f3f", linkHColor: "d33682", nameColor: "4c4c4c", quoteColor: "6b7a1e", textColor: "4c4c4c", tripColor: "bf7f3f", titleColor: "4c4c4c", headerColor: "4c4c4c", headerLColor: "bf7f3f", headerLHColor: "d33682", headerBGColor: "efefef", boardColor: "4c4c4c", postHLColor: "bf7f3f", quotesYouHLColor: "d63e34", ownPostHLColor: "bf7f3f", threadHLColor: "4c4c4c", replybgHLColor: "c7c7c7", replyslctColor: "bf7f3f" }, { name: "4chan Dark Upgrade", authorName: "ahod###ka", authorTrip: "!.pC/AHOKAg", "default": true, bgImg: "https://i.imgur.com/YUR3TW0.png", bgRPA: "repeat top left fixed", replyOp: "1.0", navOp: "0.9", bgColor: "191919", mainColor: "303030", brderColor: "3a3a3a", inputColor: "2f2f2f", inputbColor: "0f0f0f", blinkColor: "cccccc", unreadColor: "cccccc", linkColor: "dddddd", linkHColor: "eeeeee", qlColor: "dddddd", nameColor: "ffffff", quoteColor: "63995b", textColor: "ffffff", tripColor: "a7dce7", titleColor: "999999", headerColor: "ffffff", headerLColor: "dddddd", headerLHColor: "eeeeee", headerBGColor: "333333", boardColor: "ffffff", postHLColor: "a7dce7", quotesYouHLColor: "a7dce7", ownPostHLColor: "a7dce7", threadHLColor: "999999", replybgHLColor: "999999", replyslctColor: "a7dce7", customCSS: "#delform {\nbackground:rgba(22,22,22,.8)!important;\nborder:0!important;\npadding:1px!important;\nbox-shadow:rgba(0,0,0,.8) 0 0 10px;\n}\ndiv.reply.post {\nbackground-image: url('') !important;\nborder-bottom: #1f1f1f !important;\n}\n.thread:not(.stub){\nbackground:0!important\n}\na:not([href='javascript:;']){\ntext-shadow:#0f0f0f 0 1px;\n}" }, { name: "Yasashii", authorName: "Nebukazar", authorTrip: "!/Am.NeBUqQ", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", mainColor: "f8f8f8", brderColor: "f8f8f8", inputColor: "f8f8f8", inputbColor: "be7375", headerBGColor: "a6586f", headerColor: "f8f8f8", boardColor: "a6586f", bgColor: "ebebeb", textColor: "5b5c5c", blinkColor: "656599", headerLColor: "ebebeb", headerLHColor: "656599", linkColor: "b78087", linkHColor: "c8ab78", qlColor: "b78087", nameColor: "be7375", tripColor: "656599", titleColor: "b87d6e", quoteColor: "7eba6c", unreadColor: "f8f8f8", postHLColor: "9875a3", quotesYouHLColor: "656599", ownPostHLColor: "9875a3", threadHLColor: "b87d6e", replybgHLColor: "eaeaea", replyslctColor: "9875a3" }, { name: "AppChan", // Originally by Zixaphir @ http://userstyles.org/styles/54149/appchan authorName: "Zixaphir", authorTrip: "!M.........", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "2c2c2c", mainColor: "333333", brderColor: "333333", inputColor: "333333", inputbColor: "2c2c2c", blinkColor: "4f5f8f", unreadColor: "6688aa", linkColor: "6688aa", linkHColor: "6688aa", qlColor: "6688aa", nameColor: "aaaaaa", quoteColor: "789922", textColor: "aaaaaa", tripColor: "aaaaaa", titleColor: "aaaaaa", headerColor: "aaaaaa", headerLColor: "6688aa", headerLHColor: "6688aa", headerBGColor: "333333", boardColor: "aaaaaa", postHLColor: "aaaaaa", quotesYouHLColor: "aaaaaa", ownPostHLColor: "aaaaaa", threadHLColor: "aaaaaa", replybgHLColor: "282828", replyslctColor: "aaaaaa" }, { name: "Zenburned", authorName: "lazy", authorTrip: "!HONKYn7h1.", "default": true, bgImg: false, replyOp: "1.0", navOp: "0.9", bgColor: "3f3f3f", mainColor: "575757", brderColor: "5e5e5e", inputColor: "454545", inputbColor: "888888", blinkColor: "dca3a3", unreadColor: "93b3a3", linkColor: "efdcbc", linkHColor: "f8f893", qlColor: "efdcbc", nameColor: "c0bed1", quoteColor: "7f9f7f", textColor: "dcdccc", tripColor: "8cd0d3", titleColor: "aaaaaa", headerColor: "dcdccc", headerLColor: "efdcbc", headerLHColor: "f8f893", headerBGColor: "575757", boardColor: "dcdccc", postHLColor: "8cd0d3", quotesYouHLColor: "8cd0d3", ownPostHLColor: "8cd0d3", threadHLColor: "aaaaaa", replybgHLColor: "494949", replyslctColor: "8cd0d3" }, { name: "Monokai", authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, replyOp: "1.0", navOp: "0.9", bgColor: "20211c", mainColor: "272822", brderColor: "2d2e27", inputColor: "20211c", inputbColor: "171713", blinkColor: "f92672", unreadColor: "e2db74", linkColor: "e2db74", linkHColor: "ae81ff", qlColor: "e2db74", nameColor: "5ac0cc", quoteColor: "a2cc28", textColor: "f8f8f2", tripColor: "fa8220", titleColor: "ae81ff", headerColor: "f8f8f2", headerLColor: "e2db74", headerLHColor: "ae81ff", headerBGColor: "272822", boardColor: "f8f8f2", postHLColor: "fa8220", quotesYouHLColor: "fa8220", ownPostHLColor: "fa8220", threadHLColor: "ae81ff", replybgHLColor: "23241e", replyslctColor: "fa8220" }, { name: "Ao ni sarasu", // based on jaygeegeegee's http://userstyles.org/styles/75602/last-fm-kind-of-blue authorName: "Seaweed", authorTrip: "!!lq+3fff+/ev", "default": true, replyOp: "1.0", navOp: "0.9", bgColor: "e9eced", mainColor: "e3e7e8", brderColor: "cccccc", inputColor: "e9eced", inputbColor: "cccccc", blinkColor: "477085", unreadColor: "477085", linkColor: "477085", linkHColor: "5d6678", qlColor: "477085", nameColor: "4c4c4c", quoteColor: "6b7a1e", textColor: "4c4c4c", tripColor: "5d6678", titleColor: "617d6f", headerColor: "4c4c4c", headerLColor: "477085", headerLHColor: "5d6678", headerBGColor: "e3e7e8", boardColor: "477085", postHLColor: "5d6678", quotesYouHLColor: "d63e34", ownPostHLColor: "5d6678", threadHLColor: "617d6f", replybgHLColor: "d5dada", replyslctColor: "5d6678" }, { name: "Blue Tone", authorName: "Leagle", authorTrip: "!YoGiiH6Oi.", "default": true, replyOp: "1.0", navOp: "0.9", mainColor: "222222", brderColor: "222222", inputColor: "18191a", inputbColor: "121314", headerBGColor: "1b1b1b", headerColor: "dddddd", boardColor: "dddddd", bgColor: "131313", textColor: "a0a0a0", blinkColor: "3296c8", headerLColor: "3296c8", headerLHColor: "dddddd", linkColor: "a0a0a0", linkHColor: "dddddd", qlColor: "3296c8", nameColor: "dddddd", tripColor: "dddddd", titleColor: "a0a0a0", quoteColor: "009933", unreadColor: "3296c8", postHLColor: "ffffff", quotesYouHLColor: "ffffff", ownPostHLColor: "ffffff", threadHLColor: "a0a0a0", replybgHLColor: "141414", replyslctColor: "ffffff", customCSS: ".boardBanner .boardTitle {\ntext-shadow: 0 0 3px #a0a0a0 !important;\nletter-spacing: 0px !important;\npadding-top: 30px !important;\n}" }, { name: "Cold Snap", authorName: "Kori", authorTrip: "!STRaW/KORI", "default": true, replyOp: "1.0", navOp: "0.9", mainColor: "fcfcfc", brderColor: "ebebeb", inputColor: "ffffff", inputbColor: "ffffff", headerBGColor: "ffffff", headerColor: "aaaaaa", boardColor: "6699cc", bgColor: "ffffff", textColor: "232323", blinkColor: "6699cc", headerLColor: "aaaaaa", headerLHColor: "6699cc", linkColor: "6699cc", linkHColor: "6699cc", qlColor: "6699cc", nameColor: "aaaaaa", tripColor: "476b8f", titleColor: "909090", quoteColor: "83bf57", unreadColor: "6699cc", postHLColor: "476b8f", quotesYouHLColor: "476b8f", ownPostHLColor: "476b8f", threadHLColor: "909090", replybgHLColor: "eeeeee", replyslctColor: "476b8f" }, { name: "Midnight Caek", authorName: "Zixaphir", authorTrip: "!M.........", "default": true, replyOp: "1.0", navOp: "0.9", mainColor: "1c1c1c", brderColor: "1c1c1c", inputColor: "1c1c1c", inputbColor: "1c1c1c", headerBGColor: "101010", headerColor: "909090", boardColor: "909090", bgColor: "101010", textColor: "909090", blinkColor: "424247", headerLColor: "909090", headerLHColor: "47475b", linkColor: "57577b", linkHColor: "47475b", qlColor: "57577b", nameColor: "7c2d2d", tripColor: "3e7157", titleColor: "aaaaaa", quoteColor: "71793e", unreadColor: "57577b", postHLColor: "ffffff", quotesYouHLColor: "7c2d2d", ownPostHLColor: "ffffff", threadHLColor: "aaaaaa", replybgHLColor: "0e0e0e", replyslctColor: "ffffff" }], init: function() { $SS.conf["Themes"] = Array.isArray($SS.conf["Themes"]) ? this.defaults.concat($SS.conf["Themes"]) : this.defaults.slice(0); var i = $SS.location.nsfw ? $SS.conf["NSFW Theme"] : $SS.conf["Selected Theme"], tIndex = $SS.conf["Themes"][i] ? i : 0; $SS.theme = new $SS.Theme(tIndex); // Set the active theme. } }, /* MASCOTS */ Mascots: { defaults: [{ img: "https://i.imgur.com/efamPLp.png", "default": true, name: "Akaza Akari" }, { img: "https://i.imgur.com/8v6aSbV.png", "default": true, name: "Akemi Homura" }, { img: "https://i.imgur.com/fgbEdWe.png", "default": true, name: "Akiyama Mio" }, { img: "https://i.imgur.com/FWC00jB.png", "default": true, name: "Ali Baba" }, { img: "https://i.imgur.com/AD18Ld2.png", "default": true, name: "Asuka Shikinami Langley" }, { img: "https://i.imgur.com/u65u8oN.png", "default": true, name: "Cirno" }, { img: "https://i.imgur.com/97DaEBD.png", "default": true, name: "Fubuki Atsuya" }, { img: "https://i.imgur.com/BurJnOd.png", "default": true, name: "Gasai Yuno", height: "460px", hoffset: "40" }, { img: "https://i.imgur.com/HsqOvDJ.png", "default": true, name: "Hatsune Miku" }, { img: "https://i.imgur.com/ZttwSus.png", "default": true, name: "Hirasawa Yui" }, { img: "https://i.imgur.com/ttQDirH.png", "default": true, name: "Hitagi Senjougahara" }, { img: "https://i.imgur.com/4F6BAMZ.png", "default": true, name: "Horo", hoffset: "20" }, { img: "https://i.imgur.com/83sf3ZL.png", "default": true, name: "Inga", width: "301px" }, { img: "https://i.imgur.com/4FsUkrN.png", "default": true, name: "Iwakura Lain" }, { img: "https://i.imgur.com/AMmCyhq.png", "default": true, name: "Kagami Taiga" }, { img: "https://i.imgur.com/v5aBcVe.png", "default": true, name: "Kaguya Houraisan", hoffset: "-40" }, { img: "https://i.imgur.com/TVlagl3.png", "default": true, name: "Kaname Madoka", hoffset: "25" }, { img: "https://i.imgur.com/aXVz09Y.png", "default": true, name: "Kikuchi Makoto", hoffset: "20" }, { img: "https://i.imgur.com/X1r8AiN.png", "default": true, name: "Kirino x Kariya", hoffset: "1" }, { img: "https://i.imgur.com/MCvbGgt.png", "default": true, name: "Kirisame Marisa" }, { img: "https://i.imgur.com/4Hdd0R8.png", "default": true, name: "Kisaragi Chihaya", width: "306px" }, { img: "https://i.imgur.com/E0sdnuC.png", "default": true, name: "Kousaka Kirino" }, { img: "https://i.imgur.com/pMNliiX.png", "default": true, name: "Kurisu Makise" }, { img: "https://i.imgur.com/TwcfQPD.png", "default": true, name: "Kuriyama Mirai", }, { img: "https://i.imgur.com/FNgiG0D.png", "default": true, name: "Kuroko no Basuke", hoffset: "25" }, { img: "https://i.imgur.com/qSUOgQ9.png", "default": true, name: "Kusanagi Motoko" }, { img: "https://i.imgur.com/BxJylsO.png", "default": true, name: "Mashiro Shiina" }, { img: "https://i.imgur.com/Xgzke7s.png", "default": true, name: "Mayoi Hachikuji" }, { img: "https://i.imgur.com/0ogSJHX.png", "default": true, name: "Megurine Luka" }, { img: "https://i.imgur.com/TCXQaaQ.png", "default": true, name: "Mikasa Ackerman" }, { img: "https://i.imgur.com/GhwBI5n.png", "default": true, name: "Miyamoto Konatsu" }, { img: "https://i.imgur.com/NqDwk7d.png", "default": true, name: "Mokou no Fujiwara", height: "450px" }, { img: "https://i.imgur.com/Otig7OD.png", "default": true, name: "Morrigan Aensland", width: "300px" }, { img: "https://i.imgur.com/SRWU4e1.png", "default": true, name: "Nagase Iori" }, { img: "https://i.imgur.com/zio62Qq.png", "default": true, name: "Nagato Yuki", hoffset: "25" }, { img: "https://i.imgur.com/pfqZLHo.png", "default": true, name: "Nakano Azusa" }, { img: "https://i.imgur.com/7zJ6F35.png", "default": true, name: "Patchouli Knowledge" }, { img: "https://i.imgur.com/OF68sMQ.png", "default": true, name: "Poko Fox" }, { img: "https://i.imgur.com/iCzq9oO.png", "default": true, name: "Purple Heart" }, { img: "https://i.imgur.com/3YSqyiI.png", "default": true, name: "Remilia Scarlet" }, { img: "https://i.imgur.com/sFh3eE0.png", "default": true, name: "Rei Ayanami", width: "290px" }, { img: "https://i.imgur.com/UtjqvU6.png", "default": true, name: "Ruri Gokou", hoffset: "20" }, { img: "https://i.imgur.com/H7GtZ9j.png", "default": true, name: "Saber", height: "500px", hoffset: "25" }, { img: "https://i.imgur.com/jJOnYmI.png", "default": true, name: "Saigyouji Yuyuko", width: "301px" }, { img: "https://i.imgur.com/KeJysAb.png", "default": true, name: "Sakamoto-san", hoffset: "15" }, { img: "https://i.imgur.com/MPD95PX.png", "default": true, name: "Shana", hoffset: "25" }, { img: "https://i.imgur.com/yEr8m8s.png", "default": true, name: "Solaire of Astora", height: "450px", hoffset: "50" }, { img: "https://i.imgur.com/k7nFogG.png", "default": true, name: "Son Goku", width: "301px" }, { img: "https://i.imgur.com/AFINQjc.png", "default": true, name: "Touwa Erio" }, { img: "https://i.imgur.com/rddrYFR.png", "default": true, name: "Yin" }, { img: "https://i.imgur.com/bEPA1rz.png", "default": true, name: "Yoko Littner", height: "450px", hoffset: "25" }, { img: "https://i.imgur.com/uu6Dh0I.png", "default": true, name: "Yukinoshita Yukino" }, { img: "https://i.imgur.com/283FX36.png", "default": true, name: "Yuuki Asuna" }, { img: "https://i.imgur.com/84HOYIc.png", "default": true, name: "Yuzuki Yukari", hoffset: "10" }, { img: "https://i.imgur.com/PELVufb.png", "default": true, name: "Symbol 01", offset: "-20" }, { img: "https://i.imgur.com/cPXpt6h.png", "default": true, name: "Symbol 02" }, { img: "https://i.imgur.com/efV7fRL.png", "default": true, name: "Symbol 03" }], init: function() { $SS.conf["Mascots"] = Array.isArray($SS.conf["Mascots"]) ? this.defaults.concat($SS.conf["Mascots"]) : this.defaults.slice(0); var eMascot = [], mIndex; if ($SS.conf["Selected Mascots"] === 0) { eMascot = $SS.conf["Mascots"]; mIndex = Math.floor(Math.random() * eMascot.length); } else { for (var i = 0, MAX = $SS.conf["Selected Mascots"].length, j; i < MAX; ++i) { j = $SS.conf["Selected Mascots"][i]; if ($SS.conf["Mascots"][j].boards == undefined || $SS.conf["Mascots"][j].boards.split(",").indexOf($SS.location.board) !== -1) eMascot.push(j); } if (eMascot.length === 0) return $SS.mascot = new $SS.Mascot(-1); else mIndex = eMascot[Math.floor(Math.random() * eMascot.length)]; } $SS.mascot = new $SS.Mascot(mIndex); // Set the active mascot. } }, classes: { init: function() { /* Function arguments: ("Option Name", value, "class-name") */ $("html").addClass("oneechan"); $SS.theme.textColor.isLight ? $("html").addClass("isLight") : ""; $SS.theme.bgColor.isLight ? "" : $("html").addClass("dark-captcha"); $("html").optionClass("Underline QuoteLinks", true, "underline-quotes"); $("html").optionClass("Underline All Links", false, "underline-disabled"); $("html").optionClass("Style Thread Stats", true, "style-stats"); $("html").optionClass("Rounded Corners", true, "rounded-corners"); $("html").optionClass("Show Checkboxes", false, "hide-checkboxes"); $("html").optionClass("Show Board Name", false, "hide-board-name"); $("html").optionClass("Fit Width", true, "reply-fit-width"); $("html").optionClass("Show Banner", false, "hide-banner"); $("html").optionClass("Reduce Banner Opacity", true, "banner-opacity"); $("html").optionClass("Show Board Banners", false, "hide-board-banners"); $("html").optionClass("Show Post Info On Hover", true, "info-on-hover"); $("html").optionClass("Show Reply to Thread Button", false, "hide-button"); $("html").optionClass("Show Reply Header", true, "post-info"); $("html").optionClass("Show File Info", false, "show-file-info"); $("html").optionClass("Borders", 2, "borders-all"); $("html").optionClass("Borders", 3, "borders-none"); $("html").optionClass("Highlight (OP) quotes", true, "highlight-opQuotes"); $("html").optionClass("Highlight (You) quotes", true, "highlight-youQuotes"); $("html").optionClass("Post Decoration Style", 1, "hl-border"); $("html").optionClass("Post Decoration Style", 2, "hl-outline"); $("html").optionClass("Post Decoration Style", 3, "hl-border-down"); $("html").optionClass("Sidebar Position", 1, "right-sidebar"); $("html").optionClass("Sidebar Position", 2, "left-sidebar"); $("html").optionClass("Minimal Sidebar", true, "mini-sidebar"); $("html").optionClass("Recolor Even Replies", true, "recolor-even"); $("html").optionClass("Backlink Icons", true, "backlink-icon"); $("html").optionClass("Backlinks on Bottom", true, "backlink-bottom"); $("html").optionClass("Autohide Style", 2, "vertical-qr"); $("html").optionClass("Autohide Style", 3, "fade-qr"); $("html").optionClass("Transparent QR", true, "qr-opacity"); $("html").optionClass("Remove Background", true, "qr-background"); $("html").optionClass("Remove Controls", true, "qr-controls"); $("html").optionClass("Force QR to Sidebar Size", true, "force-qr"); $("html").optionClass("SS-like Sidebar", true, "ss-sidebar"); $("html").optionClass("Indent OP", false, "force-indent"); $("html").optionClass("Allow Wrapping Around OP", false, "force-wrapping"); $("html").optionClass("OP Background", true, "op-background"); $("html").optionClass("Expanding Form Inputs", true, "expand-inputs"); $("html").optionClass("Show Header Background Gradient", true, "header-gradient"); $("html").optionClass("Show Header Shadow", false, "header-shadow"); $("html").optionClass("Highlight Current Board", false, "header-highlight"); $("html").optionClass("Show Blotter", false, "hide-blotter"); $("html").optionClass("Show 4chan Ads", true, "show-ads"); $("html").optionClass("Show Top Ad", false, "hide-top"); $("html").optionClass("Show Middle Ad", false, "hide-middle"); $("html").optionClass("Show Bottom Ad", false, "hide-bottom"); $("html").optionClass("Show Navigation Links", false, "hide-navlinks"); $("html").optionClass("Show Top Links", false, "hide-navlinktop"); $("html").optionClass("Show Bottom Links", false, "hide-navlinkbot"); $("html").optionClass("Show Previous/Next buttons", false, "hide-prevnext"); $("html").optionClass("Reduce Ad Opacity", true, "ad-opacity"); $("html").optionClass("Mascots Overlap Posts", false, "mascot-overlap"); $("html").optionClass("Reduce Mascot Opacity", true, "mascot-opacity"); $("html").optionClass("Grayscale Mascots", true, "mascot-grayscale"); $("html").optionClass("Reduce Thumbnail Opacity", true, "thumb-opacity"); $("html").optionClass("Justified Text", true, "catalog-justify"); $("html").optionClass("Show Background", true, "catalog-background"); $("html").optionClass("Unified Thumbnail Size", true, "catalog-thumbsize"); } }, riceInputs: { hasInit: false, init: function() { if (!this.hasInit) { if ($SS.conf["Show Checkboxes"] && !$(".postInfo>.riceCheck").exists()) { $("input[type=checkbox]").riceCheck(); return this.hasInit = true; } else if ($SS.conf["Show Checkboxes"] && $(".postInfo>.riceCheck").exists()) { return this.hasInit = false; } } } }, jscolor: { getElementPos: function(e) { var e1 = e, e2 = e; var x = 0, y = 0; if (e1.offsetParent) do { x += e1.offsetLeft; y += e1.offsetTop; } while (e1 = e1.offsetParent); while ((e2 = e2.parentNode) && e2.nodeName.toUpperCase() !== "BODY") { x -= e2.scrollLeft; y -= e2.scrollTop; } return [x, y]; }, getElementSize: function(e) { return [e.offsetWidth, e.offsetHeight]; }, getRelMousePos: function(e) { var x = 0, y = 0; if (!e) e = window.event; if (typeof e.offsetX === "number") { x = e.offsetX; y = e.offsetY; } else if (typeof e.layerX === "number") { x = e.layerX; y = e.layerY; } return { x: x, y: y }; }, getViewPos: function() { if (typeof window.pageYOffset === "number") return [window.pageXOffset, window.pageYOffset]; else if (document.body && (document.body.scrollLeft || document.body.scrollTop)) return [document.body.scrollLeft, document.body.scrollTop]; else if (document.documentElement && (document.documentElement.scrollLeft || document.documentElement.scrollTop)) return [document.documentElement.scrollLeft, document.documentElement.scrollTop]; else return [0, 0]; }, getViewSize: function() { if (typeof window.innerWidth === "number") return [window.innerWidth, window.innerHeight]; else if (document.body && (document.body.clientWidth || document.body.clientHeight)) return [document.body.clientWidth, document.body.clientHeight]; else if (document.documentElement && (document.documentElement.clientWidth || document.documentElement.clientHeight)) return [document.documentElement.clientWidth, document.documentElement.clientHeight]; else return [0, 0]; }, // TODO: remove this array. images: { pad: [181, 101], sld: [16, 101], cross: [15, 15], arrow: [7, 11] }, color: function(target) { this.required = true; // refuse empty values? this.adjust = true; // adjust value to uniform notation? this.hash = false; // prefix color with # symbol? this.caps = false; // uppercase? this.slider = true; // show the value/saturation slider? this.valueElement = target; // value holder this.styleElement = target; // where to reflect current color this.onImmediateChange = null; // onchange callback (can be either string or function) this.hsv = [0, 0, 1]; // read-only 0-6, 0-1, 0-1 this.rgb = [1, 1, 1]; // read-only 0-1, 0-1, 0-1 this.pickerSmartPosition = true; // automatically adjust picker position when necessary this.pickerFace = 10; // px this.pickerFaceColor = "ThreeDFace"; // CSS color this.pickerBorder = 1; // px this.pickerBorderColor = "ThreeDHighlight ThreeDShadow ThreeDShadow ThreeDHighlight"; // CSS color this.pickerInset = 1; // px this.pickerInsetColor = "ThreeDShadow ThreeDHighlight ThreeDHighlight ThreeDShadow"; // CSS color this.pickerZIndex = 10000; this.hidePicker = function() { if (isPickerOwner()) removePicker(); }; this.showPicker = function() { if (!isPickerOwner()) { var tp = $SS.jscolor.getElementPos(target); // target pos var ts = $SS.jscolor.getElementSize(target); // target size var ps = getPickerDims(this); // picker size var a = 0, b = 1, c = 1; var l = (ts[1] + ps[1]) / 2; var pp = [ tp[0], tp[1] + ts[1] ]; drawPicker(pp[0], pp[1]); } }; this.importColor = function() { if (!valueElement) { this.exportColor(); } else { if (!this.adjust) { if (!this.fromString(valueElement.value, leaveValue)) { styleElement.style.backgroundColor = styleElement.jscStyle.backgroundColor; styleElement.style.color = styleElement.jscStyle.color; this.exportColor(leaveValue | leaveStyle); } } else if (!this.required && /^\s*$/.test(valueElement.value)) { valueElement.value = ""; styleElement.style.backgroundColor = styleElement.jscStyle.backgroundColor; styleElement.style.color = styleElement.jscStyle.color; this.exportColor(leaveValue | leaveStyle); } else if (!this.fromString(valueElement.value)) this.exportColor(); } }; this.exportColor = function(flags) { if (!(flags & leaveValue) && valueElement) { var value = this.toString(); if (value[0] === "#") value = value.substr(1); valueElement.value = value; } if (!(flags & leaveStyle) && styleElement) { styleElement.style.backgroundColor = "#" + this.toString(); styleElement.style.color = 0.213 * this.rgb[0] + 0.715 * this.rgb[1] + 0.072 * this.rgb[2] < 0.5 ? "#FFF" : "#000"; } if (!(flags & leavePad) && isPickerOwner()) redrawPad(); if (!(flags & leaveSld) && isPickerOwner()) redrawSld(); }; this.fromHSV = function(h, s, v, flags) { h < 0 && (h = 0) || h > 6 && (h = 6); s < 0 && (s = 0) || s > 1 && (s = 1); v < 0 && (v = 0) || v > 1 && (v = 1); this.rgb = HSV_RGB( h === null ? this.hsv[0] : (this.hsv[0] = h), s === null ? this.hsv[1] : (this.hsv[1] = s), v === null ? this.hsv[2] : (this.hsv[2] = v) ); this.exportColor(flags); }; this.fromRGB = function(r, g, b, flags) { r < 0 && (r = 0) || r > 1 && (r = 1); g < 0 && (g = 0) || g > 1 && (g = 1); b < 0 && (b = 0) || b > 1 && (b = 1); var hsv = RGB_HSV( r === null ? this.rgb[0] : (this.rgb[0] = r), g === null ? this.rgb[1] : (this.rgb[1] = g), b === null ? this.rgb[2] : (this.rgb[2] = b) ); if (hsv[0] !== null) this.hsv[0] = hsv[0]; if (hsv[2] !== 0) this.hsv[1] = hsv[1]; this.hsv[2] = hsv[2]; this.exportColor(flags); }; this.fromString = function(hex, flags) { var m = hex.match(/^\W*([0-9A-F]{3}([0-9A-F]{3})?)\W*$/i); if (!m) return false; else { if (m[1].length === 6) this.fromRGB( parseInt(m[1].substr(0, 2), 16) / 255, parseInt(m[1].substr(2, 2), 16) / 255, parseInt(m[1].substr(4, 2), 16) / 255, flags); else this.fromRGB( parseInt(m[1].charAt(0) + m[1].charAt(0), 16) / 255, parseInt(m[1].charAt(1) + m[1].charAt(1), 16) / 255, parseInt(m[1].charAt(2) + m[1].charAt(2), 16) / 255, flags); return true; } }; this.toString = function() { return ( (0x100 | Math.round(255 * this.rgb[0])).toString(16).substr(1) + (0x100 | Math.round(255 * this.rgb[1])).toString(16).substr(1) + (0x100 | Math.round(255 * this.rgb[2])).toString(16).substr(1) ); }; function RGB_HSV(r, g, b) { var n = Math.min(Math.min(r, g), b); var v = Math.max(Math.max(r, g), b); var m = v - n; if (m === 0) { return [null, 0, v]; } var h = r === n ? 3 + (b - g) / m : (g === n ? 5 + (r - b) / m : 1 + (g - r) / m); return [h === 6 ? 0 : h, m / v, v]; } function HSV_RGB(h, s, v) { if (h === null) { return [v, v, v]; } var i = Math.floor(h); var f = i % 2 ? h - i : 1 - (h - i); var m = v * (1 - s); var n = v * (1 - s * f); switch (i) { case 6: case 0: return [v, n, m]; case 1: return [n, v, m]; case 2: return [m, v, n]; case 3: return [m, n, v]; case 4: return [n, m, v]; case 5: return [v, m, n]; } } function removePicker() { delete $SS.jscolor.picker.owner; window.removeEventListener("resize", removePicker, false); target.blur(); document.getElementsByTagName("body")[0].removeChild($SS.jscolor.picker.boxB); } function drawPicker(x, y) { if (!$SS.jscolor.picker) { $SS.jscolor.picker = { box: document.createElement("div"), boxB: document.createElement("div"), pad: document.createElement("div"), padB: document.createElement("div"), padM: document.createElement("div"), sld: document.createElement("div"), sldB: document.createElement("div"), sldM: document.createElement("div") }; for (var i = 0, segSize = 4; i < $SS.jscolor.images.sld[1]; i += segSize) { var seg = document.createElement("div"); seg.style.height = segSize + "px"; seg.style.fontSize = "1px"; seg.style.lineHeight = "0"; $SS.jscolor.picker.sld.appendChild(seg); } $SS.jscolor.picker.sldB.appendChild($SS.jscolor.picker.sld); $SS.jscolor.picker.box.appendChild($SS.jscolor.picker.sldB); $SS.jscolor.picker.box.appendChild($SS.jscolor.picker.sldM); $SS.jscolor.picker.padB.appendChild($SS.jscolor.picker.pad); $SS.jscolor.picker.box.appendChild($SS.jscolor.picker.padB); $SS.jscolor.picker.box.appendChild($SS.jscolor.picker.padM); $SS.jscolor.picker.boxB.appendChild($SS.jscolor.picker.box); } var p = $SS.jscolor.picker; // controls interaction window.addEventListener("resize", removePicker, false); p.box.onmouseup = p.box.onmouseout = function() { target.focus(); }; p.box.onmousedown = function() { abortBlur = true; }; p.box.onmousemove = function(e) { if (holdPad || holdSld) { holdPad && setPad(e); holdSld && setSld(e); if (document.selection) document.selection.empty(); else if (window.getSelection) window.getSelection().removeAllRanges(); dispatchImmediateChange(); } }; p.padM.onmouseup = p.padM.onmouseout = function() { if (holdPad) { holdPad = false; $(valueElement).fire("change"); } }; p.padM.onmousedown = function(e) { holdPad = true; setPad(e); dispatchImmediateChange(); }; p.sldM.onmouseup = p.sldM.onmouseout = function() { if (holdSld) { holdSld = false; $(valueElement).fire("change"); } }; p.sldM.onmousedown = function(e) { holdSld = true; setSld(e); dispatchImmediateChange(); }; // picker var dims = getPickerDims(THIS); p.box.style.width = dims[0] + "px"; p.box.style.height = dims[1] + "px"; /** MOVE TO CSS **/ // picker border p.boxB.style.position = "fixed"; p.boxB.style.clear = "both"; p.boxB.style.left = x + "px"; p.boxB.style.top = y + "px"; p.boxB.style.zIndex = THIS.pickerZIndex; p.boxB.style.border = THIS.pickerBorder + "px solid"; p.boxB.style.borderColor = THIS.pickerBorderColor; p.boxB.style.background = THIS.pickerFaceColor; // pad image p.pad.style.width = $SS.jscolor.images.pad[0] + "px"; p.pad.style.height = $SS.jscolor.images.pad[1] + "px"; // pad border p.padB.style.position = "absolute"; p.padB.style.left = THIS.pickerFace + "px"; p.padB.style.top = THIS.pickerFace + "px"; p.padB.style.border = THIS.pickerInset + "px solid"; p.padB.style.borderColor = THIS.pickerInsetColor; // pad mouse area p.padM.style.position = "absolute"; p.padM.style.left = "0"; p.padM.style.top = "0"; p.padM.style.width = THIS.pickerFace + 2 * THIS.pickerInset + $SS.jscolor.images.pad[0] + $SS.jscolor.images.arrow[0] + "px"; p.padM.style.height = p.box.style.height; p.padM.style.cursor = "crosshair"; // slider image p.sld.style.overflow = "hidden"; p.sld.style.width = $SS.jscolor.images.sld[0] + "px"; p.sld.style.height = $SS.jscolor.images.sld[1] + "px"; // slider border p.sldB.style.display = THIS.slider ? "block" : "none"; p.sldB.style.position = "absolute"; p.sldB.style.right = THIS.pickerFace + "px"; p.sldB.style.top = THIS.pickerFace + "px"; p.sldB.style.border = THIS.pickerInset + "px solid"; p.sldB.style.borderColor = THIS.pickerInsetColor; // slider mouse area p.sldM.style.display = THIS.slider ? "block" : "none"; p.sldM.style.position = "absolute"; p.sldM.style.right = "0"; p.sldM.style.top = "0"; p.sldM.style.width = $SS.jscolor.images.sld[0] + $SS.jscolor.images.arrow[0] + THIS.pickerFace + 2 * THIS.pickerInset + "px"; p.sldM.style.height = p.box.style.height; try { p.sldM.style.cursor = "pointer"; } catch (eOldIE) { p.sldM.style.cursor = "hand"; } // load images in optimal order p.padM.style.backgroundImage = "url('')"; p.padM.style.backgroundRepeat = "no-repeat"; p.sldM.style.backgroundImage = "url('')"; p.sldM.style.backgroundRepeat = "no-repeat"; p.pad.style.backgroundImage = "url('')"; p.pad.style.backgroundRepeat = "no-repeat"; p.pad.style.backgroundPosition = "0 0"; /** UNTIL HERE **/ // place pointers redrawPad(); redrawSld(); $SS.jscolor.picker.owner = THIS; document.getElementsByTagName("body")[0].appendChild(p.boxB); } function getPickerDims(o) { var dims = [ 2 * o.pickerInset + 2 * o.pickerFace + $SS.jscolor.images.pad[0] + (o.slider ? 2 * o.pickerInset + 2 * $SS.jscolor.images.arrow[0] + $SS.jscolor.images.sld[0] : 0), 2 * o.pickerInset + 2 * o.pickerFace + $SS.jscolor.images.pad[1] ]; return dims; } function redrawPad() { // redraw the pad pointer var yComponent = 1; var x = Math.round((THIS.hsv[0] / 6) * ($SS.jscolor.images.pad[0] - 1)); var y = Math.round((1 - THIS.hsv[yComponent]) * ($SS.jscolor.images.pad[1] - 1)); $SS.jscolor.picker.padM.style.backgroundPosition = (THIS.pickerFace + THIS.pickerInset + x - Math.floor($SS.jscolor.images.cross[0] / 2)) + "px " + (THIS.pickerFace + THIS.pickerInset + y - Math.floor($SS.jscolor.images.cross[1] / 2)) + "px"; // redraw the slider image var seg = $SS.jscolor.picker.sld.childNodes; var rgb = HSV_RGB(THIS.hsv[0], THIS.hsv[1], 1); for (var i = 0; i < seg.length; i += 1) seg[i].style.backgroundColor = "rgb(" + (rgb[0] * (1 - i / seg.length) * 100) + "%," + (rgb[1] * (1 - i / seg.length) * 100) + "%," + (rgb[2] * (1 - i / seg.length) * 100) + "%)"; } function redrawSld() { // redraw the slider pointer var yComponent = 2; var y = Math.round((1 - THIS.hsv[yComponent]) * ($SS.jscolor.images.sld[1] - 1)); $SS.jscolor.picker.sldM.style.backgroundPosition = "0 " + (THIS.pickerFace + THIS.pickerInset + y - Math.floor($SS.jscolor.images.arrow[1] / 2)) + "px"; } function isPickerOwner() { return $SS.jscolor.picker && $SS.jscolor.picker.owner === THIS; } function blurTarget() { if (valueElement === target) THIS.importColor(); THIS.hidePicker(); } function blurValue() { if (valueElement !== target) THIS.importColor(); } function setPad(e) { var mpos = $SS.jscolor.getRelMousePos(e); var x = mpos.x - THIS.pickerFace - THIS.pickerInset; var y = mpos.y - THIS.pickerFace - THIS.pickerInset; THIS.fromHSV(x * (6 / ($SS.jscolor.images.pad[0] - 1)), 1 - y / ($SS.jscolor.images.pad[1] - 1), null, leaveSld); } function setSld(e) { var mpos = $SS.jscolor.getRelMousePos(e); var y = mpos.y - THIS.pickerFace - THIS.pickerInset; THIS.fromHSV(null, null, 1 - y / ($SS.jscolor.images.sld[1] - 1), leavePad); } function dispatchImmediateChange() { if (THIS.onImmediateChange) if (typeof THIS.onImmediateChange === "string") eval(THIS.onImmediateChange); else THIS.onImmediateChange(THIS); } var THIS = this; var abortBlur = false; var valueElement = this.valueElement, styleElement = this.styleElement; var holdPad = false, holdSld = false; var leaveValue = 1 << 0, leaveStyle = 1 << 1, leavePad = 1 << 2, leaveSld = 1 << 3; // target $(target).bind("focus", THIS.showPicker) .bind("blur", function() { if (!abortBlur) window.setTimeout(function() { abortBlur || blurTarget(); abortBlur = false; }); else abortBlur = false; }); // valueElement if (valueElement) { var updateField = function() { THIS.fromString(valueElement.value, leaveValue); dispatchImmediateChange(); }; $(valueElement).bind("keyup", updateField) .bind("input", updateField) .bind("blur", blurValue) .attr("autocomplete", "off"); } // styleElement if (styleElement) { styleElement.jscStyle = { backgroundColor: styleElement.style.backgroundColor, color: styleElement.style.color }; } this.importColor(); } }, /* STRUCTS */ Color: function(hex, incHover) { this.hex = "#" + hex; this.private_rgb = $SS.RGBFromHex(hex); this.rgb = this.private_rgb.join(","); this.isLight = $SS.isLight(this.private_rgb); this.shiftRGB = function(shift, smart) { var rgb = this.private_rgb.slice(0); shift = smart ? (this.isLight ? (shift < 0 ? shift : -shift) : Math.abs(shift)) : shift; rgb[0] = Math.min(Math.max(rgb[0] + shift, 0), 255); rgb[1] = Math.min(Math.max(rgb[1] + shift, 0), 255); rgb[2] = Math.min(Math.max(rgb[2] + shift, 0), 255); return rgb.join(","); }; if (incHover) this.hover = this.shiftRGB(16, true); }, colorToHex: function(color) { var digits, hex; if (color.substr(0, 1) === '#') { return color.slice(1, color.length); } if (digits = color.match(/(.*?)rgba?\((\d+), ?(\d+), ?(\d+)(.*?)\)/)) { hex = ((parseInt(digits[2], 10) << 16) | (parseInt(digits[3], 10) << 8) | (parseInt(digits[4], 10))).toString(16); while (hex.length < 6) { hex = "0" + hex; } return hex; } else { return false; } }, Image: function(img, RPA) { this.img = img; this.RPA = RPA; this.get = function() { if (!this.img) return "none "; var ret = "url('"; if ($SS.validBase64(this.img)) ret = "data:image/" + $SS.typeofBase64(this.img) + ";base64," + this.img; else ret = this.img; return (this.RPA !== undefined ? "url('" : "") + ret + (this.RPA !== undefined ? "')" + this.RPA : ""); }; }, Mascot: function(index) { // no mascot if (index == -1) { this.img = new $SS.Image(null); this.hidden = true; return; } else var mascot = $SS.conf["Mascots"][index]; this.index = index; this.hidden = $SS.conf["Hidden Mascots"].indexOf(index) !== -1; this.default = mascot.default; this.flip = mascot.flip ? "scaleX(-1); -webkit-transform: scaleX(-1)" : ""; this.img = new $SS.Image(mascot.img); this.offset = mascot.offset !== undefined ? mascot.offset : 0; this.hoffset = mascot.hoffset !== undefined ? mascot.hoffset : 0; this.name = mascot.name !== undefined ? mascot.name : "Chinese Girl Cartoon"; this.width = mascot.width !== undefined ? mascot.width : "auto"; this.maxwidth = mascot.maxwidth ? "300px" : ""; this.height = mascot.height !== undefined ? mascot.height : "auto"; this.boards = mascot.boards; this.enabled = $SS.conf["Selected Mascots"] === 0 || $SS.conf["Selected Mascots"].indexOf(index) !== -1; this.preview = function() { var div = $("<div " + (this.hidden ? "hidden=true " : "") + "id=mascot" + this.index + " class=\'mascot-preview" + (this.enabled ? " selected" : "") + "\' style=\"background: url(\'" + this.img.get() + "\')\">") .html("<span class='mascot-buttons'><a class='mascot-link delete'>Delete</a><a class='mascot-link edit'>Edit</a><br><br><a class='mascot-link mascot-name'>" + this.name + "</a></span>"); $(div).bind("click", function() { $(this).toggleClass("selected"); }); $(".mascot-link.delete", div).bind("click", function(e) { e.stopPropagation(); $SS.options.deleteMascot(index); }); $(".mascot-link.edit", div).bind("click", function(e) { e.stopPropagation(); $SS.options.showMascot(index); }); return div; } }, Theme: function(index) { var theme; if ((theme = $SS.conf["Themes"][index]) == undefined) { this.hidden = true; return; } this.index = index; this.hidden = $SS.conf["Hidden Themes"].indexOf(index) !== -1; this.name = theme.name; this.authorName = theme.authorName || "Anonymous"; this.authorTrip = theme.authorTrip || "!..NoTrip.."; this.default = theme.default; this.replyBrder = theme.replyBrder; this.bgImg = new $SS.Image(theme.bgImg, theme.bgRPA); this.replyOp = theme.replyOp; this.navOp = theme.navOp; this.bgColor = new $SS.Color(theme.bgColor); this.mainColor = new $SS.Color(theme.mainColor); this.brderColor = new $SS.Color(theme.brderColor); this.inputColor = new $SS.Color(theme.inputColor, true); this.inputbColor = new $SS.Color(theme.inputbColor); this.blinkColor = new $SS.Color(theme.blinkColor); this.unreadColor = new $SS.Color(theme.unreadColor); this.linkColor = new $SS.Color(theme.linkColor); this.linkHColor = new $SS.Color(theme.linkHColor); this.qlColor = new $SS.Color(theme.qlColor); this.nameColor = new $SS.Color(theme.nameColor); this.quoteColor = new $SS.Color(theme.quoteColor); this.textColor = new $SS.Color(theme.textColor); this.titleColor = new $SS.Color(theme.titleColor); this.tripColor = new $SS.Color(theme.tripColor); this.boardColor = new $SS.Color(theme.boardColor); this.headerColor = new $SS.Color(theme.headerColor); this.headerLColor = new $SS.Color(theme.headerLColor); this.headerLHColor = new $SS.Color(theme.headerLHColor); this.headerBGColor = new $SS.Color(theme.headerBGColor); this.headerbColor = new $SS.Color(theme.headerbColor); this.postHLColor = new $SS.Color(theme.postHLColor); this.quotesYouHLColor = new $SS.Color(theme.quotesYouHLColor); this.ownPostHLColor = new $SS.Color(theme.ownPostHLColor); this.threadHLColor = new $SS.Color(theme.threadHLColor); this.replybgHLColor = new $SS.Color(theme.replybgHLColor); this.replyslctColor = new $SS.Color(theme.replyslctColor); this.checkMark = new $SS.Image(inputImages, "no-repeat center " + (this.inputColor.isLight ? 0 : -8) + "px"); this.radioCheck = new $SS.Image(inputImages, "no-repeat center " + (this.inputColor.isLight ? -16 : -24) + "px"); this.codeBackground = (this.bgColor.isLight ? "255, 255, 255, 0.2" : "0, 0, 0, 0.2"); this.codeBorder = (this.bgColor.isLight ? "204, 204, 204, 1.0" : "204, 204, 204, 0.1"); this.dIcons = new $SS.Image(theme.dIcons); this.icons = { imgExpand: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerColor.rgb + ")' d='M25.545,23.328,17.918,15.623,25.534,8.007,27.391,9.864,29.649,1.436,21.222,3.694,23.058,5.53,15.455,13.134,7.942,5.543,9.809,3.696,1.393,1.394,3.608,9.833,5.456,8.005,12.98,15.608,5.465,23.123,3.609,21.268,1.351,29.695,9.779,27.438,7.941,25.6,15.443,18.098,23.057,25.791,21.19,27.638,29.606,29.939,27.393,21.5z'/></svg>", imgContract: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerColor.rgb + ")' d='M25.083,18.895l-8.428-2.259l2.258,8.428l1.838-1.837l7.053,7.053l2.476-2.476l-7.053-7.053L25.083,18.895zM5.542,11.731l8.428,2.258l-2.258-8.428L9.874,7.398L3.196,0.72L0.72,3.196l6.678,6.678L5.542,11.731zM7.589,20.935l-6.87,6.869l2.476,2.476l6.869-6.869l1.858,1.857l2.258-8.428l-8.428,2.258L7.589,20.935zM23.412,10.064l6.867-6.87l-2.476-2.476l-6.868,6.869l-1.856-1.856l-2.258,8.428l8.428-2.259L23.412,10.064z'/></svg>", menuIcon: "<svg viewBox='7 7 20 20' preserveAspectRatio='true' height='14' width='14' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerLColor.rgb + ")' d='M4.083,14H14V4.083H4.083V14zM17,4.083V14h9.917V4.083H17zM17,26.917h9.917v-9.918H17V26.917zM4.083,26.917H14v-9.918H4.083V26.917z'/></svg>", heart: "<svg viewBox='0 0 26 26' preserveAspectRatio='true' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.textColor.rgb + ")' d='M24.132,7.971c-2.203-2.205-5.916-2.098-8.25,0.235L15.5,8.588l-0.382-0.382c-2.334-2.333-6.047-2.44-8.25-0.235c-2.204,2.203-2.098,5.916,0.235,8.249l8.396,8.396l8.396-8.396C26.229,13.887,26.336,10.174,24.132,7.971z'/></svg>", star: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.textColor.rgb + ")' d='M14.615,4.928c0.487-0.986,1.284-0.986,1.771,0l2.249,4.554c0.486,0.986,1.775,1.923,2.864,2.081l5.024,0.73c1.089,0.158,1.335,0.916,0.547,1.684l-3.636,3.544c-0.788,0.769-1.28,2.283-1.095,3.368l0.859,5.004c0.186,1.085-0.459,1.553-1.433,1.041l-4.495-2.363c-0.974-0.512-2.567-0.512-3.541,0l-4.495,2.363c-0.974,0.512-1.618,0.044-1.432-1.041l0.858-5.004c0.186-1.085-0.307-2.6-1.094-3.368L3.93,13.977c-0.788-0.768-0.542-1.525,0.547-1.684l5.026-0.73c1.088-0.158,2.377-1.095,2.864-2.081L14.615,4.928z'/></svg>", backlink: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.blinkColor.rgb + ")' d='M12.981,9.073V6.817l-12.106,6.99l12.106,6.99v-2.422c3.285-0.002,9.052,0.28,9.052,2.269c0,2.78-6.023,4.263-6.023,4.263v2.132c0,0,13.53,0.463,13.53-9.823C29.54,9.134,17.952,8.831,12.981,9.073z'/></svg>", bubble: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.blinkColor.rgb + ")' d='M16,5.333c-7.732,0-14,4.701-14,10.5c0,1.982,0.741,3.833,2.016,5.414L2,25.667l5.613-1.441c2.339,1.317,5.237,2.107,8.387,2.107c7.732,0,14-4.701,14-10.5C30,10.034,23.732,5.333,16,5.333z'/></svg>", quickReply: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerColor.rgb + ")' d='M16,5.333c-7.732,0-14,4.701-14,10.5c0,1.982,0.741,3.833,2.016,5.414L2,25.667l5.613-1.441c2.339,1.317,5.237,2.107,8.387,2.107c7.732,0,14-4.701,14-10.5C30,10.034,23.732,5.333,16,5.333z'/></svg>", threadWatcher: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='20' width='20' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerColor.rgb + ")' d='M16,8.286C8.454,8.286,2.5,16,2.5,16s5.954,7.715,13.5,7.715c5.771,0,13.5-7.715,13.5-7.715S21.771,8.286,16,8.286zM16,20.807c-2.649,0-4.807-2.157-4.807-4.807s2.158-4.807,4.807-4.807s4.807,2.158,4.807,4.807S18.649,20.807,16,20.807zM16,13.194c-1.549,0-2.806,1.256-2.806,2.806c0,1.55,1.256,2.806,2.806,2.806c1.55,0,2.806-1.256,2.806-2.806C18.806,14.451,17.55,13.194,16,13.194z'/></svg>", threadClosed: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.headerColor.rgb + ")' d='M22.335,12.833V9.999h-0.001C22.333,6.501,19.498,3.666,16,3.666S9.666,6.502,9.666,10h0v2.833H7.375V25h17.25V12.833H22.335zM11.667,10C11.667,10,11.667,10,11.667,10c0-2.39,1.944-4.334,4.333-4.334c2.391,0,4.335,1.944,4.335,4.333c0,0,0,0,0,0v2.834h-8.668V10z'/></svg>", threadPinned: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.tripColor.rgb + ")' d='M16,3.5c-4.142,0-7.5,3.358-7.5,7.5c0,4.143,7.5,18.121,7.5,18.121S23.5,15.143,23.5,11C23.5,6.858,20.143,3.5,16,3.5z M16,14.584c-1.979,0-3.584-1.604-3.584-3.584S14.021,7.416,16,7.416S19.584,9.021,19.584,11S17.979,14.584,16,14.584z'/></svg>", threadArchived: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.tripColor.rgb + ")' d='M15.5,3.029l-10.8,6.235L4.7,21.735L15.5,27.971l10.8-6.235V9.265L15.5,3.029zM24.988,10.599L16,15.789v10.378c0,0.275-0.225,0.5-0.5,0.5s-0.5-0.225-0.5-0.5V15.786l-8.987-5.188c-0.239-0.138-0.321-0.444-0.183-0.683c0.138-0.238,0.444-0.321,0.683-0.183l8.988,5.189l8.988-5.189c0.238-0.138,0.545-0.055,0.684,0.184C25.309,10.155,25.227,10.461,24.988,10.599z'/></svg>", menuButton: "<svg viewBox='0 0 30 30' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.blinkColor.rgb + ")' d='M10.129,22.186 16.316,15.999 10.129,9.812 13.665,6.276 23.389,15.999 13.665,25.725z'/></svg>", downArrow: "<svg viewBox='7 4 29 27' preserveAspectRatio='true' height='16' width='16' xmlns='http://www.w3.org/2000/svg'>" + "<path fill='rgb(" + this.tripColor.rgb + ")' d='M8.037,11.166L14.5,22.359c0.825,1.43,2.175,1.43,3,0l6.463-11.194c0.826-1.429,0.15-2.598-1.5-2.598H9.537C7.886,8.568,7.211,9.737,8.037,11.166z'/></svg>" }; if (theme.customCSS) { try { if (theme.customCSS[0] === "(") theme.customCSS = "\"+".concat(theme.customCSS); if (theme.customCSS[theme.customCSS.length - 1] === ")") theme.customCSS += "+\""; this.customCSS = eval($SS.trimLineBreaks(new String('"' + theme.customCSS.replace(/\"/g, "\\\"").replace(/\'/g, "\\\'") + '"'))); } catch (e) { alert("Error evaluating " + this.name + "'s theme.customCSS!\n" + e.message); this.customCSS = theme.customCSS; } } else this.customCSS = ""; this.preview = function() { var div = $("<div " + (this.hidden ? "hidden=true " : "") + " id=theme" + this.index + " class=\'theme-preview " + (($SS.conf["Selected Theme"] == $SS.conf["NSFW Theme"]) && ($SS.conf["Selected Theme"] == this.index) ? "selected nsfw" : ($SS.conf["Selected Theme"] == this.index ? "selected " : "") + ($SS.conf["NSFW Theme"] == this.index ? "nsfw " : "")) + "\'>").html("<div class=reply " + "style='background-color:" + this.mainColor.hex + "!important;border:1px solid " + this.brderColor.hex + "!important;color:" + this.textColor.hex + "!important'>" + "<div class=riceCheck style='background-color:" + this.inputColor.hex + "!important;border:1px solid " + this.inputbColor.hex + "!important;box-shadow:rgba(" + this.mainColor.shiftRGB(64) + ",.3) 0 1px;'></div>" + "<span style='color:" + this.titleColor.hex + "!important; font-weight: 700 !important'>" + this.name + "</span> " + "<span style='color:" + this.nameColor.hex + "!important; font-weight: 700 !important'>" + this.authorName + "</span>" + "<span style='color:" + this.tripColor.hex + "!important'> " + this.authorTrip + "</span>" + "<time style='color:" + this.textColor.hex + "'> 20XX.01.01 12:00 </time>" + "<a href='javascript:;' style='color:" + this.linkColor.hex + "!important' " + "onmouseover='this.setAttribute(\"style\",\"color:" + this.linkHColor.hex + "!important\")' " + "onmouseout='this.setAttribute(\"style\",\"color:" + this.linkColor.hex + "!important\")'>No.22772469</a>" + "<br><blockquote><span style='color:" + this.quoteColor.hex + "'>>implying this isn't a post</span><br>Post content is right here.</blockquote>" + "<p class='theme-buttons-container'>" + "<a href='javascript:;' title='Sets the SFW theme.' style='background-color:" + this.inputColor.hex + "!important;border:1px solid " + this.inputbColor.hex + "!important;color:" + this.textColor.hex + "!important'>SFW</a>" + "<a href='javascript:;' title='Sets the NSFW theme.' style='background-color:" + this.inputColor.hex + "!important;border:1px solid " + this.inputbColor.hex + "!important;color:" + this.textColor.hex + "!important'>NSFW</a>" + "<a href='javascript:;' title=Edit style='background-color:" + this.inputColor.hex + "!important;border:1px solid " + this.inputbColor.hex + "!important;color:" + this.textColor.hex + "!important'>Edit</a>" + "<a href='javascript:;' title=Delete style='background-color:" + this.inputColor.hex + "!important;border:1px solid " + this.inputbColor.hex + "!important;color:" + this.textColor.hex + "!important'>Delete</a></p>" + "<h3 class='sfw-label notsafe'>NSFW</h3>" + "<h3 class='sfw-label safe'>SFW</h3>" + "<h3 class='sfw-label both'>SFW & NSFW</h3>" + "</div>"); $(div).bind("click", function() { var $this = $(this); if ($this.hasClass("selected nsfw")) return; $this.parent().children(".selected").removeClass("selected"); $this.parent().children(".nsfw").removeClass("nsfw"); $this.addClass("selected nsfw"); $SS.options.save(); }); $("a[title='Sets the SFW theme.']", div).bind("click", function(e) { e.stopPropagation(); var $this = $(this); if ($this.hasClass("selected")) return; $this.parent().parent().parent().parent().children(".selected").removeClass("selected"); $this.parent().parent().parent().addClass("selected"); }); $("a[title='Sets the NSFW theme.']", div).bind("click", function(e) { e.stopPropagation(); var $this = $(this); if ($this.hasClass("nsfw")) return; $this.parent().parent().parent().parent().children(".nsfw").removeClass("nsfw"); $this.parent().parent().parent().addClass("nsfw"); }); $("a[title=Delete]", div).bind("click", function(e) { e.stopPropagation(); $SS.options.deleteTheme(index); }); $("a[title=Edit]", div).bind("click", function(e) { e.stopPropagation(); $SS.options.showTheme(index); }); return div; } }, /* HELPER METHODS */ formatFont: function(font) { if (font === "sans-serif" || font === "monospace") return font; return "'" + font + "'"; }, RGBFromHex: function(hex) { var rgb = []; hex = parseInt(hex, 16); rgb[0] = (hex >> 16) & 0xFF; rgb[1] = (hex >> 8) & 0xFF; rgb[2] = hex & 0xFF; return rgb; }, isLight: function(rgb) { return rgb[0] + rgb[1] + rgb[2] >= 400; }, trimLineBreaks: function(str) { return str.replace(/(\r\n|\r|\n)/gm, ""); }, cleanBase64: function(b64) { return b64.replace(/^(data:image\/(?:gif|jpe?g|png);base64,)(\r\n|\r|\n)?/gmi, ""); }, typeofBase64: function(b64) { switch (b64.substr(0, 8)) { case "PD94bWwg": return "svg+xml"; case "R0lGODlh": return "gif"; case "/9j/4AAQ": case "/9j/4QAY": return "jpeg"; case "iVBORw0K": default: return "png"; } }, validBase64: function(b64) { return /^(?:data:image\/(?:gif|jpe?g|png);base64,)?(?:[A-Za-z0-9+\/]{4})*(?:[A-Za-z0-9+\/]{2}==|[A-Za-z0-9+\/]{3}=|[A-Za-z0-9+\/]{4})$/i.test(b64); }, validImageURL: function(img) { return /^https?:\/\/.+$/i.test(img); }, getLocation: function(url) { var obj; if (typeof url === "string") { obj = document.createElement("a"); obj.href = location.protocol + "//" + url; } else obj = window.location; var pathname = obj.pathname.substr(1).split("/"); return { sub: obj.hostname.split(".")[0], board: pathname[0], home: location.hostname === "www.4chan.org", nsfw: /^(b|d|e|f|gif|h|hr|r|s|t|u|wg|i|ic|r9k|hm|y|hc|pol|soc|aco|s4s|trash)$/.test(pathname[0]), reply: pathname[1] === "thread", catalog: pathname[1] === "catalog", archive: pathname[1] === "archive" }; } }; /* END STYLE SCRIPT CLASSES */ $SS.init(); })();