3 // @author ECHibiki - /qa/
4 // @description 4chanX - Free Stuff Enhancments
6 // @namespace http://verniy.xyz/
7 // @match *://boards.4chan.org/*
8 // @updateURL https://raw.githubusercontent.com/ECHibiki/4-FSE/master/builds/4-Free.user.js
9 // @downloadURL https://raw.githubusercontent.com/ECHibiki/4-FSE/master/builds/4-Free.user.js
10 // @grant GM_xmlhttpRequest
11 // @run-at document-start
12 // @icon 
16 4chanX-Free Stuff Enhancements is a userscript that operates with 4chanX to give it additional features. These enhancements were written by me from early 2017 up to 2018 as a way to teach myself how to work with JavaScript while giving something back to the community I took part in.
17 Some of these features are simple, like the password viewer, others are more complex using multiple concurent AJAX calls such as the thread rebuilder or the image adder. <br/>
18 Below is a description of the features this package has to offer.
20 ### Danbooru Image Adder
21 #### Adds images to your posts
22 Adds an image to your post taken from the danbooru's image collection.<br/>
23 Supply it with tags via an autocomplete, set the rating(s/q/e) and it will give an image for you to post with.
27 Converts the colors of special symbols from plain black into other prettier colors(yen == purple, kita == dark grey).<br/>
28 #### Hotkeys for Convinience
29 <strong>Press ctrl+\ for ¥</strong>
30 Highlights the whole line in purple much like how greentext works<br/>
31 <strong>Press ctrl+k for キタ━━━(゚∀゚)━━━!!</strong>
32 Highlights just the word in dark gray<br/>
34 ### 4chan-Ignoring-Enhancements
36 Gives the ability to hide images with ___ctrl+shift+click___. Stores in browser memory for new sessions.<br/>
37 Also includes over 20,000 MD5 filters of things like frogs, goldface, guro done by from QAJPYOtGo<br/>
38 https://github.com/ECHibiki/4chan-UserScripts/blob/master/MD5%20Filters%20by%20QAJPYOtGo.txt
40 Also includes the ability to do word replacements with a regex replacement system.<br>
43 #### Rebuild dead threads from scratch
44 Rebuild a thread from 4chan's archive.<br/>
45 Simple system that could use some additions(using 4chan's offsite archives for example)
48 #### Shows your 4chan post/delete password
49 * Displays your 4chan password in an inputbox.
50 * Top left is the post password, Bottom right is the delete password.
51 * Edit the input boxes to change them.
53 __Note:__ some 4chan boards don't allow custom post passwords. May require cookie manipulation, but this has not yet been tested...
56 var Password
= /** @class */ (function () {
58 this.post_id
= "postPassword";
59 this.del_id
= "delPassword";
60 this.node_post
= document
.getElementById(this.post_id
);
61 this.label_post
= document
.createElement("P");
62 this.label_post
.textContent
= "Post: ";
63 this.node_post_parent
= this.node_post
.parentNode
;
64 this.post_pass
= this.node_post
.value
;
65 this.node_del
= document
.getElementById(this.del_id
);
66 this.label_del
= document
.createElement("P");
67 this.label_del
.textContent
= "| Delete: ";
68 this.node_del_parent
= this.node_del
.parentNode
;
69 this.del_pass
= this.node_del
.value
;
71 Password
.prototype.display = function () {
72 this.node_post
.removeAttribute("type");
73 this.node_del
.removeAttribute("type");
74 this.node_post_parent
.insertBefore(this.label_post
, this.node_post
);
75 this.node_del_parent
.insertBefore(this.label_del
, this.node_del
);
76 this.node_del
.style
.display
= "block";
77 this.label_del
.style
.display
= "block";
78 document
.getElementsByClassName("deleteform")[0].style
.display
= "block";
82 var Main
= /** @class */ (function () {
86 Main
.prototype.init = function () {
87 var password
= new Password();
92 document
.addEventListener("4chanXInitFinished", function () { new Main(); });