Tumblr - Mass Post Editor Features

MassReblog ArchiveDashTaggedLikes SelectShowBy:TagType MouseMultiSelect BackdateSchedule CaptionLink BatchPhotoset FollowersFollowees +more

// ==UserScript==
// @name        Tumblr - Mass Post Editor Features
// @namespace   https://jakejilg.com/mass_post_features
// @description MassReblog ArchiveDashTaggedLikes SelectShowBy:TagType MouseMultiSelect BackdateSchedule CaptionLink BatchPhotoset FollowersFollowees +more
// @include     https://www.tumblr.com/mega-editor
// @include     https://www.tumblr.com/mega-editor/*
// @include     https://www.tumblr.com/mega-editor/*/*/*
// @include     https://*/archive?fetch=first_post_timestamp&jump=*&name=*&to=*&year=*
// @version     4.01
// @grant       none
// @run-at      document-start
// @license MIT
// ==/UserScript==

// May 2020, Mass Post Editor Features 4 (from scratch) by Jake Jilg (benign-mx)

// this month widget stuff for both includes pages
var MassPostEditorFeatures4 = function () {

  // first, these 3 functions I didn't write myself
  // begin ripped functions here:
  // a java short code thing from StackOverflow
  var shortCode = function (str) {
    var hash = 0;
    var chr;
    for (var i = 0; i < str.length; i++) {
      chr = str.charCodeAt(i);
      hash = ((hash << 5) - hash) + chr;
      hash |= 0; // Convert to 32bit integer
    }
    return hash;
  };
  // a basic setCookie function from w3schools
  var setCookie = function (cname, cvalue, exdays) {
    var d = new Date();
    d.setTime(d.getTime() + (exdays*24*60*60*1000));
    var expires = "expires="+ d.toUTCString();
    document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
  };
  // a basic readCookie function from w3schools
  var getCookie = function (cname) {
    var name = cname + "=";
    var decodedCookie = decodeURIComponent(document.cookie);
    var ca = decodedCookie.split(';');
    for (var i = 0; i <ca.length; i++) {
      var c = ca[i];
      while (c.charAt(0) == ' ') {
        c = c.substring(1);
      }
      if (c.indexOf(name) == 0) {
        return c.substring(name.length, c.length);
      }
    }
    return "";
  };
  // end: my ripped functions ^ here
  // begin all original script below

  // and I begin my own flurb src="greasemonkey.user.js"... :P
  // drop an "end" in the missing lcontent
  if (typeof l === "undefined") {
    var lcontentDiv = document.createElement("div");
    lcontentDiv.classList.add("l-content");
    lcontentDiv.classList.add("albino");
    document.body.appendChild(lcontentDiv);
  }
  // for the custom month widget that doesn't open dead months like the default
  var doubleCheckDisabledMonths = function (currentYr, lTs, fTs, jump, jumpTo) {
    var mw = document.getElementById("browse_months_widget");
    var cy = mw.getElementsByClassName(
      "current_year"
    )[0].innerText;
    var yr1 = parseInt(cy);
    var timestampF;
    var timestampL;
    var mo = mw.getElementsByClassName("months")[0].
      getElementsByTagName("li");
    var a;
    var span;
    for (var i = 0; i < 12; i++) {
      timestampF = new Date(yr1, i+1, 1).getTime();
      timestampL = new Date(yr1, i, 1).getTime();
      if (timestampL >= lTs || timestampF <= fTs) {
        if (!mo[i].classList.contains("empty")) {
          mo[i].classList.add("empty");
        }
        a = mo[i].getElementsByTagName("a");
        if (a.length > 0) {
          span = document.createElement("span");
          span.appendChild(
            document.createTextNode(
              a[0].innerText
            )
          );
          mo[i].replaceChild(span, a[0]);
        }
      } else {
        if (mo[i].classList.contains("empty")) {
          mo[i].removeAttribute("class");
        }
        a = mo[i].getElementsByTagName("span");
        var month = i;
        var ts = (new Date(yr1, month + 1, 0)).getTime() / 1000;
        var href2g2 = "http://www.tumblr.com/mega-editor/published/" +
            name + "?" + jump + "&" + jumpTo + "&" + ts +
            "#month" + (i+1) + "year" + yr1;
        if (a.length > 0) {
          span = document.createElement("a");
          span.href = href2g2;
          span.target = "_top";
          span.setAttribute("data-month-index", i.toString());
          span.appendChild(
            document.createTextNode(
              a[0].innerText
            )
          );
          mo[i].replaceChild(span, a[0]);
        } else {
          mo[i].getElementsByTagName("a")[0].href = href2g2;
        }
      }
    }
  };

  // these ^v functions function on both includes pages... coding in 3D! :)

  var i;
  var lTs;
  var fTs;
  var name;
  var makeBrowseMonthsWidget = function (currentYr, lTs, fTs, jump, jumpTo) {
    // last timestamp, first timestamp
    var browseMonthsWidget2 = document.createElement("div");
    browseMonthsWidget2.classList.add("popover");
    browseMonthsWidget2.classList.add("popover_gradient");
    browseMonthsWidget2.id = "browse_months_widget";
    var browseMonthsPopInner = document.createElement("div");
    browseMonthsPopInner.classList.add("popover_inner");
    var browseMonthsYear = document.createElement("div");
    browseMonthsYear.classList.add("year");
    var browseMonthsYearNavigation = document.createElement("div");
    browseMonthsYearNavigation.classList.add("year_navigation");
    var prevYearVis = function (e) {
      e.preventDefault();
      e.stopPropagation();
      e.cancelBubble = true;
      var cy = document.getElementsByClassName(
        "current_year"
      )[0];
      var yr = parseInt(cy.innerText);
      if (this.classList.contains("previous_year")) {
        --yr;
        cy.innerText = yr;
      } else {
        ++yr;
        cy.innerText = yr;
      }
      doubleCheckDisabledMonths(yr, lTs, fTs, jump, jumpTo);
    };
    var browseMonthPrevYearA = document.createElement("a");
    browseMonthPrevYearA.href = "#";
    browseMonthPrevYearA.addEventListener("click", prevYearVis);
    var prevYearSpan = document.createElement("span");
    prevYearSpan.appendChild(
      document.createTextNode("prev")
    );
    browseMonthPrevYearA.classList.add("previous_year");
    browseMonthPrevYearA.appendChild(prevYearSpan);
    var browseMonthNextYearA = document.createElement("a");
    browseMonthNextYearA.href = "#";
    browseMonthNextYearA.addEventListener("click", prevYearVis);
    var nextYearSpan = document.createElement("span");
    nextYearSpan.appendChild(
      document.createTextNode("next")
    );
    browseMonthNextYearA.classList.add("next_year");
    browseMonthNextYearA.appendChild(nextYearSpan);
    var currentYearSpan = document.createElement("span");
    currentYearSpan.classList.add("current_year");
    currentYearSpan.appendChild(
      document.createTextNode(currentYr)
    );
    browseMonthsYearNavigation.appendChild(browseMonthPrevYearA);
    browseMonthsYearNavigation.appendChild(currentYearSpan);
    browseMonthsYearNavigation.appendChild(browseMonthNextYearA);
    browseMonthsYear.appendChild(browseMonthsYearNavigation);
    browseMonthsPopInner.appendChild(browseMonthsYear);
    var clear1 = document.createElement("div");
    clear1.classList.add("clear");
    browseMonthsYearNavigation.appendChild(clear1);
    var browseMonths = document.createElement("div");
    browseMonths.classList.add("months");
    var browseMonthsUl = document.createElement("ul");
    var month = [
      "January", "February", "March",
      "April", "May", "June", "July",
      "August", "September", "October",
      "November", "December"
    ];
    var browseMonthsLi;
    var browseMonthsA;
    for (i = 0; i < 12; i++) {
      browseMonthsA = document.createElement("span");
      browseMonthsA.appendChild(
        document.createTextNode(month[i])
      );
      browseMonthsLi = document.createElement("li");
      browseMonthsLi.appendChild(browseMonthsA);
      browseMonthsUl.appendChild(browseMonthsLi);
    }
    browseMonths.appendChild(browseMonthsUl);
    browseMonthsYear.appendChild(browseMonths);
    browseMonthsPopInner.appendChild(browseMonthsYear);
    browseMonthsWidget2.appendChild(browseMonthsPopInner);
    return browseMonthsWidget2;
  };
  if (
    document.location.href.match( // really big RegEx
/\/archive\?fetch=first_post_timestamp&jump=[^&]+&name=[^&]+&to=[^&]+&year=\d+/i
    ) !== null
  ) {
    var megaCss = document.createElement("link");
    megaCss.setAttribute("rel", "stylesheet");
    megaCss.setAttribute("type", "text/css");
    megaCss.setAttribute(
      "href", 'https://assets.tumblr.com/assets/styles/mega-editor.css'
    );
    var glbCss = document.createElement("link");
    glbCss.setAttribute("rel", "stylesheet");
    glbCss.setAttribute("type", "text/css");
    glbCss.setAttribute(
      "href", "https://assets.tumblr.com/client/prod/app/global.build.css"
    );
    var iCss = document.createElement("style");
    iCss.type = "text/css";
    iCss.appendChild(
      document.createTextNode(
(function () {/*
body {
  background: none transparent;
}
#browse_months_widget {
  height: 422px;
  width: 225px;
  padding: 0px;
  top: 0px;
  left: 0px;
}
*/}).toString().slice(16, -3))
    );
    // this browMoWidget ^ is inside the iframe
    var newH = document.createElement("html");
    var head = document.createElement("head");
    head.appendChild(glbCss);
    head.appendChild(megaCss);
    head.appendChild(iCss);
    newH.appendChild(head);
    var body = document.createElement("body");
    var currentYr = document.location.href.match(/year=(\d+)/i)[1];
    name = document.location.href.match(/&name=([^&]+)/i)[1];
    var jump = document.location.href.match(/jump=([^&]+)/i)[1];
    var jumpTo = document.location.href.match(/to=([^&]+)/i)[1];
    var html = document.documentElement.innerHTML;
    fTs = parseInt(html.match(
      /"firstPostTimestamp":(\d+)/
    )[1]) * 1000;
    lTs = parseInt(html.match(
      /"updated":(\d+)/
    )[1]) * 1000;
    // the default archive URL makes weird dead pages...
    // I want to replace the default glitchy/month/panel/2014
    // with a more simple yet functional panel ?month&beforetimestamp
    body.appendChild(makeBrowseMonthsWidget(currentYr, lTs, fTs, jump, jumpTo));
    newH.appendChild(body);
    document.getElementsByTagName("html")[0].parentNode.replaceChild(
      newH,
      document.getElementsByTagName("html")[0]
    );
    doubleCheckDisabledMonths(currentYr, lTs, fTs, jump, jumpTo);
    return;
    // prevent the other page stuff from going
  }
  // this ^ runs on archive page only :)

  // this v runs on the megaEditor page only
  var removeS = document.getElementsByTagName("script");
  for (i = 0; i < removeS.length; i++) {
    if (
      typeof removeS[i].src.split(/\/+/g)[1] === "undefined" ||
      removeS[i].src.split(/\/+/g)[1] !== "assets.tumblr.com"
    ) {
      removeS[i].parentNode.removeChild(removeS[i]);
    }
  }
  var rewrite1 = function () { // <= outside of plugin scope
    // Tumblr was animating with
    // JQuery DOM manipulation instead of CSS3 >:P
    window.way_too_big_to_animate = true;
    window.neueCorrectionIndex = 0;
    // Tumblr was written with prototype.js in 2014 and
    // it used a lot of clumsy intervals as listeners
    // which were passed down the the jQuery Tumbr MPE
    // in 2016 and are still being used...
    for (var i = 500; i > 0; i--) {
      clearInterval(i); // their intervals have no var names
    }
    // but we use intervals too because it's still Tumblr in 2014 :)
    var href = document.location.href.split(/[\/\?&#=]+/g);
    if (
      href[3] === "published" &&
      href[5] === "follows" ||
      href[5] === "followers" ||
      href[5] === "fans"
    ) {
      window.insert_tag = function(){};
      window.render_tag_editor = function(){};
    }
    window.cleanCssAnimate = setInterval(function () {
      if (
        href[5] === "photos"
      ) {
        clearInterval(window.cleanCssAnimate);
        return;
      }
      var l = document.getElementsByClassName("l-content")[0];
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      if (typeof l === "undefined") {
        return;
      }
      if (typeof l !== "undefined" && !l.classList.contains("albino")) {
        l.innerHTML = "";
        return;
      }
      var pause = document.getElementById(
        "pause_button"
      );
      var canvas = document.getElementById("status");
      var ctx = canvas.getContext("2d");
      if (
        canvas !== null &&
        typeof canvas !== "undefined" &&
        data.classList.contains("fetching-from-tumblr-api") &&
        pause !== null &&
        typeof pause !== "undefined" &&
        pause.classList.contains("playing")
      ) {
        var toSeconds = parseFloat(
          data.getAttribute("data-to-seconds")
        );
        toSeconds++;
        if (toSeconds > 30) {
          toSeconds = 0;
        }
        ctx.fillStyle = "#9da6af";
        ctx.fillRect(
          0, 0, canvas.width, canvas.height
        );
        var width = (canvas.width - 16) * (toSeconds / 30);
        ctx.fillStyle = "#74797e";
        ctx.fillRect(
          0, canvas.height / 2 + 2, canvas.width - 16, canvas.height / 2
        );
        ctx.fillStyle = "turquoise";
        ctx.fillRect(0, canvas.height/ 2 + 2, width, canvas.height/ 2);
        ctx.fillStyle = "#9da6af";
        for (var i = canvas.width/11; i < canvas.width; i+=canvas.width/11) {
          ctx.fillRect(
            i - 3, canvas.height/ 2 + 2, 2, canvas.height / 2
          );
        }
        ctx.font = "bold 10px Arial, sans-serif";
        ctx.fillStyle = "#fff"
        ctx.fillText(
          "Posts Loaded",
          canvas.width/2 - ctx.measureText("Posts Loaded").width / 2 - 3,
          canvas.height / 2
        );
        data.setAttribute("data-to-seconds", toSeconds);
      } else if (
        pause !== null &&
        canvas !== null &&
        typeof pause !== "undefined" &&
        pause.classList.contains("paused")
      ) {
        ctx = canvas.getContext("2d");
        ctx.font = "bold 10px Arial, sans-serif";
        ctx.fillStyle = "#9da6af";
        ctx.fillRect(
          0, 0, canvas.width, canvas.height / 2
        );
        ctx.fillStyle = "#fff";
        ctx.fillText(
          "Paused",
          canvas.width/2 - ctx.measureText("Paused").width / 2 - 6,
          canvas.height / 2
        );
      }
      var fChild = l.querySelectorAll(":scope > :not(.laid)");
      if (fChild.length !== 0) {
        fChild[0].classList.add("laid");
      } else if (data.classList.contains("next_page_false")) {
        clearInterval(window.cleanCssAnimate);
        // see ^ we clear our own animate interval, Tumblr!
        // (Tumblr doens't clear theirs...)
        var p = l.querySelectorAll(":scope > a");
        document.getElementById("p_loaded").innerHTML = "x" + p.length;
        pause.classList.add("done");
        pause.classList.remove("playing");
        pause.classList.remove("paused");
        var allDone = href[5] !== "followers" && href[5] !== "follows" ?
            "All posts loaded." : "All blogs loaded.";
        pause.setAttribute("title", allDone);
        document.getElementById(
          "ajax-info_button"
        ).setAttribute("title", allDone);
        var smi = new Image();
        smi.addEventListener("load", function() {
          var canvas = document.getElementById("status");
          var ctx = canvas.getContext("2d");
          ctx.font = "bold 10px Arial, sans-serif";
          ctx.fillStyle = "#9da6af";
          ctx.fillRect(
            0, 0, canvas.width, canvas.height
          );
          ctx.fillStyle = "#fff";
          ctx.fillText(
            href[5] === "fans" ||
            href[5] === "followers" ||
            href[5] === "follows" ?
            "All Blogs" : "All Posts",
            14,
            7
          );
          ctx.fillText(
            "Loaded",
            17,
            15
          );
          ctx.drawImage(this, 1, 1);
        });
        smi.src = "" +
          "AP/gaP///wAAAAAAACH5BAEAAAUALAAAAAAMAAwAAAMlWLPcGjDKFYi9lxKBOa" +
          "GcF35DhWHamZUW0K4mAbiwWtuf0uxFAgA7";
      }
    }, 25);
    // we will need to rebuild on show only too
    (function (alias) {
      window.columns_need_rebuilding = function () {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        if (document.getElementById("p_loaded") !== null) {
          var lcontent = document.getElementsByClassName("l-content");
          var p = lcontent[0].querySelectorAll(":scope > a");
          document.getElementById("p_loaded").innerHTML = "x" + p.length;
        }
        var rebuildAnyway = data.classList.contains("rebuild_anyway");
        window.column_gutter = parseInt(
          data.getAttribute("data-column_gutter")
        );
        window.column_full_width = window.column_width + window.column_gutter;
        if (
          rebuildAnyway ||
            document.documentElement.scrollWidth >
            document.documentElement.clientWidth
        ) {
          data.classList.remove("rebuild_anyway");
          return true;
        }
        return alias.apply(this, arguments);
      }
    })(window.columns_need_rebuilding);
    (function (alias) {
      // this fires after a delete to rebuild columns...
      window.get_selected_post_ids = function () {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        data.classList.add("rebuild_anyway");
        var masonry = new CustomEvent("resize");
        window.dispatchEvent(masonry);
        return alias.apply(this, arguments);
      };
    })(window.get_selected_post_ids);
    // this ^ the pro way to alias
    clearInterval(window.timerid_auto_paginator);
    window.fetch_next_page = function () {};
    window.auto_paginator = function () {};
    // pagination? where we are going, we do not need pagination
  };
  var rewrite2 = function () {
    // my batch photos doesn't need certain functions :0
    var href = document.location.href.split(/[\/\?&#=]+/g);
    (function (alias) {
      // don't fear. these window scope references are
      // NOT unSafeWindow breaches from the plugin scope.
      // these rewrites are going into the DOM, and then
      // the plugin can no longer touch them.
      window.add_tags_to_selected_posts = function() {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        // we must remove the tag from our own custom data first
        var tagsAllArr = JSON.parse(
          data.getAttribute("data-tags_all_arr")
        );
        var tagToIds = JSON.parse(
          data.getAttribute("data-tag_to_ids")
        );
        var idToTags = JSON.parse(
          data.getAttribute("data-id_to_tags")
        );
        var hl = document.getElementsByClassName("highlighted");
        var tokens = document.getElementById("tokens");
        var tags = tokens.getElementsByClassName("tag");
        var tag;
        var id;
        var tc;
        for (var i = 0; i < tags.length; i++) {
          tag = tags[i].innerHTML;
          if (tagsAllArr.indexOf(tag) === -1) {
            tagsAllArr.push(tag); // new Tag
          }
          for (var l = 0; l < hl.length; l++) {
            id = hl[l].getAttribute("data-id");
            if (typeof idToTags[id] === "undefined") {
              idToTags[id] = [tags];
            }
            if (idToTags[id].indexOf(tag) === -1) {
              idToTags[id].push(tag);
            }
            if (typeof tagToIds[tag] === "undefined") {
              tagToIds[tag] = [id];
            }
            if (tagToIds[tag].indexOf(id) === -1) {
              tagToIds[tag].push(id);
            }
            tc = hl[l].getElementsByClassName("tag-container")[0];
            if (
              typeof idToTags[id] !== "undefined" ||
              idToTags[id].length !== 0
            ) {
              // this will happen always
              tc.innerHTML = "#" + idToTags[id].join(" #");
            } else {
              tc.innerHTML = ""; // < this might not happen
            }
          }
        }
        data.setAttribute("data-tags_all_arr", JSON.stringify(tagsAllArr));
        data.setAttribute("data-tag_to_ids", JSON.stringify(tagToIds));
        data.setAttribute("data-id_to_tags", JSON.stringify(idToTags));
        return alias.apply(this, arguments);
      };
    })(window.add_tags_to_selected_posts);
    // this takes tags out of elements when removed...
    // pry easier/better than reloading each post
    (function (alias) {
      window.remove_tags_from_selected_posts = function() {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        // we must remove the tag from our own custom data first
        var tagsAllArr = JSON.parse(
          data.getAttribute("data-tags_all_arr")
        );
        var tagToIds = JSON.parse(
          data.getAttribute("data-tag_to_ids")
        );
        var idToTags = JSON.parse(
          data.getAttribute("data-id_to_tags")
        );
        // you can take the w3c out of the jQuery,
        // but you can't take the jQuery out of w3c
        var tags2remove = document.querySelectorAll("#tags input:checked");
        // I love these new querySelector ^ things :)
        var hl = document.getElementsByClassName("highlighted");
        var id;
        var alt;
        var index;
        var tc;
        for (var i = 0; i < hl.length; i++) {
          id = hl[i].getAttribute("data-id");
          for (var l = 0; l < tags2remove.length; l++) {
            alt = tags2remove[l].getAttribute("alt");
            index = idToTags[id].indexOf(alt);
            idToTags[id].splice(index, 1);
            tc = hl[i].getElementsByClassName("tag-container")[0];
            if (
              typeof idToTags[id] !== "undefined" ||
              idToTags[id].length !== 0
            ) {
              tc.innerHTML = "#" + idToTags[id].join(" #");
            } else {
              tc.innerHTML = "";
            }
            index = tagToIds[alt].indexOf(id);
            tagToIds[alt].splice(index, 1);
            // remove when last tag removed
            if (
              typeof tagToIds[alt] === "undefined" ||
              tagToIds[alt].length === 0 // it could become undefined on shift
            ) {
              index = tagsAllArr.indexOf(alt);
              tagsAllArr.splice(index, 1);
            }
          }
        }
        data.setAttribute("data-tags_all_arr", JSON.stringify(tagsAllArr));
        data.setAttribute("data-tag_to_ids", JSON.stringify(tagToIds));
        data.setAttribute("data-id_to_tags", JSON.stringify(idToTags));
        return alias.apply(this, arguments);
      };
    })(window.remove_tags_from_selected_posts);
    // I've been told: this is the best way to alias a function
    (function (alias) {
      window.get_selected_post_ids = function () {
        window.postCountMake();
        return alias.apply(this, arguments);
      };
    })(window.get_selected_post_ids);
  };
  // some rewrites ^ to Tumblr's default code,  to use later...
  // this function is plugin scope
  var appendRichButtons = function(pbe, rich, brick) {
    // pbe meanse photo brick edit, but I recycled this
    // to make buttons for the caption adder thing too :)
    var addTextFormatting = function(e) {
      e.preventDefault();
      e.stopPropagation();
      var sel = window.getSelection();
      if(
        typeof sel.rangeCount !== "undefined" &&
        sel.rangeCount === 0
      ) {
        return;
      }
      var rng = sel.getRangeAt(0);
      var preRange = 0;
      var postRange = 0;
      var nod;
      var frag;
      var ancestor;
      var ancClone;
      var middle;
      var isNode = this.getAttribute("data-node") !== "none";
      if (isNode) {
        nod = document.createElement(this.getAttribute("data-node"));
        nod.appendChild(
          document.createTextNode(sel.toString())
        );
        if (this.getAttribute("data-class") !== "none") {
          nod.classList.add(
            this.getAttribute("data-class")
          );
        }
        if (
          this.getAttribute("data-node") === "a" &&
          this.getAttribute("data-attr") === "href"
        ) {
          nod.href = pbe.getElementsByClassName(
            "a_button_input"
          )[0].value;
        }
      } else {
        nod = document.createTextNode(sel.toString());
      }
      rng.deleteContents();
      // data-parent is like ul li || ol li...
      if (this.getAttribute("data-parent") !== "none") {
        var pnt = document.createElement(
          this.getAttribute("data-parent")
        );
        pnt.appendChild(nod);
        rng.insertNode(pnt);
      } else {
        rng.insertNode(nod);
      }
      if (!isNode) {
        if (rng.commonAncestorContainer !== rich) {
          frag = document.createDocumentFragment();
          ancestor = rng.commonAncestorContainer.cloneNode(true);
          ancClone = ancestor.cloneNode(true);
          middle = document.createDocumentFragment();
          middle.appendChild(
            document.createTextNode(
              sel.toString()
            )
          );
          ancestor.innerText = ancestor.innerText.substring(
            0, sel.anchorOffset
          );
          ancClone.innerText = ancClone.innerText.substring(
            sel.anchorOffset + sel.toString().length,
            ancClone.innerText.length
          );
          if(ancestor.innerHTML.length > 0) {
            frag.appendChild(ancestor);
          }
          frag.appendChild(middle);
          if(ancClone.innerHTML.length > 0) {
            frag.appendChild(ancClone);
          }
          rng.commonAncestorContainer.parentNode.replaceChild(
            frag, rng.commonAncestorContainer
          );
        }
      }
      brick.classList.remove("visible-colors");
      brick.classList.remove("visible-url");
      window.getSelection().removeAllRanges();
    };
    var xb = butt("X");
    xb.classList.add(xb.id);
    xb.setAttribute("data-node", "none");
    xb.setAttribute("data-class", "none");
    xb.setAttribute("data-attr", "none");
    xb.setAttribute("data-parent", "none");
    xb.removeAttribute("id");
    xb.setAttribute(
      "title", "Remove Formatting"
    );
    xb.addEventListener("click", addTextFormatting);
    var hb = butt("H");
    hb.classList.add(hb.id);
    hb.setAttribute("data-node", "h2");
    hb.setAttribute("data-class", "none");
    hb.setAttribute("data-attr", "none");
    hb.setAttribute("data-parent", "none");
    hb.removeAttribute("id");
    hb.setAttribute(
      "title", "Heading"
    );
    hb.addEventListener("click", addTextFormatting);
    var bb = butt("B");
    bb.classList.add(bb.id);
    bb.setAttribute("data-node", "b");
    bb.setAttribute("data-class", "none");
    bb.setAttribute("data-attr", "none");
    bb.setAttribute("data-parent", "none");
    bb.removeAttribute("id");
    bb.setAttribute(
      "title", "Bold"
    );
    bb.addEventListener("click", addTextFormatting);
    var ib = butt("i");
    ib.classList.add(ib.id);
    ib.setAttribute("data-node", "i");
    ib.setAttribute("data-class", "none");
    ib.setAttribute("data-attr", "none");
    ib.setAttribute("data-parent", "none");
    ib.removeAttribute("id");
    ib.setAttribute(
      "title", "Italic"
    );
    ib.addEventListener("click", addTextFormatting);
    var so = butt("S");
    so.classList.add(so.id);
    so.removeAttribute("id");
    so.setAttribute("data-node", "strike");
    so.setAttribute("data-class", "none");
    so.setAttribute("data-attr", "none");
    so.setAttribute("data-parent", "none");
    so.setAttribute(
      "title", "Strike"
    );
    so.addEventListener("click", addTextFormatting);
    var ab = butt("a");
    ab.classList.add(ab.id);
    ab.removeAttribute("id");
    var ok = butt("ok");
    ok.classList.add(ok.id);
    ok.removeAttribute("id");
    var urlInput = document.createElement("input");
    urlInput.type = "text";
    urlInput.addEventListener("focus", function () {
      this.select();
    });
    urlInput.classList.add("a_button_input");
    urlInput.value = "https://";
    ok.setAttribute("data-node", "a");
    ok.setAttribute("data-class", "none");
    ok.setAttribute("data-attr", "href");
    ok.setAttribute("data-parent", "none");
    ab.setAttribute(
      "title", "Link"
    );
    ok.addEventListener("click", addTextFormatting);
    ab.addEventListener("click", function() {
      brick.classList.add("visible-url");
    });
    var ol = butt("ol");
    ol.classList.add(ol.id);
    ol.removeAttribute("id");
    ol.setAttribute("data-node", "li");
    ol.setAttribute("data-class", "none");
    ol.setAttribute("data-attr", "none");
    ol.setAttribute("data-parent", "ol");
    ol.firstChild.innerHTML = "1.";
    ol.setAttribute(
      "title", "Ordered List"
    );
    ol.addEventListener("click", addTextFormatting);
    var ul = butt("ul");
    ul.classList.add(ul.id);
    ul.removeAttribute("id");
    ul.setAttribute("data-node", "li");
    ul.setAttribute("data-class", "none");
    ul.setAttribute("data-attr", "none");
    ul.setAttribute("data-parent", "ul");
    ul.firstChild.innerHTML = "&#x26AB;";
    ul.setAttribute(
      "title", "Unordered List (Bullet Point)"
    );
    ul.addEventListener("click", addTextFormatting);
    var bq = butt("bq");
    bq.classList.add(bq.id);
    bq.removeAttribute("id");
    bq.setAttribute("data-node", "blockquote");
    bq.setAttribute("data-class", "none");
    bq.setAttribute("data-attr", "none");
    bq.setAttribute("data-parent", "none");
    bq.firstChild.innerHTML = "&#x2590;";
    bq.setAttribute(
      "title", "Blockquote"
    );
    bq.addEventListener("click", addTextFormatting);
    var colorB = butt("colors");
    colorB.classList.add(colorB.id);
    colorB.removeAttribute("id");
    var color = document.createElement("div");
    color.classList.add("color");
    colorB.firstChild.innerHTML = color.outerHTML;
    colorB.setAttribute(
      "title", "Text Color"
    );
    colorB.addEventListener("click", function() {
      brick.classList.add("visible-colors");
    });
    var colors = [
      ["Pink", "#ff62ce", "niles"],
      ["Red", "#ff492f", "joey"],
      ["Orange", "#ff8a00", "monica"],
      ["Yellow", "#e8d73a", "phoebe"],
      ["Green", "#00cf35", "ross"],
      ["Cerulean", "#00b8ff", "rachel"],
      ["Blue", "#7c5cff", "chandler"]
    ];
    var cb;
    for (i = 0; i < colors.length; i++) {
      cb = butt(colors[i][0]);
      cb.classList.add(cb.id);
      cb.removeAttribute("id");
      cb.setAttribute(
        "title",
        colors[i][0] + " " +
        colors[i][2].charAt(0).toUpperCase() + colors[i][2].slice(1)
      );
      cb.classList.add("colors_buttons");
      cb.firstChild.innerHTML = "";
      cb.style.backgroundColor = colors[i][1];
      cb.setAttribute("data-node", "span");
      cb.setAttribute("data-class", "npf_color_" + colors[i][2]);
      cb.setAttribute("data-attr", "none");
      cb.setAttribute("data-parent", "none");
      cb.addEventListener("click", addTextFormatting);
      pbe.appendChild(cb);
    }
    var fb = butt("Q");
    fb.classList.add(fb.id);
    fb.removeAttribute("id");
    fb.setAttribute(
      "title", "Quirky/Fancy"
    );
    fb.setAttribute("data-node", "p");
    fb.setAttribute("data-class", "npf_quirky");
    fb.setAttribute("data-attr", "none");
    fb.setAttribute("data-parent", "none");
    fb.addEventListener("click", addTextFormatting);
    pbe.appendChild(xb);
    pbe.appendChild(bb);
    pbe.appendChild(ib);
    pbe.appendChild(so);
    pbe.appendChild(ab);
    pbe.appendChild(hb);
    pbe.appendChild(ol);
    pbe.appendChild(ul);
    pbe.appendChild(bq);
    pbe.appendChild(colorB);
    pbe.appendChild(fb);
    pbe.appendChild(urlInput);
    pbe.appendChild(ok);
  };
  var pluginBuildColumns = function() {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    data.classList.add("rebuild_anyway");
    // we'll dispatch a masonry event, with window resize
    // because I don't want to appendChild script xMany
    // times, to communicate to window wrapper/scope...
    var masonry = new CustomEvent("resize");
    window.dispatchEvent(masonry);
  };
  // here are some button making things
  var butt = function (nam) { // buttons for widgets
    var sel = document.createElement("button");
    sel.id = nam.toLowerCase().replace(/\s+/, "_") + "_button";
    sel.classList.add("chrome");
    sel.classList.add("big_dark");
    var div = document.createElement("div");
    div.classList.add("chrome_button"); // numbers for same name buttons
    div.appendChild(document.createTextNode(nam.replace(/\d+$/,"")));
    sel.appendChild(div);
    return sel;
  };
  var newChromeButton = function (id, text, withWidget) {
    var container = document.createElement("span");
    container.classList.add("header_button");
    var button = document.createElement("button");
    button.id = id + "_button";
    button.classList.add("chrome");
    button.classList.add("big_dark");
    var cb;
    cb = document.createElement("div");
    cb.classList.add("chrome_button");
    if (typeof text === "string") {
      cb.innerHTML = text;
    } else { // assumed element/fragment
      cb.appendChild(text);
      var sv = cb.getElementsByTagName("svg");
      for (var i = 0; i < sv.length; i++) {
        sv[i].setAttribute("fill", "#fff");
        sv[i].setAttribute("width", "15");
        sv[i].setAttribute("height", "15");
      }
    }
    if (withWidget) {
      var arrow = document.createElement("div");
      arrow.classList.add("arrow");
      cb.appendChild(arrow);
      var input = document.createElement("input");
      input.type = "checkbox";
      input.id = id;
      button.addEventListener("click", function () {
        input.checked = !input.checked;
        input.dispatchEvent(new Event("change"));
      });
      button.appendChild(cb);
      container.appendChild(button);
      container.appendChild(input);
      var widget = document.createElement("div");
      widget.classList.add("widget");
      widget.id = id + "_widget";
      container.appendChild(widget);
    } else {
      button.appendChild(cb);
    }
    container.appendChild(button);
    return container;
  };
  // end buttons stuff
  var lcontent = document.getElementsByClassName("l-content")[0];
  if (typeof lcontent !== "undefined") {
    lcontent.innerHTML = "";
  }
  var en = document.getElementsByClassName("editor_navigation");
  var enable = en[0].getElementsByTagName("button");
  for (i = 0; i < enable.length; i++) {
    enable[i].classList.add("disable-when-none-selected");
  }
  // these functions & vars may be both plugin and window
  var postCountMake = function () {
    var hl = document.getElementsByClassName("highlighted");
    var x = hl.length;
    var i;
    var privateButton = document.getElementById("private_button");
    var privateCount = 0;
    for (i = 0; i < x; i++) {
      if (hl[i].classList.contains("private")) {
        privateCount++;
      }
    }
    if (
      privateButton !== null &&
      typeof privateButton !== "undefined" &&
      privateCount === hl.length && hl.length !== 0 &&
      privateButton.getElementsByTagName("span")[0].innerText !== "(Public)"
    ) {
      privateButton.getElementsByTagName("span")[0].innerText = "(Public)";
      privateButton.setAttribute(
        "data-edit_action",'{"post[state]":"0"}'
      ); // "0" is public usually
    } else if (
      privateButton !== null &&
      typeof privateButton !== "undefined" &&
      privateButton.getElementsByTagName("span")[0].innerText !== "Private"
    ) {
      privateButton.getElementsByTagName("span")[0].innerText = "Private";
      privateButton.setAttribute(
        "data-edit_action",'{"post[state]":"private"}'
      );
    }
    // make follow or unfollow
    var href = document.location.href.split(/[\/\?&#=]+/g);
    // make public if mostly private selected
    if (href[5] === "followers" || href[5] === "following" || href[5] === "fans") {
      var followButton = document.getElementById("unfollow_button");
      var followCount = 0;
      for (i = 0; i < x; i++) {
        if (hl[i].classList.contains("unfollowed")) {
          followCount++;
        }
      }
    }
    if (
      followButton !== null &&
      typeof followButton !== "undefined" &&
      followCount === hl.length && hl.length !== 0 &&
      followButton.getElementsByTagName("span")[0].innerText !== "Follow"
    ) {
      followButton.getElementsByTagName("span")[0].innerText = "Follow";
      followButton.setAttribute(
        "data-follow", "true"
      );
      followButton.setAttribute("title", "follow selected");
      followButton.getElementsByTagName("svg")[0].parentNode.replaceChild(
        svgForType.happy.cloneNode(true),
        followButton.getElementsByTagName("svg")[0]
      );
    } else if (
      followButton !== null &&
      typeof followButton !== "undefined" &&
      followButton.getElementsByTagName("span")[0].innerText !== "UnFollow"
    ) {
      followButton.setAttribute("title", "unfollow selected");
      followButton.getElementsByTagName("span")[0].innerText = "UnFollow";
      followButton.setAttribute(
        "data-follow", "false"
      );
      followButton.getElementsByTagName("svg")[0].parentNode.replaceChild(
        svgForType.sad.cloneNode(true),
        followButton.getElementsByTagName("svg")[0]
      );
    }
    var unsel = document.getElementById("unselect");
    var count = unsel.getElementsByClassName("chrome_button_right")[0];
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var del = document.getElementById("delete_posts");
    if (data.getAttribute("data-highlight-count") !== x.toString()) {
      data.setAttribute("data-select-all_needle", "0");
      data.setAttribute("data-select-by_needle", "0");
      document.getElementById(
        "select-all_button"
      ).getElementsByTagName("span")[0].innerHTML = "Select 100";
      data.setAttribute("data-highlight-count", x);
      document.title = data.getAttribute("doc-title") + " (" + x + ")";
      count.innerHTML = "&nbsp;(" + x + ")";
      if (del !== null) {
        del.getElementsByClassName(
          "chrome_button_right"
        )[0].innerHTML = "&nbsp;(" + x + ")";
      }
      var en = document.getElementsByClassName("editor_navigation");
      var enable = en[0].getElementsByClassName(
        "disable-when-none-selected"
      );
      // disable certain edit buttons, when 0 selected posts
      if (x === 0) {
        for (i = 0; i < enable.length; i++) {
          if (enable[i].id === "select-by_button") {
            continue;
          }
          enable[i].disabled = true;
        }
        count.innerHTML = "";
        if (del !== null) {
          del.getElementsByClassName(
            "chrome_button_right"
          )[0].innerHTML = "";
        }
        document.title = data.getAttribute("doc-title");
        data.classList.add("disable-temp");
      } else if (data.classList.contains("disable-temp")) {
        for(var l = 0; l < enable.length; l++) {
          enable[l].disabled = false;
        }
        data.classList.remove("disable-temp");
      }
    }
    // populate remove_tags widget...
    // sans ajax && sans%20escaped%20labels && sans jQuery
    var idToTags = JSON.parse(
      data.getAttribute("data-id_to_tags")
    );
    var createTagThing = function (i, tag) {
      var div = document.createElement("div");
      var input = document.createElement("input");
      input.type = "checkbox";
      input.id = "tag_checkbox_" + i;
      input.setAttribute("alt", tag);
      var label = document.createElement("label");
      label.setAttribute("for", "tag_checkbox_" + i);
      label.appendChild(
        document.createTextNode(tag)
      );
      div.appendChild(input);
      div.appendChild(label);
      return div;
    };
    var id;
    var tag;
    var tags;
    var tagsAdded = [];
    var tagsWidget = document.getElementById("tags");
    if (
      window.getComputedStyle(
        tagsWidget.parentNode
      ).getPropertyValue("display") !== "block"
    ) {
      tagsWidget.innerHTML = "";
      for (i = 0; i < hl.length; i++) {
        id = hl[i].getAttribute("data-id");
        tags = idToTags[id];
        if( typeof tags !== "undefined") {
          for (l = 0; l < tags.length; l++) {
            tag = tags[l];
            if (tagsAdded.indexOf(tag) === -1) {
              tagsAdded.push(tag);
              tagsWidget.appendChild(
                createTagThing(tagsAdded.length, tag)
              );
            }
          }
        }
      }
    }
    return x;
  };
  // end dual wrapper functions

  // these are pluginScope, but all DOM, so regardless
  var precountTheSelection = function () {
    var pick = document.getElementsByClassName("picked");
    while (pick.length > 0) {
      pick[0].classList.remove("picked");
    }
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var allToSelect = JSON.parse(
      data.getAttribute("data-all-to-select")
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var tagToIds = JSON.parse(
      data.getAttribute("data-tag_to_ids")
    );
    var idToTags = JSON.parse(
      data.getAttribute("data-id_to_tags")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    var idToOrigin = JSON.parse(
      data.getAttribute("data-id_to_origin")
    );
    var idToState = JSON.parse(
      data.getAttribute("data-id_to_state")
    );
    var gt2select = JSON.parse(
      data.getAttribute("data-gt-to-select")
    );
    var lt2select = JSON.parse(
      data.getAttribute("data-lt-to-select")
    );
    // less than notes, the ID is the generated java shortcode thing
    var ltIs = data.classList.contains(// not more
      "istype-1902356151"
    );
    var gtIs = data.classList.contains( // more than notes
      "istype-454920947"// not less :)
    );
    var type;
    var id;
    var post;
    var tag;
    var ltgt;
    var toSelect = [];
    // contains tag
    for (var l = 0; l < allToSelect.istag.length; l++) {
      tag = allToSelect.istag[l];
      for (var i = 0; i < tagToIds[tag].length; i++) {
        id = tagToIds[tag][i];
        if(toSelect.indexOf(id) === -1) {
          toSelect.push(id);
        }
      }
    }
    var index;
    var spliceAfter;
    var originType;
    var origin = [
      "original",
      "reblog-self",
      "reblog-other"
    ];
    var stateType;
    if (toSelect.length === 0) {
      // contains type, go from 0, capture all
      for (l = 0; l < allToSelect.istype.length; l++) {
        type = allToSelect.istype[l];
        if (
          type === "notes-more-than" || type === "notes-less-than"
        ) {
          continue;
        }
        for (i = 0; i < typeToIds[type].length; i++) {
          id = typeToIds[type][i];
          if (
            allToSelect.istype.length > 1 && // capture some
            allToSelect.istype.indexOf(idToOrigin[id]) === -1 &&
            allToSelect.istype.indexOf(idToState[id]) === -1
          ) {
            continue; // has type1, but not type2
          } else {
            if(toSelect.indexOf(id) === -1) {
              toSelect.push(id);
            }
          }
        }
      }
    }
    if (toSelect.length !== 0) { // go twice, for 2 or 3 typeTypes
      // if doesn't contain type, remove  from selection
      for (l = 0; l < allToSelect.istype.length; l++) {
        type = allToSelect.istype[l];
        if (
          type === "notes-more-than" || type === "notes-less-than"
        ) {
          continue;
        }
        originType = origin.indexOf(type) !== -1;
        stateType = type === "private";
        for (i = 0; i < toSelect.length; i++) {
          id = toSelect[i];
          if (
            idToTypes[id] !== type && !originType && !stateType ||
            idToOrigin[id] !== type && originType ||
            idToState[id] !== type && stateType
          ) {
            index = toSelect.indexOf(id);
            if (index !== -1) {
              toSelect.splice(i, 1);
              i--;
            }
          }
        }
      }
    }
    // intermission/break here, continued from @ var notesLtGt
    if (ltIs) { // no :not, so no opposite-day ui confusion :)
      if (toSelect.length !== 0) {
        // after thought types like note count for LT
        for (i = 0; i < toSelect.length; i++) {
          id = toSelect[i];
          if(lt2select.indexOf(id) === -1) {
            toSelect.splice(i, 1);
            i--;
          }
        }
      } else {
        for (i = 0; i < lt2select.length; i++) {
          id = lt2select[i];
          if(toSelect.indexOf(id) === -1) {
            toSelect.push(id);
          }
        }
      }
    }
    if (gtIs) { // this has no :not, less confusion
      if (toSelect.length !== 0) {
        // after thought types like note count for GT
        for (i = 0; i < toSelect.length; i++) {
          id = toSelect[i];
          if(gt2select.indexOf(id) === -1) {
            toSelect.splice(i, 1);
            i--;
          }
        }
      } else {
        for (i = 0; i < gt2select.length; i++) {
          id = gt2select[i];
          if(toSelect.indexOf(id) === -1) {
            toSelect.push(id);
          }
        }
      }
    }
    // back to the normal function
    if (toSelect.length !== 0) { // remove from selection
      // doesn't contain tag
      for (l = 0; l < allToSelect.nottag.length; l++) {
        tag = allToSelect.nottag[l];
        for (i = 0; i < toSelect.length; i++) {
          id = toSelect[i];
          if(tagToIds[tag].indexOf(id) !== -1) {
            toSelect.push(id);
          }
        }
      }
    } else { // or wild select from 0, so add to selection
      for (l = 0; l < allToSelect.nottag.length; l++) {
        tag = allToSelect.nottag[l];
        for (id in idToTags) {
          if (idToTags[id] !== tag) {
            if(toSelect.indexOf(id) === -1) {
              toSelect.push(id);
            }
          }
        }
      }
    }
    if (toSelect.length !== 0) {
      // doesn't contain type, exclusive or whatever
      for (l = 0; l < allToSelect.nottype.length; l++) {
        type = allToSelect.nottype[l];
        if (
          type === "notes-more-than" || type === "notes-less-than"
        ) {
          continue;
        }
        originType = origin.indexOf(type) !== -1;
        stateType = type === "private";
        for (i = 0; i < toSelect.length; i++) {
          id = toSelect[i];
          if (
            idToTypes[id] === type && !originType && !stateType ||
            idToOrigin[id] === type && originType ||
            idToState[id] === type && originType
          ) {
            index = toSelect.indexOf(id);
            if (index !== -1) {
              toSelect.splice(i, 1);
              i--;
            }
          }
        }
      }
    } else { // select from nothing
      for (l = 0; l < allToSelect.nottype.length; l++) {
        type = allToSelect.nottype[l];
        if (
          type === "notes-more-than" || type === "notes-less-than"
        ) {
          continue;
        }
        for (var type2 in typeToIds) {
          if (type === type2) {
            continue;
          }
          for (i = 0; i < typeToIds[type2].length; i++) {
            id = typeToIds[type2][i];
            if (
              typeToIds[type].indexOf(id) !== -1 ||
              allToSelect.nottype.length > 1 && // capture some
              allToSelect.nottype.indexOf(idToOrigin[id]) !== -1 &&
              allToSelect.nottype.indexOf(idToState[id]) === -1
            ) {
              continue; // has type1, but not type2
            } else {
              if(toSelect.indexOf(id) === -1) {
                toSelect.push(id);
              }
            }
          }
        }
      }
    }
    // proudly show the posts select count
    var titleD = document.getElementById("select-by-widget_title");
    var countEl = titleD.getElementsByClassName("preselect-count")[0];
    countEl.classList.add("noanim");
    setTimeout(function (){
      countEl.classList.remove("noanim");
      countEl.innerHTML = " (x" + toSelect.length + ")";
    }, 1);
    var sb = document.getElementById("select_button");
    if (toSelect.length === 0) {
      if (!data.classList.contains("show-only")) {
        sb.disabled = true;
      }
    } else {
      sb.disabled = false;
      var sel;
      for (i = 0; i < toSelect.length; i++) {
        id = toSelect[i];
        sel = document.getElementById("post_" + id);
        if (sel !== null) {
          sel.classList.add("picked");
        }
      }
      data.setAttribute(
        "data-to-select",
        JSON.stringify(toSelect)
      );
    }// to be continued @ var selecto
  };
  var highlightBrick = function (brick, sel) {
    var x = postCountMake();
    var visible = !brick.classList.contains("display-none");
    var hilite = brick.classList.contains("highlighted");
    if(!hilite && sel && x < 100 && visible){
      brick.classList.remove("prevent-anim");
      brick.classList.add("highlighted");
    }
    if(hilite && !sel){
      brick.classList.add("prevent-anim");
      brick.classList.remove("highlighted");
      brick.classList.remove("edit-reblog-queue");
    }
    postCountMake();
  };
  var SVG = function (width, height, fill, viewBox, d) {
    var svg = document.createElementNS(
      "http://www.w3.org/2000/svg", "svg"
    );
    var path = document.createElementNS(
      "http://www.w3.org/2000/svg", "path"
    );
    path.setAttribute("d", d);
    svg.setAttribute("viewBox", viewBox);
    svg.setAttribute("width", width);
    svg.setAttribute("height", height);
    svg.setAttribute("fill", fill);
    svg.appendChild(path);
    return svg;
  };
  // these SVG are stringed wierdly... TODO, clean decimals, maybe?
  var svgForType = {
    "home": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 21,13 V 23 H 15 V 15 H 9 v 8 H 3 V 13 H 0 L 12,1 24,13 Z'
    ),
    "message": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 10.5 0 C 4.7 0 0 4.7 0 10.5 c 0 2.2 0.' +
      '7 4.2 1.8 5.8 l -0.7 4.1 l 4.5 -0.7 C 7.' +
      '1 20.5 8.8 21 10.5 21 C 16.3 21 21 16.2 ' +
      '21 10.4 S 16.3 0 10.5 0 Z M 5.9 7.6 c 0 ' +
      '-0.9 0.8 -1.7 1.7 -1.7 c 0.9 0 1.7 0.8 1' +
      '.7 1.7 c 0 0.9 -0.8 1.7 -1.7 1.7 c -0.9 ' +
      '0 -1.7 -0.8 -1.7 -1.7 Z m 4.6 8.4 c -2.1' +
      ' 0 -3.9 -1.1 -4.6 -2.7 c -0.3 -0.6 0.3 -' +
      '1.3 1.1 -1.3 h 6.8 c 0.8 0 1.4 0.7 1.1 1' +
      '.3 c -0.5 1.6 -2.3 2.7 -4.4 2.7 Z m 2.9 ' +
      '-6.8 c -0.9 0 -1.7 -0.8 -1.7 -1.7 c 0 -0' +
      '.9 0.8 -1.7 1.7 -1.7 c 0.9 0 1.7 0.8 1.7' +
      ' 1.7 c 0 0.9 -0.7 1.7 -1.7 1.7 Z'
    ),
    "friendly": SVG(
      20, 20, "rgba(0,0,0,0.65)", "-4 -4 30 30",
      'M 12 -2.2 C 7.5 -2.2 3.9 1.8 3.9 7.0 C 3.9 10' +
      '.5 5.7 13.6 8.3 15.1 C 7.7 14.9 7.1 14.5 6.5 ' +
      '14.1 C 2.5 15.9 0 21.5 0 24 L 24 24 C 24 21.5' +
      ' 21.4 15.9 17.4 14.1 C 16.8 14.5 16.3 14.9 15' +
      '.6 15.1 C 18.2 13.6 20.0 10.5 20.0 7.0 C 20.0' +
      ' 1.8 16.4 -2.2 12 -2.2 z '
    ),
    "mutual": SVG(
      20, 20, "rgba(0,0,0,0.65)", "-4 -4 30 30",
      'M 12 -2.2 C 7.5 -2.2 3.9 1.8 3.9 7.0 C 3.9 10' +
      '.5 5.7 13.6 8.3 15.1 C 7.7 14.9 7.1 14.5 6.5 ' +
      '14.1 C 2.5 15.9 0 21.5 0 24 L 24 24 C 24 21.5' +
      ' 21.4 15.9 17.4 14.1 C 16.8 14.5 16.3 14.9 15' +
      '.6 15.1 C 18.2 13.6 20.0 10.5 20.0 7.0 C 20.0' +
      ' 1.8 16.4 -2.2 12 -2.2 z M 11.8 15.2 C 12.7 1' +
      '5.1 13.6 15.5 14.1 16.4 C 15.2 14.4 18.5 15.0' +
      ' 18.5 17.5 C 18.5 19.3 16.4 21.1 14.1 23.6 C ' +
      '11.7 21.1 9.7 19.3 9.7 17.5 C 9.7 16.1 10.7 1' +
      '5.3 11.8 15.2 z '
    ),
    "happy": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 12 0.2 C 5.3 0.2 0 5.5 0 12.2 C 0 18.8 5.3 ' +
      '24.2 12 24.2 C 18.6 24.2 24 18.8 24 12.2 C 24' +
      ' 5.5 18.6 0.2 12 0.2 z M 16.1 4.5 A 2.2 3.3 0' +
      ' 0 1 18.4 7.9 A 2.2 3.3 0 0 1 16.1 11.2 A 2.2' +
      ' 3.3 0 0 1 13.9 7.9 A 2.2 3.3 0 0 1 16.1 4.5 ' +
      'z M 7.8 4.6 A 2.2 3.3 0 0 1 10.0 7.9 A 2.2 3.' +
      '3 0 0 1 7.8 11.3 A 2.2 3.3 0 0 1 5.6 7.9 A 2.' +
      '2 3.3 0 0 1 7.8 4.6 z M 4.2 11.4 C 6.3 13.3 8' +
      '.6 14.5 11.9 14.6 C 15.2 14.7 17.5 13.6 19.7 ' +
      '11.8 L 20.4 12.6 C 18.7 15.2 15.7 18.0 11.8 1' +
      '7.9 C 7.9 17.8 5.0 14.8 3.5 12.2 L 4.2 11.4 z' +
      ' '
    ),
    "sad": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 12 0.2 C 5.3 0.2 0 5.5 0 12.2 C 0 18.8 5.3 ' +
      '24.2 12 24.2 C 18.6 24.2 24 18.8 24 12.2 C 24' +
      ' 5.5 18.6 0.2 12 0.2 z M 16.1 4.5 A 2.2 3.3 0' +
      ' 0 1 18.4 7.9 A 2.2 3.3 0 0 1 16.1 11.2 A 2.2' +
      ' 3.3 0 0 1 13.9 7.9 A 2.2 3.3 0 0 1 16.1 4.5 ' +
      'z M 7.8 4.6 A 2.2 3.3 0 0 1 10.0 7.9 A 2.2 3.' +
      '3 0 0 1 7.8 11.3 A 2.2 3.3 0 0 1 5.6 7.9 A 2.' +
      '2 3.3 0 0 1 7.8 4.6 z M 11.8 12.6 C 15.7 12.5' +
      ' 18.7 15.3 20.3 18.0 L 19.6 18.8 C 17.5 16.9 ' +
      '15.1 15.8 11.8 15.8 C 8.5 15.9 6.2 17.0 4.1 1' +
      '8.9 L 3.4 18.1 C 5.0 15.5 7.9 12.6 11.8 12.6 ' +
      'z '
    ),
    "caption": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 2.3 2.8 L 2.3 4.8 L 21.2 4.8 L 21.2 2.' +
      '8 L 2.3 2.8 z M 2.5 8.6 L 2.5 10.6 L 21.' +
      '4 10.6 L 21.4 8.6 L 2.5 8.6 z M 2.5 14.5' +
      ' L 2.5 16.4 L 21.4 16.4 L 21.4 14.5 L 2.' +
      '5 14.5 z M 2.5 20.3 L 2.5 22.3 L 14.1 22' +
      '.3 L 14.1 20.3 L 2.5 20.3 z '
    ),
    "clock": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 12 0 C 5.3 0 -7.9e-17 5.3 0 12 C 0 18.' +
      '6 5.3 24 12 24 C 18.6 24 24 18.6 24 12 C' +
      ' 24 5.3 18.6 -7.9e-17 12 0 z M 12 3.9 C ' +
      '16.5 3.9 20.2 7.5 20.2 12 C 20.2 15.0 18' +
      '.4 17.7 15.8 19.1 C 14.6 19.7 13.3 20.0 ' +
      '12 20.0 C 7.4 20.0 3.7 16.4 3.7 12 C 3.7' +
      ' 7.5 7.4 3.9 12 3.9 z M 9.7 7.8 L 9.7 15' +
      '.0 L 15.3 15.0 L 15.3 12.3 L 12.3 12.3 L' +
      ' 12.3 7.8 L 9.7 7.8 z '
    ),
    "symlink": SVG( // symbol link :D
      20, 20, "#FFF", "0 0 17 17",
      'M 10.8 3.2 C 10.0 3.2 9.3 3.5 8.8 4.0 C ' +
      '8.0 4.8 7.8 7.2 7.8 8.5 L 7.6 9.4 C 7.5 ' +
      '10.8 7.2 11.7 7.0 11.9 C 6.4 12.4 5.5 12' +
      '.4 5.0 11.9 C 4.4 11.3 4.4 10.5 5.0 9.9 ' +
      'C 5.1 9.9 5.4 9.7 6.6 9.4 L 6.6 7.9 C 5.' +
      '5 8.0 4.5 8.3 4.0 8.8 C 2.9 9.9 2.9 11.8' +
      ' 4.0 12.9 C 5.1 14.1 7.0 14.0 8.1 12.9 C' +
      ' 8.7 12.2 9.0 10.6 9.1 9.3 L 10.4 9.0 C ' +
      '11.4 8.9 12.4 8.6 12.9 8.1 C 14.1 6.9 14' +
      '.1 5.1 12.9 4.0 C 12.3 3.4 11.5 3.2 10.8' +
      ' 3.2 z M 10.9 4.7 C 11.2 4.7 11.6 4.8 11' +
      '.9 5.0 C 12.5 5.6 12.5 6.4 11.9 7.0 C 11' +
      '.7 7.2 11.1 7.4 10.4 7.5 L 9.3 7.6 C 9.4' +
      ' 6.4 9.7 5.3 9.9 5.0 C 10.2 4.8 10.5 4.7' +
      ' 10.9 4.7 z '
    ),
    "select": SVG(
      20, 20, "rgba(255,255,255,1)", "0 0 1800 1800",
      'M 1190.5,1425 H 981.9 v 300 h 208.6 z m -445.0,0 H 536.' +
      '8 v 300 H 745.4 Z M 300.4,5 H 5 V 285.6 H 300.4 Z M 5,5' +
      '22.1 V 730.7 H 300.4 V 522.1 Z M 5,967.1 V 1175.8 H 300' +
      '.4 V 967.1 Z M 5,1412.2 V 1725 H 300.4 V 1412.2 Z M 142' +
      '7.0,1725 H 1725 V 1412.2 H 1427.0 Z M 1725,1175.8 V 967' +
      '.1 h -300 v 208.6 z m 0,-445.0 V 522.1 h -300 v 208.6 z' +
      ' m 0,-445.0 V 5 h -297.9 l -0.0,280.6 z M 536.8,305 H 7' +
      '45.4 V 5 H 536.8 Z m 445.0,0 H 1190.5 V 5 H 981.9 v 300'
    ),
    "unselect": SVG(
      20, 20, "rgba(255,255,255,1)", "0 0 1800 1800",
      'M 1190.5,1425 H 981.9 v 300 h 208.6 z m -445.0,0 H 536.' +
      '8 v 300 H 745.4 Z M 300.4,5 H 5 V 285.6 H 300.4 Z M 5,5' +
      '22.1 V 730.7 H 300.4 V 522.1 Z M 5,967.1 V 1175.8 H 300' +
      '.4 V 967.1 Z M 5,1412.2 V 1725 H 300.4 V 1412.2 Z M 142' +
      '7.0,1725 H 1725 V 1412.2 H 1427.0 Z M 1725,1175.8 V 967' +
      '.1 h -300 v 208.6 z m 0,-445.0 V 522.1 h -300 v 208.6 z' +
      ' m 0,-445.0 V 5 h -297.9 l -0.0,280.6 z M 536.8,305 H 7' +
      '45.4 V 5 H 536.8 Z m 445.0,0 H 1190.5 V 5 H 981.9 Z M 5' +
      '26.1,1392.8 870.3,1048.6 1214.6,1392.8 1402.4,1204.9 10' +
      '58.2,860.7 1402.4,516.5 1214.6,328.7 870.3,672.9 526.1,' +
      '328.7 338.3,516.5 682.5,860.7 338.3,1204.9 526.1,1392.8'
    ),
    "private": SVG(
      20, 20, "rgba(0,0,0,0.65)", "0 0 25 25",
      'M 12 0 C 8.687 0 6 2.687 6 6 L 6 10 L 3 ' +
      '10 L 3 24 L 21 24 L 21 10 L 18 10 L 18 6' +
      ' C 18 2.687 15.313 0 12 0 z M 12 2 C 14.' +
      '205 2 16 3.794 16 6 L 16 10 L 8 10 L 8 6' +
      ' C 8 3.794 9.794 2 12 2 z '
    ),
    "view": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M 5 2 C 3.9 2 3 2.9 3 4 L 3 19 C 3 20.1 3' +
      '.9 21 5 21 L 9.90625 21 C 9.40625 20.4 9.' +
      '1125 19.7 8.8125 19 L 5 19 L 5 4 L 17 4 L' +
      ' 17 10.8125 C 17.7 11.0125 18.4 11.40625 ' +
      '19 11.90625 L 19 4 C 19 2.9 18.1 2 17 2 L' +
      ' 5 2 z M 15 12 C 12.254545 12 10 14.25454' +
      '5 10 17 C 10 19.745455 12.254545 22 15 22' +
      ' C 16.014334 22 16.958627 21.71405 17.75 ' +
      '21.1875 L 20.59375 24 L 22 22.59375 L 19.' +
      '1875 19.75 C 19.71405 18.958627 20 18.014' +
      '334 20 17 C 20 14.254545 17.745455 12 15 ' +
      '12 z M 15 14 C 16.654545 14 18 15.345455 ' +
      '18 17 C 18 18.654545 16.654545 20 15 20 C' +
      ' 13.345455 20 12 18.654545 12 17 C 12 15.' +
      '345455 13.345455 14 15 14 z'
    ),
    "see": SVG(
      20, 20, "#fff", "0 0 25 25",
      'M12.0 7c4.7 0 8.0 3.0 9.5 4.6-1.4 1.8-4.7 ' +
      '5.3-9.5 5.3-4.4 0-7.9-3.5-9.4-5.4 1.4-1.6 ' +
      '4.8-4.5 9.4-4.5zm0-2c-7.5 0-12.0 6.5-12.0 ' +
      '6.5s4.8 7.4 12.0 7.4c7.7 0 11.9-7.4 11.9-7' +
      '.4s-4.2-6.5-11.9-6.5zm-.0 3c-2.2 0-4 1.7-4' +
      ' 4s1.7 4 4 4c2.2 0 4-1.7 4-4s-1.7-4-4-4zm-' +
      '.0 3.9c-.5.5-1.4.5-2.0 0s-.5-1.4 0-2.0c.5-' +
      '.5 1.4-.5 2.0 0s.5 1.4 0 2.0z'
    ),
    "edit": SVG(
      20, 20, "#fff", "0 0 17.6 17.6",
      'M5.3 13.8l-2.1.7.7-2.1L10.3 6l1.4 1.4-6.' +
      '4 6.4zm6.4-9.3l-1.4-1.4-1.4 1.4-6.7 6.7-' +
      '.2.5-2 5.9 3.8-1.3 2.1-.7.4-.1.3-.3 7.8-' +
      '7.8c.1 0-2.7-2.9-2.7-2.9zm5.6-1.4L14.5.3' +
      'c-.4-.4-1-.4-1.4 0l-1.4 1.4L15.9 6l1.4-1' +
      '.4c.4-.5.4-1.1 0-1.5'
    ),
    "tag": SVG(
     20, 20, "rgba(0,0,0,0.65)", "0 0 25 25",
    'M 22.548,9 C 23.206256,8.9700327 23.650255,7.910999 23,7 H 1' +
    '7.636 L 19,1 C 18.752094,0.59934281 17.927011,0.1886722 17,1' +
    ' l -1.364,6 h -5 L 12,1 C 11.549885,0.14080067 10.499307,0.2' +
    '4688203 10,1 L 8.636,7 H 2.452 C 1.4285746,7.5060381 1.19403' +
    '09,8.6369341 2,9 H 8.182 L 6.818,15 H 1.458 C 0.88718577,15.' +
    '077045 -0.12646423,15.930092 1,17 H 6.364 L 5,23 c 0.085861,' +
    '0.788259 1.3877329,1.432281 2,0 l 1.364,-6 h 5 L 12,23 c -0.' +
    '149456,1.256123 1.798475,1.024039 2,0 l 1.364,-6 h 6.185 C 2' +
    '2.966246,16.643398 22.272209,14.963206 22,15 h -6.182 l 1.36' +
    '4,-6 z m -8.73,6 h -5 l 1.364,-6 h 5 z'
    ),
    "ask": SVG(
      20, 20, "rgba(0,0,0,0.65)", "0 0 17 17",
      'M8.7 0C4.1 0 .4 3.7.4 8.3c0 1.2.2 2.3.7 3.4-.2.6-.4 1.5-.7 2' +
      '.5L0 15.8c-.2.7.5 1.4 1.2 1.2l1.6-.4 2.4-.7c1.1.5 2.2.7 3.4.' +
      '7 4.6 0 8.3-3.7 8.3-8.3C17 3.7 13.3 0 8.7 0zM15 8.3c0 3.5-2.' +
      '8 6.3-6.4 6.3-1.2 0-2.3-.3-3.2-.9l-3.2.9.9-3.2c-.5-.9-.9-2-.' +
      '9-3.2.1-3.4 3-6.2 6.5-6.2S15 4.8 15 8.3z'
    ),
    "reblog-self": SVG(
      20, 20, "rgba(0,0,0,0.65)", "0 0 17 18.1",
      'M12.8.2c-.4-.4-.8-.2-.8.4v2H' +
      '2c-2 0-2 2-2 2v5s0 1 1 1 1-1' +
      ' 1-1v-4c0-1 .5-1 1-1h9v2c0 .' +
      '6.3.7.8.4L17 3.6 12.8.2zM4.2' +
      ' 17.9c.5.4.8.2.8-.3v-2h10c2 ' +
      '0 2-2 2-2v-5s0-1-1-1-1 1-1 1' +
      'v4c0 1-.5 1-1 1H5v-2c0-.6-.3' +
      '-.7-.8-.4L0 14.6l4.2 3.3z'
      ),
    "original": SVG(
      20, 20, "rgba(0,0,0,0.65)", "0 0 27 27",
      'M 12.2,5.3 14.1,9.9 l 4.3,0.5 -2.9,4.1 0' +
      '.9,4.7 -4.8,-2.1 C 7.2,11.3 10.6,11.3 12' +
      '.2,5.3 Z M 12,0.5 8.3,8.1 0,9.3 6.0,15.1' +
      ' 4.5,23.4 12,19.4 19.4,23.4 17.9,15.1 24' +
      ',9.3 15.6,8.1 Z'
    ),
    "reblog-other": SVG(
      20, 20, "rgba(0,0,0,0.6)", "18 10 67 67",
      'M 64.7 10.1 C 63.9 10.2 63.3 11.0 63.3 12.' +
      '4 L 63.3 20.0 L 25.5 20.0 C 17.9 20.0 18 2' +
      '7.5 18 27.5 L 18 46.4 C 18 46.4 17.9 50.2 ' +
      '21.7 50.2 C 25.5 50.2 25.5 46.4 25.5 46.4 ' +
      'L 25.5 31.3 C 25.5 27.5 27.4 27.5 29.3 27.' +
      '5 L 63.3 27.5 L 63.3 35.1 C 63.3 37.4 64.4' +
      ' 37.7 66.3 36.6 L 82.2 23.7 L 66.3 10.9 C ' +
      '65.8 10.3 65.2 10.1 64.7 10.1 z M 50.5 30.' +
      '1 C 42.2 30.1 35.5 36.7 35.5 44.9 C 35.5 5' +
      '3.1 42.2 59.8 50.5 59.8 C 58.8 59.8 65.5 5' +
      '3.1 65.5 44.9 C 65.5 36.7 58.8 30.1 50.5 3' +
      '0.1 z M 50.5 32.6 C 55.1 32.6 59.2 35.1 61' +
      '.3 38.8 L 39.7 38.8 C 41.8 35.1 45.9 32.6 ' +
      '50.5 32.6 z M 78.4 38.9 C 74.6 38.9 74.6 4' +
      '2.6 74.6 42.6 L 74.6 57.8 C 74.6 61.5 72.8' +
      ' 61.5 70.9 61.5 L 36.8 61.5 L 36.8 54.0 C ' +
      '36.8 51.7 35.7 51.3 33.8 52.5 L 18 65.3 L ' +
      '33.8 78.2 C 34.4 78.7 35.0 79.0 35.4 79.0 ' +
      'C 36.3 78.9 36.8 78.1 36.8 76.7 L 36.8 69.' +
      '1 L 74.6 69.1 C 82.2 69.1 82.2 61.5 82.2 6' +
      '1.5 L 82.2 42.6 C 82.2 42.6 82.2 38.9 78.4' +
      ' 38.9 z M 38.5 41.2 L 40.9 41.2 C 41.6 43.' +
      '1 43.3 44.9 45.9 44.9 C 49.0 44.9 48.6 42.' +
      '1 50.5 42.1 C 52.4 42.1 52.0 44.9 55.1 44.' +
      '9 C 57.7 44.9 59.4 43.1 60.1 41.2 L 62.4 4' +
      '1.2 C 62.8 42.4 63.0 43.7 63.0 44.9 C 63.0' +
      ' 51.8 57.4 57.3 50.5 57.3 C 43.6 57.3 38.0' +
      ' 51.8 38.0 44.9 C 38.0 43.7 38.2 42.4 38.5' +
      ' 41.2 z M 43.6 47.3 L 43.0 48.0 C 44.4 50.' +
      '1 47.0 52.4 50.5 52.4 C 54.0 52.4 56.6 50.' +
      '1 58.0 48.0 L 57.4 47.3 C 55.5 48.8 53.4 4' +
      '9.7 50.5 49.7 C 47.6 49.7 45.5 48.8 43.6 4' +
      '7.3 z '
    ),
    "notes": SVG(
      20, 20, "rgba(0,0,0,0.65)", "0 0 20 18",
      'M14.658 0c-1.625 0-3.21.767-4.463 2.156-' +
      '.06.064-.127.138-.197.225-.074-.085-.137' +
      '-.159-.196-.225C8.547.766 6.966 0 5.35 0' +
      ' 4.215 0 3.114.387 2.162 1.117c-2.773 2.' +
      '13-2.611 5.89-1.017 8.5 2.158 3.535 6.55' +
      '6 7.18 7.416 7.875A2.3 2.3 0 0 0 9.998 1' +
      '8c.519 0 1.028-.18 1.436-.508.859-.695 5' +
      '.257-4.34 7.416-7.875 1.595-2.616 1.765-' +
      '6.376-1-8.5C16.895.387 15.792 0 14.657 0' +
      'h.001zm0 2.124c.645 0 1.298.208 1.916.68' +
      '3 1.903 1.461 1.457 4.099.484 5.695-1.97' +
      '3 3.23-6.16 6.7-6.94 7.331a.191.191 0 0 ' +
      '1-.241 0c-.779-.631-4.966-4.101-6.94-7.3' +
      '32-.972-1.595-1.4-4.233.5-5.694.619-.475' +
      ' 1.27-.683 1.911-.683 1.064 0 2.095.574 ' +
      '2.898 1.461.495.549 1.658 2.082 1.753 2.' +
      '203.095-.12 1.259-1.654 1.752-2.203.8-.8' +
      '87 1.842-1.461 2.908-1.461h-.001z'
    ),
    "liked": SVG(
      20, 20, "rgba(255,0,0,1)", "0 0 20 18",
      'M17.888 1.1C16.953.38 15.87 0 14.758 0c-1.' +
      '6 0-3.162.76-4.402 2.139-.098.109-.217.249' +
      '-.358.42a12.862 12.862 0 0 0-.36-.421C8.4.' +
      '758 6.84 0 5.248 0 4.14 0 3.06.381 2.125 1' +
      '.1-.608 3.201-.44 6.925 1.14 9.516c2.186 3' +
      '.59 6.653 7.301 7.526 8.009.38.307.851.474' +
      ' 1.333.474a2.12 2.12 0 0 0 1.332-.473c.873' +
      '-.71 5.34-4.42 7.526-8.01 1.581-2.597 1.75' +
      '5-6.321-.968-8.418'
    ),
    "text": SVG(
      20, 20, "#000", "0 0 20.8 13",
      'M.1 13h2.8l.9-3h4.7l.8 3h2.9L7.7 0h-3L.1' +
      ' 13zm6-10.1l2 5.1H4.2l1.9-5.1zM20 10V6c0' +
      '-1.1-.2-1.9-1-2.3-.7-.5-1.7-.7-2.7-.7-1.' +
      '6 0-2.7.4-3.4 1.2-.4.5-.6 1.2-.7 2h2.4c.' +
      '1-.4.2-.6.4-.8.2-.3.6-.4 1.2-.4.5 0 .9.1' +
      ' 1.2.2.3.1.4.4.4.8 0 .3-.2.5-.5.7-.2.1-.' +
      '5.2-1 .2l-.9.1c-1 .1-1.7.3-2.2.6-.9.5-1.' +
      '4 1.3-1.4 2.5 0 .9.3 1.6.8 2 .6.5 1.3.9 ' +
      '2.2.9.7 0 1.2-.3 1.7-.6.4-.2.8-.6 1.2-.9' +
      ' 0 .2 0 .4.1.6 0 .2.1.8.2 1h2.7v-.8c-.1-' +
      '.1-.3-.2-.4-.3.1-.3-.3-1.7-.3-2zm-2.2-1.' +
      '1c0 .8-.3 1.4-.7 1.7-.4.3-1 .5-1.5.5-.3 ' +
      '0-.6-.1-.9-.3-.2-.2-.4-.5-.4-.9 0-.5.2-.' +
      '8.6-1 .2-.1.6-.2 1.1-.3l.6-.1c.3-.1.5-.1' +
      '.7-.2.2-.1.3-.1.5-.2v.8z'
    ),
    "image": SVG(
      20, 20, "#ff492f", "0 0 17 15",
      'M14.6 1h-2.7l-.6-1h-6l-.6 1H2.4C1.1 1 0 ' +
      '2 0 3.3v9.3C0 13.9 1.1 15 2.4 15h12.2c1.' +
      '3 0 2.4-1.1 2.4-2.4V3.3C17 2 15.9 1 14.6' +
      ' 1zM8.3 13.1c-2.9 0-5.2-2.3-5.2-5.1s2.3-' +
      '5.1 5.2-5.1c2.9 0 5.2 2.3 5.2 5.1s-2.3 5' +
      '.1-5.2 5.1zm5.9-8.3c-.6 0-1.1-.5-1.1-1.1' +
      ' 0-.6.5-1.1 1.1-1.1s1.1.5 1.1 1.1c0 .6-.' +
      '5 1.1-1.1 1.1zm-10 3.1c0 1.2.5 2.2 1.3 3' +
      ' 0-.2 0-.4-.1-.6 0-2.2 1.8-4 4.1-4 1.1 0' +
      ' 2 .4 2.8 1.1-.3-2-2-3.4-4-3.4-2.2-.1-4.' +
      '1 1.7-4.1 3.9z'
    ),
    "link": SVG(
      20, 20, "#00cf35", "0 0 17 17",
      'M9.9 5.1c-.2.3-.5 1.4-.6 2.6l1.1-.1c.7-.' +
      '1 1.3-.3 1.5-.5.6-.6.6-1.4 0-2-.6-.5-1.4' +
      '-.5-2 0zM8.5 0C3.8 0 0 3.8 0 8.5S3.8 17 ' +
      '8.5 17 17 13.2 17 8.5 13.2 0 8.5 0zm4.4 ' +
      '8.2c-.5.5-1.5.8-2.5.9l-1.2.2c-.1 1.3-.4 ' +
      '2.9-1 3.6-1.1 1.1-3 1.2-4.1 0-1.1-1.1-1.' +
      '1-3 0-4.1.5-.5 1.5-.8 2.6-.9v1.5c-1.2.3-' +
      '1.5.5-1.6.5-.6.6-.6 1.4 0 2 .5.5 1.4.5 2' +
      ' 0 .2-.2.5-1.1.6-2.5l.1-.9c0-1.3.2-3.6 1' +
      '-4.4 1.1-1.1 3-1.2 4.1 0 1.2 1.1 1.2 2.9' +
      ' 0 4.1z'
    ),
    "quote": SVG(
      20, 20, "#ff8a00", "0 0 17 13",
      'M3.5 5.5C4 3.7 5.8 2.4 7.2 1.3L5.9 0C3 1' +
      '.8 0 5 0 8.5 0 11 1.3 13 4 13c2 0 3.7-1.' +
      '5 3.7-3.6C7.7 7 6 5.5 3.5 5.5zm9.3 0c.4-' +
      '1.8 2.2-3.1 3.7-4.2L15.2 0c-2.8 1.8-5.9 ' +
      '5-5.9 8.5 0 2.4 1.3 4.5 4 4.5 2 0 3.7-1.' +
      '5 3.7-3.6 0-2.4-1.7-3.9-4.2-3.9z'
    ),
    "chat": SVG(
      20, 20, "#00b8ff", "0 0 18.7 17",
      'M16 6.1V2.6C16 .8 15 0 13.1 0H2.9C1 0 0 ' +
      '1.1 0 3.3v10.4C0 15.9 1 17 2.9 17h10.2c1' +
      '.9 0 2.9-.8 2.9-2.6v-2.9l2.7-2.9c0-.1-2.' +
      '7-2.5-2.7-2.5zm-4.5-.7c0-.5.3-.8.7-.8s.8' +
      '.3.8.8v1.7l-.3 2.5c0 .3-.2.4-.4.4s-.4-.1' +
      '-.4-.4l-.3-2.5V5.4zm-3.8 6.4c0 .4-.1.8-.' +
      '7.8-.5 0-.7-.4-.7-.8V9.1C6.3 8.4 6 8 5.4' +
      ' 8c-.5 0-1 .4-1 1.2v2.6c0 .4-.1.8-.7.8s-' +
      '.7-.4-.7-.8V5.4c0-.5.3-.8.7-.8.4 0 .7.3.' +
      '7.8v2.1c.3-.4.7-.8 1.5-.8s1.7.5 1.7 2c.1' +
      '.1.1 3.1.1 3.1zm2.5 0c0 .4-.1.8-.7.8-.5 ' +
      '0-.7-.4-.7-.8V7.5c0-.4.1-.8.7-.8.5 0 .7.' +
      '4.7.8v4.3zm-.7-5.6c-.4 0-.7-.4-.7-.8s.3-' +
      '.8.7-.8c.4 0 .7.4.7.8s-.3.8-.7.8zm2.8 6.' +
      '3c-.4 0-.8-.4-.8-.9s.3-.9.8-.9.8.4.8.9-.' +
      '4.9-.8.9z'
    ),
    "audio": SVG(
      20, 20, "#7c5cff", "0 0 19 16",
      'M17.7 7.3c-.4-4.4-4-7.3-8.3-7.3-4.3 0-7.' +
      '9 2.9-8.3 7.4C.5 7.4 0 8 0 8.6v5c0 .8.6 ' +
      '1.4 1.3 1.4H4c.2.4.8 1 1.2 1 .6 0 .8-1 .' +
      '8-1.6V7.8c0-.5-.2-1.6-.8-1.6-.4 0-1 .8-1' +
      '.2 1.1H2.9c.4-3.5 3.2-5.6 6.5-5.6s6.2 2.' +
      '1 6.5 5.6H15c0-.3-.7-1.1-1.1-1.1-.6 0-.9' +
      ' 1-.9 1.6v6.6c0 .5.3 1.6.9 1.6.4 0 1.1-.' +
      '6 1.2-1h2.6c.7 0 1.3-.6 1.3-1.3v-5c0-.8-' +
      '.6-1.3-1.3-1.4zM3 8.5v1l-2 1.3V8.5h2zm15' +
      ' .9l-2 1.3V8.5h2v.9zm-6.4.3l-1.6.5V6.4c0' +
      '-.1-.1-.2-.2-.2s-.2 0-.2.1L7.2 12v.2c.1.' +
      '1.1.1.2.1L9 12v3.8c0 .1-.2.2-.1.2h.3c.1 ' +
      '0 .2 0 .2-.1l2.4-5.9v-.2c-.1-.1-.2-.1-.2' +
      '-.1z'
    ),
    "video": SVG(
      20, 20, "#ff62ce", "0 0 16 15",
      'M15.7 7.8c-.2-.1-.5 0-.6.1l-2.9 2.2c-.1.' +
      '1-.1.1-.2.1V8H0v3h2v3.2c0 .4.3.8.8.8h8.4' +
      'c.5 0 .8-.4.8-.8V12c0 .1.1.2.2.2l2.9 2.2' +
      'c.2.2.4.2.6.1.2-.1.3-.3.3-.5V8.4c0-.2-.1' +
      '-.5-.3-.6zM2.8 6.9c.3 0 .8.1 1.1.1h5.5c.' +
      '3 0 .8-.1 1-.1 1.6-.3 2.8-1.7 2.8-3.4 0-' +
      '1.9-1.6-3.5-3.5-3.5-1.2 0-2.4.6-3 1.7h-.' +
      '1C5.9.6 4.8 0 3.6 0 1.6 0 0 1.6 0 3.5c0 ' +
      '1.7 1.2 3 2.8 3.4zM9 4.2c1 0 1.8-.8 1.8-' +
      '1.8v-.3c.4.3.6.8.6 1.4 0 1-.8 1.8-1.8 1.' +
      '8-.9 0-1.6-.6-1.8-1.5.3.3.7.4 1.2.4zm-6.' +
      '2.1c1 0 1.8-.8 1.8-1.8v-.3c.4.2.6.7.6 1.' +
      '3 0 1-.8 1.8-1.8 1.8-.9 0-1.6-.6-1.8-1.5' +
      '.3.3.7.5 1.2.5z'
    ),
  };
  svgForType.secondary = svgForType.friendly;
  // the profile user icon thing ^

  // begin the giant selectBy widget population things
  var populateSelectByWidget = function () {
    if (!document.getElementById("select-by").checked) {
      return;
    }
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    // these are large JSON attributes DOM, but it should run ok
    // as long as no mutation events/observers on Tumblr's side
    var tagsAllArr = JSON.parse(
      data.getAttribute("data-tags_all_arr")
    );
    var typesAllArr = JSON.parse(
      data.getAttribute("data-types_all_arr")
    );
    var idsAllArr = JSON.parse(
      data.getAttribute("data-ids_all_arr")
    );
    var idToTags = JSON.parse(
      data.getAttribute("data-id_to_tags")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    var idToOrigin = JSON.parse(
      data.getAttribute("data-id_to_origin")
    );
    var idToState = JSON.parse(
      data.getAttribute("data-id_to_state")
    );
    var idToNotes = JSON.parse(
      data.getAttribute("data-id_to_notes")
    );
    var tagToIds = JSON.parse(
      data.getAttribute("data-tag_to_ids")
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var widgetFirstFocus = data.getAttribute(
      "widget_first-focus"
    );
    var rowsLength = 0;
    var anti = function () { // is and not checkboxes
      var ante = document.getElementById(
        this.getAttribute("anti")
      );
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var allToSelect = JSON.parse(
        data.getAttribute("data-all-to-select")
      );
      var tp = document.getElementsByClassName("type");
      var tg;
      var tg2;
      var tgi;
      if (this.checked && ante.checked) {
        ante.parentNode.classList.remove("ch");
        ante.classList.remove(this.id);
        ante.checked = false;
        tg = ante.getAttribute("data-is");
        tg2 = ante.getAttribute("data-tag");
        tgi = allToSelect[tg].indexOf(tg2);
        if (tgi !== -1) {
          allToSelect[tg].splice(tgi, 1);
        }
      }
      var tag = this.getAttribute("data-tag");
      var is = this.getAttribute("data-is");
      var i = allToSelect[is].indexOf(tag);
      var originSelected = false;
      if (this.checked) {
        this.parentNode.classList.add("ch");
        data.classList.add(this.id);
        var origin = ["original","reblog-self","reblog-other"];
        if(i === -1) {
          if (this.classList.contains("type")) {
            for (i = 0; i < tp.length; i++) {
              if (tp[i] !== this) {
                tg = tp[i].getAttribute("data-is");
                tg2 = tp[i].getAttribute("data-tag");
                if (tg2 === null) {
                  continue;
                }
                if (
                    (
                      data.classList.contains(tp[i].id) &&
                      tg2 !== "reblog-self" &&
                      tg2 !== "reblog-other" &&
                      tg2 !== "original" &&
                      tg2 !== "notes-less-than" &&
                      tg2 !== "notes-more-than" &&
                      tg2 !== "private" &&
                      tag !== "private"
                    ) || (
                      data.classList.contains(tp[i].id) &&
                      origin.indexOf(tg2) !== -1 &&
                      origin.indexOf(tag) !== -1
                    )
                ) {
                  // there can be only one...
                  tgi = allToSelect[tg].indexOf(tg2);
                  tp[i].parentNode.classList.remove("ch");
                  tp[i].checked = false;
                  data.classList.remove(tp[i].id);
                  if (tgi !== -1) {
                    allToSelect[tg].splice(tgi, 1);
                  }
                  // you can't select 1 post, with 2 basic types...
                  // it doesn't exist
                }
              }
            }
          }
          allToSelect[is].push(tag);
        }
      } else {
        this.parentNode.classList.remove("ch");
        data.classList.remove(this.id);
        if(i !== -1) {
          allToSelect[is].splice(i, 1);
        }
      }
      data.setAttribute(
        "data-all-to-select",
        JSON.stringify(allToSelect)
      );
      //istag, nottag, istype, nottype
      // step 1 ^ gain the checkBoxes
      // step 2 v preCount the selection
      precountTheSelection();
    };
    var notesLtGt = function () {
      var row = this.parentNode;
      var recount = row.getElementsByClassName("input_is")[0];
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var idToNotes = JSON.parse(
        data.getAttribute("data-id_to_notes")
      );
      var alreadyHidden = data.classList.contains(
         "some-posts-already-hidden"
       );
      var visibleIdsAllArr = JSON.parse(
        data.getAttribute("data-visible_ids_all_arr")
      );
      var op = this.getAttribute("data-operator")
      var ltb = op === "lt";
      var gtb = op === "gt";
      var count = 0;
      var ids = [];
      var nh; // not hidden
      var countEl = row.getElementsByClassName("count")[0];
      for (var id in idToNotes) {
        nh = ( // do not count for hidden posts
          alreadyHidden &&
          visibleIdsAllArr.indexOf(id) !== -1
        ) || !alreadyHidden;
        if(
          (idToNotes[id] < this.value && ltb && nh) ||
          (idToNotes[id] > this.value && gtb && nh)
        ) {
          ids.push(id);
          count++; // count the posts to select
        }
      }
      if (ltb) {
        data.setAttribute(
          "select-by-note_lt",
          this.value
        );
        data.setAttribute(
          "data-lt-to-select",
          JSON.stringify(ids)
        );
      }
      // to be continued @ var precountTheSelection
      if (gtb) {
         data.setAttribute(
          "select-by-note_gt",
          this.value
        );
        data.setAttribute(
          "data-gt-to-select",
          JSON.stringify(ids)
        );
      }
      countEl.innerHTML = count;
      if (recount.checked) {
        precountTheSelection();
      }
    };
    // make row function makeRow
    var widgetRow = function (tag, count, isType, tagIcon) {
      var row = document.createElement("div");
      var rowId = (isType? "type" : "tag") + shortCode(tag);
      row.id = rowId;
      row.setAttribute("data-row", rowsLength);
      row.classList.add("row");
      if (isType) {
        row.classList.add("type");
        row.classList.add(tag);
      } else {
        row.classList.add("tag");
      }
      var countColumn = document.createElement("div");
      countColumn.classList.add("count");
      countColumn.appendChild(
        document.createTextNode(
          count.toLocaleString(
            "en", {useGrouping:true}
          )
        )
      );
      var label1 = document.createElement("label");
      var label2 = document.createElement("label");
      var input1 = document.createElement("input");
      var input2 = document.createElement("input");
      input1.setAttribute("data-tag", tag);
      input2.setAttribute("data-tag", tag);
      var lb = (isType ? "type" : "tag");
      input1.setAttribute("data-is", "is" + lb);
      input2.setAttribute("data-is", "not" + lb);
      input1.classList.add(lb);
      input2.classList.add(lb);
      input1.classList.add("yes");
      input2.classList.add("no");
      input1.setAttribute("data-yn", "yes");
      input2.setAttribute("data-yn", "no");
      var id1 = "is" + rowId;
      var id2 = "not" + rowId;
      input1.setAttribute(
        "anti", "not" + rowId
      );
      input1.classList.add("input_is");
      input2.setAttribute(
        "anti", "is" + rowId
      );
      input2.classList.add("input_not");
      input1.id = id1;
      input2.id = id2;
      input1.addEventListener("change", anti);
      input2.addEventListener("change", anti);
      input1.type = "checkbox";
      input2.type = "checkbox";
      label1.setAttribute("for", id1);
      label2.setAttribute("for", id2);
      var div = document.createElement("div");
      div.classList.add("row-child");
      row.setAttribute("title", tag);
      label1.appendChild(countColumn);
      // we use html instead of textNode for emoji :(
      if (isType) {
        div.innerHTML = tag.replace(/-/g, " ").
        replace(/^.|\s./g, function (m){
          return m.toUpperCase();
        }).replace("Original","Original (op)");
      } else {
        div.innerHTML = tag;
      }
      tagIcon.classList.add("tag-icon");
      label1.appendChild(tagIcon);
      label1.appendChild(div);
      var is = document.createElement("span");
      is.appendChild(document.createTextNode("is: "))
      is.appendChild(input1);
      label2.appendChild(
        document.createTextNode("not: ")
      );
      label2.appendChild(input2);
      label1.classList.add("is");
      label2.classList.add("not");
      if (data.classList.contains("is" + rowId)) {
        input1.checked = true;
        is.classList.add("ch");
      } else if (data.classList.contains("not" + rowId)) {
        label2.classList.add("ch");
        input2.checked = true;
      }
      label1.appendChild(is);
      row.appendChild(label2);
      row.appendChild(label1);
      rowsLength++;
      return row;
    };
    var tag;
    var type;
    var widget = document.getElementById("select-by_widget");
    widget.innerHTML = "";
    var topPart = document.createElement("div");
    topPart.id = "widget-top-buttons";
    var abcSort = document.createElement("div");
    abcSort.classList.add("sort");
    abcSort.classList.add("abc");
    abcSort.appendChild(document.createTextNode("abc"));
    var numSort = document.createElement("div");
    numSort.classList.add("sort");
    numSort.classList.add("num");
    numSort.appendChild(document.createTextNode("123"));
    var dateSort = document.createElement("div");
    dateSort.classList.add("sort");
    dateSort.classList.add("date");
    dateSort.appendChild(document.createTextNode("date"));
    var redSort = document.createElement("div");
    redSort.classList.add("red");
    // the sorting method gets the arrow
    var arrow = document.createElement("div");
    arrow.classList.add("arrow");
    var widgetSortBy = data.getAttribute("widget_sort-by");
    dateSort.setAttribute("widget_sort-by", "date-down");
    abcSort.setAttribute("widget_sort-by", "abc-down");
    numSort.setAttribute("widget_sort-by", "num-down");
    if (widgetSortBy === "date-down") {
      dateSort.appendChild(arrow);
      // this is default sort method, do nothing
      dateSort.setAttribute("widget_sort-by", "date-up");
    }
    if (widgetSortBy === "date-up") {
      arrow.classList.add("reverse");
      dateSort.appendChild(arrow);
      // this is default sort method reversed
      typesAllArr.reverse();
      tagsAllArr.reverse();
    }
    if (widgetSortBy === "abc-down") {
      abcSort.appendChild(arrow);
      // sort by alphabetical
      typesAllArr.sort();
      tagsAllArr.sort();
      abcSort.setAttribute("widget_sort-by", "abc-up");
    }
    if (widgetSortBy === "abc-up") {
      arrow.classList.add("reverse");
      abcSort.appendChild(arrow);
      // sort by reverse alphabetical
      typesAllArr.sort();
      tagsAllArr.sort();
      typesAllArr.reverse();
      tagsAllArr.reverse();
    }
    var sortByCounts = function () {
      var typeArr = [];
      for(var type in typeToIds) {
        typeArr.push([typeToIds[type].length, type]);
      }
      typeArr.sort(function (a, b) {
        return parseFloat(b[0]) - parseFloat(a[0]);
      });
      for (var i = 0; i < typeArr.length; i++) {
        typesAllArr[i] = typeArr[i][1];
      }
      var tagArr = [];
      for(var tag in tagToIds) {
        tagArr.push([tagToIds[tag].length, tag]);
      }
      tagArr.sort(function (a, b) {
        return parseFloat(b[0]) - parseFloat(a[0]);
      });
      for (i = 0; i < tagArr.length; i++) {
        tagsAllArr[i] = tagArr[i][1];
      }
    };
    if (widgetSortBy === "num-down") {
      numSort.appendChild(arrow);
      // sort by counts
      sortByCounts();
      numSort.setAttribute("widget_sort-by", "num-up");
    }
    if (widgetSortBy === "num-up") {
      arrow.classList.add("reverse");
      numSort.appendChild(arrow);
      // sort by reverse counts
      sortByCounts();
      typesAllArr.reverse();
      tagsAllArr.reverse();
    }
    var sortBy = function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      data.setAttribute(
        "widget_sort-by",
        this.getAttribute("widget_sort-by")
      );
      populateSelectByWidget();
    };
    var reSte = typesAllArr.indexOf("private");
    if(reSte !== -1) {
      typesAllArr.splice(reSte, 1);
      typesAllArr.unshift("private");
    }
    var reOthr = typesAllArr.indexOf("reblog-other");
    if(reOthr !== -1) {
      typesAllArr.splice(reOthr, 1);
      typesAllArr.unshift("reblog-other");
    }
    var reSelf = typesAllArr.indexOf("reblog-self");
    if(reSelf !== -1) {
      typesAllArr.splice(reSelf, 1);
      typesAllArr.unshift("reblog-self");
    }
    var reOrgi = typesAllArr.indexOf("original");
    if(reOrgi !== -1) {
      typesAllArr.splice(reOrgi, 1);
      typesAllArr.unshift("original");
    }
    // ^ the last shall be first
    var inputFocus = function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      data.setAttribute(
        "widget_first-focus",
        this.id
      );
    };
    var memValue = function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var alreadyHidden = data.classList.contains(
        "some-posts-already-hidden"
      );
      var sb;
      var s;
      if (this.id === "uncheck") {
        s = document.getElementById(
          "select_button"
        );
        sb = s.firstChild;
        sb.innerHTML = this.checked ? "UnSelect" : "Select";
      }
      if (this.id === "show-only") {
        s = document.getElementById(
          "select_button"
        );
        sb = s.firstChild;
        sb.innerHTML = this.checked ?
          (alreadyHidden ? "ShowAll" : "Hide=!X") : "Select";
      }
      if (this.checked) {
        data.classList.add(this.id);
      } else {
        data.classList.remove(this.id);
      }
    };
    var memAndRePopulate = function () {
      var ante = document.getElementById(
        this.getAttribute("anti")
      );
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var href = document.location.href.split(/[\/\?&#=]+/g);
      if (this.checked && ante.checked) {
        ante.checked = false;
      }
      if (this.checked) {
        data.classList.add(this.id);
        data.classList.remove(ante.id);
      } else {
        data.classList.remove(this.id);
        if (ante.checked) {
          data.classList.add(ante.id);
        }
      }
    };
    dateSort.addEventListener("click", sortBy);
    abcSort.addEventListener("click", sortBy);
    numSort.addEventListener("click", sortBy);
    topPart.appendChild(numSort);
    topPart.appendChild(abcSort);
    topPart.appendChild(dateSort);
    topPart.appendChild(redSort);
    widget.appendChild(topPart);
    var scrollingPart = document.createElement("div");
    scrollingPart.classList.add("overflow-auto");
    scrollingPart.id = "widget_scrolling_part";
    widget.appendChild(scrollingPart);
    // the types / tags rows begin
    var div1 = document.createElement("div");
    div1.classList.add("tags_title");
    div1.appendChild(
      document.createTextNode(
        href[5] === "followers" || href[5] === "follows" || href[5] === "fans"?
        "Blogs By Type" :
        "Posts By Type"
      )
    );
    var wsp = document.getElementById("widget_scrolling_part");
    wsp.appendChild(div1);
    // firstly, add some integral buttons that need to go first
    var ltgtInput = document.createElement("input");
    ltgtInput.addEventListener("focus", inputFocus);
    ltgtInput.id = "hide-ltgt-than-tags";
    ltgtInput.type = "number";
    ltgtInput.addEventListener("change", function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      data.setAttribute("hide-ltgt-than-tags", this.value);
      var gtl = document.getElementById("gt_input");
      var ltl = document.getElementById("lt_input");
    });
    ltgtInput.value = parseFloat(data.getAttribute("hide-ltgt-than-tags"));
    var lt = document.createElement("input");
    lt.type = "checkbox";
    lt.id = "lt_input";
    lt.setAttribute("anti", "gt_input");
    var ltlabel = document.createElement("label");
    ltlabel.setAttribute("for", "lt_input");
    ltlabel.appendChild(document.createTextNode("Less Than"));
    var gt = document.createElement("input");
    gt.type = "checkbox";
    gt.id = "gt_input";
    gt.setAttribute("anti", "lt_input");
    var gtlabel = document.createElement("label");
    gtlabel.setAttribute("for", "gt_input");
    gtlabel.appendChild(document.createTextNode("More Than"));
    lt.checked = data.classList.contains("lt_input");
    gt.checked = data.classList.contains("gt_input");
    var hider = butt("Hide");
    hider.setAttribute("title", "Hide/Show");
    hider.addEventListener("click", function () {
      populateSelectByWidget();
    });
    var acheck = butt("Clear");
    acheck.firstChild.innerHTML = "UnCheck";
    acheck.setAttribute("title", "Uncheck All");
    acheck.addEventListener("click", function () {
      var ch = new CustomEvent("change");
      var wgt = document.getElementById("select-by_widget");
      var check = wgt.getElementsByTagName("input");
      for (var i = 0; i < check.length; i++) {
        if (
          check[i].getAttribute("type") === "checkbox" &&
          check[i].checked
        ) {
          check[i].checked = false;
          check[i].dispatchEvent(ch);
        } //else {
          //TODO ??
        //}
      }
      populateSelectByWidget();
    });
    var ltgtContainer = document.createElement("div");
    ltgtContainer.setAttribute(
      "title",
      "Hide tags that occur less than: X#"
    );
    gt.addEventListener("change", memAndRePopulate);
    lt.addEventListener("change", memAndRePopulate);
    ltgtContainer.appendChild(lt);
    ltgtContainer.appendChild(ltlabel);
    ltgtContainer.appendChild(gt);
    ltgtContainer.appendChild(gtlabel);
    ltgtContainer.appendChild(ltgtInput);
    ltgtContainer.classList.add("select-by_ltgt");
    ltgtContainer.appendChild(ltgtInput);
    ltgtContainer.appendChild(hider);
    widget.appendChild(ltgtContainer);
    // append rows for types
    var count;
    var countOver = document.getElementById("hide-ltgt-than-tags").value;
    // this boolean says to check post counts, to hide
    var lti = document.getElementById("lt_input");
    var gti = document.getElementById("gt_input");
    var postTypeTagHiddenCount = 0;
    var alreadyHidden = data.classList.contains(
      "some-posts-already-hidden"
    );
    var visibleIdsAllArr = JSON.parse(
      data.getAttribute("data-visible_ids_all_arr")
    );
    // start the types with note count rows
    var ltrow = widgetRow(
      "notes-less-than", "0", 1, svgForType.notes.cloneNode(true)
    );
    ltrow.getElementsByClassName("input_not")[0].disabled = true;
    ltrow.getElementsByClassName("not")[0].classList.add("disabled");
    var gtrow = widgetRow(
      "notes-more-than", "0", 1, svgForType.notes.cloneNode(true)
    );
    gtrow.getElementsByClassName("input_not")[0].disabled = true;
    gtrow.getElementsByClassName("not")[0].classList.add("disabled");
    var ltnumber = document.createElement("input");
    ltnumber.type = "number";
    // input focus, remembers focus, for constant DOM rebuild
    ltnumber.addEventListener("focus", inputFocus);
    var gtnumber = document.createElement("input");
    gtnumber.addEventListener("focus", inputFocus);
    gtnumber.type = "number";
    ltnumber.classList.add("number-input");
    gtnumber.classList.add("number-input");
    ltnumber.setAttribute("data-operator", "lt");
    gtnumber.setAttribute("data-operator", "gt");
    ltnumber.value = parseFloat(
      data.getAttribute("select-by-note_lt")
    );
    gtnumber.value = parseFloat(
      data.getAttribute("select-by-note_gt")
    );
    ltnumber.addEventListener("input", notesLtGt);
    gtnumber.addEventListener("input", notesLtGt);
    var quickInput = new CustomEvent("input");
    ltnumber.id = "select-by-notes_less-than";
    gtnumber.id = "select-by-notes_more-than";
    ltrow.append(ltnumber);
    gtrow.append(gtnumber);
    if (href[5] !== "follows" && href[5] !== "followers") {
      wsp.appendChild(ltrow);
      wsp.appendChild(gtrow);
    }
    // this func just counts the posts w/ note counts
    if(
      document.getElementById(
        "select-by-notes_less-than"
      ) !== null &&
      document.getElementById(
        "select-by-notes_more-than"
      ) !== null
    ) {
      document.getElementById(
        "select-by-notes_less-than"
      ).dispatchEvent(quickInput);
      document.getElementById(
        "select-by-notes_more-than"
      ).dispatchEvent(quickInput);
    }
    var div2 = document.createElement("div");
    div2.classList.add("tags_title");
    var newCount;
    var id;
    var l;
    for (var i = 0; i < typesAllArr.length; i++) {
      type = typesAllArr[i];
      if (type === "notes-more-than" || type === "notes-less-than") {
        continue;
      }
      count = typeToIds[type].length;
      if (alreadyHidden) {
        newCount = 0;
        // also do this for tags scroll below,
        // make sure id is visible
        for(l = 0; l < typeToIds[type].length; l++) {
          id = typeToIds[type][l];
          if (visibleIdsAllArr.indexOf(id) !== -1) {
            newCount++;
          }
        }
        // hide counts--; and rows that are invisible
        if(newCount === 0) {
          postTypeTagHiddenCount++;
          continue;
        } else {
          count = newCount;
        }
      }
      // skip if less than tags/type count :)
      if (
        // get both countOvers (type and tag, scroll down :)
        (
          type !== "reblog-self" &&
          type !== "reblog-other"
        ) && (
          (count < countOver && lti.checked) ||
          (count > countOver && gti.checked)
        )
      ) {
        postTypeTagHiddenCount++;
        continue;
      }
      wsp.appendChild(
        widgetRow(
          type, count, 1, svgForType[type].cloneNode(true)
        )
      );
    }
    // types / tags seperator
    div2.appendChild(
      document.createTextNode(
        href[5] === "followers" || href[5] === "follows" ?
        "" :
        "Posts By Tag"
      )
    );
    wsp.appendChild(div2);
    // append rows for tags
    for (i = 0; i < tagsAllArr.length; i++) {
      tag = tagsAllArr[i];
      count = tagToIds[tag].length;
      if (alreadyHidden) {
        newCount = 0;
        // also do this for types up above
        for(l = 0; l < tagToIds[tag].length; l++) {
          id = tagToIds[tag][l];
          if (visibleIdsAllArr.indexOf(id) !== -1) {
            newCount++;
          }
        }
        // hide counts--; and rows that are invisible (AGAIN)
        if(newCount === 0) {
          postTypeTagHiddenCount++;
          continue;
        } else {
          count = newCount;
        }
      }
      // skip if tags amount to lessThan / moreThan
      if (
        // get both countOvers (scroll up :)
        (count < countOver && lti.checked) ||
        (count > countOver && gti.checked)
      ) {
        postTypeTagHiddenCount++;
        continue;
      }
      wsp.appendChild(
        widgetRow(
          tag, count, 0, svgForType.tag.cloneNode(true)
        )
      );
    }
    // finish with the tags, show hidden count in top
    var wigTB = document.getElementById("widget-top-buttons");
    var redTB = wigTB.getElementsByClassName("red")[0];
    if (postTypeTagHiddenCount !== 0) {
      redTB.innerHTML = postTypeTagHiddenCount + " rows hidden";
    } else {
      wigTB.removeChild(redTB);
    }
    var re = butt("List");
    re.setAttribute("title", "Refresh Tags/Type List...");
    re.firstChild.innerHTML = "Refresh";
    re.addEventListener("click", function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var wsp = document.getElementById("widget_scrolling_part");
      data.setAttribute("widget_scroll-top", wsp.scrollTop);
      // refresh the tag select by widget
      document.getElementById("lt_input").checked = false;
      document.getElementById("gt_input").checked = false;
      data.classList.remove("lt_input");
      data.classList.remove("gt_input");
      populateSelectByWidget();
    });
    var cancel = butt("Cancel1");
    cancel.firstChild.innerHTML = "&#x274C;";
    cancel.setAttribute("title", "Cancel and Close Widget...");
    cancel.addEventListener("click", function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var pick = document.getElementsByClassName("picked");
      while (pick.length > 0) {
        pick[0].classList.remove("picked");
      }
      var wsp = document.getElementById("widget_scrolling_part");
      data.setAttribute("widget_scroll-top", wsp.scrollTop);
      document.getElementById("select-by").checked = false;
    });
    var needle = parseFloat(
      data.getAttribute("data-select-by_needle")
    );
    var selecto = butt("Select"); // this is the select-by/show-by button
    if (data.classList.contains("show-only")) {
      selecto.firstChild.innerHTML = (alreadyHidden ? "ShowAll" : "Hide=!X");
    } else if (
      needle > 0 &&
      !data.classList.contains("uncheck")
    ) {
      selecto.firstChild.innerHTML = "100more";
    }
    // "select by tag" "select by type"
    selecto.addEventListener("click", function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var limit = 100; // tumblr limit, for classic mass tag api
      var needle = parseFloat(
        data.getAttribute("data-select-by_needle")
      );
      var s = document.getElementById(
        "select_button"
      );
      var sb = s.firstChild;
      // Mass Post Features v3 by benign-mx (me) Jake Jilg
      // oh wait. I don't need this^ anymore... :) sorry...
      precountTheSelection();
      // continued from this^ function @ var precountTheSelection
      var toSelect = JSON.parse(
        data.getAttribute("data-to-select")
      );
      var idsAllArr = JSON.parse(
        data.getAttribute("data-ids_all_arr")
      );
      var alreadyHidden = data.classList.contains(
        "some-posts-already-hidden"
      );
      var visibleIdsAllArr = JSON.parse(
        data.getAttribute("data-visible_ids_all_arr")
      );
      var hl;
      var un = data.classList.contains("uncheck");
      var regularSelect = !data.classList.contains("show-only");
      // and finally select some posts
      var i = 0;
      var id;
      var hlBrick;
      hl = document.getElementsByClassName("highlighted");
      var needleBefore = needle;
      var selectedCount = 0;
      if (regularSelect) {
        while (hl.length > 0 && needle !== 0) {
          highlightBrick(hl[0], 0);
        }
        for (i = needle; i < toSelect.length; i++) {
          hlBrick = document.getElementById("post_" + toSelect[i]);
          if (hlBrick !== null) {
            // or deselect if uselect is checked
            if (!un) {
              needle++;
              if (needle > needleBefore + limit) { // stop at 100 select
                break;
              }
            }
            selectedCount++;
            highlightBrick(hlBrick, !un);
          }
        }
        if (selectedCount < limit) {
          needle = 0;
        }
        data.setAttribute("data-select-by_needle", needle);
      } else {
        // but this is the ShowOnly mode thing... :)
        var needRebuild = false;
        var brick;
        if (!alreadyHidden) {
          sb.innerHTML = "ShowAll";
          s.disabled = false;
          data.classList.add(
            "some-posts-already-hidden"
          );
          for (i = 0; i < idsAllArr.length; i++) {
            id = idsAllArr[i];
            brick = document.getElementById("post_" + id);
            if (toSelect.indexOf(id) !== -1){
               visibleIdsAllArr.push(id);
            }// a clone of toSelect,
            // but this staggers back for more after selections :)
            if (
              toSelect.indexOf(id) === -1 &&
              brick !== null
            ) {
              needRebuild = true;
              brick.classList.remove("brick");
              brick.classList.remove("laid");
              brick.classList.remove("highlighted");
              brick.classList.add("display-none");
            } else if (
              toSelect.indexOf(id) !== -1 &&
              brick !== null &&
              brick.classList.contains("display-none")
            ) {
              needRebuild = true;
              brick.classList.add("brick");
              brick.classList.add("laid");
              brick.classList.remove("display-none");
            }
          }
        } else {
          sb.innerHTML = "Hide=!X";
          var dn = document.getElementsByClassName("display-none");
          data.classList.remove(
            "some-posts-already-hidden"
          );
          needRebuild = dn.length > 0;
          while (dn.length > 0) {
            dn[0].classList.add("brick");
            dn[0].classList.add("laid");
            // this goes lass, or else dn[0] becomes undefined :)
            dn[0].classList.remove("display-none");
          }
        }
        if (needRebuild) {
          pluginBuildColumns();
        }
      }
      data.setAttribute(
        "data-visible_ids_all_arr",
        JSON.stringify(visibleIdsAllArr)
      );
      postCountMake();
      populateSelectByWidget();
    });
    cancel.setAttribute("title", "Close Widget");
    selecto.setAttribute("title", "Select or Show");
    widget.appendChild(selecto);
    widget.appendChild(cancel);
    widget.appendChild(acheck);
    widget.appendChild(re);
    var unlabel = document.createElement("label");
    var uncheck = document.createElement("input");
    uncheck.type = "checkbox";
    uncheck.id = "uncheck";
    uncheck.addEventListener("change", memValue);
    if (data.classList.contains("uncheck")) {
      uncheck.checked = true;
    }
    unlabel.setAttribute("for", "uncheck");
    unlabel.appendChild(document.createTextNode("Un"));
    var h1 = document.createElement("div");
    var shoLabel = document.createElement("label");
    var shoInput = document.createElement("input");
    shoInput.id = "show-only";
    shoInput.addEventListener("change", memValue);
    if (data.classList.contains("show-only")) {
      shoInput.checked = true;
    }
    shoInput.type = "checkbox";
    shoLabel.setAttribute("for", "show-only");
    shoLabel.appendChild(document.createTextNode("Show Only"));
    h1.appendChild(shoInput);
    h1.appendChild(shoLabel);
    h1.appendChild(uncheck);
    h1.appendChild(unlabel);
    h1.id = "select-by-widget_title";
    var innerSpan = document.createElement("span");
    innerSpan.appendChild(document.createTextNode("Select"));
    var countSpan = document.createElement("span");
    countSpan.classList.add("preselect-count");
    countSpan.appendChild(document.createTextNode("(x0)"));
    countSpan.setAttribute("title", "Selecting X Many...")
    innerSpan.appendChild(countSpan);
    h1.appendChild(innerSpan);
    // refocus number inputs
    var ff = document.getElementById(widgetFirstFocus);
    ff.focus();
    // all elements added, go back down/up scrollTop
    wsp.scrollTo(
      0,
      parseFloat(
        data.getAttribute("widget_scroll-top")
      )
    );
    // lastly, the title element textNode
    widget.appendChild(h1);
    precountTheSelection();
  }; // end var populateSelectByWidget

  // this had an alert(); yucky
  document.getElementById("unselect").
  parentNode.setAttribute(
    "onclick",
    (function () {
      var hl = document.getElementsByClassName("highlighted");
      while(hl.length > 0) {
        hl[0].classList.add("prevent-anim");
        hl[0].classList.remove("edit-reblog-queue");
        hl[0].classList.remove("highlighted");
      }
      window.postCountMake();
      return false;
    }).toString().slice(13,-1)
  );
  // end alert fix

  // this had escaped%20spaces in the tags eww!
  document.getElementById(
    "tags_loading"
  ).parentNode.removeChild(
    document.getElementById(
      "tags_loading"
    )
  );
  document.getElementById("remove_tags").
  parentNode.setAttribute(
    "onclick",
    (function () {
      window.just_clicked_remove_tags = !0;
      var hl = document.getElementsByClassName("highlighted");
      if (hl.length === 0) {
        document.getElementById(
          "no_tags_message"
        ).style.display = "block";
        document.getElementById(
          "remove_tag_button"
        ).style.display = "none";
      } else {
        document.getElementById(
          "remove_tag_button"
        ).style.display = "block";
        document.getElementById(
          "no_tags_message"
        ).style.display = "none";
      }
      document.getElementById(
        "remove_tags_widget"
      ).style.display = "block";
      return false;
    }).toString().slice(13,-1)
  );
  // end escape fix up in

  // these functions are only in plugin scope

  // API...? Where we are going, we won't need API :)
  var getResponseText = function (url, read, header) {
    var post = undefined;
    if (typeof url === "object") {
      post = url.post;
      url = url.url;
      // this ^ twist, maybe not elegant?
    }
    var get = "GET";
    if (// special URLs, make POST
      "/svc/secure_form_key" === url ||
      "/svc/post/update" === url.split(/\?/)[0] ||
      "/svc/post/upload_photo" === url.split(/\?/)[0] ||
      "/svc/post/upload_text_image" === url.split(/\?/)[0] ||
      "customize_api" === url.split("/")[1] &&
      typeof post !== "undefined"
    ) {
      get = "POST";
    }
    var xhttp = new XMLHttpRequest();
    xhttp.onreadystatechange = function () {
      if (
        this.readyState == 4 && this.status == 200 &&
        typeof this.responseText !== "undefined"
      ) {
        read(
          "/svc/secure_form_key" === url ?
          { // we need the puppies, to make a new post
            puppies: this.getResponseHeader("x-tumblr-secure-form-key"),
            kittens: /* this.getAllResponseHeaders() */ 0
          } :// Idk what kittens is, but it happens after success
              this.responseText
        );
      }
      if (this.readyState == 4 && this.status != 200) {
        if (typeof responseText !== "undefined") {
          read("{\"response\":{\"is_friend\":false}}");
        } else {
          read(400);
        }
      }
    };
    xhttp.open(get, url, true);
    xhttp.onerror = function(){
      read(400);
    };
    // headers only after open and only before send
     if(typeof header !== "undefined") {
      for(var i = 0; i < header.length; i++) {
         xhttp.setRequestHeader(header[i][0], header[i][1]);
      }
    }
    if (get === "GET") {
      xhttp.send();
    } else {
      xhttp.send(post);
    }
  };

  // add a bouncey reblog or heart
  var reblogAnimation = function(id) {
    var cb = document.getElementById("post_" + id);
    var bigReblog = svgForType["reblog-self"].cloneNode(true);
    bigReblog.setAttribute("fill", "#7EFF29");
    bigReblog.setAttribute("width", "125");
    bigReblog.setAttribute("height", "125");
    bigReblog.classList.add("big-reblog");
    bigReblog.addEventListener("mousedown", function(){
      this.parentNode.removeChild(this);
    });
    setTimeout(function(){
      bigReblog.parentNode.removeChild(bigReblog);
    }, 1700);
    cb.appendChild(bigReblog);
  }
  // a bouncey horsey ^

  // this v creates a post template with selected blogs
  var blogDropping = false;
  var newPostNameDrop = function() {
    if (blogDropping) {
      return;
    }
    blogDropping = true;
    var highlighted = document.getElementsByClassName("highlighted");
    var portraits = document.createElement("canvas");
    var canvas = document.createElement("canvas");
    var ctx = canvas.getContext("2d");
    var pCtx = portraits.getContext("2d");
    var img;
    var l = 0;
    var t = 0;
    var w = 5;
    var d;
    portraits.width = w * 128;
    portraits.height = Math.ceil(highlighted.length / w) * 128;
    var blogList = [];
    for (var i = 0; i < highlighted.length; i++) {
      img = highlighted[i].getElementsByClassName("follower-avatar")[0];
      blogList.push(highlighted[i].getAttribute("data-name"));
      ctx.drawImage(img, 0, 0);
      pCtx.drawImage(canvas, l * 128, t * 128);
      l++;
      if (l >= w) {
        l = 0;
        t++;
      }
    }
    portraits.toBlob(function(blob) {
      var formData = new FormData();
      formData.append("image", blob, "image" + (new Date()).getTime() + ".png");
      var apiKey = data.getAttribute("data-x-tumblr-form-key");
      getResponseText(
        {url: "/svc/post/upload_text_image?post_id=undefined&channel=" + name, post: formData},
        function(re){
          api = JSON.parse(re);
          var img = new Image();
          var rawWidth = portraits.width;
          var rawHeight = portraits.height;
          if (
            typeof api !== "undefined" &&
            typeof api[0] !== "undefined" &&
            typeof api[0].url !== "undefined"
          ) {
            img.src = api[0].url;
            rawWidth = api[0].raw_width;
            rawHeight = api[0].raw_height;
          } else {
            img.src = portraits.toDataURL();
          }// whether we get the URL or not, the show must go on
          var mediaHolder = document.createElement("div");
          mediaHolder.classList.add("media-holder");
          mediaHolder.classList.add("media-holder-draggable");
          mediaHolder.classList.add("media-holder-figure");
          mediaHolder.setAttribute("contenteditable", "false");
          mediaHolder.setAttribute("draggable", "true");
          mediaHolder.style.display = "block";
          var mediaFigure = document.createElement("figure");
          mediaFigure.setAttribute("data-orig-width", rawWidth);
          mediaFigure.setAttribute("data-orig-height", rawHeight);
          img.setAttribute("data-orig-width", rawWidth);
          img.setAttribute("data-orig-height", rawHeight);
          var mediaRemove = document.createElement("div");
          mediaRemove.classList.add("media-button");
          mediaRemove.classList.add("icon_close");
          mediaRemove.classList.add("media-killer");
          mediaFigure.appendChild(img);
          mediaHolder.appendChild(mediaFigure);
          mediaHolder.appendChild(mediaRemove);
          var iframe2 = document.createElement("iframe");
          iframe2.id = "neue_post_form-iframe";
          iframe2.addEventListener("load", function () {
            blogDropping = false;
            var posterPending = true;
            var titlePending = true;
            // this checks if done editing/closed
            var reminisce2 = setInterval(function () {
              var w = document.getElementById(
                "neue_post_form-iframe"
              ).contentWindow;
              var p = w.document.getElementsByClassName(
                "post-forms-modal"
              )[0];
              var span;
              var ul;
              var br;
              var a;
              var editor = w.document.getElementsByClassName("editor-richtext");
              var title = w.document.getElementsByClassName("editor-plaintext");
              if (editor.length > 0 && posterPending) {
                span = document.createElement("p"); // it was going to be a span
                span.appendChild(
                   document.createTextNode(
                     "I want to give a shout out to these awesome blags!"
                   )
                );
                ul = document.createElement("p"); // and a ul, but the links
                for (var i = 0; i < blogList.length; i++) {
                  br = document.createElement("br");
                  ul.appendChild(
                    document.createTextNode(
                      " @" + blogList[i] + " "
                    )
                  );
                  ul.appendChild(br); // didn't refer popovers for some reason
                }
                posterPending = false;
                editor[0].appendChild(span);
                editor[0].appendChild(mediaHolder);
                editor[0].appendChild(ul);
                editor[0].focus();
                editor[0].dispatchEvent(new Event("input"));
              }
              if (editor.length > 0 && titlePending) {
                titlePending = false;
                span = document.createElement("span");
                span.appendChild(
                   document.createTextNode(
                     "Blog Name Drop"
                   )
                );
                title[0].appendChild(span);
              }
              if (
                typeof p === "undefined" ||
                typeof p !== "undefined" &&
                p.length === 0 ||
                typeof p !== "undefined" &&
                (
                  w.getComputedStyle(p).
                  getPropertyValue("display") === "none" ||
                  w.getComputedStyle(p).
                  getPropertyValue("opacity").toString() === "0"
                )
              ) {
                clearInterval(reminisce2);
                document.body.removeChild(
                  document.getElementById("neue_post_form-iframe")
                );
              }
            }, 500);
          });
          iframe2.src = "https://www.tumblr.com/neue_web/iframe/blog/" +
            name + "/new/text";
          iframe2.setAttribute("scrolling", "no");
          iframe2.setAttribute("frameborder", "0");
          iframe2.setAttribute("title", "Post forms");
          document.body.appendChild(iframe2);
        },
        [
          ["X-tumblr-form-key", apiKey],
          ["X-Requested-With", "XMLHttpRequest"]
        ]
      )
    });
  };
  // this ^ creates a post template with selected blogs

  // this function follows and unfollows
  var followOrUnFollow = function(liked, info, button, repeat) {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    var apiKey = data.getAttribute("data-x-tumblr-form-key");
    var v2url = liked ?
        "/svc/unfollow" : "/svc/follow";
    var xhttp = new XMLHttpRequest();
    var whiteHeart;
    xhttp.onreadystatechange = function () {
      var href = document.location.href.split(/[\/\?&#=]+/g);
      if (this.readyState == 4 && this.status == 200) {
        data.setAttribute(
          "data-unstable-next-href",
          parseInt(
            data.getAttribute("data-unstable-next-href")
          ) + (liked ? -1 : 1)
        );
        button.innerHTML = "";
        var cb = document.getElementById(
          "post_" + button.getAttribute("data-id")
        );
        if (liked) {
          if (button.classList.contains("return-to-secondary")) {
            whiteHeart = svgForType.secondary.cloneNode(true);
            whiteHeart.setAttribute("fill", "#fff");
            button.setAttribute(
              "title",
              "UnFollowed Secondary. " +
              "It will be gone after you leave."
            );
          } else {
            whiteHeart = svgForType.notes.cloneNode(true);
            whiteHeart.setAttribute("fill", "#fff");
            button.setAttribute(
              "title",
              href[5] === "follows" ?
              "You no longer follow this blog." +
              "It will be gone after you leave." :
              "Click to Follow this Follower back :)"
            );
          }
          button.classList.remove("liked");
          button.classList.add("not-liked");
          cb.classList.remove("fellow");
          idToTypes[
            button.getAttribute("data-id")
          ] = "friendly";
          typeToIds["mutual"].splice(
            typeToIds["mutual"].indexOf(
              button.getAttribute("data-id")
            ), 1
          );
          typeToIds["friendly"].push(button.getAttribute("data-id"));
        } else {
          idToTypes[
            button.getAttribute("data-id")
          ] = "mutual";
          typeToIds["friendly"].splice(
            typeToIds["friendly"].indexOf(
              button.getAttribute("data-id")
            ), 1
          );
          typeToIds["mutual"].push(button.getAttribute("data-id"));
          if (button.classList.contains("return-to-secondary")) {
            whiteHeart = svgForType.secondary.cloneNode(true);
            whiteHeart.setAttribute("fill", "#9af");
            button.setAttribute(
              "title",
              "Secondary Blog:\n" +
              "Only primaries can follow you back." +
              "\n(click to unfollow)"
            );
          } else {
            whiteHeart = svgForType.liked.cloneNode(true);
            whiteHeart.setAttribute("fill", "#56f");
            button.setAttribute("title", "Mutual (Click to UnFollow)");
          }
          button.classList.add("liked");
          button.classList.remove("not-liked");
          // graphical aftertaste for reblog/follow
          var bigHeart = svgForType.liked.cloneNode(true);
          bigHeart.setAttribute("fill", "#56f");
          bigHeart.setAttribute("width", "125");
          bigHeart.setAttribute("height", "125");
          bigHeart.classList.add("big-heart");
          setTimeout(function(){
            bigHeart.parentNode.removeChild(bigHeart);
          }, 1700);
          cb.appendChild(bigHeart);
          button.classList.add("new-liked");
        }// liked means followed here; this saves css space
        button.appendChild(whiteHeart);
        button.classList.remove("clicked");
        var erq = document.getElementsByClassName("edit-reblog-queue");
        if (typeof repeat !== "undefined" && erq.length > 0) {
          erq[erq.length-1].classList.remove("edit-reblog-queue");
          repeat();
        }
        data.setAttribute(
          "data-id_to_types",
          JSON.stringify(idToTypes)
        );
        data.setAttribute(
          "data-type_to_ids",
          JSON.stringify(typeToIds)
        );
      }
    };
    xhttp.open("POST", v2url, true);
    // headers only after open and only before send
    xhttp.setRequestHeader(
      "X-tumblr-form-key", apiKey
    );
    xhttp.setRequestHeader(
      "Content-Type",
      "application/x-www-form-urlencoded; charset=UTF-8"
    );
    xhttp.setRequestHeader(
      "X-Requested-With", "XMLHttpRequest"
    );
    xhttp.send(info);
  };
  var followOrUnfollowSelected = function() {
    var erq = document.getElementsByClassName("edit-reblog-queue");
    var hl = document.getElementsByClassName("highlighted");
    while (erq.length < hl.length) {
      hl[erq.length].classList.add("edit-reblog-queue");
    }
    var repeat = function () {
      var erq = document.getElementsByClassName("edit-reblog-queue");
      var key = erq[erq.length-1].getAttribute("data-follower-key");
      var button = document.getElementById("follow_heart_" + key);
      var info = button.getAttribute("data-like-info");
      var liked = document.getElementById(
        "unfollow_button"
      ).getAttribute("data-follow") !== "true";
      followOrUnFollow(liked, info, button, repeat);
    };
    repeat(); // and follow/unfollow
  };
  // this v runs on a button ^ this runs 1 or many buttons
  var followOrUnFollowButton = function (e) {
    e.cancelBubble = true;
    e.stopPropagation();
    e.preventDefault();
    if (this.classList.contains("clicked")) {
      return;
    }
    this.classList.remove("new-liked");
    this.classList.add("clicked");
    var button = this;
    var liked = this.classList.contains("liked");
    var info = this.getAttribute("data-like-info");
    followOrUnFollow(liked, info, button);
  };
  // fun :)
  var stopToFindMutuals = function (
  me, them, url, key, link3, followerBrick, finished
  ) { // since the following API has no followback property...
    // the followers API has a followback propery tho; I guess
    // it's only because we know they already follow you...
    followerBrick.classList.add("following");
    // also ^ since these are your follows/following
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var tblg = JSON.parse(
      data.getAttribute("data-tumblelogs")
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    if (typeof typeToIds["friendly"] === "undefined") {
      typeToIds["friendly"] = [];
    }
    if (typeof typeToIds["mutual"] === "undefined") {
      typeToIds["mutual"] = [];
    }
    if (typeof typeToIds["secondary"] === "undefined") {
      typeToIds["secondary"] = [];
    }
    var apiKey = data.getAttribute("data-x-tumblr-form-key");
    var primary = data.getAttribute("data-primary-blog");
    getResponseText(
      "/svc/blog/followed_by?tumblelog=" + tblg[me] + "&query=" + them,
      function (re) {
        link3.classList.add("liked");
        // this ^ comes in for all blogs on this page, because we already follow
        var whiteHeart;
        if(re === 400) { // these fill the error console with
          // ajax err messages, but this is the Tumblr server's own
          // throw; I don't know how to stop it... try catch, doesn't
          // work for asynchronous...
          // regardless, it still works :D
          console.log(
            "/svc/blog/followed_by?tumblelog=" + tblg[me] + "&query=" + them +
            "\nSecondary blogs can't follow blogs. Error 400 is thrown when" +
            "\nthose do not exist in the mutual followers database."
          );
          typeToIds["secondary"].push(key);
          idToTypes[key] = "secondary";
          whiteHeart = svgForType.friendly.cloneNode(true);
          whiteHeart.setAttribute("fill", "#9af");
          link3.href = url;
          link3.setAttribute(
            "title",
            "Secondary Blog:\n" +
            "Only primaries can follow you back." +
            "\n(click to unfollow)"
          );
          link3.classList.add("not-liked");
          link3.appendChild(whiteHeart);
          link3.classList.add("return-to-secondary");
          data.setAttribute(
            "data-id_to_types",
            JSON.stringify(idToTypes)
          );
          data.setAttribute(
            "data-type_to_ids",
            JSON.stringify(typeToIds)
          );
          link3.addEventListener("click", followOrUnFollowButton);
          followerBrick.classList.remove("missing-follows-info");
          setTimeout(finished, 40);
          return;
          // I use timeouts to slow it down on the repeat
          // checkIfFollowing seeIfFollowing etc. stuff
          // because when I leave the connection open too long
          // it makes more error 400s which are false errs
          // not to be confused with the true error 400s which
          // come from secondary blogs that can't follow you
        }
        var api = JSON.parse(re);
        if (
          typeof api !== "undefined" &&
          typeof api.response !== "undefined" &&
          typeof api.response.is_friend !== "undefined"
        ) {
          if (
            api.response.is_friend
          ) {
            typeToIds["mutual"].push(key);
            followerBrick.classList.add("mutual");
            idToTypes[key] = "mutual";
            whiteHeart = svgForType.liked.cloneNode(true);
            whiteHeart.setAttribute("fill", "#56f");
            link3.href = url + "#unfollow:" + tblg[me];
            link3.setAttribute(
              "title",
              "Mutual of " + tblg[me] + " and more..."+
              "\n(Click to UnFollow)"
            );
            link3.appendChild(whiteHeart);
            data.setAttribute(
              "data-id_to_types",
              JSON.stringify(idToTypes)
            );
            data.setAttribute(
              "data-type_to_ids",
              JSON.stringify(typeToIds)
            );
            link3.addEventListener("click", followOrUnFollowButton);
            followerBrick.classList.remove("missing-follows-info");
            setTimeout(finished, 40);
            // mutual doesn't need to be retested again...
            // a friend is a friend, if they follow any
            // of your blogs
            return;
          } else {
            // not a 2ndary, but not a follower
            // see if following other blogs instead...?
            if (me >= tblg.length - 1) {
              // not following anyone; df just a friendly
              typeToIds["friendly"].push(key);
              idToTypes[key] = "friendly";
              whiteHeart = svgForType.liked.cloneNode(true);
              whiteHeart.setAttribute("fill", "#56f");
              link3.href = url + "#unfollow:" + them;
              link3.setAttribute("title", "Click to UnFollow");
              // these will all be unfollow buttons, because
              // we are following everybody on this page
              link3.classList.add("not-liked");
              link3.appendChild(whiteHeart);
              data.setAttribute(
                "data-id_to_types",
                JSON.stringify(idToTypes)
              );
              data.setAttribute(
                "data-type_to_ids",
                JSON.stringify(typeToIds)
              );
              link3.addEventListener("click", followOrUnFollowButton);
              followerBrick.classList.remove("missing-follows-info");
              setTimeout(finished, 40);
            } else {
              // we have more blogs to check
              setTimeout(
                function () {
                  stopToFindMutuals(
                    (me + 1), them, url, key, link3, followerBrick, finished
                  );
                }, 40
              );
            }
          }
        }
      }
    );
  };
  // this ^ checks if blogs you follow, follow back

  // this v makes the snapshot saves to a theme page
  var makeSnap = function (cat) {
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var fblg = JSON.parse(
      data.getAttribute("data-follow-blogs-all")
    );
    var mblg = JSON.parse(
      data.getAttribute("data-missing-blogs-all")
    );
    var nblg = JSON.parse(
      data.getAttribute("data-new-blogs-all")
    );
    var fblgTimestamp = JSON.parse(
      data.getAttribute("data-follow-blogs-all-updated")
    );
    var mblgTimestamp = JSON.parse(
      data.getAttribute("data-missing-blogs-all-updated")
    );
    var nblgTimestamp = JSON.parse(
      data.getAttribute("data-new-blogs-all-updated")
    );
    if (nblgTimestamp === 0) {
      nblgTimestamp = (new Date()).getTime();
    }
    if (mblgTimestamp === 0) {
      mblgTimestamp = (new Date()).getTime();
    }
    if (fblgTimestamp === 0) {
      fblgTimestamp = (new Date()).getTime();
    }
    var body = {
      "missing": mblg,
      "new": nblg,
      "all": fblg,
      "all-ch" : fblgTimestamp, // followers
      "new-ch" : nblgTimestamp, // new followers
      "missing-ch" : mblgTimestamp // missing followers
    };
    getResponseText( // this is SnapShot thing step #1
      "/customize/" + href[4],
      function(re2) {
        var div = document.createElement("div");
        div.innerHTML = re2. // parse the dom
        replace(/<(\/?)script[^>]*>/g, "<$1flurb>"). // no eval
        replace(/<img/g,"<space"); // do not onload img tags
        var flurb = div.getElementsByTagName("flurb");
        var userFormKey = false;
        var secureFormKey = false;
        var i;
        var reg1 = /Tumblr._init.user_form_key\s?=\s?['"]([^'"]+)['"]/;
        var reg2 = /Tumblr._init.secure_form_key\s?=\s?['"]([^'"]+)['"]/;
        for (i = 0; i < flurb.length; i++) {
          if (flurb[i].innerHTML.match(reg1) !== null) {
            userFormKey = flurb[i].innerHTML.match(reg1)[1];
          }
          if (flurb[i].innerHTML.match(reg2) !== null) {
            secureFormKey = flurb[i].innerHTML.match(reg2)[1];
          }
        }
        if (secureFormKey === false || userFormKey === false) {
          return;
        }
        var dogTreat = {
          "type": "custom_layout",
          "request_uri": "/mass-post-editor-snapshot-" + cat + "-data",
          "native_uri": false,
          "label": "",
          "show_link": false,
          "title": "",
          "body": JSON.stringify(body),
          "redirect_to": "",
          "user_form_key": userFormKey, // kittens
          "secure_form_key": secureFormKey // puppies
        };
        getResponseText(
          { // this is SnapShot thing step #2
            url: "/customize_api/blog/" + href[4] + "/pages",
            post: JSON.stringify(dogTreat)
          },
          function(re3) {
            // success
          },
          [ // the prev request brought us some puppies :)
            ["X-Requested-With", "XMLHttpRequest"],
            ["Content-Type", "application/json"],
            ["Accept", "application/json, text/javascript, */*; q=0.01"]
          ]
        );
      },
      [
        ["X-Requested-With", "XMLHttpRequest"]
      ]
    );
  };
  // this ^ makes a snapshot

  // this v reads the snapshot saves of a theme page
  var readSnap = function (cat, old) {
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var fblg = JSON.parse(
      data.getAttribute("data-follow-blogs-all")
    );
    var mblg = JSON.parse(
      data.getAttribute("data-missing-blogs-all")
    );
    var nblg = JSON.parse(
      data.getAttribute("data-new-blogs-all")
    );
    var fblgTimestamp = JSON.parse(
      data.getAttribute("data-follow-blogs-all-updated")
    );
    var mblgTimestamp = JSON.parse(
      data.getAttribute("data-missing-blogs-all-updated")
    );
    var nblgTimestamp = JSON.parse(
      data.getAttribute("data-new-blogs-all-updated")
    );
    var snapBody = document.getElementById("snapshot-info_body");
    var bodyNew = {
      "missing": mblg,
      "new": nblg,
      "all": fblg,
      "all-ch" : fblgTimestamp, // followers
      "new-ch" : nblgTimestamp, // new followers
      "missing-ch" : mblgTimestamp // missing followers
    };
    getResponseText(
      {
        url: "/customize_api/blog/" + href[4] + "/pages",
        post:
          "method=read&uri=/mass-post-editor-snapshot-" +
          cat + "-data"
      },
      function (re) {
        if (re === 400) {
          var h2 = document.createElement("h2");
          h2.appendChild(
            document.createTextNode(
              "There is no recorded snapshot prior, " +
              "but one was just now made for future."
            )
          );
          snapBody.appendChild(h2);
          // normally data changes would go here,
          // but there is no old data to compare to
          if (!old) {
            makeSnap(cat);
          }
          // ^ blank new snapshot
        } else if (typeof re === "string") {
          var bodyOld = JSON.parse(JSON.parse(re).body);
          // 1 parse for object, +1 parse for its property
          var i;
          var blog;
          if (!old) {
            // first find new followers
            for (i = 0; i < bodyNew.all.length; i++) {
              blog = bodyNew.all[i];
              if (bodyOld.all.indexOf(blog) === -1) {
                bodyNew.new.push(blog);
              }
            }
            // then find missing followers
            for (i = 0; i < bodyOld.all.length; i++) {
              blog = bodyOld.all[i];
              if (bodyNew.all.indexOf(blog) === -1) {
                bodyNew.missing.push(blog);
              }
            }
            // now mind the new timestamps if any
            if (bodyNew.new.length > 0) {
              nblgTimestamp = (new Date).getTime(); // new
              fblgTimestamp = (new Date).getTime(); // all
            }
            if (bodyNew.missing.length > 0) {
              mblgTimestamp = (new Date).getTime(); // missing
              fblgTimestamp = (new Date).getTime(); // all
            }
          // tally the old with the new for record purposes
            for (i = 0; i < bodyNew.new.length; i++) {
              blog = bodyNew.new[i];
              if (bodyOld.new.indexOf(blog) === -1) {
                bodyOld.new.push(blog);
              }
            }
            for (i = 0; i < bodyNew.missing.length; i++) {
              blog = bodyNew.missing[i];
              if (bodyOld.missing.indexOf(blog) === -1) {
                bodyOld.missing.push(blog);
              }
            }
          }
          // sit down and show the results
          var snapCell1 = document.createElement("div");
          var snapCell2 = document.createElement("div");
          snapCell1.id = "missing-blogs";
          snapCell2.id = "new-blogs";
          var title1 = document.createElement("h2");
          var title2 = document.createElement("h2");
          title1.appendChild(
            document.createTextNode(
              "Missing Blogs"
            )
          );
          title2.appendChild(
            document.createTextNode(
              "New Blogs"
            )
          );
          snapBody.appendChild(title1);
          snapBody.appendChild(title2);
          // I'm running out of dexterity for making variable names
          var toTheBuns = function () {
            data.setAttribute(
              this.getAttribute("data-representing"),
              JSON.stringify([]) // this clears only
            );
            var a = document.getElementById(
              this.getAttribute("data-links-id")
            ).children;
            while (a.length > 0) {
              a[0].parentNode.removeChild(a[0]);
            }
            // "this parent node remove child this" :)
            this.parentNode.removeChild(this);
            // ^ what I said to my parents when I realized the
            // meaning of life is only a constructed meaning....
            makeSnap(cat);
          };
          var a;
          var leftBuns = butt("Forget1");
          leftBuns.setAttribute(
            "title",
            "Forget/Clear missing blogs from database."
          );
          leftBuns.setAttribute(
            "data-representing",
            "data-missing-blogs-all"
          );
          leftBuns.setAttribute(
            "data-links-id",
            "missing-blogs"
          );
          leftBuns.addEventListener("click", toTheBuns);
          var rightBuns = butt("Forget2");
          rightBuns.setAttribute(
            "title",
            "Forget/Clear new blogs from database."
          );
          rightBuns.setAttribute(
            "data-representing",
            "data-new-blogs-all"
          );
          rightBuns.setAttribute(
            "data-links-id",
            "new-blogs"
          );
          rightBuns.addEventListener("click", toTheBuns);
          for (i = 0; i < bodyOld.new.length; i++) {
            a = document.createElement("a");
            a.href = "https://www.tumblr.com/dashboard/blog/" + bodyOld.new[i];
            a.appendChild(
              document.createTextNode(
                bodyOld.new[i]
              )
            );
            a.target = "_blank";
            a.setAttribute(
              "title",
              bodyOld.new[i] + " is a new blag :)"
            );
            snapCell2.appendChild(a);
          }
          for (i = 0; i < bodyOld.missing.length; i++) {
            a = document.createElement("a");
            a.href = "https://" + bodyOld.missing[i] + ".tumblr.com/";
            a.appendChild(
              document.createTextNode(
                bodyOld.missing[i]
              )
            );
            a.target = "_blank";
            a.setAttribute(
              "title",
              bodyOld.missing[i] + " is missing, but mayhaps changed their name"
            );
            snapCell1.appendChild(a);
          }
          snapBody.appendChild(snapCell1);
          snapBody.appendChild(snapCell2);
          // but only if there is any news when compared to the past
          if (bodyOld.missing.length > 0 && !old) {
            snapBody.appendChild(leftBuns);
          }
          if (bodyOld.new.length > 0 && !old) {
            snapBody.appendChild(rightBuns);
          }
          if (!old) {
            data.setAttribute(
              "data-follow-blogs-all",
              JSON.stringify(bodyNew.all) // this adds or subtracts
            );
            data.setAttribute(
              "data-new-blogs-all",
              JSON.stringify(bodyOld.new) // this adds only
            );
            data.setAttribute(
              "data-missing-blogs-all",
              JSON.stringify(bodyOld.missing) // this adds only
            );
            data.setAttribute(
              "data-follow-blogs-all-updated",
              JSON.stringify(fblgTimestamp)
            );
            data.setAttribute(
              "data-new-blogs-all-updated",
              JSON.stringify(nblgTimestamp)
            );
            data.setAttribute(
              "data-missing-blogs-all-updated",
              JSON.stringify(mblgTimestamp)
            );
            // all this ^ data
            // goes v into this database
            makeSnap(cat);
          }
        }
      },
      [
        ["Accept", "application/json, text/javascript, */*; q=0.01"],
        ["X-Requested-With", "XMLHttpRequest"],
        ["Content-Type", "application/x-www-form-urlencoded; charset=UTF-8"]
      ]
    );
  };
  // this ^ reads the snapshot saves of a theme page

  // this processes the snapshots
  var snapShotFollowers = function (cat) {
    if (document.getElementsByClassName("im-ready").length === 0) {
      if (document.getElementById("snapshot-info") !== null) {
        document.getElementById(
          "snapshot-info"
        ).parentNode.classList.add("im-ready");
        document.getElementById(
          "snapshot-load-gif"
        ).parentNode.removeChild(
          document.getElementById(
            "snapshot-load-gif"
          )
        );
      }
      document.getElementById("snapshot-info_body").innerHTML = "";
      readSnap(cat, false);
    }
  };
  var snapInfoGo = true;
  // this ^ runs on the follows/followers page only

  // this v also only runs on the follows/followers page
  var loadFollowers = function(nextHref) {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var unstableOffset = data.getAttribute("data-unstable-next-href");
    if (
      href[5] === "follows" &&
      unstableOffset !== "0" &&
      typeof nextHref !== "undefined" &&
      nextHref.match(/offset=\d+/) !== null
    ) {
      nextHref = nextHref.replace(/offset=\d+/, function (m) {
        return "offset=" +
          (
            parseInt(m.replace(/\D+/g,"")) +
          parseInt(unstableOffset)
        );
      });
    }
    if (document.getElementById("followers-css") === null) {
      var flrCss = document.createElement("style");
      flrCss.type = "text/css";
      flrCss.id = "followers-css";
      flrCss.appendChild(
        document.createTextNode(
          (function () {/*
#select-by_widget {
  height: 190px;
}
*/}).toString().slice(16, -3))
      );
      document.head.appendChild(flrCss);
      var npfrag = document.createDocumentFragment();
      npfrag.appendChild(
        svgForType.happy.cloneNode(true)
      );
      npfrag.appendChild(
        document.createTextNode("Name Drop")
      );
      var nameDrop_chrome = newChromeButton("namedrop", npfrag, false);
      nameDrop_chrome.setAttribute(
        "title",
        "Give a shout out to your (selected) closest " +
        "followers, to show your love. <3"
      );
      nameDrop_chrome.
      getElementsByTagName("button")[0].
      addEventListener("click", newPostNameDrop);
      nameDrop_chrome.
      getElementsByTagName("button")[0].
      classList.add("disable-when-none-selected");
      nameDrop_chrome.
      getElementsByTagName("button")[0].disabled = true;
      en.appendChild(nameDrop_chrome);
      var uffrag = document.createDocumentFragment();
      uffrag.appendChild(
        svgForType.sad.cloneNode(true)
      );
      var unfollowSpan = document.createElement("span");
      unfollowSpan.appendChild(
        document.createTextNode("Unfollow")
      );
      uffrag.appendChild(
        unfollowSpan
      );
      var unfollow_chrome = newChromeButton("unfollow", uffrag, false);
      unfollow_chrome.setAttribute(
        "title",
        "Unfollow :("
      );
      unfollow_chrome.
      getElementsByTagName("button")[0].
      addEventListener("click", followOrUnfollowSelected);
      unfollow_chrome.
      getElementsByTagName("button")[0].
      classList.add("disable-when-none-selected");
      unfollow_chrome.
      getElementsByTagName("button")[0].disabled = true;
      en.appendChild(unfollow_chrome);
      var snapshotInfo_frag = document.createDocumentFragment();
      snapshotInfo_frag.appendChild(svgForType.image.cloneNode(true));
      snapshotInfo_frag.appendChild(
        document.createTextNode(
          "Snapshot Info"
        )
      );
      var snapshotInfo_chrome = newChromeButton(
        "snapshot-info", snapshotInfo_frag, true
      );
      var snapshotInfo_widget = snapshotInfo_chrome.
      getElementsByClassName("widget")[0];
      var snapshotInfo_input = snapshotInfo_chrome.
      getElementsByTagName("input")[0];
      snapshotInfo_widget.style.top = "50px";
      snapshotInfo_widget.style.right = "90px";
      var snapshotInfo_body = document.createElement("div");
      snapshotInfo_body.id = "snapshot-info_body";
      var snapshot_h2 = document.createElement("h1"); // I changes the nodeName
      snapshot_h2.appendChild(
        document.createTextNode(
          "Snapshot Info"
        )
      );
      var snapShotLoadGif = new Image();
      snapShotLoadGif.src = "https://assets.tumblr.com/images/loading_ddd.gif";
      var snapshotInfo_info = document.createElement("div");
      snapshotInfo_info.id = "snapshot-load-gif";
      snapshot_h2.appendChild(snapShotLoadGif);
      snapshotInfo_body.appendChild(snapshot_h2);
      snapshotInfo_info.appendChild(
        document.createTextNode("loading...")
      );
      snapshotInfo_info.setAttribute(
        "title",
        "This feature is might not be possible for super huge blog lists."
      );
      snapshotInfo_body.appendChild(snapshotInfo_info);
      snapshotInfo_widget.appendChild(snapshotInfo_body);
      snapshotInfo_chrome.setAttribute(
        "title",
        "SnapShot Options"
      );
      en.appendChild(snapshotInfo_chrome);
      readSnap(href[5], true);
    }
    var idsAllArr = JSON.parse(
      data.getAttribute("data-ids_all_arr")
    );
    var typesAllArr = JSON.parse(
      data.getAttribute("data-types_all_arr")
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    var tblg = JSON.parse(
      data.getAttribute("data-tumblelogs")
    );
    var fblg = JSON.parse(
      data.getAttribute("data-follow-blogs-all")
    );
    if (typeof typeToIds["friendly"] === "undefined") {
      typeToIds["friendly"] = [];
    }
    if (typeof typeToIds["mutual"] === "undefined") {
      typeToIds["mutual"] = [];
    }
    if (typeof typeToIds["secondary"] === "undefined") {
      typeToIds["secondary"] = [];
    }
    if (typesAllArr.indexOf("mutual") === -1) {
      typesAllArr.push("mutual");
    }
    if (typesAllArr.indexOf("friendly") === -1) {
      typesAllArr.push("friendly");
    }
    if (
      typesAllArr.indexOf("secondary") === -1 &&
      href[5] === "follows"
    ) {
      typesAllArr.push("secondary");
    }
    var ritpm = document.getElementsByClassName(
      "remove-in-third-party-mode"
    );
    while (ritpm.length > 0) {
      ritpm[0].parentNode.removeChild(ritpm[0]);
    }
    var csrfToken = data.getAttribute("data-csrf-token");
    var token = data.getAttribute("data-api-token");
    var apiKey = data.getAttribute("data-x-tumblr-form-key");
    var hasPrimary = JSON.parse(
      data.getAttribute("data-primary-known")
    );
    var followersLoading = JSON.parse(
      data.getAttribute("data-followers-loading")
    );
    if ( // this was firing twice, because I have to
      // check for two x headers twice...
      followersLoading
    ) {
      return;
    }
    if (token === "0" || !hasPrimary) {
      return;
    }
    data.setAttribute("data-followers-loading", "true");
    var primary = data.getAttribute("data-primary-blog");
    var isFollowersPage = href[5] === "followers";
    var isFollowsPage = href[5] === "follows";
    data.classList.add("fetching-from-tumblr-api");
    var mo = [
      "Jan ", "Feb ", "Mar ", "Apr ",
      "May ", "Jun ", "Jul ", "Aug ",
      "Sep ", "Oct ", "Nov ", "Dec "
    ];
    getResponseText(
      typeof nextHref !== "undefined" ?
      "/api" + nextHref :
      isFollowersPage ?
      "/api/v2/blog/" + name + "/followers?limit=50" :
      isFollowsPage ?
      "/api/v2/blog/" + primary + "/following?limit=5" :
      "/api/v2/blog/" + name + "/following?limit=5"
      ,
      function (re) {
        data.classList.remove("fetching-from-tumblr-api");
        var api = re;
        var ing = isFollowsPage;
        if(
         typeof api === "string"
        ) {
          api = JSON.parse(re);
        }
        if(
          !ing &&
          typeof api !== "undefined" &&
          typeof api.response !== "undefined" &&
          typeof api.response.users !== "undefined" ||
          ing &&
          typeof api !== "undefined" &&
          typeof api.response !== "undefined" &&
          typeof api.response.blogs !== "undefined"
        ) {
          if (!lcontent.classList.contains("albino")) {
            lcontent.classList.add("albino");
          }// this ^ is to clear away the vanilla editor posts,
          // which do not have our extra buttons,
          // but it seems to run on my other things too :/ oops
          if (lcontent.children.length === 0) {
            var followerHeader = document.createElement("div");
            var dt = (new Date());
            followerHeader.id = "who-follows-who";
            dt.setYear(dt.getFullYear() + 1);
            if (isFollowersPage) {
              followerHeader.classList.add("heading");
              followerHeader.appendChild(
                document.createTextNode(
                  "Blogs following your blogs, \u201C" + name + "\u201D"
                )
              );
              followerHeader.setAttribute("data-timestamp", dt.getTime());
              lcontent.appendChild(followerHeader);
            }
            if (!isFollowersPage) {
              followerHeader.classList.add("heading");
              followerHeader.appendChild(
                document.createTextNode(
                  "Blogs followed by your primary, \u201C" + primary + "\u201D"
                )
              );
              followerHeader.setAttribute("data-timestamp", dt.getTime());
              lcontent.appendChild(followerHeader);
            }
          }
          var user = ing ? api.response.blogs : api.response.users;
          var followerBrick;
          var firstChild;
          var cm;
          var nm;
          var nc;
          var tc;
          var middleChild;
          var middleChildT;
          var middleChildTR;
          var middleChildTD;
          var middleChildIB;
          var lastChild;
          var avatar;
          var date;
          var px;
          var b;
          var d;
          var date;
          var jz;
          var dt;
          var nextPage;
          var groupName;
          var group;
          var hding = document.getElementsByClassName("heading");
          var dt1 = new Date();
          var dt2 = new Date();
          var link1;
          var link2;
          var link3;
          var link4;
          var whiteHeart;
          var key;
          var uuid;
          var url;
          var descript;
          var title;
          var theme;
          var cancelProp = function (e){
            e.cancelBubble = true;
            e.stopProgagation();
          };
          for (var i = 0; i < user.length; i++) {
            dt1 = new Date(
              parseInt(hding[hding.length-1].getAttribute("data-timestamp"))
            );
            dt2 = new Date(
              ing ?
              user[i].resources[0].updated * 1000 :
              user[i].blog.updated * 1000
            );
            groupName = dt2.getFullYear() === (new Date()).getFullYear() ?
              "group_" + dt2.getMonth() + "_" + dt2.getFullYear() :
              "group_yesterdays_" + dt2.getFullYear()
            ;
            group = document.getElementsByClassName(groupName);
            followerBrick = document.createElement("a");
            followerBrick.classList.add(groupName);
            if (
              group.length === 0 &&
              (
                dt2.getFullYear() === (new Date()).getFullYear() &&
                (
                  dt2.getMonth() !== dt1.getMonth() ||
                  dt2.getFullYear() !== dt1.getFullYear()
                ) || dt2.getFullYear() !== dt1.getFullYear()
              )
            ) {
              followerHeader = document.createElement("div");
              followerHeader.classList.add("heading");
              followerHeader.appendChild(
                document.createTextNode(
                  dt2.getFullYear() === (new Date()).getFullYear() ?
                  "updated in " + mo[dt2.getMonth()] + dt2.getFullYear() :
                  "updated in " + dt2.getFullYear()
                )
              );
              followerHeader.setAttribute("data-timestamp", dt2.getTime());
              lcontent.appendChild(followerHeader);
            }
            followerBrick.style.width = "125px";
            followerBrick.style.height = "125px";
            followerBrick.classList.add("brick");
            followerBrick.classList.add("follow");
            followerBrick.classList.add("photo");
            followerBrick.addEventListener("click", function (e) {
              e.stopPropagation();
              e.preventDefault();
              e.cancelBubble = true;
              highlightBrick(this, !this.classList.contains("highlighted"));
            });
            key = ing ? user[i].resources[0].key : user[i].blog.key;
            uuid = ing ? user[i].resources[0].uuid : user[i].blog.uuid;
            url = ing ? user[i].resources[0].url : user[i].blog.url;
            title = ing ? user[i].resources[0].title : user[i].blog.title;
            descript = ing ?
			  user[i].resources[0].description : user[i].blog.description;
            theme = ing ? user[i].resources[0].theme : user[i].blog.theme;
            followerBrick.id = "post_" + key;
            followerBrick.setAttribute("target", "_blank");
            followerBrick.setAttribute("data-id", key);
            followerBrick.setAttribute("data-follower-key", key);
            followerBrick.setAttribute("data-follower-uuid", uuid);
            firstChild = document.createElement("div");
            firstChild.classList.add("highlight");
            cm = new Image();
            cm.src = "https://assets.tumblr.com/images/" +
                     "small_white_checkmark.png";
            cm.classList.add("checkmark");
            nm = ing ? user[i].resources[0].name : user[i].name;
            fblg.push(nm); // <= this array is for the snapshot later
            followerBrick.setAttribute("title", nm);
            followerBrick.setAttribute("href", url);
            idsAllArr.push(key);
            firstChild.appendChild(cm);
            tc = document.createElement("div");
            tc.classList.add("tag_count");
            tc.id = "tag_count_" + key;
            tc.appendChild(document.createTextNode(nm));
            firstChild.appendChild(tc);
            nc = document.createElement("div");
            nc.classList.add("note_count");
            firstChild.appendChild(nc);
            followerBrick.appendChild(firstChild);
            // meat & tators middle child (repeat)
            middleChild = document.createElement("div");
            middleChildT = document.createElement("div");
            middleChildTR = document.createElement("div");
            middleChildTD = document.createElement("div");
            middleChildIB = document.createElement("div");
            middleChild.classList.add("overflow-hidden");
            middleChildT.classList.add("links-layer");
            middleChildTR.classList.add("trow");
            middleChildTD.classList.add("tags-layer");
            middleChildIB.classList.add("tag-container");
            middleChildIB.innerHTML = "<h2>" + title + "</h2>" +
                                              descript;
            avatar = new Image();
            avatar.setAttribute("crossorigin", "anonymous");
            avatar.width = 125;
            avatar.height = 125;
            avatar.style.width = avatar.width + "px";
            avatar.style.height = avatar.height + "px";
            followerBrick.setAttribute("data-name", nm);
            avatar.src = "https://api.tumblr.com/v2/blog/" + nm + "/avatar/128";
            avatar.classList.add("follower-avatar");
            // some followers links
            link1 = document.createElement("a");
            link1.setAttribute("target", "_blank");
            link1.classList.add("link-edit");
            link1.href = "/dashboard/blog/" + nm;
            link1.setAttribute("title", "Peepr.");
            link1.appendChild(svgForType.view.cloneNode(true));
            link1.addEventListener("click", cancelProp);
            middleChildTD.appendChild(link1);
            link4= document.createElement("a");
            link4.setAttribute("target", "_blank");
            link4.classList.add("link-reblog");
            link4.href = "/dashboard/blog/" + nm + "#avatar";
            link4.setAttribute("title", "Large Avatar.");
            link4.setAttribute("data-name", nm);
            link4.setAttribute(
              "data-font", theme.title_font
            );
            link4.setAttribute(
              "data-weight", theme.title_font_weight
            );
            link4.setAttribute(
              "data-color", theme.title_color
            );
            link4.setAttribute(
              "data-bg", theme.background_color
            );
            link4.setAttribute(
              "data-title", title
            );
            link4.appendChild(svgForType.see.cloneNode(true));
            link4.addEventListener("click", function (e) {
              e.preventDefault();
              e.stopPropagation();
              e.cancelBubble = true;
              var popoverT = document.createElement("div");
              popoverT.addEventListener("click", function() {
                this.parentNode.removeChild(this);
              });
              popoverT.classList.add("follower-pop-t");
              var popoverTR = document.createElement("div");
              popoverTR.classList.add("follower-pop-tr");
              var popoverTD = document.createElement("div");
              popoverTD.classList.add("follower-pop-td");
              var popoverAv = document.createElement("div");
              popoverAv.classList.add("follower-pop-av");
              var popoverInner = document.createElement("div");
              popoverInner.classList.add("follower-pop-inner");
              var popoverImg = new Image();
              popoverImg.classList.add("follower-pop-img");
              popoverImg.src = "https://api.tumblr.com/v2/blog/" +
                               this.getAttribute("data-name") +
                               "/avatar/512";
              var popoverTitle = document.createElement("h1");
              popoverTitle.style.fontFamily = this.getAttribute("data-font");
              popoverTitle.style.color = this.getAttribute("data-color");
              popoverInner.style.backgroundColor = this.getAttribute("data-bg");
              popoverTitle.classList.add("follower-pop-title");
              popoverTitle.innerHTML = this.getAttribute("data-title");
              popoverAv.appendChild(popoverImg);
              popoverInner.appendChild(popoverAv);
              popoverInner.appendChild(popoverTitle);
              popoverTD.appendChild(popoverInner);
              popoverTR.appendChild(popoverTD);
              popoverT.appendChild(popoverTR);
              document.body.appendChild(popoverT);
            });
            // this ^ is neat. I'm proud of this ^ :)
            middleChildTD.appendChild(link4);
            link2 = document.createElement("a");
            link2.setAttribute("target", "_blank");
            link2.classList.add("link-view");
            link2.setAttribute("title", "Visit.");
            link2.appendChild(svgForType.symlink.cloneNode(true));
            link2.addEventListener("click", cancelProp);
            middleChildTD.appendChild(link2);
            link3 = document.createElement("a");
            link3.setAttribute("target", "_blank");
            link3.classList.add("link-like");
            link3.setAttribute("data-id", key);
            link3.setAttribute(
              "data-like-info", "data[tumblelog]=" + nm
            );
            link3.id = "follow_heart_" + key;
            link3.setAttribute("target", "_blank");
            // link3: start of the giant link3 follow button
            if (href[5] === "followers") {
              if (
                typeof user[i].following !== "undefined" &&
                user[i].following
              ) { // this only runs on ?followers...
                // it is absent on the ?follows (api/following)
                followerBrick.classList.add("following");
                // so if you follow, it's auto-mutuals
                typeToIds["mutual"].push(key);
                followerBrick.classList.add("mutual");
                idToTypes[key] = "mutual";
                whiteHeart = svgForType.liked.cloneNode(true);
                whiteHeart.setAttribute("fill", "#56f");
                link3.href = url + "#unfollow:" + nm;
                link3.setAttribute("title", "(Mutual) Click to UnFollow");
                link3.classList.add("liked");
                link3.appendChild(whiteHeart);
              } else if (
                typeof user[i].following !== "undefined" &&
                !user[i].following
              ) {
                typeToIds["friendly"].push(key);
                idToTypes[key] = "friendly";
                followerBrick.classList.add("unfollowed");
                whiteHeart = svgForType.notes.cloneNode(true);
                whiteHeart.setAttribute("fill", "#fff");
                link3.href = url + "#follow:" + nm;
                link3.setAttribute("title", "Click to Follow");
                link3.classList.add("not-liked");
                link3.appendChild(whiteHeart);
              }
              link3.addEventListener("click", followOrUnFollowButton);
            } else {
              followerBrick.classList.add("missing-follows-info");
            }
            // end 1 of link3 ^ giant follow button, but there is more of it
            // to be added below/later for the ?follows api/following part
            // because Tumblr doesn't include a property for follows/mutuals
            middleChildTD.appendChild(link3);
            // end followersBricks links... Woot! finally
            middleChild.appendChild(avatar);
            middleChildTD.appendChild(middleChildIB)
            middleChildTR.appendChild(middleChildTD);
            middleChildT.appendChild(middleChildTR)
            middleChild.appendChild(middleChildT);
            followerBrick.appendChild(middleChild);// < don't forget KEVIN!
            // close off the brick and return below     (home alone)
            lastChild = document.createElement("div");
            lastChild.classList.add("overlay");
            jz = document.createElement("div");
            jz.classList.add("inner");
            dt = document.createElement("div");
            d = new Date(
              ing ?
              user[i].resources[0].updated * 1000 :
              user[i].blog.updated * 1000
            );
            b = d.getDate();
            px = ["th ", "st ", "nd ", "rd ", "th ", "th ",
                      "th ", "th ", "th ", "th ", "th "][b % 10];
            if (b === 12 || b === 11) {
              px = "th ";
            }
            date = [
              "Sun - ", "Mon - ", "Tue - ", "Wed - ",
              "Thu - ", "Fri - ", "Sat - "
            ][d.getDay()] + mo[d.getMonth()] + b + px + d.getFullYear();
            dt.classList.add("date");
            dt.appendChild(document.createTextNode(date));
            jz.appendChild(dt);
            lastChild.appendChild(jz);
            followerBrick.appendChild(lastChild);
            if (group.length > 0) {
              lcontent.insertBefore(
                followerBrick, group[group.length-1].nextSibling
              );
            } else {
              lcontent.appendChild(followerBrick);
            }
          }
          data.setAttribute(
            "data-id_to_types",
            JSON.stringify(idToTypes)
          );
          data.setAttribute(
            "data-type_to_ids",
            JSON.stringify(typeToIds)
          );
          data.setAttribute(
            "data-types_all_arr",
            JSON.stringify(typesAllArr)
          );
          data.setAttribute(
            "data-ids_all_arr",
            JSON.stringify(idsAllArr)
          );
          data.setAttribute(
            "data-follow-blogs-all",
            JSON.stringify(fblg)
          );
          data.setAttribute("data-unstable-next-href", "0");
          pluginBuildColumns();
          nextPage = false; // maybe? find out later...
          data.setAttribute("data-id_to_types", JSON.stringify(idToTypes));
          data.setAttribute("data-type_to_ids", JSON.stringify(typeToIds));
          data.setAttribute("data-types_all_arr", JSON.stringify(typesAllArr));
          var repeatedTimeOut2;
          var nextPageOfFollowers = function() {
            data.setAttribute("data-page-repeat", nextPage); // loop much?
            // this delays pagination slightly, but it may be better...
            // it's steadier, non-bot-ish, and is easier to process :)
            var tagAlongDiff = document.getElementsByClassName("brick").length -
                document.getElementsByClassName("laid").length;
            if(
              document.getElementById(
                "pause_button"
              ).classList.contains("paused") ||
              tagAlongDiff > 10 // < this :)
            ) {// the CSS3 animation thing is also crash prevention :)
              return;
            }
            clearInterval(repeatedTimeOut2);
            data.setAttribute("data-followers-loading", "false");
            loadFollowers(nextPage);
          };
          var pauseBeforeNext = function() {
            // f stands for first followed
            var fBrick = document.getElementsByClassName(
              "missing-follows-info"
            );
            if (
              typeof fBrick !== "undefined" &&
              fBrick.length > 0
            ) {
              var fName = fBrick[0].getAttribute("data-name");
              var fKey = fBrick[0].getAttribute("data-follower-key");
              var fLink3 = document.getElementById(
                "follow_heart_" + fKey
              );
              var fUrl = fBrick[0].getAttribute("href");
              stopToFindMutuals(
                0 /* primary 1st and down the line */,
                fName,
                fUrl,
                fKey,
                fLink3,
                fBrick[0],
                pauseBeforeNext
              );
            } else if (!data.classList.contains("next_page_false")){
              // stop fetching mutual info and goto next page
              repeatedTimeOut2 = setInterval(nextPageOfFollowers, 500);
            }
          };
          if(
            typeof api !== "undefined" &&
            typeof api.response !== "undefined" &&
            typeof api.response._links !== "undefined" &&
            typeof api.response._links.next !== "undefined" &&
            typeof api.response._links.next.href !== "undefined"
          ) {
            nextPage = api.response._links.next.href;
            var fBrick = document.getElementsByClassName(
              "missing-follows-info"
            );
            if (
              (href[5] === "followers") &&
              nextPage !== false &&
              nextPage !== data.getAttribute("data-page-repeat")
            ) {
              // walk, don't run :)
              repeatedTimeOut2 = setInterval(nextPageOfFollowers, 500);
            } else if (
              href[5] === "follows" &&
              nextPage !== false &&
              nextPage !== data.getAttribute("data-page-repeat")
            ) {
              // this is unique, because if we unfollow any blogs
              // during pagination, we must step back the offset,
              // by -1, or else the blogs will be off by 1
              // &&
              // if we re-follow blog during pagination, we must
              // jostle back +1... it's very unstable, but solid
              data.setAttribute(
                "data-id_to_types",
                JSON.stringify(idToTypes)
              );
              data.setAttribute(
                "data-type_to_ids",
                JSON.stringify(typeToIds)
              );
              pauseBeforeNext();
            }
          } else {
            data.classList.add("next_page_false");
            if (
              href[5] === "follows" &&
              typeof fBrick !== "undefined" &&
              fBrick.length > 0
            ) {
              pauseBeforeNext();
            }
            snapShotFollowers(href[5]);
          }
        } else {
          snapShotFollowers(href[5]);
          // this ^ would run on an api fetch with 0 results
          data.classList.add("next_page_false");
          // but so far, that never happens...
        }
      },
      [
        ["Authorization", "Bearer " + token]
      ]
    );
  };
  // load followers ^ followers mode follow mode

  // load fans v
  var loadFans = function (notesList) {
    var firstRun = typeof notesList === "undefined";
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var idsAllArr = JSON.parse(
      data.getAttribute("data-ids_all_arr")
    );
    var typesAllArr = JSON.parse(
      data.getAttribute("data-types_all_arr")
    );
    var typeToIds = JSON.parse(
      data.getAttribute("data-type_to_ids")
    );
    var idToTypes = JSON.parse(
      data.getAttribute("data-id_to_types")
    );
    if (typeof typeToIds["friendly"] === "undefined") {
      typeToIds["friendly"] = [];
    }
    if (typeof typeToIds["mutual"] === "undefined") {
      typeToIds["mutual"] = [];
    }
    if (typeof typeToIds["secondary"] === "undefined") {
      typeToIds["secondary"] = [];
    }
    var token = data.getAttribute("data-api-token");
    getResponseText(
      firstRun?
      "/activity/" + name :
      "/activity/" + notesList.channel + // name
      "/2/" + notesList.first +
      "?last_timestamp=" + notesList.last +
      "&c=" + notesList.c,
      function (re) {
        if (!firstRun) {
          re = JSON.parse(re).html;
        }
        var div = document.createElement("div");
        div.innerHTML = re. // parse the dom
        replace(/<(\/?)script[^>]*>/g, "<$1flurb>"). // no eval
        replace(/<img/g,"<space"); // do not onload img tags
        var flurb = div.getElementsByTagName("flurb");
        var notesListReg = /Tumblr\.NotesList\((\{[\s\S]*?\})\);/;
        var notesList = {}; // reset
        var i;
        for (i = 0; i < flurb.length; i++) {
          if (flurb[i].innerText.match(notesListReg) !== null) {
            eval("notesList = " + flurb[i].innerText.match(notesListReg)[1]);
            // eval('JSON.stringify...')... {bad: 'structure'}...
          }
        }
        var an = div.getElementsByClassName("activity-notification");
        var isFollower = an[0].classList.contains("is_follower");
        var isLike = an[0].classList.contains("is_like");
        var isReblog = an[0].classList.contains("is_reblog");
        var loopFirstBrick = function (an0) {
          var anName = an0.getElementsByClassName(
            "ui_avatar_tumblelog_name"
          )[0].innerText.replace(/\s+/g,"");
          var fanBrick = document.getElementById("post_" + anName);
          if (fanBrick === null) {
            // create fan brick
            getResponseText(
              "/api/v2/blog/" + anName + "/info",
              function (re2) {
                var api = JSON.parse(re2)
                if (
                  typeof api !== "undefined" &&
                  typeof api.response !== "undefined" &&
                  typeof api.response.blog !== "undefined"
                ) {// ...---***---... LOAD FANS ...---***---...
                  // with much casual copy over from load fans
                  if (!lcontent.classList.contains("albino")) {
                    lcontent.classList.add("albino");
                  }
                  if (lcontent.children.length === 0) {
                    var fanHeader = document.createElement("div");
                    var dt = (new Date());
                    fanHeader.id = "who-follows-who";
                    dt.setYear(dt.getFullYear() + 1);
                    fanHeader.classList.add("heading");
                    fanHeader.appendChild(
                      document.createTextNode(
                        "Fans of \u201C" + name + "\u201D"
                      )
                    );
                    fanHeader.setAttribute("data-timestamp", dt.getTime());
                    lcontent.appendChild(fanHeader);
                  }
                  var isFollower = an0.classList.contains("is_follower");
                  var isLike = an0.classList.contains("is_like");
                  var isReblog = an0.classList.contains("is_note");
                  var mo = [
                    "Jan ", "Feb ", "Mar ", "Apr ",
                    "May ", "Jun ", "Jul ", "Aug ",
                    "Sep ", "Oct ", "Nov ", "Dec "
                  ];
                  var hding = document.getElementsByClassName("heading");
                  var blog = api.response.blog;
                  var dt1 = new Date(
                    parseInt(hding[hding.length-1].getAttribute("data-timestamp"))
                  );
                  var dt2 = new Date(blog.updated * 1000);
                  var groupName = dt2.getFullYear() === (new Date()).getFullYear() ?
                      "group_" + dt2.getMonth() + "_" + dt2.getFullYear() :
                  "group_yesterdays_" + dt2.getFullYear()
                  ;
                  var group = document.getElementsByClassName(groupName);
                  var fanBrick = document.createElement("a");
                  fanBrick.classList.add(groupName);
                  if (
                    group.length === 0 &&
                    (
                      dt2.getFullYear() === (new Date()).getFullYear() &&
                      (
                        dt2.getMonth() !== dt1.getMonth() ||
                        dt2.getFullYear() !== dt1.getFullYear()
                      ) || dt2.getFullYear() !== dt1.getFullYear()
                    )
                  ) {
                    var fanHeader = document.createElement("div");
                    fanHeader.classList.add("heading");
                    fanHeader.appendChild(
                      document.createTextNode(
                        dt2.getFullYear() === (new Date()).getFullYear() ?
                        "updated in " + mo[dt2.getMonth()] + dt2.getFullYear() :
                        "updated in " + dt2.getFullYear()
                      )
                    );
                    fanHeader.setAttribute("data-timestamp", dt2.getTime());
                    lcontent.appendChild(fanHeader);
                  }
                  fanBrick.style.width = "125px";
                  fanBrick.style.height = "125px";
                  fanBrick.classList.add("brick");
                  fanBrick.classList.add("follow");
                  fanBrick.classList.add("photo");
                  fanBrick.addEventListener("click", function (e) {
                    e.stopPropagation();
                    e.preventDefault();
                    e.cancelBubble = true;
                    highlightBrick(this, !this.classList.contains("highlighted"));
                  });
                  var nm = blog.name;
                  var key = blog.key;
                  var uuid = blog.uuid;
                  var url = blog.url;
                  var title = blog.title;
                  var descript = blog.description;
                  var theme = blog.theme;
                  fanBrick.id = "post_" + nm;
                  fanBrick.setAttribute("target", "_blank");
                  fanBrick.setAttribute("data-id", nm);
                  fanBrick.setAttribute("data-fan-key", key);
                  fanBrick.setAttribute("data-fan-uuid", uuid);
                  var firstChild = document.createElement("div");
                  firstChild.classList.add("highlight");
                  var cm = new Image();
                  cm.src = "https://assets.tumblr.com/images/" +
                    "small_white_checkmark.png";
                  cm.classList.add("checkmark");
                  fanBrick.setAttribute("title", nm);
                  fanBrick.setAttribute("href", url);
                  idsAllArr.push(key);
                  firstChild.appendChild(cm);
                  var tc = document.createElement("div");
                  tc.classList.add("tag_count");
                  tc.id = "tag_count_" + key;
                  tc.appendChild(document.createTextNode("0 Likes"));
                  firstChild.appendChild(tc);
                  var nc = document.createElement("div");
                  nc.classList.add("note_count");
                  firstChild.appendChild(nc);
                  nc.appendChild(document.createTextNode("0 Reblog"));
                  if (isReblog) {
                    nc.innerText = (parseInt(nc.innerText.replace(/\D+/g,"")) + 1) + " Notes";
                  }
                  if (isLike) {
                    tc.innerText = (parseInt(tc.innerText.replace(/\D+/g,"")) + 1) + " Likes";
                  }
                  fanBrick.appendChild(firstChild);
                  // meat & tators middle child (repeat)
                  var middleChild = document.createElement("div");
                  var middleChildT = document.createElement("div");
                  var middleChildTR = document.createElement("div");
                  var middleChildTD = document.createElement("div");
                  var middleChildIB = document.createElement("div");
                  middleChild.classList.add("overflow-hidden");
                  middleChildT.classList.add("links-layer");
                  middleChildTR.classList.add("trow");
                  middleChildTD.classList.add("tags-layer");
                  middleChildIB.classList.add("tag-container");
                  middleChildIB.innerHTML = "<h2>" + title + "</h2>" +
                    descript;
                  var avatar = new Image();
                  avatar.setAttribute("crossorigin", "anonymous");
                  avatar.width = 125;
                  avatar.height = 125;
                  avatar.style.width = avatar.width + "px";
                  avatar.style.height = avatar.height + "px";
                  fanBrick.setAttribute("data-name", nm);
                  avatar.src = "https://api.tumblr.com/v2/blog/" + nm + "/avatar/128";
                  avatar.classList.add("fan-avatar");
                  // some fans links
                  var cancelProp = function (e){
                    e.cancelBubble = true;
                    e.stopProgagation();
                  };
                  var link1 = document.createElement("a");
                  link1.setAttribute("target", "_blank");
                  link1.classList.add("link-edit");
                  link1.href = "/dashboard/blog/" + nm;
                  link1.setAttribute("title", "Peepr.");
                  link1.appendChild(svgForType.view.cloneNode(true));
                  link1.addEventListener("click", cancelProp);
                  middleChildTD.appendChild(link1);
                  var link4= document.createElement("a");
                  link4.setAttribute("target", "_blank");
                  link4.classList.add("link-reblog");
                  link4.href = "/dashboard/blog/" + nm + "#avatar";
                  link4.setAttribute("title", "Large Avatar.");
                  link4.setAttribute("data-name", nm);
                  link4.setAttribute(
                    "data-font", theme.title_font
                  );
                  link4.setAttribute(
                    "data-weight", theme.title_font_weight
                  );
                  link4.setAttribute(
                    "data-color", theme.title_color
                  );
                  link4.setAttribute(
                    "data-bg", theme.background_color
                  );
                  link4.setAttribute(
                    "data-title", title
                  );
                  link4.appendChild(svgForType.see.cloneNode(true));
                  link4.addEventListener("click", function (e) {
                    e.preventDefault();
                    e.stopPropagation();
                    e.cancelBubble = true;
                    var popoverT = document.createElement("div");
                    popoverT.addEventListener("click", function() {
                      this.parentNode.removeChild(this);
                    });
                    popoverT.classList.add("fan-pop-t");
                    var popoverTR = document.createElement("div");
                    popoverTR.classList.add("fan-pop-tr");
                    var popoverTD = document.createElement("div");
                    popoverTD.classList.add("fan-pop-td");
                    var popoverAv = document.createElement("div");
                    popoverAv.classList.add("fan-pop-av");
                    var popoverInner = document.createElement("div");
                    popoverInner.classList.add("fan-pop-inner");
                    var popoverImg = new Image();
                    popoverImg.classList.add("fan-pop-img");
                    popoverImg.src = "https://api.tumblr.com/v2/blog/" +
                      this.getAttribute("data-name") +
                      "/avatar/512";
                    var popoverTitle = document.createElement("h1");
                    popoverTitle.style.fontFamily = this.getAttribute("data-font");
                    popoverTitle.style.color = this.getAttribute("data-color");
                    popoverInner.style.backgroundColor = this.getAttribute("data-bg");
                    popoverTitle.classList.add("fan-pop-title");
                    popoverTitle.innerHTML = this.getAttribute("data-title");
                    popoverAv.appendChild(popoverImg);
                    popoverInner.appendChild(popoverAv);
                    popoverInner.appendChild(popoverTitle);
                    popoverTD.appendChild(popoverInner);
                    popoverTR.appendChild(popoverTD);
                    popoverT.appendChild(popoverTR);
                    document.body.appendChild(popoverT);
                  });
                  // this ^ is neat. I'm proud of this ^ :)
                  middleChildTD.appendChild(link4);
                  var link2 = document.createElement("a");
                  link2.setAttribute("target", "_blank");
                  link2.classList.add("link-view");
                  link2.setAttribute("title", "Visit.");
                  link2.appendChild(svgForType.symlink.cloneNode(true));
                  link2.addEventListener("click", cancelProp);
                  middleChildTD.appendChild(link2);
                  var link3 = document.createElement("a");
                  link3.setAttribute("target", "_blank");
                  link3.classList.add("link-like");
                  link3.setAttribute("data-id", key);
                  link3.setAttribute(
                    "data-like-info", "data[tumblelog]=" + nm
                  );
                  link3.id = "follow_heart_" + key;
                  link3.setAttribute("target", "_blank");
                  // link3: start of the giant link3 follow button
                  var whiteHeart;
                  if (
                    typeof blog.followed !== "undefined" &&
                    blog.followed
                  ) { // this only runs on ?fans...
                    fanBrick.classList.add("following");
                    // so if you follow, it's auto-mutual
                    typeToIds["mutual"].push(key);
                    fanBrick.classList.add("mutual");
                    idToTypes[key] = "mutual";
                    whiteHeart = svgForType.liked.cloneNode(true);
                    whiteHeart.setAttribute("fill", "#56f");
                    link3.href = url + "#unfollow:" + nm;
                    link3.setAttribute("title", "(Mutual) Click to UnFollow");
                    link3.classList.add("liked");
                    link3.appendChild(whiteHeart);
                  } else if (
                    typeof blog.followed !== "undefined" &&
                    !blog.followed
                  ) {
                    typeToIds["friendly"].push(key);
                    idToTypes[key] = "friendly";
                    fanBrick.classList.add("unfollowed");
                    whiteHeart = svgForType.notes.cloneNode(true);
                    whiteHeart.setAttribute("fill", "#fff");
                    link3.href = url + "#follow:" + nm;
                    link3.setAttribute("title", "Click to Follow");
                    link3.classList.add("not-liked");
                    link3.appendChild(whiteHeart);
                  }
                  link3.addEventListener("click", followOrUnFollowButton);
                  // end 1 of link3 ^ giant follow button, but there is more of it
                  // to be added below/later for the ?follows api/following part
                  // because Tumblr doesn't include a property for follows/mutuals
                  middleChildTD.appendChild(link3);
                  // end fansBricks links... Woot! finally
                  middleChild.appendChild(avatar);
                  middleChildTD.appendChild(middleChildIB)
                  middleChildTR.appendChild(middleChildTD);
                  middleChildT.appendChild(middleChildTR)
                  middleChild.appendChild(middleChildT);
                  fanBrick.appendChild(middleChild);// < don't forget KEVIN!
                  // close off the brick and return below     (home alone)
                  var lastChild = document.createElement("div");
                  lastChild.classList.add("overlay");
                  var jz = document.createElement("div");
                  jz.classList.add("inner");
                  var dt = document.createElement("div");
                  var d = new Date(blog.updated * 1000);
                  var b = d.getDate();
                  var px = ["th ", "st ", "nd ", "rd ", "th ", "th ",
                            "th ", "th ", "th ", "th ", "th "][b % 10];
                  if (b === 12 || b === 11) {
                    px = "th ";
                  }
                  var date = [
                    "Sun - ", "Mon - ", "Tue - ", "Wed - ",
                    "Thu - ", "Fri - ", "Sat - "
                  ][d.getDay()] + mo[d.getMonth()] + b + px + d.getFullYear();
                  dt.classList.add("date");
                  dt.appendChild(document.createTextNode(nm));
                  jz.appendChild(dt);
                  lastChild.appendChild(jz);
                  fanBrick.setAttribute("title", nm + " " + date);
                  fanBrick.appendChild(lastChild);
                  if (group.length > 0) {
                    lcontent.insertBefore(
                      fanBrick, group[group.length-1].nextSibling
                    );
                  } else {
                    lcontent.appendChild(fanBrick);
                  }
                }
                data.setAttribute(
                  "data-id_to_types",
                  JSON.stringify(idToTypes)
                );
                data.setAttribute(
                  "data-type_to_ids",
                  JSON.stringify(typeToIds)
                );
                data.setAttribute(
                  "data-types_all_arr",
                  JSON.stringify(typesAllArr)
                );
                data.setAttribute(
                  "data-ids_all_arr",
                  JSON.stringify(idsAllArr)
                );
                data.setAttribute("data-unstable-next-href", "0");
                pluginBuildColumns();
                var nextPage = false; // maybe? find out later...
                data.setAttribute("data-id_to_types", JSON.stringify(idToTypes));
                data.setAttribute("data-type_to_ids", JSON.stringify(typeToIds));
                data.setAttribute("data-types_all_arr", JSON.stringify(typesAllArr));
                an0.classList.remove("activity-notification");
                if (an.length > 0) {
                  loopFirstBrick(an[0]);
                } else {
                  loadFans(notesList);
                }
              },
              [
                ["Authorization", "Bearer " + token]
              ]
            );
          } else {
            var nc = fanBrick.getElementsByClassName("note_count")[0]; // reblog
            var tc = fanBrick.getElementsByClassName("tag_count")[0]; // like count
            if (isReblog) {
              nc.innerText = (parseInt(nc.innerText.replace(/\D+/g,"")) + 1) + " Notes";
            }
            if (isLike) {
              tc.innerText = (parseInt(tc.innerText.replace(/\D+/g,"")) + 1) + " Likes";
            }
          }
        };
        loopFirstBrick(an[0]);
        notesList.last = an[an.length-1].getAttribute("data-timestamp");
        if (notesList.has_more) {
          setTimeout(function(){
            loadFans(notesList)
          }, 500);
        }
      },
      [
        // I don't want to parse HTML data
        ["X-Requested-With", "XMLHttpRequest"]
        // accept text/html    (-.-)_o  -BOO!
      ]
    );
  };
  // load fans ^

  // we'll need our own masonry for batch photo bricks
  var rebuildPhotoColumn = function() {
    // this fires once for each image
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var column = 150;
    var brk = document.getElementsByClassName("photo-brick");
    var rect;
    var iRct;
    var img;
    var mt; // margin Top
    var brkHeight = 0;
    var tallH;
    for (var i = 0; i < brk.length; i++) {
      img = brk[i].getElementsByClassName("photo-brick-img");
      if (
        img.length === 0 || img.length === 1 &&
        typeof img[0] !== "undefined" &&
        typeof img[0].children !== "undefined" &&
        img[0].children.length === 0
      ) {
        brk[i].parentNode.removeChild(brk[i]);
        i--;
        if (i > 0 && typeof brk[i] === "undefined") {
          break;
        }
      } else {
        brkHeight = 0;
        for (var l = 0; l < img.length; l++) {
          if(
            img[l].classList.contains("row-with-two-img") &&
            img[l].classList.contains("data-photoset-a") &&
            typeof img[l+1] !== "undefined" // nextSibling
          ){
            // neat row...? row same height #1
            tallH = Math.round(Math.min(
              img[l].children[0].clientHeight*
              (60/img[l].children[0].clientWidth),
              img[l+1].children[0].clientHeight*
              (60/img[l+1].children[0].clientWidth)
            )); //2
            img[l].style.height = tallH + "px";
            img[l+1].style.height = tallH + "px";
          }
          if(
            img[l].classList.contains("row-with-three-img") &&
            img[l].classList.contains("data-photoset-a") &&
            typeof img[l+1] !== "undefined" && // nextSibling
            typeof img[l+2] !== "undefined" // nextSibling&nextSibling
          ){
            // neat row...? row same height #1
            tallH = Math.round(Math.min(
              img[l].children[0].clientHeight*
              (38/img[l].children[0].clientWidth),
              img[l+1].children[0].clientHeight*
              (38/img[l+1].children[0].clientWidth),
              img[l+2].children[0].clientHeight*
              (38/img[l+2].children[0].clientWidth)
            )); //3
            img[l].style.height = tallH + "px";
            img[l+1].style.height = tallH + "px";
            img[l+2].style.height = tallH + "px";
          }
          if (
            typeof img[l] !== "undefined" &&
            typeof img[l].children[0] !== "undefined"
          ) {
            rect = img[l].getBoundingClientRect();
            iRct = img[l].children[0].getBoundingClientRect();
            mt = Math.round((rect.height - iRct.height) / 2);
            img[l].children[0].style.marginTop = mt + "px";
            if (
              img[l].classList.contains("row-with-one-img") ||
              img[l].classList.contains("data-photoset-a") &&
              !img[l].classList.contains("brick-dragging")
            ) {
              brkHeight += rect.height + 6;
            }
          }
        }
        if (brkHeight !== 0) {
          brk[i].style.height = Math.round(brkHeight) + "px";
          brk[i].getElementsByClassName("rich")[0].
            style.maxHeight = Math.round(brkHeight-42) > 100 ?
            Math.round(brkHeight-42) + "px" : "100px";
        }
      }
    }
    for (i = 0; i < brk.length; i++) {
      brk[i].style.top = column + "px";
      brk[i].style.left = "420px"; // :P
      column += brk[i].getBoundingClientRect().height + 6;
    }
    data.setAttribute("data-photos_height", column);
    lcontent.style.height = column + "px";
  };
  // end rebuildColumns for batch photos rebuildPhotoColumn

  // alternative name: makePhotoBrickFromUpload
  var allResized = 0;
  var brickIndex = 0;
  var reading = [{
    read: rebuildPhotoColumn
  }];
  var unreadFile = {};
  var readers = [];
  var loadPhotoIntoDOM = function(reloadedImg){
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    // new photo-brick
    var bricks = document.getElementsByClassName("photo-brick");
    var brick = document.createElement("div");
    var brickInner = document.createElement("div");
    brickInner.classList.add("photo-inner");
    brick.classList.add("photo-brick");
    brick.style.top = "-150px";
    brick.style.left = "420px";
    brick.setAttribute("onclick", "window.just_clicked_add_tags = true;");
    brick.id = "photo-brick_" + brickIndex;
    var img = new Image();
    if (
      typeof reloadedImg !== "undefined" &&
      typeof reloadedImg.target !== "undefined" &&
      typeof reloadedImg.target.imgCode !== "undefined"
    ) {
      img.setAttribute("img-code", reloadedImg.target.imgCode);
    }
    img.style.visibility = "hidden";
    img.setAttribute("data-id", brick.id);
    var pbi = document.createElement("div");
    pbi.setAttribute("data-id", brick.id);
    pbi.classList.add("row-with-one-img");
    pbi.classList.add("photo-brick-img");
    var pbic = document.createElement("div");
    pbic.classList.add("photo-brick-img-cell");
    var observer = document.createElement("div");
    observer.classList.add("resize-observer");
    // rebuildColumn after single photo dragged / resized
    new ResizeObserver(rebuildPhotoColumn).observe(observer);
    // these ^ are cool :)
    // editor portion
    var pbe = document.createElement("div");
    pbe.classList.add("photo-brick-edit");
    var rich = document.createElement("div");
    rich.setAttribute("title", "caption");
    rich.id = "rich_text_" + brickIndex;
    rich.setAttribute("data-id", brickIndex);
    var tags = document.createElement("div");
    tags.setAttribute("data-id", brickIndex);
    tags.classList.add("photo-tags");
    tags.addEventListener("click", function() {
      if (!brick.classList.contains("focused-rich")) {
        rich.focus();
      }
    });
    tags.id = "photo_tags_" + brickIndex;
    rich.contentEditable = true;
    rich.designMode = "on";
    rich.classList.add("rich");
    rich.addEventListener("focus", function () {
      if (data.classList.contains("photo-upload-in-progress")) {
        return;
      }
      if (!brick.classList.contains("focused-rich")) {
        var fr = document.getElementsByClassName("focused-rich");
        while (fr.length > 0 ) {
          fr[0].classList.remove("focused-rich");
        }
        var addTagsWidget = document.getElementById("add_tags_widget");
        addTagsWidget.style.display = "block";
        brick.classList.add("focused-rich");
      }
    });
    pbe.appendChild(rich);
    pbe.appendChild(tags);
    var stripe = document.createElement("div");
    stripe.classList.add("stripe");
    var clone = butt("Clone ABC");
    clone.classList.add(clone.id);
    clone.removeAttribute("id");
    clone.addEventListener("click", function () {
      var otherRich = document.getElementsByClassName("rich");
      for (var i = 0; i < otherRich.length; i++){
        if (otherRich[i] === rich) {
          continue;
        }
        otherRich[i].innerHTML = rich.innerHTML;
      }
    });
    clone.setAttribute(
      "title", "Copy this caption, to all photo captions."
    );
    pbe.appendChild(clone);
    appendRichButtons(pbe, rich, brick);
    pbe.appendChild(stripe);
    // end editor portion
    img.addEventListener("load", function() {
      var brick = document.getElementById(
        this.getAttribute("data-id")
      );
      var column = parseInt(
        data.getAttribute("data-photos_height")
      );
      var minBrickHeight = 120;
      this.removeAttribute("style");
      column += (this.height > minBrickHeight ?
	    this.height: minBrickHeight) + 6;
      data.setAttribute("data-photos_height", column);
      lcontent.style.height = column + "px";
    });
    img.src = typeof reloadedImg.nodeName === "undefined" ?
      this.result : reloadedImg.src;
    pbi.appendChild(img);
    observer.appendChild(pbi);
    pbic.appendChild(observer);
    brickInner.appendChild(pbic); // mayo?
    brickInner.appendChild(pbe); // lettuce?
    brick.appendChild(brickInner);
    if (typeof reading !== "undefined" && reading.length > 0) {
      reading.pop();
    }
    if (typeof reading !== "undefined" && reading.length > 0) {
      reading[reading.length - 1].read();
    }
    if (typeof reloadedImg.nodeName !== "undefined") {
      var hlb = document.getElementsByClassName("hl-bottom");
      var hlt = document.getElementsByClassName("hl-top");
      reloadedImg.parentNode.removeChild(reloadedImg);
      document.body.insertBefore(
        brick,
        hlb.length > 0 ? hlb[0].nextSibling : hlt.length > 0 ? hlt[0] :
        document.body.firstChild // < but not this usually
      );
    } else {
      document.body.appendChild(brick);
    }
    brickIndex++;
  };
  // end the batch photo brick maker thing

  // tampermonkey say this needs to be defined first Catch22
  // our own DOM builder for the Dash/Archive/Tagged API; end at return brick
  var makeBrickFromApiPost = function (post, type, content, index) {
    if (type === "undefined") {
      return false;
    }
    var i;
    var tp = {
      "chat": "conversation",
      "ask": "note",
      "image": "photo",
      "text": "regular",
      "link": "link",
      "video": "video",
      "audio": "audio",
      "quote": "quote"
    }; // tumblr 2014 post type names (archive.js)
    var smallestMedia = function (media) {
      var url = media[0].url;
      var width = 100000;
      var height = 125;
      for (var i = 0; i < media.length; i++) {
        if (typeof media[i].width === "undefined") {
          continue;
        }
        if (media[i].width === media[i].height) {
          width = media[i].width;
          height = media[i].height;
          url = media[i].url;
          break;
        }
        if (media[i].width < width && media[i].width >= 125) {
          width = media[i].width;
          height = media[i].height;
          url = media[i].url;
        }
      }
      if (width === 100000) {
        width = 125;
      }
      var img = new Image();
      img.src = url;
      img.width = 125;
      img.height = ((125/width) * height);
      img.style.width = img.width + "px";
      img.style.height = img.height + "px";
      return img;
    };
    var formatText = function (text, f, q) {
      if (typeof f === "undefined") {
        f = [];
      }
      if (typeof q === "undefined") {
        q = "nothing";
      }
      if (typeof text === "undefined") {
        text = "";
      }
      var chars = text.split("");
      chars.push("");
      var open;
      var close = "</span>";
      for (var i = 0; i < f.length; i++) {
        open = {
          "mention":
          "<span style=\"text-decoration:underline;\">",
          "link":
          "<span style=\"text-decoration:underline;\">",
          "bold":
          "<span style=\"font-weight:bold;\">",
          "color":
          "<span style=\"color:" + f[i].hex + ";\">",
          "italic":
          "<span style=\"font-style:italic;\">"
        }[f[i].type];
        chars[f[i].start] = open + chars[f[i].start];
        chars[f[i].end] = chars[f[i].end] + close;
      }
      if(q === "quirky") {
        chars.unshift(
          "<p class=\"quirky\">"
        );
        chars.push("</p>");
      }
      if(q === "heading1") {
        chars.unshift(
          "<p class=\"h1\">"
        );
        chars.push("</p>");
      }
      if(q === "heading2") {
        chars.unshift(
          "<p class=\"h2\">"
        );
        chars.push("</p>");
      }
      if(q === "link") {
        chars.unshift(
          "<div class=\"rq\">&#x2192;</div>" +
          "<p class=\"link\">"
        );
        chars.push("</p>");
      }
      if(q === "chat") {
        chars.unshift(
          "<p class=\"monospace\">"
        );
        chars.push("</p>");
      }
      if(q === "ordered-list-item") {
        chars.unshift(
          "<p class=\"ol\">"
        );
        chars.push("</p>");
      }
      if(q === "unordered-list-item") {
        chars.unshift(
          "<p class=\"ul\">"
        );
        chars.push("</p>");
      }
      if(q === "quote") {
        chars.unshift(
          "<div class=\"rq\">&rdquo;</div>" +
          "<p class=\"quote\">"
        );
        chars.push("</p>");
      }
      if(q === "note") {
        chars.unshift(
          "<div class=\"rq\">?</div>" +
          "<p class=\"quote\">"
        );
        chars.push("</p>");
      }
      return chars.join("");
    }; // format text
    var brick = document.createElement("a");
    brick.setAttribute("data-index", index);
    brick.classList.add("brick");
    brick.classList.add(tp[type]);
    brick.classList.add("timestamp_" + post.timestamp);
    brick.setAttribute("data-id", post.id);
    brick.setAttribute("data-timestamp", post.timestamp);
    brick.setAttribute("data-reblog_key", post.reblog_key);
    brick.id = "post_" + post.id;
    var firstChild = document.createElement("div");
    firstChild.classList.add("highlight");
    var cm = new Image();
    cm.src = "https://assets.tumblr.com/images/" +
      "small_white_checkmark.png";
    cm.classList.add("checkmark");
    firstChild.appendChild(cm);
    var tc = document.createElement("div");
    tc.classList.add("tag_count");
    tc.id = "tag_count_" + post.id;
    tc.appendChild(
      document.createTextNode(
        typeof post.tags === "undefined" ? "0 tags" :
        post.tags.length === 1 ? "1 tag" :
        post.tags.length + " tags"
      )
    );
    firstChild.appendChild(tc);
    var nc = document.createElement("div");
    nc.classList.add("note_count");
    nc.id = "note_count_" + post.id;
    nc.appendChild(
      document.createTextNode(
        typeof post.note_count === "undefined" ? "0 notes" :
        post.note_count === 1 ? "1 note" :
        post.note_count.toLocaleString("en", {useGrouping:true}) + " notes"
      )
    );
    firstChild.appendChild(nc);
    brick.appendChild(firstChild);
    // meat & tators middle child (again)
    var middleChild = document.createElement("div");
    var middleChildT = document.createElement("div");
    var middleChildTR = document.createElement("div");
    var middleChildTD = document.createElement("div");
    var middleChildIB = document.createElement("div");
    var fade = document.createElement("div");
    fade.classList.add("fade");
    var childTitle;
    var imgs;
    var h;
    var url;
    var av;
    var nm;
    var orly;
    var line;
    var op;
    var l;
    middleChild.classList.add("overflow-hidden");
    middleChildT.classList.add("overflow-table");
    middleChildTR.classList.add("overflow-row");
    middleChildTD.classList.add("overflow-cell");
    middleChildIB.classList.add("overflow-inline");
    if (
      type === "text" ||
      type === "chat" ||
      type === "quote" ||
      type === "ask" ||
      type === "link"
    ) {
      childTitle = document.createElement("div");
      childTitle.classList.add("title");
      if (
        typeof content[0] !== "undefined" &&
        typeof content[0].text !== "undefined"
      ) {
        childTitle.innerHTML = formatText(
          content[0].text,
          content[0].formatting,
          content[0].subtype
        );
      }
      if (type === "ask") {
        nm = typeof post.trail[0].layout[0].attribution !== "undefined" ?
          post.trail[0].layout[0].attribution.blog.name :
        post.trail[0].blog.name;
        url = "https://api.tumblr.com/v2/blog/" + nm + "/avatar/64";
        av = new Image();
        av.width = 24;
        av.height = 24;
        av.style.width = av.width + "px";
        av.style.height = av.height + "px";
        av.src = url;
        av.classList.add("ask-av");
        childTitle.appendChild(av);
        if (
          typeof post.trail[0] !== "undefined" &&
          typeof post.trail[0].content[0] !== "undefined" &&
          typeof post.trail[0].content[0].text !== "undefined"
        ) {
          childTitle.innerHTML += "<div class=\"rq\">?</div>" +
            "<div class=\"asker\">" +
            formatText(
            post.trail[0].content[0].text,
            post.trail[0].content[0].formatting,
            post.trail[0].content[0].subtype
          ) + "</div>";
        }
      }
      if (
        type === "ask" &&
        typeof post.trail[0] !== "undefined" &&
        typeof post.trail[0].content[1] !== "undefined" &&
        (
          typeof post.trail[0].content[1].text !== "undefined" ||
          typeof post.trail[0].content[1].media !== "undefined"
        )
      ) {
        if (typeof post.trail[0].content[1].text !== "undefined") {
          childTitle.innerHTML += "<div class=\"answer\">" +
            formatText(
            post.trail[0].content[1].text,
            post.trail[0].content[1].formatting,
            post.trail[0].content[1].subtype
          ) + "</div>";
        } else {
          imgs = post.trail[0].content[1].media;
          brick.classList.add("has-img");
          line = smallestMedia(imgs);
          h = line.height;
          childTitle.innerHTML +=
            line.outerHTML;
          childTitle.appendChild(fade);
        }
      }
      middleChildIB.appendChild(childTitle);
      if (
        typeof content[1] !== "undefined" &&
        typeof content[1].text !== "undefined"
      ) {
        op = document.createElement("div");
        op.classList.add("overprint");
        var alt = true;
        if (type === "chat") {
          for (i = 1; i < content.length; i++) {
            if (typeof content[i].text === "undefined") {
              continue;
            }
            line = document.createElement("div");
            line.classList = "line";
            if (alt) {
              line.classList.add("alt");
            }
            alt = !alt;
            line.innerHTML = formatText(
              content[i].text,
              content[i].formatting,
              content[i].subtype
            );
            op.appendChild(
              line
            );
          }
          middleChildIB.appendChild(op);
        }
        if (
          type === "text" || type === "quote" ||
          type === "ask" || type === "link"
        ) {
          if (
            typeof content === "undefined" ||
            typeof content !== "undefined" &&
            content.length === 0
          ) {
            if (
              typeof post.trail !== "undefined" &&
              typeof post.trail[0] !== "undefined" &&
              typeof post.trail[0].content !== "undefined" &&
              post.trail[0].content.length > 0
            ) {
              content = post.trail[0].content;
            }
          }
          for (i = 1; i < content.length; i++) {
            if (typeof content[i].text !== "undefined") {
              line = document.createElement("div");
              line.innerHTML = formatText(
                content[i].text,
                content[i].formatting,
                content[i].subtype
              );
              op.appendChild(
                line
              );
            }
            if (
              typeof content[i].media !== "undefined" &&
              content[i].media.length > 0 ||
              typeof content[i].poster !== "undefined" &&
              content[i].poster.length > 0
            ) {
              imgs = typeof content[i].poster === "undefined" ?
                content[i].media : content[i].poster;
              brick.classList.add("has-img");
              line = smallestMedia(imgs);
              h = line.height;
              op.appendChild(
                line
              );
              op.appendChild(fade);
            }
          }
          middleChildIB.appendChild(op);
        }
      }
    } // photo images, audio, video
    if (
      !(
        typeof content !== "undefined" &&
        typeof content[0] !== "undefined" &&
        typeof content[0].media !== "undefined" &&
        content[0].media.length > 0 ||
        typeof content !== "undefined" &&
        typeof content[0] !== "undefined" &&
        typeof content[0].poster !== "undefined" &&
        content[0].poster.length > 0
      )
    ) {
      if(
        typeof content !== "undefined" &&
        typeof post.content !== "undefined"
      ) {
        content = post.content; // another backflip :)
        // I'm done with ^ NPF neue posts here :)
      }
    }
    if (
      type === "link" &&
      typeof content !== "undefined" &&
      typeof content[0] !== "undefined" &&
      typeof content[0].title !== "undefined"
    ) {
      line = document.createElement("div");
      line.innerHTML = formatText(
        content[0].title,
        content[0].formatting,
        "link"
      );
      if (typeof content[0].description !== "undefined") {
        line.innerHTML += formatText(
          content[0].description,
          content[0].formatting,
          "normal"
        );
      }
      middleChildIB.appendChild(
        line
      );
    }
    if (
      typeof content !== "undefined" &&
      typeof content[0] !== "undefined" &&
      typeof content[0].media !== "undefined" &&
      content[0].media.length > 0 ||
      typeof content !== "undefined" &&
      typeof content[0] !== "undefined" &&
      typeof content[0].poster !== "undefined" &&
      content[0].poster.length > 0
    ) {
      imgs = typeof content[0].poster === "undefined" ?
        content[0].media : content[0].poster;
      line = smallestMedia(imgs);
      brick.classList.add("has-img");
      h = line.height;
      middleChildIB.appendChild(line);
      if (type === "text") {
        middleChildIB.appendChild(fade);
      }
    } else if (
      typeof content[1] !== "undefined" &&
      typeof content[1].media !== "undefined" &&
      content[1].media.length > 0 ||
      typeof content[1] !== "undefined" &&
      typeof content[1].poster !== "undefined" &&
      content[1].poster.length > 0
    ) {
      imgs = typeof content[1].poster === "undefined" ?
        content[1].media : content[1].poster;
      line = smallestMedia(imgs);
      brick.classList.add("has-img");
      h = line.height;
      middleChildIB.appendChild(line);
      if (type === "text") {
        middleChildIB.appendChild(fade);
      }
    }
    if (
      type === "image" || h < 125 &&
      type !== "text" &&
      type !== "ask"
    ) {
      brick.style.height = Math.round(h) + "px";
    } else {
      brick.style.height = "125px";
    }
    if (
      type === "image" || type === "video" || type === "audio"
    ) {
      // I discovered this looks nice, so I'm doing some design
      var captionInlineBlock = document.createElement("div");
      captionInlineBlock.classList.add("caption-inline-block");
      var captionTR = document.createElement("div");
      captionTR.classList.add("caption-tr");
      var captionTD = document.createElement("div");
      captionTD.classList.add("caption-td");
      var caption = document.createElement("div");
      caption.classList.add("caption");
      var capContent;
      if (
        typeof post.trail !== "undefined" &&
        post.trail.length > 0
      ) {
        for (i = 0; i < post.trail.length; i++) {
          if (
            typeof post.trail[i].content !== "undefined" &&
            post.trail[i].content.length > 0
          ) {
            capContent = post.trail[i].content;
            for (l = 0; l < capContent.length; l++) {
              if (
                typeof capContent[l].text !== "undefined"
              ) {
                captionInlineBlock.innerHTML += "<div>" + formatText(
                  capContent[l].text,
                  capContent[l].formatting,
                  capContent[l].subtype
                ) + "</div>";
              }
            }
          }
        }
      }
      if (captionInlineBlock.innerHTML.length === 0) {
        capContent = typeof post.content !== "undefined" &&
          post.content.length > 0 ?
          post.content : content;
        for (i = 0; i < capContent.length; i++) {
          if (typeof capContent[i].text !== "undefined") {
            captionInlineBlock.innerHTML += "<div>" + formatText(
              capContent[i].text,
              capContent[i].formatting,
              capContent[i].subtype
            ) + "</div>";
          }
        }
      }
      captionTD.appendChild(captionInlineBlock);
      captionTR.appendChild(captionTD);
      caption.appendChild(captionTR);
      brick.appendChild(caption);
    }
    if (type === "image") {
      var imgCount = -1;
      for (i = 1; i < content.length; i++) {
        if (typeof content[i].media !== "undefined") {
          ++imgCount;
        }
      }
      if (imgCount > 0) {
        var imgCountDiv = document.createElement("div");
        imgCountDiv.classList.add("img-count");
        imgCountDiv.appendChild(
          document.createTextNode("+" + imgCount + " more")
        );
        brick.appendChild(imgCountDiv);
      }
    }
    if (type === "video") {
      orly = document.createElement("div");
      orly.classList.add("play_overlay");
      brick.appendChild(orly);
    }
    if (type === "audio") {
      orly = document.createElement("div");
      orly.classList.add("listen_overlay");
      brick.appendChild(orly);
    }
    if (post.state === "private") {
      orly = document.createElement("div");
      orly.classList.add("private_overlay");
      brick.classList.add("private");
      brick.appendChild(orly);
    }
    // this is the tags and links thingy
    brick.href = post.post_url;
    brick.setAttribute("target", "_blank");
    var linksLayer = document.createElement("div");
    linksLayer.classList.add("links-layer");
    var linksTrow = document.createElement("div");
    linksTrow.classList.add("trow");
    var tagsLayer = document.createElement("div");
    tagsLayer.classList.add("tags-layer");
    if (typeof post.tags !== "undefined") {
      var tagsLayerContainer = document.createElement("div");
      tagsLayerContainer.classList.add("tag-container");
      post.tags.sort(function (a, b) {
        return a.length - b.length;
      });
      for (i = 0; i < post.tags.length; i++) {
        tagsLayerContainer.appendChild(
          document.createTextNode(
            "#" + post.tags[i] + " "
          )
        );
      }
      tagsLayer.appendChild(tagsLayerContainer);
    }
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var noEdit = typeof href[5] !== "undefined" &&
        (
          href[5] === "dashboard" ||
          href[5] === "archive" ||
          href[5] === "tagged" ||
          href[5] === "likes" ||
          href[5] === "search"
        );
    // post bricks edit button
    var link1 = document.createElement("a");
    link1.setAttribute("target", "_blank");
    link1.classList.add("link-edit");
    link1.href = noEdit ?
      "/dashboard/blog/" + post.blog_name + "/" + post.id :
    "/edit/" + post.id;
    link1.setAttribute("title",
                       (noEdit ? "Peepr" : "Edit")
                      );
    link1.appendChild(
      (noEdit?
       svgForType.view.cloneNode(true):
       svgForType.edit.cloneNode(true)
      )
    );
    link1.setAttribute("data-id", post.id);
    // only add like/reblog buttons if posts are visible
    if (!noEdit) {
      link1.addEventListener("click", function(e) {
        e.preventDefault();
        e.stopPropagation();
        e.cancelBubble = true;
        var iframe = document.createElement("iframe");
        iframe.setAttribute("data-id", this.getAttribute("data-id"));
        document.getElementById(
          "post_" + this.getAttribute("data-id")
        ).classList.remove("prevent-anim");
        iframe.id = "neue_post_form-iframe";
        var reminisce = 0;
        iframe.addEventListener("load", function () {
          var replaceAfterEdit = this;
          var id = this.getAttribute("data-id");
          // this checks if done editing/closed
          clearInterval(reminisce);
          reminisce = setInterval(function () {
            var w = document.getElementById(
              "neue_post_form-iframe"
            ).contentWindow;
            var p = w.document.getElementsByClassName(
              "post-forms-modal"
            )[0];
            if (
              typeof p === "undefined" ||
              typeof p !== "undefined" &&
              p.length === 0 ||
              typeof p !== "undefined" &&
              (
                w.getComputedStyle(p).
                getPropertyValue("display") === "none" ||
                w.getComputedStyle(p).
                getPropertyValue("opacity").toString() === "0"
              )
            ) {
              clearInterval(reminisce);
              document.body.removeChild(
                document.getElementById("neue_post_form-iframe")
              );
              reloadBrick(replaceAfterEdit);
            }
          }, 500);
        });
        iframe.src = "https://www.tumblr.com/neue_web/iframe/edit/" +
          post.id;
        iframe.setAttribute("scrolling", "no");
        iframe.setAttribute("frameborder", "0");
        iframe.setAttribute("title", "Post forms");
        document.body.appendChild(iframe);
      });
    } else {
      link1.addEventListener("click", function (e){
        e.cancelBubble = true;
        e.stopProgagation();
      });
    }
    // post bricks view post link
    var link2 = document.createElement("a");
    link2.setAttribute("target", "_blank");
    link2.addEventListener("click", function (e){
      e.cancelBubble = true;
      e.stopProgagation();
    });
    link2.classList.add("link-view");
    link2.href = post.post_url;
    link2.setAttribute("target", "_blank");
    link2.setAttribute("title", "View Post");
    link2.appendChild(
      svgForType.see.cloneNode(true)
    );
    // post bricks like button
    var isReblogable = href[3] !== "draft" && href[3] !== "queued";
    if (isReblogable) {
      var link3 = document.createElement("a");
      link3.setAttribute("target", "_blank");
      link3.classList.add("link-like");
      link3.setAttribute("data-id", post.id);
      link3.href = post.post_url + "#like" + post.reblog_key;
      link3.setAttribute(
        "data-like-info",
        JSON.stringify({"id":post.id,"reblog_key":post.reblog_key})
      );
      link3.setAttribute("target", "_blank");
      link3.setAttribute("title", "Like Post");
      var whiteHeart = post.liked ?
          svgForType.liked.cloneNode(true):
      svgForType.notes.cloneNode(true);
      whiteHeart.setAttribute("fill", post.liked ? "#f56": "#fff");
      link3.appendChild(
        whiteHeart
      );
      link3.classList.add(post.liked ? "liked" : "not-liked");
      link3.addEventListener("click", function (e) {
        e.cancelBubble = true;
        e.stopPropagation();
        e.preventDefault();
        if (this.classList.contains("clicked")) {
          return;
        }
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        this.classList.remove("new-liked");
        this.classList.add("clicked");
        var button = this;
        var liked = this.classList.contains("liked");
        var info = this.getAttribute("data-like-info");
        var v2url = liked ?
            "/api/v2/user/unlike" : "/api/v2/user/like";
        var token = data.getAttribute("data-api-token");
        var href = document.location.href.split(/[\/\?&#=]+/g);
        var name = href[4];
        var csrfToken = data.getAttribute("data-csrf-token");
        if (csrfToken !== "0") {
          var xhttp = new XMLHttpRequest();
          xhttp.onreadystatechange = function () {
            if (this.readyState == 4 && this.status == 200) {
              button.innerHTML = "";
              var cb = document.getElementById(
                "post_" + button.getAttribute("data-id")
              );
              if (liked) {
                whiteHeart = svgForType.notes.cloneNode(true);
                whiteHeart.setAttribute("fill", "#fff");
                button.classList.remove("liked");
                button.classList.add("not-liked");
                cb.classList.remove("liked");
              } else {
                whiteHeart = svgForType.liked.cloneNode(true);
                whiteHeart.setAttribute("fill", "#f56");
                button.classList.add("liked");
                button.classList.remove("not-liked");
                cb.classList.add("liked");
                // graphical aftertaste for reblog
                var bigHeart = svgForType.liked.cloneNode(true);
                bigHeart.setAttribute("fill", "#f56");
                bigHeart.setAttribute("width", "125");
                bigHeart.setAttribute("height", "125");
                bigHeart.classList.add("big-heart");
                setTimeout(function(){
                  bigHeart.parentNode.removeChild(bigHeart);
                }, 1700);
                cb.appendChild(bigHeart);
                button.classList.add("new-liked");
              }
              button.appendChild(whiteHeart);
              button.classList.remove("clicked");
            }
          };
          xhttp.open("POST", v2url, true);
          // headers only after open and only before send
          xhttp.setRequestHeader(
            "Accept", "application/json;format=camelcase"
          );
          xhttp.setRequestHeader(
            "Authorization", "Bearer " + token
          );
          xhttp.setRequestHeader(
            "X-CSRF", csrfToken
          );
          xhttp.setRequestHeader(
            "Content-Type", "application/json; charset=utf8"
          );
          xhttp.setRequestHeader(
            "X-Version", "redpop/3/0//redpop/"
          );
          xhttp.send(info);
        } // else {
        // TODO, (just in case) get a new CSRF token here?
        // this may not be needed...?
        // the token seems to stay ok, so far :)
        //}
      });
      // posts bricks reblog button
      var link4 = document.createElement("a");
      link4.setAttribute("target", "_blank");
      link4.classList.add("link-reblog");
      link4.href = post.post_url + "#like" + post.reblog_key;
      link4.setAttribute("data-id", post.id);
      link4.setAttribute("data-reblog_key", post.reblog_key);
      link4.setAttribute("target", "_blank");
      link4.setAttribute("title", "Reblog Post");
      var whiteReblog = svgForType["reblog-self"].cloneNode(true);
      whiteReblog.setAttribute("fill", "#fff");
      link4.appendChild(
        whiteReblog
      );
      link4.addEventListener("click", function (e) {
        e.cancelBubble = true;
        e.stopPropagation();
        e.preventDefault();
        if (
          this.classList.contains("clicked") ||
          this.classList.contains("reblogged")
        ) {
          return;
        }
        var id = this.getAttribute("data-id");
        var key = this.getAttribute("data-reblog_key");
        var button = this;
        this.classList.remove("new-liked");
        this.classList.add("clicked");
        data.setAttribute("data-single_edit_id", id);
        data.setAttribute("data-current_edit_index", "-1");
        data.setAttribute("data-current_edit_action", "reblog");
        // negative index for outside of queue single reblogs
        fetchEditSubmit(
          function(){
            var cb = document.getElementById(
              "post_" + button.getAttribute("data-id")
            );
            button.children[0].setAttribute("fill", "#7EFF29");
            button.classList.remove("clicked");
            button.classList.add("reblogged");
            cb.classList.add("reblogged");
            reblogAnimation(button.getAttribute("data-id"));
          });
      });
    }
    tagsLayer.addEventListener("click", function (e) {
      e.cancelBubble = true;
      e.stopPropagation();
      e.preventDefault();
      var clickParentBrick = new Event("click");
      this.parentNode.parentNode.
      parentNode.dispatchEvent(clickParentBrick);
    });
    tagsLayer.appendChild(link1);
    tagsLayer.appendChild(link2);
    if (isReblogable) {
      tagsLayer.appendChild(link3);
      tagsLayer.appendChild(link4);
    }
    linksTrow.appendChild(tagsLayer);
    linksLayer.appendChild(linksTrow);
    brick.appendChild(linksLayer);
    // sandwich, yum
    middleChildTD.appendChild(middleChildIB);
    middleChildTR.appendChild(middleChildTD);
    middleChildT.appendChild(middleChildTR);
    middleChild.appendChild(middleChildT);
    brick.appendChild(middleChild);
    // close off the brick and return below
    var lastChild = document.createElement("div");
    lastChild.classList.add("overlay");
    var jz = document.createElement("div");
    jz.classList.add("inner");
    var dt = document.createElement("div");
    var d = new Date(post.timestamp * 1000);
    var b = d.getDate();
    var px = ["th ", "st ", "nd ", "rd ", "th ", "th ",
              "th ", "th ", "th ", "th ", "th "][b % 10];
    if (b === 12 || b === 11) {
      px = "th ";
    }
    var date = [
      "Sun - ", "Mon - ", "Tue - ", "Wed - ",
      "Thu - ", "Fri - ", "Sat - "
    ][d.getDay()] + [
      "Jan ", "Feb ", "Mar ", "Apr ",
      "May ", "Jun ", "Jul ", "Aug ",
      "Sep ", "Oct ", "Nov ", "Dec "
    ][d.getMonth()] + b + px + d.getFullYear();
    dt.classList.add("date");
    dt.appendChild(document.createTextNode(date));
    jz.appendChild(dt);
    lastChild.appendChild(jz);
    brick.appendChild(lastChild);
    if (
      typeof content !== "undefined" &&
      typeof content[0] !== "undefined" &&
      typeof content[0].attribution !== "undefined" &&
      typeof content[0].attribution.url !== "undefined"
    ) {
      var sourceLabel2 = document.createElement("div");
      sourceLabel2.setAttribute(
        "title",
        "link: " + content[0].attribution.url
      );
      var symlink1 = svgForType.symlink.cloneNode(true); //:D
      symlink1.setAttribute("fill", "rgba(100,110,255,1)");
      sourceLabel2.appendChild(symlink1);
      sourceLabel2.classList.add("source-label2");
      brick.appendChild(sourceLabel2);
    }
    if (
      typeof post.source_url_raw !== "undefined" &&
      post.source_url_raw !== "" &&
      post.source_url_raw !== false
    ) {
      var sourceLabel1 = document.createElement("div");
      sourceLabel1.setAttribute(
        "title",
        "source: " + post.source_url_raw
      );
      var symlink2 = svgForType.symlink.cloneNode(true); //:D
      symlink2.setAttribute("fill", "#eee");
      sourceLabel1.appendChild(symlink2);
      sourceLabel1.classList.add("source-label1");
      brick.appendChild(sourceLabel1);
    }
    // lastly create the event to highlight single stuff
    brick.addEventListener("click", function (e) {
      e.stopPropagation();
      e.preventDefault();
      e.cancelBubble = true;
      highlightBrick(this, !this.classList.contains("highlighted"));
    });
    return brick; // end from var makeBrickFromAPIPost
  }
  // end giant makeBrick brick building function

  // since tumblr put a somewhat api/v2 on the main domain,
  // instead of api.tumblr.com ect...
  // greasemonkey can use an api
  // without registering an oauth key (_-.-)shh
  var asyncRepeatApiRead = function (api) {
    if(typeof api === "string") {
      api = JSON.parse(api);
    }
    var lcontent = document.getElementsByClassName("l-content")[0];
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var name = href[4];
    var endHeader;
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    data.classList.add("fetching-from-tumblr-api");
    if ( // this is the liked/by page if any JSON
      href[5] === "likes" &&
      typeof api.response.liked_posts !== "undefined" &&
      api.response.liked_posts.length > 0
    ) {
      api.response.posts = api.response.liked_posts;
    }
    if ( // this is the dashboards JSON
      typeof api.response.posts === "undefined" &&
      typeof api.response.timeline !== "undefined" &&
      typeof api.response.timeline.elements !== "undefined"
    ) {
      api.response.posts = api.response.timeline.elements;
    }
    if ( // tagged & search JSON
      typeof api.response.posts !== "undefined" &&
      typeof api.response.posts.data !== "undefined"
    ) {
      api.response.posts = api.response.posts.data;
      if (
        typeof api.response._links === "undefined" &&
        api.response.posts.length - 1 > 0
      ) {
        api.response._links = {
          "next": {
            "href":  data.getAttribute("data-ajax-first-subpage") +
            "&post_offset=" + api.response.posts[
              api.response.posts.length - 1
            ].timestamp
          }
        }
      };
      // I know, these ^ are endless
      // idea: [pause button]
    }
    if (
      typeof api.response.posts !== "undefined"
    ) {
      if(api.response.posts.length === 0) {
        endHeader = document.createElement("div");
        endHeader.classList.add("heading");
        endHeader.id = "heading_solum"; // end latin
        endHeader.appendChild(
          document.createTextNode("END") // idky... :)
        );
        lcontent.appendChild(endHeader);
        // done here too, should be
        data.classList.add("next_page_false");
        return;
      }
      var tagsAllArr = JSON.parse(
        data.getAttribute("data-tags_all_arr")
      );
      var idsAllArr = JSON.parse(
        data.getAttribute("data-ids_all_arr")
      );
      var typesAllArr = JSON.parse(
        data.getAttribute("data-types_all_arr")
      );
      var typeToIds = JSON.parse(
        data.getAttribute("data-type_to_ids")
      );
      var idToTags = JSON.parse(
        data.getAttribute("data-id_to_tags")
      );
      var idToTypes = JSON.parse(
        data.getAttribute("data-id_to_types")
      );
      var lastMonthTimestamp = parseFloat(
        data.getAttribute("data-last_month_timestamp")
      );
      var lastYearTimestamp = parseFloat(
        data.getAttribute("data-last_year_timestamp")
      );
      var idToOrigin = JSON.parse(
        data.getAttribute("data-id_to_origin")
      );
      var idToState = JSON.parse(
        data.getAttribute("data-id_to_state")
      );
      var idToTimestamp = JSON.parse(
        data.getAttribute("data-id_to_timestamp")
      );
      var idToNotes = JSON.parse(
        data.getAttribute("data-id_to_notes")
      );
      var tagToIds = JSON.parse(
        data.getAttribute("data-tag_to_ids")
      );
      var post = api.response.posts;
      var tag;
      var id;
      var type;
      var url;
      var reblog;
      var me;
      var media;
      var j;
      var newBrick;
      var monthHeader;
      var lastTimestamp;
      var lastYearstamp;
      if (!lcontent.classList.contains("albino")) {
        lcontent.classList.add("albino");
      }
      var t = [
        "text", "image", "chat", "ask", "video", "audio", "link", "quote"
      ];
      for (var i = 0; i < post.length; i++) {
        id = post[i].id;
        if (idsAllArr.indexOf(id) !== -1) {
          continue;
        }
        type = post[i].type;
        me = post[i];
        media = me.media;
        if (t.indexOf(type) === -1) { // neue type blocks???
          if (
            typeof post[i].trail != "undefined" &&
            typeof post[i].trail[0] !== "undefined" &&
            typeof post[i].trail[0].layout !== "undefined" &&
            typeof post[i].trail[0].layout[0] !== "undefined"
          ) {
            me = post[i].trail[0].layout;
            type = me[0].type;
          }
          if (
            t.indexOf(type) === -1 &&
            typeof post[i].trail != "undefined" &&
            typeof post[i].trail[0] !== "undefined" &&
            typeof post[i].trail[0].content !== "undefined" &&
            typeof post[i].trail[0].content[0] !== "undefined"
          ) {
            me = post[i].trail[0].content;
            type = me[0].type;
          }
          if (
            t.indexOf(type) === -1 &&
            typeof post[i].content !== "undefined" &&
            typeof post[i].content[0] === "undefined" &&
            typeof post[i].trail !== "undefined" &&
            typeof post[i].trail[0] !== "undefined" &&
            typeof post[i].trail[0].content !== "undefined"
          ) {
            me = post[i].trail[0].content;
            type = me[0].type;
          }
          if (
            t.indexOf(type) === -1 &&
            typeof post[i].content !== "undefined" &&
            typeof post[i].content[1] !== "undefined" &&
            typeof post[i].content[1].subtype !== "undefined"
          ) {
            me = post[i].content;
            type = me[1].subtype; // chat, maybe
          }
          if (
            t.indexOf(type) === -1 &&
            typeof post[i].content !== "undefined" &&
            typeof post[i].content[0] !== "undefined"
          ) {
            me = post[i].content;
            type = me[0].type;
          }
          if (
            typeof me !== "undefined" &&
            typeof me[0] !== "undefined" &&
            typeof me[0].subtype !== "undefined" &&
            type !== me[0].subtype &&
            t.indexOf(me[0].subtype) !== -1
          ) {
            type = me[0].subtype;
          }
        }
        if(typeof post[i].timestamp === "undefined") {
          continue;
        }
        lastTimestamp = (new Date(
          post[i].timestamp * 1000)
                        ).getMonth();
        lastYearstamp = (new Date(
          post[i].timestamp * 1000)
                        ).getFullYear();
        if(
          lastTimestamp !== lastMonthTimestamp ||
          lastYearstamp !== lastYearTimestamp
        ) {
          lastMonthTimestamp = lastTimestamp;
          lastYearTimestamp = lastYearstamp;
          data.setAttribute(
            "data-last_month_timestamp", lastMonthTimestamp
          );
          data.setAttribute(
            "data-last_year_timestamp", lastYearTimestamp
          );
          monthHeader = document.createElement("div");
          monthHeader.classList.add("heading");
          monthHeader.id = "heading_" + post[i].timestamp;
          monthHeader.appendChild(
            document.createTextNode([
              "Jan ", "Feb ", "Mar ", "Apr ",
              "May ", "Jun ", "Jul ", "Aug ",
              "Sep ", "Oct ", "Nov ", "Dec "
            ][lastTimestamp] + lastYearstamp)
          );
          lcontent.appendChild(monthHeader);
        }
        // this replaces everything Tumblr wrote inside the bricks
        // with our own flavor, of brick, new brick
        newBrick = makeBrickFromApiPost(
          post[i], type, me, i + parseInt(data.getAttribute("data-last-post-index"))
        );
        if (newBrick !== false) {
          lcontent.appendChild(newBrick);
        }
        idsAllArr.push(id);
        if (typesAllArr.indexOf(type) === -1) {
          typesAllArr.push(type);
          typeToIds[type] = [];
        }
        typeToIds[type].push(id);
        if (
          typeof post[i].reblogged_from_name !== "undefined"
        ) {
          reblog = post[i].reblogged_from_name;
          if (reblog === name) {
            if (
              typesAllArr.indexOf("reblog-self") === -1
            ) {
              typesAllArr.push("reblog-self");
              typeToIds["reblog-self"] = [];
            }
            typeToIds["reblog-self"].push(id);
            idToOrigin[id] = "reblog-self";
          } else {
            if (
              typesAllArr.indexOf("reblog-other") === -1
            ) {
              typesAllArr.push("reblog-other");
              typeToIds["reblog-other"] = [];
            }
            typeToIds["reblog-other"].push(id);
            idToOrigin[id] = "reblog-other";
          }
        } else {
          if (
            typesAllArr.indexOf("original") === -1
          ) {
            typesAllArr.push("original");
            typeToIds.original = [];
          }
          typeToIds.original.push(id);
          idToOrigin[id] = "original";
        }
        if (post[i].state === "private") {
          if (
            typesAllArr.indexOf("private") === -1
          ) {
            typesAllArr.push("private");
            typeToIds.private = [];

          }
          idToState[id] = "private";
          typeToIds.private.push(id);
        } else {
          idToState[id] = "public";
        }
        idToNotes[id] = post[i].note_count;
        idToTimestamp[id] = post[i].timestamp;
        idToTypes[id] = type;
        if (typeof post[i].tags !== "undefined") {
          for (var l = 0; l < post[i].tags.length; l++) {
            tag = post[i].tags[l];
            if (tagsAllArr.indexOf(tag) === -1) {
              tagsAllArr.push(tag);
              tagToIds[tag] = [];
            }
            tagToIds[tag].push(id);
            if (typeof idToTags[id] === "undefined") {
              idToTags[id] = [];
            }
            if (idToTags[id].indexOf(tag) === -1) {
              idToTags[id].push(tag)
            }
          }
        }
        if (i + 1 > post.length) {
          data.setAttribute(
            "data-last-post-index",
            parseInt(data.getAttribute("data-last-post-index")) + i
          );
        }
      }
      pluginBuildColumns();
      // the later onclick event to select-by runs outside of plugin scope
      // so we use the DOM for var memory
      data.setAttribute(
        "data-tags_all_arr", JSON.stringify(tagsAllArr)
      );
      data.setAttribute(
        "data-ids_all_arr", JSON.stringify(idsAllArr)
      );
      data.setAttribute(
        "data-types_all_arr", JSON.stringify(typesAllArr)
      );
      data.setAttribute(
        "data-id_to_tags", JSON.stringify(idToTags)
      );
      data.setAttribute(
        "data-id_to_types", JSON.stringify(idToTypes)
      );
      data.setAttribute(
        "data-id_to_origin", JSON.stringify(idToOrigin)
      );
      data.setAttribute(
        "data-id_to_state", JSON.stringify(idToState)
      );
      data.setAttribute(
        "data-id_to_timestamp", JSON.stringify(idToTimestamp)
      );
      data.setAttribute(
        "data-id_to_notes", JSON.stringify(idToNotes)
      );
      data.setAttribute(
        "data-tag_to_ids", JSON.stringify(tagToIds)
      );
      data.setAttribute(
        "data-type_to_ids", JSON.stringify(typeToIds)
      );
    }
    var token = data.getAttribute("data-api-token");
    var nextPage = false;
    if (
      typeof api.response !== "undefined" &&
      typeof api.response._links !== "undefined" &&
      typeof api.response._links.next !== "undefined" &&
      typeof api.response._links.next.href !== "undefined"
    ) {
      nextPage = api.response._links.next.href;
    } else if (
      typeof api.response !== "undefined" &&
      typeof api.response.timeline !== "undefined" &&
      typeof api.response.timeline._links.next !== "undefined" &&
      typeof api.response.timeline._links.next.href !== "undefined"
    ) {
      nextPage = api.response.timeline._links.next.href;
    }
    if (
	  nextPage !== false && nextPage !== data.getAttribute("data-page-repeat")
	) {
      data.setAttribute("data-page-repeat", nextPage); // loop much?
      // walk, don't run :)
      data.classList.add("fetching-from-tumblr-api");
      var repeatedTimeOut = setInterval(function() {
        // this delays pagination slightly, but it may be better...
        // it's steadier, non-bot-ish, and is easier to process :)
        var tagAlongDiff = document.getElementsByClassName("brick").length -
            document.getElementsByClassName("laid").length;
        if(
          document.getElementById(
            "pause_button"
          ).classList.contains("paused") ||
          tagAlongDiff > 10 // < this :)
        ) {// the CSS3 animation thing is also crash prevention :)
          return;
        }
        clearInterval(repeatedTimeOut);
        getResponseText(
          "/api" + nextPage,
          asyncRepeatApiRead,
          [
            ["Authorization", "Bearer " + token]
          ]
        );
      }, 500);
    } else {
      endHeader = document.createElement("div");
      endHeader.classList.add("heading");
      endHeader.id = "heading_solum"; // end latin
      endHeader.appendChild(
        document.createTextNode("END")
      );
      lcontent.appendChild(endHeader);
      // this is where it usually ends, mostly
      data.classList.add("next_page_false");
    }
  };
  // end var asyncRepeatApiRead

  // re the brick building for edits replaceBrick
  var reloadBrick = function (replaceAfterEdit) {
    if (
      typeof replaceAfterEdit === "undefined" || // what is this?
      replaceAfterEdit.classList.contains("reload-in-progress")
    ) {
      return;
    }
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var idsAllArr = JSON.parse(
      data.getAttribute("data-ids_all_arr")
    );
    replaceAfterEdit.classList.add("reload-in-progress");
    var highlightAfterReload = replaceAfterEdit.classList.contains("highlighted");
    var preloadContainer = document.createElement("div");
    preloadContainer.classList.add("edited-gif");
    var preloadTrow = document.createElement("div");
    preloadTrow.classList.add("trow");
    var preloadInner = document.createElement("div");
    preloadInner.classList.add("edited-center");
    // show spinner until post re-caches/updates
    var preLoad = new Image();
    preLoad.src = loderGifSrc;
    preLoad.style.width = "32px;"
    preLoad.style.height = "32px";
    preLoad.classList.add("bm_load_img");
    preloadInner.appendChild(preLoad);
    preloadTrow.appendChild(preloadInner);
    preloadContainer.appendChild(preloadTrow);
    replaceAfterEdit.appendChild(preloadContainer);
    setTimeout(function () {
      // this reloads the brick DOM after edit/close
      var href = document.location.href.split(/[\/\?&#=]+/g);
      var isDraft = href[3] === "draft";
      var isQueue = href[3] === "queued";
      var draftQueue = isQueue ? "/posts/queue" :
                       isDraft ? "/posts/draft" : "/posts";
      var id = replaceAfterEdit.getAttribute("data-id");
      var idBefore = idsAllArr.indexOf(id) - 1 > -1 ?
                     idsAllArr[idsAllArr.indexOf(id) - 1] : -1;
      var index = idsAllArr.indexOf(id);
      getResponseText(
        "/api/v2/blog/" + name + draftQueue +
        "?limit=1&reblog_info=1&npf=1&" +
        (
          isDraft ?
            idBefore !== -1 ?
            "before_id=" + idBefore :
            ""
          :// sloppy ^ yet functional :)
          isQueue ? // thanks oddly Tumblr draft and queue API
          index !== -1 ?
            "offset=" + index :
            ""
          :
          "id=" + id
        ),
        function (api) {// post to replace
          if(typeof api === "string") {
            api = JSON.parse(api);
          }
          var t = ["text", "image", "chat", "ask",
                   "video", "audio", "link", "quote"];
          var p2r = document.getElementById("post_" + id);
          var me;
          var type;
          // TODO, delete the superflous content/me argument
          // and put this inside the makeBrick function...
          // but only if it breaks...
          // not broken; don't fix it :)
          if (
            typeof api.response !== "undefined" &&
            typeof api.response.posts !== "undefined"
          ) {
            var post = api.response.posts;
            if (
              typeof post[0].trail != "undefined" &&
              typeof post[0].trail[0] !== "undefined" &&
              typeof post[0].trail[0].layout !== "undefined" &&
              typeof post[0].trail[0].layout[0] !== "undefined"
            ) {
              me = post[0].trail[0].layout;
              type = me[0].type;
            }
            if (
              t.indexOf(type) === -1 &&
              typeof post[0].trail != "undefined" &&
              typeof post[0].trail[0] !== "undefined" &&
              typeof post[0].trail[0].content !== "undefined" &&
              typeof post[0].trail[0].content[0] !== "undefined"
            ) {
              me = post[0].trail[0].content;
              type = me[0].type;
            }
            if (
              t.indexOf(type) === -1 &&
              typeof post[0].content !== "undefined" &&
              typeof post[0].content[0] === "undefined" &&
              typeof post[0].trail !== "undefined" &&
              typeof post[0].trail[0] !== "undefined" &&
              typeof post[0].trail[0].content !== "undefined"
            ) {
              me = post[0].trail[0].content;
              type = me[0].type;
            }
            if (
              t.indexOf(type) === -1 &&
              typeof post[0].content !== "undefined" &&
              typeof post[0].content[1] !== "undefined" &&
              typeof post[0].content[1].subtype !== "undefined"
            ) {
              me = post[0].content;
              type = me[1].subtype; // chat, maybe
            }
            if (
              t.indexOf(type) === -1 &&
              typeof post[0].content !== "undefined" &&
              typeof post[0].content[0] !== "undefined"
            ) {
              me = post[0].content;
              type = me[0].type;
            }
            if (
              typeof me !== "undefined" &&
              typeof me[0] !== "undefined" &&
              typeof me[0].subtype !== "undefined" &&
              type !== me[0].subtype &&
              t.indexOf(me[0].subtype) !== -1
            ) {
              type = me[0].subtype;
            }
            var newBrick = makeBrickFromApiPost(
              post[0], type, me, p2r.getAttribute("data-index")
            ); // this third ^ me argument could be expunged
            newBrick.classList.add("laid");
            var lcontent = document.getElementsByClassName(
              "l-content"
            )[0];
            lcontent.replaceChild(newBrick, p2r);
            if (highlightAfterReload) {
              highlightBrick(
                document.getElementById("post_" + id), true
              );
            }
            pluginBuildColumns();
          }
        },
        [
          [
            "Authorization",
            "Bearer " + data.getAttribute("data-api-token")
          ]
        ]
      );
    }, 1000); // delay 1 secode for cache update, perhaps?
  };
  // end the brick reload function

  // this is how we upload photos/images
  var photoUploadAndSubmit = function () { // and repeat asynchronously
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var asDraftCheck = document.getElementById("photos_as_draft");
    var papb = document.getElementById("post_all_photos_button");
    if (!data.classList.contains("photo-upload-in-progress")) {
      data.classList.add("photo-upload-in-progress");
      asDraftCheck.disabled = true;
      papb.disabled = true;
    }
    var asDraft = asDraftCheck.checked;
    var apiKey = data.getAttribute("data-x-tumblr-form-key");
    var brk = document.getElementsByClassName("photo-brick");
    var brick = brk[brk.length - 1];
    brick.classList.add("upload-working");
    brick.scrollIntoView({behavior: "smooth"});
    var i;
    var rich = brick.getElementsByClassName("rich")[0];
    var img = brick.getElementsByClassName("photo-brick-img");
    var uploaded = brick.getElementsByClassName("uploaded");
    var squeakyToy = {};
    var code;
    var formData;
    var upImg;
    var api;
    // upload first or return or repeat
    if (uploaded.length !== img.length) {
      code = img[uploaded.length].firstChild.getAttribute("img-code");
      formData = new FormData();
      formData.append("photo", unreadFile[code]);
      getResponseText(
        {url: "/svc/post/upload_photo?source=post_type_form", post: formData},
        function(re){
          api = JSON.parse(re);
          if (
            typeof api !== "undefined" &&
            typeof api.response !== "undefined" &&
            typeof api.response[0] !== "undefined" &&
            typeof api.response[0].url !== "undefined"
          ) {
            img[uploaded.length].firstChild.src = api.response[0].url;
          }// whether we get the URL or not, the show must go on
          img[uploaded.length].classList.add("uploaded");
          photoUploadAndSubmit();
          // the fallback is to post a straight data url and let
          // Tumblr backend convert it to image/png etc on post
          // but that shouldn't have to happen
        },
        [
          ["X-tumblr-form-key", apiKey],
          ["X-Requested-With", "XMLHttpRequest"]
        ]
      );
      return;
    }
    // AFTER THE UPLOAD, SUMMER HAS GONE...
    brick.style.top = (0 - brick.clientHeight) + "px";
    // this v runs after that ^ runs for each photo to upload
    squeakyToy["post[two]"] = rich.innerHTML;
    squeakyToy["post[three]"] = "";
    // this post is an edit
    squeakyToy.channel_id = name;
    squeakyToy["post[type]"] = "photo";
    squeakyToy["post[state]"] = asDraft ? "1" : "0";
    squeakyToy["post[slug]"] = "";
    squeakyToy["post[date]"] = "";
    squeakyToy["post[publish_on]"] = "";
    if (img.length > 0) {
      var order = [];
      var oneone = "";
      var one = 0;
      for (i = 0; i < img.length; i++) {
        order.push("o" + (i+1));
        if (img[i].classList.contains("row-with-one-img")) {
          oneone += "1"; // new photoset order
          one = 0;
        }
        if (img[i].classList.contains("row-with-two-img")) {
          if (one === 0) {
            oneone += "2"; // new photoset order
          }
          ++one;
          if (one >= 2) {
            one = 0;
          }
        }
        if (img[i].classList.contains("row-with-three-img")) {
          if (one === 0) {
            oneone += "3"; // new photoset order
          }
          ++one;
          if (one >= 3) {
            one = 0;
          }
        }
        squeakyToy["images[o" + (i+1) + "]"] = img[i].firstChild.src;
        squeakyToy["caption[o" + (i+1) + "]"] = "";
      }
      squeakyToy["post[photoset_order]"] = order.join(",");
      squeakyToy["post[photoset_layout]"] = oneone;
    }
    squeakyToy["post[tags]"] = "";
    var tag = brick.getElementsByClassName("tag");
    var tags = [];
    if (tag.length > 0) {
      for (i = 0; i < tag.length; i++) {
        tags.push(tag[i].innerHTML);
      }
      squeakyToy["post[tags]"] = tags.join(",");
    }
    getResponseText( // this is step #2
      "/svc/secure_form_key",
      function(re2) {
        getResponseText(
          { // this is step #3
            url: "/svc/post/update",
            post: JSON.stringify(squeakyToy)
          },
          function(re3) {
            if (!JSON.parse(re3).errors) { // success image posted!
              if (brk.length > 0) {
                brick.parentNode.removeChild(brick);
              }
              if (brk.length > 0) {
                photoUploadAndSubmit();
              } else {
                var blogLink = document.createElement("a");
                var bigHome = svgForType.home.cloneNode(true);
                bigHome.setAttribute("width", "40");
                bigHome.setAttribute("height", "40");
                bigHome.setAttribute("fill", "#555");
                blogLink.appendChild(bigHome);
                blogLink.appendChild(
                  document.createTextNode(
                    "Visit your new posts..."
                  )
                );
                blogLink.id = "return_to_dash_link";
                blogLink.href = "/blog/" + name + (asDraft ? "/drafts" : "");
                data.classList.remove("photo-upload-in-progress");
                asDraftCheck.disabled = false;
                papb.disabled = false;
                document.body.appendChild(blogLink);
              }
            }
          },
          [ // the prev request brought us some puppies :)
            ["X-tumblr-puppies", re2.puppies],
            ["X-tumblr-form-key", apiKey],
            ["X-Requested-With", "XMLHttpRequest"],
            ["Content-Type", "application/json"],
            ["Accept", "application/json, text/javascript, */*; q=0.01"]
          ]
        );
      },
      [
        ["Accept", "application/json, text/javascript, */*; q=0.01"],
        ["X-tumblr-form-key", apiKey],
        ["X-Requested-With", "XMLHttpRequest"]
      ]
    );
  };
  // end photoUploadAndSubmit

  // this edits posts and reblogs posts,
  // and it can even clone posts accidentally :P
  var fetchEditSubmit = function (success) {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var isDraft = document.getElementById("re-as-draft").checked;
    var action = data.getAttribute("data-current_edit_action");
    var isReblog = action === "reblog";
    var href = document.location.href.split(/[\/\?&#=]+/g);
    var name = href[4];
    var reblogger = data.getAttribute("data-reblog-to-here"); // if any
    var apiKey = data.getAttribute("data-x-tumblr-form-key");
    var id;
    var key;
    var changes;
    var change;
    var brick;
    var editQueue = document.getElementsByClassName("edit-reblog-queue");
    // editReblog queue index
    var qIndex = parseInt(data.getAttribute("data-current_edit_index"));
    if (qIndex === -1) {
      id = data.getAttribute("data-single_edit_id");
      brick = document.getElementById("post_" + id);
      brick.classList.add("edit-reblog-queue");
      if (id === "0") {
        return; // just in case
      }
    } else { // batch  reblogEdit v / ^ single reblogEdit
      id = editQueue[qIndex].getAttribute("data-id");
      brick = document.getElementById("post_" + id);
    }
    var postInEdit = document.getElementById("post_" + id);
    key = postInEdit.getAttribute("data-reblog_key");
    if (apiKey !== "0") {
      getResponseText(// A Reblog/Edit Takes 4 AJAX Steps
        "/svc/post/fetch?" + (
          isReblog ?
          "reblog_id=" + id + "&reblog_key=" + key :
          "post_id=" + id
        ),
        // this is step #1
        function(re1) {
          var fetch = JSON.parse(re1).post;
          var bone = {}; // puppies / fetch / bone :)
          var reblog_post_id = typeof fetch.parent_id !== "undefined" ?
              fetch.parent_id :
          typeof fetch.root_id !== "undefined" ?
              fetch.root_id : id; // this is step #2// this is step #2
          // text chat quote
          if (typeof fetch.one !== "undefined") {
            bone["post[one]"] = fetch.one;
          }
          if (typeof fetch.two !== "undefined") {
            bone["post[two]"] = fetch.two;
          }
          if (typeof fetch.three !== "undefined") {
            bone["post[three]"] = fetch.three;
          }
          if (typeof fetch.source_url !== "undefined") {
            bone["post[source_url]"] = fetch.source_url;
          }
          if (typeof fetch["post[state]"] !== "undefined") {
            bone["post[state]"] = fetch["post[state]"];
          }
          bone["post[type]"] = fetch.type;
          if (isReblog) {
            // this post is a reblog
            bone.channel_id = reblogger;
            bone.reblog = true;
            bone.reblog_key = key;
            bone.reblog_post_id = reblog_post_id;
            bone.context_id = reblogger;
            bone["post[state]"] = isDraft ? "1" : "0";
            bone["post[slug]"] = ""; // bone, slug, and harmony :);
            bone["post[tags]"] = "";
            bone["post[date]"] = "";
            bone["post[publish_on]"] = "";
          } else {
            // this post is an edit
            bone.channel_id = name;
            bone.post_id = id;
            bone.edit_post_id = id;
            bone.reblog = false;
            bone["post[state]"] = fetch.state.toString();
            bone["post[slug]"] = fetch.slug; // lol what? :);
            bone["post[tags]"] = fetch.tags;
            bone["post[date]"] = fetch.date;
            bone["post[publish_on]"] = "";
            if (
              action !== "caption" &&
              action !== "backdate"
            ) {
              // simple edits, less dynamic and easy
              changes = JSON.parse(action);
              if(Array.isArray(changes)) {
                change = changes[qIndex];
              } else {
                change = changes;// turn and face the strange :)
              }
              for (var ch in change) {
                bone[ch] = change[ch];
              }
              var removeWhenDone =
                  typeof changes["post[state]"] !== "undefined" &&
                  changes["post[state]"] === "1" ||
                  changes["post[state]"] === "0" &&
                  href["3"] === "queued" ||
                  changes["post[state]"] === "0" &&
                  href["3"] === "draft" ||
                  changes["post[state]"] === "on.2" ||
                  changes["post[state]"] === "2"
            } else if (action === "caption") {
              var rich2 = document.getElementById(
                "rich_text_caption"
              );
              var b4 = document.getElementById(
                "prepend-caption-option"
              ).checked;
              var ow = document.getElementById(
                "overwrite-caption-option"
              ).checked;
              var af = document.getElementById(
                "append-caption-option"
              ).checked;
              bone["post[two]"] = af ? bone["post[two]"] + rich2.innerHTML:
                                  ow ? rich2.innerHTML:
                                  b4 ? rich2.innerHTML + bone["post[two]"] :
                                       bone["post[two]"] + rich2.innerHTML;//""?
            } else if (action === "backdate") {
              var isOneDay = document.getElementById(
                "bd-one-day"
              ).checked;
              var isTwoDay = document.getElementById(
                "bd-two-day"
              ).checked;
              var isNoDay = document.getElementById(
                "bd-no-day"
              ).checked;
              var isOneTime = document.getElementById(
                "bt-one-time"
              ).checked;
              var isTwoTime = document.getElementById(
                "bt-two-time"
              ).checked;
              var isNoTime = document.getElementById(
                "bt-no-time"
              ).checked;
              var mo1 = document.getElementById("moleft").value - 1;
              var mo2 = document.getElementById("moright").value - 1;
              var dt1 = document.getElementById("dtleft").value;
              var dt2 = document.getElementById("dtright").value;
              var yr1 = document.getElementById("yrleft").value;
              var yr2 = document.getElementById("yrright").value;
              var ho1 = document.getElementById("holeft").value;
              var ho2 = document.getElementById("horight").value;
              var mt1 = document.getElementById("mtleft").value;
              var mt2 = document.getElementById("mtright").value;
              var pm1 = document.getElementById("pmleft").checked;
              var pm2 = document.getElementById("pmright").checked;
              // 1000 because seconds to miliseconds...
              var ts = parseInt(editQueue[qIndex].getAttribute("data-timestamp"));
              var d1 = new Date();
              var d2 = new Date();
              if (isOneDay || isTwoDay) {
                d1.setMonth(mo1);
                d1.setDate(dt1);
                d1.setYear(yr1);
              }
              if (isOneTime || isTwoTime) {
                d1.setMinutes(mt1);
                d1.setHours(ho1 + pm1 ? 12 : 0);
              }
              if (isTwoDay) {
                d2.setMonth(mo2);
                d2.setDate(dt2);
                d2.setYear(yr2);
              }
              if (isTwoTime) {
                d2.setMinutes(mt2);
                d2.setHours(ho2 + pm2 ? 12 : 0);
              }
              var df = (d1.getTime() - d2.getTime()) / (editQueue.length+1);
              var b = new Date();
              b.setTime(d1.getTime() - df * qIndex);
              var dt = [
                "Jan ", "Feb ", "Mar ", "Apr ",
                "May ", "Jun ", "Jul ", "Aug ",
                "Sep ", "Oct ", "Nov ", "Dec "
              ][b.getMonth()] + b.getDate() + ", " + b.getFullYear();
              var h = (b.getHours() < 12 ? b.getHours() : b.getHours()-12);
              if (h === 0) {
                h = 12;
              }
              var time = " " + h + ":" +
                  (b.getMinutes()/100).toFixed(2).split(".")[1] + ":" +
                  (b.getSeconds()/100).toFixed(2).split(".")[1] +
                  (b.getHours() < 12 ? "am" : "pm");
              if (href[3] === "draft") {
                bone["post[publish_on]"] = dt + time;
                bone["post[state]"] = "on.2";
              } else {
                bone["post[date]"] = dt + time;
              }
            }
          }
          // photo posts
          if (typeof fetch.photos !== "undefined") {
            var order = [];
            var oneone = "";
            var photo;
            for (var i = 0; i < fetch.photos.length; i++) {
              photo = fetch.photos[i];
              order.push(photo.id);
              oneone += "1"; // backup photoset order
              bone["images[" + photo.id + "]"] = "";
              bone["caption[" + photo.id + "]"] = "";
            }
            bone["post[photoset_order]"] = order.join(",");
            bone["post[photoset_layout]"] = (
              typeof fetch.photoset_layout !== "undefined"
            ) ?
              fetch.photoset_layout : oneone;
          }
          getResponseText( // this is step #3
            "/svc/secure_form_key",
            function(re2) {
              getResponseText(
                { // this is step #4
                  url: "/svc/post/update",
                  post: JSON.stringify(bone)
                },
                function(re3) {
                  if (!JSON.parse(re3).errors) { // success reblogged!
                    brick.classList.remove("edit-reblog-queue");
                    if (!isReblog) {// assume edited appearance
                      if (
                        removeWhenDone
                      ) {
                        brick.parentNode.removeChild(brick);
                        pluginBuildColumns();
                      } else {
                        reloadBrick(brick);
                      }
                    } else {
                      reblogAnimation(id);
                    }
                    success(success);
                  } else {
                    brick.classList.remove("edit-reblog-queue");
                    success(success);// repeat for next
                  }
                },
                [ // the prev request brought us some puppies :)
                  ["X-tumblr-puppies", re2.puppies],
                  ["X-tumblr-form-key", apiKey],
                  ["X-Requested-With", "XMLHttpRequest"],
                  ["Content-Type", "application/json"],
                  ["Accept", "application/json, text/javascript, */*; q=0.01"]
                ]
              );
            },
            [
              ["Accept", "application/json, text/javascript, */*; q=0.01"],
              ["X-tumblr-form-key", apiKey],
              ["X-Requested-With", "XMLHttpRequest"]
            ]
          );
        },
        [
          ["Accept", "application/json, text/javascript, */*; q=0.01"],
          ["X-tumblr-form-key", apiKey],
          ["X-Requested-With", "XMLHttpRequest"]
        ]
      );
    }
  };
  // end the single fetchEdit reblog/edit

  // this function runs once v ^ then this goes repeatedly
  var fetchEditSubmitMulti = function () {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var highlighted = document.getElementsByClassName("highlighted");
    var qIndex = -1;
    for (var i = 0; i < highlighted.length; i++) {
      if (
        this.getAttribute("data-edit_action") === "reblog" &&
        highlighted[i].classList.contains("private")
      ) {
        continue;
      }
      qIndex++;
      highlighted[i].classList.add("edit-reblog-queue");
    }
    data.setAttribute("data-current_edit_index", qIndex);
    data.setAttribute(
      "data-current_edit_action",
      this.getAttribute("data-edit_action")
    );
    fetchEditSubmit(function(success){
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var qIndex = parseInt(data.getAttribute("data-current_edit_index"));
      qIndex--;
      if (qIndex >= 0) {
        data.setAttribute("data-current_edit_index", qIndex);
        fetchEditSubmit(success);
        // repeat
      }
    });
  };
  // end edit/reblogging stuff

  // extra chrome buttons and widgets, and nav-links
  var mpe = document.createElement("div");
  var mpeIcon = new Image();
  mpeIcon.width = 18;
  mpeIcon.height = 16;
  mpeIcon.src = // PNG is the monkey emoji from windows 8.1
    '' +
    'AAAAAcCAYAAAAAwr0iAAAABmJLR0QA/wD/AP+gvaeTAAAACX' +
    'BIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH5AUIEy8cVCgtoA' +
    'AAAB1pVFh0Q29tbWVudAAAAAAAQ3JlYXRlZCB3aXRoIEdJTV' +
    'BkLmUHAAAGt0lEQVRIx62Xa2wU1xXHf/fO7MO7awMOdkyIU1' +
    'roIynhUbWGEh4BVB4NKDWvuGkaCkHQVHGkkGLvAkXFIpm1oa' +
    'QNBaXIxRAItagbmkARKCpQIkxJoUrSDy2VEESkYIgxNvauvb' +
    'Mzc/rBNjH4RSTOt7mPc/73f849/zuKPqzWmhe28RelVPBlD/' +
    '2QgbPHw3xjVnTHh9wj071N/Dn+s3CbCpZk0FI5UK4/nC2fhQ' +
    'dIw4qINFbVxF/8Tue6E9aiewfgT/HiLhPekDSBdVqpW2MKEP' +
    'SYCDefA/ib9ZQxObbv3gA4Fi9ifnQLAFs3rFXipEK+rBzyCn' +
    '6A63oACAo/KbKlfkWtVSjAi/csBVOj1VyMj+VQfGnOg8a1X2' +
    'aFfbu/PGYC949bSOQrBYhj39okdLCiZNAXCbaz/BfdvlXXgW' +
    'PxokEaryFDkngChHMZPGIM/ztzhAy/RrqsdTFOtapI8fTonr' +
    'P9BT5tzWVc7AAAr1f8ytB46oWSVU5nWrssnJMN6vrnRxVEXJ' +
    'Q27/RZB/LSuNjB6qPxp5kW3dvv6c9as7SJGzmnR84AFcj1Lr' +
    '8HXoPu81Io1S24oPAw3h0XO1hdVb7WnBbdS61V2GvgyooyAN' +
    'L4JyUJ3/iSd756mPffbRr3qofxxG0RUwRsm8BhUCkPLT05VA' +
    'gad8pR6+lNg+XaDNng0xNi+zlhLegRwLKSdQA4+GpctL6ihv' +
    '6wIHZwQFKFd6eVP3YLwPvWAibH/tgyKVYzu0Vlrb+psk8p5B' +
    'LwiaDq7/D79TA3X86Ruv21xtxigMmxGo5ZRT2C+G3Fpu8bOK' +
    'GkimwOqtTbALOiO58VjJG3AEyK1XA83u5genSPNTNa9VhB7O' +
    'BD42IHhtWrvFKFdONCIX6FV37CWrAYYGqsukcAGZIYrEA3M9' +
    'B/jSG+zvFMaVxzWwoej3Z38E78+SEZJGb3lmMDN2DgFh62fp' +
    'Lf3r6718M549EjHjr5gHwyNFOaMjrH3whEd+j+qjdEImziDO' +
    '9tXiEI+skgbc8BTIjtvw3E9ooNVPx83tWkCp8FVQgy/7Xy1z' +
    'TA7pUFzf0CsAnm2gTGgvRYlJ3dMUhyVa1VuEKWtYMAOBBfzv' +
    'KSte1APe/HIOdy5fLakfLPnN9VvNq3GHUxr4sU0BsIhYQ03u' +
    'aTw+cXv1P+fB7A3Oh2AE5ahUxfvffqVZW/UuMNVVCyhG19O+' +
    '20v8SXj/fTdmqgXMfrB69CsFUAm8AxQb2ukI+mRfdeADhq/Y' +
    'hpsbf4a/yZ4z7sKQkiI9L4z5v9EyCdrbcVVFLh3dcXEz5JiZ' +
    '/UVFsFpnro0yeshb9JqKxj06K/rwNIkLkxTy5NbFUZq/2klv' +
    'XLwKH4svEG7imT9Acm9p6gJNeAur+/faq9ZpSHxiZQ7eArTR' +
    'K6NCdWKSetefUe+sZEu+Zr+m6VzMCpmxLdtwXUprtZLyjVUR' +
    'sSoLUoSHLRABr9AAkVed9PasSrocqA7t+RxsAhU5pMgFbCV9' +
    'L46d6YeidDAR7GIx7aBzBI6o8D5EjdhNsAVJaX9VQBKQ9Nig' +
    'AALWpAwlYB94u8A1xMmtWAs3Uq326/VoYfREKSmGUesRYzM7' +
    'arXThK24VjS/mmoeO9o1kJssw20tMVQpPK1gAZJC74JfUPYH' +
    'znw6QvNhRCSgXrw7T8YXZ0h93BqqdxlY3/72Zn8APW8pyQSn' +
    'w3JIlhzfLxY4LO85PKVOKN9ZGmUWWfAwhJS1rjtTqYOJhnTJ' +
    'xWA3dSXwy0EVy/zb+2EfZ1KKNZYABLS9e/bbY/LhfOhRvzXX' +
    'wPGzj5A6WhzUN7HloE9ZGHrs3zPt3aUYxtCkm3EaRJZVc+4F' +
    '1811H+3QqZ3uvVxPG/YJeNKo4/kw5LIlfhLrLxf3rhlW8p83' +
    'B8yUxTGnfYBK5pvBhws7OCr+tc75wa3VBS8tN/hX8t5uH40l' +
    'GuNIxWyFdBofEGfXv14SsfWHNWuhhrBDXfwDXuTElEbq52MA' +
    'pBpTTuGA+DpIpE/22MxTRwy3zYg8/rRxY+W/rK8a4byza+mT' +
    'XZPTT5pDXvCaf1qeEG7miF5AH5HW00CFAQO/jxkfIlL2V4za' +
    'cdfGMc5RsuqJBPbFchuSbpfBNnIigczIaEytw6O1r1FoCpca' +
    'ua1H037gx+IL4ikuG+V2xKeh3gBmm9qBBXUA3AdZAmkDMAx+' +
    'NF6vHSqsvAZqrE2PrZplEGTmSwXHMypPnBgdLwqMYLeGidVJ' +
    'EPZ2TtrIZdn2tB2cZd31i3avF/rI3bia1a3vFbVhjSuE8q5J' +
    'spgmdNnMsGju64RoaNP2mr4PnvRd9s6iq9nep3N2Zt3M7/Ad' +
    'nvxY2Pj+AwAAAAAElFTkSuQmCC';
  mpe.id = "mpe_title";
  mpe.appendChild(mpeIcon);
  mpe.setAttribute("title", "Mass Post Editor Features 4");
  en = document.getElementsByClassName("editor_navigation")[0];
  var selectAllFrag = document.createDocumentFragment();
  selectAllFrag.appendChild(svgForType.select.cloneNode(true));
  var selectAllSpan = document.createElement("span");
  selectAllSpan.appendChild(document.createTextNode("Select 100"));
  selectAllFrag.appendChild(selectAllSpan);
  var selectAll_chrome = newChromeButton("select-all", selectAllFrag, false);
  var selectByFrag = document.createDocumentFragment();
  selectByFrag.appendChild(svgForType.select.cloneNode(true));
  selectByFrag.appendChild(document.createTextNode("Select By"));
  var selectBy_chrome = newChromeButton("select-by", selectByFrag, true);
  var selectBy_widget = selectBy_chrome.getElementsByClassName(
    "widget"
  )[0];
  selectBy_widget.style.top = "50px";
  selectBy_widget.style.right = "90px";
  // this shows the select-by widget and populates it with tags/types
  selectBy_chrome.getElementsByTagName("input")[0].
    addEventListener("change", populateSelectByWidget);
  var pauseFrag1 = document.createDocumentFragment();
  var playSpan = document.createElement("span");
  playSpan.classList.add("play");
  playSpan.innerHTML = "&#x25B6;";
  var pauseSpan = document.createElement("span");
  pauseSpan.classList.add("pause");
  pauseSpan.innerHTML = "&#x2590;&#x2590;";
  pauseFrag1.appendChild(playSpan);
  pauseFrag1.appendChild(pauseSpan);
  var pause_chrome = newChromeButton(
    "pause", pauseFrag1, false
  );
  var pauseFrag2 = document.createDocumentFragment();
  var canvas = document.createElement("canvas");
  canvas.id = "status";
  canvas.width = 72;
  canvas.height = 15;
  var pLoaded = document.createElement("span");
  pLoaded.id = "p_loaded";
  pLoaded.appendChild(
    document.createTextNode("x0")
  );
  pauseFrag2.appendChild(canvas);
  pauseFrag2.appendChild(pLoaded);
  var ajaxInfo_chrome = newChromeButton(
    "ajax-info", pauseFrag2, false
  );
  // gutter control (easy)
  var gutterFrag = document.createDocumentFragment();
  var gutterInputCheck = document.createElement("input");
  gutterInputCheck.type = "checkbox";
  gutterInputCheck.checked = false;
  var gutterInputNumber = document.createElement("input");
  gutterInputNumber.type = "number";
  gutterInputNumber.value = 6;
  gutterInputCheck.id = "gutter-checkbox";
  var gutterLabel = document.createTextNode("Gutter");
  var newGutterChange = function () {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var newGutter = gutterInputNumber.value;
    if (gutterInputCheck.checked) {
      data.setAttribute("data-column_gutter", newGutter);
    } else {
      data.setAttribute("data-column_gutter", "6");
    }
    pluginBuildColumns();
  };
  gutterInputCheck.addEventListener("change", newGutterChange);
  gutterInputNumber.addEventListener("change", newGutterChange);
  gutterFrag.appendChild(gutterInputCheck);
  gutterFrag.appendChild(gutterLabel);
  gutterFrag.appendChild(gutterInputNumber);
  gutterInputNumber.addEventListener("click", function(e) {
    e.stopPropagation();
    e.preventDefault();
    e.cancelBubble = true;
  });
  gutterInputCheck.addEventListener("click", function(e) {
    this.checked = !this.checked;
  });
  var gutter_chrome = newChromeButton(
    "gutter", gutterFrag, false
  );
  gutter_chrome.getElementsByTagName("button")[0].
    addEventListener("click", function() {
    var b = this.getElementsByTagName("input")[0];
    b.checked = !b.checked;
    newGutterChange();
  });
  // view captions
  var hoverSpan = document.createElement("span");
  var hoverLabel = document.createElement("label");
  var hoverCheck = document.createElement("input");
  hoverCheck.type = "checkbox";
  hoverCheck.id = "hover-only";
  hoverCheck.addEventListener("change", function () {
    var lcontent = document.getElementsByClassName("l-content")[0];
    if (this.checked) {
      lcontent.classList.remove("hoverless");
      setCookie("view_hover", "on", 99);
    } else {
      lcontent.classList.add("hoverless");
      setCookie("view_hover", "", -1);
    }
  });
  hoverLabel.appendChild(
    svgForType.see.cloneNode(true)
  );
  hoverLabel.appendChild(
    document.createTextNode("+Hover")
  );
  hoverLabel.setAttribute("for", "hover-only");
  hoverSpan.appendChild(hoverCheck);
  hoverSpan.appendChild(hoverLabel);
  var captionsFrag = document.createDocumentFragment();
  captionsFrag.appendChild(svgForType.see.cloneNode(true));
  captionsFrag.appendChild(svgForType.caption.cloneNode(true));
  var captions_chrome = newChromeButton(
    "view-captions", captionsFrag, false
  );
  captions_chrome.getElementsByTagName(
    "button"
  )[0].addEventListener("click", function () {
    var lcontent = document.getElementsByClassName("l-content")[0];
    if (lcontent.classList.contains("with-captions")) {
      lcontent.classList.remove("with-captions");
      setCookie("view_captions", "", -1);
      this.removeAttribute("style");
      for (i = 0; i < 2; i++) {
        this.getElementsByTagName("svg")[i].setAttribute("fill", "#fff");
      }
    } else {
      lcontent.classList.add("with-captions");
      setCookie("view_captions", "on", 99);
      this.style.color = "rgba(0,65,100,1)";
      this.children[0].setAttribute("fill", "rgba(0,65,100,1");
      this.style.boxShadow = "inset 0 3px 2px 2px rgba(0,0,0,0.4)";
      for (i = 0; i < 2; i++) {
        this.getElementsByTagName("svg")[i].setAttribute(
		  "fill", "rgba(0,65,100,1)"
		);
      }
    }
  });
  // editlinksReblogLikeButton
  var linksFrag = document.createDocumentFragment();
  linksFrag.appendChild(svgForType.see.cloneNode(true));
  linksFrag.appendChild(svgForType.notes.cloneNode(true));
  linksFrag.appendChild(svgForType["reblog-self"].cloneNode(true));
  linksFrag.appendChild(svgForType.edit.cloneNode(true));
  var links_chrome = newChromeButton(
    "view-links", linksFrag, false
  );
  links_chrome.getElementsByTagName(
    "button"
  )[0].addEventListener("click", function () {
    var i;
    var lcontent = document.getElementsByClassName("l-content")[0];
    if (lcontent.classList.contains("with-links")) {
      for (i = 0; i < 4; i++) {
        this.getElementsByTagName("svg")[i].setAttribute("fill", "#fff");
      }
      this.removeAttribute("style");
      lcontent.classList.remove("with-links");
      setCookie("view_links", "", -1);
    } else {
      for (i = 0; i < 4; i++) {
        this.getElementsByTagName("svg")[i].setAttribute("fill", "rgba(0,65,100,1)");
      }
      this.style.boxShadow = "inset 0 3px 2px 2px rgba(0,0,0,0.4)";
      lcontent.classList.add("with-links");
      setCookie("view_links", "on", 99);
    }
  });
  // pause buttons
  pause_chrome.getElementsByTagName(
    "button"
  )[0].classList.add("playing");
  pause_chrome.getElementsByTagName(
    "button"
  )[0].addEventListener("click", function () {
    if (this.classList.contains("done")) {
      return;
    }
    var b = this.classList.contains("playing");
    this.classList.add(b?"paused":"playing");
    this.classList.remove(!b?"paused":"playing");
  });
  ajaxInfo_chrome.getElementsByTagName(
    "button"
  )[0].addEventListener("click", function () {
    var pause = document.getElementById(
      "pause_button"
    );
    if (pause.classList.contains("done")) {
      return;
    }
    var b = pause.classList.contains("playing");
    pause.classList.add(b?"paused":"playing");
    pause.classList.remove(!b?"paused":"playing");
  });
  ajaxInfo_chrome.setAttribute(
    "title", "Time Till Next Page - Posts Loaded"
  );
  pause_chrome.setAttribute("title", "Pause Page Loading");
  selectAll_chrome.getElementsByTagName("button")[0].
    addEventListener(
    "click",
    function () {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      var idsAllArr = JSON.parse(
        data.getAttribute("data-ids_all_arr")
      );
      var alreadyHidden = data.classList.contains(
        "some-posts-already-hidden"
      );
      var visibleIdsAllArr = JSON.parse(
        data.getAttribute("data-visible_ids_all_arr")
      );
      var needle = parseFloat(
        data.getAttribute("data-select-all_needle")
      );
      var id;
      var hlBrick;
      var unSelctBrick;
      var firstNeedle = needle;
      var i;
      var limit = 100; // tumblr limit; not mine
      var selectedCount = 0;
      unSelctBrick = document.getElementsByClassName("highlighted");
      while (unSelctBrick.length > 0 ) {
        highlightBrick(unSelctBrick[0], 0);
      }
      if (alreadyHidden) { // select from visible
        while(
          needle < visibleIdsAllArr.length &&
          needle < firstNeedle + limit
        ) {
          id = visibleIdsAllArr[needle];
          hlBrick = document.getElementById("post_" + id);
          if (hlBrick !== null) {
            highlightBrick(hlBrick, 1);
            selectedCount++;
          }
          needle++;
        }
      } else { // select from all
        while(
          needle < idsAllArr.length &&
          needle < firstNeedle + limit
        ) {
          id = idsAllArr[needle];
          hlBrick = document.getElementById("post_" + id);
          if (hlBrick !== null) {
            highlightBrick(hlBrick, 1);
            selectedCount++;
          }
          needle++;
        }
      }
      this.getElementsByTagName("span")[0].innerHTML = "100 More";
      if (selectedCount < limit) {
        needle = 0;
        this.getElementsByTagName("span")[0].innerHTML = "Select 100";
      }
      data.setAttribute("data-select-all_needle", needle);
    }
  );
  document.getElementById(
    "delete_posts"
  ).parentNode.classList.add("remove-in-third-party-mode");
  document.getElementById(
    "delete_posts"
  );
  document.getElementById(
    "remove_tags"
  ).parentNode.classList.add("remove-in-third-party-mode");
  document.getElementById(
    "add_tags"
  ).parentNode.classList.add("remove-in-third-party-mode");
  var href = document.location.href.split(/[\/\?&#=]+/g);
  var name = href[4];
  links_chrome.setAttribute(
    "title",
    href[5] !== "follows" && href[5] !== "following" ?
    "Links: See tags. View Posts. Edit posts." :
    "Links: Follow/Unfollow URL Peepr ect."
  );
  captions_chrome.setAttribute("title", "See photo captions.");
  selectBy_chrome.setAttribute("title", "Select posts by tag.");
  ajaxInfo_chrome.setAttribute("title", "Pause posts loading.");
  selectBy_chrome.setAttribute("title", "Pause posts loading.");
  selectAll_chrome.setAttribute("title", "Select all posts.");
  gutter_chrome.setAttribute("title", "Create bigger gutters.");
  // this is the make private button
  var privateFrag = document.createDocumentFragment();
  privateFrag.appendChild(svgForType.private.cloneNode(true));
  var privateSpan = document.createElement("span");
  privateSpan.appendChild(document.createTextNode("Private"));
  privateFrag.appendChild(privateSpan);
  var private_chrome = newChromeButton("private", privateFrag, false);
  private_chrome.classList.add("remove-in-third-party-mode");
  private_chrome.getElementsByTagName(
    "button"
  )[0].addEventListener("click", fetchEditSubmitMulti);
  private_chrome.getElementsByTagName("button")[0].
    disabled = true;
  private_chrome.getElementsByTagName("button")[0].
    classList.add("disable-when-none-selected");
  private_chrome.classList.add("remove-in-third-party-mode");
  private_chrome.classList.add("remove-in-drafts-queue-mode");
  private_chrome.setAttribute("title", "Make selected private/unprivate.");
  // append chromeButtons
  var unselectFrag = document.createDocumentFragment();
  var unselectIcon = svgForType.unselect.cloneNode(true);
  unselectIcon.setAttribute("width", "15");
  unselectIcon.setAttribute("height", "15");
  unselectFrag.appendChild(unselectIcon);
  var unselectSpan = document.createElement("span");
  unselectSpan.classList.add("chrome_button");
  unselectSpan.appendChild(document.createTextNode("UnSelect"));
  unselectFrag.appendChild(unselectSpan);
  var cbr = document.createElement("span");
  cbr.classList.add("chrome_button_right");
  unselectFrag.appendChild(cbr);
  var unslect = document.getElementById("unselect")
  unslect.innerHTML = "";
  unslect.appendChild(unselectFrag);
  var unPnt = unslect.parentNode;
  var rtPnt = document.getElementById("remove_tags").parentNode;
  var dlPnt = document.getElementById("delete_posts").parentNode;
  // editor navigation
  var remTag = document.getElementById("remove_tags").children[0];
  remTag.innerHTML = "";
  var remFrag = document.createDocumentFragment();
  var remSymbol = document.createElement("h2");
  remSymbol.appendChild(document.createTextNode("-"));
  var addTag = document.getElementById("add_tags").children[0];
  addTag.innerHTML = "";
  remFrag.appendChild(remSymbol);
  remFrag.appendChild(document.createTextNode("Tags"));
  var addSymbol = document.createElement("h2");
  var addFrag = document.createDocumentFragment();
  addSymbol.appendChild(document.createTextNode("+"));
  addFrag.appendChild(addSymbol);
  var captionFrag = document.createDocumentFragment();
  captionFrag.appendChild(addSymbol.cloneNode(true));
  captionFrag.appendChild(document.createTextNode("Caption"));
  var caption_chrome = newChromeButton("add-caption", captionFrag, true);
  caption_chrome.classList.add("remove-in-third-party-mode");
  var caption_widget = caption_chrome.getElementsByClassName("widget")[0];
  var caption_check = caption_chrome.getElementsByTagName("input")[0];
  caption_check.classList.add("disable-when-none-selected");
  caption_check.disabled = true;
  caption_chrome.setAttribute("title", "Caption selected posts.");
  // this part is all add caption widget
  var rich2 = document.createElement("div");
  rich2.setAttribute("title", "caption");
  rich2.id = "rich_text_caption";
  rich2.contentEditable = true;
  rich2.designMode = "on";
  rich2.classList.add("rich");
  appendRichButtons(caption_widget, rich2, caption_widget);
  var captionTitle = document.createElement("h2");
  captionTitle.appendChild(
    document.createTextNode("Caption Posts")
  );
  var captionSubtitle = document.createElement("div");
  captionSubtitle.appendChild(
    document.createTextNode("Image,Video,Audio,Quote,Link,Chat, and Text")
  );
  caption_widget.appendChild(captionTitle);
  caption_widget.appendChild(captionSubtitle);
  caption_widget.appendChild(rich2);
  var pendContainer = document.createElement("div");
  pendContainer.classList.add("pend-container");
  var pend1 = document.createElement("div");
  var pend2 = document.createElement("div");
  var pend3 = document.createElement("div");
  var b4Radio = document.createElement("input");
  b4Radio.id = "prepend-caption-option";
  var b4Label = document.createElement("label");
  b4Label.setAttribute("for", "prepend-caption-option");
  b4Label.appendChild(document.createTextNode("Prepend"));
  var owRadio = document.createElement("input");
  owRadio.id = "overwrite-caption-option";
  var owLabel = document.createElement("label");
  owLabel.setAttribute("for", "overwrite-caption-option");
  owLabel.appendChild(document.createTextNode("Overwrite"));
  var owWarn = document.createElement("span");
  owWarn.classList.add("robot-warning");
  owWarn.appendChild(
    document.createTextNode(
      "This will erase and replace the whole text body of any post."
    )
  );
  var afRadio = document.createElement("input");
  afRadio.id = "append-caption-option";
  var afLabel = document.createElement("label");
  afLabel.setAttribute("for", "append-caption-option");
  afLabel.appendChild(document.createTextNode("Append"));
  b4Radio.type = "radio";
  b4Radio.name = "pend";
  b4Radio.classList.add("pend");
  pend1.appendChild(b4Radio);
  pend1.appendChild(b4Label);
  owRadio.type = "radio";
  owRadio.name = "pend";
  owRadio.classList.add("pend");
  pend2.appendChild(owRadio);
  pend2.appendChild(owLabel);
  pend2.appendChild(owWarn);
  afRadio.type = "radio";
  afRadio.name = "pend";
  afRadio.classList.add("pend");
  afRadio.checked = true;
  pend3.appendChild(afRadio);
  pend3.appendChild(afLabel);
  pendContainer.appendChild(pend1);
  pendContainer.appendChild(pend2);
  pendContainer.appendChild(pend3);
  caption_widget.appendChild(pendContainer);
  var capButt = butt("Add Caption");
  capButt.id = "add-caption_button2";
  capButt.setAttribute("data-edit_action", "caption");
  capButt.style.top = "268px";
  capButt.style.right = "9px";
  capButt.style.padding = "0 7px";
  capButt.addEventListener("click", fetchEditSubmitMulti);
  caption_widget.appendChild(capButt);
  var cancelCaption = butt("Cancel3");
  cancelCaption.addEventListener("click", function () {
    document.getElementById("add-caption").checked = false;
  });
  cancelCaption.style.top = "238px";
  cancelCaption.style.right = "9px";
  cancelCaption.style.padding = "0 7px";
  cancelCaption.setAttribute("title", "Close widget");
  caption_widget.appendChild(cancelCaption);
  // this part is backdate widget
  var scheduleInstead = href[3] === "draft";
  var backdateFrag = document.createDocumentFragment();
  backdateFrag.appendChild(
    svgForType.clock.cloneNode(true)
  );
  backdateFrag.appendChild(
    document.createTextNode(scheduleInstead ? "Schedule" : "BackDate")
  );
  var backdate_chrome = newChromeButton(
    "backdate", backdateFrag, true
  );
  backdate_chrome.classList.add("remove-in-third-party-mode");
  var backdate_widget = backdate_chrome.getElementsByClassName("widget")[0];
  var backdate_check = backdate_chrome.getElementsByTagName("input")[0];
  backdate_check.addEventListener("change", function () {
    if (!this.checked) {
      return;
    }
    var hl = document.getElementsByClassName("highlighted");
    var d1 = new Date(
      parseInt(
        hl[0].getAttribute("data-timestamp")
      ) * 1000
    );
    var d2 = new Date(
      parseInt(
        hl[hl.length-1].getAttribute("data-timestamp")
      ) * 1000
    );
    var inp = new Event("input");
    document.getElementById("moleft").value = d1.getMonth() + 1;
    document.getElementById("moright").value = d2.getMonth() + 1;
    document.getElementById("dtleft").value = d1.getDate();
    document.getElementById("dtright").value = d2.getDate();
    document.getElementById("yrleft").value = d1.getFullYear();
    document.getElementById("yrright").value = d2.getFullYear();
    document.getElementById("holeft").value = d1.getHours() >= 12 ?
      d1.getHours() - 12 : d1.getHours();
    document.getElementById("horight").value = d2.getHours()>= 12 ?
      d2.getHours() - 12 : d2.getHours();
    document.getElementById("mtleft").value = d1.getMinutes();
    document.getElementById("mtright").value = d2.getMinutes();
    document.getElementById("pmleft").checked = d1.getHours() >= 12;
    document.getElementById("pmright").checked = d2.getHours() >= 12;
    document.getElementById("moleft").dispatchEvent(inp);
    document.getElementById("moright").dispatchEvent(inp);
    document.getElementById("mtleft").dispatchEvent(inp);
    document.getElementById("mtright").dispatchEvent(inp);
  });
  backdate_check.classList.add("disable-when-none-selected");
  backdate_check.disabled = true;
  backdate_chrome.setAttribute(
    "title", scheduleInstead ?
    "Schedule up to 200 posts." :
    "Backdate selected posts."
  );
  var bdBody = document.createElement("div");
  bdBody.id = "backdate-body";
  var backdateTitle = document.createElement("h2");
  var backdateRules = document.createElement("div");
  backdateTitle.appendChild(
    document.createTextNode(
      scheduleInstead ?
      "Schedule Month/Date/Year":
      "BackDate Month/Date/Year"
    )
  );
  backdateRules.appendChild(
    document.createTextNode(" ")
  );
  bdBody.appendChild(backdateTitle);
  bdBody.appendChild(backdateRules);
  // I don't like new-fangled type="date" inputs that throw NaN sometimes
  var dateByNumbers = function(id){ // I'm old fashioned like Safari
    var d = new Date();
    var container = document.createElement("div");
    container.classList.add("date-input-bunch");
    var day = document.createElement("label");
    var thday = [
      "Sun ", "Mon ", "Tue ", "Wed ",
      "Thu ", "Fri ", "Sat "
    ];
    day.innerText = thday[d.getDay()];
    var mo = document.createElement("input");
    mo.type = "number";
    mo.value = d.getMonth() + 1;
    mo.id = "mo" + id;
    mo.classList.add("linput");
    var moLabel = document.createElement("label");
    moLabel.classList.add("rlabel");
    moLabel.setAttribute("for", "mo" + id);
    var month = [0,
      "Jan", "Feb", "Mar", "Apr",
      "May", "Jun", "Jul", "Aug",
      "Sep", "Oct", "Nov", "Dec"
    ];
    moLabel.innerText = month[d.getMonth()+1];
    var dt = document.createElement("input");
    dt.type = "number";
    dt.value = d.getDate();
    dt.id = "dt" + id;
    var dtLabel = document.createElement("label");
    dtLabel.setAttribute("for", "dt" + id);
    dtLabel.classList.add("narrow");
    dt.classList.add("linput");
    dtLabel.classList.add("rlabel");
    var px = function (b) {
      var px = ["th", "st", "nd", "rd", "th", "th",
                "th", "th", "th", "th", "th"][b % 10];
      if (b === 12 || b === 11) {
        px = "th ";
      }
      return px;
    };
    var yr = document.createElement("input");
    yr.type = "number";
    yr.id = "yr" + id;
    yr.value = d.getFullYear();
    dtLabel.innerText = px(d.getDate());
    var inputs = function () {
      if (this === mo && mo.value < 1) {
        mo.value = 12;
      }
      if (this === mo && mo.value > 12) {
        mo.value = 1;
      }
      var s = mo.value.toString();
      if (
        this === mo &&
        (
          s.length >= 2 && s.charAt(0) === "1" ||
          s.length >= 1 && s.charAt(0) !== "1"
        )
      ) {
        dt.focus();
      }
      s = dt.value.toString();
      if (
        this === dt &&
        (
          s.length >= 2 && s.charAt(0) === "1" ||
          s.length >= 1 && s.charAt(0) !== "1" &&
          s.charAt(0) !== "2" && s.charAt(0) !== "3"
        )
      ) {
        yr.focus();
      }
      var newD = new Date(yr.value, mo.value, 0);
      if (this === dt && dt.value <= 0) {
        dt.value = newD.getDate();
      }
      if (this === dt && dt.value > newD.getDate()) {
        dt.value = 1;
      }
      if (this === yr && dt.value < 0) {
        dt.value = 1;
      }
      if (this === yr && dt.value > newD.getDate()) {
        dt.value = newD.getDate();
      }
      newD = new Date(yr.value, mo.value-1, dt.value);
      day.innerText = thday[newD.getDay()];
      moLabel.innerText = month[mo.value];
      dtLabel.innerText = px(dt.value);
    };
    mo.addEventListener("input", inputs);
    dt.addEventListener("input", inputs);
    yr.addEventListener("input", inputs);
    var thisSelect = function () {
      this.select();
    };
    mo.addEventListener("focus", thisSelect);
    dt.addEventListener("focus", thisSelect);
    yr.addEventListener("focus", thisSelect);
    container.appendChild(mo);
    container.appendChild(moLabel);
    container.appendChild(dt);
    container.appendChild(dtLabel);
    container.appendChild(yr);
    container.appendChild(day);
    return container;
  };
  var bddate1 = dateByNumbers("left");
  var bddate2 = dateByNumbers("right");
  var bdrowDate = document.createElement("div");
  var bdinput1 = document.createElement("input");
  var bdinput2 = document.createElement("input");
  var bdinput3 = document.createElement("input");
  var bdlabel1 = document.createElement("label");
  var bdlabel2 = document.createElement("label");
  var bdlabel3 = document.createElement("label");
  bdinput1.id = "bd-no-day";
  bdinput2.id = "bd-one-day";
  bdinput3.id = "bd-two-day";
  bdinput2.checked = true;
  bdinput1.name = "bd-date-option";
  bdinput2.name = "bd-date-option";
  bdinput3.name = "bd-date-option";
  bdlabel1.setAttribute("for", "bd-no-day");
  bdlabel2.setAttribute("for", "bd-one-day");
  bdlabel3.setAttribute("for", "bd-two-day");
  bdlabel1.appendChild(
    document.createTextNode("Keep Same Date")
  );
  bdlabel2.appendChild(
    document.createTextNode("All Same Date")
  );
  bdlabel3.appendChild(
    document.createTextNode("Between Dates")
  );
  bdinput1.type = "radio";
  bdinput2.type = "radio";
  bdinput3.type = "radio";
  bdrowDate.appendChild(bdinput2);
  bdrowDate.appendChild(bdlabel2);
  bdrowDate.appendChild(bdinput3);
  bdrowDate.appendChild(bdlabel3);
  bdrowDate.appendChild(bdinput1);
  bdrowDate.appendChild(bdlabel1);
  bdrowDate.appendChild(bddate1);
  bdrowDate.appendChild(bddate2);
  bdBody.appendChild(bdrowDate);
  backdateTitle = document.createElement("h2");
  backdateRules = document.createElement("div");
  backdateTitle.appendChild(
    document.createTextNode(
      scheduleInstead ?
      "Schedule Hour:Minute":
      "BackDate Hour:Minute"
    )
  );
  backdateRules.appendChild(
    document.createTextNode(" ")
  );
  bdBody.appendChild(backdateTitle);
  bdBody.appendChild(backdateRules);
  var btrowTime = document.createElement("div");
  var btinput1 = document.createElement("input");
  var btinput2 = document.createElement("input");
  var btinput3 = document.createElement("input");
  var btlabel1 = document.createElement("label");
  var btlabel2 = document.createElement("label");
  var btlabel3 = document.createElement("label");
  btinput1.id = "bt-no-time";
  btinput2.id = "bt-one-time";
  btinput3.id = "bt-two-time";
  btinput1.checked = true;
  btinput1.name = "bt-time-option";
  btinput2.name = "bt-time-option";
  btinput3.name = "bt-time-option";
  btlabel1.setAttribute("for", "bt-no-time");
  btlabel2.setAttribute("for", "bt-one-time");
  btlabel3.setAttribute("for", "bt-two-time");
  btlabel1.appendChild(
    document.createTextNode("Keep Same Time")
  );
  btlabel2.appendChild(
    document.createTextNode("All Same Time")
  );
  btlabel3.appendChild(
    document.createTextNode("Between Times")
  );
  btinput1.type = "radio";
  btinput2.type = "radio";
  btinput3.type = "radio";
  btrowTime.appendChild(btinput2);
  btrowTime.appendChild(btlabel2);
  btrowTime.appendChild(btinput3);
  btrowTime.appendChild(btlabel3);
  btrowTime.appendChild(btinput1);
  btrowTime.appendChild(btlabel1);
  var timeByNumbers = function(id){
    var d = new Date();
    var container = document.createElement("div");
    container.classList.add("date-input-bunch");
    var ho = document.createElement("input");
    ho.type = "number";
    ho.value = d.getHours();
    ho.id = "ho" + id;
    ho.classList.add("linput");
    var hoLabel = document.createElement("label");
    hoLabel.classList.add("rlabel");
    hoLabel.setAttribute("for", "ho" + id);
    hoLabel.innerText = ":"
    hoLabel.classList.add("narrow");
    var mt = document.createElement("input");
    mt.type = "number";
    mt.value = d.getMinutes();
    mt.id = "mt" + id;
    mt.classList.add("linput");
    var pm = document.createElement("input");
    pm.type = "checkbox";
    pm.id = "pm" + id;
    var pmLabel = document.createElement("label");
    pmLabel.checked = d.getHours() >= 12;
    pmLabel.setAttribute("for", "pm" + id);
    pmLabel.classList.add("rlabel");
    var inputs = function () {
      if (ho.value >= 12) {
        ho.value = 1;
      }
      if (ho.value <= 0) {
        ho.value = 12;
      }
      if (mt.value > 60) {
        mt.value = 1;
      }
      if (mt.value < 0) {
        mt.value = 60;
      }
      var s = ho.value.toString();
      if (
        this === ho &&
        (
          s.length >= 2 && s.charAt(0) === "1" ||
          s.length >= 1 && s.charAt(0) !== "1"
        )
      ) {
        mt.focus();
      }
      if (mt.value <= 9) {
        mt.value = "0" + mt.value;
      }
    };
    inputs();
    ho.addEventListener("input", inputs);
    mt.addEventListener("input", inputs);
    var thisSelect = function () {
      this.select();
    };
    ho.addEventListener("focus", thisSelect);
    mt.addEventListener("focus", thisSelect);
    container.appendChild(ho);
    container.appendChild(hoLabel);
    container.appendChild(mt);
    container.appendChild(pm);
    container.appendChild(pmLabel);
    return container;
  };
  var btTime1 = timeByNumbers("left");
  var btTime2 = timeByNumbers("right");
  btrowTime.appendChild(btTime1);
  btrowTime.appendChild(btTime2);
  bdBody.appendChild(btrowTime);
  backdateRules = document.createElement("i");
  backdateRules.appendChild(
    document.createTextNode(
      "Visual Post-Brick-Re-Order Happens After Reload"
    )
  );
  var backdate2 = butt("Backdate2");
  if (scheduleInstead) {
    backdate2.children[0].innerHTML = "Schedule";
  }
  backdate2.setAttribute("data-edit_action", "backdate");
  var cancelBackdate = butt("Cancel4");
  cancelBackdate.addEventListener("click", function () {
    document.getElementById("backdate").checked = false;
  });
  backdate2.addEventListener("click", fetchEditSubmitMulti);
  bdBody.appendChild(backdateRules);
  bdBody.appendChild(backdate2);
  bdBody.appendChild(cancelBackdate);
  backdate_widget.appendChild(bdBody);
  // this is the other stuff that squeezes into a widget/button
  var urlFrag = document.createDocumentFragment();
  var urlSVG = svgForType.symlink.cloneNode(true);
  urlSVG.setAttribute("viewBox", "2 2 13 13");
  urlFrag.appendChild(urlSVG); // :D
  urlFrag.appendChild(
    document.createTextNode("URLs")
  );
  var url_chrome = newChromeButton(
    "urlstuff", urlFrag, true
  );
  url_chrome.classList.add("remove-in-third-party-mode");
  var url_widget = url_chrome.getElementsByClassName("widget")[0];
  var url_check = url_chrome.getElementsByTagName("input")[0];
  url_check.disabled = true;
  url_check.classList.add("disable-when-none-selected");
  var urlRow1 = document.createElement("div");
  var urlTitle1 = document.createElement("h2");
  urlTitle1.appendChild(
    document.createTextNode("Source URL")
  );
  urlRow1.appendChild(urlTitle1);
  var urlInput1 = document.createElement("input"); // source URL
  urlInput1.type = "text";
  urlInput1.id = "source_url";
  var urlRow2 = document.createElement("div");
  var urlTitle2 = document.createElement("h2");
  urlTitle2.appendChild(
    document.createTextNode("ClickThrough Link")
  );
  var urlInput2 = document.createElement("input"); // clickthrough
  urlInput2.type = "text";
  urlInput2.id = "clickthrough";
  var urlRow3 = document.createElement("div");
  var urlTitle3 = document.createElement("h2");
  urlTitle3.innerHTML = ".../URL/<b>slug</b>";
  var urlInput3 = document.createElement("input"); // slug
  urlInput3.type = "text";
  urlInput3.id = "slug";
  var urlThing = document.createElement("div");
  urlThing.id = "urlstuff_body";
  var addURL = butt("Add URLs");
  addURL.addEventListener("click", fetchEditSubmitMulti);
  var setURLValues = function () {
    var changes = {
      "post[three]": urlInput2.value,
      "post[source_url]": urlInput1.value,
      "post[slug]": urlInput3.value
    };
    addURL.setAttribute("data-edit_action", JSON.stringify(changes));
  };
  setURLValues();
  urlInput1.addEventListener("input", setURLValues);
  urlInput2.addEventListener("input", setURLValues);
  urlInput3.addEventListener("input", setURLValues);
  var urlRules1 = document.createElement("div");
  urlRules1.appendChild(
    document.createTextNode("(Original Posts Only)")
  );
  var urlRules2 = document.createElement("div");
  urlRules2.appendChild(
    document.createTextNode("Leave Blank to Remove")
  );
  var urlRules3 = document.createElement("div");
  urlRules3.appendChild(
    document.createTextNode("Media/Image Posts Only")
  );
  urlRow1.appendChild(urlTitle1);
  urlRow1.appendChild(urlInput1);
  urlRow2.appendChild(urlTitle2);
  urlRow2.appendChild(urlInput2);
  urlRow3.appendChild(urlTitle3);
  urlRow3.appendChild(urlInput3);
  urlThing.appendChild(urlRules2);
  urlThing.appendChild(urlRow3);
  urlThing.appendChild(urlRow1);
  urlThing.appendChild(urlRules1);
  urlThing.appendChild(urlRow2);
  urlThing.appendChild(urlRules3);
  var cancelURL = butt("Cancel5");
  cancelURL.addEventListener("click", function () {
    document.getElementById("urlstuff").checked = false;
  });
  urlThing.appendChild(cancelURL);
  urlThing.appendChild(addURL);
  url_widget.appendChild(urlThing);
  // this part is mixing the editor nav panel a bit
  addFrag.appendChild(document.createTextNode("Tags"));
  addTag.appendChild(addFrag);
  addTag.setAttribute("title", "Add tags, from selected posts...");
  remTag.appendChild(remFrag);
  remTag.setAttribute("title", "Remove tags, from selected posts...");
  // get rid of oddly inline style attributes
  document.getElementById("tags").removeAttribute("style");
  // append all our new buttons "buttoned"
  en.insertBefore(pause_chrome, rtPnt);
  en.insertBefore(ajaxInfo_chrome, rtPnt);
  en.insertBefore(gutter_chrome, rtPnt);
  en.insertBefore(links_chrome, rtPnt);
  en.insertBefore(captions_chrome, rtPnt);
  en.insertBefore(hoverSpan, rtPnt);
  en.insertBefore(caption_chrome, rtPnt);
  en.insertBefore(backdate_chrome, rtPnt);
  en.insertBefore(url_chrome, rtPnt);
  en.insertBefore(private_chrome, rtPnt);
  en.appendChild(dlPnt);
  // turn links on by default
  if (getCookie("view_links") === "on") {
    document.getElementById("view-links_button").dispatchEvent(
      new Event("click")
    );
  }
  if (getCookie("view_captions") === "on") {
    document.getElementById("view-captions_button").dispatchEvent(
      new Event("click")
    );
  }
  if (getCookie("view_hover") === "on") {
    document.getElementById("hover-only").checked = true;
    document.getElementById("hover-only").dispatchEvent(
      new Event("change")
    );
  } else {
    lcontent.classList.add("hoverless");
  }
  // extra buttons for queue/drafts
  if (href[3] === "draft" || href[3] === "queued") {
    var publish_chrome = newChromeButton("publish", "Publish", false);
    publish_chrome.getElementsByTagName("button")[0].
      setAttribute(
        "data-edit_action", '{"post[state]":"0"}'
      );
    publish_chrome.getElementsByTagName("button")[0].
      addEventListener("click", fetchEditSubmitMulti);
    en.insertBefore(publish_chrome, rtPnt);
  }
  if (href[3] === "draft") {
    var queue_chrome = newChromeButton(
      "queue", "Queue Drafts", false
    );
    queue_chrome.getElementsByTagName("button")[0].
      setAttribute(
        "data-edit_action", '{"post[state]":"2"}'
      );
    queue_chrome.getElementsByTagName("button")[0].
      addEventListener("click", fetchEditSubmitMulti);
    en.insertBefore(queue_chrome, rtPnt);
  }
  if (href[3] === "queued") {
    var makeDraft_chrome = newChromeButton(
      "make-draft", "ReDraft", false
    );
    makeDraft_chrome.getElementsByTagName("button")[0].
      setAttribute(
        "data-edit_action", '{"post[state]":"1"}'
      );
    makeDraft_chrome.getElementsByTagName("button")[0].
      addEventListener("click", fetchEditSubmitMulti);
    en.insertBefore(makeDraft_chrome, rtPnt);
  }
  en.insertBefore(selectBy_chrome, unPnt);
  en.insertBefore(selectAll_chrome, dlPnt);
  var navLinks = document.getElementsByClassName("post-state-nav-item");
  var navDash = document.createElement("a");
  var navInputContainer = document.createElement("div");
  navInputContainer.classList.add("widget");
  navInputContainer.id = "reblog_widget";
  var navWidgetTrow = document.createElement("div");
  navWidgetTrow.classList.add("trow");
  var navWidgetInner = document.createElement("div");
  navWidgetInner.classList.add("inner");
  var navWidgetH2 = document.createElement("h2");
  navWidgetH2.appendChild(
    document.createTextNode("Load From Page for ReBlog")
  );
  navWidgetH2.id = "reblog-widget_h2";
  navWidgetInner.appendChild(navWidgetH2);
  var reblogDescription = document.createElement("div");
  reblogDescription.innerHTML = "Reblogging from the \"dashboard\"...";
  reblogDescription.id = "reblog-widget_description";
  var reblogInputText = document.createElement("input");
  reblogInputText.type = "text";
  reblogInputText.addEventListener("focus", function () {
    this.select();
  });
  reblogInputText.disabled = true;
  reblogInputText.id = "reblog-widget_input";
  reblogInputText.value = "dashboard";
  var loadp = butt("Load Page");
  var loadpSubmit = function () {
    var wGinput = document.getElementById(
      "reblog-widget_input"
    );
    var url = wGinput.getAttribute("data-url") + wGinput.value;
    if (wGinput.getAttribute("data-member-input") !== null) {
      setCookie(
        wGinput.getAttribute("data-member-input"),
        wGinput.value, 99
      );
    }
    document.location.href = url.replace(/\s+/g, "+");
  };
  reblogInputText.addEventListener("keyup", function (e) {
    if (e.keyCode === 13) {
      loadpSubmit();
    }
  });
  loadp.addEventListener("click", loadpSubmit);
  var cancelp = butt("Cancel2");
  cancelp.setAttribute( // so these aren't "undefined"
    "data-default-input", "null"
  );
  cancelp.setAttribute(
    "data-default-disabled", "null"
  );
  cancelp.setAttribute(
    "data-default-description", "null"
  );
  cancelp.setAttribute(
    "data-default-url", "null"
  );
  var openReblogsWidget = function (e) {
    e.preventDefault();
    e.cancelBubble = true;
    e.stopPropagation();
    var navLinks = document.getElementsByClassName(
      "post-state-nav-item"
    );
    var nav = navLinks[0].parentNode;
    if (nav.classList.contains("open")) {
      nav.classList.remove("open");
    } else {
      var data = document.getElementById(
        "mass_post_features-plugin_data"
      );
      data.classList.add("open-blog_menu");
      var wGinput = document.getElementById(
        "reblog-widget_input"
      );
      wGinput.value = this.getAttribute("data-default-input");
      wGinput.setAttribute(
        "data-member-input", this.getAttribute("data-member-input")
      );
      wGinput.disabled = this.getAttribute("data-default-disabled") === "1";
      wGinput.setAttribute("data-url", this.getAttribute("data-default-url"));
      document.getElementById(
        "reblog-widget_description"
      ).innerHTML = "Reblogging from the \"" +
        this.getAttribute("data-default-description") +
        "\"...";
      nav.classList.add("open");
    }
  };
  cancelp.addEventListener("click", openReblogsWidget);
  navWidgetInner.appendChild(reblogInputText);
  navWidgetInner.appendChild(loadp);
  navWidgetInner.appendChild(cancelp);
  var robotWarningReblogs = document.createElement("div");
  var robotTitleReblogs = document.createElement("strong");
  robotTitleReblogs.appendChild(
    document.createTextNode(
      "Friendly Robot Warning"
    )
  );
  robotWarningReblogs.classList.add("robot-warning");
  robotWarningReblogs.appendChild(robotTitleReblogs);
  robotWarningReblogs.appendChild(
    document.createTextNode(
      "Please: utilize \"Pause Button\" for extra long feeds. " +
      "Please: Reblog responsibly!"
    )
  );
  navWidgetInner.appendChild(reblogDescription);
  navWidgetInner.appendChild(robotWarningReblogs);
  navWidgetTrow.appendChild(navWidgetInner);
  navInputContainer.appendChild(navWidgetTrow);
  navLinks[0].parentNode.appendChild(navInputContainer);
  navDash.appendChild(
    svgForType["reblog-self"].cloneNode(true)
  );
  navDash.appendChild(
    document.createTextNode("Dashboard")
  );
  navDash.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navDash.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navDash.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  var navChive = document.createElement("a");
  navChive.appendChild(
    svgForType["reblog-self"].cloneNode(true)
  );
  navChive.appendChild(
    document.createTextNode("Archive")
  );
  navChive.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navChive.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navChive.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  var navTagged = document.createElement("a");
  navTagged.appendChild(
    svgForType["reblog-self"].cloneNode(true)
  );
  navTagged.appendChild(
    document.createTextNode("Tagged")
  );
  navTagged.id = "nav-tagged";
  navTagged.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navTagged.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navTagged.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  var navSearch = document.createElement("a");
  navSearch.appendChild(
    svgForType["reblog-self"].cloneNode(true)
  );
  navSearch.appendChild(
    document.createTextNode("Search")
  );
  navSearch.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navSearch.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navSearch.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  var navLikes = document.createElement("a");
  navLikes.id = "nav-likes";
  navLikes.appendChild(
    svgForType["reblog-self"].cloneNode(true)
  );
  navLikes.appendChild(
    document.createTextNode("Likes")
  );
  navLikes.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navLikes.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navLikes.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  var navPhoto = document.createElement("a");
  navPhoto.appendChild(
    svgForType.image.cloneNode(true)
  );
  navPhoto.appendChild(
    document.createTextNode("Batch")
  );
  navPhoto.id = "nav-photo";
  navPhoto.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navPhoto.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navPhoto.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  navPhoto.classList.add("post-state-nav-item");
  navPhoto.setAttribute(
    "href", "/mega-editor/published/" + name + "?photos"
  );
  navLinks[0].parentNode.appendChild(mpe);
  var navFollows = document.createElement("a");
  navFollows.appendChild(
    svgForType.friendly.cloneNode(true)
  );
  navFollows.appendChild(
    document.createTextNode("I Follow")
  );
  navFollows.id = "nav-follows";
  navFollows.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navFollows.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navFollows.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  navFollows.classList.add("post-state-nav-item");
  navFollows.setAttribute(
    "href", "/mega-editor/published/" + name + "?follows"
  );
  var navFollowers = document.createElement("a");
  navFollowers.appendChild(
    svgForType.friendly.cloneNode(true)
  );
  navFollowers.appendChild(
    document.createTextNode("Followers")
  );
  navFollowers.id = "nav-followers";
  navFollowers.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navFollowers.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navFollowers.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  navFollowers.classList.add("post-state-nav-item");
  navFollowers.setAttribute(
    "href", "/mega-editor/published/" + name + "?followers"
  );
  var navFans = document.createElement("a");
  navFans.appendChild(
    svgForType.mutual.cloneNode(true)
  );
  navFans.appendChild(
    document.createTextNode("Fans")
  );
  navFans.id = "nav-fans";
  navFans.getElementsByTagName("svg")[0].setAttribute("width", 15);
  navFans.getElementsByTagName("svg")[0].setAttribute("height", 15);
  navFans.getElementsByTagName("svg")[0].setAttribute("fill", "#fff");
  navFans.classList.add("post-state-nav-item");
  navFans.setAttribute(
    "href", "/mega-editor/published/" + name + "?fans"
  );
  var four = [// < there were only 4 when I named this...
    "dashboard", "archive", "tagged", "search", "likes", // reblogging pages
    "photos", "follows", "followers", "fans" //special features
  ];
  if (typeof href[5] !== "undefined" && four.indexOf(href[5]) !== -1) {
    document.getElementsByClassName("active")[0].classList.remove("active");
    if (href[5] === "dashboard") {
      navDash.classList.add("active");
    }
    if (href[5] === "archive") {
      navChive.classList.add("active");
    }
    if (href[5] === "tagged") {
      navTagged.classList.add("active");
    }
    if (href[5] === "search") {
      navSearch.classList.add("active");
    }
    if (href[5] === "likes") {
      navLikes.classList.add("active");
    }
    if (href[5] === "photos") {
      navPhoto.classList.add("active");
    }
    if (href[5] === "follows") {
      navFollows.classList.add("active");
    }
    if (href[5] === "followers") {
      navFollowers.classList.add("active");
    }
    if (href[5] === "fans") {
      navFans.classList.add("active");
    }
  }
  navTagged.setAttribute(
    "data-default-input", getCookie("cats") !== "" ? getCookie("cats") : "cats"
  );
  navTagged.setAttribute(
    "data-member-input", "cats"
  );
  navTagged.setAttribute(
    "data-default-description", "Tagged Page"
  );
  navTagged.setAttribute(
    "data-default-url", "/mega-editor/published/" + name + "?tagged&"
  );
  navTagged.addEventListener("click", openReblogsWidget);
  navTagged.href = "/mega-editor/published/" + name + "?tagged&" +
    (getCookie("cats") !== "" ? getCookie("cats") : "cats");
  navTagged.classList.add("post-state-nav-item");
  navLinks[0].parentNode.appendChild(navTagged);
  navLikes.setAttribute(
    "data-default-input", name
  );
  navLikes.setAttribute(
    "data-default-description", "Liked/By Page"
  );
  navLikes.setAttribute(
    "data-default-url", "/mega-editor/published/" + name + "?likes&"
  );
  navLikes.addEventListener("click", openReblogsWidget);
  navLikes.href = "/mega-editor/published/" + name + "?likes&" + name;
  navLikes.classList.add("post-state-nav-item");
  navLikes.setAttribute(
    "data-member-input", "name1"
  );
  navLinks[0].parentNode.appendChild(navLikes);
  navSearch.setAttribute(
    "data-default-input", getCookie("cats2") !== "" ? getCookie("cats2") : "cats"
  );
  navSearch.setAttribute(
    "data-default-disabled", "0"
  );
  navSearch.setAttribute(
    "data-default-description", "Search Page"
  );
  navSearch.setAttribute(
    "data-default-url", "/mega-editor/published/" + name + "?search&"
  );
  navSearch.addEventListener("click", openReblogsWidget);
  navSearch.href = "/mega-editor/published/" + name + "?search&" +
    (getCookie("cats2") !== "" ? getCookie("cats2") : "cats");
  navSearch.setAttribute(
    "data-member-input", "cats2"
  );
  navSearch.classList.add("post-state-nav-item");
  navLinks[0].parentNode.appendChild(navSearch);
  navChive.setAttribute(
    "data-default-input", getCookie("david") !== "" ? getCookie("david") : "david"
  );
  navChive.setAttribute(
    "data-member-input", "david"
  );
  navChive.setAttribute(
    "data-default-disabled", "0"
  );
  navChive.setAttribute(
    "data-default-description", "Archive Page"
  );
  navChive.setAttribute(
    "data-default-url", "/mega-editor/published/" + name + "?archive&"
  );
  navChive.addEventListener("click", openReblogsWidget);
  navChive.href = "/mega-editor/published/" + name + "?archive&" +
    (getCookie("david") !== "" ? getCookie("david") : "david");
  navChive.classList.add("post-state-nav-item");
  navLinks[0].parentNode.appendChild(navChive);
  navDash.setAttribute(
    "data-default-input", "dashboard"
  );
  navDash.setAttribute(
    "data-default-disabled", "1"
  );
  navDash.setAttribute(
    "data-default-description", "Dashboard"
  );
  navDash.setAttribute(
    "data-default-url", "/mega-editor/published/" + name + "?dashboard&"
  );
  navDash.addEventListener("click", openReblogsWidget);
  navDash.href = "/mega-editor/published/" + name + "?dashboard";
  navDash.classList.add("post-state-nav-item");
  navLinks[0].parentNode.appendChild(navDash);
  navLinks[0].parentNode.appendChild(navPhoto);
  navLinks[0].parentNode.appendChild(navFollows);
  navLinks[0].parentNode.appendChild(navFollowers);
  // navLinks[0].parentNode.appendChild(navFans); // html api, too unstable...
  navLinks[0].insertBefore(
    svgForType.edit.cloneNode(true), navLinks[0].firstChild
  );
  navLinks[1].insertBefore(
    svgForType.edit.cloneNode(true), navLinks[1].firstChild
  );
  navLinks[2].insertBefore(
    svgForType.edit.cloneNode(true), navLinks[2].firstChild
  );
  navLinks[0].getElementsByTagName("svg")[0].setAttribute("width", 15);
  navLinks[0].getElementsByTagName("svg")[0].setAttribute("height", 15);
  navLinks[1].getElementsByTagName("svg")[0].setAttribute("width", 15);
  navLinks[1].getElementsByTagName("svg")[0].setAttribute("height", 15);
  navLinks[2].getElementsByTagName("svg")[0].setAttribute("width", 15);
  navLinks[2].getElementsByTagName("svg")[0].setAttribute("height", 15);
  // end extra chrome buttons and widgets, and nav-links

  // the replace/alias some of the default functions
  var rewriterScript = document.createElement("script");
  rewriterScript.type = "text/javascript";
  rewriterScript.id = "mass_post_features-plugin_functions";
  rewriterScript.appendChild(
    document.createTextNode(
      rewrite1.toString().slice(13, -1)
    )
  );
  rewriterScript.appendChild(
    document.createTextNode(
      "// The doc_title (#) is superfluous; use a visible (#)\n" +
      "window.postCountMake = " +
      postCountMake.toString() + ";\n"
    )
  );
  rewriterScript.appendChild(
    document.createTextNode(
      rewrite2.toString().slice(13, -1)
    )
  );
  document.head.appendChild(rewriterScript);
  // end the default script replacements/aliases

  // begin the plugin css below
  // (I tweaked this CSS for hours upon days to be utmost pretty)
  var pluginStyle = document.createElement("style");
  pluginStyle.id = "mass_post_features-plugin_style";
  pluginStyle.type = "text/css";
  pluginStyle.appendChild(
    document.createTextNode(
      (function () {/*

h2 {
  display: block;
  font-weight: 600;
}

a {
  text-decoration: underline;
}

b, strong {
  font-weight: 700;
}

h2 b, h2 strong {
  font-weight: 900;
}

em, i {
  font-style: italic;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote {
  border-left: 3px solid #000;
  padding-left: 4px;
}

blockquote:after,
blockquote:before,
q:after,
q:before {
  content: none;
}

ol, ul {
  margin-bottom: .75em;
  padding-left: 2.8em;
}

ol ol,
ol ul,
ul ol,
ul ul {
  margin: 0;
  padding-left: 1.1em;
}

ul li {
  list-style-type: disc;
}

ul li li {
  list-style-type: circle;
}

ol li {
  list-style-type: decimal;
  font-feature-settings: "tnum";
}

blockquote, p,
pre {
  margin-bottom: .75em;
}

p.npf_quirky {
  font-family: Fairwater, serif;
  font-size: 24px;
  line-height: 1.3em;
}

p.npf_chat {
  font-family: Source Code Pro, monospace;
}

p.npf_color_joey,
span.npf_color_joey {
  color: #ff492f;
}

p.npf_color_monica,
span.npf_color_monica {
  color: #ff8a00;
}

p.npf_color_phoebe,
span.npf_color_phoebe {
  color: #e8d73a;
}

p.npf_color_ross,
span.npf_color_ross {
  color: #00cf35;
}

p.npf_color_rachel,
span.npf_color_rachel {
  color: #00b8ff;
}

p.npf_color_chandler,
span.npf_color_chandler {
  color: #7c5cff;
}

p.npf_color_niles,
span.npf_color_niles {
  color: #ff62ce;
}

p.npf_color_frasier,
span.npf_color_frasier {
  color: #001935;
}

p.npf_color_mr_big,
span.npf_color_mr_big {
  color: #000c1a;
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-light-0db5d248.woff) format("woff");
  font-weight: 100;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-regular-d83b428c.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-semibold-b0fc2672.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-bold-c6132b6e.woff) format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-light-italic-ed49facd.woff) format("woff");
  font-weight: 100;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-italic-e1dcd616.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Gibson;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-semibold-italic-ae8d9810.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Bold;
  src: url(https://assets.tumblr.com/pop/fonts/gibson/gibson-bold-italic-94b05ba2.woff) format("woff");
  font-weight: 900;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Franklin Gothic Medium;
  src: url(https://assets.tumblr.com/pop/fonts/franklingothic/franklingothic-medium-1beb5103.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-stretch: normal;
  font-display: swap
}

@font-face {
  font-family: Franklin Gothic Medium Condensed;
  src: url(https://assets.tumblr.com/pop/fonts/franklingothic/franklingothic-medium-compressed-58222bfb.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Franklin Gothic Compressed;
  src: url(https://assets.tumblr.com/pop/fonts/franklingothic/franklingothic-compressed-02ac5e26.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Walsheim;
  src: url(https://assets.tumblr.com/pop/fonts/walsheim/walsheim-medium-40fd0505.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Fairwater;
  src: url(https://assets.tumblr.com/pop/fonts/fairwater/fairwater-regular-b7ab7a58.woff2) format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Favorit;
  src: url(https://assets.tumblr.com/pop/fonts/favorit/favorit-85-8ff1c986.woff2) format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap
}

@font-face {
  font-family: Favorit;
  src: url(https://assets.tumblr.com/pop/fonts/favorit/favorit-85-italic-a883bce7.woff2) format("woff2");
  font-style: italic;
  font-weight: 400;
  font-display: swap
}

@font-face {
  font-family: Favorit;
  src: url(https://assets.tumblr.com/pop/fonts/favorit/favorit-medium-be005cc5.woff2) format("woff2");
  font-style: normal;
  font-weight: 700;
  font-display: swap
}

@font-face {
  font-family: Favorit;
  src: url(https://assets.tumblr.com/pop/fonts/favorit/favorit-medium-italic-4d1adc26.woff2) format("woff2");
  font-style: italic;
  font-weight: 700;
  font-display: swap
}

@font-face {
  font-family: "1785 GLC Baskerville";
  src: url(https://assets.tumblr.com/pop/fonts/1785glcbaskerville/1785glcbaskerville-regular-2c131a72.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: "1785 GLC Baskerville";
  src: url(https://assets.tumblr.com/pop/fonts/1785glcbaskerville/1785glcbaskerville-italic-1a724410.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Alternate Gothic;
  src: url(https://assets.tumblr.com/pop/fonts/alternategothic/alternategothic-regular-d11d1e96.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Arquitecta;
  src: url(https://assets.tumblr.com/pop/fonts/arquitecta/arquitecta-book-cee560b5.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Arquitecta;
  src: url(https://assets.tumblr.com/pop/fonts/arquitecta/arquitecta-bold-5ec6543e.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Avalon;
  src: url(https://assets.tumblr.com/pop/fonts/avalon/avalon-book-de1d38eb.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Avalon;
  src: url(https://assets.tumblr.com/pop/fonts/avalon/avalon-bold-26f8ad53.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Bodoni Recut FS;
  src: url(https://assets.tumblr.com/pop/fonts/bodonirecutfs/bodonirecutfs-regular-283bd6c9.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Bodoni Recut FS;
  src: url(https://assets.tumblr.com/pop/fonts/bodonirecutfs/bodonirecutfs-demi-1c2ff649.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Bodoni Recut FS;
  src: url(https://assets.tumblr.com/pop/fonts/bodonirecutfs/bodonirecutfs-italic-54315813.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Bodoni Recut FS;
  src: url(https://assets.tumblr.com/pop/fonts/bodonirecutfs/bodonirecutfs-demi-italic-b5e01932.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Bookmania;
  src: url(https://assets.tumblr.com/pop/fonts/bookmania/bookmania-regular-271d947c.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Bookmania;
  src: url(https://assets.tumblr.com/pop/fonts/bookmania/bookmania-bold-5e09e821.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Brutal Type;
  src: url(https://assets.tumblr.com/pop/fonts/brutaltype/brutaltype-regular-ef623c78.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Brutal Type;
  src: url(https://assets.tumblr.com/pop/fonts/brutaltype/brutaltype-bold-a5e007f4.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Calluna;
  src: url(https://assets.tumblr.com/pop/fonts/calluna/calluna-regular-60172bcd.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Calluna;
  src: url(https://assets.tumblr.com/pop/fonts/calluna/calluna-black-cfbfc0fb.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Calluna;
  src: url(https://assets.tumblr.com/pop/fonts/calluna/calluna-italic-405661eb.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Calluna;
  src: url(https://assets.tumblr.com/pop/fonts/calluna/calluna-bold-italic-760a50f4.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Calluna Sans;
  src: url(https://assets.tumblr.com/pop/fonts/callunasans/callunasans-regular-4c9b1de7.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Calluna Sans;
  src: url(https://assets.tumblr.com/pop/fonts/callunasans/callunasans-black-9c48542e.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Calluna Sans;
  src: url(https://assets.tumblr.com/pop/fonts/callunasans/callunasans-italic-83d2e0f0.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Calluna Sans;
  src: url(https://assets.tumblr.com/pop/fonts/callunasans/callunasans-black-italic-55e41442.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Capita;
  src: url(https://assets.tumblr.com/pop/fonts/capita/capita-regular-b20fa714.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Capita;
  src: url(https://assets.tumblr.com/pop/fonts/capita/capita-bold-16bd5c46.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Caslon FS;
  src: url(https://assets.tumblr.com/pop/fonts/caslonfs/caslonfs-book-b1f3d7b2.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Caslon FS;
  src: url(https://assets.tumblr.com/pop/fonts/caslonfs/caslonfs-bold-c9f15be5.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Clarendon Text Pro;
  src: url(https://assets.tumblr.com/pop/fonts/clarendontextpro/clarendontextpro-regular-8665c534.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Clarendon Text Pro;
  src: url(https://assets.tumblr.com/pop/fonts/clarendontextpro/clarendontextpro-bold-f0e91a3c.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Clarendon Text Pro;
  src: url(https://assets.tumblr.com/pop/fonts/clarendontextpro/clarendontextpro-italic-f50fadcc.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Clarendon Text Pro;
  src: url(https://assets.tumblr.com/pop/fonts/clarendontextpro/clarendontextpro-bold-italic-0b93f3fe.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Clearface FS;
  src: url(https://assets.tumblr.com/pop/fonts/clearface/clearface-regular-0877705c.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Clearface FS;
  src: url(https://assets.tumblr.com/pop/fonts/clearface/clearface-black-7307513a.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Clearface FS;
  src: url(https://assets.tumblr.com/pop/fonts/clearface/clearface-italic-12dd08d2.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Clearface FS;
  src: url(https://assets.tumblr.com/pop/fonts/clearface/clearface-black-italic-95e89c47.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Garamond Classic FS;
  src: url(https://assets.tumblr.com/pop/fonts/garamondclassicfs/garamondclassicfs-regular-37325adf.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Garamond Classic FS;
  src: url(https://assets.tumblr.com/pop/fonts/garamondclassicfs/garamondclassicfs-heavy-d6b7cb51.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Garamond Classic FS;
  src: url(https://assets.tumblr.com/pop/fonts/garamondclassicfs/garamondclassicfs-italic-a9e735d6.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Garamond Classic FS;
  src: url(https://assets.tumblr.com/pop/fonts/garamondclassicfs/garamondclassicfs-bold-italic-73da3cdb.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Grumpy Black\ 48;
  src: url(https://assets.tumblr.com/pop/fonts/grumpyblack48/grumpyblack48-60ad3944.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Grumpy Black\ 48;
  src: url(https://assets.tumblr.com/pop/fonts/grumpyblack48/grumpyblack48-60ad3944.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Lorimer No\ 2;
  src: url(https://assets.tumblr.com/pop/fonts/lorimerno2/lorimerno2-medium-5ed17651.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Lorimer No\ 2;
  src: url(https://assets.tumblr.com/pop/fonts/lorimerno2/lorimerno2-semibold-c615f79e.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Lorimer No\ 2;
  src: url(https://assets.tumblr.com/pop/fonts/lorimerno2/lorimerno2-medium-italic-a7cb2829.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Lorimer No\ 2;
  src: url(https://assets.tumblr.com/pop/fonts/lorimerno2/lorimerno2-semibold-italic-803dc0f4.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: News Gothic FS;
  src: url(https://assets.tumblr.com/pop/fonts/newsgothicfs/newsgothicfs-book-b71e5c48.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: News Gothic FS;
  src: url(https://assets.tumblr.com/pop/fonts/newsgothicfs/newsgothicfs-bold-dad27eb5.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: News Gothic FS;
  src: url(https://assets.tumblr.com/pop/fonts/newsgothicfs/newsgothicfs-book-oblique-0a0ccd73.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: News Gothic FS;
  src: url(https://assets.tumblr.com/pop/fonts/newsgothicfs/newsgothicfs-bold-oblique-4767b553.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Pratt Pro;
  src: url(https://assets.tumblr.com/pop/fonts/prattpro/prattpro-regular-27555c58.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Pratt Pro;
  src: url(https://assets.tumblr.com/pop/fonts/prattpro/prattpro-bold-f978900f.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Quadrat;
  src: url(https://assets.tumblr.com/pop/fonts/quadrat/quadrat-regular-eade9dc0.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Quadrat;
  src: url(https://assets.tumblr.com/pop/fonts/quadrat/quadrat-serial-f6e71145.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Sofia Pro;
  src: url(https://assets.tumblr.com/pop/fonts/sofiapro/sofiapro-regular-f2aae9ec.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Sofia Pro;
  src: url(https://assets.tumblr.com/pop/fonts/sofiapro/sofiapro-bold-cdb403a0.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Spade;
  src: url(https://assets.tumblr.com/pop/fonts/spade/spade-6085b923.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Spade;
  src: url(https://assets.tumblr.com/pop/fonts/spade/spade-6085b923.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Square Serif;
  src: url(https://assets.tumblr.com/pop/fonts/squareserif/squareserif-book-0a547297.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Square Serif;
  src: url(https://assets.tumblr.com/pop/fonts/squareserif/squareserif-demi-1bdcd0c8.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Square Serif;
  src: url(https://assets.tumblr.com/pop/fonts/squareserif/squareserif-book-italic-0ecc7c19.woff) format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Square Serif;
  src: url(https://assets.tumblr.com/pop/fonts/squareserif/squareserif-demi-italic-b4286785.woff) format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap
}

@font-face {
  font-family: Streetscript;
  src: url(https://assets.tumblr.com/pop/fonts/streetscript/streetscript-e1665af6.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Streetscript;
  src: url(https://assets.tumblr.com/pop/fonts/streetscript/streetscript-e1665af6.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Typewriter FS;
  src: url(https://assets.tumblr.com/pop/fonts/typewriterfs/typewriterfs-regular-c0a07f03.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Typewriter FS;
  src: url(https://assets.tumblr.com/pop/fonts/typewriterfs/typewriterfs-bold-d4592705.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Ziclets;
  src: url(https://assets.tumblr.com/pop/fonts/ziclets/ziclets-b6989e95.woff) format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap
}

@font-face {
  font-family: Ziclets;
  src: url(https://assets.tumblr.com/pop/fonts/ziclets/ziclets-b6989e95.woff) format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap
}

@keyframes happy-bounce {
  0% {
    opacity: 0;
    transform: rotate(40deg) translateY(0);
  }

  10% {
    transform: rotate(0deg) translateY(-50px);
    opacity: 1;
  }

  20% {
    transform: rotate(-40deg) translateY(0);
  }

  30% {
    transform: rotate(0deg) translateY(-40px);
  }

  40% {
    transform: rotate(40deg) translateY(0);
  }

  50% {
    transform: rotate(0deg) translateY(-30px);
  }

  60% {
    transform: rotate(-40deg) translateY(0);
  }

  70% {
    transform: rotate(0deg) translateY(-20px);
  }

  80% {
    transform: rotate(40deg) translateY(0);
  }

  90% {
    opacity: 1;
    transform: rotate(0deg) translateY(-10px);
  }

  100% {
    opacity: 0;
    transform: rotate(-40deg) translateY(0);
  }
}

@keyframes blinking {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes updown {
  100% {
    margin-top: 0;
  }

  50% {
    margin-top: -15px;
  }

  0% {
    margin-top: 0;
  }
}

@keyframes flip {
  100% {
    transform: rotateX(0);
    opacity: 1;
  }

  0% {
    transform: rotateX(-180deg);
    opacity: 0;
  }
}

.l-content {
  min-height: calc(100vh - 177px);
}

.l-content>* {
  opacity: 0;
  transition: all 0.4s ease-out;
}

.l-content>*.display-none {
  display: none;
}

#select-by-widget_title .preselect-count,
#select-by_widget .row,
.l-content>*.laid {
  opacity: 1;
  animation: flip 0.25s ease-in-out both;
}

#select-by-widget_title .preselect-count.noanim,
#select-by_widget .row:active {
  animation: none;
  opacity: 1;
}

#mass_post_features-plugin_data {
  display: none;
}

#mass_post_features-plugin_selection_box {
  position: absolute;
  background-color: rgba(50, 90, 250, 0.4);
  box-shadow: inset 0 0 0 1px rgba(50, 90, 250, 1);
  z-index: 100;
  cursor: pointer;
}

a.blog_title {
  cursor: pointer;
}

#delete_posts {
  background-color: #c00;
}

#unselect .chrome_button_right {
  display: inline-block;
}

.blue_bar .editor_navigation {
  text-align: center;
  float: none;
  display: block;
}

.blue_bar .editor_navigation .header_button {
  display: inline-block;
  vertical-align: top;
}

#status {
  margin: 0px 0px -3px 0px;
}

#pause_button .play,
#pause_button .pause {
  color: #fff;
  font-size: 10px;
  padding: 0 2px;
}

#pause_button.playing .play,
#pause_button.paused .pause,
#pause_button.done .play,
#pause_button.done .pause {
  color: rgba(255, 255, 255, 0.3);
}

.chrome h2 {
  display: inline-block;
  font-size: 25px;
  vertical-align: top;
  color: inherit;
  font-weight: bold;
}


.chrome_button h2 {
  vertical-align: sub;
  font-family: monospace;
  position: relative;
}

#add_tag_button,
#cancel_add_tag_button,
#cancel_remove_tag_button,
#remove_tag_button {
  margin-bottom: -30px;
}

#tag_editor,
#tags {
  font: normal 11px 'Lucida Grande', Verdana, sans-serif;
  width: 326px;
  position: absolute;
  left: 20px;
  top: 19px;
  text-align: left;
  height: 170px;
  overflow: auto;
  color: #555;
  background-color: rgba(255, 255, 255, 0.7);
}

#unselect.chrome,
#select-all_button.chrome,
#select-by_button.chrome,
#view-links_button.chrome,
#view-captions_button.chrome {
  background: #7D99FF none;
}

.blue_bar .editor_navigation .header_button button.chrome {
  padding: 0 4px 0 0;
  margin: 1px 0 0 2px;
}

#gutter_button input[type="number"] {
  width: 40px;
  height: 18px;
  padding: 0 3px;
  background-color: #ccc;
  border: 0 none;
  box-shadow: inset 0 2px 2px 0px #000;
  top: -2px;
  position: relative;
}

#cancel5_button,
#add_urls_button,
#post_all_photos_button,
#cancel2_button,
#cancel1_button,
#select_button,
#clear_button,
#hide_button,
#list_button {
  border: 0 none;
  padding: 0 5px;
}

#select_button {
  position: absolute;
  bottom: 13px;
  left: 10px;
  width: 68px;
}

#reblog_widget .robot-warning {
  width: 190px;
  margin: 10px 10px 11px 10px;
}

#cancel2_button {
  position: absolute;
  bottom: 10px;
  right: 10px;
}

#cancel1_button {
  position: absolute;
  top: 10px;
  right: 10px;
}

#clear_button {
  position: absolute;
  bottom: 13px;
  right: 10px;
}

#hide_button {
  position: absolute;
  bottom: 7px;
  right: 6px;
  height: 24px;
}

#list_button {
  position: absolute;
  bottom: 13px;
  right: 307px;
  height: 24px;
}

#photos-drop-zone *,
#photos-drop-zone,
.blog_title,
#jump_to_month,
#mpe_title,
.post-state-nav-item,
.l-content>*,
button,
label {
  user-drag: none;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

.l-content .brick.photo {
    min-height: 50px;
    vertical-align: ;
}

.l-content .heading {
  padding-top: 20px;
}

.l-content .brick .overprint {
  width: 120px;
  top: 0px;
  left: 5px;
}

.l-content .brick.video .play_overlay,
.l-content .brick.audio .listen_overlay {
  z-index: 9;
}

.l-content .brick {
  overflow: visible;
  background: linear-gradient(135deg,
      rgba(242, 242, 242, 1) 0%,
      rgba(209, 209, 209, 1) 44%,
      rgba(209, 209, 209, 1) 100%,
      rgba(226, 226, 226, 1) 100%);
}

.l-content .brick .overflow-hidden {
  position: absolute;
  height: 100%;
  overflow: hidden;
  width: 125px;
  bottom: 0;
  right: 0;
  left: 0;
  top: 0;
}

.l-content .brick .monospace *,
.l-content .brick .monospace {
  font-family: "Courier", monospace;
}

.l-content .brick .ol {
  display: list-item;
  list-style: decimal inside;
}

.l-content .brick .ul {
  display: list-item;
  list-style: disc inside;
}

.l-content .brick .h1 {
  font-size: 115%;
  text-align: center;
}

.l-content .brick .quote {
  font-size: 125%;
  font-family: "Times", "Times New Roman", serif;
}

.l-content .brick .rq {
  font-size: 140px;
  font-weight: bold;
  font-family: "Times", "Times New Roman", "Times", serif;
  color: rgba(0, 0, 0, 0.15);
  position: absolute;
  top: 0px;
  right: 0;
  line-height: 110px;
}

.l-content .brick.link .rq {
  bottom: -20px;
}

.l-content .brick.note .ask-av {
  display: inline-block;
  vertical-align: middle;
  border-radius: 20px;
}

.l-content .brick.has-img .fade {
  width: 125px;
  height: 90px;
  position: absolute;
  left: 0;
  bottom: 0;
  background: linear-gradient(to bottom,
      rgba(206, 206, 206, 0) 0%,
      rgba(208, 208, 208, 0) 73%,
      rgba(209, 209, 209, 1) 100%);
}

.l-content .brick .asker {
  display: inline-block;
  vertical-align: middle;
}

.l-content .brick .answer {
  font-weight: normal;
  padding-top: 30px;
}

.l-content .brick .h2 {
  font-size: 105%;
}

.l-content .brick .link {
  text-decoration: underline;
}

.l-content .brick .quirky {
  font-family: Fairwater, serif;
  font-size: 112%;
}

.l-content .brick.highlighted .overlay {
  background: none;
  border: 0 none;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  text-align: center;
  color: #fff;
  opacity: 1;
  filter: none;
  z-index: 999;
  display: block;
}

.l-content .brick.highlighted .overlay .inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin-top: 0;
  height: 100%;
}

.l-content .brick.highlighted .overlay .inner .date {
  color: #fff;
  position: absolute;
  left: 0px;
  right: 0px;
  padding: 2px 6px 0px 2px;
  background-color: #73bae7;
  height: 13px;
  font-size: 10px;
  line-height: 11px;
}

.l-content .brick.highlighted .highlight .tag_count {
  display: block !important;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  max-width: 115px;
}

.tag_count[style]:after {
    content: " tags";
}

.l-content .brick.highlighted .highlight .note_count {
  color: #fff;
  position: absolute;
  right: 0px;
  bottom: 0px;
  padding: 2px 6px 0px 2px;
  background-color: #73bae7;
  background-color: rgba(115,186,231,0.8);
  height: 11px;
  font-size: 10px;
  line-height: 11px;
  border-top-left-radius: 5px;
  display: block !important;
}

.l-content .brick.highlighted .overlay .inner .notes {
  margin-top: 5px;
  position: absolute;
  bottom: 0px;
  right: 0px;
  padding: 3px 6px 0px 5px;
  background-color: #73bae7;
  height: 13px;
  font-size: 10px;
  line-height: 10px;
  border-top-left-radius: 5px;
  display: block !important;
}

#widget-top-buttons .red {
  border: 1px rgba(255, 0, 0, 0.4) solid;
  background-color: rgba(255, 0, 0, 0.1);
  color: rgba(255, 0, 0, 0.6);
  position: absolute;
  right: 7px;
  top: 30px;
  font-size: 10px;
  padding: 1px 6px;
  font-weight: bold;
}

#widget-top-buttons .arrow,
.blue_bar .arrow {
  display: inline-block;
  position: relative;
  top: -1px;
  width: 0;
  height: 0;
  margin-left: 4px;
  border-top: 6px solid;
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
}
#widget-top-buttons .arrow {
  border-top-color: #555;
}
#widget-top-buttons .arrow.reverse {
  border-bottom: 6px solid;
  border-bottom-color: #99a3ae;
  border-top: 0;
}

.blue_bar .chrome {
  cursor: pointer;
}

.blue_bar .chrome label .arrow {
  border-top-color: #fff;
}

.blue_bar .small_text {
  width: 280px;
  position: relative;
  margin: 0;
  padding: 0;
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0;
  line-height: 15px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  left: 10px;
  text-align: center;
}

.blue_bar .title .blog_title {
  color: #99a3ae;
  text-decoration: none;
  top: -3px;
}

#blog_menu {
  display: none;
}

#blog_menu .avatar_img,
#blog_menu .avatar {
  display: inline-block;
  float: left;
  width: 36px;
  height: 36px;
  margin: 3px 0px 0px 3px;
  vertical-align: bottom;
}

#blog_menu .avatar_img {
  border: 1px solid #000;
  border-radius: 4px;
  background-color: rgba(255, 255, 255, 0.9);
}

#blog_menu .avatar {
  position: relative;
  top: 0;
  left: 0;
}

#blog_menu .avatar svg {
  display: none;
}

#blog_menu .avatar.reblog-to-here svg {
  display: block;
  position: absolute;
  background-color: rgba(0, 0, 0, 0.8);
  box-shadow: 0 0 0 2px #7D99FF;
  border-radius: 2px;
  top: 4px;
  left: 4px;
  width: 26px;
  height: 26px;
  padding: 5px;
}

.blog_menu_child {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.13);
  padding: 2px 0px 4px 0px;
}

.subt {
  text-align: center;
  height: 40px;
  width: 300px;
  top: 5px;
  position: relative;
  margin: 0px 0px 0px 48px;
}

.subt a {
  padding: 2px;
  color: #7D99FF;
  margin: 2px;
}

.subt button,
.subt a {
  cursor: pointer;
}

.subt .blank-space,
.subt button,
.subt a {
  height: 24px;
  font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-size: 10px;
  line-height: 14px;
  font-weight: bold;
  text-decoration: none;
}

.subt .blank-space,
.subt button {
  display: inline-block;
  min-height: 52px;
  position: relative;
  margin: 0;
}

.subt button {
  width: 82px;
  min-height: 52px;
  white-space: normal;
  top: -17px;
  padding: 3px 8px 3px 8px;
  border-color: #000;
  border-radius: 2px;
  background-color: #444;
  border-width: 1px;
  border-style: solid;
  color: #fff;
  position: relative;
  left: 5px;
}

.subt .blank-space {
  width: 60px;
  height: 30px;
  top: -19px;
  vertical-align: middle;
}

.subt a:active {
  text-decoration: underline;
}

.subt button:active {
  background-color: #969696;
  border-color: #8a8f96;
  border-color: rgba(0, 0, 0, 0.2);
  box-shadow: none
}

.open #blog_menu {
  display: block;
  position: fixed;
  text-align: center;
  left: 0;
  width: 400px;
  height: auto;
  max-height: calc(100vh - 50px);
  padding: 0;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: #001935;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.13);
  z-index: 100;
  top: 0;
  padding-bottom: 10px;
}

a.open {
  cursor: normal;
}

#blog_menu::-webkit-scrollbar,
#widget_scrolling_part::-webkit-scrollbar {
  width: 8px;
  height: 10px;
}

#blog_menu::-webkit-scrollbar-thumb,
#widget_scrolling_part::-webkit-scrollbar-thumb {
  border-radius: 8px;
  background: #c2c9d2;
}

.editor_navigation span input+.widget {
  display: none;
}

.editor_navigation span input:checked+.widget {
  display: block;
}

#urlstuff_widget {
  padding: 30px;
}

#urlstuff_widget .chrome {
  margin: 14px;
}

.row label.not.disabled {
  background-color: rgba(0, 0, 0, 0.1);
  opacity: 0.3;
}

.row label.not.ch {
  background-color: rgba(250, 170, 100, 0.2);
}

#snapshot-info_widget,
#backdate_widget,
#urlstuff_widget,
#add-caption_widget,
#reblog_widget,
#remove_tags_widget,
#add_tags_widget,
#select-by_widget {
  cursor: grab !important;
}

#select-by,
#backdate,
#snapshot-info,
#urlstuff,
#add-caption {
  opacity: 0;
  width: 0;
  height: 0;
}

#urlstuff_body,
#backdate-body,
#reblog_widget button,
#reblog_widget input,
#tags {
  cursor: auto;
}

.brick-dragging *,
.brick-dragging,
#snapshot-info_widget.widget-dragging *,
#snapshot-info_widget.widget-dragging,
#backdate_widget.widget-dragging *,
#backdate_widget.widget-dragging,
#urlstuff_widget.widget-dragging *,
#urlstuff_widget.widget-dragging,
#add-caption_widget.widget-dragging *,
#add-caption_widget.widget-dragging,
#reblog_widget.widget-dragging *,
#reblog_widget.widget-dragging,
#remove_tags_widget.widget-dragging *,
#remove_tags_widget.widget-dragging,
#add_tags_widget.widget-dragging *,
#add_tags_widget.widget-dragging,
#select-by_widget.widget-dragging *,
#select-by_widget.widget-dragging {
  cursor: grabbing !important;
}

#reblog_widget h2,
#reblog_widget div,
#reblog_widget span,
#remove_tags_widget div,
#add-caption_widget div,
#add-caption_widget h2,
#backdate_widget h2,
#backdate_widget span,
#backdate_widget div,
#snapshot-info_widget h2,
#snapshot-info_widget span,
#snapshot-info_widget div,
#urlstuff_widget h2,
#urlstuff_widget span,
#urlstuff_widget div,
#add-caption_widget span,
#select-by_widget span,
#select-by_widget div {
  user-drag: none;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

#backdate-body {
  top: 20px;
  position: relative;
}

#select-by_widget .row span.ch {
  background-color: rgba(100, 170, 250, 0.2);
}

#select-by_widget .row label.is {
  position: absolute;
  left: 0;
  top: 0;
  right: 50px;
  height: 20px;
}

#select-by_widget .row svg {
  position: absolute;
  left: 78px;
  top: 0;
  width: 20px;
  height: 20px;
}

#select-by_widget .row label.is .row-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-block;
  width: 255px;
  font-size: 11px;
  line-height: 19px;
  left: 102px;
  top: 0;
  position: absolute;
  height: 20px;
}

#select-by_widget .row .is span {
  height: 20px;
  line-height: 25px;
  font-size: 10px;
  position: absolute;
  width: 40px;
  right: 0px;
  text-align: center;
  top: 0;
}

#select-by_widget .row .not {
  height: 20px;
  line-height: 25px;
  font-size: 10px;
  position: absolute;
  width: 44px;
  right: 0;
  top: 0;
  text-align: center;
}

#select-by_widget .row label {
  cursor: pointer;
}

#select-by_widget .row div.count {
  width: 72px;
  background-color: rgba(50, 50, 50, 0.1);
  height: 20px;
  text-align: right;
  text-overflow: unset;
  padding-right: 4px;
  position: absolute;
  overflow: hidden;
  left: 0;
  top: 0;
}

#select-by_widget .row {
  height: 20px;
  position: relative;
  top: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.6);
}

#select-by_widget .row,
#select-by_widget .tags_title {
  border-bottom: 1px solid #ccc;
}

#select-by_widget .tags_title {
  color: #555;
  height: 15px;
  font-size: 10px;
  font-weight: bold;
  text-align: center;
  background-color: rgba(50, 50, 50, 0.1);
}

#select-by_widget {
  height: 480px;
}

.widget,
#remove_tags_widget,
#add_tags_widget,
#reblog_widget,
#backdate_widget,
#snapshot-info_widget,
#urlstuff_widget,
#add-caption_widget,
#select-by_widget {
  background: rgba(235, 235, 235, 0.9) none !important;
  box-shadow: inset 0 0 4px 5px #fff,
    inset 0 0 5px 2px #000,
    0 0 8px 1px #000;
  border-radius: 9px;
  position: fixed;
}

#select-by_widget {
  font: normal 12px 'Lucida Grande', Verdana, sans-serif;
  padding: 9px;
  width: 440px;
  text-align: left;
  z-index: 10;
}

#tag_editor * {
  font: normal 14px/1.4 "Helvetica Neue",
    "HelveticaNeue", Helvetica, Arial, sans-serif;
}

#tags,
#tag_editor,
#widget_scrolling_part {
  box-shadow: inset 0 0 0 1px #ccc,
    inset 0px 3px 6px 0px #ccc;
}

#tag_editor {
  background: none rgba(255, 255, 255, 0.7);
}

#widget_scrolling_part {
  overflow-x: hidden;
  overflow-y: auto;
  position: absolute;
  top: 48px;
  left: 4px;
  right: 4px;
  bottom: 48px;
  cursor: default;
}

#widget-top-buttons,
#widget-top-buttons .sort {
  position: absolute;
}

#widget-top-buttons {
  top: 0;
  left: 0;
  right: 0;
}

#widget-top-buttons .sort {
  top: 30px;
  font-size: 12px;
  font-weight: bold;
  color: #555;
  cursor: pointer;
}

#widget-top-buttons .sort.num {
  left: 15px;
}

#widget-top-buttons .sort.abc {
  left: 90px;
}

#widget-top-buttons .sort.date {
  left: 185px;
}

.row .tag-icon {
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-right: 5px;
  margin-left: 1px;
  opacity: 0.6;
}

.row.type.notes-more-than .number-input,
.row.type.notes-less-than .number-input {
  border: 1px solid #555;
  width: 90px;
  position: absolute;
  right: 88px;
  height: 18px;
  top: 0;
  border: 1px solid #555;
  box-shadow: inset 0 1px 2px 0px #ccc;
}

#urlstuff_widget input {
  width: 180px;
  height: 22px;
  border: 1px solid #999;
  padding: 2px;
  box-shadow: inset 0 1px 2px 0px #555;
}

#select-by-widget_title {
  font-size: 17px;
  font-weight: bold;
  color: #555;
}

#select-by-widget_title .preselect-count {
  color: rgba(0, 130, 0, 0.6);
  font-size: 12px;
  background-color: #fff;
  height: 21px;
  min-width: 60px;
  border-radius: 12px;
  box-shadow: inset 0 1px 2px 0px #555;
  margin-left: 12px;
  position: absolute;
  top: 8px;
  left: 160px;
  text-align: center;
  line-height: 21px;
  transform: translateX(-505%);
}

#uncheck+label {
  color: #999;
}

#show-only:checked+label+#uncheck+label+span,
#show-only+label {
  color: #999;
}

#show-only:checked+label,
#uncheck:checked+label {
  color: #555;
}

#show-only:checked+label+#uncheck+label,
#show-only:checked+label+#uncheck {
  visibility: hidden;
}

#show-only {
  margin-top: 5px;
  margin-right: 60px;
}

#show-only,
#show-only+label {
  float: right;
}

#select-by_widget .select-by_ltgt {
  position: absolute;
  bottom: 5px;
  right: 90px;
  border: 1px solid #888;
  width: 203px;
  height: 39px;
}

#gt_input,
#lt_input {
  position: absolute;
  left: 78px;
}

#lt_input,
#lt_input+label {
  top: 4px;
}

#gt_input,
#gt_input+label {
  top: 22px;
}

#gt_input+label,
#lt_input+label {
  left: 0px;
  width: 72px;
  position: absolute;
  color: #999;
  text-align: right;
  cursor: pointer;
}

#gt_input:checked+label,
#lt_input:checked+label {
  color: #555;
}

#lt_input+label+#gt_input+label+#hide-ltgt-than-tags {
  opacity: 0.5;
  width: 55px;
  position: absolute;
  top: 8px;
  left: 97px;
  border: 1px solid #555;
  box-shadow: inset 0 1px 2px 0px #ccc;
  height: 23px;
}

#lt_input+label+#gt_input:checked+label+#hide-ltgt-than-tags,
#lt_input:checked+label+#gt_input+label+#hide-ltgt-than-tags {
  opacity: 1;
}

.l-content .brick .title {
  margin: 0;
  padding: 0;
  background-color: rgba(255, 255, 255, 0.1);
  overflow: hidden;
  width: 110px;
}

.l-content .brick>* {
  max-width: 125px;
}

.l-content .brick.picked {
  overflow: visible;
  box-shadow: 0 0 12px 2px rgba(14, 19, 84, 0.5);
  z-index: 60;
}

.l-content .brick.highlighted {
  animation: updown 0.1s ease-in both;
}

.l-content .brick.highlighted.picked {
  overflow: visible;
  box-shadow: 0 0 12px 2px rgba(0, 0, 0, 0.5);
  z-index: 60;
}

.l-content .brick.prevent-anim,
.l-content .brick.highlighted.picked {
  animation: none;
}
*/}).toString().slice(15,-3) + // this is a pointing hand graphic
'.l-content .brick.picked:before { content: ""; top: -35px;\n'+
'width: 50px; height: 50px; position: absolute;left: 25px;\n' +
'animation: updown 0.5s infinite ease-out both;\n' + // bounces up&down :)
'background: url("' +
'S4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcKICAgeG1sbnM' +
'6ZGM9Imh0dHA6Ly9wdXJsLm9yZy9kYy9lbGVtZW50cy8xLjEvIgogICB4bWxuczpjYz0ia' +
'HR0cDovL2NyZWF0aXZlY29tbW9ucy5vcmcvbnMjIgogICB4bWxuczpyZGY9Imh0dHA6Ly9' +
'3d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiCiAgIHhtbG5zOnN2Zz0ia' +
'HR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgIHhtbG5zPSJodHRwOi8vd3d3LnczLm9' +
'yZy8yMDAwL3N2ZyIKICAgeG1sbnM6c29kaXBvZGk9Imh0dHA6Ly9zb2RpcG9kaS5zb3VyY' +
'2Vmb3JnZS5uZXQvRFREL3NvZGlwb2RpLTAuZHRkIgogICB4bWxuczppbmtzY2FwZT0iaHR' +
'0cDovL3d3dy5pbmtzY2FwZS5vcmcvbmFtZXNwYWNlcy9pbmtzY2FwZSIKICAgd2lkdGg9I' +
'jI0IgogICBoZWlnaHQ9IjI0IgogICB2aWV3Qm94PSIwIDAgMjQgMjQiCiAgIHZlcnNpb24' +
'9IjEuMSIKICAgaWQ9InN2ZzQiCiAgIHNvZGlwb2RpOmRvY25hbWU9ImI2NC5zdmciCiAgI' +
'Glua3NjYXBlOnZlcnNpb249IjAuOS41ICgyMDYwZWMxZjlmLCAyMDIwLTA0LTA4KSI+CiA' +
'gPG1ldGFkYXRhCiAgICAgaWQ9Im1ldGFkYXRhMTAiPgogICAgPHJkZjpSREY+CiAgICAgI' +
'DxjYzpXb3JrCiAgICAgICAgIHJkZjphYm91dD0iIj4KICAgICAgICA8ZGM6Zm9ybWF0Pml' +
'tYWdlL3N2Zyt4bWw8L2RjOmZvcm1hdD4KICAgICAgICA8ZGM6dHlwZQogICAgICAgICAgI' +
'HJkZjpyZXNvdXJjZT0iaHR0cDovL3B1cmwub3JnL2RjL2RjbWl0eXBlL1N0aWxsSW1hZ2U' +
'iIC8+CiAgICAgICAgPGRjOnRpdGxlPjwvZGM6dGl0bGU+CiAgICAgIDwvY2M6V29yaz4KI' +
'CAgIDwvcmRmOlJERj4KICA8L21ldGFkYXRhPgogIDxkZWZzCiAgICAgaWQ9ImRlZnM4IiA' +
'vPgogIDxzb2RpcG9kaTpuYW1lZHZpZXcKICAgICBwYWdlY29sb3I9IiNmZmZmZmYiCiAgI' +
'CAgYm9yZGVyY29sb3I9IiM2NjY2NjYiCiAgICAgYm9yZGVyb3BhY2l0eT0iMSIKICAgICB' +
'vYmplY3R0b2xlcmFuY2U9IjEwIgogICAgIGdyaWR0b2xlcmFuY2U9IjEwIgogICAgIGd1a' +
'WRldG9sZXJhbmNlPSIxMCIKICAgICBpbmtzY2FwZTpwYWdlb3BhY2l0eT0iMCIKICAgICB' +
'pbmtzY2FwZTpwYWdlc2hhZG93PSIyIgogICAgIGlua3NjYXBlOndpbmRvdy13aWR0aD0iN' +
'zMyIgogICAgIGlua3NjYXBlOndpbmRvdy1oZWlnaHQ9IjQ4MCIKICAgICBpZD0ibmFtZWR' +
'2aWV3NiIKICAgICBzaG93Z3JpZD0iZmFsc2UiCiAgICAgaW5rc2NhcGU6em9vbT0iOS44I' +
'gogICAgIGlua3NjYXBlOmN4PSIxMiIKICAgICBpbmtzY2FwZTpjeT0iMTIiCiAgICAgaW5' +
'rc2NhcGU6d2luZG93LXg9IjAiCiAgICAgaW5rc2NhcGU6d2luZG93LXk9IjAiCiAgICAga' +
'W5rc2NhcGU6d2luZG93LW1heGltaXplZD0iMCIKICAgICBpbmtzY2FwZTpjdXJyZW50LWx' +
'heWVyPSJzdmc0IiAvPgogIDxwYXRoCiAgICAgZD0ibSA1LjQsMTYuNCBjIDEuMSwwLjIgN' +
'C42LDAuOSA1LjUsMS4wIHYgMy41IGMgMCwxLjYgMS4zLDIuOSAzLDIuOSAxLjYsMCAzLC0' +
'xLjMgMywtMi45IHYgLTcuNCBjIDAuNSwwLjMgMS4xLDAuNiAxLjgsMC43IEMgMjAuNiwxN' +
'C41IDIyLDEzLjMgMjIsMTEuOCAyMiwxMSAyMS42LDEwLjEgMjAuOSw5LjUgMTcuMCw1LjU' +
'gMTUuMiw0LjQgMTQuOSwwIEggNSB2IDEuNyBjIDAsNS4xIC0zLDYuMCAtMywxMC4wIDAsM' +
'i40IDEuMCw0LjEgMy40LDQuNiB6IgogICAgIGlkPSJwYXRoMTQiIC8+CiAgPHBhdGgKICA' +
'gICBkPSJNIDUuMSw4LjQgQyA1LjksNi45IDYuOSw1LjEgNi45LDIgaCA2LjEgYyAwLjcsM' +
'y44IDMuOCw2LjMgNi40LDguOSAwLjYsMC42IDAuMywxLjMgLTAuNCwxLjMgQyAxNy44LDE' +
'yLjMgMTYuMCwxMC40IDE1LDkuMSBWIDIxLjAgQyAxNSwyMS41IDE0LjUsMjIgMTQsMjIgM' +
'TMuNCwyMiAxMywyMS41IDEzLDIxLjAgdiAtNi45IGMgMCwtMC4zIC0wLjIsLTAuNSAtMC4' +
'1LC0wLjUgLTAuMywwIC0wLjUsMC4yIC0wLjUsMC41IHYgMC41IGMgMCwwLjUgLTAuNCwwL' +
'jkgLTEuMCwwLjggLTAuMywtMC4wIC0wLjYsLTAuNCAtMC42LC0wLjggdiAtMS4yIGMgMCw' +
'tMC4zIC0wLjIsLTAuNSAtMC41LC0wLjUgLTAuMywwIC0wLjUsMC4yIC0wLjUsMC41IHYgM' +
'C44IGMgMCwwLjUgLTAuNCwwLjkgLTEuMCwwLjggQyA3LjYsMTQuOSA3LjMsMTQuNiA3LjM' +
'sMTQuMiB2IC0xLjUgYyAwLC0wLjMgLTAuMiwtMC41IC0wLjUsLTAuNSAtMC4zLDAgLTAuN' +
'SwwLjIgLTAuNSwwLjUgdiAwLjkgYyAwLDAuNSAtMC41LDAuOCAtMS4wLDAuNiBDIDQuNSw' +
'xMy45IDQsMTMuMyA0LDExLjcgNCwxMC40IDQuNCw5LjUgNS4xLDguNCBaIgogICAgIGlkP' +
'SJwYXRoMiIKICAgICBzdHlsZT0iZmlsbDojZmZmZmZmIiAvPgo8L3N2Zz4K") 0 0 ' +
'no-repeat transparent;\nbackground-size: 50px 50px; z-index: 1001;}' +
// this ^ is a hand pointing pointer graphic
// this v is a tiny robot head icon
'.robot-warning { padding: 8px 9px 8px 21px;' + // :) tampermonkey tells
'background: 4px 2px no-repeat url("' + //  me it's superfluous to combine
'' + //  string literals with the
'hEUgAAABAAAAAYBAMAAAABjmA/AAAAElBMVEUAAA' + // + operator! but it's
'ABBABHSEajnp28trX8//tPIl81AAAAAXRSTlMAQO' + // also not lint to
'bYZgAAAAFiS0dEAIgFHUgAAAAJcEhZcwAALiMAAC' + // go above 80 characters
'4jAXilP3YAAAAHdElNRQfkBQgSLgK2/ku1AAAAa0' + // in width...
'lEQVQI123O2w3AIAgFUNygoAxANzBxAasL+OH+qx' + // dear StackExchange...
'R8tGnS+3USLgEAAIQZ148J7m0jr9G1Rk8Z3Be4An' +
'SOCIQ6khWp1mKIkgp5BfeQe/tFxFTQOsW2k4KIRM' + // kumate!
'Q6zK1ZxxuiQuwk5ffWfuMG6yMYLhjK67sAAAAASU' +
'VORK5CYII=") rgba(255,190,170,1);' +
'box-shadow: 0 0 0 1px red;font-size: 12px;font-weight: normal;'+
'color: red; width: 172px;overflow-wrap: normal;'+
'white-space: normal;margin: 9px;display:block;}' +
(function () {/*
.l-content .brick .private_overlay {
  z-index: 9;
}

.robot-warning strong {
  font-size: 13px;
  font-weight: bold;
  display: block;
}

.blue_bar .editor_navigation .notice {
  color: rgba(150, 150, 150, 1);
  margin: 0;
  padding: 5px 0px 0px 5px;
  float: right;
}

.l-content .brick .caption {
  display: none;
}

.l-content.with-captions.hoverless .brick .caption,
.l-content.with-captions .brick:hover .caption {
  display: table;
  background: rgba(40, 50, 60, 0.6);
  box-shadow: inset 0 0 0 4px rgba(40, 50, 60, 0.6);
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99;
  text-align: left;
  width: 125px;
  height: 100%;
  animation: fadein 0.5s ease-in-out both;
}

.overflow-table {
  display: table;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 125px;
  height: 100%;
}

.overflow-row,
.caption-tr {
  display: table-row;
}

.overflow-cell,
.caption-td {
  display: table-cell;
  text-align: center;
  vertical-align: middle;
}

.overflow-inline {
  display: inline-block;
  text-align: left;
}

.caption-inline-block {
  display: inline-block;
  text-align: left;
  max-width: 115px;
  max-height: 115px;
  overflow: hidden;
}

.header_button > input[disabled]+.widget+.chrome svg,
.header_button > input[disabled]+.widget+.chrome .arrow,
.chrome.big_dark[disabled] svg {
  opacity: 0.5;
}

.blue_bar .editor_navigation .header_button .chrome .chrome_button {
  padding: 1px 0px 0px 2px;
  font-family: Franklin Gothic Medium Compressed, Arial, Helvetica, sans-serif;
  font-size: 13px;
  line-height: 14px;
  font-weight: normal;
}

.chrome.big_dark svg, .chrome_button svg {
  opacity: 1;
  margin-right: 1px;
  vertical-align: baseline;
  max-width: 13px;
  max-height: 13px;
  margin-left: 4px;
  position: relative;
}

#neue_post_form-iframe {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  background-color: rgba(0, 10, 30, 0.9);
  animation: fadein 0.5s ease-in-out both;
}

.l-content .links-layer {
  display: none;
}

.l-content .brick .edited-gif,
.l-content.with-links .brick:hover .links-layer,
.l-content.with-links.hoverless .brick .links-layer {
  background-color: rgba(40, 50, 60, 0.6);
  box-shadow: inset 0 0 0 4px rgba(40, 50, 60, 0.6);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  color: #fff;
  z-index: 100;
  display: table;
  width: 125px;
  height: 100%;
  animation: fadein 0.5s ease-in-out both;
}

.tags-layer h2, .tags-layer a {
  color: inherit;
}

.follow .tag-container {
  max-width: 89px;
  overflow: hidden;
  max-height: 100px;
}

.l-content.with-links .brick:hover .tags-layer,
.l-content.with-links .brick:hover .links-layer,
.l-content.with-links.hoverless .brick .tags-layer,
.l-content.with-links.hoverless .brick .links-layer {
  transition: all 0.2s ease-out;
}

.l-content.with-links.hoverless .brick:hover .links-layer,
.l-content.with-links.hoverless .brick:hover .tags-layer {
  color: rgba(255, 255, 255, 0);
  background-color: rgba(0, 0, 0, 0);
}

.l-content.with-links .brick.highlighted:hover .links-laye
.l-content.with-links.hoverless .brick.highlighted .links-layer {
  z-index: 1000;
  background-color: rgba(0, 80, 255, 0.5);
  box-shadow: inset 0 0 0 4px rgba(115, 186, 231, 1);
}

.l-content.with-links.hoverless .brick.highlighted:hover .links-layer {
  background-color: rgba(0, 80, 255, 0.05);
}

.brick.highlighted a.link-reblog,
.brick.highlighted a.link-like,
.brick.highlighted a.link-edit,
.brick.highlighted a.link-view {
  background: rgba(115, 186, 231, 1);
}

.l-content .brick .edited-gif .trow,
.l-content.with-links .brick:hover .links-layer .trow,
.l-content.with-links.hoverless .brick .links-layer .trow {
  display: table-row;
  vertical-align: middle;
  text-align: center;
}

.l-content .brick .tags-layer,
.l-content .brick .edited-center {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  padding: 0px 18px 0 18px;
}

.links-layer a.link-view {
  position: absolute;
  right: 4px;
  top: 4px;
  border-bottom-left-radius: 5px
}

.links-layer a.link-edit {
  position: absolute;
  left: 4px;
  bottom: 4px;
  border-top-right-radius: 5px;
}

.links-layer a.link-like {
  right: 4px;
  bottom: 4px;
  border-top-left-radius: 5px;
}

.links-layer a.link-reblog {
  left: 4px;
  top: 4px;
  border-bottom-right-radius: 5px;
}

.links-layer a.link-reblog,
.links-layer a.link-like,
.links-layer a.link-edit,
.links-layer a.link-view {
  background-color: rgba(40, 50, 60, 0.6);
  padding: 3px;
  width: 20px;
  height: 20px;
  text-align: center;
  position: absolute;
}

svg.big-heart,
svg.big-reblog {
  position: absolute;
  left:0;
  bottom:0;
  width: 125px;
  height: 125px;
  z-index: 999;
  animation: happy-bounce 1.7s ease-out both;
}

.links-layer a.link-reblog.clicked svg,
.links-layer a.link-like.clicked svg {
  animation: flip 0.75s infinite ease-out both;
  position: relative;
}

.links-layer a.link-reblog.reblogged {
  cursor: default;
}

#view-links_button svg {
  margin: 0;
}

#mpe_title {
  position: relative;
  display: inline-block;
}

.post-state-nav-item {
  display: inline-block;
  text-decoration: none;
}

.post-state-nav-item svg {
  opacity: 0.5;
  display: inline-block;
  vertical-align: text-top;
}

.post-state-nav-item.active svg {
  opacity: 1;
}

.blue_bar .post-state-nav .post-state-nav-item {
  color: #99a3ae;
  font-weight: bold;
  padding: 3px 6px;
  top: -3px;
  left: 0;
  z-index: 9;
  position: relative;
  background: #001935 none;
}

#re-as-draft:checked+label+.robot-warning {
  display: none;
}

#re-as-draft+label {
  color: #7D99FF;
  padding-left: 5px;
  font-size: 20px;
}

#reblog_widget {
  display: none;
}

.open #reblog_widget {
  width: 300px;
  height: 200px;
  z-index: 999;
  left: 340px;
  display: table;
}

#urlstuff_widget,
#backdate_widget,
#snapshot-info_widget,
#add-caption_widget {
  z-index: 9;
}

#reblog_widget .trow {
  display: table-row;
}

#reblog_widget .inner {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}

#reblog_widget h2 {
  color: #555;
  font-size: 17px;
}

#reblog-widget_input {
  width: 190px;
  padding: 6px;
  box-shadow: inset 0 2px 3px 0px rgba(0, 0, 0, 0.5);
  margin: 0;
  border: 0 none;
}

.header_button > input[disabled]+.widget+.chrome,
#reblog-widget_input[disabled] {
  color: #ccc;
}

#browse_months {
  position: relative;
  top: -3px;
  left: 0;
}

iframe#browse_months_widget {
  height: 423px;
  width: 226px;
  border-radius: 5px;
  box-shadow: 0 0 4px 2px rgba(0, 0, 0, 0.2);
}

div#browse_months_widget {
  height: 422px;
  width: 225px;
  padding: 0px;
  top: 0px;
  left: 0px;
}

.post-state-nav,
#mpe_title,
#nav-photo {
  border-left: 1px solid #122943;
  padding-left: 20px;
}

#nav_archive {
    text-align: center;
    line-height: 18px;
}

.blue_bar .title, #browse_months {
    display: inline-block;
    flex-direction: unset;
    float: none;
}

.chrome_button_right, .chrome_button_left {
  display: inline;
}

#tags {
  padding: 5px;
}

#tags div {
  margin: 0px 5px 5px 0px;
  overflow: hidden;
  display: inline-block;
  border: solid 1px rgba(255,75,35,1);
  background-color: rgba(255,75,35,0.4);
  padding: 5px;
  border-radius: 2px;
  color: #111;
  max-width: 200px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#photos-drop-zone.full {
  cursor: copy;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(200,255,200,0.5);
  z-index: 1000;
}

#photos-drop-zone {
  top: 90px;
  left: 20px;
  width: 300px;
  height: 190px;
  transition: all 0.4s ease-out;
  background-color: rgb(220, 220, 220);
  position: fixed;
  display: block;
  text-align: center;
  border-radius: 14px;
  box-shadow: inset 0 0 0 5px #f4f4f4, 0 0 0 4px rgb(220, 220, 220);
  z-index: 9;
}

#photos-drop-zone h2 {
  color: #f4f4f4;
  display: inline;
  font-size: 25px;
  font-weight: bold;
  top: 20px;
  position: relative;
  text-align: center;
  display: block;
}

#photos-drop-zone input {
  position: relative;
  top: 210px;
}

#drop_images_here {
  position: fixed;
  top: 168px;
  left: 70px;
  z-index: 12;
  font-size: 23px;
}

#photo_file_input {
  position: fixed;
  bottom: 40px;
  left: 40px;
}

#post_all_photos_button {
  position:fixed;
  top: 300px;
  cursor: pointer;
  color: #fff;
  font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-size: 14px;
  line-height: 14px;
  left: 40px;
}

#post_all_photos_button[disabled] {
  color: #ccc;
}

.photo-brick.upload-working {
  animation: updown 0.3s infinite linear;
}

span.im-ready {
  animation: updown 0.25s 5 ease-out;
  position: relative;
  display: inline-block;
  z-index: 9;
}

.photo-brick-img,
.photo-brick {
  transition: all 0.4s ease-out;
}
.photo-brick {
  position: absolute;
  width: 500px;
  background-color: rgb(220, 220, 220);
  cursor: grab;
  display: table;
  min-height: 150px;
}

.img-count {
  position: absolute;
  bottom: 0;
  right: 0;
  font-size: 21px;
  color: rgba(255,255,255,0.9);
  z-index: 9;
  font-weight: bold;
  background-color: rgba(0,0,0,0.65);
  padding: 6px 9px;
  border-top-left-radius: 9px;
}

.photo-inner {
  display: table-row;
  height: 100%;
  width: 100%;
}

.photo-brick-img.brick-dragging,
.photo-brick.brick-dragging {
  z-index: 1000;
  opacity: 0.3;
  box-shadow: 0 0 5px 2px #000;
  transition: none;
  postion: absolute;
}

.photo-brick.hl-top {
  border-top: 3px dashed #0cf;
  margin-top: 5px;
}

.photo-brick.hl-bottom {
  margin-top: -5px;
  border-bottom: 3px dashed #0cf;
}

.hl-up {
  border-top: 3px dashed #0cf;
  margin-top: 5px;
}

.hl-down {
  border-bottom: 3px dashed #0cf;
  margin-bottom: 5px;
}

.hl-left {
  border-left: 3px dashed #0cf;
  margin-left: 5px;
}

.hl-right {
  border-right: 3px dashed #0cf;
  margin-right: 5px;
}

.photo-brick-edit {
  display: table-cell;
}

.photo-brick-img-cell {
  position: relative;
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  top: 0;
  left: 0;
  width: 137px;
  background-color: #001935;
}

.pre-photoset .photo-brick-img-cell {
  background-color: #405975;
  box-shadow: inset 0 0 8px 1px #fff;
}

.photo-brick-img:first-child {
  margin-top: 5px;
}

.photo-brick-img {
  display: inline-block;
  position: relative;
  top: 0;
  left: 0;
  margin-bottom: 5px;
}

.photo-brick-img.brick-dragging,
.photo-brick-img.brick-dragging img,
.row-with-one-img,
.row-with-one-img img {
  width: 125px;
}

.row-with-two-img,
.row-with-two-img img {
  width: 60px;
}

.row-with-three-img,
.row-with-two-img {
  overflow: hidden;
}

.row-with-three-img img,
.row-with-two-img img {
  width: 100%;
  height: auto;
  max-width: 125px;
}

.row-with-two-img.data-photoset-a {
  margin-right: 5px;
}

.row-with-three-img,
.row-with-three-img img {
  width: 38px;
}

.row-with-three-img.data-photoset-a,
.row-with-three-img.data-photoset-b {
  margin-right: 5px;
}

.photo-brick img {
  user-drag: none;
  user-select: none;
  -moz-user-select: none;
  -webkit-user-drag: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

.photo-brick-edit .rich {
  background-color: rgba(255,255,255,0.8);
  margin: 34px 6px 0px 6px;
  box-shadow: inset 0 2px 3px 0 #999;
  padding: 5px;
  cursor: auto;
  overflow-y: scroll;
  overflow-x: hidden;
  text-align: left;
  display: block;
  width: 340px;
  height: calc(100% - 42px);
}

#add-caption_widget .rich {
  background-color: rgba(255,255,255,0.8);
  margin: 30px 7px 0px 7px;
  box-shadow: inset 0 2px 3px 0 #999;
  padding: 5px;
  cursor: auto;
  overflow-y: scroll;
  overflow-x: hidden;
  display: block;
  width: 340px;
  height: 150px;
  text-align: left;
}

#add-caption_widget.visible-url .chrome,
#add-caption_widget .chrome,
.focused-rich.visible-url .photo-brick-edit .chrome,
.photo-brick-edit .chrome {
  font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-size: 14px;
  display: none;
  position: absolute;
  cursor: pointer;
  min-width: 30px;
}

#add-caption_widget {
  height: 300px;
  width: 365px;
}

#snapshot-info_body {
  cursor: auto;
}

#snapshot-info_widget {
  padding: 20px;
  width: 400px;
  height: 320px;
}

#snapshot-info_body {
  position: relative;
  top: 0;
  left: 0;
  height: 360px;
}

#new-blogs {
  right: 10px;
  bottom: 55px;
}

#missing-blogs {
  left: 10px;
  bottom: 55px;
}

#snapshot-info_body h2 {
  display: inline-block;
  width: 190px;
  text-align: center;
}

#missing-blogs, #new-blogs {
  border: 1px solid #555;
  height: 240px;
  width: 169px;
  padding: 8px;
  position: absolute;
  overflow-x: hidden;
  text-overflow: ellipsis;
  overflow-y: auto;
  font: normal 11px 'Lucida Grande', Verdana, sans-serif;
  color: #555;
  background-color: rgba(255, 255, 255, 0.7);
}

#backdate_widget {
  height: 260px;
  width: 540px;
  font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-size: 14px;
}

#backdate_widget .chrome{
  margin: 5px;
  float: right;
  padding: 0 8px;
}

#snapshot-info_widget .chrome,
#backdate_widget .chrome,
#add-caption_widget .chrome {
  border: 0 none;
}

.focused-rich.visible-url .photo-brick-edit .chrome,
.photo-brick-edit .chrome {
  top: 3px;
}

#add-caption_widget .chrome {
  top: 45px;
}

.photo-brick.focused-rich {
  z-index: 100;
  box-shadow: 0 0 5px 1px #03f;
  margin: -2px 0px 0px 5px;
}

.photo-brick-edit .photo-tags {
  max-height: 135px;
  display: inline-block;
  position: absolute;
  right: 0;
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
  top: 0;
  transform: translateX(100%);
}

.focused-rich .photo-tags {
  overflow: auto;
  background-color: rgba(0, 33, 255, 0.5);
  padding: 4px 0px 0px 6px;
}

#add-caption_widget.visible-url .chrome,
#add-caption_widget .chrome,
.focused-rich .photo-brick-edit .chrome {
  display: block;
}

.stripe {
  position: absolute;
  top: 7px;
  left: 143px;
  border-top: 5px solid #BBB;
  height: 10px;
  width: calc(100% - 150px);
  display: block;
  border-bottom: 5px solid #BBB;
}

.focused-rich .photo-brick-edit .stripe {
  display: none;
}

.focused-rich .photo-brick-edit .photo-tags .token {
  float: left;
  padding: 3px 5px;
  border: solid 1px #b7c963;
  background-color: #C7DA76;
  color: #111;
  margin: 0px 5px 5px 0px;
  border-radius: 2px;
  font: normal 14px/1.4 "Helvetica Neue",
    "HelveticaNeue", Helvetica, Arial, sans-serif;
  text-decoration: none;
  cursor: auto;
}

.photo-brick-edit .photo-tags .token .tag:before {
  content: "#";
  display: inline-block;
}

.focused-rich .photo-brick-edit .photo-tags .token .tag:before {
  content: "";
  display: none;
}

.photo-brick-edit .token a {
  display: none;
}

#add-caption_widget a,
.focused-rich .photo-brick-edit .token a {
  font-weight: bold;
  margin-left: 7px;
  text-decoration: none;
  color: #749440;
  display: inline-block;
}

.photo-brick-edit .photo-tags .token {
  float: left;
  padding: 3px 5px;
  color: #999;
  font-weight: bold;
  margin: 0px 5px 5px 0px;
  font: normal 14px/1.4 "Helvetica Neue",
    "HelveticaNeue", Helvetica, Arial, sans-serif;
  text-decoration: underline;
  display: inline-block;
  cursor: auto;
}

.photo-brick-edit .clone_abc_button {
  right: 265px;
  width: 94px;
  line-height: 11px;
  top: -31px;
  box-shadow: 0 1px 0 3px rgb(220, 220, 220),
              0 0 5px 3px #03f;
}

#add-caption_widget .pink_button,
#add-caption_widget .x_button,
.photo-brick-edit .pink_button,
.photo-brick-edit .x_button {
  right: 327px;
  font-weight: 900;
  color: #f00;
}

#add-caption_widget .red_button,
#add-caption_widget .b_button,
.photo-brick-edit .red_button,
.photo-brick-edit .b_button {
  right: 295px;
  font-weight: 900;
}

#add-caption_widget .orange_button,
#add-caption_widget .i_button,
.photo-brick-edit .orange_button,
.photo-brick-edit .i_button {
  right: 263px;
  font-style: italic;
}

#add-caption_widget .yellow_button,
#add-caption_widget .s_button,
.photo-brick-edit .yellow_button,
.photo-brick-edit .s_button {
  right: 231px;
  font-style: italic;
  text-decoration-line: line-through;
}

#add-caption_widget .green_button,
#add-caption_widget .a_button,
.photo-brick-edit .green_button,
.photo-brick-edit .a_button {
  right: 199px;
  color: #009;
  text-decoration-line: underline;
}

#add-caption_widget .ok_button,
.focused-rich .photo-brick-edit .ok_button {
  right: 7px;
  display: none;
}

#add-caption_widget.visible-url .chrome,
#add-caption_widget.visible-colors .chrome,
#add-caption_widget .colors_buttons,
.focused-rich.visible-colors .photo-brick-edit .chrome,
.photo-brick-edit .colors_buttons,
.focused-rich .photo-brick-edit .colors_buttons {
  display: none;
}

#add-caption_widget .a_button_input,
.photo-brick-edit .a_button_input,
.focused-rich .photo-brick-edit .a_button_input {
  display: none;
  right: 199px;
  color: #009;
  text-decoration-line: underline;
  position: absolute;
  top: 3px;
  height: 30px;
  width: 318px;
  padding: 0 3px;
  left: 143px;
  background-color: #fff;
  box-shadow: 0 0 0 1px #eee, inset 0 2px 2px 0 #000;
}

#add-caption_widget.visible-url .a_button_input,
#add-caption_widget.visible-url .ok_button,
.focused-rich.visible-url .photo-brick-edit .a_button_input,
.focused-rich.visible-url .photo-brick-edit .ok_button {
  display: block;
}

#add-caption_widget.visible-colors .colors_buttons,
.focused-rich.visible-colors .photo-brick-edit .colors_buttons {
  display: block;
}

#add-caption_widget .cerulean_button,
#add-caption_widget .h_button,
.photo-brick-edit .cerulean_button,
.photo-brick-edit .h_button {
  right: 167px;
  font-weight: 900;
}

#add-caption_widget .blue_button,
#add-caption_widget .ol_button,
.photo-brick-edit .blue_button,
.photo-brick-edit .ol_button {
  right: 135px;
}

#add-caption_widget .ul_button,
.photo-brick-edit .ul_button {
  right: 103px;
}

#add-caption_widget .bq_button,
.photo-brick-edit .bq_button {
  right: 71px;
}

#add-caption_widget .colors_button,
.photo-brick-edit .colors_button {
  right: 39px;
}

#add-caption_widget .q_button,
.photo-brick-edit .q_button {
  right: 7px;
  font-family: Fairwater, serif;
  font-size: 17px;
  line-height: 26px;
}

#add-caption_widget .colors_button .color,
.photo-brick-edit .colors_button .color {
  width: 14px;
  height: 17px;
  border-radius: 6px;
  box-shadow: inset 0 0 0 1px #fff;
  background: linear-gradient(
    to bottom,
    rgba(255,0,0,1) 0%,
    rgba(255,85,0,1) 20%,
    rgba(255,255,0,1) 40%,
    rgba(0,255,0,1) 60%,
    rgba(0,0,255,1) 80%,
    rgba(255,0,255,1) 100%
  );
}

#photos_as_draft_container {
    position: fixed;
    top: 340px;
    left: 50px;
}

#photos_as_draft + label + .robot-warning {
  display: block;
}

#photos_as_draft:checked + label + .robot-warning {
  display: none;
}

#return_to_dash_link {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #555;
  font-size: 45px;
}

#add-caption_widget .robot-warning {
  display: inline-block;
}

.pend-container {
  text-align: left;
}

.pend-container div {
  height: 20px;
}

.pend-container label {
  cursor: pointer;
}

#overwrite-caption-option + label +.robot-warning {
  position: absolute;
  left: 70px;
  bottom: -11px;
  width: 136px;
  display: none;
  height: 50px;
}

#overwrite-caption-option:checked + label +.robot-warning {
  display: block;
}

.pend-container {
  position: relative;
  left: 6px;
  bottom: -6px;
}

#bt-no-time + label,
#bt-one-time + label,
#bt-two-time + label,
#bd-no-day + label,
#bd-one-day + label,
#bd-two-day + label {
  width: 130px;
  text-align: left;
  height: 19px;
  background-color: rgba(14,20,25,0.5);
  border-radius: 10px;
  color: #fff;
  padding: 5px 20px;
}

#bt-no-time:checked + label,
#bt-one-time:checked + label,
#bt-two-time:checked + label,
#bd-no-day:checked + label,
#bd-one-day:checked + label,
#bd-two-day:checked + label {
  background-color: #0ae;
}

#bt-no-time,
#bt-one-time,
#bt-two-time,
#bd-no-day,
#bd-one-day,
#bd-two-day {
  position: relative;
  left: 18px;
}

.date-input-bunch * {
  float: left;
  line-height: 17px;
}

.date-input-bunch {
  display: inline-block;
  background-color: rgba(30,85,125,1);
  color: #fff;
  margin: 0px 3px;
  width: 245px;
  height: 22px;
  top: 9px;
  position: relative;
  padding: 3px 0px 3px 5px;
}

.date-input-bunch input[type="number"] {
  margin-left: 3px;
  max-width: 50px;
  box-shadow: inset 0px 1px 3px 0px #000;
}

.date-input-bunch label {
  text-align: center;
  color: #0ae;
  width: 40px;
  font-size: 14px;
  font-weight: bold;
  line-height: 22px;
}

.date-input-bunch label.rlabel {
  background-color: #3bc;
  color: #fff;
  border-bottom-right-radius: 9px;
  border-top-right-radius: 9px;
  height: 21px;
}

.date-input-bunch label.rlabel.narrow {
  width: 20px;
}

.date-input-bunch .linput {
 width: 40px;
}

#bt-no-time:checked+label+.date-input-bunch+.date-input-bunch,
#bt-no-time:checked+label+.date-input-bunch,
#bd-no-day:checked+label+.date-input-bunch+.date-input-bunch,
#bd-no-day:checked+label+.date-input-bunch {
  opacity: 0.3;
}

#bt-one-time:checked+label+input+label+input+label+
.date-input-bunch+.date-input-bunch,
#bd-one-day:checked+label+input+label+input+label+
.date-input-bunch+.date-input-bunch {
  opacity: 0.3;
}

#backdate_widget div {
  margin-bottom: 7px;
}

#pmright+label:before,
#pmleft+label:before {
  position: relative;
  content: "am";
  display: inline-block;
}

#pmright:checked+label:before,
#pmleft:checked+label:before {
  content: "pm";
}

.source-label1 {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 9;
  background-color: rgba(0,0,0,0.5);
  border-radius: 30px;
}

.source-label2 {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 9;
  background-color: rgba(100,110,255,0.4);
  border-radius: 30px;
}

.follower-pop-t {
  display: table;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,0.8);
  z-index: 1000;
}

.follower-pop-tr {
  display: table-row;
  width: 100%;
  height: 100%;
}

.follower-pop-td {
  display: table-cell;
  width: 100%;
  height: 100%;
  text-align: center;
  vertical-align: middle;
}

.follower-pop-inner {
  display: inline-block;
  width: 512px;
}

.follower-pop-av,
.follower-pop-img {
  display: inline-block;
  width: 512px;
  height: 512px;
}

.follower-pop-title {
  font-size: 45px;
  padding: 9px;
  line-height: 45px;
}

.l-content .brick.follow.missing-follows-info .overlay {
  opacity: 1;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url(https://assets.tumblr.com/images/loading_ddd.gif)
              50% 20px no-repeat rgba(255,255,255,0.9);
  width: 125px;
  height: 125px;
  border: 0 none;
}
.l-content .brick.edit-reblog-queue .highlight {
  background: url(https://assets.tumblr.com/images/loading_ddd.gif)
              50% 20px no-repeat rgba(225,185,35,0.9);
  display: block;
  border-color: rgba(225,95,35,1);
}

.l-content .brick.edit-reblog-queue .highlight .note_count,
.l-content .brick.edit-reblog-queue .highlight .tag_count,
.l-content .brick.edit-reblog-queue .highlight .tag_count:after,
.l-content .brick.edit-reblog-queue .overlay .inner .date {
  background-color: rgba(225,95,35,1);
}

#hover-only {
  margin-left: 3px;
}

#hover-only,
#hover-only+label svg {
  vertical-align: text-bottom;
}

#hover-only+label svg {
  width: 10px;
  height: 10px;
}

#hover-only+label {
  font-weight: bold;
  color: #fff;
  opacity: 0.5;
  font-size: 10px;
}

#hover-only:checked+label {
  opacity: 1;
}

#hover-only, #hover-only+label {
  top: 3px;
  position: relative;
}

#who-follows-who {
    font-size: 24px;
}

#snapshot-info_body * {
  font-family: "Helvetica Neue",
    "HelveticaNeue", Helvetica, Arial, sans-serif;
}

#forget1_button, #forget2_button {
  position: absolute;
  bottom: 29px;
  padding: 0 9px;
}

#snapshot-info_body a {
  display: block;
  text-align: left;
  margin: 4px;
  font-size: 14px;
}

#forget1_button {
  left: 65px;
}

#forget2_button {
  right: 65px;
}

#snapshot-info_body h1 {
  color: #555;
  font-size: 20px;
  display: block;
  font-weight: bold;
}

#snapshot-load-gif {
  position: absolute;
  top: 0;
  left: 0;
}

#new-blogs a {
  color: #59f;
}

#missing-blogs a {
  color: #f00;
}

.l-content~.l-content {
  display: none;
}
*/}).toString().slice(15,-3)
    )
  );
  // all of my extra css are in this ^ inline style
  document.head.appendChild(pluginStyle);
  // end extra CSS

  // my plugin will not use unSafeWindow, so instead
  // this v, is how I shall use fake window scope wrapper variables
  // for asynchronous window functions, the plugin data must be in the DOM
  // the DOM can be accessed by both wrapper scopes
  // it's like a 4 dimensional being :)
  var pluginData = document.createElement("div");
  pluginData.id = "mass_post_features-plugin_data";
  pluginData.classList.add("blog-menu-preload");
  pluginData.classList.add("month-menu-preload");
  pluginData.setAttribute("widget_sort-by", "date-down");
  pluginData.setAttribute("data-last-post-index", "0");
  pluginData.setAttribute("data-select-all_needle", "0");
  pluginData.setAttribute("data-select-by_needle", "0");
  pluginData.setAttribute("data-last_month_timestamp", "0")
  pluginData.setAttribute("data-last_year_timestamp", "0");
  pluginData.setAttribute("widget_scroll-top", "0");
  pluginData.setAttribute("widget_first-focus", "hide-ltgt-than-tags");
  pluginData.setAttribute("select-by-note_lt", "10");
  pluginData.setAttribute("select-by-note_gt", "5");
  pluginData.setAttribute("hide-ltgt-than-tags", "5");
  pluginData.setAttribute("data-to-seconds", "0");
  pluginData.setAttribute("data-unstable-next-href", "0");
  pluginData.setAttribute("data-lt-to-select", "[]");
  pluginData.setAttribute("data-gt-to-select", "[]");
  pluginData.setAttribute(
    "data-all-to-select",
    "{\"istag\":[],\"nottag\":[],\"istype\":[],\"nottype\":[]}"
  );// this ^ has the 4 dimensions of the select-by widget
  pluginData.setAttribute("data-to-select", "[]");
  pluginData.setAttribute("data-tags_all_arr", "[]");
  pluginData.setAttribute("data-ids_all_arr", "[]");
  pluginData.setAttribute("data-visible_ids_all_arr", "[]");
  pluginData.setAttribute("data-types_all_arr", "[]");
  pluginData.setAttribute("data-follow-blogs-all", "[]");
  pluginData.setAttribute("data-new-blogs-all", "[]");
  pluginData.setAttribute("data-missing-blogs-all", "[]");
  pluginData.setAttribute("data-follow-blogs-all-updated", "0");
  pluginData.setAttribute("data-new-blogs-all-updated", "0");
  pluginData.setAttribute("data-missing-blogs-all-updated", "0");
  pluginData.setAttribute("data-id_to_tags", "{}");
  pluginData.setAttribute("data-id_to_types", "{}")
  pluginData.setAttribute("data-id_to_image", "{}");
  pluginData.setAttribute("data-id_to_origin", "{}");
  pluginData.setAttribute("data-id_to_state", "{}");
  pluginData.setAttribute("data-id_to_timestamp", "{}");
  pluginData.setAttribute("data-id_to_notes", "{}");
  pluginData.setAttribute("data-tag_to_ids", "{}");
  pluginData.setAttribute("data-type_to_ids", "{}");
  pluginData.setAttribute("data-csrf-token", "0");
  pluginData.setAttribute("data-reblog-to-here", name);
  pluginData.setAttribute("data-primary-blog", name); // correct guess later
  pluginData.setAttribute("data-tumblelogs", "[]"); // all blogss
  pluginData.setAttribute("data-primary-known", "false");
  pluginData.setAttribute("data-followers-loading", "false");
  pluginData.setAttribute("data-x-tumblr-form-key", "0");
  pluginData.setAttribute("data-column_gutter", "6");
  pluginData.setAttribute("data-current_edit_index", "-1");
  pluginData.setAttribute("data-single_edit_id", "0");
  pluginData.setAttribute("data-current_edit_action", "reblog");
  pluginData.setAttribute("data-photos_height", "150");
  var pluginDataShell = document.createElement("div");
  pluginDataShell.appendChild(pluginData);
  document.body.insertBefore(pluginDataShell, document.body.firstChild);
  // this ^, per classList booleans and data-attributes, etc.
  // one giant DOM element attribute tree,
  // like every post on the Tumblr dashboard 2016

  // this v, is how I shall draw a selection box
  var data = document.getElementById(
    "mass_post_features-plugin_data"
  );
  data.setAttribute("doc-title", document.title);

  // the mousedown contains a variety of things for other functions
  window.addEventListener("mousedown", function (e) {
    if (e.which !== 1) {
      return true;
    }
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var selectionBox = document.getElementById(
      "mass_post_features-plugin_selection_box"
    );
    var targ = e.target;
    var cont = targ; // container(parent)
    // this only runs on the photos page
    if (data.classList.contains("is-uploading-photos")) {
      // batch photos dragging
      while (
        cont.parentNode !== null &&
        typeof cont.parentNode !== "undefined" &&
        cont.nodeName !== "BODY" &&
        cont.id !== "add_tags_widget" &&
        cont.nodeName !== "A" &&
        cont.nodeName !== "BUTTON" &&
        !cont.classList.contains("photo-tags") &&
        !cont.classList.contains("photo-brick") &&
        !cont.classList.contains("photo-brick-img") &&
        !cont.classList.contains("rich") // edit
      ) {
        cont = cont.parentNode;
      }
      if (
        !data.classList.contains("photo-upload-in-progress") &&
        typeof cont !== "undefined" &&
        typeof cont.nodeName !== "undefined" &&
        (
          cont.nodeName === "A" ||
          cont.nodeName === "BUTTON"
        )
      ) {
        if (cont.parentNode.classList.contains("token")) {
          cont.parentNode.parentNode.removeChild(
            cont.parentNode
          );
        }
        e.preventDefault();
        e.stopPropagation();
        e.cancelBubble = true;
        return true;
      }
      if (
        !data.classList.contains("photo-upload-in-progress") &&
        typeof cont !== "undefined" &&
        typeof cont.classList !== "undefined" &&
        (
          cont.classList.contains("photo-brick") ||
          cont.classList.contains("photo-brick-img")
        )
      ) {
        if (cont.classList.contains("focused-rich")) {
          var addTagsWidget = document.getElementById(
            "add_tags_widget"
          );
          addTagsWidget.style.display = "block";
        }
        var bcr = cont.getBoundingClientRect();
        cont.setAttribute("original-x", bcr.left);
        cont.setAttribute("original-y", bcr.top);
        var bmx = bcr.left - e.clientX;
        var bmy = bcr.top - e.clientY;
        if (cont.classList.contains("photo-brick-img")) {
          bmx -= 360;
          bmy -= cont.parentNode.getBoundingClientRect().top +
                 document.documentElement.scrollTop;
        }
        cont.setAttribute("mouse-x-from-left", bmx);
        cont.setAttribute("mouse-y-from-top", bmy - cont.clientHeight);
        cont.classList.add("brick-dragging");
        cont.style.marginBottom = "-" + cont.clientHeight + "px";
      } else if (
        typeof cont !== "undefined" &&
        typeof cont.classList !== "undefined" &&
        !cont.classList.contains("rich") &&
        cont.id !== "add_tags_widget"
      ) {
        var fr = document.getElementsByClassName("focused-rich");
        while (fr.length > 0 ) {
          fr[0].classList.remove("focused-rich");
        }
      }
    }
    targ = e.target;
    cont = targ;
    var initialMouseX = e.pageX;
    var initialMouseY = e.pageY;
    while (
      cont.parentNode !== null &&
      typeof cont.parentNode !== "undefined" &&
      cont.nodeName !== "BODY" &&
      cont.id !== "nav_archive" &&
      cont.id !== "blog_menu" &&
      cont.id !== "select-by_widget" &&
      cont.id !== "add-caption_widget" &&
      cont.id !== "backdate_widget" &&
      cont.id !== "snapshot-info_widget" &&
      cont.id !== "snapshot-info_body" &&
      cont.id !== "urlstuff_widget" &&
      cont.id !== "urlstuff_body" &&
      cont.id !== "backdate-body" &&
      cont.id !== "reblog_widget" &&
      cont.id !== "select-by-widget_title" &&
      cont.id !== "remove_tags_widget" &&
      cont.id !== "add_tags_widget" &&
      cont.id !== "tags" &&
      cont.id !== "tags_to_add" &&
      cont.id !== "tag_editor" &&
      cont.id !== "widget_scrolling_part" &&
      cont.id !== "reblog-widget_input" &&
      cont.id !== "rich_text_caption"
    ) {
      cont = cont.parentNode;
    }
    if (
        cont.id === "select-by_widget" ||
        cont.id === "select-by-widget_title" ||
        cont.id === "remove_tags_widget" ||
        cont.id === "add_tags_widget" ||
        cont.id === "reblog_widget" ||
        cont.id === "add-caption_widget" ||
        cont.id === "backdate_widget" ||
        cont.id === "snapshot-info_widget" ||
        cont.id === "urlstuff_widget"
    ) {
      var sbw = document.getElementById(
        cont.id === "select-by-widget_title" ? "select-by_widget": cont.id
      );
      // grabbing and dragging step #1
      var mx = sbw.getBoundingClientRect().left - e.clientX;
      var my = sbw.getBoundingClientRect().top - e.clientY;
      sbw.setAttribute("mouse-x-from-left", mx);
      sbw.setAttribute("mouse-y-from-top", my);
      sbw.classList.add("widget-dragging");
    }
    // close snapshot-info_widget
    var snapshotInfo = document.getElementById("snapshot-info");
    if (
      cont.id !== "snapshot-info_widget" &&
      cont.id !== "snapshot-info_body" &&
      snapshotInfo !== null && snapshotInfo.checked
    ) {
      snapshotInfo.checked = false;
    }
    // close urlstuff_widget
    var urlstuff = document.getElementById("urlstuff");
    if (
      cont.id !== "urlstuff_widget" &&
      cont.id !== "urlstuff_body" &&
      urlstuff !== null && urlstuff.checked
    ) {
      urlstuff.checked = false;
    }
    // close backdate_widget
    var backdate = document.getElementById("backdate");
    if (
      cont.id !== "backdate_widget" &&
      cont.id !== "backdate-body" &&
      backdate !== null && backdate.checked
    ) {
      backdate.checked = false;
    }
    // close add-caption_widget
    var addCaption = document.getElementById("add-caption");
    if (
      cont.id !== "add-caption_widget" &&
      cont.id !== "rich_text_caption" &&
      addCaption !== null && addCaption.checked
    ) {
      addCaption.checked = false;
    }
    // close select-by_widget
    var selectBy = document.getElementById("select-by");
    if (
      cont.id !== "select-by_widget" &&
      cont.id !== "select-by-widget_title" &&
      cont.id !== "widget_scrolling_part" &&
      selectBy !== null && selectBy.checked
    ) {
      var wsp = document.getElementById("widget_scrolling_part");
      data.setAttribute("widget_scroll-top", wsp.scrollTop);
      var pick = document.getElementsByClassName("picked");
      while (pick.length > 0) {
        pick[0].classList.remove("picked");
      }
      selectBy.checked = false;
    }
    // close blog menu, close reblog widget
    if (
      cont.id !== "blog_menu" &&
      cont.id !== "reblog_widget" &&
      cont.id !== "reblog-widget_input" &&
      data.classList.contains("open-blog_menu") &&
      !data.classList.contains("closing-blog_menu")
    ) {
      var o = document.getElementsByClassName("open");
      while (o.length > 0) {
        o[0].classList.remove("open");
      }
      data.classList.remove("open-blog_menu");
      e.cancelBubble = true;
      e.stopPropagation();
      data.classList.add("closing-blog_menu");
      data.classList.remove("open-blog_menu");
      return false;
    }
    if (data.classList.contains("closing-blog_menu")) {
      data.classList.remove("closing-blog_menu");
    }
    if (data.classList.contains("is-uploading-photos")) {
      return true;
      // we return here, because all this other thing
      // stuff is for other editor modes...
    }
    // draw selection box
    if (
      e.shiftKey &&
      !data.classList.contains("shift_key")
    ) {
      data.classList.add("shift_key");
    }
    if (
      !data.classList.contains("mousedown") &&
      cont !== null &&
      typeof cont === "object" &&
      cont.nodeName === "BODY" &&
      cont.id !== "nav_archive"
    ) {
      data.classList.add("mousedown");
      data.setAttribute("data-initial_mouse_x", initialMouseX);
      data.setAttribute("data-initial_mouse_y", initialMouseY);
    }
  });
  window.addEventListener("mouseup", function (e) {
    var drg = document.getElementsByClassName("widget-dragging");
    while (drg.length > 0) {
      drg[0].classList.remove("widget-dragging");
    }
    var pre = document.getElementsByClassName("pre-photoset");
    var hu;
    var hd;
    var hl;
    var hr;
    var hlb = document.getElementsByClassName("hl-bottom");
    var hlt = document.getElementsByClassName("hl-top");
    var bd = document.getElementsByClassName("brick-dragging");
    if (bd.length > 0 && bd[0].classList.contains("photo-brick")) {
      // drop row inbetween rows
      if (hlb.length + hlt.length === 0) {
        bd[0].style.left = bd[0].getAttribute("original-x") + "px";
        bd[0].style.top = bd[0].getAttribute("original-y") + "px";
      } else if (hlt.length > 0) {
        document.body.insertBefore(bd[0], hlt[0]);
      } else if (hlb.length > 0) {
        document.body.insertBefore(bd[0], hlb[0].nextSibling);
      }
      while (hlb.length > 0) {
        hlb[0].classList.remove("hl-bottom");
      }
      while (hlt.length > 0) {
        hlt[0].classList.remove("hl-top");
      }
      while (bd.length > 0) {
        bd[0].style.removeProperty("margin-bottom");
        bd[0].classList.remove("brick-dragging");
      }
      // rebuildColumn after row dragged
      rebuildPhotoColumn();
    } else if (
      bd.length > 0 && bd[0].classList.contains("photo-brick-img")
    ) {
      // drop into photoset instead...
      hu = document.getElementsByClassName("hl-up");
      hd = document.getElementsByClassName("hl-down");
      hl = document.getElementsByClassName("hl-left");
      hr = document.getElementsByClassName("hl-right");
      if (
        hlb.length + hlt.length > 0 &&
        hu.length + hd.length + hl.length + hr.length === 0
      ) {
        // drop into new Editor row thing, instead...
        bd[0].style.left = "0px";
        bd[0].style.top = "0px";
        loadPhotoIntoDOM(bd[0].children[0]);
      } else if (hu.length + hd.length + hl.length + hr.length > 0) {
        if (hu.length > 0) {
          // insert photo above, above (clap, clap, clap)
          if (
            hu[0].classList.contains("row-with-one-img") ||
            (
              (
                hu[0].classList.contains("row-with-two-img") &&
                hu[0].classList.contains("data-photoset-a")
              ) || (
                hu[0].classList.contains("row-with-three-img") &&
                hu[0].classList.contains("data-photoset-a")
              )
            )
          ) {
            // insertBefore... :P
            hu[0].parentNode.insertBefore(bd[0], hu[0]);
          } else if (
            (
              hu[0].classList.contains("row-with-two-img") &&
              hu[0].classList.contains("data-photoset-b")
            ) || (
              hu[0].classList.contains("row-with-three-img") &&
              hu[0].classList.contains("data-photoset-b")
            )
          ) {
            // insertBefore&Before
            hu[0].parentNode.insertBefore(
              bd[0], hu[0].previousSibling
            );
          } else if (
            hu[0].classList.contains("row-with-three-img") &&
            hu[0].classList.contains("data-photoset-c")
          ) {
            // insertAfter&Before&Before
            hu[0].parentNode.insertBefore(
              bd[0], // weird: siblings ARE always there and !== undefined
              hu[0].previousSibling.previousSibling
            ); // because everything is correct :P
          } else {
            hu[0].parentNode.insertBefore(bd[0], hu[0]);
          }
          bd[0].classList.add("row-with-one-img");
          bd[0].classList.remove("data-photoset-a");
          bd[0].classList.remove("data-photoset-b");
          bd[0].classList.remove("data-photoset-c"); // abc...
          bd[0].classList.remove("row-with-two-img");
          bd[0].classList.remove("row-with-three-img");
        } else if (hd.length > 0) {
          // insert photo below, below photo (clap, clap, clap)
          if (
            hd[0].classList.contains("row-with-one-img") ||
            (
              (
                hd[0].classList.contains("row-with-two-img") &&
                hd[0].classList.contains("data-photoset-b")
              ) || (
                hd[0].classList.contains("row-with-three-img") &&
                hd[0].classList.contains("data-photoset-c")
              )
            )
          ) {
            // insertAfter... :P
            hd[0].parentNode.insertBefore(bd[0], hd[0].nextSibling);
          } else if (
            (
              hd[0].classList.contains("row-with-two-img") &&
              hd[0].classList.contains("data-photoset-a")
            ) || (
              hd[0].classList.contains("row-with-three-img") &&
              hd[0].classList.contains("data-photoset-b")
            )
          ) {
            // insertAfter&After
            hd[0].parentNode.insertBefore(
              bd[0], hd[0].nextSibling.nextSibling
            );
          } else if (
            hd[0].classList.contains("row-with-three-img") &&
            hd[0].classList.contains("data-photoset-a")
          ) {
            // insertAfter&After&After
            hd[0].parentNode.insertBefore(
              bd[0], // assumed: my siblings ARE there and !== undefined
              hd[0].nextSibling.nextSibling.nextSibling
            ); // because everything is correct :P
          }
          bd[0].classList.add("row-with-one-img");
          bd[0].classList.remove("row-with-two-img");
          bd[0].classList.remove("row-with-three-img");
          // insert to the left, to the left... (clap, clap, clap)
        } else if (hl.length > 0) {
          // START: these next few chucks are: long and similar; don't get lost
          if (hl[0].classList.contains("row-with-one-img")) {
            bd[0].classList.add("data-photoset-a");
            hl[0].classList.add("data-photoset-b");
            // 123...
            bd[0].classList.remove("data-photoset-c");
            bd[0].classList.remove("data-photoset-b");
            hl[0].classList.remove("data-photoset-a");
            hl[0].classList.remove("data-photoset-c");
            // abc...
            hl[0].classList.remove("row-with-one-img");
            hl[0].classList.add("row-with-two-img");
            bd[0].classList.remove("row-with-one-img");
            bd[0].classList.add("row-with-two-img");
            bd[0].classList.remove("row-with-three-img");
          } else if (hl[0].classList.contains("row-with-two-img")) {
            // left of an "a" goes to the left
            if (hl[0].classList.contains("data-photoset-a")) {
              bd[0].classList.add("data-photoset-a");
              hl[0].classList.add("data-photoset-b");
              hl[0].nextSibling.classList.add("data-photoset-c");
              // 123...
              hl[0].nextSibling.classList.remove("data-photoset-b");
              hl[0].nextSibling.classList.remove("data-photoset-a");
              bd[0].classList.remove("data-photoset-c");
              bd[0].classList.remove("data-photoset-b");
              hl[0].classList.remove("data-photoset-a");
              hl[0].classList.remove("data-photoset-c");
              // abc...
              hl[0].classList.remove("row-with-two-img");
              hl[0].classList.add("row-with-three-img");
              hl[0].nextSibling.classList.remove("row-with-two-img");
              hl[0].nextSibling.classList.add("row-with-three-img");
              // left of a "b" goes in-between
            } else if (hl[0].classList.contains("data-photoset-b")) {
              hl[0].classList.add("data-photoset-c");
              bd[0].classList.add("data-photoset-b");
              hl[0].previousSibling.classList.add("data-photoset-a");
              // 123...
              hl[0].previousSibling.classList.remove("data-photoset-b");
              hl[0].previousSibling.classList.remove("data-photoset-c");
              bd[0].classList.remove("data-photoset-c");
              bd[0].classList.remove("data-photoset-a");
              hl[0].classList.remove("data-photoset-b");
              hl[0].classList.remove("data-photoset-a");
              // abc...
              hl[0].classList.remove("row-with-two-img");
              hl[0].classList.add("row-with-three-img");
              hl[0].previousSibling.classList.remove("row-with-two-img");
              hl[0].previousSibling.classList.add("row-with-three-img");
            }
            bd[0].classList.remove("row-with-one-img");
            bd[0].classList.remove("row-with-two-img");
            bd[0].classList.add("row-with-three-img");
          }
          // regardless, it's to the left...
          hl[0].parentNode.insertBefore(bd[0], hl[0]);
        } else if (hr.length > 0) {
          // insert to the right, to the right... (clap, clap, clap)
          if (hr[0].classList.contains("row-with-one-img")) {
            hr[0].classList.add("data-photoset-a");
            bd[0].classList.add("data-photoset-b");
            // 123...
            bd[0].classList.remove("data-photoset-c");
            bd[0].classList.remove("data-photoset-a");
            hr[0].classList.remove("data-photoset-b");
            hr[0].classList.remove("data-photoset-c");
            // abc...
            hr[0].classList.remove("row-with-one-img");
            hr[0].classList.add("row-with-two-img");
            bd[0].classList.remove("row-with-one-img");
            bd[0].classList.add("row-with-two-img");
            bd[0].classList.remove("row-with-three-img");
          } else if (hr[0].classList.contains("row-with-two-img")) {
            // right of an "a" goes to the in-between
            if (hr[0].classList.contains("data-photoset-a")) {
              hr[0].classList.add("data-photoset-a");
              bd[0].classList.add("data-photoset-b");
              hr[0].nextSibling.classList.add("data-photoset-c");
              // 123...
              hr[0].nextSibling.classList.remove("data-photoset-b");
              hr[0].nextSibling.classList.remove("data-photoset-a");
              bd[0].classList.remove("data-photoset-c");
              bd[0].classList.remove("data-photoset-a");
              hr[0].classList.remove("data-photoset-b");
              hr[0].classList.remove("data-photoset-c");
              // abc...
              hr[0].classList.remove("row-with-two-img");
              hr[0].classList.add("row-with-three-img");
              hr[0].nextSibling.classList.remove("row-with-two-img");
              hr[0].nextSibling.classList.add("row-with-three-img");
              // right of a "b" goes to the right
            } else if (hr[0].classList.contains("data-photoset-b")) {
              hr[0].previousSibling.classList.add("data-photoset-a");
              hr[0].classList.add("data-photoset-b");
              bd[0].classList.add("data-photoset-c");
              // 123...
              hr[0].previousSibling.classList.remove("data-photoset-b");
              hr[0].previousSibling.classList.remove("data-photoset-c");
              bd[0].classList.remove("data-photoset-a");
              bd[0].classList.remove("data-photoset-b");
              hr[0].classList.remove("data-photoset-a");
              hr[0].classList.remove("data-photoset-c");
              // abc...
              hr[0].classList.remove("row-with-two-img");
              hr[0].classList.add("row-with-three-img");
              hr[0].previousSibling.classList.remove("row-with-two-img");
              hr[0].previousSibling.classList.add("row-with-three-img");
            }
            bd[0].classList.remove("row-with-one-img");
            bd[0].classList.remove("row-with-two-img");
            bd[0].classList.add("row-with-three-img");
          }
          // regardless, it's to the right...
          hr[0].parentNode.insertBefore(bd[0], hr[0].nextSibling);
        }
      }
      if (
        !bd[0].classList.contains("row-with-one-img") &&
        !bd[0].classList.contains("row-with-two-img") &&
        !bd[0].classList.contains("row-with-three-img")
      ){
        bd[0].classList.add("row-with-one-img")
      }
      // END: thanks for bearing with me.
      pre = document.getElementsByClassName("pre-photoset");
      hu = document.getElementsByClassName("hl-up");
      hd = document.getElementsByClassName("hl-down");
      hl = document.getElementsByClassName("hl-left");
      hr = document.getElementsByClassName("hl-right");
      hlb = document.getElementsByClassName("hl-bottom");
      hlt = document.getElementsByClassName("hl-top");
      while (hlt.length > 0) {
        hlt[0].classList.remove("hl-top");
      }
      while (hlb.length > 0) {
        hlb[0].classList.remove("hl-bottom");
      }
      while (pre.length > 0) {
        pre[0].classList.remove("pre-photoset");
      }
      while (bd.length > 0) {
        bd[0].style.left = "0px";
        bd[0].style.top = "0px";
        bd[0].style.removeProperty("margin-bottom");
        bd[0].classList.remove("brick-dragging");
      }
      while (hu.length > 0) {
        hu[0].classList.remove("hl-up");
      }
      while (hd.length > 0) {
        hd[0].classList.remove("hl-down");
      }
      while (hl.length > 0) {
        hl[0].classList.remove("hl-left");
      }
      while (hr.length > 0) {
        hr[0].classList.remove("hl-right");
      }
      // observers should rebuildPhotoColumn
      setTimeout(rebuildPhotoColumn, 800);
      // but here goes one more time just in case :P
      // I thinks my pretty transition is delaying
      // the top/left/height... or something IDK...
    }
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var selectionBox = document.getElementById(
      "mass_post_features-plugin_selection_box"
    );
    if (data.classList.contains("mousedown")) {
      data.classList.remove("mousedown");
    }
    if (data.classList.contains("shift_key")) {
      data.classList.remove("shift_key");
    }
    if (selectionBox !== null) {
      selectionBox.parentNode.removeChild(selectionBox);
    }
    var ts = document.getElementsByClassName("temp-select");
    while (ts.length > 0) {
      ts[0].classList.remove("temp-select");
    }
  });
  var blueUp = 0;
  // resize the selection box and stuff :)
  window.addEventListener("mousemove", function (e) {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    var i;
    if (
      document.getElementsByClassName(
        "brick-dragging"
      ).length === 1
    ) {
      var bdrg = document.getElementsByClassName(
        "brick-dragging"
      )[0]; // being dragged
      var brk = document.getElementsByClassName(
        "photo-brick"
      );
      var img = document.getElementsByClassName(
        "photo-brick-img-cell"
      );
      var bmx = parseFloat(bdrg.getAttribute("mouse-x-from-left"));
      var bmy = parseFloat(bdrg.getAttribute("mouse-y-from-top"));
      var pre = document.getElementsByClassName("pre-photoset");
      var st = document.documentElement.scrollTop;
      var bx = e.clientX + bmx;
      var by = e.clientY + bmy + st;
      bdrg.style.left = bx + "px";
      bdrg.style.top = by + "px";
      var t;
      var b;
      var l;
      var pbi;
      var pr;
      var hlb = document.getElementsByClassName("hl-bottom");
      var hlt = document.getElementsByClassName("hl-top");
      if (
        !data.classList.contains("blueup-drag-scroll") &&
        e.clientY < 90 &&
        typeof bdrg !== "undefined"
      ) {
        data.classList.add("blueup-drag-scroll");
        clearInterval(blueUp);
        blueUp = setInterval(function () {
          var doc = document.documentElement;
          window.scrollTo(doc.scrollLeft, doc.scrollTop - 10);
        }, 10);
      } else if (
        !data.classList.contains("blueup-drag-scroll") &&
        e.clientY > window.innerHeight - 90 &&
        typeof bdrg !== "undefined"
      ) {
        data.classList.add("blueup-drag-scroll");
        clearInterval(blueUp);
        blueUp = setInterval(function () {
          var doc = document.documentElement;
          window.scrollTo(doc.scrollLeft, doc.scrollTop + 10);
        }, 10);
      } else {
        data.classList.remove("blueup-drag-scroll");
        clearInterval(blueUp);
      }
      if (bdrg.classList.contains("photo-brick")) {
        for (i = 0; i < brk.length; i++) {
          b = brk[i].getBoundingClientRect();
          t = b.top + st; // dragging photo-brick over <this
          if (
            (by > t && by < t + b.height) ||
            (i === 0 && by < t) ||
            (i === brk.length -1 && by > t)
          ) {
            if (
              (by + b.height / 2 > t) ||
              (i === brk.length -1 && by > t)
            ) { // highlight bottom
              brk[i].classList.add("hl-bottom");
              brk[i].classList.remove("hl-top");
            } else if (
              (by - b.height / 2 < t) ||
              (i === 0 && by < t)
            ) { // highlight top
              brk[i].classList.add("hl-top");
              brk[i].classList.remove("hl-bottom");
            }
          } else {
            brk[i].classList.remove("hl-bottom");
            brk[i].classList.remove("hl-top");
          }
        }
      }else if (bdrg.classList.contains("photo-brick-img")) {
        while (hlb.length > 0) {
          hlb[0].classList.remove("hl-bottom");
        }
        while (hlt.length > 0) {
          hlt[0].classList.remove("hl-top");
        }
        // this part withdraws the dragged image bdrg from current row
        if (// this may seem repetative...
          bdrg.classList.contains("row-with-two-img") &&
          bdrg.classList.contains("data-photoset-a") &&
          bdrg.nextSibling.classList.contains("data-photoset-b")
        ) {
          bdrg.style.removeProperty("height");
          bdrg.nextSibling.style.removeProperty("height");
          // 2
          bdrg.classList.remove("row-with-two-img");
          bdrg.nextSibling.classList.remove("row-with-two-img");
          // 1
          bdrg.nextSibling.classList.add("row-with-one-img");
          // and shift pop around
          bdrg.nextSibling.classList.remove("data-photoset-b");
          // remove remnant
          bdrg.classList.remove("data-photoset-a");
        } else if (
          bdrg.classList.contains("row-with-two-img") &&
          bdrg.classList.contains("data-photoset-b") &&
          bdrg.previousSibling.classList.contains("data-photoset-a")
        ) {
          bdrg.style.removeProperty("height");
          bdrg.previousSibling.style.removeProperty("height");
          // 2
          bdrg.classList.remove("row-with-two-img");
          bdrg.previousSibling.classList.remove("row-with-two-img");
          // 1
          bdrg.previousSibling.classList.add("row-with-one-img");
          // and shift pop around
          bdrg.previousSibling.classList.remove("data-photoset-a");
          // remove remnant
          bdrg.classList.remove("data-photoset-b");
        } else if (
          bdrg.classList.contains("row-with-three-img") &&
          bdrg.classList.contains("data-photoset-a") &&
          bdrg.nextSibling.classList.contains("data-photoset-b")
        ) {
          bdrg.style.removeProperty("height");
          bdrg.nextSibling.style.removeProperty("height");
          bdrg.nextSibling.nextSibling.
          style.removeProperty("height");
          // 3
          bdrg.classList.remove("row-with-three-img");
          bdrg.nextSibling.classList.remove("row-with-three-img");
          bdrg.nextSibling.nextSibling.
          classList.remove("row-with-three-img");
          // 2
          bdrg.nextSibling.classList.add("row-with-two-img");
          bdrg.nextSibling.nextSibling.
          classList.add("row-with-two-img");
          // and shift pop around
          bdrg.nextSibling.classList.add("data-photoset-a");
          bdrg.nextSibling.classList.remove("data-photoset-b");
          bdrg.nextSibling.nextSibling.
          classList.add("data-photoset-b");
          bdrg.nextSibling.nextSibling.
          classList.remove("data-photoset-c");
          // remove remnant
          bdrg.classList.remove("data-photoset-a");
        } else if (
          bdrg.classList.contains("row-with-three-img") &&
          bdrg.classList.contains("data-photoset-b") &&
          bdrg.nextSibling.classList.contains("data-photoset-c")
        ) {
          bdrg.style.removeProperty("height");
          bdrg.nextSibling.style.removeProperty("height");
          bdrg.previousSibling.style.removeProperty("height");
          // 3
          bdrg.classList.remove("row-with-three-img");
          bdrg.nextSibling.classList.remove("row-with-three-img");
          bdrg.previousSibling.classList.remove("row-with-three-img");
          // 2
          bdrg.nextSibling.classList.add("row-with-two-img");
          bdrg.previousSibling.classList.add("row-with-two-img");
          // and shift pop around
          bdrg.nextSibling.classList.add("data-photoset-b");
          bdrg.nextSibling.classList.remove("data-photoset-c");
          // this is a rare chance flip around
          bdrg.parentNode.insertBefore(bdrg.nextSibling, bdrg);
          // remove remnant
          bdrg.classList.remove("data-photoset-b");
        } else if (
          bdrg.classList.contains("row-with-three-img") &&
          bdrg.classList.contains("data-photoset-c") &&
          bdrg.previousSibling.classList.contains("row-with-three-img")
        ) {
          bdrg.style.removeProperty("height");
          bdrg.previousSibling.style.removeProperty("height");
          bdrg.previousSibling.previousSibling
            .style.removeProperty("height");
          // 3
          bdrg.classList.remove("row-with-three-img");
          bdrg.previousSibling.classList.remove("row-with-three-img");
          bdrg.previousSibling.previousSibling.
          classList.remove("row-with-three-img");
          // 2
          bdrg.previousSibling.classList.add("row-with-two-img");
          bdrg.previousSibling.previousSibling.
          classList.add("row-with-two-img");
          // and shift pop around
          // b stays b, a stays a
          // remove remnant
          bdrg.classList.remove("data-photoset-c");
        } // last one ^
        bdrg.classList.remove("hl-up");
        bdrg.classList.remove("hl-down");
        bdrg.classList.remove("hl-left");
        bdrg.classList.remove("hl-right");
        rebuildPhotoColumn();
        for (i = 0; i < brk.length; i++) { // dragging image
          b = brk[i].getBoundingClientRect();
          if (
            e.clientX > b.left &&
            e.clientX < b.left + 137 &&
            e.clientY > b.top &&
            e.clientY < b.bottom
          ) {
            brk[i].classList.add("pre-photoset");
            pbi = brk[i].getElementsByClassName("photo-brick-img");
            for (l = 0; l < pbi.length; l++) {
              if (typeof pbi[l] === "undefined" || pbi[l] === bdrg) {
                continue;
              }
              if (
                pbi.length >= 10 &&
                brk[i].getElementsByClassName(
                  "brick-dragging"
                ).length === 0
              ) {
                break;
              }
              pr = pbi[l].getBoundingClientRect();
              if (
                e.clientX > pr.left &&
                e.clientX < pr.right &&
                e.clientY > pr.top &&
                e.clientY < pr.bottom &&
                brk[i].classList.contains("pre-photoset")
              ) { // I should use dragover, but this is (sophisticated :p)
                if (e.clientY < pr.top + pr.height / 3) {
                  pbi[l].classList.add("hl-up");
                  // sliding to the above
                  pbi[l].classList.remove("hl-down");
                  pbi[l].classList.remove("hl-left");
                  pbi[l].classList.remove("hl-right");
                  // sliding to the under
                } else if (e.clientY > pr.top + pr.height * 0.75) {
                  pbi[l].classList.add("hl-down");
                  pbi[l].classList.remove("hl-up");
                  pbi[l].classList.remove("hl-left");
                  pbi[l].classList.remove("hl-right");
                  // sliding to the right
                } else if (e.clientX > pr.left + pr.width / 2) {
                  if (!pbi[l].classList.contains("row-with-three-img")) {
                    pbi[l].classList.remove("hl-up");
                    pbi[l].classList.remove("hl-down");
                    pbi[l].classList.remove("hl-left");
                    pbi[l].classList.add("hl-right");
                  }
                  // sliding to the left
                } else if (e.clientX < pr.left + pr.width / 2) {
                  if (!pbi[l].classList.contains("row-with-three-img")) {
                    pbi[l].classList.remove("hl-up");
                    pbi[l].classList.remove("hl-down");
                    pbi[l].classList.add("hl-left");
                    pbi[l].classList.remove("hl-right");
                  }
                }
              } else {
                pbi[l].classList.remove("hl-up");
                pbi[l].classList.remove("hl-down");
                pbi[l].classList.remove("hl-left");
                pbi[l].classList.remove("hl-right");
              }
            }
          } else { // dragging out of a photoset into new row
            brk[i].classList.remove("pre-photoset");
            if (
              e.clientX > b.left + 177 &&
              e.clientX < b.left + b.width &&
              e.clientY > b.top &&
              e.clientY < b.bottom
            ) {
              if (
                (e.clientY + b.height / 2 > b.top) ||
                (i === brk.length -1 && e.clientY > b.bottom)
              ) { // highlight bottom
                brk[i].classList.add("hl-bottom");
                brk[i].classList.remove("hl-top");
              } else if (
                (e.clientY - b.height / 2 < b.top) ||
                (i === 0 && e.clientY < b.top)
              ) { // highlight top
                brk[i].classList.add("hl-top");
                brk[i].classList.remove("hl-bottom");
              }
            } else {
              brk[i].classList.remove("hl-bottom");
              brk[i].classList.remove("hl-top");
            }
          }
        }
      }
    }
    if (
      document.getElementsByClassName(
        "widget-dragging"
      ).length === 1
    ) {
      var drg = document.getElementsByClassName(
        "widget-dragging"
      )[0];
      // grabbing and dragging step #2
      var mx = parseFloat(drg.getAttribute("mouse-x-from-left"));
      var my = parseFloat(drg.getAttribute("mouse-y-from-top"));
      if (document.getElementById("reblog_widget") !== null) {
        document.getElementById(
          "reblog_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "reblog_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("select-by_widget") !== null) {
        document.getElementById(
          "select-by_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "select-by_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("remove_tags_widget") !== null) {
        document.getElementById(
          "remove_tags_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "remove_tags_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("add_tags_widget") !== null) {
        document.getElementById(
          "add_tags_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "add_tags_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("add-caption_widget") !== null) {
        document.getElementById(
          "add-caption_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "add-caption_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("backdate_widget") !== null) {
        document.getElementById(
          "backdate_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "backdate_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("urlstuff_widget") !== null) {
        document.getElementById(
          "urlstuff_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "urlstuff_widget"
        ).style.top = (e.clientY + my) + "px";
      }
      if (document.getElementById("snapshot-info_widget") !== null) {
        document.getElementById(
          "snapshot-info_widget"
        ).style.left = (e.clientX + mx) + "px";
        document.getElementById(
          "snapshot-info_widget"
        ).style.top = (e.clientY + my) + "px";
      }
    }
    var targ = e.target;
    var cont = targ;
    var initialMouseX = parseFloat(
      data.getAttribute("data-initial_mouse_x")
    );
    var initialMouseY = parseFloat(
      data.getAttribute("data-initial_mouse_y")
    );
    var newMouseX = e.pageX;
    var newMouseY = e.pageY;
    var mouseWidth = Math.abs(initialMouseX - newMouseX);
    var mouseHeight = Math.abs(initialMouseY - newMouseY);
    var mouseDiff = Math.hypot(mouseWidth, mouseHeight);
    var selectionBox = document.getElementById(
      "mass_post_features-plugin_selection_box"
    );
    if (
      mouseDiff > 6 &&
      data.classList.contains("mousedown") &&
      selectionBox === null
    ) {
      var pluginSelectionBox = document.createElement("div");
      pluginSelectionBox.id = "mass_post_features-" +
                              "plugin_selection_box";
      document.body.appendChild(pluginSelectionBox);
      selectionBox = document.getElementById(
        "mass_post_features-plugin_selection_box"
      );
      if (!data.classList.contains("shift_key")) {
        var hl = document.getElementsByClassName("highlighted");
        while (hl.length > 0) {
          highlightBrick(hl[0], 0);
        }
      }
    }
    if (
      mouseDiff > 6 &&
      data.classList.contains("mousedown") &&
      selectionBox !== null
    ) {
      var selLeft;
      var selTop;
      if (initialMouseX < newMouseX) {
        selectionBox.style.left = initialMouseX + "px";
        selLeft = initialMouseX;
      }
      if (initialMouseY < newMouseY) {
        selectionBox.style.top = initialMouseY + "px";
        selTop = initialMouseY;
      }
      if (initialMouseX > newMouseX) {
        selectionBox.style.left = (initialMouseX - mouseWidth) + "px";
        selLeft = initialMouseX - mouseWidth;
      }
      if (initialMouseY > newMouseY) {
        selectionBox.style.top = (initialMouseY - mouseHeight) + "px";
        selTop = initialMouseY - mouseHeight;
      }
      selectionBox.style.width = mouseWidth + "px";
      selectionBox.style.height = mouseHeight + "px";
      var brick = document.getElementsByClassName("brick");
      var rec;
      var sT = document.documentElement.scrollTop;
      var sL = document.documentElement.scrollLeft; // 0
      for (i = 0; i < brick.length; i++) {
        rec = brick[i].getBoundingClientRect();
         if (
           !brick[i].classList.contains("highlighted") &&
           !brick[i].classList.contains("temp-select") &&
           rec.right + sL > selLeft &&
           rec.left + sL < selLeft + mouseWidth &&
           rec.bottom + sT > selTop &&
           rec.top + sT < selTop + mouseHeight
         ) {
           brick[i].classList.add("temp-select");
           highlightBrick(brick[i], 1);
         } else if (
           brick[i].classList.contains("temp-select") &&
           brick[i].classList.contains("highlighted") &&
           (
             (
               rec.right + sL < selLeft ||
               rec.left + sL > selLeft + mouseWidth
             ) || (
               rec.bottom + sT < selTop ||
               rec.top + sT > selTop + mouseHeight
             )
           )
         ) {
           brick[i].classList.remove("temp-select");
           highlightBrick(brick[i], 0);
         }
      }
    }
  });
  // end of selection box feature

  // begin blogs menu / blog menu dropdown
  var loderGifSrc =
        '' +
        'QEBDo6OhYWFg4ODi4uLoCAgAgICBgYGAICAmxsbH' +
        'h4eBwcHF5eXsDAwLS0tJKSkvLy8v///xISEhAQEE' +
        'ZGRqioqGRkZFBQUCIiIiYmJjY2Np6enk5OTuDg4D' +
        'AwMNLS0lZWVoKCgqCgoLKysgAAAAAAAAAAAAAAAA' +
        'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA' +
        'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA' +
        'AAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAA' +
        'Ah/hlPcHRpbWl6ZWQgdXNpbmcgZXpnaWYuY29tAC' +
        'H5BAUKABkALAAAAAAgACAAAAbkwIxwSCQOIJBFcc' +
        'k0GoiBSCRQBDSZl8YGKqUOB4fnFdpoUIbR6Tc8GB' +
        'crZXHamwEf3EVCOSGcCwFseEUhcRl+dWFuBARVZQ' +
        '+GXYiJTl8FlkpDDGUYAwEBdpN/EoF1FpYFDG2ljF' +
        'UTCKJsqmgKp5+CoKNMABSnIHi4bgMMBZhjCKS/gn' +
        'VNgLhgyojNzZ7U1ALK07EH1dV3t9rgztjS0szY0A' +
        'ahV82/o+rMsfDa7fNO8aJL7JLI+/bkx+rSBUznrx' +
        '+oVsEClZMEDZaYhQKtoAu1kOE4isgqJpxQcI3Ehh' +
        '4/glz37koQACH5BAkKABIALAAAAAAZABgAAAaVQI' +
        'lwSCQaHA5BcWkEEAmNBqEYYEo0BcszOh2KIg8moV' +
        'DoXrnDQARsTZCdZ+nwsx5YF2SKECqXMNYFVkIgb3' +
        'FTAxARHU1FA3mGEgVrVUIGAZd2aW+WBAYLaw1GHp' +
        'eYlSALS1CojaQBCwiCsQgYrbG2AASutrsGu00AwM' +
        'GwvpUHxsfGxMXIx8oSCMLCztPU1dbX2NfDgkEAIf' +
        'kECQoAFgAsAAAAAB8AGAAABr9Ai3BIJAIUikFxyR' +
        'waEMZCYVEkNJeHgCc6JSoaiatRK3BKqUJCAywmas' +
        'jp83CzNrSdcMtCbqGsGXducHtdBg5rYgAARQBaVo' +
        'RUDGtWXmEWCAeZi3gBTwufAmsPbh0REZQTmgNQlx' +
        'lKVRtleg2mEQ1GqnZ3AyK1HYBYqncjtV1NmJl3BB' +
        'EiaG2sykyYitSKgUKbuKqa19aM29yB3rjV1N3Zz9' +
        '3n6MfJiRLh7wdXyMLPq+32rcGs7Hju2HI9qXclCA' +
        'Ah+QQJCgAZACwAAAAAIAAYAAAGvcCMcEgkIgIBQH' +
        'HJNBYHyMGzyTQcJsYokVOgUJ9XpRCaHC4K3S/4YN' +
        'YKLWixehweuwnowHyNyJClAApoagBydFd+WgFxRR' +
        'cXQwhhhlaSA5FoDFsVDQ0YZpWQhmMWUn4PnA0PfI' +
        'hzBgqoFV5VknMhqAwGX5GsXxgNCgJ7fsKes4XHhc' +
        'RIy1FhzrxqARHT1NPPtHvS1dSRyMfKzG5LfXvk5d' +
        'BN34QSdevt45bYuvHvh+8Ton749tDy+pW7+rULAg' +
        'Ah+QQJCgAUACwAAAAAIAAZAAAGwECKcEgsHo7FpJ' +
        'KIMB4BxqXSgBwCnsRMACN1VinX72Cb6XqtWKGHbG' +
        'amw1Awu+1GwuVb89U7AGMXc0MaGmhpQlR2UACBFB' +
        'kJBQUChYYDcUwecQIMkAUMfF9di5wJBEuIoEsgnA' +
        'GWU5Wtpp19dE20ple4uHR4BL2+T8CoUgQNxcbFwc' +
        'C7xMfGCLm5y7+/psu7frBKARGRehKGUh8R456uwW' +
        '0LDeMRHwGflhPZuo0d6w91BvjPVM+gBRDjru0a0E' +
        'lIEAAh+QQJCgAWACwAAAAAIAAeAAAG2ECLcEgsHo' +
        '7FpJKIMB4BxqXSgBwCnsyq1IoVXrXfwdZ54IK1Y2' +
        '83rEanLQMsG+5OXsliNtV97rabdwh+cBoBAQZmfn' +
        'F2E02EhoZ4dVMZkBoCS3uTRpALjplxUGMGhqJpn6' +
        'OgV6t3b2ELsLFPs6ajBbe4t7O7b3C5uYKsq71xsr' +
        'GZxL10tUsEDQyIW69pGw3WFKqzpw/WDRsEkqaNSQ' +
        'EfC0LO3QlZaJrBghERIkQMDtZZqO/LUCLxAUwMLi' +
        'izAyHCh4FvCsRjgDBNh3hiGkoJsFDilgYROCgJAg' +
        'Ah+QQJCgAYACwAAAAAIAAgAAAF4CAmjmR5nGWqko' +
        'h5AuaqGugIvGwt27h467/BznXgAXVDXy+oRCYxAx' +
        'wT6kzdiEImzUkzSmBeKhUZbDV7YpcZEUWfq6u2Oz' +
        'efvQxDNhz7hPbNVjeCgn9ybUEvdXEBjI2MiZB/jo' +
        '56g1dPZYdxf31jSQsFAWAyiEkWBagEcYaApAyoBR' +
        'YLWF88KQQbAj4JsBR0eF6gBQsCDQ0KJAEKqDmtlR' +
        'gBEREBGArGqjaMeTjR01AODRudZyLd1BgM1+NfRe' +
        'XS5xgVxsCfaOYjBMYXhRPJ7yQPGsAb584bwR0DIE' +
        'CY9SQEACH5BAkKABQALAAAAAAgACAAAAXmICWOZH' +
        'mcZaqSiHkC5qoa6Ai8bC3buHjrv8HOdeABdUNfL6' +
        'hEJikDHBPqTN2IQibNSTNKYF4qFRlsNXtilxkRRZ' +
        '+rq7Y7N5+9DEM2HPuE9s1WN4KCfVSDZS91cYmMjX' +
        'uBjnqHgHmTVzN/hVtJAwELlHaKJgGkAouMnASkpV' +
        'hfPh8BVhZCUBqrGHR4Iw8REQQCDAwCAwUFHCQLqz' +
        'mUC70NFAQNDQQUHMULdEMNvdjR01AKxoUiAb0F5N' +
        'LU0NfjHdzo3yIJxWBJDL0MI97q6+JPHBE+IEtHgk' +
        'GBDONMEEy4w4ADB6aehAAAIfkECQoAFgAsAAAAAC' +
        'AAIAAABeCgJY5keZxlqpKIeQLmqhroCLxsLdu4eO' +
        'u/wc514AF1Q18vqEQmLQMcE+pM3YhCJs1JM0pgXi' +
        'oVGWw1e2KXGRFFn6urtjs3n70MQzYc+4T2zVY3go' +
        'J9VINlL3VxiYyNe4GOeoeAeZNXM39/BRABSYRDDB' +
        '0RER2eiSsEDaMRDQSmjCUPqx0cPhuuRG94I6sFQi' +
        'IJDa0DAQFtxXRFIwkPCyzCD1AFvlDFvzxDD8IC0t' +
        'QIxR6FIqkNDLbU1cbiFdvnzuPWfRTCFDbT7+nKSQ' +
        'ENGyQL9/6pE/cvIMEdABQouDYkBAAh+QQJCgAaAC' +
        'wAAAAAIAAgAAAF2aAmjmR5nGWqkoh5AuaqGugIvG' +
        'wt27h467/BznXgAXVDXy+oRCY1AxwT6kzdiEImzU' +
        'kzSmBeKhUZbDV7YpcZEUWfq6u2OzefvQxDNhz7hP' +
        'bNVgGCgwELfVQ3iRoQEY2OEQx/L5MHjI+NkU9BlA' +
        'uEg4aaiaKAMZp/DA4ESYpDFBUNsKuTcQ+wDQ8Ysp' +
        'QlCbYVAT4WoHRveCO2DMYaFAUFAmVuW0UjFwkCLM' +
        '2RA4JZc107DM1Z3E2HPs3AUORjYH0J4j7rY4cE6D' +
        'byU0kZBRYs8vPm/BUKmOffjhAAIfkECQoAFQAsAA' +
        'AAACAAIAAABujAinBILB6OxaSSiDAeAcal0oAcAp' +
        '7MqtSKFV6138HWeeCCtWNvN6xGpysDLBvuTjIYZD' +
        'Gb6qYOCRERHQFZSFd0aGFNcB+BESMLXEkIE4uUT2' +
        'JEDBCOBZljcZhTD44jaaF1Rg0RhKBdaQRvcEsCBL' +
        'a3trJ0V7wVDg3AwQ0UsmGYB7/CwMRvxse4uMW804' +
        'uTxcUBCpGuBrAJBeCnolMM4AUMAuLHRRTmCRltk5' +
        'VtrxXmAVBCGAH4l/6fiMr8oQAQAL9Ye+rRGRNtjs' +
        'JTB+lJ1KWBn6VXElLRijgxIDYPhfLF05WHZDONSY' +
        'IAACH5BAUKABYALAAAAAAgACAAAAbuQItwSCwejs' +
        'WkkkgYEAFHgHGpTEQ+z2jWQC0yIhHGEIoUkp1dYg' +
        'eMPo/L6WEA/DBrLe44scHG3+9UFBRGYA1+SAaAdn' +
        'INjQREBWCPUIdodn8bjQ0hAmYjAUkIEwiXihYUDp' +
        'oMXHEDURJSoQmaIa2vaQIPDY+4plQYenhLrgvFxp' +
        'a2UMoWCgXOzwW8ya9HzdDO0r3U28fIXaLK4cPBpH' +
        'qiAd5Ky7gaAe7TsaEE7u6s38SmGPQaE2+ho6XgnK' +
        'pXrhI4cAITJcQQr5JDfEbsDdOSx5c2VhUt/oKT51' +
        'Awh6XeCLzXT2RDYh//jUw5sWCaIAA7';
  var navArchive = document.getElementById("nav_archive");
  var blogMenu = document.createElement("div");
  blogMenu.id = "blog_menu";
  var blogMenuLink = navArchive.
    getElementsByClassName("title")[0].
    getElementsByTagName("a")[0];
  blogMenuLink.innerHTML = "Blogs";
  blogMenuLink.insertBefore(blogMenu, blogMenuLink.firstChild);
  var arrow = document.createElement("div");
  arrow.classList.add("arrow");
  blogMenuLink.removeAttribute("href");
  blogMenuLink.insertBefore(arrow, blogMenuLink.firstChild);
  // this makes a batch reblog button
  var reblogMenuButton = function (name) {
    var button = document.createElement("button");
    button.setAttribute(
	  "title", "Batch reblog selected posts to \"" + name + "\""
	);
    var svg = svgForType["reblog-self"].cloneNode(true);
    svg.setAttribute("width","11");
    svg.setAttribute("height","11");
    svg.setAttribute("fill","#fff");
    button.appendChild(svg);
    button.appendChild(
      document.createTextNode(
        " BATCH REBLOG SELECTED"
      )
    );
    button.setAttribute("data-edit_action", "reblog");
    button.setAttribute("data-name", name);
    button.addEventListener(
      "click",
      function() {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        data.setAttribute(
          "data-reblog-to-here", this.getAttribute("data-name")
        );
        var rb = document.getElementsByClassName("reblog-to-here");
        while (rb.length > 0) {
          rb[0].classList.remove("reblog-to-here");
        }
        document.getElementById(
          "reblog-to_" + this.getAttribute("data-name")
        ).classList.add("reblog-to-here");
        data.setAttribute(
          "data-reblog-to-here", this.getAttribute("data-name")
        );
        fetchEditSubmitMulti.apply(this, arguments);
      }
    );
    return button;
  }
  // this loads the secondaries for menu and data
  if (
    document.getElementById("bm_load_img") === null &&
    data.classList.contains("blog-menu-preload")
  ) {
    data.classList.remove("blog-menu-preload");
    // first time open, fetch the blogs, if any
    var xhttp = new XMLHttpRequest();
    var preLoad = new Image();
    preLoad.src = loderGifSrc;
    preLoad.style.width = "32px;"
    preLoad.style.height = "32px";
    preLoad.id = "bm_load_img";
    document.getElementById("blog_menu").appendChild(preLoad);
    xhttp.onreadystatechange = function () {
      if (this.readyState == 4 && this.status == 200) {
        var data = document.getElementById(
          "mass_post_features-plugin_data"
        );
        var div = document.createElement("div");
        div.innerHTML = this.responseText. // parse the dom
        replace(/<(\/?)script[^>]*>/g, "<$1flurb>"). // no eval
        replace(/<img/g,"<space"); // do not onload img tags
        var apiKey = div.querySelectorAll(
          "meta[name=tumblr-form-key]"
        )[0].getAttribute("content");
        data.setAttribute("data-x-tumblr-form-key", apiKey);
        var l = div.getElementsByClassName("l-container")[0];
        var li = l.getElementsByClassName("is_tumblelog");
        var tumblelogs = [];
        var st;
        var a;
        var av;
        var ho;
        var tray;
        var subt;
        var name1;
        var link0;
        var link1;
        var link2;
        var link3;
        var link4;
        var edIcon;
        var visIcon;
        var reIcon;
        var primIcon;
        var frIcon;
        var phIcon;
        var href = document.location.href.split(/[\/\?&#=]+/g);
        var name = href[4];
        var reAsDraftContainer = document.createElement("div");
        reAsDraftContainer.classList.add("blog_menu_child");
        var reAsDraft = document.createElement("input");
        reAsDraft.type = "checkbox";
        reAsDraft.id = "re-as-draft";
        reAsDraft.checked = true;
        reAsDraftContainer.appendChild(reAsDraft);
        var reAsDraftLabel = document.createElement("label");
        reAsDraftLabel.setAttribute("for", "re-as-draft");
        reAsDraftLabel.appendChild(
          document.createTextNode("Reblog Posts as Draft")
        );
        var navFollows1;
        var robotWarning = document.createElement("div");
        var robotTitle = document.createElement("strong");
        robotTitle.appendChild(
          document.createTextNode(
            "Friendly Robot Warning"
          )
        );
        robotWarning.classList.add("robot-warning");
        robotWarning.appendChild(robotTitle);
        robotWarning.appendChild(
          document.createTextNode(
            "Dash flooding might make you lose followers!"
          )
        );
        reAsDraftContainer.appendChild(reAsDraftLabel);
        reAsDraftContainer.appendChild(robotWarning);
        document.getElementById("blog_menu").appendChild(reAsDraftContainer);
        for (var i = 0; i < li.length; i++) {
          a = li[i].getElementsByTagName("a")[0];
          av = a.getElementsByClassName("avatar")[0];
          av.removeAttribute("style");
          av.innerHTML = av.innerHTML.replace(/<space/g,"<img");
          st = a.getElementsByClassName("small_text")[0];
          ho = a.getElementsByClassName("hide_overflow")[0];
          tray = document.createElement("div");
          tray.classList.add("blog_menu_child");
          name1 = ho.innerHTML.replace(/\s+/g, "");
          tray.setAttribute("data-name", name1);
          tumblelogs.push(name1);
          if (i === 0) { // assuming primary is first blog :)
            data.setAttribute("data-primary-blog", name1);
            navFollows1 = document.getElementById("nav-follows");
            navFollows1.setAttribute(
              "href", "/mega-editor/published/" + name1 + "?follows"
            );
            data.setAttribute("data-primary-known", "true");
            // this is the follows and followers
            if (
              href[3] === "published" &&
              (
                href[5] === "follows" ||
                href[5] === "followers"
              )
            ) {
              loadFollowers();
            }
            var navLikes = document.getElementById("nav-likes");
            navLikes.setAttribute(
              "data-default-input", getCookie("name1") !== "" ? getCookie("name1") : name1
            );
            primIcon = svgForType.original.cloneNode(true);
            primIcon.setAttribute("width", 20);
            primIcon.setAttribute("height", 20);
            primIcon.setAttribute("title", "Primary Blog");
            primIcon.setAttribute("fill", "rgba(0,65,100,1)");
            st.insertBefore(primIcon, st.firstChild);
          }
          reIcon = svgForType["reblog-self"].cloneNode(true);
          reIcon.setAttribute("width", "26");
          reIcon.setAttribute("height", "26");
          reIcon.setAttribute("fill", "#7D99FF");
          av.appendChild(reIcon);
          av.setAttribute("title", "Select Avatar for Quick-Reblogs");
          av.setAttribute("data-name", name1);
          av.id = "reblog-to_" + name1;
          av.addEventListener("click", function() {
            var data = document.getElementById(
              "mass_post_features-plugin_data"
            );
            var rb = document.getElementsByClassName("reblog-to-here");
            while (rb.length > 0) {
              rb[0].classList.remove("reblog-to-here");
            }
            this.classList.add("reblog-to-here");
            data.setAttribute(
              "data-reblog-to-here", this.getAttribute("data-name")
            );
          });
          if (name.toLowerCase() === name1.toLowerCase()) {
            av.classList.add("reblog-to-here");
            data.setAttribute("data-reblog-to-here", name);
          }
          tray.appendChild(av);
          tray.appendChild(st);
          link0 = document.createElement("a");
          link1 = document.createElement("a");
          link2 = document.createElement("a");
          link3 = document.createElement("a");
          link4 = document.createElement("a");
          subt = document.createElement("div");
          link0.setAttribute(
            "title", "edit \"" + name1 + "\" drafts"
          );
          link0.setAttribute(
            "href", "https://www.tumblr.com/mega-editor/draft/" + name1
          );
          link1.setAttribute(
            "title", "visit \"" + name1 + "\""
          );
          link1.setAttribute(
            "href", "https://www.tumblr.com/blog/" + name1
          );
          link1.setAttribute(
            "target", "_blank"
          );
          link3.setAttribute(
            "title", "batch photo upload to \"" + name1 + "\""
          );
          link4.setAttribute(
            "title", "\"" + name1 + "\" followers"
          );
          link2.setAttribute(
            "href",
            "https://www.tumblr.com/mega-editor/published/" + name1
          );
          link3.setAttribute(
            "href",
            "https://www.tumblr.com/mega-editor/publish/" + name1 + "?photos"
          );
          link4.setAttribute(
            "href",
            "https://www.tumblr.com/mega-editor/published/" + name1 + "?followers"
          );
          link0.appendChild(
            document.createTextNode(
              "Drafts"
            )
          );
          link1.appendChild(
            document.createTextNode(
              "Visit"
            )
          );
          link2.appendChild(
            document.createTextNode(
              "Editor"
            )
          );
          link3.appendChild(
            document.createTextNode(
              "Photos"
            )
          );
          link4.appendChild(
            document.createTextNode(
              "Followers"
            )
          );
          edIcon = svgForType.edit.cloneNode(true);
          edIcon.setAttribute("width", 12);
          edIcon.setAttribute("height", 12);
          edIcon.setAttribute("fill", "#7D99FF");
          frIcon = svgForType.mutual.cloneNode(true);
          frIcon.setAttribute("width", 12);
          frIcon.setAttribute("height", 12);
          frIcon.setAttribute("fill", "#7D99FF");
          phIcon = svgForType.image.cloneNode(true);
          phIcon.setAttribute("width", 12);
          phIcon.setAttribute("height", 12);
          phIcon.setAttribute("fill", "#7D99FF");
          visIcon = svgForType.home.cloneNode(true);
          visIcon.setAttribute("width", 12);
          visIcon.setAttribute("height", 12);
          visIcon.setAttribute("fill", "#7D99FF");
          link0.appendChild(edIcon.cloneNode(true));
          link1.appendChild(visIcon.cloneNode(true));
          link2.appendChild(edIcon.cloneNode(true));
          link3.appendChild(phIcon.cloneNode(true));
          link4.appendChild(frIcon.cloneNode(true));
          subt.appendChild(link2);
          subt.appendChild(link0);
          subt.appendChild(link3);
          subt.appendChild(link4);
          subt.appendChild(link1);
          if (
            !data.classList.contains("is-uploading-photos") &&
            href[5] !== "followers" && href[5] !== "follows"
          ) {
            subt.appendChild(reblogMenuButton(name1));
          } else {
            var blankSpace = document.createElement("div");
            blankSpace.classList.add("blank-space");
            subt.appendChild(blankSpace);
          }
          subt.classList.add("subt");
          tray.appendChild(subt);
          document.getElementById("blog_menu").appendChild(tray);
        }
        data.setAttribute(
          "data-tumblelogs", JSON.stringify(tumblelogs)
        );
        document.getElementById("blog_menu").removeChild(
          document.getElementById("bm_load_img")
        );
      }
    };
    xhttp.open("GET", "/settings", true);
    xhttp.send();
  } // this loads the blog menu

  // this opens the blog menu
  blogMenuLink.addEventListener("click", function (e) {
    var data = document.getElementById(
      "mass_post_features-plugin_data"
    );
    // any other time, just open menu
    if (
      !this.classList.contains("open") &&
      !data.classList.contains("open-blog_menu") &&
      !data.classList.contains("closing-blog_menu")
    ) {
      data.classList.add("open-blog_menu");
      this.classList.add("open");
      e.cancelBubble = true;
      e.preventDefault();
      e.stopPropagation();
    }
    e.cancelBubble = true;
    e.stopPropagation();
  });
  // end of blogs menu blog dropdown...

  // tumblr now has its own default queue/drafts pages
  // so we'll fake a query with userscript booleans
  if(
    href[3] === "published" || href[3] === "draft" || href[3] === "queued"
  ) {
    getResponseText("/blog/" + name, function (re){
      var div = document.createElement("div");
      div.innerHTML = re. // parse the dom
      replace(/<(\/?)script[^>]*>/g, "<$1flurb>"). // no eval
      replace(/<img/g,"<space"); // do not onload img tags
      var flurb = div.getElementsByTagName("flurb");
      var keyReg = /"API_TOKEN"[^:]*:[^"]*"([^"]+)"/i;
      var csrfReg = /"CSRFTOKEN"[^:]*:[^"]*"([^"]+)"/i;
      // find the flurb :) not joking
      var apiToken = 0;
      var csrfToken = 0;
      var primary = name;
      for (var i = 0; i < flurb.length; i++) {
        if (flurb[i].innerText.match(keyReg) !== null) {
          apiToken = flurb[i].innerText.match(keyReg)[1];
          break;
        }
      }
      for (i = 0; i < flurb.length; i++) {
        if (flurb[i].innerText.match(csrfReg) !== null) {
          csrfToken = flurb[i].innerText.match(csrfReg)[1];
          break;
        }
      }
      if (apiToken !== 0) {
        // this is Tumblr's own API key! (0_0)
        data.setAttribute("data-api-token", apiToken);
        data.setAttribute("data-csrf-token", csrfToken);
        // please use this ^ responsibly! (O.O)
        if (
          href[3] === "published" &&
          href[5] === "fans"
        ) {
          var token = data.getAttribute("data-api-token");
        }
        if (
          href[3] === "published" &&
          (
            href[5] === "dashboard" ||
            href[5] === "archive" ||
            href[5] === "tagged" ||
            href[5] === "likes" ||
            href[5] === "search"
          )
        ) {
          // hide editor functions for archive view / reblog mode
          var ritpm = document.getElementsByClassName(
            "remove-in-third-party-mode"
          ); // edit buttons don't work in reblog mode... I tried :)
          while (ritpm.length > 0) {
            ritpm[0].parentNode.removeChild(ritpm[0]);
          }
          var notice = document.createElement("div");
          notice.classList.add("notice");
          notice.appendChild(
            document.createTextNode(
              "Page may be endless; Utilize pause button."
            )
          );
          document.getElementsByClassName(
            "editor_navigation"
          )[0].appendChild(notice);
          if (href[5] === "dashboard") {
            i = "dash";
          }
          if (href[5] === "archive") {
            i = "archive";
          }
          if (href[5] === "tagged") {
            i = "tagged";
          }
          if (href[5] === "likes") {
            i = "likes";
          }
          if (href[5] === "search") {
            i = "search";
          }
        } else {
          i = href[3];
          // this is the fans
          if (
            href[3] === "published" &&
            href[5] === "fans"
          ) {
           // loadFans(); // html api; too unstable
          }
        }
        if (
          href[3] === "published" && href[5] === "archive" ||
          href[3] === "published" && href[5] === "likes" ||
          href[3] === "published" && href[5] === "dashboard" ||
          href[3] === "published" && href[5] === "tagged" ||
          href[3] === "published" && href[5] === "search" ||
          (
            i === "published" && href[5] !== "photos" &&
            i === "published" && href[5] !== "follows" &&
            i === "published" && href[5] !== "followers" &&
            i === "published" && href[5] !== "fans"
          ) ||
          i === "queued" ||
          i === "draft"
        ) {
          var q = typeof href[6] !== "undefined" ? href[6] : "cats";
          var o = typeof href[7] !== "undefined" && !isNaN(href[7]) ?
              "&before=" + href[7] : "";
          if (q === name) {
            q = data.getAttribute("data-primary-blog");
            // all secondaries goto the blog that likes, for likes :)
          }
          var subpage = {
            "published" :
              "/v2/blog/" + name +
			  "/posts?limit=50&reblog_info=1&npf=1&page=1" + o,
            "likes":
              "/v2/blog/" + q +
			  "/likes?limit=50&reblog_info=1&npf=1&page=1" + o,
            "draft":
              "/v2/blog/" + name +
			  "/posts/draft?limit=50&reblog_info=1&npf=1&page=1" + o,
            "queued":
              "/v2/blog/" + name +
			  "/posts/queue?limit=50&reblog_info=1&npf=1&page=1" + o,
            "archive":
              "/v2/blog/" + q +
			  "/posts?limit=50&reblog_info=1&npf=1&page=1" + o,
            "dash" :
              "/v2/timeline/dashboard",
            "search" :
              "/v2/mobile/search/posts?blog_limit=0&post_limit=50&query=" + q +
              "&mode=top" + o,
            "tagged" : // why is these mobile? I'm not quite sure...
              "/v2/mobile/search/posts?blog_limit=0&post_limit=50m&query=" + q +
              "&mode=top&mode=recent" + o
          }[i];
          data.setAttribute("data-ajax-first-subpage", subpage);
          asyncRepeatApiRead({
            "response": { // we wil use all neue npf format, because
              "_links": { // some posts are neue npf, no matter what
                "next": { // (if you can't beat 'em, join 'em)
                  "href":  subpage
                }
              }
            }
          });// this thing paginates itself
        }
        // this is the follows and followers
        if (
          href[3] === "published" &&
          (
            href[5] === "follows" ||
            href[5] === "followers"
          )
        ) {
          loadFollowers();
        }
      }
    });
  };

  // the month widget must be modified to accomidate Archives
  var broMo = document.createElement("div");
  broMo.id = "browse_months";
  broMo.setAttribute("onclick", "just_clicked_browse_months = true;");
  var jum2mo = document.createElement("div");
  jum2mo.id = "jump_to_month";
  var aro2 = document.createElement("span");
  aro2.classList.add("arrow");
  jum2mo.appendChild(aro2);
  broMo.addEventListener("click", function () {
    var bmw = document.getElementById(
      "browse_months_widget"
    );
    if (
      window.getComputedStyle(bmw).
        getPropertyValue("display") === "none"
     ) {
      bmw.style.display = "block";
    } else {
      bmw.style.display = "none";
    }
  });
  var mo2;
  var jum = typeof href[5] !== "undefined" ? href[5] : "jump";
  var jumto = typeof href[6] !== "undefined" ? href[6] : name;
  var year = typeof href[7] !== "undefined" && !isNaN(href[7]) ?
        (new Date(parseInt(href[7]) * 1000)).getFullYear() :
        (new Date()).getFullYear();
  if (href[3] === "queued" || href[3] === "draft") {
    var ridqm = document.getElementsByClassName(
      "remove-in-drafts-queue-mode"
    );
    while (ridqm.length > 0) {
      ridqm[0].parentNode.removeChild(ridqm[0]);
    }
  }
  if (href[3] === "published" &&
      (
        typeof href[5] === "undefined" ||
        href[5] === "jump" ||
        href[5] === "archive"
      )
  ) {
    mo2 = document.createElement("span");
    mo2.classList.add("month");
    mo2.appendChild(document.createTextNode("Month"));
    jum2mo.appendChild(mo2);
    // this is a sneaky trick to get that elusive "firstPostTimeStamp"
    var monthIframe = document.createElement("iframe");
    monthIframe.style.display = "none";
    monthIframe.id = "browse_months_widget";
    monthIframe.setAttribute("scrolling", "no");
    monthIframe.setAttribute("frameborder", "0");
    monthIframe.setAttribute("title", "Post forms");
    monthIframe.src = "https://" + jumto + ".tumblr.com/" +
                      "archive?fetch=first_post_timestamp" +
                      "&jump=" + jum + "&name=" + name + "&to=" +
                      jumto + "&year=" + year;
    // these ^ url parameters need to be in alphabetical order
    jum2mo.appendChild(monthIframe);
    broMo.appendChild(jum2mo);
    document.getElementById(
      "browse_months"
    ).parentNode.replaceChild(
      broMo,
      document.getElementById(
        "browse_months"
      )
    );
  } else {
    mo2 = document.createElement("span");
    mo2.classList.add("month");
    mo2.appendChild(document.createTextNode("Month"));
    jum2mo.appendChild(mo2);
    // this is for getting before timestamps for other feeds
    jum = typeof href[5] !== "undefined" ? href[5] : "jump";
    jumto = typeof href[6] !== "undefined" ? href[6] : name;
    year = typeof href[7] !== "undefined" && !isNaN(href[7]) ?
        (new Date(parseInt(href[7]) * 1000)).getFullYear() :
        (new Date()).getFullYear();
    lTs = (new Date()).getTime();
    fTs = (new Date(1970, 0, 1)).getTime();
    var monthDiv = makeBrowseMonthsWidget(year, lTs, fTs, jum, jumto);
    monthDiv.style.display = "none";
    jum2mo.appendChild(monthDiv);
    broMo.appendChild(jum2mo);
    document.getElementById(
      "browse_months"
    ).parentNode.replaceChild(
      broMo,
      document.getElementById(
        "browse_months"
      )
    );
    doubleCheckDisabledMonths(year, lTs, fTs, jum, jumto);
  }

  // this is the new batch photos page! BATCH PHOTOS PAGE
  if (href[3] === "published" && href[5] === "photos") {
    navArchive = document.getElementById("nav_archive");
    navArchive.style.zIndex = "1000";
    var addTagsWidget = document.getElementById("add_tags_widget");
    navArchive.appendChild(addTagsWidget);
    var addTagButton = document.getElementById("add_tag_button");
    addTagButton.removeAttribute("onclick");
    var addTagButton2 = addTagButton.cloneNode(true);
    addTagButton.firstChild.innerHTML = "Add Tags (single)";
    addTagButton2.firstChild.innerHTML = "Add Tags to All";
    addTagButton2.id += "2";
    addTagButton2.style.position = "absolute";
    addTagButton2.style.bottom = "8px";
    addTagButton2.style.left = "161px";
    addTagButton2.addEventListener("click", function () {
      var token = document.getElementById("tokens").children;
      var pb = document.getElementsByClassName("photo-brick");
      var phTags;
      var aToken;
      var child;
      var a;
      var addToken = true;
      for (var j = 0; j < pb.length; j++) {//pb & j :)
        phTags = pb[j].getElementsByClassName("photo-tags")[0];
        aToken = phTags.children;
        for (var i = 0; i < token.length; i++) {
          addToken = true;
          for (var l = 0; l < aToken.length; l++) {
            if (token[i].innerHTML === aToken[l].innerHTML) {
              addToken = false;
              break;
            }
          }
          if (addToken) {
            child = token[i].cloneNode(true);
            a = child.getElementsByTagName("a");
            a[0].removeAttribute("onclick");
            phTags.appendChild(child);
          }
        }
      }
    });
    addTagButton.addEventListener("click", function () {
      var fr = document.getElementsByClassName("focused-rich");
      if (fr.length === 0) {
        return;
      }
      var token = document.getElementById("tokens").children;
      var phTags = fr[0].getElementsByClassName("photo-tags")[0];
      var aToken = phTags.children;
      var addToken = true;
      for (var i = 0; i < token.length; i++) {
        addToken = true;
        for (var l = 0; l < aToken.length; l++) {
          if (token[i].innerHTML === aToken[l].innerHTML) {
            addToken = false;
            break;
          }
        }
        if (addToken) {
          phTags.appendChild(token[i].cloneNode(true));
        }
      }
    });
    addTagButton.parentNode.parentNode.appendChild(addTagButton2);
    addTagsWidget.style.top = "83px";
    addTagsWidget.style.left = "15px";
    addTagsWidget.style.removeProperty("right");
    lcontent.classList.add("albino");
    lcontent.classList.add("hoverless");
    lcontent.classList.add("photo-page");
    data.classList.add("is-uploading-photos");
    var dragEnter = function(e){
      e.preventDefault();
      if (
        document.getElementsByClassName(
          "brick-dragging"
        ).length > 0
      ) {
        return;
      }
      var pdz = document.getElementById("photos-drop-zone");
      pdz.classList.add("full");
    };
    var dragLeave = function(e) {
      e.preventDefault();
      var pdz = document.getElementById("photos-drop-zone");
      pdz.classList.remove("full");
    };
    var drop = function(e) {
      e.preventDefault();
      var papb = document.getElementById("post_all_photos_button");
      if (papb.getAttribute("disabled") !== null) {
        papb.removeAttribute("disabled");
      }
      var pdz = document.getElementById("photos-drop-zone");
      pdz.classList.remove("full");
      var files;
      if (typeof e.dataTransfer !== "undefined") {
        files = e.dataTransfer.files;
      } else if (typeof this.files !== "undefined") {
        files = this.files;
      }
      var r;
      for (var i = 0; i < files.length; i++) {
        if(files[i].type.toString().split(/\//)[0] !== "image") {
          continue;
        }
        r = new FileReader();
        r.imgCode = "img"+shortCode(files[i].name);
        r.addEventListener("load", loadPhotoIntoDOM);
        reading.push(
          {
            read: function(){
              reading[reading.length - 1].reader.readAsDataURL(
                reading[reading.length - 1].file
              );
            },
            file: files[i],
            reader: r
          }
        );
        unreadFile["img"+shortCode(files[i].name)] = files[i];
      }
      reading[reading.length - 1].read();
    };
    en = document.getElementsByClassName("editor_navigation");
    // remove all navigation buttons, editor widgets, and start anew
    en[0].parentNode.removeChild(en[0]);
    var dropZone = document.createElement("div");
    dropZone.id = "photos-drop-zone";
    var dropTitle = document.createElement("h2");
    dropTitle.appendChild(
      document.createTextNode("Drop Photos Here")
    );
    dropTitle.id = "drop_images_here";
    var inputBackup = document.createElement("input");
    inputBackup.type = "file";
    inputBackup.accept = "image/x-png,image/gif,image/jpeg,image/png";
    inputBackup.multiple = true;
    inputBackup.addEventListener("change", drop);
    inputBackup.id = "photo_file_input";
    var postPhotos = butt("Post Photos");
    postPhotos.disabled = true;
    postPhotos.id = "post_all_photos_button";
    postPhotos.setAttribute("title", "Post All Photos");
    postPhotos.addEventListener("click", photoUploadAndSubmit);
    var photosAsDraft = document.createElement("input");
    photosAsDraft.id = "photos_as_draft";
    photosAsDraft.type = "checkbox";
    photosAsDraft.checked = true;
    var photosAsDraftLabel = document.createElement("label");
    photosAsDraftLabel.setAttribute("for", "photos_as_draft");
    photosAsDraftLabel.appendChild(
      document.createTextNode(
        "New Photo/Photoset Posts"
      )
    );
    var asB = document.createElement("strong");
    asB.appendChild(
      document.createTextNode(" as Draft")
    );
    photosAsDraftLabel.appendChild(asB);
    var photosAsDraftContainer = document.createElement("div");
    photosAsDraftContainer.id = "photos_as_draft_container";
    photosAsDraftContainer.appendChild(photosAsDraft);
    photosAsDraftContainer.appendChild(photosAsDraftLabel);
    var photosRobotWarning = document.createElement("div");
    photosRobotWarning.classList.add("robot-warning");
    var robotTitlePhotos = document.createElement("strong");
    robotTitlePhotos.appendChild(
      document.createTextNode(
        "Friendly Robot Warning"
      )
    );
    photosRobotWarning.appendChild(robotTitlePhotos);
    photosRobotWarning.appendChild(
      document.createTextNode(
        "Dash flooding might make you lose followers. " +
        "Perhaps \"check\" post \"as draft\" instead?"
      )
     );
    photosAsDraftContainer.appendChild(photosRobotWarning);
    document.body.appendChild(photosAsDraftContainer);
    document.body.appendChild(inputBackup);
    document.body.appendChild(postPhotos);
    document.body.appendChild(dropTitle);
    document.body.appendChild(dropZone);
    document.documentElement.addEventListener("dragenter", dragEnter, false);
    document.documentElement.addEventListener("dragover", dragEnter, false);
    document.documentElement.addEventListener("dragleave", dragLeave, false);
    document.documentElement.addEventListener("drop", drop, false);
  }
};
// May 2020, Mass Post Editor Features 4 (from scratch) by Jake Jilg (benign-mx)
document.onreadystatechange = function () {
  // Hello :)
  if (document.readyState === "interactive") {
    MassPostEditorFeatures4();
  }
}; // Hello world!