Greasy Fork is available in English.

ZFDev-百度网盘文件树视图

添加文件树视图,全局查看文件详情

// ==UserScript==
// @icon         
// @name         ZFDev-百度网盘文件树视图
// @namespace    https://zfdev.com/
// @version      0.4
// @description  添加文件树视图,全局查看文件详情
// @author       ZFDev
// @match        https://pan.baidu.com/s/1*
// @match        https://yun.baidu.com/s/1*
// @require        https://cdn.staticfile.org/html2canvas/0.5.0-beta4/html2canvas.js
// @grant        GM_addStyle
// @run-at       document-idle
// ==/UserScript==

(function() {
    'use strict';
    GM_addStyle('.zfdev-tree-manager{background: white;}.zfdev-tree-manager .treeview-node {cursor: unset;-webkit-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;height: 30px;position: relative;}.zfdev-tree-manager .treeview-node .treeview-txt{cursor: auto;-webkit-user-select: auto;-moz-user-select: auto;-ms-user-select: auto;user-select: auto;}.zfdev-tree-manager .treeview-node:not(.treeview-node-on) {border-bottom: 1px solid #f2f6fd;}.zfdev-tree-manager .treeview-node:hover {background: #e5f0fb;}.zfdev-tree-manager .treeview-node .treeview-node-handler {display: inline-block;min-width: 60%;width: auto;}.zfdev-tree-manager .treeview-node .treeview-size,.zfdev-tree-manager .treeview-node .treeview-time{position: relative;display: inline-block;color: #666;}.zfdev-tree-manager .treeview-node .treeview-size{width:16%;}.zfdev-tree-manager .treeview-node .treeview-time{width:23%;}.zfdev-tree-manager .treeview-node .treeview-txt{width: 80%;padding-right: 10px;white-space: nowrap;text-overflow: ellipsis;overflow: hidden;}#gengrate-image-copy-dom li,#gengrate-image-copy-dom ul.treeview, {width: max-content;}#gengrate-image-copy-dom .treeview-node{padding-right: 60px;height: 30px;border-bottom: 1px solid #f2f6fd;}#gengrate-image-copy-dom .treeview-node-handler{margin-right: 0!important;}#gengrate-image-copy-dom .treeview-node span {width: 100%;}#zfdev-treeview-img-div{max-height: 800px;position: absolute;z-index: 99999999;top: 50%;left: 50%;transform: translate(-50%,-50%);box-sizing: border-box;-webkit-box-shadow: 0 0.5em 1em 0.5em rgba(0,0,0,.19);box-shadow: 0 0.5em 1em 0.5em rgba(0,0,0,.19);border-bottom-left-radius: .3em;border-bottom-right-radius: .3em;padding: 10px;}#zfdev-treeview-img-div em{height: 25px;width: 25px;padding: 0;margin: 0;line-height: 25px;font-size: 12px;}#zfdev-treeview-img-div > div > a{border-radius: 50%;position: absolute;right: -20px;width: 25px;line-height: 25px;height: 25px;background-color: white;box-shadow: rgba(0, 0, 0, 0.19) 0px 0.3px 1em 0.3px;border: 1px solid rgb(192, 217, 254);padding: 0px;margin-right: 0px;text-align: center;}');
    GM_addStyle('@font-face{font-family:"iconfont-zfdev-filetree";src:url(data:font/truetype;charset=utf-8;base64,AAEAAAALAIAAAwAwR1NVQrD+s+0AAAE4AAAAQk9TLzI8fUhsAAABfAAAAFZjbWFws/QcPQAAAeQAAAGcZ2x5ZqQfxqgAAAOMAAABjGhlYWQTLAKJAAAA4AAAADZoaGVhB94DhQAAALwAAAAkaG10eBAAAAAAAAHUAAAAEGxvY2EBAgCUAAADgAAAAAptYXhwARcARQAAARgAAAAgbmFtZYx+aQAAAAUYAAADIXBvc3QPWfb4AAAIPAAAAEoAAQAAA4D/gABcBAAAAAAABAAAAQAAAAAAAAAAAAAAAAAAAAQAAQAAAAEAAEEtmIxfDzz1AAsEAAAAAADYBl9GAAAAANgGX0YAAP+ABAADgAAAAAgAAgAAAAAAAAABAAAABAA5AAkAAAAAAAIAAAAKAAoAAAD/AAAAAAAAAAEAAAAKAB4ALAABREZMVAAIAAQAAAAAAAAAAQAAAAFsaWdhAAgAAAABAAAAAQAEAAQAAAABAAgAAQAGAAAAAQAAAAAAAQQAAZAABQAIAokCzAAAAI8CiQLMAAAB6wAyAQgAAAIABQMAAAAAAAAAAAAAAAAAAAAAAAAAAAAAUGZFZABA5gfmegOA/4AAXAOAAIAAAAABAAAAAAAABAAAAAQAAAAEAAAABAAAAAAAAAUAAAADAAAALAAAAAQAAAFoAAEAAAAAAGIAAwABAAAALAADAAoAAAFoAAQANgAAAAgACAACAADmB+Yx5nr//wAA5gfmMeZ6//8AAAAAAAAAAQAIAAgACAAAAAMAAQACAAABBgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAMAAAAAAA0AAAAAAAAAAMAAOYHAADmBwAAAAMAAOYxAADmMQAAAAEAAOZ6AADmegAAAAIAAAAAADwAlADGAAAAAgAA/4wD9AN0AAsAHgAAAQYABxYAFzYANyYAEwEHBiIvAiY0NjIfAQE2MhYUAgDU/uUFBQEb1NQBGwUF/uU+/rYEChsKA6QJExoKkQE3ChoTA3QF/uXU1P7lBQUBG9TUARv+of62BAoKBKQKGhMJkQE3ChQaAAAACQAA/5QD1gM8ABUAGgAeACMAJwAsADAANAA4AAABFSM1MzUjNSMRIRUzNSMVIzUzFTM1Ex0BITUHITUhBR0BITUHITUhBR0BITUHITUhARUhNQchNSEB1urq6iQBDgIC6uoCEQHsJP5cAaT+OAHsJP5cAaT+OAHsJP5cAaT8cQHSOf6eAWIBDyvMJJ/9WCt7LNArewEMNmSaajrMNmSaajrANmSaajoDPdLSrIkAAAACAAD/gAQAA4AACwAXAAABHgEXDgEHLgEnPgE3BgAHFgAXNgA3JgACAL79BQX9vr79BQX9vtr+3wUFASHa2gEhBQX+3wNABf2+vv0FBf2+vv1FBf7f2tr+3wUFASHa2gEhAAAAAAASAN4AAQAAAAAAAAAVAAAAAQAAAAAAAQAXABUAAQAAAAAAAgAHACwAAQAAAAAAAwAXADMAAQAAAAAABAAXAEoAAQAAAAAABQALAGEAAQAAAAAABgAXAGwAAQAAAAAACgArAIMAAQAAAAAACwATAK4AAwABBAkAAAAqAMEAAwABBAkAAQAuAOsAAwABBAkAAgAOARkAAwABBAkAAwAuAScAAwABBAkABAAuAVUAAwABBAkABQAWAYMAAwABBAkABgAuAZkAAwABBAkACgBWAccAAwABBAkACwAmAh0KQ3JlYXRlZCBieSBpY29uZm9udAppY29uZm9udC16ZmRldi1maWxldHJlZVJlZ3VsYXJpY29uZm9udC16ZmRldi1maWxldHJlZWljb25mb250LXpmZGV2LWZpbGV0cmVlVmVyc2lvbiAxLjBpY29uZm9udC16ZmRldi1maWxldHJlZUdlbmVyYXRlZCBieSBzdmcydHRmIGZyb20gRm9udGVsbG8gcHJvamVjdC5odHRwOi8vZm9udGVsbG8uY29tAAoAQwByAGUAYQB0AGUAZAAgAGIAeQAgAGkAYwBvAG4AZgBvAG4AdAAKAGkAYwBvAG4AZgBvAG4AdAAtAHoAZgBkAGUAdgAtAGYAaQBsAGUAdAByAGUAZQBSAGUAZwB1AGwAYQByAGkAYwBvAG4AZgBvAG4AdAAtAHoAZgBkAGUAdgAtAGYAaQBsAGUAdAByAGUAZQBpAGMAbwBuAGYAbwBuAHQALQB6AGYAZABlAHYALQBmAGkAbABlAHQAcgBlAGUAVgBlAHIAcwBpAG8AbgAgADEALgAwAGkAYwBvAG4AZgBvAG4AdAAtAHoAZgBkAGUAdgAtAGYAaQBsAGUAdAByAGUAZQBHAGUAbgBlAHIAYQB0AGUAZAAgAGIAeQAgAHMAdgBnADIAdAB0AGYAIABmAHIAbwBtACAARgBvAG4AdABlAGwAbABvACAAcAByAG8AagBlAGMAdAAuAGgAdAB0AHAAOgAvAC8AZgBvAG4AdABlAGwAbABvAC4AYwBvAG0AAAAAAgAAAAAAAAAKAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAQIBAwEEAQUACXh1YW56aG9uZwdzaHV4aW5nCnVuc2VsZWN0ZWQAAAAA) format("truetype");font-weight:normal;font-style:normal;}.iconfont-zfdev-filetree{font-family:"iconfont-zfdev-filetree" !important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;display:inline-block;}.icon-shuxing:before{content:"\\e67a";}.icon-xuanzhong:before{content:"\\e631";}.icon-unselected:before{content:"\\e607";}');

    let log = function() {
        // console.log.apply(console, arguments)
    };
    let filesIcon = {
        "bt": ["fileicon-small-bt", "fileicon-large-bt", "fileicon-middle-bt"],
        "torrent": ["fileicon-small-bt", "fileicon-large-bt", "fileicon-middle-bt"],
        "dws": ["fileicon-small-dws", "fileicon-large-dws", "fileicon-middle-dws"],
        "dwt": ["fileicon-small-dws", "fileicon-large-dws", "fileicon-middle-dws"],
        "dxf": ["fileicon-small-dws", "fileicon-large-dws", "fileicon-middle-dws"],
        "dwg": ["fileicon-small-dws", "fileicon-large-dws", "fileicon-middle-dws"],
        "cad": ["fileicon-small-dws", "fileicon-large-dws", "fileicon-middle-dws"],
        "as": ["fileicon-small-code", "fileicon-large-code"],
        "sh": ["fileicon-small-code", "fileicon-large-code"],
        "c": ["fileicon-small-code", "fileicon-large-code"],
        "cpp": ["fileicon-small-code", "fileicon-large-code"],
        "h": ["fileicon-small-code", "fileicon-large-code"],
        "cs": ["fileicon-small-code", "fileicon-large-code"],
        "asp": ["fileicon-small-code", "fileicon-large-code"],
        "css": ["fileicon-small-code", "fileicon-large-code"],
        "pas": ["fileicon-small-code", "fileicon-large-code"],
        "diff": ["fileicon-small-code", "fileicon-large-code"],
        "patch": ["fileicon-small-code", "fileicon-large-code"],
        "erl": ["fileicon-small-code", "fileicon-large-code"],
        "groovy": ["fileicon-small-code", "fileicon-large-code"],
        "java": ["fileicon-small-code", "fileicon-large-code"],
        "jsp": ["fileicon-small-code", "fileicon-large-code"],
        "js": ["fileicon-small-code", "fileicon-large-code"],
        "json": ["fileicon-small-code", "fileicon-large-code"],
        "pl": ["fileicon-small-code", "fileicon-large-code"],
        "php": ["fileicon-small-code", "fileicon-large-code"],
        "py": ["fileicon-small-code", "fileicon-large-code"],
        "rb": ["fileicon-small-code", "fileicon-large-code"],
        "sass": ["fileicon-small-code", "fileicon-large-code"],
        "scss": ["fileicon-small-code", "fileicon-large-code"],
        "scala": ["fileicon-small-code", "fileicon-large-code"],
        "sql": ["fileicon-small-code", "fileicon-large-code"],
        "vb": ["fileicon-small-code", "fileicon-large-code"],
        "xml": ["fileicon-small-code", "fileicon-large-code"],
        "xhtml": ["fileicon-small-code", "fileicon-large-code"],
        "html": ["fileicon-small-code", "fileicon-large-code"],
        "htm": ["fileicon-small-code", "fileicon-large-code"],
        "md": ["fileicon-small-code", "fileicon-large-code"],
        "less": ["fileicon-small-code", "fileicon-large-code"],
        "lua": ["fileicon-small-code", "fileicon-large-code"],
        "go": ["fileicon-small-code", "fileicon-large-code"],
        "bat": ["fileicon-small-code", "fileicon-large-code"],
        "wml": ["fileicon-small-code", "fileicon-large-code"],
        "txt": ["fileicon-small-txt", "fileicon-large-txt", "fileicon-middle-txt"],
        "rtf": ["fileicon-small-txt", "fileicon-large-txt", "fileicon-middle-txt"],
        "pdf": ["fileicon-small-pdf", "fileicon-large-pdf", "fileicon-middle-pdf"],
        "doc": ["fileicon-small-doc", "fileicon-large-doc", "fileicon-middle-doc"],
        "docx": ["fileicon-small-doc", "fileicon-large-doc", "fileicon-middle-doc"],
        "ppt": ["fileicon-small-ppt", "fileicon-large-ppt", "fileicon-middle-ppt"],
        "pptx": ["fileicon-small-ppt", "fileicon-large-ppt", "fileicon-middle-ppt"],
        "xls": ["fileicon-small-xls", "fileicon-large-xls", "fileicon-middle-xls"],
        "xlsx": ["fileicon-small-xls", "fileicon-large-xls", "fileicon-middle-xls"],
        "vsd": ["fileicon-small-vsd", "fileicon-large-vsd", "fileicon-middle-vsd"],
        "jpg": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "jpeg": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "livp": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "gif": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "bmp": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "png": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "jpe": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "cur": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "svgz": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "tif": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "tiff": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "ico": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "heic": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "heif": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "avci": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "mmap": ["fileicon-small-mmap", "fileicon-large-mmap", "fileicon-middle-mmap"],
        "xmind": ["fileicon-small-xmind", "fileicon-large-xmind", "fileicon-middle-xmind"],
        "mm": ["fileicon-small-mm", "fileicon-large-mm", "fileicon-middle-mm"],
        "wma": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "wav": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "mp3": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "aac": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "ra": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "ram": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "mp2": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "ogg": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "aif": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "mpega": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "amr": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "mid": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "midi": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "m4a": ["fileicon-small-mp3", "fileicon-large-mp3", "fileicon-middle-mp3"],
        "jpg": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "jpeg": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "gif": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "bmp": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "png": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "jpe": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "cur": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "svgz": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "tif": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "tiff": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "ico": ["fileicon-small-pic", "default-large", "fileicon-middle-pic"],
        "exe": ["fileicon-sys-s-exe", "fileicon-sys-l-exe"],
        "msi": ["fileicon-sys-s-exe", "fileicon-sys-l-exe"],
        "dmg": ["fileicon-sys-s-exe", "fileicon-sys-l-dmg"],
        "pkg": ["fileicon-sys-s-exe", "fileicon-sys-l-dmg"],
        "psd": ["fileicon-sys-s-psd", "fileicon-sys-l-psd"],
        "apk": ["fileicon-sys-s-apk", "fileicon-sys-l-apk"],
        "key": ["fileicon-sys-s-key", "fileicon-sys-l-key"],
        "ai": ["fileicon-sys-s-ai", "fileicon-sys-l-ai"],
        "ipa": ["fileicon-sys-s-ipa", "fileicon-sys-l-ipa"],
        "pages": ["fileicon-sys-s-pages", "fileicon-sys-l-pages"],
        "numbers": ["fileicon-sys-s-numbers", "fileicon-sys-l-numbers"],
        "eot": ["fileicon-sys-s-fonts", "fileicon-sys-l-fonts"],
        "ttf": ["fileicon-sys-s-fonts", "fileicon-sys-l-fonts"],
        "woff": ["fileicon-sys-s-fonts", "fileicon-sys-l-fonts"],
        "eps": ["fileicon-sys-s-eps", "fileicon-sys-l-eps"],
        "lnk": ["fileicon-sys-s-links", "fileicon-sys-l-links"],
        "link": ["fileicon-sys-s-links", "fileicon-sys-l-links"],
        "swf": ["fileicon-sys-s-swf", "fileicon-sys-l-swf"],
        "php": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "c": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "js": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "css": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "html": ["fileicon-sys-s-web", "fileicon-sys-l-web"],
        "htm": ["fileicon-sys-s-web", "fileicon-sys-l-web"],
        "xhtml": ["fileicon-sys-s-web", "fileicon-sys-l-web"],
        "java": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "cc": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "python": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "json": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "sh": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "bat": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "ejs": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "xml": ["fileicon-sys-s-code", "fileicon-sys-l-code"],
        "ts": ["fileicon-sys-s-video", "fileicon-sys-l-video"],
        "wmv": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "rmvb": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mpeg4": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mpeg2": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "flv": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "avi": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "3gp": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mpga": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "qt": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "rm": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "wmz": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "wmd": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "wvx": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "wmx": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "wm": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mpg": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mp4": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mkv": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mpeg": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "mov": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "asf": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "m4v": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "m3u8": ["fileicon-small-video", "fileicon-large-video", "fileicon-middle-video"],
        "rar": ["fileicon-small-zip", "fileicon-large-zip", "fileicon-middle-zip"],
        "zip": ["fileicon-small-zip", "fileicon-large-zip", "fileicon-middle-zip"],
        "other": ["default-small", "default-large", ]
    };
    const name_re = new RegExp().compile(/(^[\d]*)/);
    const name_re2 = new RegExp().compile(/\d/g);

    function listSort(a, b) {
        if (a.isdir === b.isdir) {
            let key = "server_filename";
            let n1 = a[key].match(name_re),
                n2 = b[key].match(name_re);
            if (n1 === null || n2 === null) {
                return (a[key] + "").localeCompare(b[key] + "")
            } else {
                return parseInt(n1.join("")) - parseInt(n2.join(""))
            }
        } else {
            return a.isdir ? -1 : 1
        }
    }

    function listSort2(a, b) {
        if (a.isdir === b.isdir) {
            let key = "server_filename";
            let n1 = a[key].match(name_re2),
                n2 = b[key].match(name_re2);
            if (n1 === null || n2 === null) {
                return (a[key] + "").localeCompare(b[key] + "")
            } else {
                return parseInt(n1.join("")) - parseInt(n2.join(""))
            }
        } else {
            return a.isdir ? -1 : 1
        }
    }

    function pathChange(path) {
        let parentPath = yunData.FILEINFO[0].parent_path;
        let old = location.hash.split("&");
        let newArr = [];
        path = path.substring(0, path.lastIndexOf("/"))
        if (path === decodeURIComponent(parentPath)) {
            path = "/"
        }
        newArr.push("#list/path=" + encodeURIComponent(path));
        if (parentPath) {
            newArr.push("parentPath=" + parentPath)
        }
        old.forEach(function(item, i) {
            let data = item.split("=");
            if (data[0] === "#list/path") {} else if (data[0] === "parentPath") {} else {
                newArr.push(item)
            }
        });
        location.hash = newArr.join("&")
    }

    function conver_size_int_to_str(limit) {
        let size = "";
        let bit = 1;
        if (limit < Math.pow(1024, 1)) {
            size = limit.toFixed(bit) + "B"
        } else if (limit < Math.pow(1024, 2)) {
            size = (limit / Math.pow(1024, 1)).toFixed(bit) + "K"
        } else if (limit < Math.pow(1024, 3)) {
            size = (limit / (Math.pow(1024, 2))).toFixed(bit) + "M"
        } else {
            size = (limit / (Math.pow(1024, 3))).toFixed(bit) + "G"
        }
        let sizestr = size + "";
        let len = sizestr.indexOf(".");
        let dec = sizestr.substr(len + 1, bit);
        if (dec === "00") {
            return sizestr.substring(0, len) + sizestr.substr(len + bit + 1, 2)
        }
        return sizestr
    }

    function conver_size_str_to_int(sizestr) {
        let size = 0;
        if (sizestr.substring(sizestr.length - 2) === s.z) {
            size = parseInt(sizestr.substring(0, sizestr.length - 2)) * Math.pow(1024, 1)
        } else if (sizestr.substring(sizestr.length - 1) === s.v) {
            size = parseInt(sizestr.substring(0, sizestr.length - 1)) * Math.pow(1024, 2)
        } else if (sizestr.substring(sizestr.length - 1) === s.w) {
            size = parseInt(sizestr.substring(0, sizestr.length - 1)) * Math.pow(1024, 3)
        } else if (sizestr.substring(sizestr.length - 1) === s.aa) {
            size = parseInt(sizestr.substring(0, sizestr.length - 1)) * Math.pow(1024, 4)
        } else {}
        return size
    }
    Date.prototype.format = function() {
        return this.getFullYear() + '-' + (this.getMonth() + 1) + '-' + this.getDate() + " " + this.getHours() + ":" + this.getMinutes()
    };

    function formatDateTime(inputTime) {
        var date = new Date(inputTime);
        return date.format()
    };
    let get_uk = function() {
        return yunData.SHARE_UK
    };
    let get_shareid = function() {
        return yunData.SHARE_ID
    };
    let getCacheData = function(path) {
        path = path.substring(0, 1) != "/" ? "/" + path : path;
        if (cache.list.data.hasOwnProperty(path)) {
            if (cache.list.data[path].hasMore) {
                return false
            }
            return cache.list.data[path].list.sort(listSort2).sort(listSort)
        } else {
            return false
        }
    }
    let getList = function(path, page = 1) {
        return new Promise(function(resolve, reject) {
            if (page === 1) {
                path = path.substring(0, 1) != "/" ? "/" + path : path;
                path = encodeURIComponent(path)
            }
            let uk = get_uk(),
                shareid = get_shareid(),
                url = `/share/list?uk=${uk}&shareid=${shareid}&page=${page}&num=100&dir=${path}`;
            $.ajax({
                type: "GET",
                url: url,
                cache: false,
                async: true,
                success: function(res) {
                    if (res && res.list.length === 100) {
                        getList(path, page + 1).then(res2 => {
                            res.list.push.apply(res.list, res2.list);
                            resolve(res)
                        })
                    } else {
                        resolve(res)
                    }
                },
                failure: function(result) {
                    reject(false)
                },
                error: function(result) {
                    reject(false)
                },
            })
        })
    };
    let addNode = function(node, item, level) {},
        getItme = function(node) {},
        setState = function(node) {},
        itemToHTML = function(item, level, index) {
            let html = `<li><div class="treeview-node ${item.isdir ? '' : 'treenode-empty'}    "_pl="${level*15}px"style="padding-left:${level*15}px"><span class="treeview-node-handler"style="    margin-right: ${-((level-2)*15)}px;">${item.isdir?'':'<span style="position: absolute;left: 20px;color: #888;padding-left: '+((level-1)*15-10)+'px">'+index+'.</span>'}<em class="b-in-blk plus icon-operate"></em>${item.isdir?'<dfn class="b-in-blk treeview-ic">':getIconHTML(item.server_filename)}</dfn><span class="treeview-txt"node-level="${level}"node-path="${item.path}"node-category="${item.category}"node-fs_id="${item.fs_id}"node-isdir="${item.isdir}"node-local_ctime="${item.local_ctime}"node-local_mtime="${item.local_mtime}"node-md5="${item.md5}"node-server_ctime="${item.server_ctime}"node-server_filename="${item.server_filename}"node-server_mtime="${item.server_mtime}"node-size="${item.size}"owner-uk="">${item.server_filename}</span></span><div class="treeview-size">${item.isdir?'':conver_size_int_to_str(item.size)}</div><div class="treeview-time">${item.isdir?'':formatDateTime(item.server_mtime*1000)}</div></div><ul class="treeview  treeview-content treeview-collapse"_pl="${(level+1)*15}px"></ul></li>`;
            return html
        },
        listToHTML = function(list, level) {
            let html = "";
            let fileIndex = 0;
            for (let i = 0; i < list.length; i++) {
                if (!list[i].isdir) fileIndex++;
                html += itemToHTML(list[i], level, fileIndex)
            }
            return html
        },
        getIcon = function(filename) {
            let t = filename.lastIndexOf('.');
            if (t > 0) {
                let type = filename.substring(t + 1, filename.length);
                if (filesIcon.hasOwnProperty(type)) {
                    return filesIcon[type][0]
                }
            }
            return filesIcon.other[0]
        },
        getIconHTML = function(filename) {
            let html = '<dfn class="JS-fileicon '+ getIcon(filename) +'"style="height: 26px;width: 26px;display: inline-block;zoom: 1;vertical-align: middle;"></dfn>';
            return html
        };
    require.loadCss('/sns/box-static/disk-share/pkg/plugin_aef2d24.css')
    let treeHTML = '<div class="zfdev-tree-manager" id="zfdev-tree-manager" style="padding: 0 15px;"><div class="file-tree-container" style="overflow-y: auto; overflow-x: hidden;  height: 619px;"><ul class="treeview treeview-content"><li><div class="treeview-node   treeview-root _minus" _pl="0px" style="padding-left:0px"><span class="treeview-node-handler"><em class="b-in-blk plus icon-operate minus"></em><dfn class="b-in-blk treeview-ic"></dfn><span class="treeview-txt" node-path="/" node-isdir="1" owner-uk="">ZFDev Manager</span></span></div><ul class="treeview treeview-root-content treeview-content" _pl="15px"></ul></li></ul></div></div>';
    $('.KPDwCE').append(treeHTML);
    $("#zfdev-tree-manager .file-tree-container").css('height', $('#shareqr > div.KPDwCE  div.zJMtAEb div.NHcGw').css('height'));
    (function() {
        var observer = new MutationObserver(function(mutations, observer) {
            mutations.forEach(function(mutation) {
                $("#zfdev-tree-manager .file-tree-container").css('height', mutation.target.style.height)
            })
        });
        var config = {
            attributes: true,
            attributeOldValue: false,
            attributeFilter: ['style']
        };
        var el = document.querySelector('#shareqr > div.KPDwCE  div.zJMtAEb div.NHcGw');
        observer.observe(el, config)
    })();
    let $manager = $("#zfdev-tree-manager");
    let rowClick = function(e) {
        log("点击张开");
        let ul = e.parent().parent().next();
        let div = e.parent().parent();
        let textEle = e.next().next();
        let name = textEle.attr('node-server_filename');
        if (div.hasClass('treenode-empty')) {
            return false
        }
        if (e.hasClass('minus')) {
            ul.addClass('treeview-collapse');
            e.removeClass('minus');
            div.removeClass('_minus')
        } else {
            let path = textEle.attr('node-path'),
                level = textEle.attr('node-level'),
                isdir = parseInt(textEle.attr('node-isdir'));
            if (isdir && ul.children().length === 0) {
                let cureentCache = getCacheData(path);
                if (cureentCache) {
                    let html = listToHTML(cureentCache, parseInt(level) + 1);
                    ul.append(html)
                } else {
                    e.addClass('treeview-leaf-loading');
                    getList(path).then(res => {
                        e.removeClass('treeview-leaf-loading');
                        if (res && res.errno === 0) {
                            cache.list.data[path] = {
                                hasMore: false,
                                list: res.list.sort(listSort2).sort(listSort),
                                names: undefined,
                                share: 0
                            };
                            let html = listToHTML(res.list, parseInt(level) + 1);
                            ul.append(html);
                            if (res.list.length === 0) {
                                div.addClass('treenode-empty')
                            }
                        } else {
                            log('返回失败', res)
                        }
                    }, res => {
                        e.removeClass('treeview-leaf-loading')
                    })
                }
            }
            ul.removeClass('treeview-collapse');
            e.addClass('minus');
            div.addClass('_minus')
        }
    };
    $('body .zfdev-tree-manager').on('click', '.treeview-node', e => {
        log("点击张开");
        e = $(e.currentTarget);
        rowClick(e.find('em'));
        $('.treeview-node-on').removeClass('treeview-node-on');
        e.addClass('treeview-node-on');
        let path = e.find('.treeview-txt').attr('node-path');
        pathChange(path);
        setTimeout(function() {
            $('#shareqr div.zJMtAEb dd.JS-item-active .EOGexf').click();
            let name = e.find('.treeview-txt').attr('node-server_filename');
            $('#shareqr div.zJMtAEb dd:not(.JS-item-active):has(.file-name > .text:Contains("' + name + '")) .EOGexf').click()
        }, 200)
    });
    let btnHTML = '<a class="zfdev-tree-switch iconfont-zfdev-filetree icon-shuxing" value="false" href="javascript:void(0)"node-type="zfdev-tree"style="height:30px;width:30px;float:left;background:no-repeat;color:#5f6f95;font-size:20px;text-decoration:blink;"id="zfdev-tree-view-btn"></a>';
    $('#shareqr > div.module-toolbar div.list-grid-switch').append(btnHTML);
    $('#zfdev-tree-view-btn').click(function() {
        if ($('#zfdev-tree-manager').attr('value') === "true") {
            $('#shareqr > div.KPDwCE > div.zJMtAEb').css({
                display: 'block'
            });
            $('#shareqr > div.KPDwCE > div.fyQgAEb').css({
                display: 'none'
            });
            $('#zfdev-tree-manager').css({
                display: 'none'
            });
            $('#zfdev-tree-manager').attr('value', false)
        } else {
            $('#shareqr > div.KPDwCE > div.zJMtAEb').css({
                display: 'none'
            });
            $('#shareqr > div.KPDwCE > div.fyQgAEb').css({
                display: 'none'
            });
            $('#zfdev-tree-manager').css({
                display: ''
            });
            $('#zfdev-tree-manager').attr('value', true)
        }
    });
    $('#shareqr > div.KPDwCE > div.zJMtAEb, #shareqr > div.KPDwCE > div.fyQgAEb').click(function() {
        $('#zfdev-tree-manager').css({
            display: 'none'
        });
        $('#shareqr > div.KPDwCE > div.QxJxtg').css({
            display: ''
        })
    })
    let index = 0
    getCacheData('/').forEach(function(item, index) {
        let html = itemToHTML(item, 1, index);
        $manager.find('.treeview-root-content').append(html)
    })
    function listMenu(e) {
        var i = e("base:widget/libs/jquerypacket.js"),
            t = e("system-core:context/context.js").instanceForSystem,
            s = e("disk-share:widget/pageModule/list/listInit.js"),
            n = void 0,
            r = {
                treeTarget: "#zfdev-tree-manager",
            },
            copyItem = {},
            converItem = function(ele) {
                let item = {
                    category: parseInt(ele.attr('node-path')),
                    docpreview: ele.attr('node-docpreview'),
                    fs_id: parseInt(ele.attr('node-fs_id')),
                    isdir: parseInt(ele.attr('node-isdir')),
                    local_ctime: parseInt(ele.attr('node-local_ctime')),
                    local_mtime: parseInt(ele.attr('node-local_mtime')),
                    md5: ele.attr('node-md5'),
                    path: ele.attr('node-path'),
                    server_ctime: parseInt(ele.attr('node-server_ctime')),
                    server_filename: ele.attr('node-server_filename'),
                    server_mtime: parseInt(ele.attr('node-server_mtime')),
                    size: parseInt(ele.attr('node-size')),
                };
                return item
            },
            o = {
                top: [{
                    title: "展开全部",
                    action: function() {
                        let ul = $(this).closest('.treeview-node').next();
                        let textEle = ul.find('.treeview-txt');
                        ul.find("> li > .treeview-node:not(.treenode-empty) em.icon-operate:not(.minus)").click();
                        return true
                    },
                    display: function() {
                        let node = $(this).closest('.treeview-node');
                        let textEle = node.find('.treeview-txt');
                        let item = converItem(textEle);
                        if (!item.isdir) {
                            return false
                        }
                    },
                    keyboard: ""
                }, {
                    title: "折叠全部",
                    action: function() {
                        let ul = $(this).closest('.treeview-node').next();
                        let textEle = ul.find('.treeview-txt');
                        ul.find("> li > .treeview-node:not(.treenode-empty) em.icon-operate.minus").click();
                        return true
                    },
                    display: function() {
                        let node = $(this).closest('.treeview-node');
                        let textEle = node.find('.treeview-txt');
                        let item = converItem(textEle);
                        if (!item.isdir) {
                            return false
                        }
                    },
                    keyboard: ""
                }],
                middle: [],
                bottom: []
            };
        t.Broker.initMenuBroker({
            target: i(r.treeTarget)[0],
            type: "zfdev-tree",
            config: o,
            events: {
                beforeMenu: function() {
                    let node = $(this).closest('.treeview-node');
                    $('.treeview-node-on').removeClass('treeview-node-on');
                    node.addClass('treeview-node-on')
                },
                afterMenu: function() {
                    s.lock(!0)
                },
                menuHide: function() {
                    s.lock(!1)
                }
            }
        })
    };
    listMenu(require);

    function generateImage() {

        let $img = $("#zfdev-tree-manager-img");
        if ($img.length === 0) {
            let imgHTML = '<div id="zfdev-treeview-img-div"style=""><img id="zfdev-tree-manager-img"src=""style="height: auto;width: auto;max-width: 100%;max-height: 100%;display: block;margin: 0 auto;"><div style="display:block;"><a class="g-button"id="zfdev-treeview-img-zoom"href="javascript:;"title="放大"style="display:none;top:65px;"><span><em class="icon icon-picpre-enlarge"title="放大"style=""></em></span></a><a class="g-button"id="zfdev-treeview-img-download"href="javascript:;"title="下载"style="display:none;top:25px;"><span><em class="icon icon-download"title="下载"style=""></em></span></a><a class="g-button"id="zfdev-treeview-img-close"href="javascript:;"title="关闭"style="top:-15px;color:#666;"><span><em class="icon icon-close"title="关闭"style=""></em></span></a></div></div>';
            $("body").prepend($(imgHTML));
            $img = $('#zfdev-tree-manager-img');
            $('#zfdev-treeview-img-close').click(function() {
                $('#zfdev-treeview-img-div').remove()
            });
            $('#zfdev-treeview-img-download').click(function() {
                var link = document.createElement('a');
                link.href = $("#zfdev-tree-manager-img").attr('src');
                link.download = yunData.FILENAME + ".png";
                var e = document.createEvent('MouseEvents');
                e.initEvent('click', true, true);
                link.dispatchEvent(e);
                link.remove()
            });
            $('#zfdev-treeview-img-zoom').click(function() {
                let w = window.open('https://zfdev.com');
                w.document.write($("#zfdev-tree-manager-img")[0].outerHTML);
                w.document.body.style.background = "dimgrey";
                w.document.title = yunData.FILENAME;
                w.document.title += " 预览图";
            })
        }else{
            $('#zfdev-treeview-img-download').css('display', 'none');
            $('#zfdev-treeview-img-zoom').css('display', 'none');
            $('#zfdev-treeview-img-div').height('');
        }
        $img[0].src = "/box-static/system-core/system/uiService/tip/img/loading-white_e1bf1df.gif";

        var element = $('#zfdev-tree-manager .file-tree-container > .treeview-content ');
        var copyDom = element.clone();
        copyDom.css("background", "white");
        copyDom.addClass("zfdev-tree-manager");
        copyDom.find(".treeview-time").remove();
        copyDom.attr('id', "gengrate-image-copy-dom");
        copyDom.width("max-content");
        copyDom.css('visibility', 'hidden');
        $(copyDom).find('.treeview-node-on').removeClass('treeview-node-on');
        $('#bd').append(copyDom);
        let w = copyDom.width();
        w = w % 2 ? w + 1 : w;
        copyDom.width(w + "px");
        let h = copyDom.height();
        h = h % 2 ? h + 1 : h;
        h = h + 16;
        copyDom.height(h + "px");
        copyDom.css('visibility', 'unset')
        html2image(copyDom, $img[0]);

        function setWatermark(canvas, text, fsz) {
            let context = canvas.getContext('2d');
            context.font = 'bold ' + fsz + 'px Arial';
            context.textBaseline = 'bottom';
            context.fillStyle = '#ccc';
            context.strokeStyle = '#ccc';
            context.fillText(text, context.canvas.width - 150, context.canvas.height - 2);
            context.lineWidth = 2;
            context.strokeRect(0, 0, context.canvas.width, context.canvas.height)
        }

        function html2image(source, image) {
            html2canvas(source, {
                allowTaint: false,
                taintTest: false,
            }).then(function(canvas) {
                setWatermark(canvas, "由 ZFDev Manager 生成", 10);
                var imageData = canvas.toDataURL(1);
                image.src = imageData;
                source.remove();
                $('#zfdev-treeview-img-download').css('display', 'block');
                $('#zfdev-treeview-img-zoom').css('display', 'block');
                if (h > 600) {
                    $('#zfdev-treeview-img-div').height('600px')
                }
            })
        }
    }
    let generateImageHTML = '<a class="g-button" data-button-id="zfdev-filetree-image" id="share-zfdev-filetree-image-btn" data-button-index="2" href="javascript:;" title="预览图"><span class="g-button-right"><em class="iconfont-zfdev-filetree icon-shuxing" title="预览图"></em><span class="text" style="width: auto;padding-left: 5px;">预览图</span></span></a>';
    let $generate_image_button = $(generateImageHTML);
    $("#bd-main .module-share-header .slide-show-right .x-button-box").prepend($generate_image_button);
    $generate_image_button.click(function() {
        generateImage()
    });


    // 默认使用“文件树”视图, 不需要可关闭
    $('#zfdev-tree-view-btn').click()
})();