summaryrefslogtreecommitdiffhomepage
path: root/themes/luci-theme-material/htdocs/js/script.js
diff options
context:
space:
mode:
Diffstat (limited to 'themes/luci-theme-material/htdocs/js/script.js')
-rwxr-xr-xthemes/luci-theme-material/htdocs/js/script.js294
1 files changed, 294 insertions, 0 deletions
diff --git a/themes/luci-theme-material/htdocs/js/script.js b/themes/luci-theme-material/htdocs/js/script.js
new file mode 100755
index 0000000000..7ba9624c9c
--- /dev/null
+++ b/themes/luci-theme-material/htdocs/js/script.js
@@ -0,0 +1,294 @@
+/**
+ * Created by WebStorm on 15-9-13.
+ */
+(function ($) {
+ var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",
+ a256 = '',
+ r64 = [256],
+ r256 = [256],
+ i = 0;
+ var UTF8 = {
+ /**
+ * Encode multi-byte Unicode string into utf-8 multiple single-byte characters
+ * (BMP / basic multilingual plane only)
+ *
+ * Chars in range U+0080 - U+07FF are encoded in 2 chars, U+0800 - U+FFFF in 3 chars
+ *
+ * @param {String} strUni Unicode string to be encoded as UTF-8
+ * @returns {String} encoded string
+ */
+ encode: function (strUni) {
+ // use regular expressions & String.replace callback function for better efficiency
+ // than procedural approaches
+ var strUtf = strUni.replace(/[\u0080-\u07ff]/g, // U+0080 - U+07FF => 2 bytes 110yyyyy, 10zzzzzz
+ function (c) {
+ var cc = c.charCodeAt(0);
+ return String.fromCharCode(0xc0 | cc >> 6, 0x80 | cc & 0x3f);
+ })
+ .replace(/[\u0800-\uffff]/g, // U+0800 - U+FFFF => 3 bytes 1110xxxx, 10yyyyyy, 10zzzzzz
+ function (c) {
+ var cc = c.charCodeAt(0);
+ return String.fromCharCode(0xe0 | cc >> 12, 0x80 | cc >> 6 & 0x3F, 0x80 | cc & 0x3f);
+ });
+ return strUtf;
+ },
+ /**
+ * Decode utf-8 encoded string back into multi-byte Unicode characters
+ *
+ * @param {String} strUtf UTF-8 string to be decoded back to Unicode
+ * @returns {String} decoded string
+ */
+ decode: function (strUtf) {
+ // note: decode 3-byte chars first as decoded 2-byte strings could appear to be 3-byte char!
+ var strUni = strUtf.replace(/[\u00e0-\u00ef][\u0080-\u00bf][\u0080-\u00bf]/g, // 3-byte chars
+ function (c) { // (note parentheses for precence)
+ var cc = ((c.charCodeAt(0) & 0x0f) << 12) | ((c.charCodeAt(1) & 0x3f) << 6) | (c.charCodeAt(2) & 0x3f);
+ return String.fromCharCode(cc);
+ })
+ .replace(/[\u00c0-\u00df][\u0080-\u00bf]/g, // 2-byte chars
+ function (c) { // (note parentheses for precence)
+ var cc = (c.charCodeAt(0) & 0x1f) << 6 | c.charCodeAt(1) & 0x3f;
+ return String.fromCharCode(cc);
+ });
+ return strUni;
+ }
+ };
+ while (i < 256) {
+ var c = String.fromCharCode(i);
+ a256 += c;
+ r256[i] = i;
+ r64[i] = b64.indexOf(c);
+ ++i;
+ }
+ function code(s, discard, alpha, beta, w1, w2) {
+ s = String(s);
+ var buffer = 0,
+ i = 0,
+ length = s.length,
+ result = '',
+ bitsInBuffer = 0;
+ while (i < length) {
+ var c = s.charCodeAt(i);
+ c = c < 256 ? alpha[c] : -1;
+ buffer = (buffer << w1) + c;
+ bitsInBuffer += w1;
+ while (bitsInBuffer >= w2) {
+ bitsInBuffer -= w2;
+ var tmp = buffer >> bitsInBuffer;
+ result += beta.charAt(tmp);
+ buffer ^= tmp << bitsInBuffer;
+ }
+ ++i;
+ }
+ if (!discard && bitsInBuffer > 0) result += beta.charAt(buffer << (w2 - bitsInBuffer));
+ return result;
+ }
+
+ var Plugin = $.base64 = function (dir, input, encode) {
+ return input ? Plugin[dir](input, encode) : dir ? null : this;
+ };
+ Plugin.btoa = Plugin.encode = function (plain, utf8encode) {
+ plain = Plugin.raw === false || Plugin.utf8encode || utf8encode ? UTF8.encode(plain) : plain;
+ plain = code(plain, false, r256, b64, 8, 6);
+ return plain + '===='.slice((plain.length % 4) || 4);
+ };
+ Plugin.atob = Plugin.decode = function (coded, utf8decode) {
+ coded = String(coded).split('=');
+ var i = coded.length;
+ do {
+ --i;
+ coded[i] = code(coded[i], true, r64, a256, 6, 8);
+ } while (i > 0);
+ coded = coded.join('');
+ return Plugin.raw === false || Plugin.utf8decode || utf8decode ? UTF8.decode(coded) : coded;
+ };
+}(jQuery));
+
+
+function trimText(text) {
+ return text.replace(/[ \t\n\r]+/g, " ");
+}
+
+(function ($) {
+ var tree = undefined;
+ var lastNode = undefined;
+
+ function getCurrentNodeByHash() {
+ var ret = false;
+ var hash = window.location.hash;
+ if (hash.substr(0, 6) == "#tree-") {
+ hash = $.base64.decode(hash.substr(6));
+ tree = hash.split("|");
+ $(".main > .main-left > .nav > .slide > .menu").each(function () {
+ var that = $(this);
+ if (trimText(that.data("title")) == tree[0]) {
+ that.click();
+ that.next().find("a").each(function () {
+ var that = $(this);
+ if (trimText(that.data("title")) == tree[1]) {
+ lastNode = that.parent();
+ lastNode.addClass("active");
+ ret = true;
+ return true;
+ }
+ });
+ }
+ });
+ }
+ return ret;
+ }
+
+ function getCurrentNodeByUrl() {
+ var ret = false;
+ var getUrlNode = function (href){
+ var linkPos = href.indexOf(";");
+ if (linkPos == -1){
+ return "login";
+ }else{
+ linkPos = href.indexOf("/", linkPos);
+ if (linkPos == -1){
+ return "overview";
+ }else{
+ var link = href.substr(linkPos);
+ if (link == "/")
+ return "overview";
+ else
+ return link;
+ }
+ }
+ };
+
+ var currentNode = getUrlNode(window.location.pathname);
+
+ if (currentNode == "login"){
+ tree = ["Main", "Login"];
+ return false;
+ }else if(currentNode == "overview"){
+ tree = ["Status", "Overview"];
+ lastNode = $($($(".main > .main-left > .nav > .slide > .menu")[0]).next().find("a")[0]).parent();
+ return false;
+ }
+
+ $(".main > .main-left > .nav > .slide > .menu").each(function () {
+ var ulNode = $(this);
+ ulNode.next().find("a").each(function () {
+ var that = $(this);
+ var href = that.attr("href");
+
+ if (currentNode.indexOf(getUrlNode(href)) != -1){
+ ulNode.click();
+ lastNode = that.parent();
+ tree = [trimText(ulNode.data("title")), trimText(that.data("title"))];
+ lastNode.addClass("active");
+ ret = true;
+ return true;
+ }
+ });
+ });
+ return ret;
+ }
+
+ $(".main > .main-left > .nav > .slide > .menu").click(function () {
+ var ul = $(this).next(".slide-menu");
+ var menu = $(this);
+ if (!ul.is(":visible")) {
+ menu.addClass("active");
+ ul.addClass("active");
+ ul.stop(true).slideDown();
+ } else {
+ ul.slideUp(function () {
+ menu.removeClass("active");
+ ul.removeClass("active");
+ });
+ }
+ });
+
+ $(".main > .main-left > .nav > .slide > .slide-menu > li > a").click(function () {
+ var href = $(this).attr("href");
+ var tree = trimText($(this).parent().parent().prev().data("title")) + "|" + trimText($(this).data("title"));
+ tree = $.base64.encode(tree);
+ window.location = href + "#tree-" + tree;
+ if (lastNode != undefined) lastNode.removeClass("active");
+ $(this).parent().addClass("active");
+ return false;
+ });
+
+ $(".main > .main-left > .nav > .slide > .slide-menu > li").click(function () {
+ $(this).find("a").click();
+ });
+
+
+ if (!getCurrentNodeByUrl()){
+ getCurrentNodeByHash();
+ if (tree[0] == "Status" && tree[1] == "Overview"){
+ //overview
+ lastNode.addClass("active");
+ $($(".main > .main-left > .nav > .slide > .menu")[0]).click();
+ }
+ }
+ var mainNodeName = "node-"+ tree[0] + "-" + tree[1];
+ $("body").addClass(mainNodeName.replace(/[ \t\n\r\/]+/g,"_").toLowerCase());
+ $(".cbi-button-up").val("");
+ $(".cbi-button-down").val("");
+
+
+ $("#maincontent > .container").find("a").each(function () {
+ var that = $(this);
+ var onclick = that.attr("onclick");
+ if (onclick == undefined || onclick == ""){
+ that.click(function () {
+ var href = that.attr("href");
+ if (tree != undefined && href.indexOf("Text") == -1) {
+ window.location = href + "#tree-" + $.base64.encode(tree[0] + "|" + tree[1]);
+ return false;
+ }else{
+ return true;
+ }
+ });
+ }
+ });
+
+ var showSide = false;
+ $(".showSide").click(function () {
+ if (showSide){
+ $(".darkMask").stop(true).fadeOut();
+ $(".main-left").stop(true).animate({
+ width: "0"
+ });
+ showSide = false;
+ }else{
+ $(".darkMask").stop(true).fadeIn();
+ $(".main-left").stop(true).animate({
+ width: "15rem"
+ });
+ showSide = true;
+ }
+ });
+
+
+ $(".darkMask").click(function () {
+ if (showSide){
+ showSide = false;
+ $(".darkMask").stop(true).fadeOut();
+ $(".main-left").stop(true).animate({
+ width: "0"
+ });
+ }
+ });
+
+ $(window).resize(function() {
+ if ($(window).width() > 921) {
+ $(".main-left").css("width", "");
+ $(".darkMask").stop(true);
+ $(".darkMask").css("display", "none");
+ showSide = false;
+ }
+ });
+
+ $("legend").each(function () {
+ var that = $(this);
+ that.after("<span class='panel-title'>" + that.text() + "</span>");
+ });
+
+ window.scrollTo(0,1);
+})(jQuery);