diff options
author | 2018-06-13 16:43:42 +0100 | |
---|---|---|
committer | 2018-06-13 16:43:42 +0100 | |
commit | be2bbe35cf49763ad0258c005f3cbdddd7a21d75 (patch) | |
tree | 962d5e52f4bb57c397c068ae6a11b57952cfc459 /static/js/revision_diff.js | |
parent | [DB] Attempt reconnection if current connection was lost (diff) |
Compile as much JS with Gulp as possible
This will concatenate ALL of our JS, and minify it - thus leaving us with a single file to be loaded.
There's a few libraries we can't do this with, unfortunately - these are now added in fouc.js:
* Ace Editor
* Flatpickr
* Font-Awesome
Diffstat (limited to 'static/js/revision_diff.js')
-rw-r--r-- | static/js/revision_diff.js | 84 |
1 files changed, 0 insertions, 84 deletions
diff --git a/static/js/revision_diff.js b/static/js/revision_diff.js deleted file mode 100644 index 0dd17544..00000000 --- a/static/js/revision_diff.js +++ /dev/null @@ -1,84 +0,0 @@ -"use strict"; - -(function() { - const buttons = document.querySelectorAll("td input"); // Fetch all radio buttons - const id_reg = /compare-(before|after)-([\w|-]+)/; // Matches compare-after/before-ID - - - function getRevisionId(element){ - const e = element.id.match(id_reg); // Match ID with RegExp - return [e[1], e[2]]; // e is in format of [full id, after/before, ID] we only want ID & mode - } - - function getRevision(id) { - /* global revisions */ // TODO: FIXME - - const e = revisions.filter((x) => { - // Filter through all revisions to find the selected one (revisions in declared in the template) - return x.id === id; - }); - return e[0]; - } - - function radioButtonChecked(element) { - // console.log("change detected"); - const id = getRevisionId(element); - const rev = getRevision(id[1]); - if (id[0] === "after"){ - /* - * Deselect the opposite checkbox to the one which has been checked - * because we don't want checking of the same revision - */ - - document.querySelector(`#compare-before-${id[1]}`).checked = false; - - buttons.forEach((e) => { - if (getRevisionId(e)[0] === "after" && e.id !== element.id) { // Deselect all checkboxes in the same row - e.checked = false; - } - }); - } else { // This else does the same as above but for the before column - document.querySelector(`#compare-after-${id[1]}`).checked = false; - buttons.forEach((e) => { - if (getRevisionId(e)[0] === "before" && e.id !== element.id) { - e.checked = false; - } - - // This makes sure that you do not compare a new revision with an old one - if (getRevisionId(e)[0] === "after") { - const tmprev = getRevision(getRevisionId(e)[1]); - // console.log(tmprev); - if (tmprev.date <= rev.date) { - document.querySelector(`#${e.id}`).setAttribute("disabled", ""); - } else { - document.querySelector(`#${e.id}`).removeAttribute("disabled"); - } - } - }); - } - - let aft, bef; - - buttons.forEach((button) => { // Find the selected posts - const id = getRevisionId(button); - if (button.checked && id[0] === "before") { - bef = id[1]; - } - - if (button.checked && id[0] === "after") { - aft = id[1]; - } - }); - - // Switch the buttons HREF to point to the correct compare URL - document.getElementById("compare-submit").href = `/history/compare/${bef}/${aft}`; - - } - - buttons.forEach((button) => { - button.checked = false; // Some browsers remember if a button is checked. - button.onchange = function() { - radioButtonChecked(button); - }; - }); -})(); |