// ==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()
})();