lib:progress bar

none

// ==UserScript==
// @name         lib:progress bar
// @version      7
// @description  none
// @license      GPLv3
// @run-at       document-start
// @author       rssaromeo
// @match        *://*/*
// @include      *
// @tag          lib
// @exclude      /livereload.net\/files\/ffopen\/index.html$/
// @icon         
// @grant        none
// @namespace https://greasyfork.org/users/1184528
// ==/UserScript==
;(() => {
  const a = loadlib("allfuncs")

  class progressBar {
    constructor(min, max, name = "") {
      this.min = min
      this.max = max
      this.barname = name
      document.body.appendChild(
        (this.parent = a.newelem(
          "div",
          {
            position: "fixed",
            top: "0",
            left: 0,
            border: "30px solid #999",
            backgroundColor: "black",
            color: "white",
            width: "calc(100vw - 60px)",
            height: "29px",
          },
          [
            (this.progresstext = a.newelem("div", {
              // backgroundColor: "#fff",
              height: "20px",
            })),
            (this.progressbar = a.newelem("div", {
              backgroundColor: "#777",
              width: "100%",
              height: "10px",
            })),
          ]
        ))
      )
    }
    set(val, name = "") {
      this.progresstext.innerHTML = `${val}/${this.max}: ${name}`
      this.progressbar.style.width =
        "calc(" + a.rerange(val, 0, this.max, 0, 100) + "% - 2px)"
    }
    remove() {
      this.parent.remove()
      delete this.parent
    }
  }
  loadlib("libloader").savelib("progress bar", progressBar)
})()