├── img └── browser-2023-03-04.png ├── previous ├── ss18-font.user.css ├── ss16boardbanner.css ├── ss18-catalog.user.css ├── ss19-catalog.user.css ├── curabitr2.user.css ├── curabitr1.user.css └── ss16.user.min.css ├── readme.md ├── ss21boardbanner.css └── sidedish.user.js /img/browser-2023-03-04.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/saxamaphone69/ss21/HEAD/img/browser-2023-03-04.png -------------------------------------------------------------------------------- /previous/ss18-font.user.css: -------------------------------------------------------------------------------- 1 | @import url('https://fonts.googleapis.com/css?family=Arimo:400,700|Karla:400|Inconsolata:400|Material+Icons&display=swap'); 2 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | # ss21 2 | a self-centered, fresh attempt at (user)styling 4chan 3 | 4 | ![screenshot of ss21 applied](img/browser-2023-03-04.png) 5 | 6 | following the success (or lack of) from curabitr and xl, ss21 provides a fresh and clean userstyle for use with either [ccd0's 4chan x](https://ccd0.github.io/4chan-x/) or [tuxedotako's typescript fork](https://github.com/TuxedoTako/4chan-xt) in ~~2019, 2020, 2021, 2022, 2023, 2024~~, 2025! 7 | 8 | created by **saxamaphone** "sax" `!3.saxN0DHY`, who has been making userstyles for 4chan since 2009 with styles such as 3 Shades of 4chan (which only exists as Midnight Caek in App/OneeChan now), curabitr, and xl 9 | 10 | ss21 is a fresh attempt to make a userstyle that looks radically different from the typical App/OneeChan aesthetic of today, utilising modern web standards and bleeding edge CSS technologies 11 | 12 | ## about 13 | | feature | detail | 14 | | --- | --- | 15 | | **documented** | looking through the original `ss21` file contains comments that explain what things do and why they are there | 16 | | **variables** | thankfully, we now use the preprocessor `.styl` within stylus for built in functions not previously possible | 17 | | **sidedish** | unlike most userstyles, `ss21` requires a companion userscript for additonal rice and features not found in 4chan X | 18 | | **filters** | through the use of 4chan X's filtering system, additional classes are added to certain posts for further enhancements | 19 | | **web fonts** | using `@import`, we can load fonts from the web, no longer requiring downloaded and locally installed fonts | 20 | | **rebase** | utilising code from well-established web projects such as bootstrap, carbon, and the material design guidelines, elements are rendered consistently and correctly across browsers | 21 | 22 | ### another userscript? a.k.a. why you need `sidedish` too 23 | `sidedish` adds those few extra ricing options: 24 | - removes the `:` from the settings' option labels and their descriptions 25 | - adds a scrolling progress indicator to the header 26 | - posts that have 8 or more backlinks have an additional class added to them indicating 'hotness' for styling 27 | - wraps the numbers in thread summaries in `b` to make them stand out 28 | - swaps the post info and file elements in OPs for consistent styling across posts 29 | - strips the brackets around the page number in the post info on the index 30 | - gives 'tall' posts a discernible class for styling 31 | - approximates aspect ratio of files and adds a `data-aspect-ratio` attribute for styling 32 | - adds a shortcut to crudely download all files within a thread 33 | - adds an off-canvas navigation menu/drawer of all the boards 34 | - changes the text of the QR buttons so they can become icons 35 | - adds a `captcha-loaded` discernible class to the captcha for styling 36 | - resizes large quote previews to fix the viewport 37 | - stylises the bottom board list to match the footer aesthetic, including moving the pass link 38 | - adds a discernible class for index sorting mode 39 | - if enabled in `ss21`, provides a polyfill for `display: masonry` 40 | - adds a imperial/metric weight and length unit converter for /fit/ 41 | - adds OPs image/video to the banner for aesthetics 42 | 43 | it should be noted that `ss21` **does not** function properly with the default 4chan extension or App/OneeChan 44 | 45 | it is **highly** recommended you play with the settings within the userstyle 46 | 47 | ## installation 48 | this userstyle is currently being actively developed for chrome first, with firefox as an after thought. you will require [stylus](http://add0n.com/stylus.html) ([don't use stylish anymore](https://robertheaton.com/2018/08/16/stylish-is-back-and-you-still-shouldnt-use-it/)), a userscript manager such as [tampermonkey](https://tampermonkey.net/), and a blocking extension such as [ublock origin](https://chrome.google.com/webstore/detail/ublock-origin/cjpalhdlnbpafiamejdnhcphjbkeiagm?hl=en). 49 | 50 | 1. install [`ss21.user.styl`](https://github.com/saxamaphone69/ss21/raw/main/ss21.user.styl) (stylus should prompt you to install) 51 | 2. install [`sidedish.user.js`](https://github.com/saxamaphone69/ss21/raw/main/sidedish.user.js) (your userscript manager should prompt you to install) 52 | 3. add the blocking filters (to your blocking extension) and 4chan x filters (to 4chan x) below 53 | 4. cross your fingers and hope it works! 54 | 55 | ### blocker filters 56 | a blocker is used to not only hide ads, but also block some other stuff to save on network requests. 57 | `danbo` and `pubfuture` ads are blocked via easylist. if you're not using that, you'll need to zap them on your own. 58 | go to your blocker-of-choice options, and locate where you can add your own filters. add the following: 59 | 60 | ``` 61 | ! ss21 Blocking Suggestions 62 | ! REQUIRED: Block all external stylesheets (Yostuba, Tomorrow, etc.) 63 | *//s.4cdn.org/css^$domain=boards.4chan.org 64 | *//s.4cdn.org/js/prettify/prettify.*.css 65 | 66 | ! REQUIRED: Block potentially harmful scripts inserted into 4chan 67 | @@||4chan.org^*$csp=default-src 'self' * data: 'unsafe-inline' 'unsafe-eval' 68 | 69 | ! This one used to work, or was needed for something, but I don't remember. Here for archives sake: 70 | ! 4chan.org##script:inject(abort-current-inline-script.js, String.fromCharCode) 71 | 72 | ! Add exceptions to certain stylesheets (flags, tegaki, etc.) 73 | @@||s.4cdn.org/css/flags.*.css 74 | @@||s.4cdn.org/css/painter.*.css 75 | @@||s.4cdn.org/css/tegaki.*.css 76 | @@||s.4cdn.org/css/yui.css 77 | @@||s.4cdn.org/css/global.*.css 78 | @@||s.4cdn.org/css/error.css 79 | 80 | ! RECOMMENDED: Block board banners (above /g/ - Technology) 81 | *//s.4cdn.org/image/title/*^$domain=boards.4chan.org,important 82 | 83 | ! RECOMMENDED: Block contest banners (advertisements to other boards) 84 | *//s.4cdn.org/image/contest_banners/*^$domain=boards.4chan.org,important 85 | 86 | ! OPTIONAL: Block snow.js, which adds snowflakes at Christmas 87 | *//s.4cdn.org/js/snow.js$script,important 88 | 89 | ! OPTIONAL: Block the Google Analytics script 90 | *//www.google-analytics.com/analytics.js^$domain=boards.4chan.org 91 | ``` 92 | 93 | essentially: 94 | - block those bitcoin mining ads hiroshimoot uses 95 | - all 4chan css, with a few exceptions 96 | - title and contest banners (technically skippable) 97 | 98 | ### 4chan x filters 99 | ss21 makes use of the highlighting feature in 4chan x to give certain posts extra styling. if you'd like to experience ss21 as intended, add these filters: 100 | 101 | | section | filter | 102 | | --- | --- | 103 | | **post numbers** | `/(\d)\1$/;highlight:post--dubs;top:no;boards:s4s` | 104 | | **capcodes** | `/Founder$/;highlight:poster--founder;op:yes`
`/Admin$/;highlight:poster--admin;op:yes`
`/Mod$/;highlight:poster--mod;op:yes`
`/Manager$/;highlight:poster--manager;op:yes`
`/Developer$/;highlight:poster--developer;op:yes`
`/Verified$/;highlight:poster--verified;op:yes` | 105 | | **pass dates** | `/./;highlight:poster--pass;top:no;` | 106 | | **subject** | `/./;op:only;top:no;highlight:thread--subject`
`/(.){40,}/;op:only;top:no;highlight:thread--subject-long` | 107 | | **comment** | `/^\W*(\w+\b\W*){50,90}$/;op:only;top:no;highlight:thread--long`
`/^\W*(\w+\b\W*){91,149}$/;op:only;top:no;highlight:thread--extra-long`
`/^\W*(\w+\b\W*){150,}$/;op:only;top:no;highlight:thread--silly-long`
`/(?:[^\n]*(\n+)){5,}/;op:only;top:no;highlight:thread--new-lines` | 108 | | **filenames** | `/.webm$/;highlight:file--video;top:no;`
`/.gif$/;highlight:file--gif;top:no;` | 109 | | **image dimensions** | `/\d{4}x/;highlight:file--wide;top:no;`
`/x\d{4}/;highlight:file--high;top:no;` | 110 | | **filesize** | `/MB/;op:yes;highlight:file--huge;top:no;` | 111 | 112 | ## reporting bugs and feature requests 113 | feel free to open an issue for any bugs or requests here on the issue tracker 114 | 115 | ## licensing 116 | code released under CC-BY-SA-4.0
117 | contains code from https://github.com/ryanmorr/ready
118 | icons provided by https://www.material.io/resources/icons/ 119 | -------------------------------------------------------------------------------- /previous/ss16boardbanner.css: -------------------------------------------------------------------------------- 1 | @-moz-document regexp("https://boards\\.4chan(?:nel)?\\.org.*") { 2 | /* 3 | .board_ .boardBanner::after { 4 | background-image: url(''); 5 | } 6 | */ 7 | .board_g .boardBanner::after { 8 | background-image: url(''); 9 | } 10 | } 11 | -------------------------------------------------------------------------------- /ss21boardbanner.css: -------------------------------------------------------------------------------- 1 | @-moz-document regexp("https://boards\\.4chan(?:nel)?\\.org.*") { 2 | /* 3 | Use the following format as a guide: 4 | .board_[ENTER_THE_BOARD_LETTER_HERE].boardBanner::after { 5 | background-image: url(''); 6 | } 7 | */ 8 | .board_g .boardBanner::after { 9 | background-image: url(''); 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /previous/ss18-catalog.user.css: -------------------------------------------------------------------------------- 1 | /* ==UserStyle== 2 | @name ss18 catalogue 3 | @namespace github.com/openstyles/stylus 4 | @version 1.0.0 5 | @description A new userstyle 6 | @author Me 7 | ==/UserStyle== */ 8 | 9 | @-moz-document domain("boards.4chan.org"), 10 | domain('boards.4channel.org') { 11 | /** 12 | * catalogue support 😂👌 13 | * what level of css archeticure are you on? 14 | * idk, bem or something 15 | * ha, pathetic; watch this 16 | * 17 | */ 18 | 19 | /** 20 | * if you switch from catalogue view to any other index view, the catalogue 21 | * specific elements remain in the dom, so need to hide them 22 | */ 23 | 24 | :root:not(.catalog-mode) .board [class^=catalog] { 25 | display: none; 26 | } 27 | 28 | .catalog-container > .hide-thread-button, 29 | .catalog-post .fileThumb, 30 | :root.bottom-backlinks .catalog-post > .container, 31 | .werkTyme-filename { 32 | display: none; 33 | } 34 | 35 | :root.catalog-mode .board { 36 | max-width: 100%; 37 | width: 100%; 38 | display: grid; 39 | grid-gap: 1rem; 40 | grid-auto-rows: 22.5rem; 41 | grid-auto-flow: dense; 42 | justify-content: stretch; 43 | padding: 0 1.5rem; 44 | margin-bottom: 2rem; 45 | } 46 | 47 | :root.catalog-mode .board .thread:last-of-type { 48 | margin-bottom: 0; 49 | } 50 | 51 | :root.catalog-mode .board.catalog-small { 52 | grid-template-columns: repeat(12, 1fr); 53 | } 54 | 55 | :root.catalog-mode .board.catalog-large { 56 | grid-template-columns: repeat(6, 1fr); 57 | } 58 | 59 | /** 60 | * by default, each thread takes up 1 column. we also have to remove the 61 | * `padding` and `margin` we give to normal threads 62 | */ 63 | 64 | .catalog-thread { 65 | position: relative; 66 | grid-column: span 1; 67 | padding: 0; 68 | margin-bottom: 0; 69 | /*overflow: hidden;*/ 70 | z-index: 2; 71 | max-height: 20rem; 72 | border-radius: 2px; 73 | box-shadow: 0 .125rem .25rem rgba(33, 33, 33, .25); 74 | transition: all .25s; 75 | } 76 | 77 | .catalog-thread.thread--long { 78 | grid-column: span 2; 79 | } 80 | 81 | .catalog-thread.thread--extra-long { 82 | grid-column: span 2; 83 | grid-row: span 2; 84 | max-height: 41rem; 85 | } 86 | /* 87 | .catalog-thread::after { 88 | content: ''; 89 | display: block; 90 | position: absolute; 91 | left: -1rem; 92 | top: -1rem; 93 | width: calc(100% + 2rem); 94 | height: calc(100% + 2rem); 95 | background-color: transparent; 96 | transition: background-color .25s, transform .25s; 97 | transform: scale(0); 98 | } 99 | 100 | .catalog-thread:hover::after { 101 | background-color: var(--background-primary); 102 | box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 103 | 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 104 | 0px 1px 10px 0px rgba(0, 0, 0, 0.12); 105 | transform: scale(1); 106 | z-index: 3; 107 | } 108 | */ 109 | /* 110 | .catalog-thread:hover .catalog-post { 111 | z-index: 4; 112 | transform: scale(1.2); 113 | } 114 | */ 115 | /* 116 | 117 | .catalog-thread:hover { 118 | transform: scale(1.02); 119 | z-index: 3; 120 | } 121 | 122 | .catalog-thread::after { 123 | content: ''; 124 | display: block; 125 | position: absolute; 126 | left: -1rem; 127 | top: -1rem; 128 | width: calc(100% + 2rem); 129 | height: calc(100% + 2rem); 130 | background-color: transparent; 131 | transition: background-color .25s; 132 | z-index: 2; 133 | } 134 | 135 | .catalog-thread:hover::after { 136 | background-color: var(--background-primary); 137 | box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 138 | 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 139 | 0px 1px 10px 0px rgba(0, 0, 0, 0.12); 140 | }*/ 141 | 142 | .catalog-post { 143 | display: flex; 144 | flex-direction: column; 145 | align-items: stretch; 146 | padding: 0; 147 | min-height: 20rem; 148 | position: relative; 149 | transition: transform .25s; 150 | } 151 | 152 | .catalog-post > .postInfo > :not(.subject), 153 | .catalog-post .subject:not(:empty)::after { 154 | display: none; 155 | } 156 | 157 | .catalog-post .file { 158 | order: 1; 159 | } 160 | 161 | .catalog-thread.thread--extra-long .catalog-post { 162 | min-height: 41rem; 163 | } 164 | 165 | .catalog-link { 166 | display: block; 167 | position: relative; 168 | order: 2; 169 | } 170 | 171 | .catalog-thumb { 172 | object-fit: cover; 173 | object-position: 50% 50%; 174 | width: 100% !important; 175 | height: 10rem !important; 176 | } 177 | 178 | .catalog-stats { 179 | order: 5; 180 | position: relative; 181 | padding: 0 .5rem 0 .75rem; 182 | display: flex; 183 | align-items: center; 184 | height: 3rem; 185 | background-color: var(--background-secondary); 186 | border-top: 1px solid var(--background-outline); 187 | } 188 | 189 | .catalog-stats > span[title] { 190 | color: var(--text-hint-on-background); 191 | cursor: help; 192 | } 193 | 194 | .catalog-stats > span[title] > span { 195 | color: var(--text-primary-on-background); 196 | } 197 | 198 | .catalog-stats > .catalog-icons { 199 | flex: 1; 200 | } 201 | 202 | .catalog-icons > img { 203 | margin-left: .5rem; 204 | } 205 | 206 | .catalog-stats > .menu-button { 207 | position: relative; 208 | top: auto; 209 | right: auto; 210 | display: inline-flex; 211 | align-items: center; 212 | } 213 | 214 | .catalog-post > .postInfo { 215 | order: 3; 216 | position: relative; 217 | } 218 | 219 | .catalog-post .subject:not(:empty) { 220 | color: var(--text-primary-on-dark); 221 | background-color: rgba(0, 0, 0, .5); 222 | display: block; 223 | position: absolute; 224 | top: -3rem; 225 | width: 100%; 226 | padding: 0 1rem; 227 | height: 3rem; 228 | line-height: 3; 229 | overflow: hidden; 230 | white-space: nowrap; 231 | text-overflow: ellipsis; 232 | pointer-events: none; 233 | } 234 | 235 | .catalog-post > .postMessage { 236 | font-size: .875rem; 237 | padding: 1rem 1rem 1.5rem; 238 | margin: 0; 239 | flex: 1 1 4.5rem; 240 | overflow: hidden; 241 | order: 4; 242 | word-break: break-word; 243 | } 244 | /* 245 | .catalog-post > .postMessage:empty { 246 | display: none; 247 | } 248 | */ 249 | .catalog-replies { 250 | display: none; 251 | order: 6; 252 | } 253 | /* 254 | .catalog-thread:hover .catalog-post > .postMessage { 255 | overflow: auto; 256 | } 257 | */ 258 | /** 259 | * idea of a "full card" on hover taken from smashing magazine redesign and also 260 | * 4chan x's catalogue 261 | */ 262 | 263 | /* 264 | .article--grid::before { 265 | display: block; 266 | width: calc(100% + 60px); 267 | height: calc(100% + 60px); 268 | height: 100%; 269 | content: ""; 270 | position: absolute; 271 | left: -30px; 272 | top: -30px; 273 | transition: background-color .1s ease-out; 274 | background-color: transparent; 275 | padding: 30px; 276 | } 277 | .article--grid:not(.col--article--meow):hover::before { 278 | background-color: #fff; 279 | box-shadow: 0 0 40px rgba(0,0,0,.15); 280 | } 281 | 282 | .article--grid { 283 | display: -ms-flexbox; 284 | display: flex; 285 | -ms-flex-direction: column; 286 | flex-direction: column; 287 | min-height: 0; 288 | padding: 0 1em; 289 | padding-bottom: 150px; 290 | transition: all .2s ease-out; 291 | position: relative; 292 | } 293 | .article--grid:not(.col--article--meow):hover { 294 | transform: scale(1.02); 295 | } 296 | .article--grid__title a { 297 | transition: all .2s ease-out; 298 | color: #111; 299 | text-decoration: none; 300 | padding: 10px 0; 301 | background-image: linear-gradient(#2da2c5,#2da2c5); 302 | background-repeat: no-repeat; 303 | background-size: 100% 1.5px; 304 | background-position: center bottom 29%; 305 | background-origin: padding-box; 306 | text-shadow: 3px 0 #f6f3f2, 2px 0 #f6f3f2, 1px 0 #f6f3f2, -1px 0 #f6f3f2, -2px 0 #f6f3f2, -3px 0 #f6f3f2; 307 | transition: color .1s ease-out; 308 | position: static; 309 | } 310 | .article--grid:hover .article--grid__title a { 311 | color: #d33a2c; 312 | text-decoration: none; 313 | padding: 10px 0; 314 | background-image: linear-gradient(#666,#666); 315 | background-repeat: no-repeat; 316 | background-size: 100% 1.5px; 317 | background-position: center bottom 29%; 318 | background-origin: padding-box; 319 | text-shadow: 3px 0 #fff, 2px 0 #fff, 1px 0 #fff, -1px 0 #fff, -2px 0 #fff, -3px 0 #fff; 320 | transition: color .1s ease-out; 321 | } 322 | */ 323 | } 324 | -------------------------------------------------------------------------------- /previous/ss19-catalog.user.css: -------------------------------------------------------------------------------- 1 | /* ==UserStyle== 2 | @name ss19 catalogue 3 | @namespace github.com/openstyles/stylus 4 | @version 1.0.0 5 | @description A new userstyle 6 | @author Me 7 | ==/UserStyle== */ 8 | @-moz-document domain('boards.4chan.org'), 9 | domain('boards.4channel.org'){ 10 | 11 | /* 12 | * hides the file thumbnail 13 | */ 14 | 15 | :root:not(.catalog-mode) .board [class^=catalog], 16 | .catalog-container > .hide-thread-button, 17 | .catalog-post > .file, 18 | .catalog-post > .postInfo > :not(.subject), 19 | .catalog-post .subject:not(:empty)::after, 20 | :root .catalog-post > .container { 21 | display: none; 22 | } 23 | 24 | /* 25 | .catalog-container:not(:hover) > * > .file, 26 | .catalog-container:not(:hover) > * > .postInfo > :not(.subject), 27 | .catalog-container:not(:hover) > * > .catalog-replies, 28 | .catalog-container:not(:hover) .extra-linebreak, 29 | .catalog-container:not(:hover) .abbr, 30 | :root:not(.catalog-hover-expand) .catalog-container > * > .file, 31 | :root:not(.catalog-hover-expand) .catalog-container > * > .postInfo > :not(.subject), 32 | :root:not(.catalog-hover-expand) .catalog-container > * > .catalog-replies, 33 | :root:not(.catalog-hover-expand) .catalog-container .extra-linebreak, 34 | :root:not(.catalog-hover-expand) .catalog-container .abbr, 35 | .catalog-thread > .catalog-container > :not(.catalog-post), 36 | .catalog-post > .file > :not(.fileText), 37 | .catalog-post > * > .fileText > :not(:first-child), 38 | .catalog-post > .postInfo > :not(.subject):not(.nameBlock):not(.dateTime), 39 | .catalog-post > * > * > .posteruid, 40 | :root.bottom-backlinks .catalog-post > .container, 41 | .post:not(.catalog-post) > .catalog-link, 42 | .post:not(.catalog-post) > .catalog-stats, 43 | .post:not(.catalog-post) > .catalog-replies { 44 | display: none; 45 | } 46 | */ 47 | /* 48 | * in catalogue mode, reset the board to take full width 49 | */ 50 | 51 | :root.catalog-mode .board { 52 | max-width: none; 53 | padding: 0 3.5rem; 54 | display: grid; 55 | grid-gap: 1rem; 56 | grid-auto-rows: 15rem; 57 | align-items: stretch; 58 | grid-auto-flow: dense; 59 | } 60 | 61 | :root.catalog-mode .board.catalog-small { 62 | grid-template-columns: repeat(12, 1fr); 63 | } 64 | 65 | :root.catalog-mode .board.catalog-large { 66 | grid-template-columns: repeat(8, 1fr); 67 | } 68 | 69 | @media (max-width: 75rem) { 70 | :root.catalog-mode .board.catalog-small { 71 | grid-template-columns: repeat(6, 1fr); 72 | } 73 | 74 | :root.catalog-mode .board.catalog-large { 75 | grid-template-columns: repeat(4, 1fr); 76 | } 77 | } 78 | 79 | /** 80 | * by default, each thread takes up 1 column. we also have to remove the 81 | * `padding` and `margin` we give to normal threads 82 | */ 83 | 84 | .catalog-thread { 85 | position: relative; 86 | grid-column: span 1; 87 | padding: 0; 88 | margin: 0; 89 | z-index: 2; 90 | min-height: 15rem; 91 | max-height: 15rem; 92 | /*box-shadow: 0 3px 1px -2px rgba(0,0,0,.2), 93 | 0 2px 2px 0 rgba(0,0,0,.14), 94 | 0 1px 5px 0 rgba(0,0,0,.12);*/ 95 | transition: all .25s; 96 | border-radius: 4px; 97 | } 98 | 99 | .catalog-thread.thread--long { 100 | grid-column: span 2; 101 | } 102 | 103 | .catalog-thread.thread--extra-long { 104 | grid-column: span 2; 105 | grid-row: span 2; 106 | max-height: 31rem; 107 | } 108 | 109 | .catalog-post { 110 | display: flex; 111 | flex-direction: column; 112 | align-items: stretch; 113 | position: relative; 114 | box-shadow: none; 115 | transition: all .25s; 116 | min-height: 15rem; 117 | border-radius: 4px; 118 | overflow: hidden; 119 | } 120 | 121 | .catalog-thread.thread--extra-long .catalog-post { 122 | min-height: 31rem; 123 | } 124 | 125 | .catalog-post .postInfo { 126 | background: none; 127 | padding: 0; 128 | order: 3; 129 | position: relative; 130 | line-height: inherit; 131 | height: auto; 132 | } 133 | 134 | .catalog-post .subject:not(:empty) { 135 | color: var(--text-primary-on-dark); 136 | background-color: rgba(0, 0, 0, .5); 137 | display: block; 138 | position: absolute; 139 | top: calc(-1 * (18px + 32px)); 140 | width: 100%; 141 | max-width: none; 142 | padding: 0 .5rem; 143 | height: 2rem; 144 | line-height: 2; 145 | letter-spacing: .02em; 146 | overflow: hidden; 147 | white-space: nowrap; 148 | text-overflow: ellipsis; 149 | pointer-events: none; 150 | } 151 | 152 | .catalog-link { 153 | display: block; 154 | position: relative; 155 | order: 1; 156 | border-top-left-radius: 4px; 157 | border-top-right-radius: 4px; 158 | overflow: hidden; 159 | } 160 | 161 | .catalog-stats { 162 | order: 2; 163 | text-align: center; 164 | font-size: .75rem; 165 | } 166 | 167 | .catalog-stats > span[title] { 168 | color: var(--text-hint-on-background); 169 | } 170 | 171 | .catalog-stats > span[title] > span { 172 | color: var(--text-primary-on-background); 173 | } 174 | 175 | .catalog-post:not(:hover) .menu-button { 176 | opacity: 0; 177 | } 178 | 179 | .catalog-icons { 180 | display: inline-block; 181 | transform: scale(.75); 182 | } 183 | 184 | .catalog-stats #menu { 185 | text-align: left; 186 | } 187 | 188 | .catalog-thumb { 189 | object-fit: cover; 190 | object-position: 50% 50%; 191 | width: 100% !important; 192 | height: 7.5rem !important; 193 | } 194 | 195 | .catalog-post > .postMessage { 196 | font-size: .75rem; 197 | letter-spacing: 0.025em; 198 | flex: 1 1 auto; 199 | margin: 0; 200 | order: 4; 201 | padding: .5rem .75rem; 202 | position: relative; 203 | } 204 | /* 205 | .catalog-post::before { 206 | content: ''; 207 | display: block; 208 | width: calc(100% + 2rem); 209 | height: calc(100% + 2rem); 210 | position: absolute; 211 | left: -1rem; 212 | top: -1rem; 213 | transition: all .25s ease-out; 214 | background-color: transparent; 215 | padding: 1rem; 216 | border-radius: 3px; 217 | } 218 | 219 | .catalog-post:hover::before { 220 | background-color: #fff; 221 | box-shadow: 0 8px 17px 2px rgba(0,0,0,0.14), 222 | 0 3px 14px 2px rgba(0,0,0,0.12), 223 | 0 5px 5px -3px rgba(0,0,0,0.2); 224 | } 225 | */ 226 | .catalog-replies { 227 | font-size: .75rem; 228 | position: relative; 229 | order: 6; 230 | } 231 | /* 232 | .catalog-post:hover { 233 | transform: scale(1.02); 234 | z-index: 1; 235 | } 236 | */ 237 | .catalog-container:not(:hover) > * > .file, 238 | .catalog-container:not(:hover) > * > .postInfo > :not(.subject), 239 | .catalog-container:not(:hover) > * > .catalog-replies, 240 | .catalog-container:not(:hover) .extra-linebreak, 241 | .catalog-container:not(:hover) .abbr, 242 | :root:not(.catalog-hover-expand) .catalog-container > * > .file, 243 | :root:not(.catalog-hover-expand) .catalog-container > * > .postInfo > :not(.subject), 244 | :root:not(.catalog-hover-expand) .catalog-container > * > .catalog-replies, 245 | :root:not(.catalog-hover-expand) .catalog-container .extra-linebreak, 246 | :root:not(.catalog-hover-expand) .catalog-container .abbr, 247 | .catalog-thread > .catalog-container > :not(.catalog-post), 248 | .catalog-post > .file > :not(.fileText), 249 | .catalog-post > * > .fileText > :not(:first-child), 250 | .catalog-post > .postInfo > :not(.subject):not(.nameBlock):not(.dateTime), 251 | .catalog-post > * > * > .posteruid, 252 | :root.bottom-backlinks .catalog-post > .container, 253 | .post:not(.catalog-post) > .catalog-link, 254 | .post:not(.catalog-post) > .catalog-stats, 255 | .post:not(.catalog-post) > .catalog-replies { 256 | display: none; 257 | } 258 | 259 | .catalog-replies::before { 260 | content: ''; 261 | height: 1px; 262 | width: calc(100% - 1rem); 263 | margin: auto; 264 | background-color: var(--background-outline); 265 | display: block; 266 | } 267 | 268 | .catalog-reply { 269 | white-space: nowrap; 270 | 271 | display: flex; 272 | flex-direction: row; 273 | align-items: stretch; 274 | } 275 | .catalog-reply > * { 276 | padding: 3px; 277 | overflow: hidden; 278 | flex: none; 279 | } 280 | .catalog-reply > span { 281 | font-style: italic; 282 | font-weight: bold; 283 | } 284 | .catalog-reply-excerpt { 285 | -webkit-flex: 1 1 auto; 286 | flex: 1 1 auto; 287 | } 288 | 289 | .catalog-container:not(:hover) { 290 | overflow: hidden; 291 | box-shadow: 0 3px 1px -2px rgba(0,0,0,.2), 292 | 0 2px 2px 0 rgba(0,0,0,.14), 293 | 0 1px 5px 0 rgba(0,0,0,.12); 294 | } 295 | 296 | .catalog-container { 297 | position: absolute; 298 | top: 0; 299 | left: 0; 300 | right: 0; 301 | bottom: 0; 302 | z-index: 9; 303 | } 304 | 305 | .catalog-post { 306 | margin: 0; 307 | overflow: visible; 308 | } 309 | 310 | .catalog-post { 311 | position: absolute; 312 | top: 0; 313 | left: 0; 314 | right: 0; 315 | } 316 | 317 | .catalog-container:hover .catalog-post { 318 | top: .5rem; 319 | margin: -1rem -3rem; 320 | transform: scale(1.02) translateY(-1%); 321 | box-shadow: 0 8px 17px 2px rgba(0,0,0,0.14), 322 | 0 3px 14px 2px rgba(0,0,0,0.12), 323 | 0 5px 5px -3px rgba(0,0,0,0.2); 324 | } 325 | 326 | .catalog-thread:hover { 327 | z-index: 10; 328 | } 329 | 330 | } 331 | -------------------------------------------------------------------------------- /previous/curabitr2.user.css: -------------------------------------------------------------------------------- 1 | /* ==UserStyle== 2 | @name curabitr 2 3 | @namespace github.com/openstyles/stylus 4 | @version 1.0.0 5 | @description A new userstyle 6 | @author Me 7 | ==/UserStyle== */ 8 | @-moz-document domain("boards.4chan.org") { 9 | 10 | /* 11 | aw yeah, google web fonts BITCH 12 | */ 13 | @font-face { 14 | font-family: Gudea; 15 | src: url('http://themes.googleusercontent.com/font?kit=thW9JAelqegPZr6cy_hdlJuy9QftGgiCbPT5J2Tle6QGEtCW0q5T6QHEAICoCh1h9R715REvNVFz5maQ3RAjMvuvYlUZxjWJuWoIFYd8ZVs9VGRJmXaKNSd0UG6XHo4E&text') format('woff'); 16 | } 17 | 18 | @font-face { 19 | font-family: GudeaBold; 20 | font-weight: 800; 21 | src: url('http://themes.googleusercontent.com/font?kit=6M2RKly85u67vSsXH0-zqihqGa-CSr3nQtF3lrv2wWeu7RP096c_0cFQ7arjjB7ybFaXKHeky_O7IdzbE_trRh2NL1ThVuLv506WDWjwTFK0tkCcv8VGcP6XCC56Ww8-&text') format('woff'); 22 | } 23 | 24 | /* 25 | next, we kill the crab (getting rid of shit i don't personally use) 26 | 1) banner and heading 27 | 2) posting mode: reply 28 | 3) [return] [bottom] [top] 29 | 4) bottom navigation 30 | 5) horizontal lines 31 | 6) style changer (you're using this one!) and reporting/post deletion (NO SHAME, NO BLAME) 32 | 7) copyright crap 33 | 8) ads (>not using adblock, >2025) 34 | */ 35 | .boardBanner, 36 | /* 1) */ 37 | .postingMode, 38 | /* 2) */ 39 | .navLinks, 40 | /* 3) */ 41 | #boardNavDesktopFoot, 42 | /* 4) */ 43 | hr, 44 | /* 5) */ 45 | .deleteform, 46 | .stylechanger, 47 | /* 6) */ 48 | #absbot, 49 | /* 7) */ 50 | img[src^="//static.4chan.org/support/"]/* 8) */ 51 | { 52 | display: none!important 53 | } 54 | 55 | /* 56 | postform specific crap (only effects you if you AREN'T using quick reply for some reason) 57 | 1) formally .postblock 58 | 2) recaptcha buttons 59 | 3) more recaptcha stuff 60 | 4) browse button (file input for firefox) 61 | 5) (password used for file deletion) 62 | 6) posting rules 63 | */ 64 | #postForm > tbody > tr > td:first-child, 65 | /* 1) */ 66 | #recaptcha_table tr[height] > td:not(:first-child), 67 | /* 2) */ 68 | #recaptcha_table tr[height] + tr > td:not(:first-child), 69 | /* 3) */ 70 | #postForm #postFile > input[type=button], 71 | /* 4) */ 72 | #postForm #postPassword + span, 73 | /* 5) */ 74 | #postForm .rules/* 6) */ 75 | { 76 | display: none!important 77 | } 78 | 79 | /* 80 | general reset: 81 | 1) border-box because fuck you when i say 70 i mean 70 82 | 2) indian red selection (feel free to make highlighed text your own colour) 83 | 3) i don't want no ugly border around focused elements, i'm not blind 84 | 4) font reset (and making sure bold is actual bold, not faux bold) 85 | 5) links 86 | 6) text-shadow for web2.0 87 | */ 88 | * { 89 | /* 1) */ 90 | -moz-box-sizing: border-box !important; 91 | box-sizing: border-box !important; 92 | } 93 | 94 | ::selection { 95 | /* 2) */ 96 | color: #fafafa !important; 97 | background: indianRed !important; 98 | } 99 | 100 | ::-moz-selection { 101 | color: #fafafa !important; 102 | background: indianRed !important; 103 | } 104 | 105 | :focus, 106 | :active { 107 | /* 3) */ 108 | outline: 0 !important; 109 | } 110 | 111 | /* 112 | -moz-hyphens:auto; 113 | -ms-hyphens:auto; 114 | -webkit-hyphens:auto; 115 | hyphens:auto; 116 | word-wrap:break-word; 117 | */ 118 | html { 119 | word-wrap: break-word; 120 | overflow-wrap: break-word; 121 | overflow-y: scroll; 122 | position: relative; 123 | height: 100%; 124 | } 125 | 126 | body, 127 | span, 128 | div, 129 | input, 130 | textarea, 131 | select, 132 | td, 133 | strong, 134 | a, 135 | big { 136 | /* 4) */ 137 | font-family: Gudea, Helvetica, Arial, sans-serif !important; 138 | font-size: 1em !important; 139 | font-weight: 400 !important; 140 | line-height: 1.4 !important; 141 | letter-spacing: .2px; 142 | color: #2d2d2d !important; 143 | vertical-align: baseline !important; 144 | } 145 | 146 | .subject, 147 | .name, 148 | .capcode, 149 | .pages strong, 150 | #boardNavDesktop .current { 151 | font-family: GudeaBold, Helvetica, Arial, sans-serif !important; 152 | font-weight: 800 !important; 153 | } 154 | 155 | a { 156 | /* 5) */ 157 | color: cornflowerBlue !important; 158 | text-decoration: none !important; 159 | } 160 | 161 | blockquote { 162 | /* 6) */ 163 | text-shadow: 0 1px 1px #fafafa; 164 | } 165 | 166 | .abbr, 167 | .summary { 168 | color: #ababab !important; 169 | } 170 | 171 | .spoiler { 172 | text-shadow: none; 173 | background: #2d2d2d !important; 174 | border-radius: 3px; 175 | -moz-transition: color .1s; 176 | } 177 | 178 | .spoiler:hover { 179 | color: #fafafa !important; 180 | } 181 | 182 | /* 183 | the meaty part (vanilla 4chan only) 184 | */ 185 | body { 186 | /*background-color: 187 | background-image: 188 | background-position: 189 | background-repeat: 190 | background-attachment:*/ 191 | padding: 0 !important; 192 | margin: 0 !important; 193 | position: relative; 194 | height: 100%; 195 | } 196 | 197 | body { 198 | /* this means no harmony */ 199 | background-size: calc(10 * 0.5px) calc(10 * 0.5px), cover; 200 | background-image: radial-gradient(#ddd 0.5px, transparent 0.5px), -webkit-radial-gradient(50% 50%, circle cover, #fafafa, #ededed 100%) !important; 201 | background-attachment: fixed !important; 202 | background-repeat: repeat !important; 203 | /* but what is that you say? you want harmony? uncomment the following line for permanent harmony oh love */ 204 | /*background: url("http://static.4chan.org/image/tmp/rainbow.gif") repeat scroll 0 0 #EEF2FF !important;*/ 205 | } 206 | 207 | /* 208 | body::after { 209 | content: ''; 210 | display: block; 211 | height: 935px; 212 | width: 715px; 213 | background: url('file:///W:/curabitr/ANIME.png'); 214 | position: fixed; 215 | bottom: -250px; 216 | right: -100px; 217 | pointer-events: none; 218 | z-index: 2; 219 | opacity: .2; 220 | } 221 | */ 222 | /*url('file:///W:/curabitr/ANIME.png'),*/ 223 | /* 224 | navigation 225 | */ 226 | #boardNavDesktop { 227 | font-size: 12px !important; 228 | position: fixed; 229 | /*bottom: 0; 230 | left: 0;*/ 231 | width: 100%; 232 | color: #bababa !important; 233 | background-image: -moz-linear-gradient(#4c4c4c, #2d2d2d); 234 | text-align: center; 235 | padding-bottom: 2px; 236 | box-shadow: 0 1px 10px rgba(0, 0, 0, .25); 237 | z-index: 5; 238 | -moz-user-select: none; 239 | /*-moz-transition: left .2s ease-in-out;*/ 240 | } 241 | 242 | /* 243 | #boardNavDesktop:not(:hover) { 244 | left: -95%; 245 | border-radius: 5px; 246 | } 247 | */ 248 | #boardNavDesktop a { 249 | color: #fafafa !important; 250 | -moz-transition: text-shadow .2s ease-in-out; 251 | } 252 | 253 | #boardNavDesktop a:hover { 254 | text-shadow: 0 0 1px #fafafa; 255 | } 256 | 257 | #navtopr { 258 | float: none !important; 259 | } 260 | 261 | /* 262 | #boardNavDesktop { 263 | font-size: 0 !important; 264 | color: transparent !important; 265 | position: fixed; 266 | width: 100%; 267 | text-align: center; 268 | background: black; 269 | padding-bottom: 2px; 270 | box-shadow: 0 2px 10px rgba(0,0,0,.25); 271 | z-index: 5; 272 | opacity: .25; 273 | -moz-transition: opacity .1s ease-in-out; 274 | } 275 | 276 | #boardNavDesktop:hover { 277 | opacity: .75; 278 | } 279 | 280 | #boardNavDesktop a { 281 | font-size: 14px !important; 282 | color: #fafafa !important; 283 | -moz-transition: text-shadow .2s ease-in-out; 284 | } 285 | 286 | #boardNavDesktop a:hover { 287 | text-shadow: 0 0 1px #fafafa; 288 | } 289 | 290 | #navtopr { 291 | float: none !important; 292 | }*/ 293 | /* 294 | #boardNavDesktop { 295 | position: fixed; 296 | width: 100%; 297 | text-align: center; 298 | background: black; 299 | padding-bottom: 2px; 300 | box-shadow: 0 2px 10px rgba(0,0,0,.25); 301 | z-index: 5; 302 | opacity: .25; 303 | -moz-transition: opacity .1s ease-in-out; 304 | } 305 | 306 | #boardNavDesktop:hover { 307 | opacity: .75; 308 | } 309 | 310 | #boardNavDesktop a { 311 | color: #fafafa !important; 312 | -moz-transition: text-shadow .2s ease-in-out; 313 | } 314 | 315 | #boardNavDesktop a:hover { 316 | text-shadow: 0 0 1px #fafafa; 317 | } 318 | */ 319 | #navtopr { 320 | font-size: 0 !important; 321 | color: transparent !important; 322 | float: none !important; 323 | } 324 | 325 | #navtopr > a:first-child::before { 326 | content: ''; 327 | font-family: Webdings !important; 328 | font-size: 16px !important; 329 | color: #fafafa !important; 330 | } 331 | 332 | /* 4chan s */ 333 | /* 334 | #boardNavDesktop { 335 | position: fixed !important; 336 | top: 0 !important; 337 | left: 0 !important; 338 | right: 0 !important; 339 | padding: 5px; 340 | color: #aaa !important; 341 | text-align: center !important; 342 | background-image: -webkit-linear-gradient(#3d3d3d,#2d2d2d); 343 | background-image: -moz-linear-gradient(#3d3d3d,#2d2d2d); 344 | box-shadow: 0 1px 3px rgba(0,0,0,.25); 345 | z-index: 2; 346 | -webkit-user-select: none; 347 | -moz-user-select: none; 348 | user-select: none; 349 | } 350 | 351 | #boardNavDesktop a { 352 | color: #fafafa !important; 353 | padding: 0 !important; 354 | } 355 | 356 | #boardNavDesktop a:hover { 357 | text-shadow: 0 0 3px rgba(255,255,255,.75), 0 0 5px rgba(255,255,255,.5); 358 | } 359 | 360 | #boardNavDesktop, #navtopr { 361 | float: none !important; 362 | } 363 | 364 | .current { 365 | font-weight: bold !important; 366 | text-shadow: 0 0 3px rgba(255,255,255,.75), 0 0 5px rgba(255,255,255,.5); 367 | } 368 | */ 369 | /* 4chan s' hidden menu */ 370 | .hidemeaway { 371 | position: relative; 372 | cursor: pointer; 373 | color: #bababa !important; 374 | } 375 | 376 | .hiddenmenu { 377 | display: none; 378 | position: absolute; 379 | background: #2d2d2d; 380 | box-shadow: 0 0 3px rgba(0, 0, 0, .25); 381 | top: 100%; 382 | left: 0; 383 | width: 82px; 384 | padding: 5px 0; 385 | } 386 | 387 | .hiddenmenu a { 388 | display: block; 389 | } 390 | 391 | .hidemeaway:hover .hiddenmenu { 392 | display: block; 393 | } 394 | 395 | /* 396 | ensure space between navigation and content 397 | */ 398 | #mpostform + div { 399 | height: 50px; 400 | position: static !important; 401 | } 402 | 403 | /* 404 | postarea/postform 405 | */ 406 | #postForm { 407 | position: fixed; 408 | right: 1%; 409 | bottom: 1%; 410 | } 411 | 412 | .closed { 413 | font-size: 2em !important; 414 | padding: 50px 0 10px 0 !important; 415 | } 416 | 417 | /* 418 | announcements 419 | */ 420 | .globalMessage { 421 | text-shadow: 0 1px 1px #fafafa; 422 | width: 90%; 423 | margin: auto; 424 | } 425 | 426 | .globalMessage strong, 427 | .globalMessage big { 428 | color: #dd3434 !important; 429 | } 430 | 431 | .globalMessage a { 432 | color: #0050b3 !important; 433 | } 434 | 435 | #globalToggle { 436 | display: block !important; 437 | width: 300px; 438 | margin: 0 auto; 439 | text-align: center; 440 | color: #fafafa !important; 441 | background: -moz-linear-gradient(#e01919, #aa1111); 442 | border-radius: 3px; 443 | padding: 4px 0 5px; 444 | } 445 | 446 | .globalMessage.hideMobile { 447 | display: none; 448 | } 449 | 450 | /* 451 | main board 452 | */ 453 | #delform { 454 | width: 80%; 455 | margin: 30px auto; 456 | } 457 | 458 | .thread::before, 459 | .thread::after, 460 | .op::before, 461 | .op::after { 462 | content: ''; 463 | display: table; 464 | } 465 | 466 | .thread::after, 467 | .op::after { 468 | clear: both; 469 | } 470 | 471 | .thread { 472 | margin: 10px 0 !important; 473 | } 474 | 475 | .thread:first-of-type { 476 | margin-top: 0 !important; 477 | } 478 | 479 | .thread:last-of-type { 480 | margin-bottom: 0 !important; 481 | } 482 | 483 | .fileThumb, 484 | .fileThumb img { 485 | margin: 0 !important; 486 | } 487 | 488 | /* 489 | replies 490 | */ 491 | .opContainer { 492 | margin-bottom: 5px; 493 | } 494 | 495 | .replyContainer { 496 | position: relative; 497 | } 498 | 499 | .useremail .name, 500 | .useremail .postertrip { 501 | color: #0050b3 !important; 502 | } 503 | 504 | .fileThumb { 505 | padding: 5px; 506 | background: #ffffff; 507 | border: 1px solid #e3e3e3; 508 | border-radius: 5px; 509 | box-shadow: 0 0 0 rgba(0, 0, 0, .25); 510 | -moz-transition: box-shadow .2s ease-in-out; 511 | } 512 | 513 | .fileThumb:hover { 514 | box-shadow: 0 0 2px rgba(0, 0, 0, .25); 515 | } 516 | 517 | /* get rid of fancy border around expanded images */ 518 | .image_expanded .fileThumb { 519 | padding: 0; 520 | box-shadow: none; 521 | border: 0; 522 | border-radius: 0; 523 | } 524 | 525 | .postNum { 526 | font-size: 0 !important; 527 | color: transparent !important; 528 | } 529 | 530 | .postNum > a:not(:first-child) { 531 | font-size: 16px !important; 532 | color: cornflowerBlue !important; 533 | } 534 | 535 | .postNum > a:first-child::after { 536 | content: '#'; 537 | font-size: 16px !important; 538 | color: cornflowerBlue !important; 539 | } 540 | 541 | .postNum > a.replylink { 542 | font-size: 14px !important; 543 | color: #2d2d2d !important; 544 | /* okay for some nigger reason i need to have the extra a (although i think i know why) */ 545 | text-transform: lowercase; 546 | text-shadow: 0 1px 1px rgba(255, 255, 255, .9); 547 | display: inline-block; 548 | padding: 3px 7px; 549 | margin: 0 5px; 550 | background: -webkit-linear-gradient(#fafafa, #e3e3e3); 551 | background: -moz-linear-gradient(#fafafa, #e3e3e3); 552 | box-shadow: 0 1px 2px rgba(0, 0, 0, .2); 553 | border: 1px solid #bbb; 554 | border-radius: 5px; 555 | cursor: pointer; 556 | } 557 | 558 | .replylink:hover { 559 | box-shadow: 0 1px 3px rgba(0, 0, 0, .2); 560 | } 561 | 562 | .replylink:active { 563 | background-image: -webkit-linear-gradient(#e3e3e3, #fafafa); 564 | background-image: -moz-linear-gradient(#e3e3e3, #fafafa); 565 | position: relative; 566 | top: 1px; 567 | } 568 | 569 | /* 570 | span[id^="nothread"] a:nth-of-type(3) { 571 | font-family: Helvetica, Arial, sans-serif; 572 | font-size: 11pt; 573 | text-transform: lowercase; 574 | text-shadow: 0 1px 1px rgba(255,255,255,.9); 575 | color: #555 !important; 576 | display: inline-block; 577 | padding: 3px 7px; 578 | margin: 0 5px; 579 | background: -webkit-linear-gradient(#fafafa,#e3e3e3); 580 | background: -moz-linear-gradient(#fafafa,#e3e3e3); 581 | box-shadow: 0 1px 2px rgba(0,0,0,.2); 582 | border: 1px solid #bbb; 583 | border-radius: 5px; 584 | outline: 0; 585 | cursor: pointer; 586 | } 587 | 588 | span[id^="nothread"] a:nth-of-type(3):hover { 589 | box-shadow: 0 1px 3px rgba(0,0,0,.2); 590 | } 591 | 592 | span[id^="nothread"] a:nth-of-type(3):active { 593 | background-image: -webkit-linear-gradient(#e3e3e3,#fafafa); 594 | background-image: -moz-linear-gradient(#e3e3e3,#fafafa); 595 | position: relative; 596 | top: 1px; 597 | } 598 | */ 599 | /*.useremail:hover::after {content: attr(href);}*/ 600 | .postMessage > br + br + strong[style] { 601 | color: #dd3434 !important; 602 | } 603 | 604 | a.summary { 605 | display: inline-block; 606 | margin-left: 10px; 607 | position: relative; 608 | top: 1px; 609 | background: #fafafa; 610 | font-size: .9em !important; 611 | padding: 0 3px; 612 | border-top-left-radius: 5px; 613 | border-top-right-radius: 5px; 614 | border: 1px solid #e6e6e6; 615 | border-bottom: 0; 616 | } 617 | 618 | .postertrip { 619 | font-family: monospace !important; 620 | font-size: 1.2em !important; 621 | } 622 | 623 | .dateTime { 624 | color: #bababa !important; 625 | } 626 | 627 | .quote { 628 | color: #5c9e0f !important; 629 | } 630 | 631 | /* 632 | .op .file { 633 | float: right !important; 634 | } 635 | */ 636 | .fileInfo { 637 | margin: 0 !important; 638 | } 639 | 640 | /* 641 | .fileInfo > a { 642 | font-size: 0 !important; 643 | color: transparent !important; 644 | -moz-transition: all .2s; 645 | } 646 | 647 | .fileInfo:hover > a { 648 | font-size: .8em !important; 649 | color: cornflowerBlue !important; 650 | } 651 | */ 652 | .fileInfo > a { 653 | font-size: .75em !important; 654 | } 655 | 656 | .subject { 657 | color: #696969 !important; 658 | } 659 | 660 | .sideArrows { 661 | display: none; 662 | } 663 | 664 | .sideArrows.hide_reply_button { 665 | display: block; 666 | font-size: 12px !important; 667 | position: absolute; 668 | top: 1px; 669 | right: 3px; 670 | margin: 0 !important; 671 | opacity: 0; 672 | -moz-transition: opacity .3s ease-in-out; 673 | } 674 | 675 | .op .fileThumb { 676 | float: right !important; 677 | } 678 | 679 | .post.reply .fileThumb { 680 | margin-right: 5px !important; 681 | } 682 | 683 | .postContainer:hover .sideArrows.hide_reply_button { 684 | opacity: .5; 685 | } 686 | 687 | .stub + .sideArrows + .post { 688 | display: none !important; 689 | } 690 | 691 | .post input { 692 | display: none; 693 | } 694 | 695 | .post { 696 | margin: 0 !important; 697 | } 698 | 699 | .post.reply { 700 | clear: both; 701 | display: block !important; 702 | background: #fafafa !important; 703 | padding: 3px 0 3px 10px !important; 704 | border: 1px solid #e6e6e6 !important; 705 | border-bottom: 0 !important; 706 | -moz-transition: background .5s ease-in-out; 707 | } 708 | 709 | .post.reply.highlight { 710 | background: #efefef !important; 711 | } 712 | 713 | .thread .replyContainer:last-child .post.reply { 714 | border-bottom: 1px solid #e3e3e3 !important; 715 | } 716 | 717 | .postMessage { 718 | margin: 0 !important; 719 | } 720 | 721 | /* 722 | /g/ [code] tags 723 | */ 724 | .prettyprint { 725 | background-color: #151717 !important; 726 | padding: 5px !important; 727 | margin: 0; 728 | text-shadow: none; 729 | white-space: pre-wrap; 730 | border-radius: 5px; 731 | } 732 | 733 | .prettyprint span { 734 | font-family: monospace !important; 735 | color: #fafafa !imporant; 736 | /* so that when .prettyprint loads */ 737 | } 738 | 739 | .prettyprint .str { 740 | color: #edd400 !important; 741 | } 742 | 743 | /* string - butter2 */ 744 | .prettyprint .kwd { 745 | color: #fff !important; 746 | font-weight: bold !important; 747 | } 748 | 749 | /* keyword - white */ 750 | .prettyprint .com { 751 | color: #888a85 !important; 752 | } 753 | 754 | /* comment - aluminum4 */ 755 | .prettyprint .typ { 756 | color: #8ae234 !important; 757 | font-weight: bold !important; 758 | } 759 | 760 | /* type - chameleon1 */ 761 | .prettyprint .lit { 762 | color: #edd400 !important; 763 | } 764 | 765 | /* literal - butter2 */ 766 | .prettyprint .pun { 767 | color: #d3d7cf !important; 768 | } 769 | 770 | /* punctuation - aluminium2 */ 771 | .prettyprint .pln { 772 | color: #d3d7cf !important; 773 | } 774 | 775 | /* plaintext - aluminium2 */ 776 | .prettyprint .tag { 777 | color: #729fcf !important; 778 | } 779 | 780 | /* html/xml tag - skyblue1 */ 781 | .prettyprint .atn { 782 | color: #8ae234 !important; 783 | font-weight: bold !important; 784 | } 785 | 786 | /* html/xml attribute name - chameleon1 */ 787 | .prettyprint .atv { 788 | color: #edd400 !important; 789 | } 790 | 791 | /* html/xml attribute value - butter2 */ 792 | .prettyprint .dec { 793 | color: #ce5c00 !important; 794 | } 795 | 796 | /* decimal - orange3 */ 797 | /* 798 | pages 799 | */ 800 | .pagelist .next, 801 | .pagelist .prev { 802 | display: none; 803 | } 804 | 805 | .pagelist { 806 | background: none !important; 807 | padding: 0 !important; 808 | border: 0 !important; 809 | margin-bottom: 30px !important; 810 | float: none !important; 811 | word-spacing: 10px; 812 | text-align: center; 813 | overflow: visible !important; 814 | } 815 | 816 | .pagelist .pages { 817 | padding: 0 !important; 818 | float: none !important; 819 | font-size: 0 !important; 820 | color: transparent !important; 821 | } 822 | 823 | .pagelist .pages strong, 824 | .pagelist .pages a { 825 | display: inline-block; 826 | font-size: 16px !important; 827 | color: #2d2d2d !important; 828 | min-width: 20px; 829 | padding: 3px 7px 1px 8px; 830 | border-radius: 5px; 831 | box-shadow: 0 1px 2px rgba(0, 0, 0, .4); 832 | -webkit-transition: box-shadow .2s; 833 | -moz-transition: box-shadow .2s; 834 | transition: box-shadow .2s; 835 | } 836 | 837 | .pagelist .pages a { 838 | background-image: -webkit-linear-gradient(#fafafa, #e3e3e3); 839 | background-image: -moz-linear-gradient(#fafafa, #e3e3e3); 840 | background-image: linear-gradient(#fafafa, #e3e3e3); 841 | } 842 | 843 | .pagelist .pages strong { 844 | color: #e3e3e3 !important; 845 | background-image: -webkit-linear-gradient(#3d3d3d, #2d2d2d); 846 | background-image: -moz-linear-gradient(#3d3d3d, #2d2d2d); 847 | background-image: linear-gradient(#3d3d3d, #2d2d2d); 848 | } 849 | 850 | .pages a:hover { 851 | box-shadow: 0 1px 4px rgba(0, 0, 0, .75); 852 | } 853 | 854 | /* 855 | 4chan x specific 856 | */ 857 | #overlay { 858 | z-index: 10 !important; 859 | background-image: -moz-radial-gradient(50% 50%, circle cover, rgba(50, 50, 50, .5), rgba(0, 0, 0, .75) 100%) !important; 860 | } 861 | 862 | #options { 863 | background-color: #ededed !important; 864 | border-radius: 5px; 865 | width: 75% !important; 866 | height: 75%; 867 | vertical-align: middle !important; 868 | } 869 | 870 | #content { 871 | height: 95% !important; 872 | } 873 | 874 | form[name=post] > h1 { 875 | display: none; 876 | } 877 | 878 | .reply.dialog { 879 | border: 0 !important; 880 | } 881 | 882 | .hide_thread_button > span { 883 | background-image: -moz-linear-gradient(#fafafa, #e3e3e3); 884 | margin-right: 5px; 885 | text-align: center; 886 | padding: 2px 4px; 887 | border-radius: 5px; 888 | box-shadow: 0 1px 2px rgba(0, 0, 0, .4); 889 | } 890 | 891 | .hide_reply_button.stub { 892 | background: #fafafa; 893 | border: 1px solid #e6e6e6; 894 | border-bottom: 0; 895 | } 896 | 897 | .thread .replyContainer:last-child .hide_reply_button.stub { 898 | border-bottom: 1px solid #e6e6e6; 899 | } 900 | 901 | .hide_reply_button.stub > a { 902 | display: block; 903 | padding: 3px 0 3px 10px; 904 | } 905 | 906 | .hide_reply_button.stub > a > span { 907 | display: none; 908 | } 909 | 910 | .post.reply.highlight { 911 | background: #efefef !important; 912 | } 913 | 914 | .thread .replyContainer:last-child .post.reply { 915 | border-bottom: 1px solid #e3e3e3 !important; 916 | } 917 | 918 | #stats { 919 | font-size: 12px !important; 920 | top: 3px !important; 921 | left: auto !important; 922 | right: 20px !important; 923 | width: 60px; 924 | text-align: right; 925 | z-index: 6; 926 | } 927 | 928 | #stats > .move { 929 | color: #fafafa !important; 930 | cursor: default !important; 931 | } 932 | 933 | #postcount, 934 | #imagecount { 935 | color: #fafafa !important; 936 | } 937 | 938 | #watcher { 939 | position: fixed !important; 940 | width: 200px; 941 | background: #fafafa !important; 942 | border-radius: 5px; 943 | opacity: .5; 944 | box-shadow: 0 2px 4px rgba(0, 0, 0, .25); 945 | z-index: 2; 946 | } 947 | 948 | #watcher:hover { 949 | opacity: .9; 950 | } 951 | 952 | #watcher > div { 953 | color: #bbb !important; 954 | } 955 | 956 | #watcher > .move { 957 | text-align: center; 958 | text-decoration: none !important; 959 | text-transform: lowercase; 960 | } 961 | 962 | #watcher > div > a:first-child { 963 | color: #dd3434 !important; 964 | } 965 | 966 | #imgControls { 967 | height: 0; 968 | } 969 | 970 | #imageType { 971 | display: none; 972 | } 973 | 974 | #imgControls > label { 975 | font-size: 0 !important; 976 | color: transparent !important; 977 | } 978 | 979 | #imageExpand { 980 | position: fixed; 981 | top: 6px; 982 | right: 5px; 983 | z-index: 6; 984 | -moz-appearance: none; 985 | height: 10px; 986 | width: 10px; 987 | border: 1px solid rgba(0, 0, 0, .5) !important; 988 | background: #fafafa !important; 989 | border-radius: 3px !important; 990 | margin: 0; 991 | } 992 | 993 | .container { 994 | display: block; 995 | font-size: .8em !important; 996 | line-height: .8 !important; 997 | color: #bababa !important; 998 | margin-left: 5px; 999 | } 1000 | 1001 | .container::before { 1002 | content: 'le quoted by: '; 1003 | } 1004 | 1005 | .container::after { 1006 | content: '.'; 1007 | } 1008 | 1009 | .container .backlink:not(:only-child):not(:last-child)::after { 1010 | content: ','; 1011 | } 1012 | 1013 | #updater { 1014 | font-size: 12px !important; 1015 | top: auto !important; 1016 | left: auto !important; 1017 | bottom: 0 !important; 1018 | right: 5px !important; 1019 | } 1020 | 1021 | #updater #count:not(.new):not(.error) { 1022 | display: none; 1023 | } 1024 | 1025 | #updater #count.new { 1026 | color: limeGreen !important; 1027 | background: none !important; 1028 | } 1029 | 1030 | #qr { 1031 | right: 5px !important; 1032 | bottom: 5px !important; 1033 | top: auto !important; 1034 | left: auto !important; 1035 | background: none !important; 1036 | opacity: .3; 1037 | -moz-transition: opacity .2s ease-in-out; 1038 | } 1039 | 1040 | #qr:hover { 1041 | opacity: .8; 1042 | } 1043 | 1044 | #qr > .move > #autohide, 1045 | #qr > .move > span, 1046 | /*#qr:not(:hover) > form,*/ 1047 | #qr [type=file] > [type=button] { 1048 | display: none; 1049 | } 1050 | 1051 | #qr > .move { 1052 | color: #bbb !important; 1053 | text-transform: lowercase; 1054 | text-align: center; 1055 | cursor: default !important; 1056 | } 1057 | 1058 | /* 1059 | #qr { 1060 | opacity: .3; 1061 | background: none !important; 1062 | z-index: 6; 1063 | -moz-transition: opacity .2s ease-in-out; 1064 | } 1065 | 1066 | #qr:hover { 1067 | opacity: .8; 1068 | } 1069 | 1070 | #qr > .move { 1071 | display: none; 1072 | } 1073 | 1074 | #qr .field { 1075 | border: 1px solid #bbb !important; 1076 | padding: 0; 1077 | background: #fafafa; 1078 | } 1079 | 1080 | #qr .field:focus { 1081 | border: 1px solid cornflowerBlue !important; 1082 | } 1083 | 1084 | #qr textarea.field { 1085 | min-height: 200px !important; 1086 | resize: vertical; 1087 | } 1088 | 1089 | #qr [type=file] > [type=button] { 1090 | display: none; 1091 | } 1092 | 1093 | #qr [type=file] { 1094 | width: 30% !important; 1095 | margin: 0 !important; 1096 | } 1097 | 1098 | #qr [type=submit] { 1099 | -moz-appearance: none; 1100 | width: 30% !important; 1101 | padding: 0 !important; 1102 | border: 0; 1103 | margin: 0 !important; 1104 | } 1105 | */ 1106 | #qp { 1107 | background: #fafafa !important; 1108 | box-shadow: 0 0 5px rgba(0, 0, 0, .25); 1109 | opacity: .95; 1110 | padding: 3px 10px !important; 1111 | border-radius: 1px; 1112 | } 1113 | 1114 | #qp .post { 1115 | padding: 0 !important; 1116 | border: 0 !important; 1117 | margin: 0 !important; 1118 | } 1119 | 1120 | .qphl { 1121 | outline: 0 !important; 1122 | } 1123 | 1124 | .qphl.reply { 1125 | background: #e6e6e6 !important; 1126 | } 1127 | 1128 | /*.sideArrows.hide_reply_button { 1129 | display: block; 1130 | font-size: 12px !important; 1131 | position: absolute; 1132 | top: 1px; 1133 | right: 3px; 1134 | margin: 0 !important; 1135 | opacity: 0; 1136 | -moz-transition: opacity .3s ease-in-out; 1137 | } 1138 | 1139 | .postContainer:hover .sideArrows.hide_reply_button { 1140 | opacity: .5; 1141 | }*/ 1142 | .menu_button { 1143 | font-size: 12px !important; 1144 | color: #2d2d2d !important; 1145 | position: absolute; 1146 | top: 1px; 1147 | right: 25px; 1148 | opacity: 0; 1149 | -moz-transition: opacity .3s ease-in-out; 1150 | } 1151 | 1152 | .postContainer:hover .menu_button { 1153 | opacity: .5; 1154 | } 1155 | 1156 | /* yay, filters */ 1157 | .filter_highlight { 1158 | box-shadow: none !important; 1159 | } 1160 | 1161 | .filter_highlight .postMessage { 1162 | text-decoration: underline; 1163 | -moz-text-decoration-color: indianRed; 1164 | } 1165 | 1166 | .seaweed .reply, 1167 | #qp.seaweed { 1168 | background: -moz-linear-gradient(to right, #fafafa, #f7d79a) !important; 1169 | } 1170 | 1171 | .zixaphir .reply { 1172 | background: -moz-linear-gradient(to right, #fafafa, #7f89bd) !important; 1173 | } 1174 | 1175 | .sax .reply { 1176 | background: -moz-linear-gradient(to right, #fafafa, #c5e6ee) !important; 1177 | } 1178 | 1179 | .mayhem .reply { 1180 | background: -moz-linear-gradient(to right, #fafafa, #cd93de) !important; 1181 | } 1182 | 1183 | .mod .reply { 1184 | background: -moz-linear-gradient(to right, #fafafa, #c647c6) !important; 1185 | } 1186 | 1187 | .moot .reply { 1188 | background: -moz-linear-gradient(to right, #fafafa, #cc0000) !important; 1189 | } 1190 | 1191 | .large.mb .fileThumb { 1192 | background: skyBlue; 1193 | } 1194 | 1195 | .match .fileThumb { 1196 | background: yellowGreen; 1197 | } 1198 | 1199 | .large .fileThumb { 1200 | background: indianRed; 1201 | } 1202 | 1203 | /* 1204 | @media (min-width: 960px) {} 1205 | 1206 | page is BIGGER than 960px 1207 | 1208 | ---------------------------------------- 1209 | 1210 | @media (max-width: 960px) {} 1211 | 1212 | page is SMALLER than 960px 1213 | 1214 | */ 1215 | } 1216 | -------------------------------------------------------------------------------- /previous/curabitr1.user.css: -------------------------------------------------------------------------------- 1 | /* ==UserStyle== 2 | @name curabitr 1 3 | @namespace github.com/openstyles/stylus 4 | @version 1.0.0 5 | @description A new userstyle 6 | @author Me 7 | ==/UserStyle== */ 8 | @-moz-document domain("boards.4chan.org") { 9 | 10 | /* defaultan */ 11 | body { 12 | background: #ebebeb url('') !important; 13 | padding: 0 !important; 14 | margin: 0 !important; 15 | } 16 | 17 | a { 18 | color: #2b75c0 !important; 19 | text-decoration: none !important; 20 | -webkit-transition: text-shadow .3s; 21 | -moz-transition: text-shadow .3s; 22 | } 23 | 24 | a:hover { 25 | text-shadow: 0 0 3px #3b86d2; 26 | } 27 | 28 | a:active, 29 | a:focus { 30 | outline: 0 !important; 31 | } 32 | 33 | ::selection { 34 | color: #fafafa; 35 | background-color: deepPink; 36 | text-shadow: none !important; 37 | } 38 | 39 | ::-moz-selection { 40 | color: #fafafa; 41 | background-color: deepPink; 42 | text-shadow: none !important; 43 | } 44 | 45 | /* shitblockan */ 46 | .boardBanner, 47 | /* heading/logo (cause if you don't know what board you're on, you must have problems) */ 48 | img[src^="http://static.4chan.org/support/"], 49 | /* ads (>2011 >not using adblock) */ 50 | hr, 51 | /* horizontal rules on the page */ 52 | .postingMode, 53 | /* posting mode: reply */ 54 | .navLinks, 55 | /* [return] [bottom/top] */ 56 | .pagelist .prev, 57 | .pagelist .next, 58 | /* previous and next page buttons */ 59 | .stylechanger, 60 | /* yotsuba style selector */ 61 | #absbot/* bottom nav and any copyright crap */ 62 | { 63 | display: none !important; 64 | } 65 | 66 | #boardNavDesktop { 67 | position: fixed !important; 68 | left: 0 !important; 69 | opacity: .5; 70 | top: -21px !important; 71 | -webkit-transition: all.2s; 72 | -moz-transition: all .2s; 73 | right: 0 !important; 74 | text-align: center !important; 75 | background-color: #222; 76 | background-image: -webkit-linear-gradient(#444, #222); 77 | background-image: -moz-linear-gradient(#444, #222); 78 | min-height: 20px; 79 | font-size: 0 !important; 80 | color: transparent !important; 81 | box-shadow: 0 0 20px 0 rgba(0, 0, 0, .75); 82 | border-bottom: 1px solid #222; 83 | z-index: 1; 84 | } 85 | 86 | #boardNavDesktop::after { 87 | content: 'Navigation'; 88 | font-size: 12px; 89 | color: #fafafa; 90 | position: absolute; 91 | display: inline-block; 92 | top: 21px; 93 | width: 200px; 94 | left: 50%; 95 | margin-left: -100px; 96 | background-color: #222; 97 | padding-bottom: 2px; 98 | border-bottom-left-radius: 3px; 99 | border-bottom-right-radius: 3px; 100 | } 101 | 102 | #boardNavDesktop:hover { 103 | opacity: .95; 104 | top: 0 !important; 105 | } 106 | 107 | #boardNavDesktop a { 108 | color: #ebebeb !important; 109 | padding: 0 !important; 110 | font-size: 12px !important; 111 | line-height: 20px; 112 | margin: 0 3px; 113 | -webkit-transition: text-shadow .5s; 114 | -moz-transition: text-shadow .5s; 115 | } 116 | 117 | #boardNavDesktop a:hover { 118 | text-shadow: 0 0 2px #fff, 0 0 5px #eee; 119 | } 120 | 121 | #navtopr { 122 | float: none !important; 123 | } 124 | 125 | /* announcements */ 126 | /* pick a heading and stick with it moot, damn */ 127 | .globalMessage { 128 | margin: 30px 0 20px; 129 | } 130 | 131 | .globalMessage * { 132 | font-family: 'Helvetica', 'Arial', sans-serif; 133 | color: #b90000 !important; 134 | text-shadow: 0 1px 1px #ffe9e9; 135 | margin: 0; 136 | } 137 | 138 | .globalMessage blink { 139 | text-decoration: none !important; 140 | } 141 | 142 | .globalMessage a { 143 | color: #2083fe !important; 144 | } 145 | 146 | .globalMessage a:hover { 147 | text-shadow: none; 148 | } 149 | 150 | /* for when moot and mods want to add youtube/sounds */ 151 | /* so, with some CSS, you can at least see the button, to pause the music :) */ 152 | embed { 153 | position: fixed; 154 | bottom: 0; 155 | left: 0; 156 | width: 30px !important; 157 | height: 25px !important; 158 | } 159 | 160 | /* main body */ 161 | #delform { 162 | width: 900px; 163 | margin: /*30px 75px 0 20px*/ 164 | 0 auto !important; 165 | } 166 | 167 | /* postarea */ 168 | /* to-do from the top of my head */ 169 | /* use the spoiler image from master (cause i reckon it's sexy), 170 | add :place-holder text styling, 171 | add button[disabled] (cooldown, 404) styling, 172 | either wait for the #qr rewrite, or make it look a bit more presentable: 173 | captcha image 174 | autohide fanciness 175 | opcaity transitions 176 | captcha counter 177 | autosubmit checkbox/label 178 | multiple files 179 | */ 180 | /* hiding shiz */ 181 | #postForm input[type="file"] > input[type="button"], 182 | #postForm #postPassword + span, 183 | #postForm .rules, 184 | #postForm span:empty, 185 | #postForm td:empty, 186 | #postForm > tbody > tr > td:first-of-type { 187 | display: none; 188 | } 189 | 190 | #postForm { 191 | position: fixed; 192 | right: -325px; 193 | bottom: 30px; 194 | -webkit-transition: right 2s ease-in-out 3s; 195 | -moz-transition: right 2s ease-in-out 3s; 196 | z-index: 5; 197 | } 198 | 199 | #postForm:hover { 200 | right: 5px; 201 | -webkit-transition: right .5s; 202 | -moz-transition: right .5s; 203 | } 204 | 205 | #postForm:hover textarea { 206 | right: 0; 207 | -webkit-transition: right .5s; 208 | -moz-transition: right .5s; 209 | } 210 | 211 | #postForm input:focus { 212 | right: 330px; 213 | -webkit-transition: right 1s ease-in-out 3.5s; 214 | -moz-transition: right 1s ease-in-out 3.5s; 215 | } 216 | 217 | #postForm:hover input:focus, 218 | #postForm:hover textarea:focus { 219 | right: 0; 220 | -webkit-transition: right .5s; 221 | -moz-transition: right .5s; 222 | } 223 | 224 | #postForm input:not(:focus) { 225 | right: 0; 226 | -webkit-transition: right .5s; 227 | -moz-transition: right .5s; 228 | } 229 | 230 | #postForm textarea { 231 | position: relative; 232 | right: 50px; 233 | -webkit-transition: right 1s ease-in-out 3.5s; 234 | -moz-transition: right 1s ease-in-out 3.5s; 235 | } 236 | 237 | #postForm textarea:focus { 238 | right: 330px; 239 | } 240 | 241 | #postForm input[type="text"], 242 | #postForm input[type="file"] > input[type="text"], 243 | #postForm input[name="recaptcha_response_field"] { 244 | -webkit-appearance: none; 245 | -moz-appearance: none; 246 | font-family: Helvetica, Arial, sans-serif !important; 247 | font-size: 13px !important; 248 | line-height: 18px !important; 249 | color: #222; 250 | background-color: #fafafa; 251 | padding: 2px 2px 3px !important; 252 | border: 1px solid #bbb !important; 253 | border-radius: 3px; 254 | margin: 0 !important; 255 | margin-bottom: 1px !important; 256 | width: 300px !important; 257 | vertical-align: baseline; 258 | position: relative !important; 259 | } 260 | 261 | #postForm input[type="file"] { 262 | -webkit-appearance: none; 263 | margin: 0; 264 | width: 244px !important; 265 | } 266 | 267 | #postForm input[type="text"], 268 | #postForm input[type="file"] > input[type="text"], 269 | #postForm input[name="recaptcha_response_field"] { 270 | height: auto !important; 271 | } 272 | 273 | #postForm textarea { 274 | min-height: 200px; 275 | resize: vertical; 276 | overflow: auto; 277 | } 278 | 279 | #postForm input[name="recaptcha_response_field"] { 280 | color: #222 !important; 281 | background-color: #fff; 282 | border-top-width: 0 !important; 283 | border-top-left-radius: 0; 284 | border-top-right-radius: 0; 285 | } 286 | 287 | /* silly chrumb~ */ 288 | /* well, not really. it's just that an id overrides selectors such as above (in chrumb at least) */ 289 | #postForm .recaptchatable #recaptcha_image { 290 | border: 0 !important; 291 | } 292 | 293 | #postForm .recaptchatable #recaptcha_response_field { 294 | border: 1px solid #bbb !important; 295 | border-top-width: 0 !important; 296 | } 297 | 298 | #postForm input[name="sub"], 299 | #postForm input[type="file"] > input[type="text"] { 300 | width: 244px !important; 301 | } 302 | 303 | #postForm input[name="pwd"] { 304 | color: #bbb; 305 | width: 55px !important; 306 | position: absolute !important; 307 | bottom: 0; 308 | right: 0; 309 | -webkit-transition: width .2s; 310 | -moz-transition: width .2s; 311 | } 312 | 313 | .webkit #postForm input[name="pwd"] { 314 | bottom: -1px; 315 | } 316 | 317 | #postForm input:focus { 318 | outline: none; 319 | } 320 | 321 | #postForm input[name="pwd"]:focus { 322 | width: 90px !important; 323 | z-index: 2; 324 | -webkit-transition: width .2s; 325 | -moz-transition: width .2s; 326 | } 327 | 328 | #postForm input[type="submit"], 329 | #postForm input[type="submit"][disabled] { 330 | -webkit-appearance: none; 331 | -moz-appearance: none; 332 | font-family: Helvetica, Arial, sans-serif; 333 | font-size: 13px; 334 | line-height: 18px !important; 335 | text-shadow: 0 1px 0 #fafafa; 336 | text-transform: lowercase; 337 | color: #777 !important; 338 | background-image: -webkit-linear-gradient(#fafafa, #cdcdcd); 339 | background-image: -moz-linear-gradient(#fafafa, #cdcdcd); 340 | padding: 0px 4px; 341 | border: 1px solid #bbb !important; 342 | border-radius: 3px; 343 | margin: 0 0 -0 1px !important; 344 | min-width: 55px; 345 | width: 55px; 346 | max-width: 55px; 347 | min-height: 25px; 348 | height: 25px; 349 | max-height: 25px; 350 | vertical-align: top; 351 | position: relative; 352 | cursor: pointer; 353 | } 354 | 355 | #postForm input[type="submit"][disabled]:active { 356 | background-color: #cdcdcd; 357 | } 358 | 359 | 360 | #postForm input[type="file"]::-webkit-file-upload-button { 361 | -webkit-appearance: none; 362 | -moz-appearance: none; 363 | font-family: Helvetica, Arial, sans-serif; 364 | font-size: 13px; 365 | line-height: 18px !important; 366 | text-shadow: 0 1px 0 #fafafa; 367 | text-transform: lowercase; 368 | color: #777 !important; 369 | background-image: -webkit-linear-gradient(#fafafa, #cdcdcd); 370 | background-image: -moz-linear-gradient(#fafafa, #cdcdcd); 371 | padding: 0px 4px; 372 | border: 1px solid #bbb; 373 | border-radius: 3px; 374 | margin: 0 0 -0 1px !important; 375 | min-width: 100px; 376 | width: 100px; 377 | max-width: 100px; 378 | min-height: 25px; 379 | height: 25px; 380 | max-height: 25px; 381 | vertical-align: top; 382 | position: relative; 383 | cursor: pointer; 384 | } 385 | 386 | #postForm input[type="submit"]:disabled { 387 | cursor: default; 388 | text-shadow: none; 389 | background-image: none; 390 | background-color: #cdcdcd; 391 | } 392 | 393 | #postForm { 394 | border-spacing: 0; 395 | border-collapse: collapse; 396 | } 397 | 398 | #postForm #recaptcha_table tr[height="73"] td[style] a:not(:first-of-type), 399 | #postForm #recaptcha_table tr[height="73"] td:last-of-type, 400 | #postForm #recaptcha_table tr:last-of-type td:not(:first-of-type) { 401 | display: none; 402 | } 403 | 404 | #postForm #recaptcha_widget_div { 405 | width: 300px !important; 406 | position: relative; 407 | } 408 | 409 | #postForm #recaptcha_table tr[height] { 410 | height: auto !important; 411 | } 412 | 413 | #postForm #recaptcha_table *:not(input):not(img) { 414 | padding: 0 !important; 415 | } 416 | 417 | #postForm #recaptcha_image { 418 | border: 0 !important; 419 | position: relative !important; 420 | } 421 | 422 | #postForm #recaptcha_image > img { 423 | width: 298px !important; 424 | border: 1px solid #bbb !important; 425 | border-bottom: 0 !important; 426 | border-top-left-radius: 3px; 427 | border-top-right-radius: 3px; 428 | } 429 | 430 | #postForm #recaptcha_reload { 431 | position: absolute !important; 432 | top: 0 !important; 433 | right: 0 !important; 434 | background-image: url('http://i.imgur.com/ljf6O.png'); 435 | height: 0 !important; 436 | width: 16px !important; 437 | padding-top: 16px !important; 438 | } 439 | 440 | /* [O Spoiler Image] */ 441 | #postForm tr:nth-of-type(3) td:not(.postblock) { 442 | font-size: 0 !important; 443 | color: transparent; 444 | } 445 | 446 | #postForm tr:nth-of-type(3) label { 447 | font-size: 8pt; 448 | position: absolute; 449 | bottom: 2px; 450 | left: 5px; 451 | line-height: 25px; 452 | text-transform: lowercase; 453 | letter-spacing: -5px; 454 | -webkit-transition-property: color, letter-spacing; 455 | -webkit-transition: .5s ease-in-out; 456 | -moz-transition-property: color, letter-spacing; 457 | -moz-transition: .5s ease-in-out; 458 | z-index: 5; 459 | } 460 | 461 | #postForm tr:nth-of-type(3) label:hover { 462 | color: black; 463 | letter-spacing: 0; 464 | } 465 | 466 | #postForm input[type="checkbox"] { 467 | -moz-appearance: none; 468 | border: 1px solid #bbb !important; 469 | border-radius: 3px !important; 470 | margin: 0 3px 0 0; 471 | vertical-align: middle; 472 | } 473 | 474 | /* okay, so chrumb fucks us over with checkboxes */ 475 | /* it removes the tick! so, either have a border/box-shadow/background-color change */ 476 | /* seaweeedchan has content: 'img'; (would it be cross browser?) */ 477 | /* images with the borders */ 478 | img:-moz-broken { 479 | background: black; 480 | } 481 | 482 | img[md5] { 483 | border: 4px solid #fafafa !important; 484 | border-radius: 4px; 485 | box-shadow: 0 0 0 1px #bbb, 0 0 0px rgba(0, 0, 0, .25); 486 | margin: 3px 7px 5px 3px !important; 487 | -moz-transition: box-shadow .2s; 488 | } 489 | 490 | img[md5]:hover { 491 | box-shadow: 0 0 0 1px #bbb, 0 0 5px rgba(0, 0, 0, .25); 492 | } 493 | 494 | .reply img, 495 | .replyhl img { 496 | margin-bottom: 0 !important; 497 | } 498 | 499 | .abbr, 500 | span.omittedposts { 501 | color: #222 !important; 502 | } 503 | 504 | .omittedposts { 505 | font-size: 11px; 506 | text-shadow: none !important; 507 | display: block; 508 | clear: both; 509 | float: right; 510 | padding: 2px 5px; 511 | margin-right: 20px; 512 | margin-bottom: -1px; 513 | background-image: -webkit-linear-gradient(#fafafa, #ddd); 514 | background-image: -moz-linear-gradient(#fafafa, #ddd); 515 | border-top-left-radius: 5px; 516 | border-top-right-radius: 5px; 517 | } 518 | 519 | .container { 520 | display: block; 521 | font-size: 8pt; 522 | margin-left: 30px; 523 | line-height: 10pt; 524 | color: #777; 525 | } 526 | 527 | .container + br { 528 | display: none; 529 | } 530 | 531 | .container::before { 532 | content: 'quoted by: '; 533 | } 534 | 535 | .container::after { 536 | content: '.'; 537 | } 538 | 539 | .container .backlink:last-of-type:not(:first-of-type)::before { 540 | content: ' and '; 541 | color: #777; 542 | text-shadow: none; 543 | cursor: text; 544 | } 545 | 546 | .container .backlink:not(:last-of-type):not(:nth-last-of-type(2))::after { 547 | content: ','; 548 | color: #777; 549 | text-shadow: none; 550 | cursor: text; 551 | } 552 | 553 | span[id^="no"] > a:nth-of-type(1) { 554 | font-size: 0; 555 | color: transparent !important; 556 | } 557 | 558 | span[id^="no"] > a:nth-of-type(1):before { 559 | content: "#"; 560 | font-size: 10pt; 561 | color: #2b75c0 !important; 562 | } 563 | 564 | span[id^="nothread"] { 565 | font-size: 0; 566 | color: transparent; 567 | } 568 | 569 | span[id^="nothread"] a { 570 | font-size: 10pt; 571 | color: #2b75c0; 572 | } 573 | 574 | span[id^="nothread"] a:nth-of-type(3) { 575 | display: inline-block; 576 | background-image: -webkit-linear-gradient(#fafafa, #ccc); 577 | background-image: -moz-linear-gradient(#fafafa, #ccc); 578 | border: 1px solid #bbb; 579 | border-radius: 3px; 580 | text-transform: lowercase; 581 | color: #555 !important; 582 | text-shadow: 0 1px 0 #fff; 583 | padding: 3px 5px; 584 | margin: 0 5px; 585 | } 586 | 587 | span[id^="nothread"] a:nth-of-type(3):hover { 588 | box-shadow: 0 0 2px #bbb; 589 | } 590 | 591 | span[id^="nothread"] a:nth-of-type(3):active { 592 | background-image: -webkit-linear-gradient(#ccc, #eee); 593 | background-image: -moz-linear-gradient(#ccc, #eee); 594 | } 595 | 596 | /* put all replies underneath op */ 597 | table { 598 | clear: both; 599 | position: relative; 600 | } 601 | 602 | /* replies */ 603 | .post { 604 | font: 10pt 'Helvetica', 'Arial', sans-serif !important; 605 | line-height: 12pt !important; 606 | color: #777 !important; 607 | background-image: -webkit-linear-gradient(#eee, #ddd) !important; 608 | background-image: -moz-linear-gradient(#eee, #ddd) !important; 609 | box-shadow: 0 0 1px #999; 610 | padding: 5px !important; 611 | border: 0 !important; 612 | border-radius: 5px !important; 613 | position: relative; 614 | width: 100%; 615 | } 616 | 617 | td.replyhl { 618 | font: 10pt 'Helvetica', 'Arial', sans-serif !important; 619 | line-height: 12pt !important; 620 | color: #777 !important; 621 | background-image: -webkit-linear-gradient(#eee, #ddd) !important; 622 | background-image: -moz-linear-gradient(#eee, #ddd) !important; 623 | box-shadow: 0 0 5px #999; 624 | padding: 5px !important; 625 | border: 0 !important; 626 | border-radius: 5px !important; 627 | position: relative; 628 | width: 100%; 629 | } 630 | 631 | /* post time */ 632 | time, 633 | .posttime { 634 | color: #777; 635 | } 636 | 637 | /* filesize and filenames */ 638 | .filesize { 639 | font: 10pt 'Helvetica', 'Arial', sans-serif; 640 | color: #777; 641 | line-height: 12pt; 642 | } 643 | 644 | .filesize a:first-of-type::after { 645 | content: " "; 646 | } 647 | 648 | .reply .filesize a:first-of-type::before, 649 | .replyhl .filesize a:first-of-type::before { 650 | content: " : "; 651 | color: #777; 652 | } 653 | 654 | .filesize span { 655 | font-size: 0; 656 | color: transparent !important; 657 | } 658 | 659 | .filesize span:after { 660 | content: attr(title); 661 | font-size: 10pt; 662 | color: #777 !important; 663 | } 664 | 665 | .forwardlink { 666 | color: #102073 !important; 667 | } 668 | 669 | .unkfunc { 670 | color: #669933 !important; 671 | } 672 | 673 | /* (user was warned/banned for this post) */ 674 | blockquote > b[style="color:red;"] { 675 | background-color: rgba(255, 0, 0, 0.15); 676 | border-radius: 3px; 677 | padding: 2px 5px 3px; 678 | } 679 | 680 | /* moot and mods */ 681 | .postername > span, 682 | .postertrip > span, 683 | .commentpostername > span { 684 | font-size: 12pt; 685 | text-shadow: 0px 0px 5px pink; 686 | } 687 | 688 | blockquote > div { 689 | background-color: rgba(255, 0, 0, .15); 690 | padding: 3px !important; 691 | border: 0 !important; 692 | margin: 0 !important; 693 | } 694 | 695 | /* subject / name */ 696 | .filetitle, 697 | .replytitle, 698 | .postername, 699 | .commentpostername { 700 | font-weight: 600 !important; 701 | background: none !important; 702 | display: inline-block; 703 | unicode-bidi: normal; 704 | } 705 | 706 | .filetitle, 707 | .replytitle { 708 | color: #575757 !important; 709 | } 710 | 711 | .filetitle:not(:empty), 712 | .replytitle:not(:empty) { 713 | margin-left: 2px; 714 | } 715 | 716 | /* 717 | .linkmail { 718 | color: #102073 !important; 719 | text-shadow: 0 0 3px #3b86d2; 720 | } 721 | 722 | .linkmail > .postertrip { 723 | color: blue; 724 | } 725 | 726 | .postername + .linkmail::before, 727 | .commentpostername + .linkmail::before { 728 | font-weight: 100; 729 | content: ' ['attr(href)']'; 730 | } 731 | 732 | .postername > .linkmail::after, 733 | .commentpostername > .linkmail::after { 734 | font-weight: 100; 735 | content: ' ['attr(href)']'; 736 | } 737 | */ 738 | .linkmail { 739 | color: #222 !important; 740 | } 741 | 742 | span + .linkmail:before { 743 | content: ''; 744 | } 745 | 746 | .linkmail:before { 747 | content: ' ['attr(href)'] '; 748 | font-weight: 100; 749 | } 750 | 751 | .postername, 752 | .commentpostername { 753 | color: #222 !important; 754 | } 755 | 756 | /* trip */ 757 | .postertrip { 758 | font-family: "Courier New", monospace; 759 | color: #222 !important; 760 | text-shadow: 0 0 1px #102073; 761 | background: none !important; 762 | } 763 | 764 | blockquote { 765 | font: 10pt 'Helvetica', 'Arial', sans-serif !important; 766 | color: #222; 767 | line-height: 12pt !important; 768 | margin: 0 0 0 20px !important; 769 | } 770 | 771 | input[type="checkbox"] { 772 | -moz-appearance: none; 773 | margin: 0; 774 | border: 1px solid #AAA !important; 775 | background: rgba(255, 255, 255, .5) !important; 776 | border-radius: 3px !important; 777 | } 778 | 779 | /* bye bye unicode fags :) */ 780 | .filetitle, 781 | .replytitle, 782 | .postername, 783 | .commentpostername, 784 | .postertrip { 785 | unicode-bidi: normal; 786 | display: inline-block; 787 | } 788 | 789 | /* spoilers */ 790 | .spoiler { 791 | color: transparent !important; 792 | background: #222 !important; 793 | border-radius: 3px; 794 | box-shadow: 0 0 3px rgba(0, 0, 0, .25); 795 | -webkit-transition: all .2s; 796 | -moz-transition: all .2s; 797 | } 798 | 799 | .spoiler:hover { 800 | color: #222 !important; 801 | background: none !important; 802 | box-shadow: none; 803 | } 804 | 805 | .quotelink { 806 | text-shadow: none; 807 | } 808 | 809 | .spoiler .unkfunc { 810 | color: transparent !important; 811 | text-shadow: none; 812 | } 813 | 814 | .spoiler:hover .unkfunc { 815 | color: #669933 !important; 816 | } 817 | 818 | /* pages */ 819 | .pages { 820 | float: none !important; 821 | border-spacing: 0; 822 | border-collapse: collapse; 823 | display: block; 824 | position: relative; 825 | clear: both; 826 | width: 100%; 827 | background: none !important; 828 | border: 0 !important; 829 | text-align: center; 830 | margin: 20px 0; 831 | } 832 | 833 | .pages, 834 | .pages tbody, 835 | .pages tr, 836 | .pages td { 837 | display: block; 838 | } 839 | 840 | .pages td { 841 | padding: 0 !important; 842 | font-size: 0 !important; 843 | color: transparent; 844 | word-spacing: 7px; 845 | } 846 | 847 | .pages td:not(:nth-of-type(2)) { 848 | display: none; 849 | } 850 | 851 | .pages a, 852 | .pages b { 853 | font-size: 14px !important; 854 | color: #2d2d2d !important; 855 | padding: 3px 2px !important; 856 | min-width: 16px; 857 | display: inline-block; 858 | background-image: -webkit-linear-gradient(#fff, #ddd); 859 | background-image: -moz-linear-gradient(#fff, #ddd); 860 | box-shadow: 0 1px 2px rgba(0, 0, 0, .5); 861 | border-radius: 3px !important; 862 | -webkit-transition: box-shadow .2s; 863 | -moz-transition: box-shadow .2s; 864 | text-shadow: none; 865 | } 866 | 867 | .pages a:hover { 868 | box-shadow: 0 1px 4px rgba(0, 0, 0, .75); 869 | } 870 | 871 | .pages b { 872 | font-weight: 600; 873 | color: #ededed !important; 874 | background-image: -webkit-linear-gradient(#4c4c4c, #2d2d2d); 875 | background-image: -moz-linear-gradient(#4c4c4c, #2d2d2d); 876 | cursor: default; 877 | } 878 | 879 | /* deleting posts and reporting */ 880 | table[align=right] td { 881 | font: 8pt 'Helvetica', 'Arial', sans-serif !important; 882 | color: #777; 883 | background-color: #fafafa; 884 | position: fixed; 885 | right: -277px; 886 | bottom: 425px; 887 | opacity: .5; 888 | padding: 1px 0 0 5px !important; 889 | height: 25px; 890 | line-height: 25px !important; 891 | border-top-left-radius: 5px; 892 | border-bottom-left-radius: 5px; 893 | -webkit-transition: all .2s; 894 | -moz-transition: all .2s; 895 | } 896 | 897 | table[align=right] td:hover { 898 | opacity: .9; 899 | right: 0; 900 | } 901 | 902 | table[align=right] input[name=pwd] { 903 | -webkit-appearance: none; 904 | -moz-appearance: none; 905 | padding: 3px 2px !important; 906 | border: 1px solid #bbb !important; 907 | color: #bbb; 908 | border-radius: 3px; 909 | margin: 0 !important; 910 | line-height: 16px !important; 911 | width: 75px !important; 912 | } 913 | 914 | table[align=right] input[value=Delete], 915 | table[align=right] input[value=Report] { 916 | -webkit-appearance: none; 917 | -moz-appearance: none; 918 | cursor: pointer; 919 | font: 8pt 'Helvetica', 'Arial', sans-serif; 920 | background-image: -webkit-linear-gradient(#fafafa, #ccc); 921 | background-image: -moz-linear-gradient(#fafafa, #ccc); 922 | border: 1px solid #bbb; 923 | border-radius: 3px; 924 | text-transform: lowercase; 925 | color: #555; 926 | text-shadow: 0 1px 0 #fff; 927 | padding: 2px 0 1px 0 !important; 928 | min-height: 24px !important; 929 | margin-right: 3px; 930 | } 931 | 932 | .stub { 933 | margin: 8px 0; 934 | clear: both; 935 | padding: 5px; 936 | background-image: -webkit-linear-gradient(#eee, #ddd); 937 | background-image: -moz-linear-gradient(#eee, #ddd); 938 | box-shadow: 0 0 1px #999; 939 | border-radius: 5px; 940 | } 941 | 942 | .stub a { 943 | display: block; 944 | } 945 | 946 | .op > a[href="javascript:;"]:first-of-type { 947 | padding: 2px; 948 | margin-right: 5px; 949 | background-image: -webkit-linear-gradient(#eee, #ddd); 950 | background-image: -moz-linear-gradient(#eee, #ddd); 951 | box-shadow: 0 0 1px #999; 952 | border-radius: 5px; 953 | } 954 | 955 | .stub:hover { 956 | box-shadow: 0 0 2px #999; 957 | } 958 | 959 | .stub:hover a { 960 | text-shadow: none 961 | } 962 | 963 | /* thread watcher */ 964 | #watcher { 965 | position: fixed !important; 966 | opacity: .5; 967 | padding: 5px; 968 | border: 0 !important; 969 | border-radius: 4px; 970 | background-color: #e7e7e7 !important; 971 | box-shadow: 0 0 10px rgba(0, 0, 0, .25); 972 | -webkit-transition: opacity .1s; 973 | -moz-transition: opacity .1s; 974 | } 975 | 976 | #watcher:hover { 977 | opacity: .8; 978 | } 979 | 980 | #watcher > div { 981 | padding: 0 !important; 982 | } 983 | 984 | #watcher > .move { 985 | color: #777; 986 | text-align: center; 987 | text-transform: lowercase; 988 | text-decoration: none !important; 989 | } 990 | 991 | /* stats */ 992 | #stats { 993 | color: #222; 994 | opacity: .5; 995 | padding: 5px; 996 | border-radius: 4px; 997 | background-color: #e7e7e7 !important; 998 | box-shadow: 0 0 10px rgba(0, 0, 0, .25); 999 | } 1000 | 1001 | #stats:hover #postcount::after { 1002 | content: " post(s)"; 1003 | } 1004 | 1005 | #stats:hover #imagecount::after { 1006 | content: " image(s)"; 1007 | } 1008 | 1009 | #qp { 1010 | border: 0 !important; 1011 | background: rgba(235, 235, 235, .85) !important; 1012 | padding: 5px !important; 1013 | border-radius: 3px; 1014 | } 1015 | 1016 | .qphl { 1017 | outline: 0 !important; 1018 | box-shadow: 0 0 5px #999 !important; 1019 | } 1020 | 1021 | #updater { 1022 | color: #777 !important; 1023 | background-image: -webkit-linear-gradient(#eee, #ddd) !important; 1024 | background-image: -moz-linear-gradient(#eee, #ddd) !important; 1025 | top: auto !important; 1026 | right: 30px !important; 1027 | bottom: 0 !important; 1028 | left: auto !important; 1029 | border: 0 !important; 1030 | padding: 3px; 1031 | border-top-left-radius: 3px; 1032 | border-top-right-radius: 3px; 1033 | box-shadow: 0 0 1px #999; 1034 | z-index: 3; 1035 | } 1036 | 1037 | #updater .move { 1038 | cursor: default !important; 1039 | text-align: center; 1040 | } 1041 | 1042 | #updater #count:not(.new):not(.error) { 1043 | display: none; 1044 | } 1045 | 1046 | #updater .new { 1047 | color: #20cc50; 1048 | background: none !important; 1049 | } 1050 | 1051 | #updater .error { 1052 | color: #b90000 !important; 1053 | } 1054 | 1055 | #updater input { 1056 | margin-left: 3px; 1057 | } 1058 | 1059 | #updater input[name="Interval"] { 1060 | -webkit-appearance: none; 1061 | -moz-appearance: none; 1062 | text-align: center; 1063 | padding: 3px 2px; 1064 | border: 1px solid #bbb; 1065 | border-radius: 3px; 1066 | } 1067 | 1068 | #updater div:last-of-type { 1069 | text-align: center; 1070 | } 1071 | 1072 | #updater input[value="Update Now"] { 1073 | -webkit-appearance: none; 1074 | -moz-appearance: none; 1075 | cursor: pointer; 1076 | font-family: 'Helvetica', 'Arial', sans-serif; 1077 | color: #555; 1078 | text-shadow: 0 1px 0 #fff; 1079 | background-image: -webkit-linear-gradient(#fafafa, #ccc); 1080 | background-image: -moz-linear-gradient(#fafafa, #ccc); 1081 | padding: 1px 3px; 1082 | border: 1px solid #bbb; 1083 | border-radius: 3px; 1084 | margin: 1px; 1085 | } 1086 | 1087 | #updater input[value="Update Now"]:hover { 1088 | box-shadow: 0 0 2px #bbb; 1089 | } 1090 | 1091 | #imgControls input[type="checkbox"] { 1092 | -moz-appearance: none; 1093 | border: 1px solid #bbb !important; 1094 | border-radius: 3px !important; 1095 | margin: 0 4px 0 0; 1096 | vertical-align: baseline; 1097 | } 1098 | 1099 | #imgControls { 1100 | background-image: -webkit-linear-gradient(#eee, #ddd); 1101 | background-image: -moz-linear-gradient(#eee, #ddd); 1102 | padding: 3px 2px 2px; 1103 | border-top-left-radius: 3px; 1104 | border-top-right-radius: 3px; 1105 | box-shadow: 0 0 1px #999; 1106 | position: fixed; 1107 | bottom: 0; 1108 | right: 75px; 1109 | z-index: 2; 1110 | } 1111 | 1112 | #imgControls:hover > #imageType { 1113 | visibility: visible; 1114 | width: auto; 1115 | } 1116 | 1117 | #imgControls > #imageType { 1118 | -moz-appearance: none; 1119 | visibility: collapse; 1120 | width: 1px; 1121 | color: #777; 1122 | background: none; 1123 | border: 0; 1124 | } 1125 | 1126 | #imageType > *:not(option) { 1127 | visibility: collapse; 1128 | } 1129 | 1130 | #imgControls > label { 1131 | font-size: 0; 1132 | } 1133 | 1134 | .op { 1135 | position: relative; 1136 | } 1137 | 1138 | .reportbutton { 1139 | color: #2d2d2d !important; 1140 | text-shadow: none !important; 1141 | background-image: -webkit-linear-gradient(#eee, #ddd); 1142 | background-image: -moz-linear-gradient(#eee, #ddd); 1143 | padding: 2px 3px 3px; 1144 | border-radius: 3px; 1145 | box-shadow: 0 0 1px #999; 1146 | position: absolute; 1147 | top: 0; 1148 | right: 0; 1149 | -webkit-transition: box-shadow .2s; 1150 | -moz-transition: box-shadow .2s; 1151 | } 1152 | 1153 | .reportbutton:hover { 1154 | box-shadow: 0 0 3px #999; 1155 | } 1156 | } 1157 | -------------------------------------------------------------------------------- /previous/ss16.user.min.css: -------------------------------------------------------------------------------- 1 | /* ==UserStyle== 2 | @name ss18 3 | @version 2.0.6 4 | @namespace https://github.com/saxamaphone69/ 5 | @description a self-centered, fresh attempt at (user)styling 4chan 6 | @author sax 7 | @homepageURL https://github.com/saxamaphone69/ss16 8 | @supportURL https://github.com/saxamaphone69/ss16/issues 9 | @license CC-BY-SA-4.0 10 | ==/UserStyle== */ 11 | @-moz-document domain('boards.4chan.org'){:root{--primary-50:rgba(243,229,245,.5);--primary-300:#ba68c8;--primary-500:#9c27b0;--primary-700:#7b1fa2;--primary-dark:#454545;--secondary-300:#ffb74d;--secondary-500:#ff9800;--secondary-700:#f57c00;--background-primary:#fff;--background-secondary:#fafafa;--background-hint:#e8e8e8;--background-outline:rgba(205,205,205,.75);--red-50:#ffebee;--red-300:#e57373;--red-500:#f44336;--red-700:#d32f2f;--blue-50:#e3f2fd;--blue-300:#64b5f6;--blue-500:#2196f3;--blue-700:#1976d2;--green-50:#e8f5e9;--green-300:#81c784;--green-500:#4caf50;--green-700:#388e3c;--purple-50:#f3e5f5;--purple-300:#ba68c8;--purple-500:#9c27b0;--purple-700:#7b1fa2;--orange-50:#fff3e0;--orange-300:#ffb74d;--orange-500:#ff9800;--orange-700:#f57c00;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-300:#e0e0e0;--gray-500:#9e9e9e;--gray-700:#616161;--gray-900:#212121;--text-primary-on-primary:#fff;--text-secondary-on-primary:rgba(255,255,255,.7);--text-hint-on-primary:rgba(255,255,255,.5);--text-disabled-on-primary:rgba(255,255,255,.5);--text-icon-on-primary:rgba(255,255,255,.5);--text-primary-on-primary-light:#fff;--text-secondary-on-primary-light:rgba(255,255,255,.7);--text-hint-on-primary-light:rgba(255,255,255,.5);--text-disabled-on-primary-light:rgba(255,255,255,.5);--text-icon-on-primary-light:rgba(255,255,255,.5);--text-primary-on-primary-dark:#fff;--text-secondary-on-primary-dark:rgba(255,255,255,.7);--text-hint-on-primary-dark:rgba(255,255,255,.5);--text-disabled-on-primary-dark:rgba(255,255,255,.5);--text-icon-on-primary-dark:rgba(255,255,255,.5);--text-primary-on-secondary:rgba(0,0,0,.87);--text-secondary-on-secondary:rgba(0,0,0,.54);--text-hint-on-secondary:rgba(0,0,0,.38);--text-disabled-on-secondary:rgba(0,0,0,.38);--text-icon-on-secondary:rgba(0,0,0,.38);--text-primary-on-secondary-light:rgba(0,0,0,.87);--text-secondary-on-secondary-light:rgba(0,0,0,.54);--text-hint-on-secondary-light:rgba(0,0,0,.38);--text-disabled-on-secondary-light:rgba(0,0,0,.38);--text-icon-on-secondary-light:rgba(0,0,0,.38);--text-primary-on-secondary-dark:#fff;--text-secondary-on-secondary-dark:rgba(255,255,255,.7);--text-hint-on-secondary-dark:rgba(255,255,255,.5);--text-disabled-on-secondary-dark:rgba(255,255,255,.5);--text-icon-on-secondary-dark:rgba(255,255,255,.5);--text-primary-on-background:rgba(0,0,0,.87);--text-secondary-on-background:rgba(0,0,0,.54);--text-hint-on-background:rgba(0,0,0,.38);--text-disabled-on-background:rgba(0,0,0,.38);--text-icon-on-background:rgba(0,0,0,.38);--text-primary-on-light:rgba(0,0,0,.87);--text-secondary-on-light:rgba(0,0,0,.54);--text-hint-on-light:rgba(0,0,0,.38);--text-disabled-on-light:rgba(0,0,0,.38);--text-icon-on-light:rgba(0,0,0,.38);--text-primary-on-dark:#fff;--text-secondary-on-dark:rgba(255,255,255,.7);--text-hint-on-dark:rgba(255,255,255,.5);--text-disabled-on-dark:rgba(255,255,255,.5);--text-icon-on-dark:rgba(255,255,255,.5);--font-family-default:arimo,roboto,helvetica,arial,sans-serif;--font-family-compliment:karla,sans-serif;--font-family-monospace:inconsolata,roboto mono,monospace,monospace;--font-family-icon:material icons,font awesome;--depth-material:0 2px 1px -1px rgba(0,0,0,.2),0 1px 1px 0 rgba(0,0,0,.14),0 1px 3px 0 rgba(0,0,0,.12);--depth-default:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2)}:root.ss16--invert{--primary-50:rgba(60,1,68,.25);--background-primary:#2b3942;--background-secondary:#2c343a;--background-hint:#1e2a31;--background-outline:rgba(33,40,44,.5);--text-primary-on-background:#8a9ba1;--text-secondary-on-background:rgba(138,155,161,.7);--text-hint-on-background:rgba(138,155,161,.5)}:root.nws{--primary-50:rgba(239,235,233,.5);--primary-300:#a1887f;--primary-500:#795548;--primary-700:#5d4037;--secondary-300:#81c784;--secondary-500:#4caf50;--secondary-700:#388e3c}:root.site-loading #delform::before{content:'';display:block;border:.5rem solid var(--text-hint-on-background);border-top-color:var(--primary-500);width:10rem;height:10rem;margin:auto;border-radius:50%;animation:loading 1s infinite}:root.site-loading #delform{display:flex;align-items:center;justify-content:center;height:calc(100vh - 30rem)}:root.site-loading,:root.site-loading body{padding:0!important}:root.site-loading #bannerCnt,:root.site-loading #header-bar,:root.site-loading .board,:root.site-loading .navLinks,:root.site-loading .pagelist{display:none!important}@keyframes loading{to{transform:rotate(359deg)}}.arc-ads,.center,[hidden]{display:none!important}#navbotright,.ad-plea,.desktop:not(#bannerCnt):not(.postInfo):not(.postNum):not(.summary):not(.pagelist):not(#boardNavDesktopFoot),.mobile,.postForm,.postInfo>input,.qr-link-container,.sideArrows,hr:not(#unread-line){display:none}:root{font-family:var(--font-family-default);font-size:1rem;line-height:1.5;color:var(--text-primary-on-background);background-color:var(--background-hint);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-y:scroll;box-sizing:border-box}*,::after,::before{box-sizing:inherit}:focus{outline:0}::-moz-selection{background-color:var(--primary-50)}::selection{background-color:var(--primary-50)}::-webkit-scrollbar{width:.5rem;height:.5rem;background-color:var(--gray-300)}::-webkit-scrollbar-thumb{background-color:var(--gray-500)}blockquote,body,h1,h2,h3,h4,h5,h6,p{margin:0}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700;margin-bottom:.5rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:1rem}.name,.subject,b,legend,strong,th{font-weight:700}[style*='weight:']{font-weight:700!important}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}a{color:inherit;background-color:transparent;text-decoration:none;transition:color .25s}.linkify{text-decoration:solid underline;text-decoration-skip:ink}.postertrip,pre{font-size:1em}.postertrip,.posteruid,code,kbd,pre{font-family:var(--font-family-monospace)}code,kbd{font-size:87.5%;padding:.25rem .5rem .125rem;border-radius:2px}code{word-break:break-word;color:var(--text-primary-on-light);background-color:var(--gray-100)}kbd{color:var(--text-primary-on-dark);background-color:var(--gray-900)}embed,iframe,img,svg,video{vertical-align:middle;height:auto;max-width:100%}audio{vertical-align:middle}svg{fill:currentColor}iframe{border:0}table{border-collapse:collapse;border-spacing:0}progress{vertical-align:baseline}button,input,select,textarea{font:inherit;color:inherit;margin:0}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{padding:0;border-style:none}textarea{resize:vertical;overflow:auto}fieldset{min-width:0;padding:0;border:0;margin:0}legend{box-sizing:border-box;color:inherit;display:block;max-width:100%;padding:0;white-space:normal}.hand,label{cursor:pointer}[type=search]{-webkit-appearance:textfield}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}.postNum .replylink::after{content:'View'}.postNum .replylink::after,button,input[type=button],input[type=submit]{font-size:1rem;color:var(--text-primary-on-primary);background-color:var(--primary-500);text-align:center;display:inline-block;vertical-align:middle;padding:.375rem .75rem;border:0;border-radius:2px;transition:background-color .25s}.postNum .replylink:hover::after,button:hover,input[type=button]:hover,input[type=submit]:hover{background-color:var(--primary-700);cursor:pointer}button:disabled{opacity:.75;background-color:var(--primary-500);cursor:not-allowed}.field{background-color:transparent;padding:.375rem .75rem;border:1px solid var(--background-outline);border-radius:2px;transition:all .25s}.field:focus{border-color:var(--primary-300)}.field:disabled{color:var(--text-disabled-on-light);background-color:var(--background-hint);cursor:not-allowed}::placeholder{color:var(--text-hint-on-background);opacity:1}select{background-color:transparent;padding:.375rem .75rem;border:1px solid var(--background-outline);border-radius:2px}.postMessage>s{text-decoration:none;color:var(--gray-900)!important;background-color:var(--gray-900);transition:color .25s}.postMessage s:hover{color:var(--gray-50)!important}.postMessage s a{color:var(--gray-900);border-bottom:0}.postMessage s a:hover{color:var(--gray-50)}#unread-line{box-sizing:content-box;height:1px;background-color:var(--green-500);overflow:visible;border:0;margin:0 0 1rem}.prettyprinted{font-size:87.5%;-webkit-font-smoothing:subpixel-antialiased;white-space:pre-wrap;word-spacing:normal;word-break:normal;-moz-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;hyphens:none;overflow:auto;padding:.5rem;margin:0;display:inline-block;vertical-align:middle;max-width:100%;background-color:#2f3640;border-radius:2px}.prettyprinted .kwd,.prettyprinted .typ{color:#4fc1e9}.prettyprinted .com{color:#656d78}.prettyprinted .tag{color:#ed5565}.prettyprinted .atn{color:#a0d468}.prettyprinted .atv,.prettyprinted .str{color:#ffce54}.prettyprinted .dec,.prettyprinted .lit{color:#ac92ec}.prettyprint,.prettyprinted .clo,.prettyprinted .fun,.prettyprinted .opn,.prettyprinted .pln,.prettyprinted .pun,.prettyprinted .var{color:#e6e9ed}.prettyprint{font-size:87.5%;-webkit-font-smoothing:subpixel-antialiased;white-space:pre-wrap;word-spacing:normal;word-break:normal;-moz-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;hyphens:none;overflow:auto;padding:.5rem;margin:0;display:inline-block;vertical-align:middle;max-height:70vh;max-width:100%;background-color:#2f3640;border-radius:2px}.menu-button{display:inline-block;position:relative;cursor:pointer}#add-post::after,#index-rev::after,#index-search-clear::after,#navlinks a::after,.checkbox-letter::after,.close::after,.copy-text-link::after,.download-link::after,.entry input[type=checkbox]::after,.fa::after,.file--gif:not(.expanded-image)>.post>.file>.fileThumb::after,.file--video:not(.expanded-image)>.post>.file>.fileThumb::after,.gal-close::after,.gal-next::after,.gal-prev::after,.gal-start::after,.gal-stop::after,.has-submenu::after,.jump::after,.menu-button::after,.n-pu::after,.pagelist .next a::after,.pagelist .prev a::after,.qr-preview-spoiler::after,.report-link::after,.show-announcement.entry::after,.watch-thread-link::after{font-family:var(--font-family-icon);font-weight:400;font-style:normal;font-size:24px;display:inline-block;line-height:1;text-transform:none;letter-spacing:normal;word-wrap:normal;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;font-feature-settings:'liga';color:inherit;visibility:visible}.fa-spin::after{animation:spin 2s infinite linear}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(359deg)}}.menu-button::after{content:'more_vert'}.fa-eye::after{content:'remove_red_eye'}.fa-expand::after{content:'fullscreen'}.fa-compress::after{content:'fullscreen_exit'}.fa-picture-o::after{content:'photo'}.fa-comment-o::after{content:'comment'}.fa-refresh::after{content:'refresh'}.fa-wrench::after{content:'settings'}.fa-minus-square-o::after,.fa-minus-square::after{content:'remove_circle'}.fa-plus-square-o::after,.fa-plus-square::after{content:'add_circle'}.close::after,.fa-times::after,.gal-close::after{content:'close'}.watch-thread-link::after{content:'favorite_border'}.watch-thread-link.watched::after{content:'favorite'}#navlinks a:first-of-type::after{content:'keyboard_arrow_up'}#navlinks a:last-of-type::after{content:'keyboard_arrow_down'}#index-rev::after{content:'swap_vert'}.pagelist .prev a::after{content:'arrow_back'}.pagelist .next a::after{content:'arrow_forward'}.fa-edit::after{content:'format_paint'}.copy-text-link::after,.fa-link::after{content:'link'}#paste-area::after{content:'content_paste'}.fa-clock-o::after{content:'timer'}#index-search-clear::after,.fa-times-circle::after{content:'cancel'}.checkbox-letter::after,.qr-preview-spoiler::after{content:'strikethrough_s'}#add-post::after,#qr .fa-plus-square::after{content:'add_box'}.gal-start::after{content:'play_arrow'}.gal-stop::after{content:'stop'}.gal-prev::after,.left .has-submenu::after{content:'keyboard_arrow_left'}.gal-next::after,.has-submenu::after{content:'keyboard_arrow_right'}.jump::after{content:'subdirectory_arrow_right'}.show-announcement.entry::after{content:'chat_bubble'}.report-link::after{content:'warning'}.file--video:not(.expanded-image)>.post>.file>.fileThumb::after{content:'play_circle_outline'}.file--gif:not(.expanded-image)>.post>.file>.fileThumb::after{content:'gif'}.download-link::after,.fa-download::after{content:'file_download'}.n-pu::after{content:'person'}.entry input[type=checkbox]::after{content:'check_box_outline_blank';font-size:1.125rem;color:var(--text-icon-on-background);visibility:visible;display:block}.entry input[type=checkbox]:checked::after{content:'check_box';color:var(--green-500)}.archivedIcon,.closedIcon,.stickyIcon{background-image:url("data:image/svg+xml, %3Csvg height='24' width='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M18 8h-1V6c0-2.76-2.24-5-5-5S7 3.24 7 6v2H6c-1.1 0-2 .9-2 2v10c0 1.1.9 2 2 2h12c1.1 0 2-.9 2-2V10c0-1.1-.9-2-2-2zm-6 9c-1.1 0-2-.9-2-2s.9-2 2-2 2 .9 2 2-.9 2-2 2zm3.1-9H8.9V6c0-1.71 1.39-3.1 3.1-3.1 1.71 0 3.1 1.39 3.1 3.1v2z'/%3E%3C/svg%3E");height:0;width:1.5rem;padding-top:1.5rem;background-repeat:no-repeat}.archivedIcon,.stickyIcon{background-image:url("data:image/svg+xml, %3Csvg height='24' width='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20.54 5.23l-1.39-1.68C18.88 3.21 18.47 3 18 3H6c-.47 0-.88.21-1.16.55L3.46 5.23C3.17 5.57 3 6.02 3 6.5V19c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V6.5c0-.48-.17-.93-.46-1.27zM12 17.5L6.5 12H10v-2h4v2h3.5L12 17.5zM5.12 5l.81-1h12l.94 1H5.12z'/%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3C/svg%3E")}.stickyIcon{background-image:url("data:image/svg+xml, %3Csvg height='24' width='24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 0 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3Cpath d='M0 0h24v24H0z' fill='none'/%3E%3C/svg%3E")}.identityIcon{vertical-align:baseline}:root.shortcut-icons #shortcuts .fa{font-size:0;visibility:hidden}:root:not(.shortcut-icons) #shortcuts .fa::after{display:none}#watcher-link.replies-quoting-you::after{color:var(--secondary-500)}.boardBanner{color:var(--text-primary-on-primary);text-align:center;height:40vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background-image:linear-gradient(pink,#6495ed);overflow:hidden;pointer-events:none;user-select:none;contain:strict}.boardTitle{font-family:var(--font-family-compliment);font-size:calc(100% + 5vw);line-height:1;text-transform:lowercase;text-shadow:1rem 1rem 0 var(--primary-500);will-change:text-shadow;transition:text-shadow .1s;z-index:1}.boardSubtitle,.boardTitle{white-space:pre-line}.boardSubtitle[title],.boardTitle[title]{cursor:help}.boardSubtitle[contenteditable=true],.boardTitle[contenteditable=true]{cursor:text;border-bottom:1px dashed}.postMessage>.quote{color:var(--green-500)}.warning{color:var(--red-500)}[color=red],[style*='color: red'],[style*='color:red']{color:var(--red-500)!important}.move{cursor:grab;overflow:hidden}.move:active{cursor:grabbing}.posteruid{font-size:0}.painted{font-size:1rem;display:inline-flex;align-items:center;justify-content:center;padding:.25rem .5rem .125rem;border-radius:2px;position:relative}.painted:hover::after{content:'';display:block;position:absolute;top:0;left:0;width:100%;height:100%;border-radius:2px;background-color:rgba(0,0,0,.1)}:root.fixed.top-header{padding-top:3rem}:root.fixed.bottom-header{padding-bottom:3rem}:root.fixed.top-header #header-bar{top:0}:root.fixed.bottom-header #header-bar{bottom:0}:root.fixed #header-bar{position:fixed}:root.centered-links #board-list,:root.centered-links #full-board-list .boardList,:root.centered-links #header-bar .boardList{justify-content:center}#header-bar{color:var(--text-primary-on-primary);background-color:var(--primary-500);position:relative;z-index:10;padding:0 1.5rem;left:0;right:0;display:flex;justify-content:space-between;align-items:center;will-change:background-color,transform;transition:background-color .25s,transform .25s}:root.fixed.top-header #header-bar.autohide:not(:hover){margin-bottom:-1rem;transform:translateY(-100%)}:root.fixed.bottom-header #header-bar.autohide:not(:hover){transform:translateY(100%)}#board-list,#custom-board-list,#full-board-list,#full-boord-list .boardList{display:flex;align-items:center}#board-list{font-family:var(--font-family-compliment);flex:1;user-select:none}#board-list .boardList{flex-wrap:wrap}#board-list a{text-transform:lowercase;display:inline-flex;justify-content:center;align-items:center;position:relative;padding:0 .75rem;height:3rem;min-width:3.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;will-change:opacity;transition:opacity .25s;flex-grow:0;flex-shrink:0}#board-list a:not(.current){opacity:.7}#board-list a:not(.current):hover{opacity:.85}#board-list .current{opacity:1}#board-list a::after{display:none;position:absolute;bottom:0;left:0;width:100%;height:2px;content:'';pointer-events:none;background-color:var(--secondary-500)}#board-list .current::after,#board-list a:hover::after,#fourchanx-settings label{display:block}#full-board-list .boardList span,.pagelist button{display:none}#shortcuts:empty{display:none}:root.autohiding-scrollbar #shortcuts{margin-right:2rem}:root:not(.fappeTyme) #shortcut-fappe,:root:not(.werkTyme) #shortcut-werk{display:none}.indicator,.shortcut{display:inline-flex;align-items:center;justify-content:center}.indicator{background-color:var(--secondary-500);width:2rem;border-radius:2px;color:var(--text-primary-on-primary);height:2rem;transition:background-color .25s}.indicator:hover{background-color:var(--secondary-700);cursor:pointer}#shortcuts{display:flex;align-items:center}.shortcut{color:var(--text-icon-on-primary);min-width:3rem;height:3rem;padding:0 .5rem;transition:opacity .25s}.shortcut:hover{color:var(--text-secondary-on-primary)}.shortcut:not(#shortcut-fappe):not(#shortcut-werk):not(#shortcut-updater):not(#shortcut-stats):not(#shortcut-menu){font-family:var(--font-family-compliment)}.shortcut>.menu-button{display:inline-flex}#scroll-marker{position:absolute;display:none;height:1rem;left:0;right:0}#header-bar:not(.autohide) #scroll-marker{pointer-events:none}:root.fixed #scroll-marker{display:block}:root.fixed.top-header #scroll-marker{top:100%}:root.fixed.bottom-header #scroll-marker{bottom:100%}#scroll-progress{position:absolute;top:100%;left:0;width:100%;height:.25rem;opacity:0;background-color:var(--gray-300);border:0;will-change:opacity;transition:opacity .25s;pointer-events:none}:root.bottom-header #scroll-progress{bottom:100%;top:auto}#header-bar.scrolled #scroll-progress,#index-search-clear:hover::after,.notification .fa-times:hover::after{opacity:1}#scroll-progress::-webkit-progress-bar{background-color:var(--gray-300)}#scroll-progress::-webkit-progress-value{background-color:var(--green-500)}#scroll-progress::-moz-progress-bar{background-color:var(--green-500)}#notifications{position:fixed;top:0;height:0;text-align:center;left:0;right:0;visibility:visible}:root.fixed.top-header #header-bar.autohide #notifications,:root.fixed.top-header:not(.gallery-open) #notifications{position:absolute;top:100%}.notification{color:var(--text-primary-on-primary);margin:.5rem auto 0;border-radius:2px;width:50rem;max-width:100%;position:relative;padding:.5rem 1rem;will-change:opacity;transition:opacity .25s}.notification.error{background-color:var(--red-500)}.notification.warning{background-color:var(--orange-500)}.notification.success{background-color:var(--green-500)}.notification.info{background-color:var(--blue-500)}.notification .fa-times::after{position:absolute;right:1rem;top:50%;transform:translateY(-50%);opacity:.75;transition:opacity .25s}.message{white-space:pre-line;margin-right:2rem;max-height:10rem;overflow:auto}#boardNavDesktopFoot a:hover::after,.message a{border-bottom:1px solid}:root.hide-announcement .globalMessage,:root.tainted .report-error{display:none}.globalMessage{contain:content;position:fixed;bottom:1.5rem;left:1.5rem;max-width:25vw;z-index:7;background-color:var(--background-primary);display:flex;align-items:center;justify-content:flex-start;padding:1rem 1rem .5rem 1.5rem;border-radius:2px;box-shadow:0 0 1.5rem rgba(33,33,33,.25);transition:box-shadow .25s}.globalMessage:hover{box-shadow:0 0 1.75rem rgba(33,33,33,.5)}.globalMessage .hide-announcement{font-size:0;margin-left:.5rem}.globalMessage .hide-announcement>a{font-size:1rem;color:var(--primary-500);text-transform:uppercase;display:inline-block;padding:.25rem .5rem;border-radius:2px;transition:all .25s}.globalMessage .hide-announcement>a:hover{background-color:var(--primary-50)}#thread-stats,#updater{font-family:var(--font-family-monospace)}:root.float #thread-stats,:root.float #updater{position:fixed;z-index:5;background-color:var(--primary-500);display:inline-flex;justify-content:center;align-items:center;height:1.75rem;padding:.5rem}#thread-stats span,#updater{color:var(--text-secondary-on-primary)}#updater>.move{position:absolute;z-index:-1;top:-.125rem;right:-.125rem;bottom:-.125rem;left:-.125rem}#updater .new{color:var(--green-500)}#update-status:not(.empty)+#update-timer:not(.empty):not(.loading){margin-left:.5rem}#page-count,#update-timer{cursor:pointer}#thread-stats{color:var(--text-hint-on-primary)}#thread-stats .warning{color:var(--red-500)}:root.float #thread-stats>.move>span:not(#page-count){pointer-events:none}.navLinks.json-index{color:var(--text-primary-on-primary);background-color:var(--primary-500);width:75rem;padding:0 1.5rem;max-width:100%;margin:-2rem auto 3rem;position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:3rem}#index-search{color:var(--text-primary-on-background);background-color:var(--background-primary);padding-right:1.5rem;margin:0 1rem}#index-search-clear{font-size:0;width:0}#index-search-clear::after{position:relative;color:var(--red-500);font-size:1.125rem;left:-2.5rem;opacity:.75;transition:opacity .25s}#hidden-label{color:var(--text-secondary-on-primary)}#index-rev{visibility:hidden;width:1.5rem;height:100%;margin:0 .25rem;display:inline-flex;align-items:center}#index-rev::after{color:var(--text-icon-on-primary);visibility:visible;cursor:pointer;transition:color .25s}#index-rev:checked::after{color:var(--secondary-500)}.navLinks select{color:var(--text-primary-on-background);background-color:var(--background-primary);margin-right:.25rem}#index-search:not([data-searching])+#index-search-clear,.archlistlink,.bottomlink,.cataloglink,.indexlink,:root:not(.catalog-mode) #hidden-label,:root:not(.catalog-mode) #index-size,:root:not(.paged-mode) .pagelist{display:none}#index-options{display:flex;align-items:center}#lastlong-options{display:inline-flex;flex-direction:column;margin-right:.25rem}#lastlong-options>input{font-family:var(--font-family-monospace);text-align:center;background:0 0;height:50%;width:2.25rem;padding:0;border:0;margin:1px 0}@media (max-width:75rem){#header-bar{padding:0 .5rem}#board-list a,.shortcut{font-size:80%;padding:0 .25rem;min-width:1rem}}:root.index .board{min-height:calc(100vh - (40vh + 6rem))}:root.thread-view .board{min-height:calc(100vh - (40vh + 2rem + 95px + 121px))}.closed{position:fixed;display:flex;z-index:10;bottom:0;left:50%;height:3rem;align-items:center;justify-content:center;padding:0 1.5rem;transform:translate(-50%,0);color:var(--text-primary-on-dark);border-radius:2px;background-color:var(--gray-900)}.board{max-width:70rem;margin:-2rem auto 0;position:relative;z-index:1;contain:layout}.thread{padding:0 1.5rem;margin-bottom:1rem}.board .thread:last-of-type{margin-bottom:2rem}.postContainer{position:relative;margin-bottom:1rem}.section-main>fieldset>div[data-name]:last-of-type,.thread .postContainer:last-of-type{margin-bottom:0}.post,.summary{background-color:var(--background-primary)}.summary{text-align:center;line-height:3;margin-top:1px;z-index:1;position:relative;display:block}.post{display:flow-root;border-radius:2px;padding:.5rem 1rem;transition:background-color .25s;box-shadow:0 2px 10px 0 rgba(33,33,33,.1)}.container>a,.postMessage a,.postNum>a,.summary>.replylink{color:var(--primary-500)}.container>a:hover,.postMessage a:hover,.postNum>a:hover,.summary>.replylink:hover{color:var(--primary-700)}.postInfo{display:flex;align-items:center;padding:.5rem 1rem .275rem .5rem;background-color:rgba(117,117,117,.025)}.noFile .postInfo{border-bottom:1px solid var(--background-hint)}.postInfo>.subject{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.post{padding:0}.replylink:visited::after{background-color:var(--primary-700)}.postMessage:empty{display:none}.postMessage{font-size:1.125rem;margin:.5rem 1rem}:root.bottom-backlinks .container{display:block;font-size:87.5%;font-family:var(--font-family-monospace);padding:.25rem .5rem;background-color:rgba(117,117,117,.025);border-top:1px solid var(--background-hint);clear:both}:root .container:empty{display:none}.summary{margin-bottom:1rem}.inlined{opacity:.7}.inline{margin:.5rem 0;clear:both;display:flow-root;box-shadow:0 0 1rem rgba(33,33,33,.25);border-radius:2px}.postMessage .inline{margin-bottom:-1rem}.container+.inline{margin-top:1.5rem}.container~.inline:last-of-type{margin-bottom:.5rem}.postNum>span:last-child{font-size:0;vertical-align:middle}.pagelist,:root .pagelist:not(.json-index){display:flex;text-align:center}.pagelist a{color:var(--text-secondary-on-background);display:block;transition:color .25s,background-color .25s}.pagelist .pages>strong>a,.pagelist a:hover{color:var(--text-primary-on-primary);background-color:var(--primary-300)}.pagelist .pages>strong>a{background-color:var(--primary-500)}.pagelist .next,.pagelist .prev{width:10%}.pagelist .next a::after,.pagelist .prev a::after{font-size:4.25rem;flex:1;height:3rem;overflow:hidden;display:block;padding-top:.25rem}.pagelist .pages:not(.cataloglink){font-size:0;flex:1;display:flex}.pages a{font-size:3.5rem;font-weight:700;line-height:1;padding-top:.25rem;height:3rem;flex:1;overflow:hidden}.pages strong{flex:1}:root.hide-bottom-board-list #boardNavDesktopFoot{display:none}#boardNavDesktopFoot::before{content:'Full 4chan Board List';font-size:1.25rem;display:block;padding:2rem 1.5rem 0;max-width:75rem;margin:auto;cursor:ns-resize;color:var(--text-primary-on-background)}#boardNavDesktopFoot:not(.is-active)::before{padding-bottom:2rem}#boardNavDesktopFoot{font-size:0;font-family:var(--font-family-compliment);color:var(--text-secondary-on-background);background-color:var(--background-primary);border-top:1px solid var(--background-outline)}#boardNavDesktopFoot .boardList{display:flex;flex-wrap:wrap;flex-direction:column;height:calc(2rem*20);padding:1rem 1.5rem 2rem;width:100%;max-width:75rem;margin:auto;transition:height .25s;overflow-x:auto}#boardNavDesktopFoot:not(.is-active) .boardList{height:0;padding:0;overflow:hidden}#boardNavDesktopFoot a{display:block;margin-right:1rem;margin-bottom:.25rem}#boardNavDesktopFoot .current,#boardNavDesktopFoot a:hover,#footer-links a:hover{color:var(--text-primary-on-background)}#boardNavDesktopFoot a::before{content:attr(href);font-size:1rem;display:inline-block;margin-right:.5rem;min-width:5ch}#boardNavDesktopFoot a::after{content:attr(title);font-size:1rem;display:inline}.absBotText{font-size:.85rem;color:var(--text-secondary-on-background);background-color:var(--background-primary);user-select:none}.absBotDisclaimer{display:block;max-width:75rem;padding:2rem 1.5rem 1rem;margin:auto;border-top:1px solid var(--background-outline)}#footer-links{font-size:0;max-width:75rem;padding:0 1.5rem 2rem;margin:0 auto;position:relative}#footer-links a{font-size:.85rem;display:inline-block;width:calc((100%/4) - 1rem);margin-right:1rem}#footer-links::after{content:url(https://s.4cdn.org/image/favicon.ico);display:block;height:1rem;width:1rem;position:absolute;right:1.5rem;bottom:2.125rem;filter:grayscale(1);opacity:.5}.subject:not(:empty)::after{content:' by ';font-weight:400;color:var(--text-secondary-on-background);margin-right:.25rem}.ip-counter{color:var(--text-secondary-on-background)}.abbr,.dateTime,.page-num{color:var(--text-hint-on-background)}.dateTime{margin:0 .25rem}.postNum>a:first-child{font-size:0}.postNum>a:first-child::after{content:'#';font-size:1rem}.file{color:var(--text-hint-on-light);position:relative}.fileThumb{float:left;margin:.5rem}.fileText{font-size:87.5%;padding:0 1rem .125rem;background-color:rgba(117,117,117,.025);border-bottom:1px solid var(--background-hint)}.fileText a{color:var(--primary-300);unicode-bidi:isolate}.fa-download::after{font-size:1.125rem;vertical-align:bottom}.expanded-image>.post>.file>.fileThumb>img[data-md5],.expanded-image>.post>.file>.fileThumb>video[data-md5],.fileText-original,.fnswitch:hover>.fntrunc,.fnswitch:not(:hover)>.fnfull,.full-image{display:none}.fnfull{overflow-wrap:break-word}.full-image{cursor:pointer}video.full-image{min-width:20rem}.expanded-image>.post>.file>.fileThumb>.full-image{display:inline}.expanded-image{clear:left}.expanding{opacity:.5}:root.fit-height .full-image{max-height:100vh}:root.fixed.fit-height .full-image{max-height:calc(100vh - 3rem)}:root.fit-width .full-image{max-width:100%}:root.ua-gecko.fit-width .full-image{width:100%}.expanded-image.file--wide .postMessage,.fileThumb>.warning{clear:both}.expanded-image.file--wide>.post>.file>.fileThumb{position:relative;display:block!important;max-width:80vw;width:80vw;left:calc(-40vw + (70rem/2) - 2rem)}.expanded-image.file--wide>.post>.file>.fileThumb>.full-image{width:100%}.hide-reply-button,.hide-thread-button{position:absolute;top:1rem;right:2.5rem;opacity:0;z-index:1;will-change:opacity;transition:opacity .25s}.postContainer:hover>.hide-thread-button,.postContainer:hover>div>.hide-reply-button{opacity:.75}.fa-minus-square-o::after,.fa-minus-square::after{font-size:1.125rem;color:var(--text-secondary-on-background)}.stub~*,div[data-checked=false]>.suboption-list{display:none}.stub{display:flex;background-color:var(--background-primary);justify-content:space-between;align-items:center;padding:.5rem 1rem;height:3rem}.stub>a:first-child{display:flex}.stub .fa-plus-square,.stub .fa-plus-square-o{display:inline-flex;align-items:center;justify-content:center;margin-right:.25rem}.stub>.menu-button{color:var(--text-icon-on-background);display:inline-flex;align-items:center;justify-content:center;opacity:0;will-change:opacity;transition:opacity .25s}.stub:hover>.menu-button,.stub>.menu-button.active{opacity:1}#ihover,#qp{position:fixed;z-index:15}#qp .post{border:1px solid var(--background-outline);margin:1rem 1rem 1rem -1rem}#qp.warning{background-color:var(--background-primary);padding:.5rem 1rem}:root.catalog-mode #navlinks,:root.fappeTyme .thread>.noFile,:root.fappeTyme .threadContainer>.noFile{display:none}:root.werkTyme .catalog-thumb:not(.deleted-file):not(.no-file),:root.werkTyme .postContainer:not(.noFile) .fileThumb,:root:not(.werkTyme) .werkTyme-filename{display:none}.exif{font-size:.75rem;display:none}#overlay{position:fixed;z-index:16;background-color:rgba(33,33,33,.75);top:0;left:0;width:100%;height:100%}#fourchanx-settings{position:fixed;z-index:17;background-color:var(--background-primary);top:50%;left:50%;transform:translate(-50%,-50%);width:75rem;max-width:90%;height:90vh;margin:auto;display:flex;flex-direction:column;contain:paint;animation-name:bounceIn;animation-duration:.75s;animation-fill-mode:both}@keyframes bounceIn{0%,20%,40%,60%,80%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(-50%,-50%) scale3d(.3,.3,.3)}20%{transform:translate(-50%,-50%) scale3d(1.1,1.1,1.1)}40%{transform:translate(-50%,-50%) scale3d(.9,.9,.9)}60%{opacity:1;transform:translate(-50%,-50%) scale3d(1.03,1.03,1.03)}80%{transform:translate(-50%,-50%) scale3d(.97,.97,.97)}to{opacity:1;transform:translate(-50%,-50%) scale3d(1,1,1)}}#fourchanx-settings nav{font-size:0;font-family:var(--font-family-compliment);color:var(--text-primary-on-primary);background-color:var(--primary-500);display:flex;align-items:center;padding:0 1.5rem;text-transform:lowercase}.credits,.sections-list{display:flex}#fourchanx-settings nav a:not([download]){font-size:1rem;display:inline-flex;justify-content:center;align-items:center;height:3rem;padding:0 .75rem;position:relative;min-width:3.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;will-change:opacity;opacity:.7;transition:opacity .25s;flex-grow:0;flex-shrink:0}#fourchanx-settings nav a:not([download]):hover{opacity:.85;cursor:pointer}#fourchanx-settings nav a.tab-selected,.post:hover>.postInfo>.menu-button,.post>.postInfo>.menu-button.active{opacity:1}#fourchanx-settings nav a:not(.close)::after{display:none;position:absolute;bottom:0;left:0;width:100%;height:2px;content:'';pointer-events:none;background-color:var(--secondary-500)}#fourchanx-settings nav a.tab-selected::after,#fourchanx-settings nav a:not(.close):hover::after{display:block}.imp-exp-result{flex:1;margin:0}.section-container{flex:1;overflow:auto;overscroll-behavior:contain;padding:0 1rem}.section-container>section{padding:.5rem 0 1rem}#fourchanx-settings fieldset{padding:1rem;border:1px solid rgba(33,33,33,.25);border-radius:2px;margin-bottom:1rem}#fourchanx-settings fieldset:last-of-type{margin:0}#fourchanx-settings legend{padding:0 .5rem}#fourchanx-settings textarea{font-family:var(--font-family-monospace);width:100%}#fourchanx-settings .description{color:var(--text-secondary-on-background);display:block}#fourchanx-settings button+.description{display:inline-block;margin-left:1rem}.suboption-list{position:relative;margin-left:1rem}.section-main>fieldset>div[data-name]{margin-left:4rem;margin-bottom:.5rem}.suboption-list>div[data-name]{margin-top:.5rem}.suboption-list>div[data-name]:not(:last-of-type){margin-bottom:.5rem}.section-main input[type=checkbox]{visibility:hidden;position:absolute;left:-99rem}.section-main label{position:relative}.section-main label::after,.section-main label::before{content:'';display:inline-block;position:absolute;transition:all .25s}.section-main label::before{opacity:.38;border-radius:1rem;width:3rem;height:1rem;background-color:#000;left:-4rem;top:1rem}.section-main div[data-checked=true]>label::before{background-color:var(--secondary-300);opacity:.5}.section-main label::after{background-color:#fafafa;border-radius:50%;width:1.5rem;height:1.5rem;left:-4.25rem;top:.75rem;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12)}.section-main div[data-checked=true]>label::after{background-color:var(--secondary-500);transform:translateX(2rem)}.section-filter select{width:100%;margin-bottom:1rem}.section-filter ul{padding:0 2rem;margin:1rem 0}.section-filter textarea,.section-sauce textarea{height:40rem}#sauce-doc-expand:not(:checked)~#sauce-doc{max-height:12rem;overflow:auto}#sauce-doc>label{float:right;margin:0 .5rem}#sauce-doc{margin-bottom:1rem}#sauce-doc-expand+.riceCheck{display:none}.section-advanced>fieldset:first-child{position:relative}#archive-board-select{position:absolute;background-color:var(--background-primary);top:0;left:7.5rem}#archive-table{width:100%}#archive-table .archive-cell{text-align:center;width:calc(100%/3)}#lastarchivecheck+label{float:right}.section-advanced .note{font-size:80%;color:var(--text-secondary-on-background);margin-left:1rem}.section-advanced a{color:var(--primary-500)}.section-advanced textarea{height:10rem}.section-advanced textarea[name=archiveLists]{height:5rem}.favicon-preview>img:nth-of-type(3n+1){margin-left:.5rem}.section-keybinds table{margin:auto}.section-keybinds .field{font-family:var(--font-family-monospace)}.unscroll{overflow:hidden}#navlinks{position:fixed;z-index:10;top:5rem;right:0;font-size:0;color:var(--text-secondary-on-primary);background-color:var(--primary-500)}#navlinks a:hover::after{background-color:var(--primary-700);transition:background-color .25s}.post .menu-button{position:absolute;top:1rem;right:1rem;z-index:2}.post .menu-button::after{font-size:1.125rem;color:var(--text-secondary-on-background)}.post>.postInfo>.menu-button{opacity:0;will-change:opacity;transition:opacity .25s}.menu-button.active::after{border-radius:2px;box-shadow:0 0 .125rem .125em var(--primary-50)}#menu,.submenu{background-color:var(--background-primary);padding:.5rem 0;border:1px solid rgba(33,33,33,.25);border-radius:2px}#menu{z-index:16;font-size:90%;color:var(--text-primary-on-background);white-space:nowrap;position:fixed}.entry{line-height:2.5rem;display:block;position:relative;min-width:12.5rem;cursor:pointer;padding:0 1rem;transition:background-color .25s}.entry:hover{background-color:var(--background-secondary)}.entry .shortcut-text{font-size:75%;color:var(--text-hint-on-background);margin-left:.5rem}.entry.has-shortcut-text{display:flex;justify-content:space-between;align-items:center}.entry::after,.show-announcement.entry::after{color:var(--text-icon-on-background);position:absolute;right:.5rem;font-size:1rem;line-height:2.5rem}.submenu{display:none;position:absolute;left:100%;margin-top:calc((.5rem + 1px)*-1)}.submenu[style*='m: 0']{margin-top:0;margin-bottom:calc((.5rem + 1px)*-1)}.focused>.submenu{display:block}.entry .field{width:auto}.entry input[type=number]{width:5rem;padding:0 0 0 .375rem}.entry input[type=checkbox]{visibility:hidden;margin-right:.5rem}:root.ua-gecko .entry input[type=checkbox]{visibility:visible}:root.fixed-watcher #thread-watcher{z-index:10;position:fixed}#thread-watcher{z-index:5;position:absolute;background-color:var(--background-primary);white-space:nowrap;min-width:10rem}#thread-watcher>.move{font-family:var(--font-family-compliment);text-transform:lowercase;background-color:var(--primary-500);display:flex;align-items:center;height:3rem;padding:0 1.5rem;color:var(--text-primary-on-primary)}#thread-watcher>.move>.refresh{display:inline-flex;align-items:center;margin-left:.5rem;opacity:.7;transition:opacity .25s}#thread-watcher>.move>.refresh:hover,.watch-thread-link:hover::after{opacity:.85}#watcher-status{flex:1}#thread-watcher>.move>.menu-button{font-family:var(--font-family-default);text-transform:capitalize;display:inline-flex;align-items:center;margin-right:.5rem}#thread-watcher>.move>.close{font-size:0}#watched-threads{overflow-x:hidden;overflow-y:auto;border:1px solid var(--background-outline);border-top:0}#watched-threads:empty::after{content:'No threads being watched.';display:block;color:var(--text-hint-on-background);padding:.25rem 1rem}:root.fixed-watcher #watched-threads{max-height:85vh}:root:not(.fixed-watcher) #watched-threads:not(:hover){max-height:210px;overflow-y:hidden}#watched-threads>div{display:flex;align-items:center;height:3rem;padding:0 1.5rem}#watched-threads>div:nth-of-type(even),.flashListing tr:nth-of-type(odd){background-color:var(--background-secondary)}#watched-threads .fa-times{display:inline-flex;align-items:center;margin-right:.5rem;color:var(--red-500)}#watched-threads .fa-times:hover{color:var(--red-700)}#watched-threads .dead-thread>.watcher-link{text-decoration:line-through;color:var(--text-hint-on-background);opacity:.75}#watched-threads .replies-read{color:var(--text-secondary-on-background)}#watched-threads>.current .watcher-title{font-weight:700}#watched-threads .watcher-link{max-width:22.5rem;display:inline-flex;flex-direction:row}#watched-threads .watcher-unread{flex:0;margin-right:.25rem}#watched-threads .watcher-title{overflow:hidden;text-overflow:ellipsis;flex:0 1 auto}#watched-threads .replies-unread .watcher-link{color:var(--blue-500)}#watched-threads .replies-quoting-you .watcher-link{color:var(--red-500)}.watch-thread-link{position:relative;display:inline-block;vertical-align:middle}.watch-thread-link::after{color:var(--red-500);opacity:.7;transition:opacity .25s}.watch-thread-link.watched::after{opacity:1}.watch-thread-link::before{content:'';position:absolute;opacity:0;pointer-events:none;border-radius:50%;background-color:rgba(222,68,44,.26);height:1.25rem;width:1.25rem;transform-origin:50% 50%;transform:scale(.75);transition:opacity .25s,transform .25s}.watch-thread-link:active::before{opacity:1;transform:scale(2)}#embedding{position:fixed;z-index:10}#embedding.empty,.embedder:not(.embedded)>span{display:none}#embedding>div:first-child{display:flex;font-size:0;color:var(--text-primary-on-primary);background-color:var(--primary-500);padding:0 1.5rem;height:3rem;align-items:center}#embedding .move{flex:1}#embedding .move::before{content:'embedded content';font-family:var(--font-family-compliment);font-size:1rem}#embedding .jump::after,#qr .persona button{margin-right:.5rem}#media-embed{background-color:var(--background-primary)}#autohide,#file-n-submit:not(.has-file) #qr-filerm,#qr .oekaki-bg input[name=oekaki-bg]:not(:checked)+input[name=oekaki-bgcolor],#qr .oekaki.has-file,#qr select[data-name=thread],#qr.autohide:not(.focus):not(:hover):not(:active)>form,#qr.forced-anon [name=name],#qr.forced-anon [name=sub],#qr.reply-to-thread [name=filetag],#qr.reply-to-thread [name=sub],#qr.tex-preview .textarea>:not(#tex-preview),#qr:not(.dump) #dump-list-container,#qr:not(.has-math) #tex-preview-button,#qr:not(.has-sjis) #sjis-toggle,#qr:not(.tex-preview) #tex-preview,body:not(.board_f) #qr [name=filetag]{display:none}#qr{position:fixed;z-index:10;background-color:var(--background-primary);min-width:30rem;max-width:50rem;contain:paint;box-shadow:0 2px 10px 0 rgba(33,33,33,.1)}#qr>.move{color:var(--text-primary-on-primary);background-color:var(--primary-500);padding:0 1.5rem;display:flex;height:3rem;align-items:center;justify-content:space-between}#qr>.move>label{font-family:var(--font-family-compliment);text-transform:lowercase}#qr>.move>.close{font-size:0}#qr>form{padding:1rem;border:1px solid var(--background-outline);border-top:0;max-height:calc(100vh - 5rem);overflow-x:hidden;overflow-y:auto}#qr .persona{display:flex;margin-bottom:.5rem}#qr .persona .field{flex:1}#qr .persona .field:not(:first-of-type){margin-left:.5rem}#qr .persona .field:focus,#qr .persona .field:hover{flex:1.5}#qr.sjis-preview #sjis-toggle,#qr.tex-preview #tex-preview-button{background-color:var(--primary-300)}#qr .captcha-root,#qr .textarea{position:relative;margin-bottom:.5rem}#qr textarea{display:block;min-height:10rem;min-width:100%}#char-count{position:absolute;pointer-events:none;font-size:.75rem;right:.5rem;bottom:.5rem}#qr.captcha-v1 #qr-captcha-iframe{display:none}#qr.captcha-v1 .captcha-img{text-align:center;min-height:59px;min-width:302px;margin-bottom:.5rem;cursor:pointer}#qr.captcha-v1 .captcha-input{width:100%;margin-bottom:.5rem}#qr .captcha-container>div{margin:auto;width:304px;overflow:hidden}#qr .captcha-counter{display:block;width:100%;text-align:center;pointer-events:none}#qr.captcha-open .captcha-counter{position:absolute;bottom:3px}#qr .captcha-counter>a{pointer-events:auto;display:inline-block}#qr:not(.captcha-open) .captcha-counter>a{display:block;width:100%}#qr.captcha-v2 #qr-captcha-iframe{width:302px;height:423px;border:0;display:block;margin:auto}.goog-bubble-content{max-width:100vw;max-height:100vh;overflow:auto}.goog-bubble-content iframe{position:static!important}#g-recaptcha{min-height:78px;height:auto}#dump-list-container{position:relative;overflow-y:hidden;margin-bottom:.5rem}#dump-list{overflow:auto;white-space:nowrap;display:flex;flex-wrap:wrap;min-height:8.5rem;max-height:10rem}#dump-list .qr-preview:only-of-type>.remove,#file-n-submit.has-file #paste-area,#file-n-submit.has-file #url-button,#file-n-submit:not(.custom-cooldown) #custom-cooldown-button,#file-n-submit:not(.has-file) #qr-spoiler-label,#qr:not(.has-spoiler) #qr-spoiler-label,#qr:not(.has-spoiler) .qr-preview-spoiler,.qr-preview:not(.has-file) label{display:none}.qr-preview{display:inline-block;flex:none;counter-increment:thumbnails;height:7.5rem;width:7.5rem;cursor:move;padding:.25rem;opacity:.5;margin-right:.25rem;margin-bottom:.25rem;position:relative;overflow:hidden;background-size:cover;background-color:var(--gray-50);will-change:opacity,transform;transition:opacity .25s,transform .25s}.qr-preview::before{content:counter(thumbnails);position:aboslute;top:0;right:0;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;width:1.5rem;height:1.5rem;color:var(--text-primary-on-dark);background-color:var(--background-outline);border-radius:50%}.qr-preview:focus,.qr-preview:hover{opacity:.85}#selected{opacity:1}.qr-preview.drag{transform:scale(.8)}.qr-preview.over{transform:scale(1.1);z-index:1}.qr-preview .fa-times-circle::after{font-size:1.125rem;color:var(--red-500);cursor:pointer}.qr-preview.has-file>span{color:var(--text-primary-on-primary)}#add-post,.qr-preview-spoiler{font-size:0}#add-post{position:absolute;right:0;bottom:0}#add-post::after{font-size:3rem;color:var(--blue-500);transition:color .25s}#add-post:hover::after{color:var(--blue-700)}#qr .oekaki{display:flex;align-items:stretch;margin-bottom:.5rem}#qr-draw-button{width:15%;margin-right:.5rem}#qr .oekaki>label{flex:1;margin-right:.5rem}#qr .oekaki>label>span{color:var(--text-hint-on-background);margin-right:.25rem}#qr .oekaki>label>input{max-width:10rem}#qr .oekaki-bg{display:inline-block;width:15%}#qr .oekaki-bg input[name=oekaki-bg]{position:absolute;z-index:1}#qr .oekaki-bg input[name=oekaki-bgcolor]{position:absolute;top:0;left:0;height:100%;width:100%;border:none;padding:0;background:0 0}#file-n-submit{display:flex;align-items:stretch}#qr-file-button{width:15%;margin-right:.5rem}#qr-filename-container{all:unset;flex:1;display:flex;align-items:stretch;position:relative;margin-right:.5rem}#file-n-submit.has-file #qr-no-file,#qr-filename{display:none}#file-n-submit.has-file #qr-filename,#qr-no-file{flex:1;padding:.375rem .75rem .375rem 0;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#qr-no-file{color:var(--text-hint-on-background)}#qr-filename{background-color:transparent;border:0}#qr .oekaki-bg,.qr-spoiler-label{position:relative}#qr-file-spoiler{position:absolute;opacity:0;pointer-events:none}#qr-file-spoiler:checked+.checkbox-letter::after{opacity:1}.checkbox-letter{font-size:0}#qr-filename-container .fa::after,.checkbox-letter::after{margin-top:.375rem;margin-right:.25rem;opacity:.55;cursor:pointer;transition:opacity .25s}#qr-filename-container .fa:hover::after,#qr.dump #dump-button .fa::after,.checkbox-letter:hover::after,.gal-buttons>a:hover::after{opacity:.85}#custom-cooldown-button.disabled{opacity:.25}#file-n-submit input[type=submit]{background-color:var(--secondary-500);width:25%}#file-n-submit input[type=submit]:hover{background-color:var(--secondary-700)}#qr [type=file]{visibility:hidden;position:absolute}.flagSelector,select[name=filetag]{width:100%;margin-top:.5rem}.hashlink::before{content:' '}.backlink.forwardlink,.quotelink.forwardlink{background-image:url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 4'%3E%3Cstyle%3E.st%7Banimation:shift .5s linear infinite;stroke:currentColor;%7D@keyframes shift %7Bto %7Btransform:translateX%28-20px%29;%7D%7D%3C/style%3E%3Cpath fill='none' d='M0 3.5c5 0 5-3 10-3s5 3 10 3 5-3 10-3 5 3 10 3' class='st' style='stroke:var%28--primary-500, currentColor%29;'/%3E%3C/svg%3E");background-position:0 100%;background-size:auto 3px;background-repeat:repeat-x}.qmark-dead,.qmark-op{opacity:.5;position:relative;font-size:75%;line-height:0;vertical-align:baseline;top:-.5em}.deadlink{opacity:.5;text-decoration:line-through}:root.thread-hide .party-hat{left:19px}.party-hat{left:0;margin-top:-80px;position:absolute;pointer-events:none;z-index:1}.threadContainer{margin:0 0 1rem 1.5rem}#a-gallery,.gal-viewport{display:flex;flex-direction:row}#a-gallery{z-index:20;background-color:rgba(33,33,33,.75);top:0;right:0;bottom:0;left:0;position:fixed}.gal-viewport{align-items:stretch;flex:1;overflow:hidden;position:relative}.gal-buttons{position:absolute;top:1.5rem;left:50%;display:flex;color:var(--text-primary-on-dark);background-color:rgba(33,33,33,.5);padding:.5rem 1rem;border-radius:2px}.gal-buttons.gal-playing>.gal-start,.gal-buttons:not(.gal-playing)>.gal-stop{display:none}.gal-buttons>a::after{font-size:3rem;margin-right:1rem;opacity:.7;transition:opacity .25s}.gal-buttons>a:last-child::after{margin-right:0}.gal-close{font-size:0}.gal-count,.gal-name{display:block;position:absolute;left:50%;transform:translateX(-50%);background-color:rgba(33,33,33,.5);padding:.5rem 1rem;border-radius:2px}.gal-name{z-index:1;bottom:1.5rem;color:var(--text-primary-on-dark)}.gal-name:hover{color:var(--primary-300)}.gal-count{bottom:4.5rem;color:var(--text-hint-on-dark);pointer-events:none}.gal-count>span{color:var(--text-primary-on-dark)}.gal-image{flex:1;display:flex;align-items:flex-start;justify-content:space-around;overflow:hidden}.gal-image>a{display:block;margin:auto;max-width:100%}.gal-image iframe,:root.gal-pdf .gal-image a{width:100%;height:100%}:root.gal-fit-width .gal-image [src]{max-width:100%}:root.gal-fit-height .gal-image [src]{max-height:100vh}.gal-next,.gal-prev{color:var(--text-primary-on-dark)}.gal-next{cursor:pointer}.gal-next::after,.gal-prev::after{font-size:3rem;display:inline-flex;align-items:center;justify-content:center;height:100vh;padding:0 .75rem;opacity:.7}.gal-next:hover::after,.gal-prev:hover::after{background-color:rgba(33,33,33,.5)}.gal-prev{cursor:url('data:image/svg+xml;utf8, ') 16 16,auto}.gal-thumbnails{display:flex;flex-direction:column;align-items:center;overflow-y:auto}.gal-thumb{display:block}.gal-thumb:not(:last-of-type){margin-bottom:.5rem}.gal-highlight{outline:1px solid var(--secondary-500)}.is_arclist h4.center{display:block!important;text-align:center;color:var(--text-primary-on-primary);background-color:var(--red-500);padding:.5rem 1rem;margin:0}.flashListing{background-color:var(--background-primary);max-width:100%;margin:auto}.flashListing tr.highlightPost{background-color:#fffde7}.board_f.is_index .board{max-width:80%;margin-bottom:2rem}#arc-list{position:relative;max-width:70rem;z-index:1;margin:-2rem auto 0}#arc-list thead td,.board_f .flashListing>tbody>tr:first-child td{color:var(--text-primary-on-primary);text-align:center;background-color:var(--primary-500);border:1px solid var(--primary-700);padding:0 .5rem;min-width:5rem;height:3rem}.flashListing td{height:3rem;padding:0 .5rem;border:1px solid var(--background-outline)}.flashListing>tbody tr td:first-of-type{text-align:center}.file-col,.flashListing .subject span{font-size:0}.file-col a::after{color:var(--primary-500);border-bottom:1px solid}.file-col a:hover::after{color:var(--primary-700)}.flashListing .subject::after{display:none}.file-col a::after,.flashListing .subject span::after{content:attr(title);font-size:1rem}.board_f .flashListing tr:not(:first-child) td:nth-child(4),.board_f .flashListing tr:not(:first-child) td:nth-child(8){text-align:center}.board_f .flashListing tr:not(:first-child) td:nth-child(6){text-align:right}.board_f .flashListing tr:not(:first-child) td:nth-child(9){font-size:0;padding:0;border-color:var(--primary-700)}.board_f .flashListing tr:not(:first-child) td:nth-child(9) a::after{content:'View';font-size:1rem;color:var(--text-primary-on-primary);background-color:var(--primary-500);display:inline-flex;align-items:center;justify-content:center;height:100%;width:100%}#arc-list tr td:nth-of-type(1n){width:15%}#arc-list tr td:nth-of-type(2n){width:75%}#arc-list tr td:nth-of-type(3n){width:10%}#swf-embed{z-index:50}.post--hot>.post{background-image:linear-gradient(to bottom,var(--background-primary),#ffebee)}:root.ss16--invert .post--hot>.post{background-image:linear-gradient(to bottom,var(--background-primary),#573737)}.highlight,.post:target,.qphl,.yourPost>.post,:root.highlight-own .yourPost .stub{background-color:#fffde7}.quotesYou>.post{background-color:#fff8e1}.poster--founder>.post{background-color:#e0f2f1}.poster--founder .nameBlock{color:#009688}.poster--admin>.post{background-color:#ffebee}.capcodeAdmin,.poster--admin .nameBlock{color:#f44336}.poster--mod>.post{background-color:#ede7f6}.capcodeMod,.poster--mod .nameBlock{color:#673ab7}.poster--developer>.post{background-color:#e0f7fa}.poster--developer .nameBlock{color:#00bcd4}.poster--manager>.post{background-color:#fce4ec}.poster--manager .nameBlock{color:#e91e63}.poster--verified>.post{background-color:#e8eaf6}.poster--verified .nameBlock{color:#3f51b5}.poster--pass>.post{background-color:#f9fbe7}.poster--pass .n-pu{color:#afb42b;display:inline-block;vertical-align:middle}.file--gif .fileThumb,.file--video .fileThumb{position:relative}.file--gif:not(.expanded-image)>.post>.file>.fileThumb::after,.file--video:not(.expanded-image)>.post>.file>.fileThumb::after{font-size:3rem;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background-image:linear-gradient(to bottom,rgba(33,33,33,0),#212121);opacity:.7;transition:opacity .25s}.file--gif:not(.expanded-image)>.post>.file:hover>.fileThumb::after,.file--video:not(.expanded-image)>.post>.file:hover>.fileThumb::after{opacity:.55}audio.controls-added{display:block;margin:auto}:root.anti-autoplay div.embed{position:static;width:auto;height:auto;text-align:center}:root.anti-autoplay .autoplay-removed{visibility:visible!important;min-width:640px;min-height:360px}:root[xmlns] #doc{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100vh}:root[xmlns] #doc a{color:var(--primary-500)}:root[xmlns] #doc a:hover{color:var(--primary-700);border-bottom:1px solid}:root[xmlns] #doc .boxbar{color:var(--red-500)}:root[xmlns] #doc .boxcontent{margin-top:1rem}:root[xmlns] #copyright{color:var(--text-secondary-on-background);margin:0}.ss16--dialog{position:fixed;top:0;left:0;display:flex;align-items:center;justify-content:center;width:100%;height:100%;z-index:50;background-color:rgba(33,33,33,.75)}.ss16--dialog-window{background-color:var(--background-primary);box-shadow:0 11px 15px -7px rgba(0,0,0,.2),0 24px 38px 3px rgba(0,0,0,.14),0 9px 46px 8px rgba(0,0,0,.12);border-radius:2px;padding:1rem 1.5rem}.ss16--dialog-header{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.ss16--dialog-description{color:var(--text-secondary-on-background);margin-bottom:.5rem}.ss16--index-searching-curtain{position:fixed;top:0;left:0;width:100%;height:100vh;pointer-events:none;background-image:linear-gradient(to bottom,rgba(33,33,33,.75),rgba(33,33,33,0))}:root.ss16--index-searching .board:empty::after{content:'No threads found; try searching again.';color:var(--text-secondary-on-background);background-color:var(--background-primary);max-width:75%;margin:auto;display:flex;align-items:center;justify-content:center;height:40vh}.ss16--board-drawer-background{position:fixed;overflow:hidden;contain:strict;width:100%;height:100%;top:0;left:0;pointer-events:none;z-index:99}.ss16--board-drawer-background::before{content:'';display:block;will-change:opacity;background-color:rgba(33,33,33,.6);position:absolute;top:0;left:0;height:100%;width:100%;opacity:0;transition:opacity .25s}.drawer-open{pointer-events:auto}.drawer-open::before{opacity:1}.ss16--board-drawer{width:320px;background:var(--background-primary);left:0;right:initial;height:100%;display:flex;position:absolute;flex-direction:column;will-change:transform;transform:translateX(-100%);transition:transform .25s;overflow-y:scroll}.drawer-open .ss16--board-drawer{transform:translateX(0)}.board-list-entry{display:block;color:var(--text-primary-on-background);text-decoration:none;height:3rem;line-height:3;padding-left:1rem;transition:background-color .25s}.board-list-entry:hover{background-color:rgba(33,33,33,.12)}.board-list-entry.board--ws{color:#000;background-color:#d6daf0}.board-list-entry.board--nws{color:maroon;background-color:#f0e0d6}#board-list a.ss16--board-drawer-toggle{order:-1;opacity:1}:root.ss16--yotsuba.ws{--text-primary-on-primary:#000;--text-icon-on-primary:#000;--background-primary:#d6daf0;--background-secondary:#c7cbe4;--background-outline:rgba(161,166,202,.5);--primary-500:#c7cbe4;--primary-700:#a1a6ca}:root.ss16--yotsuba.ws body{color:#000;background-color:#eef2ff!important}:root.ss16--yotsuba.ws .abbr,:root.ss16--yotsuba.ws .dateTime,:root.ss16--yotsuba.ws .page-num{color:#000}:root.ss16--yotsuba.ws a{color:#34345c}:root.ss16--yotsuba.ws .post{background-color:#d6daf0!important}:root.ss16--yotsuba.ws .boardTitle{color:#af0a0f}:root.ss16--yotsuba.ws .subject{color:#0f0c5d}:root.ss16--yotsuba.ws .name{color:#117743}:root.ss16--yotsuba.ws .quote{color:#789922}:root.ss16--yotsuba.ws .quotelink,:root.ss16--yotsuba.ws .shortcut:hover,:root.ss16--yotsuba.ws a:hover{color:#d00}:root.ss16--yotsuba.nws .field:not(#qr-filename-container),:root.ss16--yotsuba.nws select,:root.ss16--yotsuba.ws .field:not(#qr-filename-container),:root.ss16--yotsuba.ws select{background-color:#fff!important;border-color:#ccc!important}:root.ss16--yotsuba.ws .field:focus,:root.ss16--yotsuba.ws select:focus{border-color:#98e!important}:root.ss16--yotsuba.ws.bottom-backlinks .container{background-color:#c7cbe4;border-color:#b7c5d9}:root.ss16--yotsuba.nws{--text-primary-on-primary:maroon;--text-icon-on-primary:maroon;--background-primary:#f0e0d6;--background-secondary:#ddcabe;--background-outline:rgba(198,178,165,.5);--primary-500:#ddcabe;--primary-700:#c6b0a2}:root.ss16--yotsuba.nws body{color:maroon;background-color:#ffe!important}:root.ss16--yotsuba.nws .abbr,:root.ss16--yotsuba.nws .dateTime,:root.ss16--yotsuba.nws .page-num{color:maroon}:root.ss16--yotsuba.nws a{color:#00e}:root.ss16--yotsuba.nws .quotelink{color:navy}:root.ss16--yotsuba.nws .post{background-color:#f0e0d6!important}:root.ss16--yotsuba.nws .boardTitle{color:#af0a0f}:root.ss16--yotsuba.nws .subject{color:#cc1105}:root.ss16--yotsuba.nws .name{color:#117743}:root.ss16--yotsuba.nws .quote{color:#789922}:root.ss16--yotsuba.nws .shortcut:hover,:root.ss16--yotsuba.nws a:hover{color:red}:root.ss16--yotsuba.nws .field:not(#qr-filename-container):focus,:root.ss16--yotsuba.nws select:focus{border-color:#ea8!important}:root.ss16--yotsuba.nws.bottom-backlinks .container{background-color:#ddcabe;border-color:#d9bfb7}.n-atb{border-radius:2px;padding:1px 4px;color:#353839}.atsb2018 table{width:100%;max-width:70rem;margin:1rem auto 2rem;border-radius:2px;background-color:var(--background-primary);box-shadow:0 2px 10px 0 rgba(33,33,33,.1)}.atsb2018 td,.atsb2018 th{padding:.5rem .75rem;border-bottom:1px solid var(--background-hint)}.atsb2018 tr:not(:first-child) td:first-child,.atsb2018 tr:not(:first-child) td:last-child{font-family:var(--font-family-monospace);font-size:1.125rem;text-align:center}.atsb2018 .atsgc{width:75%}.atsb2018 .atgg{height:2rem}.n-atb-0{background-color:#f56fa1}.n-atb-1{background-color:#7b3f00;color:#f2f3f4}.n-atb-2{background-color:#fffdd0}.n-atb-3{background-color:#e4d00a}.n-atb-4{background-color:#50c878}.n-atb-0::after{content:'Team Peep'}.n-atb-1::after{content:'Team Chocolate'}.n-atb-2::after{content:'Team Creme'}.n-atb-3::after{content:'Team Peanut Butter'}.n-atb-4::after{content:'Team Mini'}} 12 | -------------------------------------------------------------------------------- /sidedish.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name ss21 sidedish 3 | // @version 2.5.3 4 | // @description A companion userscript for the ss21 userstyle. 5 | // @author saxamaphone69 6 | // @namespace https://github.com/saxamaphone69/ss21 7 | // @match *://boards.4chan.org/* 8 | // @match *://find.4chan.org/* 9 | // @match *://www.4chan.org/* 10 | // @connect 4chan.org 11 | // @connect a.4cdn.org 12 | // @connect 4cdn.org 13 | // @grant GM.xmlHttpRequest 14 | // @run-at document-start 15 | // @icon data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 96 960 960'%3E%3Cpath d='M70 622q0-15 11-29.5t29-23.5q22-9 44-22.5t54-13.5q48 0 72.5 28.5T343 590q37 0 64-28.5t74-28.5q47 0 72.5 28.5T618 590q36 0 62-28.5t73-28.5q33 0 54.5 14t43.5 23q18 9 29 23t11 29q0 13-9 21.5t-21 6.5q-36-8-56.5-26T753 606q-37 0-63.5 28.5T617 663q-48 0-74-28.5T481 606q-36 0-63.5 28.5T342 663q-47 0-72-28.5T208 606q-31 0-51.5 18T101 650q-13 2-22-6.5T70 622Zm0 185q0-14 10.5-28.5T110 756q22-9 44-23t54-14q47 0 72 28.5t63 28.5q37 0 64-28.5t74-28.5q47 0 72.5 28.5T617 776q36 0 62.5-28.5T753 719q32 0 54 14t45 23q18 8 28.5 22t10.5 29q0 14-9 22t-21 6q-36-8-56.5-25.5T753 792q-37 0-63.5 28.5T617 849q-48 0-74-28.5T481 792q-36 0-63.5 28.5T343 849q-47 0-73-28.5T208 792q-31 0-51.5 17.5T100 835q-12 2-21-6t-9-22Zm0-371q0-15 11-29.5t29-23.5q22-9 44-22.5t54-13.5q48 0 72.5 28.5T343 404q37 0 64-28.5t74-28.5q47 0 72.5 28.5T618 404q36 0 62-28.5t73-28.5q33 0 54.5 14t43.5 23q18 9 29 23t11 29q0 13-9 21.5t-21 6.5q-36-8-56.5-26T753 420q-37 0-63.5 28.5T617 477q-48 0-74-28.5T481 420q-36 0-64 28.5T342 477q-47 0-72-28.5T208 420q-31 0-51.5 18T101 464q-13 2-22-6.5T70 436Z'/%3E%3C/svg%3E 16 | // @noframes 17 | // @updateURL https://github.com/saxamaphone69/ss21/raw/main/sidedish.user.js 18 | // @downloadURL https://github.com/saxamaphone69/ss21/raw/main/sidedish.user.js 19 | // ==/UserScript== 20 | (async () => { 21 | "use strict"; 22 | //console.group("Initialising ss21 sidedish..."); 23 | /*! @ryanmorr/ready v1.4.0 | https://github.com/ryanmorr/ready */ 24 | function _typeof(a){return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(a){return typeof a}:function(a){return a&&"function"==typeof Symbol&&a.constructor===Symbol&&a!==Symbol.prototype?"symbol":typeof a},_typeof(a)}(function(a,b){"object"===("undefined"==typeof exports?"undefined":_typeof(exports))&&"undefined"!=typeof module?module.exports=b():"function"==typeof define&&define.amd?define(b):(a=a||self,a.ready=b())})(this,function(){'use strict';function a(a){for(var b,c=a.selector,d=a.callback,e=g.querySelectorAll(c),f=0,j=e.length;f { 30 | switch (location.pathname.split("/")[2]) { 31 | case "thread": 32 | return "thread"; 33 | case "catalog": 34 | return "catalog"; 35 | case "archive": 36 | return "archive"; 37 | default: 38 | return "index"; 39 | } 40 | })(); 41 | 42 | function $(sel, root) { 43 | return (root || d).querySelector(sel); 44 | } 45 | 46 | function $$(sel, root) { 47 | return [...(root || d).querySelectorAll(sel)]; 48 | } 49 | 50 | // add `.site-loading` to `html` so css can hide the page loading 51 | doc.classList.add("site-loading"); 52 | 53 | if (location.pathname.split("/")[1] === 'search') { 54 | doc.classList.remove("site-loading"); 55 | doc.classList.add("is-search"); 56 | $('link[title]', d.head).disabled = true; 57 | } 58 | 59 | function on(sel, events, cb) { 60 | sel = Array.isArray(sel) ? sel : [sel]; 61 | let event = events.split(/\s+/); 62 | sel.forEach((sel) => { 63 | event.forEach((ev) => { 64 | sel.addEventListener(ev, cb, { 65 | passive: true, 66 | }); 67 | }); 68 | }); 69 | return this; 70 | } 71 | 72 | function make(obj) { 73 | let key, 74 | el = d.createElement(obj.el); 75 | if (obj.cl4ss) { 76 | el.className = obj.cl4ss; 77 | } 78 | if (obj.html) { 79 | el.innerHTML = obj.html; 80 | } 81 | if (obj.attr) { 82 | for (key in obj.attr) { 83 | if (obj.attr.hasOwnProperty(key)) { 84 | el.setAttribute(key, obj.attr[key]); 85 | } 86 | } 87 | } 88 | if (obj.appendTo) { 89 | let parent = obj.appendTo; 90 | if (typeof parent === "string") { 91 | $(parent).appendChild(el); 92 | } else { 93 | parent.appendChild(el); 94 | } 95 | } 96 | if (obj.prepend) { 97 | let parent = obj.prepend; 98 | if (typeof parent === "string") { 99 | $(parent).prepend(el); 100 | } else { 101 | parent.prepend(el); 102 | } 103 | } 104 | return el; 105 | } 106 | 107 | function removeStyle(sel) { 108 | if (sel) { 109 | console.log( 110 | "%css21 sidedish is removing this stylesheet: ", 111 | "color:green;", 112 | sel 113 | ); 114 | sel.remove(); 115 | return true; 116 | } else { 117 | console.log("%css21 sidedish was unable to find: ", "color:red;", sel); 118 | return false; 119 | } 120 | } 121 | 122 | function sendNotification(type, content) { 123 | d.dispatchEvent( 124 | new CustomEvent("CreateNotification", { 125 | detail: { 126 | type: type, // success, info, warning, error 127 | content: content, 128 | lifetime: 0, 129 | }, 130 | }) 131 | ); 132 | } 133 | 134 | function removeStyles() { 135 | removeStyle($("link[rel='stylesheet']", d.head)); 136 | removeStyle($("style[type]", d.head)); // this removes the inline mobile css 137 | removeStyle($("#fourchanx-css", d.head)); // this removes the css required by 4chan x 138 | removeStyle($("#custom-css", d.head)); // this removes extra, custom css by 4chan x 139 | //removeStyle($("#sound-player-css", d.head)); // sounds player 140 | } 141 | 142 | function replace4chanFooterList() { 143 | // Okay, so this used to work fine. Then Cloudflare has added some CDN protection thingy to 4chan.org, which makes any attempts to read the HTML not work. 144 | // I had this as a request so that if any boards were added, it would auto update. I'll stick to hard coding it instead. 145 | let footer = $("#boardNavDesktopFoot"); 146 | let boardList = `
147 |

