p/w styling
[4Free-FSE.git] / builds / 4-Free.user.js
blob98e1340f3a723e4336be849d686d7f3e804ee022
1 // ==UserScript==
2 // @name         4-FSE
3 // @author       ECHibiki - /qa/
4 // @description  4chanX - Free Stuff Enhancments
5 // @version      0.1
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  
13 // ==/UserScript==
15     ## About 4chanX-FSE
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.
25     ### Kita-Yen
26     #### Color text
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
35     #### Hides images.
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
39     #### Word Filters
40     Also includes the ability to do word replacements with a regex replacement system.<br>
42     ### Thread Rebuilder
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)
47     ### Visible Password
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...
55 */ 
56 var Password = /** @class */ (function () {
57     function Password() {
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;
70     }
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";
79     };
80     return Password;
81 }());
82 var Main = /** @class */ (function () {
83     function Main() {
84         this.init();
85     }
86     Main.prototype.init = function () {
87         var password = new Password();
88         password.display();
89     };
90     return Main;
91 }());
92 document.addEventListener("4chanXInitFinished", function () { new Main(); });