Japanese Culture

148 | 160 |

Video Games

161 | 171 |
172 |
173 |

Interests

174 | 191 |
192 |
193 |

Creative

194 | 210 |
211 |
212 |

Other

213 | 225 |

Misc.(NSFW)

226 | 234 |
235 |
236 |

Adult(NSFW)

237 | 252 |
`; 253 | if (footer) { 254 | footer.innerHTML = `
${boardList}
`; 255 | footer.classList.add('ss21--footer-enhanced'); 256 | if ($(`#boardNavDesktopFoot a[href$="/${currentBoard}/`)) { 257 | $(`#boardNavDesktopFoot a[href$="/${currentBoard}/`).classList.add('current'); 258 | } 259 | } 260 | } 261 | 262 | function init() { 263 | on(d, "IndexBuild", doc.classList.remove("site-loading")); 264 | 265 | const isChanX = doc && doc.classList.contains('fourchan-x'); 266 | 267 | if (!isChanX) { 268 | doc.classList.remove("site-loading"); 269 | doc.classList.add("is-ext"); 270 | } 271 | 272 | on(d, "OpenSettings", function () { 273 | const settingDescriptions = $$(".description"); 274 | for (let settingDescription of settingDescriptions) { 275 | const content = settingDescription.textContent.slice(2); 276 | settingDescription.textContent = content; 277 | } 278 | }); 279 | 280 | removeStyles(); 281 | 282 | // this should return the `#header-bar` element 283 | const headerBar = $("#header-bar") || $('#boardNavDesktop'); 284 | // set the header height as its own variable for reference in css 285 | const updateHeight = () => 286 | doc.style.setProperty('--headerBar-height', `${headerBar.offsetHeight}px`); 287 | new ResizeObserver(updateHeight).observe(headerBar); 288 | updateHeight(); 289 | 290 | const scrollProgress = make({ 291 | //el: "progress", 292 | el: "div", 293 | attr: { 294 | id: "scroll-progress"//, 295 | //value: 0, 296 | //max: 100, 297 | }, 298 | appendTo: headerBar, 299 | }); 300 | /* 301 | const hero = $(".boardBanner"), 302 | heroHeight = 480, 303 | boardTitle = $(".boardTitle"), 304 | mVal = 300; 305 | 306 | //boardTitle.style.setProperty("--length", boardTitle.innerText.length); 307 | 308 | let ticking = false; 309 | 310 | function rAF(args) { 311 | if (!ticking) { 312 | window.requestAnimationFrame(function () { 313 | ticking = false; 314 | }); 315 | } 316 | ticking = true; 317 | }*/ 318 | /* 319 | //https://github.com/adactio/FitText.js/blob/master/fittext.js 320 | //https://github.com/rikschennink/fitty/blob/gh-pages/src/fitty.js 321 | function fitText(el) { 322 | el.style.fontSize = Math.max(Math.min(el.clientWidth / 10, parseFloat(1/0)), parseFloat(-1/0)) + 'px'; 323 | } 324 | 325 | fitText(hero); 326 | */ 327 | // https://codepen.io/shshaw/pen/LYVBVve 328 | /* 329 | [...document.querySelectorAll("[data-fit-text]")].forEach(el => { 330 | // We just need the length of the string as a CSS variable... 331 | el.style.setProperty("--length", el.innerText.length); 332 | }); 333 | */ 334 | /* 335 | [data-fit-text] { 336 | // Sized via the viewport, but the --width variable could be set by JS based on the element or parent's width. 337 | --width: 100vw; 338 | 339 | // Adjust scale depending on your exact font. 340 | --scale: 0.9; 341 | 342 | font-size: calc(var(--width) / (var(--length, 1) * 0.5) * var(--scale, 1)); 343 | 344 | font-family: "Poppins", sans-serif; 345 | font-weight: 600; 346 | line-height: 1; 347 | margin: 1rem 0; 348 | } 349 | */ 350 | /* 351 | function fancyShadow(el) { 352 | let oVal = window.scrollY, 353 | nVal = (oVal / 2.5) * 0.1; 354 | if (oVal >= heroHeight) { 355 | headerBar.classList.add("scrolled"); 356 | el.style.textShadow = "0 0 var(--primary-500)"; 357 | } else { 358 | headerBar.classList.remove("scrolled"); 359 | el.style.textShadow = 360 | 16 + -nVal + "px " + (16 + -nVal) + "px var(--primary-500)"; 361 | } 362 | } 363 | 364 | function parallaxHero(el) { 365 | let oVal, cVal; 366 | oVal = Math.round(window.scrollY / 3); 367 | if (oVal < mVal) { 368 | cVal = oVal; 369 | } else { 370 | cVal = mVal; 371 | } 372 | el.style.transform = "translate3d(0, " + cVal + "px, 0)"; 373 | } 374 | 375 | function progressScroll(el) { 376 | let dHeight = d.body.clientHeight, 377 | wHeight = window.innerHeight, 378 | scrollPercent = (window.scrollY / (dHeight - wHeight)) * 100; 379 | el.value = scrollPercent.toFixed(2); 380 | } 381 | 382 | on(window, "scroll", function (e) { 383 | rAF(parallaxHero(hero)); 384 | rAF(fancyShadow(boardTitle)); 385 | rAF(progressScroll(scrollProgress)); 386 | }); 387 | */ 388 | function countBacks() { 389 | //console.log("Counting backlinks"); 390 | let posts = $$(".post"); 391 | for (let post of posts) { 392 | let backlinks = $$(".backlink", post); 393 | post.setAttribute("data-backlinks-length", backlinks.length); 394 | if (backlinks.length > 8) { 395 | post.parentNode.classList.add("post--hot"); 396 | } 397 | } 398 | } 399 | 400 | function convertSummaries() { 401 | //console.log("Converting summaries"); 402 | let summaries = $$(".summary:not(.summary-bottom, .preview-summary)"); 403 | for (let summary of summaries) { 404 | summary.classList.add('summary--converted'); 405 | let oldText, newText; 406 | oldText = summary.innerHTML; 407 | newText = oldText.replace(/(\d+(?=\ ))/g, "$1"); 408 | summary.innerHTML = newText; 409 | //summary.innerHTML = `open_in_new` + newText + ``; 410 | } 411 | } 412 | 413 | function markExternalLinks() { 414 | document.querySelectorAll('.postMessage .linkify').forEach(link => { 415 | // If a string is passed, convert it into an anchor element 416 | if (typeof link === 'string') { 417 | const temp = document.createElement('a'); 418 | temp.href = link; 419 | link = temp; 420 | } 421 | 422 | let url; 423 | try { 424 | url = new URL(link.href); 425 | } catch (err) { 426 | // Skip this link if it's not a valid URL 427 | return link; 428 | } 429 | 430 | // Skip internal links 431 | if (url.origin === window.location.origin) return link; 432 | 433 | // Clear content and mark the link as parsed 434 | link.textContent = ''; 435 | link.classList.add('link-parsed'); 436 | 437 | // Define parts to wrap 438 | const parts = [ 439 | { name: 'schema', value: url.protocol + '//' }, 440 | { name: 'host', value: url.hostname }, 441 | { name: 'path', value: url.pathname }, 442 | { name: 'query', value: url.search }, 443 | { name: 'hash', value: url.hash } 444 | ]; 445 | 446 | // Create and append spans 447 | for (const { name, value } of parts) { 448 | if (value) { 449 | const span = document.createElement('span'); 450 | span.classList.add(`link-parsed--${name}`); 451 | span.textContent = value; 452 | link.appendChild(span); 453 | } 454 | } 455 | 456 | return link; 457 | }); 458 | } 459 | 460 | function checkers() { 461 | let obs = $$('.thread'); 462 | [...obs].forEach((ob) => { 463 | const observer = new MutationObserver(function(mutations) { 464 | mutations.forEach(function(mutation) { 465 | if (mutation.type == 'childList') { 466 | convertSummaries() 467 | } 468 | }); 469 | }); 470 | observer.observe(ob, {childList: true}); 471 | })/* 472 | const observer = new MutationObserver(function(mutations) { 473 | mutations.forEach(function(mutation) { 474 | console.log(mutation.removedNodes); 475 | }); 476 | }); 477 | observer.observe(ob, {childList: true}); 478 | }*/ 479 | } 480 | if (config === "index") { 481 | on(d, "IndexRefresh", checkers); 482 | } 483 | /* 484 | function watchElForDeletion(elToWatch, callback, parent = document.querySelector('body')){ 485 | const observer = new MutationObserver(function (mutations) { 486 | 487 | // loop through all mutations 488 | mutations.forEach(function (mutation) { 489 | 490 | // check for changes to the child list 491 | if (mutation.type === 'childList') { 492 | 493 | // check if anything was removed and if the specific element we were looking for was removed 494 | if (mutation.removedNodes.length > 0 && mutation.removedNodes[0] === elToWatch) { 495 | callback(); 496 | } 497 | } 498 | }); 499 | }); 500 | 501 | // start observing the parent - defaults to document body 502 | observer.observe(parent, { childList: true }); 503 | }; 504 | 505 | const target = $(".board"); 506 | const config = { 507 | childList: true, 508 | }; 509 | 510 | function subscriber(mutations) { 511 | convertSummaries(); 512 | swapInfo(); 513 | disabledPrevAndNext(); 514 | } 515 | const observer = new MutationObserver(subscriber); 516 | observer.observe(target, config); 517 | */ 518 | /* 519 | function watchThreadForSummary() { 520 | let threads = $$('.thread'); 521 | for (let thread of threads) { 522 | const observer = new MutationObserver(function(mutations) { 523 | mutations.forEach(function(mutation) { 524 | if (mutation.type === 'childList') { 525 | console.log(mutation.target); 526 | if (mutation.target.classList.contains('summary')) { 527 | let summary = mutation.target; 528 | console.log(summary); 529 | //let oldText, newText; 530 | //oldText = summary.innerHTML; 531 | //newText = oldText.replace(/(\d+(?=\ ))/g, "$1"); 532 | //summary.innerHTML = `open_in_new` + newText + ``; 533 | //summary.innerHTML = `open_in_new` + newText + ``; 534 | } 535 | } 536 | }); 537 | }); 538 | observer.observe(thread, {childList:true}); 539 | } 540 | } 541 | */ 542 | /* 543 | function getSumms() { 544 | console.log('RUNNING GETSUMMS'); 545 | ready('.summary:not(.summary-bottom)', (element) => { 546 | let summary = element; 547 | let oldText, newText; 548 | 549 | oldText = summary.innerHTML; 550 | newText = oldText.replace(/(\d+(?=\ ))/g, "$1"); 551 | console.log('old: ' + oldText + ', new: ' + newText); 552 | summary.innerHTML = `open_in_new` + newText + ``; 553 | }); 554 | convertSummaries(); 555 | } 556 | */ 557 | //getSumms(); 558 | 559 | function swapInfo() { 560 | //console.log("Switching OP's post info"); 561 | let ops = $$(".op"); 562 | for (let op of ops) { 563 | let opPostInfo = $(".postInfo", op); 564 | op.prepend(opPostInfo); 565 | op.classList.add("post--file-swapped"); 566 | } 567 | } 568 | 569 | function stripPageBrackets() { 570 | //console.log("Switching OP's post info"); 571 | let pagenums = $$(".page-num:not(.page-num--converted)"); 572 | for (let pagenum of pagenums) { 573 | let oldText, newText; 574 | oldText = pagenum.innerText; 575 | newText = oldText.match(/\d+/)[0]; 576 | pagenum.innerHTML = `${newText}`; 577 | pagenum.classList.add('page-num--converted'); 578 | } 579 | } 580 | 581 | // if a thumbnail has a tall aspect ratio, allow for greater styling control 582 | function checkHeights() { 583 | let thumbs = $$(".fileThumb"); 584 | for (let thumb of thumbs) { 585 | let thumbSize = $("img", thumb); 586 | let thumbHeight = thumbSize.style.height; 587 | let thumbWidth = thumbSize.style.width; 588 | if (thumbHeight.slice(0, -2) > thumbWidth.slice(0, -2)) { 589 | // adds it to the `.thread` container 590 | thumb.parentNode.parentNode.parentNode.parentNode.classList.add("file--tall"); 591 | } 592 | } 593 | } 594 | 595 | function checkAspect() { 596 | // https://stackoverflow.com/a/61544600 597 | let ERROR_ALLOWED = 0.05 598 | let STANDARD_ASPECT_RATIOS = [ 599 | [1, '1'], 600 | [4/3, '43'], 601 | [5/4, '54'], 602 | [3/2, '32'], 603 | [16/10, '1610'], 604 | [16/9, '169'], 605 | [21/9, '219'], 606 | [32/9, '329'], 607 | ] 608 | let RATIOS = STANDARD_ASPECT_RATIOS.map(function(tpl){return tpl[0]}).sort() 609 | let LOOKUP = Object() 610 | for (let i=0; i < STANDARD_ASPECT_RATIOS.length; i++){ 611 | LOOKUP[STANDARD_ASPECT_RATIOS[i][0]] = STANDARD_ASPECT_RATIOS[i][1] 612 | } 613 | 614 | /* 615 | Find the closest value in a sorted array 616 | */ 617 | function findClosest(arrSorted, value){ 618 | var closest = arrSorted[0] 619 | var closestDiff = Math.abs(arrSorted[0] - value) 620 | for (let i=1; i { 742 | const item = document.getElementById(id); 743 | if (item) { 744 | // Save original position 745 | originalPositions.set(id, { parent: item.parentElement, nextSibling: item.nextElementSibling }); 746 | 747 | // Clone and append to placeholder 748 | const clone = item.cloneNode(true); 749 | clone.id = `${id}-clone`; // Ensure unique ID for the clone 750 | shortcutPlaceholder.appendChild(clone); 751 | 752 | // Initially hide the clone 753 | clone.hidden = true; 754 | } 755 | }); 756 | 757 | const moveItemsToMenu = () => { 758 | const menu = document.querySelector('#shortcut-menu #menu'); 759 | if (menu) { 760 | itemsToMove.forEach(id => { 761 | const clone = document.getElementById(`${id}-clone`); 762 | if (clone && clone.parentElement !== menu) { 763 | menu.appendChild(clone); 764 | clone.hidden = false; // Show the clone when added to the menu 765 | } 766 | }); 767 | } 768 | }; 769 | 770 | const handleResize = (width) => { 771 | if (width < 600) { 772 | const menu = document.querySelector('#shortcut-menu #menu'); 773 | if (!menu) { 774 | // Hide originals and show clones in the placeholder 775 | itemsToMove.forEach(id => { 776 | const original = document.getElementById(id); 777 | const clone = document.getElementById(`${id}-clone`); 778 | if (original) original.hidden = true; 779 | if (clone) clone.hidden = false; 780 | }); 781 | } 782 | 783 | // Observe for menu creation and move clones to it 784 | const menuObserver = new MutationObserver((mutations) => { 785 | mutations.forEach(mutation => { 786 | if (mutation.type === 'childList') { 787 | const menu = document.querySelector('#shortcut-menu #menu'); 788 | if (menu) { 789 | moveItemsToMenu(); 790 | menuObserver.disconnect(); // Stop observing once #menu is created 791 | } 792 | } 793 | }); 794 | }); 795 | 796 | menuObserver.observe(shortcutMenu, { childList: true, subtree: true }); 797 | } else { 798 | // Restore originals and hide clones when width >= 600px 799 | itemsToMove.forEach(id => { 800 | const original = document.getElementById(id); 801 | const clone = document.getElementById(`${id}-clone`); 802 | if (original) original.hidden = false; 803 | if (clone) clone.hidden = true; 804 | 805 | // Restore original position if it's not already in place 806 | const originalPosition = originalPositions.get(id); 807 | if (originalPosition && original.parentElement !== originalPosition.parent) { 808 | const { parent, nextSibling } = originalPosition; 809 | parent.insertBefore(original, nextSibling || null); 810 | } 811 | }); 812 | } 813 | }; 814 | 815 | const resizeObserver = new ResizeObserver(entries => { 816 | for (let entry of entries) { 817 | if (entry.target === document.body) { 818 | const width = entry.contentRect.width; 819 | handleResize(width); 820 | } 821 | } 822 | }); 823 | 824 | resizeObserver.observe(document.body); 825 | } 826 | 827 | moveShortcuts(); 828 | */ 829 | // two from https://github.com/duanemoody 830 | // javascript:let p=$$("a.download-button"), i=0, v=setInterval(() => {p[i++].click(); (i>p.length) && clearInterval(v);}, 1000); 831 | // javascript:var pics=document.querySelectorAll("a.download-button"), counter=0, interval=setInterval(function() {pics[counter].click(); counter++; if (counter > pics.length) {clearInterval(interval);}}, 1000); 832 | // https://stackoverflow.com/questions/30088897/trying-to-download-all-of-the-images-on-the-website-using-javascript 833 | // https://gist.github.com/sfrdmn/8834747 834 | // https://gist.github.com/lucidBrot/432d2c6184a188a060e58dbb36bd2084 835 | function downloadMedia() { 836 | ready('#shortcuts', (element) => { 837 | let _this = element; 838 | make({ 839 | el: 'a', 840 | cl4ss: 'material-icons shortcut ss21--download-all', 841 | attr: { 842 | title: 'Download all media in thread' 843 | }, 844 | prepend: _this, 845 | html: `download_for_offline` 846 | }); 847 | }); 848 | let imgToggle = $('.ss21--download-all'); 849 | imgToggle.addEventListener('click', function() { 850 | let allMedia = [].slice.call($$('.download-button')); 851 | let i = 0; 852 | try { 853 | allMedia.forEach(function(media) { 854 | downloadThem(media, i++); 855 | }) 856 | } catch(e) { 857 | console.log('Something went wrong...', e); 858 | } 859 | function downloadThem(media) { 860 | setTimeout(() => { 861 | media.click(); 862 | }, i * 500) 863 | } 864 | }); 865 | } 866 | if (config === "thread") { 867 | downloadMedia(); 868 | } 869 | 870 | function boardDrawer() { 871 | let boardDrawer = make({ 872 | el: "aside", 873 | cl4ss: "ss21--board-drawer-background", 874 | appendTo: "body", 875 | html: ``, 876 | }); 877 | ready("#board-list", (element) => { 878 | let _this = element; 879 | make({ 880 | el: "a", 881 | cl4ss: "material-icons ss21--board-drawer-toggle", 882 | prepend: headerBar, 883 | attr: { 884 | title: "Open board list drawer", 885 | }, 886 | html: `menu`, 887 | }); 888 | }); 889 | let boardNavToggle = $(".ss21--board-drawer-toggle"); 890 | let url = "https://a.4cdn.org/boards.json"; 891 | 892 | function createNode(element) { 893 | return d.createElement(element); 894 | } 895 | 896 | function append(parent, el) { 897 | return parent.appendChild(el); 898 | } 899 | 900 | boardDrawer.addEventListener("click", function (e) { 901 | if (e.target === boardDrawer) { 902 | boardDrawer.classList.remove("drawer-open"); 903 | } 904 | }); 905 | 906 | on(boardNavToggle, "click", function () { 907 | boardDrawer.classList.add("drawer-open"); 908 | fetch(url) 909 | .then((resp) => resp.json()) 910 | .then(function (data) { 911 | let boards = data.boards; 912 | return boards.map(function (board) { 913 | let anchor = createNode("a"); 914 | anchor.classList.add("board-list-entry"); 915 | anchor.textContent = `/${board.board}/ - ${board.title}`; 916 | if (board.ws_board === 0) { 917 | anchor.classList.add("board--nws"); 918 | anchor.href = `https://boards.4chan.org/${board.board}/`; 919 | } else { 920 | anchor.classList.add("board--ws"); 921 | anchor.href = `https://boards.4chan.org/${board.board}/`; 922 | } 923 | append($(".ss21--board-drawer"), anchor); 924 | }); 925 | }); 926 | }); 927 | } 928 | 929 | //boardDrawer(); 930 | /* 931 | function getBoardInfo() { 932 | let cbBoard, cbTitle, cbMetad; 933 | fetch("https://a.4cdn.org/boards.json") 934 | .then(resp => resp.json()) 935 | .then(data => { 936 | let foundBoard = data.boards.find(board => board.board === currentBoard); 937 | cbBoard = foundBoard.board; 938 | cbTitle = foundBoard.title; 939 | cbMetad = foundBoard.meta_description.replace(/"/g, '"').replace(/&/g, '&'); 940 | }); 941 | } 942 | 943 | getBoardInfo(); 944 | */ 945 | function changeFileName(observer) { 946 | // Temporarily disconnect the observer to avoid a loop 947 | if (observer) observer.disconnect(); 948 | 949 | $('#qr-file-button').value = 'upload'; 950 | $('#file-n-submit input[type="submit"]').value = 'send'; 951 | 952 | // Reconnect the observer after the change with inline config 953 | if (observer) { 954 | observer.observe($('#qr'), { 955 | attributes: true,// Watch for attribute changes 956 | attributeFilter: ['value'], // Only watch the 'value' attribute 957 | subtree: true,// Monitor changes within child elements of #qr 958 | }); 959 | } 960 | } 961 | /* 962 | on(d, 'QRDialogCreation', function() { 963 | const captchaContainer = document.querySelector(".captcha-root"); 964 | 965 | let tBgObserver = null; 966 | 967 | const observeTBgStyle = (tBg) => { 968 | // Disconnect any existing observer to avoid duplicate listeners 969 | if (tBgObserver) { 970 | tBgObserver.disconnect(); 971 | tBgObserver = null; 972 | } 973 | 974 | // If tBg exists, observe its style attribute 975 | if (tBg) { 976 | tBgObserver = new MutationObserver(() => { 977 | const bgImage = window.getComputedStyle(tBg).backgroundImage; 978 | 979 | if (bgImage && bgImage !== "none") { 980 | captchaContainer.classList.add("captcha-loaded"); 981 | } else { 982 | captchaContainer.classList.remove("captcha-loaded"); 983 | } 984 | }); 985 | 986 | tBgObserver.observe(tBg, { 987 | attributes: true, 988 | attributeFilter: ["style"], // Only watch the style attribute 989 | }); 990 | 991 | // Run the check immediately to handle cases where the background-image is already set 992 | const bgImage = window.getComputedStyle(tBg).backgroundImage; 993 | if (bgImage && bgImage !== "none") { 994 | captchaContainer.classList.add("captcha-loaded"); 995 | } else { 996 | captchaContainer.classList.remove("captcha-loaded"); 997 | } 998 | } else { 999 | // If tBg is not present, ensure the class is removed 1000 | captchaContainer.classList.remove("captcha-loaded"); 1001 | } 1002 | }; 1003 | 1004 | const observer = new MutationObserver(() => { 1005 | const tBg = captchaContainer.querySelector("#t-bg"); 1006 | observeTBgStyle(tBg); // Attach a new observer to the re-added #t-bg element 1007 | }); 1008 | 1009 | observer.observe(captchaContainer, { 1010 | childList: true, // Monitor direct child changes 1011 | subtree: true, // Monitor all descendant changes 1012 | }); 1013 | 1014 | }); 1015 | */ 1016 | on(d, 'QRDialogCreation', function() { 1017 | const observer = new MutationObserver((mutationsList) => { 1018 | for (const mutation of mutationsList) { 1019 | if (mutation.target.matches('#file-n-submit input[type="submit"]') && mutation.attributeName === 'value') { 1020 | changeFileName(observer); 1021 | } 1022 | } 1023 | }); 1024 | 1025 | // Initial call to set the values 1026 | changeFileName(observer); 1027 | observer.observe($('#qr'), { 1028 | attributes: true,// Watch for attribute changes 1029 | attributeFilter: ['value'], // Only watch the 'value' attribute 1030 | subtree: true,// Monitor changes within child elements of #qr 1031 | }); 1032 | }); 1033 | 1034 | function resizeQuotePreviews() { 1035 | ready("#qp", (element) => { 1036 | let _this = element; 1037 | let winHeight = window.innerHeight; 1038 | let qpHeight = _this.offsetHeight + 32; 1039 | if (qpHeight > winHeight) { 1040 | let scaledHeight = winHeight / qpHeight; 1041 | _this.style.transformOrigin = "top left"; 1042 | _this.style.transform = "scale(" + scaledHeight + ")"; 1043 | } 1044 | }); 1045 | } 1046 | 1047 | resizeQuotePreviews(); 1048 | 1049 | replace4chanFooterList(); 1050 | 1051 | function getSortMode() { 1052 | //console.log('sorting mode'); 1053 | let sorter, boardCon, oldVal; 1054 | sorter = $("#index-sort"); 1055 | boardCon = $(".board"); 1056 | oldVal = sorter.value; 1057 | boardCon.classList.add(oldVal); 1058 | on(sorter, "change", () => { 1059 | boardCon.classList.remove(oldVal); 1060 | boardCon.classList.add(sorter.value); 1061 | }); 1062 | } 1063 | 1064 | if (config === "index") { 1065 | on(d, "IndexRefresh", getSortMode); 1066 | } 1067 | 1068 | function passLinker() { 1069 | let passLink, bottomLinks; 1070 | passLink = $(".pass-link-container"); 1071 | bottomLinks = $("#footer-links"); 1072 | if (passLink) { 1073 | bottomLinks.appendChild(passLink); 1074 | } else { 1075 | return false; 1076 | } 1077 | } 1078 | 1079 | passLinker(); 1080 | 1081 | function masonry() { 1082 | if(!getComputedStyle(document.documentElement).getPropertyValue("--masonry")) { 1083 | return false; 1084 | } 1085 | let grids = [...document.querySelectorAll(':root.catalog-mode .board')]; 1086 | 1087 | if (grids.length && getComputedStyle(grids[0]).gridTemplateRows !== 'masonry' && getComputedStyle(grids[0]).gridAutoRows !== '240px') { 1088 | //console.log('got a grid, going to masonry it', grids); 1089 | grids = grids.map(grid => ({ 1090 | _el: grid, 1091 | gap: parseFloat(getComputedStyle(grid).gridRowGap), 1092 | items: [...grid.childNodes].filter(c => c.nodeType === 1 && +getComputedStyle(c).gridColumnEnd !== -1), 1093 | ncol: 0, 1094 | mod: 0 })); 1095 | 1096 | function layout() { 1097 | //console.log('running layout'); 1098 | grids.forEach(grid => { 1099 | /* get the post relayout number of columns */ 1100 | let ncol = getComputedStyle(grid._el).gridTemplateColumns.split(' ').length; 1101 | 1102 | grid.items.forEach(c => { 1103 | let new_h = c.getBoundingClientRect().height; 1104 | 1105 | if (new_h !== +c.dataset.h) { 1106 | c.dataset.h = new_h; 1107 | grid.mod++; 1108 | } 1109 | }); 1110 | 1111 | /* if the number of columns has changed */ 1112 | if (grid.ncol !== ncol || grid.mod) { 1113 | /* update number of columns */ 1114 | grid.ncol = ncol; 1115 | 1116 | /* revert to initial positioning, no margin */ 1117 | grid.items.forEach(c => c.style.removeProperty('margin-top')); 1118 | 1119 | /* if we have more than one column */ 1120 | if (grid.ncol > 1) { 1121 | grid.items.slice(ncol).forEach((c, i) => { 1122 | let prev_fin = grid.items[i].getBoundingClientRect().bottom /* bottom edge of item above */, 1123 | curr_ini = c.getBoundingClientRect().top /* top edge of current item */; 1124 | c.style.marginTop = `${prev_fin + grid.gap - curr_ini}px`; 1125 | }); 1126 | } 1127 | 1128 | grid.mod = 0; 1129 | } 1130 | }); 1131 | } 1132 | layout(); 1133 | //addEventListener('load', e => { 1134 | // layout(); /* initial load */ 1135 | addEventListener('resize', layout, false); /* on resize */ 1136 | //}, false); 1137 | } 1138 | } 1139 | if (config === "index") { 1140 | const target = $(".board"); 1141 | const config = { 1142 | childList: true, 1143 | }; 1144 | 1145 | function subscriber(mutations) { 1146 | masonry(); 1147 | //if(!getComputedStyle(document.documentElement).getPropertyValue("--masonry")) { 1148 | // masonry(); 1149 | //} 1150 | } 1151 | const observer = new MutationObserver(subscriber); 1152 | observer.observe(target, config); 1153 | } 1154 | //on(d, "IndexBuild", masonry); 1155 | //const isInViewport = (e, {top:t, height:h} = e.getBoundingClientRect()) => t <= innerHeight && t + h >= 0; 1156 | /* 1157 | function switchOPimg() { 1158 | let files = $$('.catalog-post'); 1159 | for (let file of files) { 1160 | let fullLink = $("a.fileThumb", file); 1161 | let thumbLink = $("a.fileThumb img", file); 1162 | let catLink = $(".catalog-thumb", file); 1163 | if (!fullLink) { 1164 | console.log('no file'); 1165 | } else if (fullLink.href.endsWith("m")) { 1166 | let OpVideo = d.createElement("video"); 1167 | OpVideo.classList.add("catalog-thumb-video"); 1168 | OpVideo.poster = thumbLink.src; 1169 | OpVideo.loop = true; 1170 | OpVideo.playsinline = true; 1171 | OpVideo.autoplay = true; 1172 | OpVideo.src = fullLink; 1173 | //OpVideo.play(); 1174 | OpVideo.muted = true; 1175 | catLink.before(OpVideo); 1176 | catLink.remove(); 1177 | // let playPromise = OpVideo.play(); 1178 | // if (playPromise !== undefined) { 1179 | // playPromise.then((_) => { 1180 | // // all good, video started 1181 | // }).catch((error) => { 1182 | // // hey the video didn't play 1183 | // //if (isInViewport(OpVideo) === true) { 1184 | // OpVideo.play(); 1185 | // //} 1186 | // }); 1187 | // } 1188 | } else { 1189 | catLink.src = fullLink.href; 1190 | } 1191 | } 1192 | } 1193 | function playVids() { 1194 | const OPvids = [...document.querySelectorAll('.file--video')]; 1195 | OPvids.forEach(el => { 1196 | el.addEventListener("mouseover", (e) => { 1197 | $('.catalog-thumb-video', el).play(); 1198 | }, false); 1199 | el.addEventListener('mouseleave', (e) => { 1200 | $('.catalog-thumb-video', el).pause(); 1201 | }, false); 1202 | }) 1203 | } 1204 | if (doc.classList.contains('catalog-mode')) { 1205 | on(d, "IndexRefresh", switchOPimg); 1206 | on(d, "IndexRefresh", playVids); 1207 | //on(d, "IndexBuild", switchOPimg); 1208 | //on(d, "IndexRefresh", masonry); 1209 | // window.addEventListener('resize', masonry); 1210 | // masonry(); 1211 | } 1212 | */ 1213 | 1214 | 1215 | // https://www.smashingmagazine.com/2021/07/dynamic-header-intersection-observer/ 1216 | // https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API 1217 | /* 1218 | function intObs() { 1219 | const boxes = [...document.querySelectorAll('.catalog-thumb-video')] 1220 | 1221 | const getOptions = () => { 1222 | return { 1223 | root: null, 1224 | rootMargin: '0px', 1225 | threshold: 1 1226 | } 1227 | } 1228 | 1229 | const setInViewStyles = (target) => { 1230 | target.classList.add('is-inview') 1231 | target.play() 1232 | //$('.catalog-thumb-video', target).play(); 1233 | //dElementToInfoBox(target) 1234 | // console.log('in view') 1235 | } 1236 | 1237 | const setOutOfViewStyles = (target) => { 1238 | target.classList.remove('is-inview') 1239 | target.pause() 1240 | //$('.catalog-thumb-video', target).pause(); 1241 | //moveElementFromInfoBox(target) 1242 | // console.log('out of view') 1243 | } 1244 | 1245 | const onIntersect = (entries) => { 1246 | entries.forEach(entry => { 1247 | const { target, isIntersecting, intersectionRatio } = entry 1248 | //console.log(entry) 1249 | 1250 | if (intersectionRatio >= 1 && isIntersecting) { 1251 | return setInViewStyles(target) 1252 | } 1253 | 1254 | return setOutOfViewStyles(target) 1255 | }) 1256 | } 1257 | 1258 | const reinitObserver = (options) => { 1259 | if (observer) { 1260 | observer.disconnect() 1261 | } 1262 | 1263 | setTimeout(() => { 1264 | observer = new IntersectionObserver(onIntersect, options) 1265 | 1266 | boxes.forEach(el => { 1267 | observer.observe(el) 1268 | }) 1269 | }, 100) 1270 | } 1271 | 1272 | let observer = new IntersectionObserver(onIntersect, getOptions()) 1273 | 1274 | boxes.forEach(el => { 1275 | observer.observe(el) 1276 | }) 1277 | } 1278 | 1279 | on(d, "IndexRefresh", intObs); 1280 | */ 1281 | 1282 | function spinnerText() { 1283 | let footer = $("#absbot"); 1284 | let svgSpin = make({ 1285 | el: "div", 1286 | cl4ss: "ss21--spinner-text", 1287 | html: `
4chan4chan4chan4chan
`, 1288 | appendTo: footer 1289 | }); 1290 | } 1291 | 1292 | spinnerText(); 1293 | 1294 | if (location.pathname.split("/")[1] === "fit") { 1295 | function weightConverter() { 1296 | let weightElement = make({ 1297 | el: "aside", 1298 | cl4ss: "ss21--fit ss21--fit-weight", 1299 | appendTo: "body", 1300 | html: `
1301 | lbs
1302 | 0kg 1303 |
`, 1304 | }); 1305 | } 1306 | 1307 | weightConverter(); 1308 | 1309 | function heightConverter() { 1310 | let heightElement = make({ 1311 | el: "aside", 1312 | cl4ss: "ss21--fit ss21--fit-height", 1313 | appendTo: "body", 1314 | html: `
1315 | 1316 |
1317 | 0cm 1318 |
`, 1319 | }); 1320 | } 1321 | 1322 | heightConverter(); 1323 | } 1324 | 1325 | function searchCurtain() { 1326 | ready("#index-search", (element) => { 1327 | let _this = element; 1328 | make({ 1329 | el: "aside", 1330 | cl4ss: "ss21--index-searching-curtain", 1331 | appendTo: "body", 1332 | }); 1333 | on(_this, "focus", function () { 1334 | doc.classList.add("ss21--index-searching"); 1335 | }); 1336 | on(_this, "blur", function () { 1337 | if (_this.dataset.searching != 1) { 1338 | doc.classList.remove("ss21--index-searching"); 1339 | } 1340 | }); 1341 | }); 1342 | } 1343 | 1344 | if (config === "index") { 1345 | searchCurtain(); 1346 | } 1347 | /* 1348 | function checkBlockedBanner() { 1349 | ready('#bannerCnt > img', (element) => { 1350 | let _this = element; 1351 | setTimeout(function () { 1352 | if (_this.attributes.length === 3) { 1353 | doc.classList.add("ss21--banner-blocked"); 1354 | //_this.parentNode.removeAttribute('title'); 1355 | $('#bannerCnt').removeAttribute('title'); 1356 | } 1357 | }, 1000); 1358 | }); 1359 | } 1360 | 1361 | on(d, "IndexRefresh", checkBlockedBanner); 1362 | */ 1363 | function checkBlockedBanner() { 1364 | function rrready(selector, callback) { 1365 | const observer = new MutationObserver((mutations, observer) => { 1366 | const element = document.querySelector(selector); 1367 | if (element) { 1368 | observer.disconnect(); 1369 | callback(element); 1370 | } 1371 | }); 1372 | 1373 | observer.observe(document.body, { 1374 | childList: true, 1375 | subtree: true 1376 | }); 1377 | 1378 | // Check if the element is already present 1379 | const element = document.querySelector(selector); 1380 | if (element) { 1381 | observer.disconnect(); 1382 | callback(element); 1383 | } 1384 | } 1385 | 1386 | rrready('#bannerCnt > img', (element) => { 1387 | function checkImage() { 1388 | if (element.complete && element.naturalWidth === 0) { 1389 | rrready('img[alt="4chan"]', (element) => { 1390 | if (element.attributes.length === 3) { 1391 | document.documentElement.classList.add("ss21--banner-blocked"); 1392 | element.parentNode.removeAttribute('title'); 1393 | } else { 1394 | setTimeout(checkImage, 1000); 1395 | } 1396 | }); 1397 | } else if (element.complete) { 1398 | document.documentElement.classList.add("ss21--banner-unblocked"); 1399 | } else { 1400 | setTimeout(checkImage, 1000); // Retry after 1 second if not complete 1401 | } 1402 | } 1403 | 1404 | checkImage(); 1405 | }); 1406 | } 1407 | 1408 | // Usage 1409 | checkBlockedBanner(); 1410 | 1411 | function relocateElementBySelector(elementSelector, destSelector, location) { 1412 | // Find the element to relocate 1413 | let element = document.querySelector(elementSelector); 1414 | 1415 | if (!element) { 1416 | console.error('Element not found'); 1417 | return; 1418 | } 1419 | 1420 | // Find the destination element where the element will be moved 1421 | let destElement = document.querySelector(destSelector); 1422 | 1423 | if (!destElement) { 1424 | console.error('Destination element not found'); 1425 | return; 1426 | } 1427 | 1428 | // Remove the element from its current parent 1429 | let elementParent = element.parentElement; 1430 | if (elementParent) { 1431 | elementParent.removeChild(element); 1432 | } 1433 | 1434 | // Append the element to the destination element 1435 | if (location === 'append') { 1436 | destElement.appendChild(element); 1437 | } else if (location === 'prepend') { 1438 | destElement.prepend(element); 1439 | } 1440 | } 1441 | 1442 | // 2025GRID 1443 | //relocateElementBySelector('.pagelist', '#delform', 'append'); 1444 | //relocateElementBySelector('.navLinks.json-index', '#delform', 'prepend'); 1445 | /** 1446 | * Clone a node, remove the original, and prepend the clone to a target element. 1447 | * @param {string} nodeSelector - The CSS selector of the node to clone and remove. 1448 | * @param {string} targetSelector - The CSS selector of the target element to prepend the clone. 1449 | */ 1450 | function cloneAndPrepend(nodeSelector, targetSelector) { 1451 | // Step 1: Select the node you want to clone and remove 1452 | const originalNode = document.querySelector(nodeSelector); 1453 | 1454 | if (!originalNode) { 1455 | console.error('Original node not found'); 1456 | return; 1457 | } 1458 | 1459 | // Step 2: Clone the node 1460 | const clonedNode = originalNode.cloneNode(true); // true means a deep clone 1461 | 1462 | // Step 3: Remove the original node 1463 | originalNode.remove(); 1464 | 1465 | // Step 4: Select the target element where you want to prepend the cloned node 1466 | const targetElement = document.querySelector(targetSelector); 1467 | 1468 | if (!targetElement) { 1469 | console.error('Target element not found'); 1470 | return; 1471 | } 1472 | 1473 | // Step 5: Prepend the cloned node to the target element 1474 | targetElement.prepend(clonedNode); 1475 | } 1476 | 1477 | // 2025GRID 1478 | //cloneAndPrepend('.boardBanner', '#delform'); 1479 | 1480 | function OPAsBanner() { 1481 | ready(".thread > .opContainer > .op > .file .fileThumb", (element) => { 1482 | let _this = element, 1483 | banner = $(".boardBanner"); 1484 | let OpFullFile = _this.href; 1485 | if (OpFullFile.endsWith("m") || OpFullFile.endsWith("4")) { 1486 | //comment start 1487 | /* 1488 | let OpVideo = document.createElement("video"); 1489 | OpVideo.classList.add("ss21--op-banner"); 1490 | OpVideo.loop = true; 1491 | OpVideo.src = OpFullFile; 1492 | let playPromise = OpVideo.play(); 1493 | if (playPromise !== undefined) { 1494 | playPromise.then((_) => {}).catch((error) => {}); 1495 | } 1496 | OpVideo.muted = true; 1497 | banner.appendChild(OpVideo); 1498 | //comment end 1499 | */ 1500 | const OpVideo = document.createElement("video"); 1501 | OpVideo.classList.add("ss21--op-banner"); 1502 | OpVideo.loop = true; 1503 | OpVideo.src = OpFullFile; 1504 | OpVideo.muted = true; 1505 | banner.appendChild(OpVideo); 1506 | 1507 | const playPromise = OpVideo.play(); 1508 | if (playPromise !== undefined) { 1509 | playPromise.then(() => { 1510 | console.log("Video is playing"); 1511 | }).catch((error) => { 1512 | console.error("Error playing video:", error); 1513 | }); 1514 | } 1515 | } else { 1516 | let OpImage = new Image(); 1517 | OpImage.classList.add("ss21--op-banner"); 1518 | OpImage.src = OpFullFile; 1519 | banner.appendChild(OpImage); 1520 | } 1521 | }); 1522 | } 1523 | 1524 | if (config === "thread") { 1525 | OPAsBanner(); 1526 | } 1527 | 1528 | /* 1529 | async function OPAsBanner() { 1530 | // Wait for the ".op .fileThumb" element to be ready 1531 | ready(".op .fileThumb", async (element) => { 1532 | const banner = document.querySelector(".boardBanner"); 1533 | const OpFullFile = element.href; 1534 | 1535 | // If the file is a video 1536 | if (OpFullFile.endsWith("m")) { 1537 | const OpVideo = document.createElement("video"); 1538 | OpVideo.classList.add("ss21--op-banner"); 1539 | OpVideo.loop = true; 1540 | OpVideo.src = OpFullFile; 1541 | OpVideo.muted = true; 1542 | banner.appendChild(OpVideo); 1543 | 1544 | try { 1545 | await OpVideo.play(); // Wait for the video to start playing 1546 | console.log("Video is playing"); 1547 | } catch (error) { 1548 | console.error("Error playing video:", error); 1549 | } 1550 | 1551 | } else { // If the file is an image 1552 | const OpImage = new Image(); 1553 | OpImage.classList.add("ss21--op-banner"); 1554 | OpImage.src = OpFullFile; 1555 | 1556 | // Create a promise that resolves when the image has loaded 1557 | await new Promise((resolve, reject) => { 1558 | OpImage.onload = resolve; 1559 | OpImage.onerror = reject; 1560 | }); 1561 | 1562 | banner.appendChild(OpImage); 1563 | console.log("Image loaded and appended to banner"); 1564 | } 1565 | }); 1566 | } 1567 | 1568 | if (config === "thread") { 1569 | OPAsBanner(); 1570 | } 1571 | */ 1572 | /** 1573 | * Wrap the contents of the specified node inside a new div. 1574 | * @param {string} selector - The CSS selector of the node to wrap. 1575 | */ 1576 | function wrapNodeContents(selector) { 1577 | const node = document.querySelector(selector); 1578 | 1579 | if (!node) { 1580 | console.error('Node not found'); 1581 | return; 1582 | } 1583 | 1584 | // Step 2: Create a new wrapper div with a dynamically generated class name 1585 | const wrapper = document.createElement('div'); 1586 | 1587 | // Remove leading dot or hash if it's a class or id selector 1588 | let baseClass = selector.replace(/^[.#]/, ''); 1589 | wrapper.classList.add(`${baseClass}_inner`); 1590 | 1591 | // Step 3: Move the children of the original node into the new wrapper 1592 | while (node.firstChild) { 1593 | wrapper.appendChild(node.firstChild); 1594 | } 1595 | 1596 | // Step 4: Append the new wrapper to the original node 1597 | node.appendChild(wrapper); 1598 | } 1599 | // 2025GRID 1600 | //wrapNodeContents('.navLinks'); 1601 | //wrapNodeContents('#header-bar'); 1602 | //wrapNodeContents('#thread-watcher'); 1603 | 1604 | // Function to extract the initial number and update the data attribute 1605 | if (config === "index") { 1606 | function updateHiddenCount(element) { 1607 | if (!element) { 1608 | return false; 1609 | } 1610 | const text = element.textContent; 1611 | const match = text.match(/(\d+)/); 1612 | if (match) { 1613 | const count = parseInt(match[1], 10); 1614 | document.querySelector('#hidden-toggle > a').dataset.hiddenCount = count; 1615 | } else { 1616 | document.querySelector('#hidden-toggle > a').dataset.hiddenCount = 0; // Default to 0 if no match 1617 | } 1618 | } 1619 | 1620 | // Initial setup 1621 | const hiddenCountElement = document.getElementById('hidden-count'); 1622 | updateHiddenCount(hiddenCountElement); 1623 | 1624 | // Create a MutationObserver to watch for changes to the element's text content 1625 | const observer = new MutationObserver((mutationsList) => { 1626 | for (const mutation of mutationsList) { 1627 | if (mutation.type === 'childList' || mutation.type === 'characterData') { 1628 | updateHiddenCount(hiddenCountElement); 1629 | } 1630 | } 1631 | }); 1632 | 1633 | document.querySelector('#hidden-toggle > a').onclick = function(e) { 1634 | e.target.classList.toggle('hidden-view-toggle'); 1635 | }; 1636 | document.querySelector('#hidden-toggle > a').title = "Toggle hidden threads"; 1637 | 1638 | // Observe changes to the element's text content 1639 | observer.observe(hiddenCountElement, { childList: true, characterData: true, subtree: true }); 1640 | } 1641 | 1642 | doc.classList.add("sidedish-enabled"); 1643 | 1644 | // Adds a discernable class to `html` when 4chan sounds player is enabled 1645 | ready("#sound-player-css", (element) => { 1646 | doc.classList.add('fcsp-enabled'); 1647 | }); 1648 | 1649 | ready("#StyleChanLink", (element) => { 1650 | doc.classList.add('stylechan-enabled'); 1651 | $("#ch4SS", document.head).remove(); 1652 | $("#fourchanx-bgcolor-css", document.head).remove(); 1653 | }); 1654 | 1655 | ready("#mascot", (element) => { 1656 | // in theory, this means the user has oneechan enabled 1657 | console.log("%cSilly goose, you left OneeChan on.", "color:red;"); 1658 | function backupStyleRemoval(sel) { 1659 | if (sel) { 1660 | console.log("%css21 sidedish is removing this stylesheet: ","color:green;",sel); 1661 | sel.remove(); 1662 | return true; 1663 | } else { 1664 | console.log("%css21 sidedish was unable to find: ","color:red;",sel); 1665 | return false; 1666 | } 1667 | } 1668 | backupStyleRemoval($("#ch4SS")); 1669 | backupStyleRemoval($("#fourchanx-bgcolor-css")); 1670 | if (element) { 1671 | make({ 1672 | el: "aside", 1673 | cl4ss: "fcx-announcement warning", 1674 | html: `ss21 is not compatible with OneeChan; please disable it to continue using ss21 as intended.`, 1675 | appendTo: "body", 1676 | }); 1677 | } 1678 | console.timeLog("Running init() from sidedish"); 1679 | }); 1680 | } 1681 | 1682 | on(d, "4chanXInitFinished", init); 1683 | 1684 | if (window.location.host.split('.')[0] === 'find') { 1685 | doc.classList.remove("site-loading"); 1686 | doc.classList.add("sidedish-enabled"); 1687 | doc.classList.add("is-search"); 1688 | let currentSearch = window.location.href;//window.location.search; 1689 | document.addEventListener('DOMContentLoaded', (event) => { 1690 | function swapInfo() { 1691 | let ops = $$(".op"); 1692 | for (let op of ops) { 1693 | let opPostInfo = $(".postInfo", op); 1694 | op.prepend(opPostInfo); 1695 | op.classList.add("post--file-swapped"); 1696 | } 1697 | } 1698 | swapInfo(); 1699 | function fitText(el) { 1700 | // el.style.fontSize = Math.max(Math.min(el.clientWidth / (compressor*10), parseFloat(settings.maxFontSize)), parseFloat(settings.minFontSize)) + 'px'; 1701 | el.style.fontSize = Math.max(Math.min(el.clientWidth / 10, parseFloat(1/0)), parseFloat(-1/0)) + 'px'; 1702 | el.style.setProperty("--length", el.innerText.length); 1703 | } 1704 | 1705 | fitText($('.boardTitle')); 1706 | make({ 1707 | el: "aside", 1708 | cl4ss: "fcx-announcement warning", 1709 | html: `4chan X doesn't work on the find subdomain, though ss21 tries to style it.`, 1710 | appendTo: "body", 1711 | }); 1712 | function pageCurrent() { 1713 | let pagelists = $$('.pagelist.desktop .pages a'); 1714 | let firstPageStrong = null; 1715 | let matched = false; 1716 | pagelists.forEach((pagelist, index) => { 1717 | let parentStrong = pagelist.parentNode; 1718 | parentStrong.classList.remove('current-page'); 1719 | pagelist.textContent = pagelist.textContent.trim(); 1720 | if (index === 0) { 1721 | firstPageStrong = parentStrong; 1722 | } 1723 | if (pagelist.href === currentSearch) { 1724 | parentStrong.classList.add('current-page'); 1725 | matched = true; 1726 | } 1727 | }); 1728 | if (!matched && firstPageStrong) { 1729 | firstPageStrong.classList.add('current-page'); 1730 | } 1731 | } 1732 | pageCurrent(); 1733 | }) 1734 | } 1735 | //on(d, "PlayerEvent", removeStyle($("#sound-player-css", d.head))); 1736 | /* 1737 | function backup() { 1738 | doc.classList.remove('site-loading'); 1739 | doc.classList.add('no-fourchan-x'); 1740 | on(d, "4chanXInitFinished", doc.classList.remove('no-fourchan-x')); 1741 | } 1742 | 1743 | on(d, 'DOMContentLoaded', backup); 1744 | */ 1745 | ready(".custom-menu-ctrl", (element) => { 1746 | //doc.classList.remove('site-loading'); 1747 | //doc.classList.add('fourchan-ext'); 1748 | init(); 1749 | }); 1750 | 1751 | on(d, '4chanMainInit', function() { 1752 | //doc.classList.remove('site-loading'); 1753 | // doc.classList.add('fourchan-ext'); 1754 | function removeStyle(sel) { 1755 | if (sel) { 1756 | console.log( 1757 | "%css21 sidedish is removing this stylesheet: ", 1758 | "color:green;", 1759 | sel 1760 | ); 1761 | sel.remove(); 1762 | return true; 1763 | } else { 1764 | console.log("%css21 sidedish was unable to find: ", "color:red;", sel); 1765 | return false; 1766 | } 1767 | } 1768 | removeStyle($("style[type]", d.head)); // this removes the inline mobile css 1769 | on(d, 'DOMContentLoaded', replace4chanFooterList); 1770 | function swapInfo() { 1771 | let ops = $$(".op"); 1772 | for (let op of ops) { 1773 | let opPostInfo = $(".postInfo", op); 1774 | op.prepend(opPostInfo); 1775 | op.classList.add("post--file-swapped"); 1776 | } 1777 | } 1778 | on(d, 'DOMContentLoaded', swapInfo); 1779 | }); 1780 | })(); 1781 | --------------------------------------------------------------------------------