| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588 | $(document).ready(function() {    let fileSearch;    autoFlashHeight();    $('#filing').height($(".sjs-height-0").height() - $('#add-slibing').parent().parent().height() - 10);    class FilingObj {        constructor(setting) {            // 原始数据整理后的树结构,用来整理zTree显示            this.dragTree = createDragTree({                id: 'id',                pid: 'tree_pid',                level: 'tree_level',                order: 'tree_order',                rootId: '-1'            });            // 界面显示的zTree            this.setting = setting;            this.filingTree = null;            this.pageCount = 15;            this.expandKey = 'filing-' + window.location.pathname.split('/')[2];            const cache = getLocalCache(this.expandKey);            this.expandCache = cache ? _.uniq(cache.split(',')) : [];            this.curFilingKey = 'cur-filing-' + window.location.pathname.split('/')[2];            $('#filing').height($(".sjs-height-0").height()-$('.d-flex',".sjs-height-0").height() - 10);            this.fileOrderKey = 'fileOrder';            this.fileOrder = getLocalCache(this.fileOrderKey) || 'create_time|desc';        }        refreshFileOrderButton() {            const orderBy = this.fileOrder.split('|');            const field = orderBy[0], sort = orderBy[1];            const buttons = $('[name=file-sort]');            for (const b of buttons) {                const curField = b.getAttribute('field');                if (curField === field) {                    $(b).html(`<i class="fa fa-sort-amount-${sort}" aria-hidden="true"></i>`).attr('tag', `${curField}|${sort === 'asc' ? 'desc' : 'asc'}`);                } else {                    $(b).html('<i class="fa fa-sort" aria-hidden="true">').attr('tag', `${curField}|desc`);                }            }        }        calcTotalFileCount() {            this.dragTree.recursiveFun(this.dragTree.children, x => {                if (x.children && x.children.length > 0) {                    x.total_file_count = x.children.reduce((pre, c) => {                        if (x.filing_type === 1) console.log('reduce', c.name, c.total_file_count);                        return pre + c.total_file_count                    }, 0);                } else {                    x.total_file_count = x.file_count || 0;                }                if (x.filing_type === 1) console.log(x.name, x.total_file_count);            });        }        _loadFilingSourceNode() {            const self = this;            const loadChildren = function(children) {                for (const child of children) {                    if (child.children && child.children.length > 0) loadChildren(child.children);                    child.source_node = self.dragTree.getItems(child.id);                }            };            const nodes = this.filingTree.getNodes();            loadChildren(nodes);        }        loadFiling() {            const self = this;            if (this.filingTree) $.fn.zTree.destroy(this.setting.treeId);            const sortNodes = this.dragTree.nodes.map(x => {                const result = {                    id: x.id,                    tree_pid: x.tree_pid,                    name: x.name + (x.total_file_count > 0 ? `(${x.total_file_count})` : ''),                    spid: x.spid,                    tips: x.tips || '',                };                if (x.is_fixed) result.isParent = true;                if (x.is_folder || x.is_fixed) result.open = self.expandCache.indexOf(result.id) >= 0;                return result;            });            this.filingTree = $.fn.zTree.init($('#filing'), this.setting, sortNodes);            this._loadFilingSourceNode();            const curCache = getLocalCache(this.curFilingKey);            const curNode = curCache ? this.filingTree.getNodeByParam('id', curCache) : null;            if (curNode){                this.filingTree.selectNode(curNode);                filingObj.setCurFiling(curNode);            }        }        analysisFiling(data) {            this.dragTree.loadDatas(data);            this.calcTotalFileCount();            this.loadFiling();        }        _getFileNameHtml(file) {            const moveHtml = file.canEdit ? `<a href="javascript: void(0);" class="mr-1" name="move-file" fid="${file.id}"><i class="fa fa-exchange fa-fw"></i></a>` : '';            const editHtml = file.canEdit ? `<a href="javascript: void(0);" class="mr-1" name="edit-file" fid="${file.id}"><i class="fa fa-pencil fa-fw"></i></a>` : '';            const viewHtml = file.viewpath ? `<a href="${file.viewpath}" class="mr-1" target="_blank"><i class="fa fa-eye fa-fw"></i></a>` : '';            const downHtml = `<a href="javascript: void(0);" onclick="AliOss.downloadFile('${file.filepath}', '${file.filename + file.fileext}')" class="mr-1"><i class="fa fa-download fa-fw"></i></a>`;            const delHtml = file.canEdit || canDelete ? `<a href="javascript: void(0);" class="mr-1 text-danger" name="del-file" fid="${file.id}"><i class="fa fa-trash-o fa-fw"></i></a>` : '';            return `<div class="d-flex justify-content-between align-items-center table-file"><div name="filename" fid="${file.id}">${file.filename}${file.fileext}</div><div class="btn-group-table" style="display: none;">${moveHtml}${editHtml}${viewHtml}${downHtml}${delHtml}</div></div>`;        }        _getEditFileNameHtml(file) {            const inputHtml = `<input type="text" class="form-control form-control-sm form-control-width" maxlength="100" value="${file.filename + file.fileext}" fid="${file.id}">`;            const btnHtml = `<div class="btn-group-table" style="display: none;"><a href="javascript: void(0)" class="mr-1" name="edit-file-ok"><i class="fa fa-check fa-fw"></i></a><a href="javascript: void(0)" class="mr-1" name="edit-file-cancel"><i class="fa fa-remove fa-fw"></i></a></div>`;            return `<div class="d-flex justify-content-between align-items-center table-file"><div>${inputHtml}</div>${btnHtml}</div>`;        }        _getFileHtml(file) {            const html = [];            html.push(`<tr fid="${file.id}">`);            html.push(`<td class="text-center"><input type="checkbox" name="bd-check" fid="${file.id}"></td>`);            html.push(`<td fid="${file.id}">${this._getFileNameHtml(file)}</td>`);            html.push(`<td class="text-center">${file.user_name}</td>`);            html.push(`<td class="text-center">${moment(file.create_time).format('YYYY-MM-DD HH:mm:ss')}</td>`);            html.push(`<td class="text-center">${file.fileext_str}</td>`);            html.push('</tr>');            return html.join('');        }        refreshFilesTable() {            const html = [];            const files = this.curFiling.source_node.files;            if (!files || files.length === 0) {                $('#file-list').html('');                return;            }            const startIndex = (this.curPage - 1)*this.pageCount;            const endIndex = this.curPage*this.pageCount;            for (const [i, f] of files.entries()) {                if (i < startIndex || i >= endIndex) continue;                html.push(this._getFileHtml(f));            }            $('#file-list').html(html.join(''));        }        refreshPages() {            if (!filingObj.curFiling) return;            filingObj.curTotalPage = Math.ceil(filingObj.curFiling.source_node.file_count / this.pageCount);            filingObj.curPage = Math.min(filingObj.curTotalPage, Math.max(filingObj.curPage, 1));            $('#curPage').html(filingObj.curPage);            $('#curTotalPage').html(filingObj.curTotalPage);            if (filingObj.curTotalPage > 1) {                $('#showPage').show();            } else {                $('#showPage').hide();            }        }        async loadFiles(node, page) {            if (node.source_node.children && node.source_node.children.length > 0) return;            if (!node.source_node.files) node.source_node.files = [];            if (!node.source_node.file_count) return;            if (node.source_node.files && node.source_node.files.length === node.source_node.file_count) return;            const needFiles = Math.min(page*this.pageCount, node.source_node.file_count);            if (node.source_node.files && needFiles <= node.source_node.files.length) return;            const files = await postDataAsync('file/load', { filing_id: node.id, page, count: this.pageCount, order: this.fileOrder });            files.forEach(x => {                const file = node.source_node.files.find(f => {return x.id === f.id; });                if (file) {                    Object.assign(file, x);                } else {                    node.source_node.files.push(x);                }            });            // node.source_node.files.sort((x, y) => {            //     return x.create_time - y.create_time;            // });        }        addSiblingFiling(node) {            const self = this;            postData('filing/add', { tree_pid: node.tree_pid, tree_pre_id: node.id }, function(result) {                const refreshData = self.dragTree.loadPostData(result);                const newNode = refreshData.create[0];                const nodes = self.filingTree.addNodes(node.getParentNode(), node.getIndex() + 1, [{ id: newNode.id, tree_pid: newNode.tree_pid, name: newNode.name, spid: newNode.spid }]);                nodes[0].source_node = newNode;            });        }        addChildFiling(node) {            const self = this;            postData('filing/add', { tree_pid: node.id }, function(result) {                const refreshData = self.dragTree.loadPostData(result);                const newNode = refreshData.create[0];                const nodes = self.filingTree.addNodes(node, -1, [{ id: newNode.id, tree_pid: newNode.tree_pid, name: newNode.name, spid: newNode.spid}]);                nodes[0].source_node = newNode;            });        }        delFiling(node, callback) {            const parent = node.getParentNode();            const self = this;            postData('filing/del', { id: node.id }, function(result) {                self.updateFilingFileCount(node, 0);                self.dragTree.loadPostData(result);                self.filingTree.removeNode(node);                self.calcTotalFileCount();                if (parent) {                    const path = parent.getPath();                    for (const p of path) {                        p.name = p.source_node.name + (p.source_node.total_file_count > 0 ? `(${p.source_node.total_file_count})` : '');                        if (p.source_node.is_fixed) p.isParent = true;                        filingObj.filingTree.updateNode(p);                    }                }                if (callback) callback();            });        }        async renameFiling(node, newName) {            const result = await postDataAsync('filing/save', { id: node.id, name: newName });            node.source_node.name = newName;            node.name = node.source_node.name + (node.source_node.total_file_count > 0 ? `(${node.source_node.total_file_count})` : '');            return result;        }        updateFilingFileCount(filing, count) {            let differ = count - (filing.source_node.file_count || 0);            filing.source_node.file_count = count;            filing.source_node.total_file_count = count;            filing.name = filing.source_node.name + (filing.source_node.total_file_count > 0 ? `(${filing.source_node.total_file_count})` : '');            filingObj.filingTree.updateNode(filing);            let parent = filing.getParentNode();            while (!!parent) {                parent.source_node.total_file_count = parent.source_node.total_file_count ? parent.source_node.total_file_count + differ : differ;                parent.name = parent.source_node.name + (parent.source_node.total_file_count > 0 ? `(${parent.source_node.total_file_count})` : '');                filingObj.filingTree.updateNode(parent);                parent = parent.getParentNode();            }        }        checkFilesExist(files, callback) {            const data = [];            for (const file of files) {                if (file === undefined) return [];                data.push(file.name);            }            postData('file/check', { filing_id: filingObj.curFiling.id, files: data }, function(result) {                callback(result);            });        }        uploadFiles(files, filterFiles, callback) {            const formData = new FormData();            formData.append('filing_id', filingObj.curFiling.id);            let count = 0;            for (const file of files) {                if (filterFiles.indexOf(file.name) >= 0) continue;                if (file === undefined) {                    toastr.error('未选择上传文件。');                    return false;                }                if (file.size > 50 * 1024 * 1024) {                    toastr.error('上传文件大小超过50MB。');                    return false;                }                const fileext = '.' + file.name.toLowerCase().split('.').splice(-1)[0];                if (whiteList.indexOf(fileext) === -1) {                    toastr.error('仅支持office文档、图片、压缩包格式,请勿上传' + fileext + '格式文件。');                    return false;                }                formData.append('size', file.size);                formData.append('file[]', file);                count++;            }            if (count === 0) {                toastr.warning('没有可上传的文件');                return false;            }            postDataWithFile('file/upload', formData, function (data) {                filingObj.updateFilingFileCount(filingObj.curFiling, data.filing.file_count);                filingObj.curFiling.source_node.files.unshift(...data.files);                filingObj.refreshPages();                filingObj.refreshFilesTable();                if (callback) callback();            });        }        uploadBigFile(file, callback) {            if (file.size > 500 * 1024 * 1024) {                toastr.error('上传文件大小超过500MB。');                return false;            }            const fileext = '.' + file.name.toLowerCase().split('.').splice(-1)[0];            if (whiteList.indexOf(fileext) === -1) {                toastr.error('仅支持office文档、图片、压缩包格式,请勿上传' + fileext + '格式文件。');                return false;            }            AliOss.uploadBigFile(file, 'file/upload/big', { filing_id: filingObj.curFiling.id },                { progressObj: $('#upload-big-file-progress'), resumeObj: $('#add-big-file-resume'), stopObj: $('#add-big-file-stop') },                function(result) {                    filingObj.curFiling.source_node.files.unshift(...result.files);                    filingObj.updateFilingFileCount(filingObj.curFiling, result.filing.file_count);                    filingObj.refreshPages();                    filingObj.refreshFilesTable();                    if (callback) callback();            });        }        delFiles(files, callback) {            postData('file/del', { del: files }, async function(data) {                const relaFiling = data.filing.id === filingObj.curFiling.source_node.id                    ? filingObj.curFiling : filingObj.findFiling(data.filing.id);                for (const id of data.del) {                    const fIndex = relaFiling.source_node.files.findIndex(x => { return x.id === id });                    if (fIndex >= 0) relaFiling.source_node.files.splice(fIndex, 1);                    fileSearch.removeSearchFile(id);                }                filingObj.updateFilingFileCount(relaFiling, data.filing.file_count);                await filingObj.loadFiles(relaFiling, filingObj.curPage);                if (data.filing.id === filingObj.curFiling.source_node.id) {                    filingObj.refreshPages();                    filingObj.refreshFilesTable();                }                if (callback) callback();            });        }        renameFile(file, filename) {            const self = this;            const td = $(`td[fid=${file.id}]`);            postData('file/save', { id: file.id, filename }, function(data) {                const relaFiling = filingObj.findFiling(file.filing_id);                const relaFile = relaFiling.source_node.files.find(x => { return x.id === file.id });                relaFile.filename = data.filename;                relaFile.fileext = data.fileext;                td.html(self._getFileNameHtml(relaFile));                fileSearch.renameSearchFile(file.id, data);            }, function() {                td.html(self._getFileNameHtml(file));                fileSearch.renameSearchFile(file.id);            });        }        relaFiles(files, callback) {            postData('file/rela', { filing_id: this.curFiling.id, files: files }, async function(data) {                filingObj.curFiling.source_node.files.unshift(...data.files);                filingObj.updateFilingFileCount(filingObj.curFiling, data.filing.file_count);                filingObj.refreshFilesTable();                filingObj.refreshPages();                if (callback) callback();            });        }        moveFile(file, filingId, callback) {            if (file.filing_id === filingId) {                callback();                return;            }            postData('file/move', { id: file.id, filingId: filingId }, function(data) {                const orgFiling = filingObj.findFiling(file.filing_id);                filingObj.updateFilingFileCount(orgFiling, orgFiling.source_node.file_count - 1);                const fIndex = orgFiling.source_node.files.findIndex(x => { return x.id === file.id });                if (fIndex >= 0) orgFiling.source_node.files.splice(fIndex, 1);                const targetFiling = filingObj.findFiling(filingId);                filingObj.updateFilingFileCount(targetFiling, targetFiling.source_node.file_count + 1);                if (file.filing_id === filingObj.curFiling.source_node.id) {                    filingObj.refreshPages();                    filingObj.refreshFilesTable();                }                fileSearch.refreshSearchFile(data.file);                callback();            });        }        async setCurFiling(node) {            filingObj.curFiling = node;            filingObj.curPage = 1;            filingObj.refreshPages();            if (filingObj.curFiling.source_node.children && filingObj.curFiling.source_node.children.length > 0) {                $('#file-view').hide();            } else {                $('#file-view').show();                await filingObj.loadFiles(node, 1);                filingObj.refreshFilesTable();            }            if (filingObj.curFiling.source_node.filing_type === 5) {                $('#rela-file-btn').show();            } else {                $('#rela-file-btn').hide();            }            setLocalCache(this.curFilingKey, filingObj.curFiling.id);        }        findFiling(id) {            return filingObj.filingTree.getNodeByParam('id', id);        }        prePage() {            if (this.curPage === 1) return;            this.curPage = this.curPage - 1;            this.refreshPages();            this.refreshFilesTable();        }        async nextPage() {            if (this.curPage === this.curTotalPage) return;            await filingObj.loadFiles(this.curFiling, this.curPage + 1);            this.curPage = this.curPage + 1;            this.refreshPages();            this.refreshFilesTable();        }        getCurFilingFullPath(){            let cur = filingObj.curFiling;            const result = [];            while (cur) {                result.unshift(cur.source_node.name);                cur = cur.getParentNode();            }            return result.join('/');        }        expandFiling(node, expand) {            if (expand) {                this.expandCache.push(node.id);            } else{                this.expandCache = this.expandCache.filter(x => { return x !== node.id });            }            setLocalCache(this.expandKey, this.expandCache.join(','));        }        expandByLevel(level) {            this.expandByCustom(x => {                return x.level + 1 < level;            })        }        expandByCustom(fun) {            const self = this;            const expandCache = [];            const expandChildren = function(children) {                for (const child of children) {                    if (!child.children || child.children.length === 0) continue;                    const expand = fun(child);                    if (expand) expandCache.push(child.id);                    self.filingTree.expandNode(child, expand, false, false);                    expandChildren(child.children);                }            };            const nodes = this.filingTree.getNodes();            expandChildren(nodes);            this.expandCache = expandCache;            setLocalCache(this.expandKey, this.expandCache.join(','));        }        moveFiling(node, tree_pid, tree_order) {            if (tree_pid === node.source_node.tree_pid && tree_order === node.source_node.tree_order) return;            const self = this;            postData('filing/move', { id: node.id, tree_pid, tree_order }, function(result) {                const refresh = self.dragTree.loadPostData(result);                self.calcTotalFileCount();                const updated = [];                for (const u of refresh.update) {                    const node = self.filingTree.getNodeByParam('id', u.id);                    if (node) {                        const path = node.getPath();                        for (const p of path) {                            if (updated.indexOf(p.id) >= 0) continue;                            p.name = p.source_node.name + (p.source_node.total_file_count > 0 ? `(${p.source_node.total_file_count})` : '');                            filingObj.filingTree.updateNode(p);                            updated.push(p.id);                        }                    }                }            });        }        _clearAllFileCache() {            const nodes = this.filingTree.getNodes();            for (const node of nodes) {                if (node.children && node.children.length > 0) continue;                if (node.source_node.files) node.source_node.files.length = 0;            }        }        changeFileOrder(fileOrder) {            this.fileOrder = fileOrder;            setLocalCache(this.fileOrderKey, fileOrder);            this.refreshFileOrderButton();            this._clearAllFileCache();            this.setCurFiling(this.curFiling);        }        getNodeFilingType(node) {            if (!node.is_fixed) return [];            const types = [];            if (node.children && node.children.length > 0) {                for (const child of node.children) {                    const childTypes = this.getNodeFilingType(child);                    if (childTypes.length > 0) types.push(...childTypes);                }            }            if (types.length === 0) types.push(node.filing_type);            return types;        }        getParentFilingType(node) {            const parent = this.dragTree.getParent(node);            if (!parent) return [];            if (parent.is_fixed) return [parent.filing_type];            return this.getParentFilingType(parent);        }        getAllFilingType() {            const types = [];            for (const node of this.dragTree.children) {                types.push(...this.getNodeFilingType(node))            }            return types;        }        getCurFilingType() {            const cur = filingObj.curFiling;            const node = this.dragTree.nodes.find(x => { return x.id === cur.source_node.id; });            return node.is_fixed ? this.getNodeFilingType(node) : this.getParentFilingType(node);        }    }    const levelTreeSetting = {        treeId: 'filing',        view: {            selectedMulti: false,            showTitle: true,        },        data: {            simpleData: {                idKey: 'id',                pIdKey: 'tree_pid',                rootPId: '-1',                enable: true,            },            key: { title: 'tips' },        },        edit: {            enable: true,            showRemoveBtn: function(treeId, treeNode) {                if (!canFiling) return false;                return !treeNode.source_node.is_fixed;            },            showRenameBtn: function(treeId, treeNode) {                if (!canFiling) return false;                return !treeNode.source_node.is_fixed;            },            renameTitle: '编辑',            removeTitle: '删除',            drag: {                isCopy: false,                isMove: true,                pre: true,                next: true,                inner: false,            },            editNameSelectAll: true,        },        callback: {            onClick: async function (e, key, node) {                if (filingObj.curFiling && filingObj.curFiling.id === node.id) return;                filingObj.setCurFiling(node);            },            beforeEditName: function(key, node) {                node.name = node.source_node.name;            },            beforeRename: async function(key, node, newName, isCancel) {                if (!isCancel) await filingObj.renameFiling(node, newName);                return true;            },            onRename: function(e, key, node, isCancel) {                node.name = node.name + (node.source_node.total_file_count > 0 ? `(${node.source_node.total_file_count})` : '');                filingObj.filingTree.updateNode(node);            },            beforeRemove: function(key, node, isCancel) {                $('#del-filing').modal('show');                return false;            },            onExpand(e, key, node) {                filingObj.expandFiling(node, true);            },            onCollapse: function(e, key, node) {                filingObj.expandFiling(node, false);            },            beforeDrop: function(key, nodes, target, moveType, isCopy) {                if (!canFiling) return false;                if (!target) return false;                if (nodes[0].level < 1) {                    toastr.error('顶层节点请勿移动');                    return false;                }                if (nodes[0].is_fixed) {                    toastr.error('固定分类请勿移动');                    return false;                }                if (nodes[0].source_node.filing_type !== target.source_node.filing_type) {                    toastr.error('请勿跨越最顶层节点移动');                    return false;                }                if (target.source_node.file_count > 0 && moveType === 'inner') {                    toastr.error(`节点[${target.source_node.name}]下存在文件,不可添加子级`);                    return false;                }                const order = nodes[0].getIndex() + 1;                const targetOrder = target.getIndex() + 1;                const targetMax = target.getParentNode().children.length;                if (moveType === 'prev') {                    if (target.tree_pid === nodes[0].tree_pid) {                        if (targetOrder > order) {                            filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder === 1 ? 1 : targetOrder - 1);                        } else {                            filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder === 1 ? 1 : targetOrder);                        }                    } else {                        filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder === 1 ? 1 : targetOrder);                    }                } else if (moveType === 'next') {                    if (target.tree_pid === nodes[0].tree_pid) {                        if (targetOrder < order) {                            filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder === targetMax ? targetMax : targetOrder + 1);                        } else {                            filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder === targetMax ? targetMax : targetOrder);                        }                    } else {                        filingObj.moveFiling(nodes[0], target.tree_pid, targetOrder + 1);                    }                } else if (moveType === 'inner') {                    filingObj.moveFiling(nodes[0], target.tree_id, targetMax + 1);                }            }        }    };    const filingObj = new FilingObj(levelTreeSetting);    filingObj.analysisFiling(filing);    $('#add-slibing').click(() => {        if (!filingObj.curFiling) return;        if (filingObj.curFiling.source_node.is_fixed) {            toastr.error('固定分类不可添加同级');            return;        }        filingObj.addSiblingFiling(filingObj.curFiling);    });    $('#add-child').click(() => {        if (!filingObj.curFiling) return;        const fixedChild = filingObj.curFiling.source_node.children.find(x => { return x.is_fixed; });        if (fixedChild) {            toastr.error('该分类下存在固定分类,不可添加子级');            return;        }        if (filingObj.curFiling.source_node.file_count > 0) {            toastr.error('该分类下已导入文件,不可添加子级');            return;        }        filingObj.addChildFiling(filingObj.curFiling);    });    $('[name=file-sort]').click(function() {        const tag = this.getAttribute('tag');        filingObj.changeFileOrder(tag);    });    // $('#del-filing-btn').click(() => {    //     if (!filingObj.curFiling) return;    //     if (filingObj.curFiling.source_node.is_fixed) {    //         toastr.error('固定分类不可删除');    //         return;    //     }    //    //     $('#del-filing').modal('show');    // });    $('#del-filing-ok').click(() => {        filingObj.delFiling(filingObj.curFiling, function() {            $('#del-filing').modal('hide');        });    });    $('#add-file').on('show.bs.modal', function() {        $('#filter-same')[0].checked = false;        $('#filter-same').parent().hide();        $('#upload-file-hint').hide();        $('#upload-file')[0].value = '';        if ($('#add-file-ok').hasClass('btn-warning')) $('#add-file-ok').removeClass('btn-warning').addClass('btn-primary');    });    $('#upload-file').change(() => {        $('#add-file-ok').attr('disabled', true);        const input = $('#upload-file');        filingObj.checkFilesExist(input[0].files, function(result) {            if (result.length === 0) {                $('#upload-file-hint').hide();                $('#add-file-ok').removeClass('btn-warning').addClass('btn-primary').attr('disabled', false);                $('#filter-same').parent().hide();            } else {                const msg = result[0] + (result.length > 1 ? `(等${result.length}个文件)`: '') + '</br>存在同名文件,请确认是否上传重复';                $('#upload-file-hint').html(msg).show();                $('#add-file-ok').removeClass('btn-primary').addClass('btn-warning').attr('disabled', false);                $('#filter-same').parent().show();                $('#filter-same').attr('filterFiles', result.join('$;$'));            }        });    });    $('#add-file-ok').click(() => {        const input = $('#upload-file');        const filter = $('#filter-same')[0].checked;        const filterFiles = filter ? $('#filter-same').attr('filterFiles').split('$;$') : [];        filingObj.uploadFiles(input[0].files, filterFiles, function() {            $(input).val('');            $('#add-file').modal('hide');        });    });    $('#add-big-file').on('show.bs.modal', function() {        $('#upload-big-file-hint').hide();        $('#upload-big-file')[0].value = '';        if ($('#add-big-file-ok').hasClass('btn-warning')) $('#add-big-file-ok').removeClass('btn-warning').addClass('btn-primary');    });    $('#upload-big-file').change(() => {        $('#add-big-file-ok').attr('disabled', true);        const input = $('#upload-big-file');        filingObj.checkFilesExist(input[0].files, function(result) {            if (result.length === 0) {                $('#upload-big-file-hint').hide();                $('#add-big-file-ok').removeClass('btn-warning').addClass('btn-primary').attr('disabled', false);            } else {                $('#upload-big-file-hint').html('存在同名文件,请确认是否上传重复').show();                $('#add-big-file-ok').removeClass('btn-primary').addClass('btn-warning').attr('disabled', false);            }        });    });    $('#add-big-file-ok').click(() => {        const input = $('#upload-big-file');        filingObj.uploadBigFile(input[0].files[0], function () {            $('#upload-big-file').val('');            $('#add-big-file').modal('hide');        });    });    $('body').on('mouseenter', ".table-file", function(){        $(this).children(".btn-group-table").css("display","block");    });    $('body').on('mouseleave', ".table-file", function(){        $(this).children(".btn-group-table").css("display","none");    });    $('body').on('click', "a[name=del-file]", function() {        const del = [this.getAttribute('fid')];        filingObj.delFiles(del);    });    $('body').on('click', "a[name=edit-file]", function() {        const check = $('[name=filename] input[fid]');        if (check.length > 0 && check[0].getAttribute('fid') === this.getAttribute('fid')) return;        const id = this.getAttribute('fid');        const file = filingObj.curFiling.source_node.files.find(x => { return x.id === id });        $(`td[fid=${id}]`).html(filingObj._getEditFileNameHtml(file));    });    $('body').on('click', "a[name=edit-file-ok]", function() {        const td = $(this).parent().parent().parent();        const fid = td.attr('fid');        const file = filingObj.curFiling.source_node.files.find(x => { return x.id === fid });        if (!file) return;        const filename = $('input', td).val();        if (filename === file.filename + file.fileext) {            td.html(this._getFileNameHtml(file));            return;        }        filingObj.renameFile(file, filename);    });    $('body').on('click', "a[name=edit-file-cancel]", function() {        const td = $(this).parent().parent().parent();        const fid = td.attr('fid');        const file = filingObj.curFiling.source_node.files.find(x => { return x.id === fid });        if (!file) return;        td.html(filingObj._getFileNameHtml(file));    });    class MoveFileObj {        constructor() {            const self = this;            this.setting = {                treeId: 'moveTree',                view: {                    selectedMulti: false,                    showTitle: true,                },                data: {                    simpleData: {                        idKey: 'id',                        pIdKey: 'tree_pid',                        rootPId: '-1',                        enable: true,                    },                    key: { title: 'tips' },                },                edit: {                    enable: false,                },            };            this.moveTree = null;            $('#move-file2-ok').click(function() {                const targetFiling = self.moveTree.getSelectedNodes()[0];                if (!targetFiling) {                    toastr.warning('请选择目标分类');                    return;                }                if (targetFiling.children && targetFiling.children.length > 0) {                    toastr.warning('请选择最底层目标分类');                    return;                }                filingObj.moveFile(self.file, targetFiling.id, function() {                    $('#move-file2').modal('hide');                });            });            // 显示层次            (function (select) {                $(select).click(function () {                    const tag = $(this).attr('tag');                    setTimeout(() => {                        showWaitingView();                        switch (tag) {                            case "1":                            case "2":                            case "3":                            case "4":                                self.expandByLevel(parseInt(tag));                                break;                            case "last":                                self.expandByCustom(() => { return true; });                                break;                        }                        closeWaitingView();                    }, 100);                });            })('a[name=mf2-showLevel]');        }        expandByLevel(level) {            this.expandByCustom(x => {                return x.level + 1 < level;            })        }        expandByCustom(fun) {            const self = this;            const expandChildren = function(children) {                for (const child of children) {                    if (!child.children || child.children.length === 0) continue;                    const expand = fun(child);                    self.moveTree.expandNode(child, expand, false, false);                    expandChildren(child.children);                }            };            const nodes = this.moveTree.getNodes();            expandChildren(nodes);        }        initMoveTree() {            if (this.moveTree) $.fn.zTree.destroy(this.setting.treeId);            const sortNodes = filingObj.dragTree.nodes.map(x => {                const result = {                    id: x.id,                    tree_pid: x.tree_pid,                    name: x.name,                    spid: x.spid,                    tips: x.tips || '',                };                if (x.is_fixed) result.isParent = true;                return result;            });            this.moveTree = $.fn.zTree.init($('#moveFile'), this.setting, sortNodes);        }        show (file) {            this.file = file;            this.initMoveTree();            $('#move-file2').modal('show');        }    }    const moveFileObj = new MoveFileObj();    $('body').on('click', "a[name=move-file]", function() {        const id = this.getAttribute('fid');        const file = filingObj.curFiling.source_node.files.find(x => { return x.id === id });        moveFileObj.show(file);    });    // $('body').on('blur', "[name=filename] input[fid]", function() {    //     filingObj.renameFile(this.getAttribute('fid'), this.value);    // });    // $('body').on('keypress', "[name=filename] input[fid]", function(e) {    //     if (e.keyCode == 13) {    //         filingObj.renameFile(this.getAttribute('fid'), this.value);    //     }    // });    $('.page-select').click(function() {        const content = this.getAttribute('content');        switch(content) {            case 'pre': filingObj.prePage(); break;            case 'next': filingObj.nextPage(); break;            default: return;        }    });    $('#batch-download').click(function () {        const self = this;        const files = [];        const checkes = $('[name=bd-check]:checked');        checkes.each(function() {            const fid = this.getAttribute('fid');            const file = filingObj.curFiling.source_node.files.find(x => { return x.id === fid; });            file && files.push(file);        });        if (files.length === 0) return;        $(self).attr('disabled', 'true');        AliOss.zipFiles(files, filingObj.curFiling.source_node.name + '.zip', (fails) => {            $(self).removeAttr('disabled');            if (fails.length === 0) {                toastr.success('下载成功');            } else {                toastr.warning(`下载成功(${fails.length}个文件下载失败)`);            }        }, () => {            $(self).removeAttr('disabled');            toastr.error('批量下载失败');        });    });    $('#batch-del-file-btn').click(() => {        const checkes = $('[name=bd-check]:checked');        if (checkes.length === 0) {            return;        } else {            for (const c of checkes) {                const fid = c.getAttribute('fid');                const file = filingObj.curFiling.source_node.files.find(x => { return x.id === fid });                if (!file) continue;                if (file.user_id !== userID) {                    toastr.error(`文件【${file.filename + file.fileext}】不是您上传的文件,请勿删除`);                    return;                }            }        }        $('#batch-del-file').modal('show');    });    $('#batch-del-file-ok').click(function() {        const del = [];        const checkes = $('[name=bd-check]:checked');        checkes.each(function() {            del.push(this.getAttribute('fid'));        });        filingObj.delFiles(del, function() {            $('#batch-del-file').modal('hide');        });    });    class RelaFileLoader {        constructor() {            const self = this;            // 可导入的标段            this.treeSetting = {                view: {                    selectedMulti: false                },                data: {                    simpleData: {                        idKey: 'id',                        pIdKey: 'tree_pid',                        rootPId: '-1',                        enable: true,                    }                },                edit: {                    enable: false,                },                callback: {                    onClick: async function (e, key, node) {                        if (this.curTender && this.curTender.id === node.id) return;                        self.setCurTender(node);                    },                }            };            $('body').on('click', '[name=rf-check]', function () {                self.selectFile(this.getAttribute('rfid'), this.checked);            });            $('#tf-type').change(function() {                self.selectTfType(this.value);            });            $('#tf-sub-type').change(function() {                self.selectTfSubType(this.value);            });            $('#tf-stage').change(function() {                self.selectTfStage(this.value);            });            $('#rela-file-ok').click(function() {                const selectFiles = self.getSelectRelaFile();                filingObj.relaFiles(selectFiles, function() {                    $('#rela-file').modal('hide');                });            });        }        clearFileSelect() {            if (!this.tenderTree) return;            const nodes = this.tenderTree.getNodes();            nodes.forEach(node => {                const x = node.source_node;                x.selectFiles = [];                if (x.att) x.att.forEach(la => { la.checked = false });                if (x.advance) {                    x.advance.forEach(a => {                        if (a.files) a.files.forEach(aa => { aa.checked = false });                    });                }                if (x.stage) {                    x.stage.forEach(s => {                        if (s.att) s.att.forEach(sa => { sa.checked = false });                    })                }            });        }        refreshSelectHint(){            if (this.curTender) {                $('#cur-tender-hint').html(`当前标段,已选${this.curTender.source_node.selectFiles.length}文件`);            } else {                $('#cur-tender-hint').html('');            }            const nodes = this.tenderTree.getNodes();            const selectTenders = nodes.filter(x => { return x.source_node.selectFiles.length > 0; });            if (selectTenders.length > 0) {                const count = selectTenders.reduce((rst, x) => { return rst + x.source_node.selectFiles.length; }, 0);                $('#rela-file-hint').html(`已选择${selectTenders.length}个标段,共${count}个文件`);            } else {                $('#rela-file-hint').html('未选择标段、文件');            }        }        selectFile(fileId, isSelect) {            const file = this.curFiles.find(x => { return x.rf_id == fileId });            if (file) {                file.checked = isSelect;                if (isSelect) {                    this.curTender.source_node.selectFiles.push(file);                } else {                    const index = this.curTender.source_node.selectFiles.findIndex(x => { return x.rf_id === file.rf_id });                    this.curTender.source_node.selectFiles.splice(index, 1);                }                this.refreshSelectHint();            }        }        async showRelaFile(){            $('#rela-filing-hint').html(`当前目录:${filingObj.getCurFilingFullPath()}`);            if (!this.tenderTree) {                const tenders = await postDataAsync('file/rela/tender', {});                const sortNodes = tenders.map(x => {                    return { id: x.id, tree_pid: -1, name: x.name, source_node: x };                });                this.tenderTree = this.filingTree = $.fn.zTree.init($('#rela-tender'), this.treeSetting, sortNodes);            }            this.clearFileSelect();            this.refreshSelectHint();            const firstNode = this.filingTree.getNodes()[0];            if (firstNode) {                this.filingTree.selectNode(firstNode);                await this.setCurTender(firstNode);            }        }        refreshTenderFileStage() {            if (this.rfType.sub_type) {                const type = this.tenderFileType.find(x => { return x.value === this.rfType.type});                const subType = type.subType ? type.subType.find(x => { return x.value === this.rfType.sub_type; }) : null;                if (subType) {                    this.rfType.stage = subType.stage[0].value;                    const html= [];                    for (const stage of subType.stage) {                        html.push(`<option value="${stage.value}">${stage.text}</option>`);                    }                    $('#tf-stage').html(html.join('')).show();                } else {                    $('#tf-stage').html('').hide();                }            } else {                $('#tf-stage').html('').hide();            }        }        refreshTenderFileSubType() {            const type = this.tenderFileType.find(x => { return x.value === this.rfType.type});            if (type.subType && type.subType.length > 0) {                this.rfType.sub_type = type.subType[0].value;                const html= [];                for (const tfst of type.subType) {                    html.push(`<option value="${tfst.value}">${tfst.text}</option>`);                }                $('#tf-sub-type').html(html.join('')).show();            } else {                $('#tf-sub-type').html('').hide();            }        }        refreshTenderFileType() {            const html= [];            for (const tft of this.tenderFileType) {                html.push(`<option value="${tft.value}">${tft.text}</option>`);            }            $('#tf-type').html(html.join(''));        }        refreshSelects(tender) {            this.tenderFileType = [];            this.tenderFileType.push({ value: 'ledger', text: '台账附件' });            if (tender.stage && tender.stage.length > 0) {                const stages = tender.stage.map(x => { return {value: x.id, text: `第${x.order}期`}; });                this.tenderFileType.push({                    value: 'stage', text: '计量期',                    subType: [                        { value: 'att', text: '计量附件', stage: JSON.parse(JSON.stringify(stages)) },                    ],                });            }            if (tender.advance && tender.advance.length > 0) {                const advanceType = [];                tender.advance.forEach(x => {                    let at = advanceType.find(y => { return y.value === x.type + '' });                    if (!at) {                        at = { value: x.type + '', text: x.type_str, stage: [] };                        advanceType.push(at);                    }                    at.stage.push({ value: x.id, text: `第${x.order}期`});                });                this.tenderFileType.push({                    value: 'advance', text: '预付款', subType: advanceType                });            }            this.rfType = { type: this.tenderFileType[0].value };            this.refreshTenderFileType();            this.refreshTenderFileSubType();            this.refreshTenderFileStage();        }        async selectTfStage(stage){            this.rfType.stage = stage;            await this.loadFiles();            this.refreshFileTable();        }        async selectTfSubType(sub_type){            this.rfType.sub_type = sub_type;            this.refreshTenderFileStage();            await this.loadFiles();            this.refreshFileTable();        }        async selectTfType(type){            this.rfType.type = type;            this.refreshTenderFileSubType();            this.refreshTenderFileStage();            await this.loadFiles();            this.refreshFileTable();        }        refreshFileTable() {            const html = [];            const typeStr = [];            const selectOption = $('option:selected');            selectOption.each((i, x) => {               typeStr.push(x.innerText);            });            for (const f of this.curFiles) {                html.push('<tr>');                const checked = f.checked ? "checked" : '';                html.push(`<td><input type="checkbox" name="rf-check" rfid="${f.rf_id}" ${checked}></td>`);                html.push(`<td>${f.filename}${f.fileext}</td>`);                html.push(`<td>${typeStr.join(' - ')}</td>`);                html.push('</tr>');            }            $('#rf-files').html(html.join(''));        };        initFilesId(files){            const tender_id = this.curTender.id;            const rfType = this.rfType;            files.forEach((f, i) => {                f.rf_id = `${tender_id}-${rfType.type}-${rfType.sub_type}-${rfType.stage}-${i}`;                f.rf_key = {                    tender_id, ...rfType, id: f.id,                };            });        }        async _loadRelaFiles(rfType) {            return await postDataAsync('file/rela/files', { tender_id: this.curTender.id, ...rfType });        }        async _loadLedgerFile() {            if (!this.curTender.source_node.att) this.curTender.source_node.att = await this._loadRelaFiles(this.rfType);            this.curFiles = this.curTender.source_node.att;        }        async _loadStageFile() {            const rfType = this.rfType;            const stage = this.curTender.source_node.stage.find(x => {                return x.id == rfType.stage;            });            if (!stage) {                this.curFiles = [];                return;            }            if (!stage[this.rfType.sub_type]) stage[this.rfType.sub_type] = await this._loadRelaFiles(rfType);            this.curFiles = stage[this.rfType.sub_type];        }        async _loadAdvanceFile() {            const rfType = this.rfType;            const advance = this.curTender.source_node.advance.find(x => {                return x.id == rfType.stage;            });            if (!advance) {                this.curFiles = [];                return;            }            if (!advance.files) advance.files = await this._loadRelaFiles(rfType);            this.curFiles = advance.files;        }        async loadFiles() {            switch (this.rfType.type) {                case 'ledger': await this._loadLedgerFile(); break;                case 'stage': await this._loadStageFile(); break;                case 'advance': await this._loadAdvanceFile(); break;            }            this.initFilesId(this.curFiles);        }        async setCurTender(node) {            this.curTender = node;            this.refreshSelects(node.source_node);            await this.loadFiles();            this.refreshSelectHint();            this.refreshFileTable();        }        getSelectRelaFile() {            const data = [];            const nodes = this.tenderTree.getNodes();            nodes.forEach(node => {                if (node.source_node.selectFiles.length === 0) return;                node.source_node.selectFiles.forEach(x => {                    data.push({                        filename: x.filename, fileext: x.fileext, filepath: x.filepath, filesize: x.filesize,                        rela_info: x.rf_key,                    })                });            });            return data;        }    }    const relaFileLoader = new RelaFileLoader();    $('#rela-file').on('show.bs.modal', function() {        relaFileLoader.showRelaFile(this.getAttribute('content'));    });    // 授权相关    class FilingPermission {        constructor (setting) {            this.setting = setting;            const self = this;            $(setting.modal).on('show.bs.modal', () => {                self.loadPermission();            });            $(`${setting.modal}-ok`).click(() => {                self.savePermission();            });            $('[name=ftName]').click(function () {                const filingId = this.getAttribute('ftid');                self.setCurFiling(filingId);            });            $('.book-list').on('click', 'dt', function () {                const idx = $(this).find('.acc-btn').attr('data-groupid');                const type = $(this).find('.acc-btn').attr('data-type');                if (type === 'hide') {                    $(this).parent().find(`div[data-toggleid="${idx}"]`).show(() => {                        $(this).children().find('i').removeClass('fa-plus-square').addClass('fa-minus-square-o')                        $(this).find('.acc-btn').attr('data-type', 'show')                    })                } else {                    $(this).parent().find(`div[data-toggleid="${idx}"]`).hide(() => {                        $(this).children().find('i').removeClass('fa-minus-square-o').addClass('fa-plus-square')                        $(this).find('.acc-btn').attr('data-type', 'hide')                    })                }                return false;            });            $('dl').on('click', 'dd', function () {                const type = $(this).data('type');                if (type === 'all') {                    const cid = parseInt($(this).data('id'));                    const company = self.company.find(x => { return x.id === cid });                    for (const u of company.users) {                        if (u.filing_type.indexOf(self.curFiling) < 0) u.filing_type.push(self.curFiling);                    }                } else {                    const uid = $(this).data('id');                    const pu = self.permissionUser.find(x => { return x.id === uid });                    if (pu.filing_type.indexOf(self.curFiling) < 0) pu.filing_type.push(self.curFiling);                }                self.loadCurFiling();            });            $('#sync-filing').click(function() {                const selectFiling = $('[name=cbft]:checked');                if (selectFiling.length === 0) {                    toastr.warning('请先选择文档类别');                    return;                }                const selectFilingId = [];                selectFiling.each((i, x) => { selectFilingId.push(x.value); });                self.syncFiling(self.curFiling, selectFilingId);                toastr.success('同步成功');                $('[name=cbft]').removeAttr('checked');                $('#filing-select-all')[0].checked = false;            });            $('#batch-del-filing').click(() => {                const selectUser = $('[name=ftu-check]:checked');                if (selectUser.length === 0) {                    toastr.warning('请先选择用户');                    return;                }                const userId = [];                selectUser.each((i, x) => { userId.push(x.getAttribute('uid')); });                self.delFiling(self.curFiling, userId);                self.loadCurFiling();            });            $('body').on('click', '[name=del-filing]', function() {                const id = this.getAttribute('uid');                self.delFiling(self.curFiling, id);                self.loadCurFiling();            });            $('#user-select-all').click(function(){                $('input[uid]').attr('checked', this.checked);            });            $('#filing-select-all').click(function(){                $('input[name=cbft]').attr('checked', this.checked);            });        }        analysisFiling(data) {            this.permissionUser = data;            this.permissionUser.forEach(x => { x.filing_type = x.filing_type ? x.filing_type.split(',') : []; });            this.company = [];            for (const pu of this.permissionUser) {                let c = this.company.find(x => { return x.company === pu.company });                if (!c) {                    c = { id: this.company.length + 1, company: pu.company, users: [] };                    this.company.push(c);                }                c.users.push(pu);            }        }        loadCurFiling() {            const html = [];            for (const f of this.permissionUser) {                if (f.filing_type.indexOf(this.curFiling) < 0) continue;                html.push('<tr>');                html.push(`<td><input uid="${f.id}" type="checkbox" name="ftu-check"></td>`);                html.push(`<td>${f.name}</td>`);                html.push(`<td>${moment(f.create_time).format('YYYY-MM-DD HH:mm:ss')}</td>`);                html.push(`<td>${f.file_permission}</td>`);                html.push(`<td><button class="btn btn-sm btn-outline-danger" uid="${f.id}" name="del-filing">移除</button></td>`);                html.push('</tr>');            }            $(this.setting.list).html(html.join(''));            $('#user-select-all')[0].checked = false;        }        setCurFiling(filingType) {            this.curFiling = filingType;            $('[name=ftName]').removeClass('bg-warning-50');            $(`[ftid=${filingType}]`).addClass('bg-warning-50');            this.loadCurFiling();        }        loadPermissionUser() {            const html = [];            for (const c of this.company) {                html.push(`<dt><a href="javascript: void(0);" class="acc-btn" data-groupid="${c.id}" data-type="hide"><i class="fa fa-plus-square"></i></a> ${c.company}</dt>`);                html.push(`<div class="dd-content" data-toggleid="${c.id}">`);                html.push(`<dd class="border-bottom p-2 mb-0 " data-id="${c.id}" data-type="all"><p class="mb-0 d-flex"><span class="text-primary">添加单位下全部用户</span></p></dd>`);                for (const u of c.users) {                    html.push(`<dd class="border-bottom p-2 mb-0 " data-id="${u.id}" >`);                    html.push(`<p class="mb-0 d-flex"><span class="text-primary">${u.name}</span><span class="ml-auto">${u.mobile}</span></p>`);                    html.push(`<span class="text-muted">${u.role}</span>`);                    html.push(`</dd>`);                }                html.push('</div>');            }            $('#puList').html(html.join(''));        }        loadPermission() {            const self = this;            postData('permission', {}, function(result) {                self.analysisFiling(result);                if (!self.curFiling) {                    self.setCurFiling($('[name=ftName]').attr('ftid'));                } else {                    self.loadCurFiling();                }                self.loadPermissionUser();            });        }        syncFiling(sourceId, targetIds) {            for (const pu of this.permissionUser) {                if (pu.filing_type.indexOf(sourceId) >= 0) {                    targetIds.forEach(id => {                        if (pu.filing_type.indexOf(id) < 0) pu.filing_type.push(id);                    });                } else {                    targetIds.forEach(id => {                        if (pu.filing_type.indexOf(id) >= 0) pu.filing_type.splice(pu.filing_type.indexOf(id), 1);                    })                }            }        }        delFiling(filingId, userId) {            const userIds = userId instanceof Array ? userId : [userId];            for (const id of userIds) {                const pu = this.permissionUser.find(x => { return x.id === id });                if (!pu) continue;                if (pu.filing_type.indexOf(filingId) >= 0) pu.filing_type.splice(pu.filing_type.indexOf(filingId), 1);            }        }        savePermission() {            const self = this;            const data = this.permissionUser.map(x => {                return { id: x.id, filing_type: x.filing_type.join(',') };            });            postData('permission/save', data, function(result) {                $(self.setting.modal).modal('hide');            });        }    }    const filingPermission = new FilingPermission({        modal: '#filing-permission',        list: '#filing-valid',    });    class FileSearch {        constructor() {            this.searchResult = [];            this.initSearch();        }        getOperateHtml(file) {            const locateHtml = `<a href="javascript: void(0);" class="mr-1" name="locate-search-file" fid="${file.id}"><i class="fa fa-crosshairs"></i></a>`;            const editHtml = file.canEdit ? `<a href="javascript: void(0);" class="mr-1" name="edit-search-file" fid="${file.id}"><i class="fa fa-pencil fa-fw"></i></a>` : '';            const viewHtml = file.viewpath ? `<a href="${file.viewpath}" class="mr-1" target="_blank"><i class="fa fa-eye fa-fw"></i></a>` : '';            const downHtml = `<a href="javascript: void(0);" onclick="AliOss.downloadFile('${file.filepath}', '${file.filename + file.fileext}')" class="mr-1"><i class="fa fa-download fa-fw"></i></a>`;            const delHtml = file.canEdit ? `<a href="javascript: void(0);" class="mr-1 text-danger" name="del-search-file" fid="${file.id}"><i class="fa fa-trash-o fa-fw"></i></a>` : '';            return `<div class="d-flex justify-content-between align-items-center table-file">${locateHtml}${editHtml}${viewHtml}${downHtml}${delHtml}</div>`        }        getFileHtml(file) {            const html = [];            html.push(`<tr fid="search_${file.id}">`);            html.push(`<td fid="search_${file.id}">${file.filename}${file.fileext}</td>`);            html.push(`<td class="text-center">${file.user_name}</td>`);            html.push(`<td class="text-center">${this.getOperateHtml(file)}</td>`);            html.push('</tr>');            return html.join('');        }        getResultHtml (result) {            this.searchResult = result;            const html = [];            for (const r of result) {                html.push(this.getFileHtml(r));            }            return html.join('');        }        getSearchFilter() {            const filter = $('#search-filter').val();            const filing_type = filter === 'all' ? filingObj.getAllFilingType() : filingObj.getCurFilingType();            return { filing_type };        }        getEditFileNameHtml(file) {            const inputHtml = `<input type="text" class="form-control form-control-sm form-control-s-width" maxlength="100" value="${file.filename + file.fileext}" fid="${file.id}">`;            const btnHtml = `<div class="btn-group-table" style="display: none;"><a href="javascript: void(0)" class="mr-1" name="edit-search-file-ok"><i class="fa fa-check fa-fw"></i></a><a href="javascript: void(0)" class="mr-1" name="edit-search-file-cancel"><i class="fa fa-remove fa-fw"></i></a></div>`;            return `<div class="d-flex justify-content-between align-items-center table-file"><div>${inputHtml}</div>${btnHtml}</div>`;        }        search() {            const searchData = this.getSearchFilter();            searchData.keyword = $('#search-keyword', '#search').val();            if (!searchData.keyword) {                toastr.warning('请输入查询的文件名称');                this.getResultHtml([]);                return;            }            postData(window.location.pathname + '/search', searchData, function(result) {                if (result.list.length === result.limit) toastr.warning(`最多查询${result.limit}个结果,请给出更准确的文件名称`);                $('#search-list').html(fileSearch.getResultHtml(result.list));            });        }        refreshSearchFile(file) {            const sfile = this.searchResult.find(x => { return x.id === file.id; });            if (sfile) {                for (const prop in file) {                    if (prop === 'id') continue;                    sfile[prop] = file[prop];                }            }        }        removeSearchFile(fid){            $(`tr[fid=search_${fid}]`, '#search').remove();            const index = this.searchResult.findIndex(x => { return x.id === fid; });            this.searchResult.splice(index, 1);        }        renameSearchFile(fid, data) {            const file = this.searchResult.find(x => { return x.id === fid; });            if (file) {                file.filename = data.filename;                file.fileext = data.fileext;                const td = $(`td[fid=search_${file.id}]`);                td.html(`${file.filename}${file.fileext}`);            }        }        initSearch() {            const self = this;            $.divResizer({                select: '#right-spr',                callback: function() {},            });            $('input', '#search').bind('keydown', function (e) {                if (e.keyCode == 13) self.search();            });            $('button', '#search').bind('click', () => { self.search(); });            $('body').on('click', "a[name=del-search-file]", function() {                const del = [this.getAttribute('fid')];                filingObj.delFiles(del);            });            $('body').on('click', "a[name=locate-search-file]", function() {                const fid = this.getAttribute('fid');                const file = self.searchResult.find(x => { return x.id === fid});                const filing = filingObj.findFiling(file.filing_id);                filingObj.filingTree.selectNode(filing);                filingObj.setCurFiling(filing);            });            $('body').on('click', "a[name=edit-search-file]", function() {                const check = $('[name=search-filename] input[fid]');                if (check.length > 0 && check[0].getAttribute('fid') === this.getAttribute('fid')) return;                const id = this.getAttribute('fid');                const file = self.searchResult.find(x => { return x.id === id });                $(`td[fid=search_${id}]`).html(self.getEditFileNameHtml(file));            });            $('body').on('click', "a[name=edit-search-file-ok]", function() {                const td = $(this).parent().parent().parent();                const fid = td.attr('fid').split('_')[1];                const file = self.searchResult.find(x => { return x.id === fid });                if (!file) return;                filingObj.renameFile(file, $('input', td).val());            });            $('body').on('click', "a[name=edit-search-file-cancel]", function() {                const td = $(this).parent().parent().parent();                const fid = td.attr('fid').split('_')[1];                const file = self.searchResult.find(x => { return x.id === fid });                if (!file) return;                td.html(`${file.filename}${file.fileext}`);            });        }    }    fileSearch = new FileSearch();    const showSideTools = function (show) {        const left = $('#left-view'), right = $('#right-view'), parent = left.parent();        if (show) {            right.show();            autoFlashHeight();            /**             * right.show()后, parent被撑开成2倍left.height, 导致parent.width减少了10px             * 第一次left.width调整后,parent的缩回left.height, 此时parent.width又增加了10px             * 故需要通过最终的parent.width再计算一次left.width             *             * Q: 为什么不通过先计算left.width的宽度,以避免计算两次left.width?             * A: 右侧工具栏不一定显示,当右侧工具栏显示过一次后,就必须使用parent和right来计算left.width             *             */                //left.css('width', parent.width() - right.outerWidth());                //left.css('width', parent.width() - right.outerWidth());            const percent = 100 - right.outerWidth() /parent.width() * 100;            left.css('width', percent + '%');        } else {            left.width(parent.width());            right.hide();        }    };    // 展开收起标准清单    $('a', '#side-menu').bind('click', function (e) {        e.preventDefault();        const tab = $(this), tabPanel = $(tab.attr('content'));        // 展开工具栏、切换标签        if (!tab.hasClass('active')) {            // const close = $('.active', '#side-menu').length === 0;            $('a', '#side-menu').removeClass('active');            $('.tab-content .tab-select-show.tab-pane.active').removeClass('active');            tab.addClass('active');            tabPanel.addClass('active');            // $('.tab-content .tab-pane').removeClass('active');            showSideTools(tab.hasClass('active'));        } else { // 收起工具栏            tab.removeClass('active');            tabPanel.removeClass('active');            showSideTools(tab.hasClass('active'));        }    });    // 显示层次    (function (select) {        $(select).click(function () {            const tag = $(this).attr('tag');            setTimeout(() => {                showWaitingView();                switch (tag) {                    case "1":                    case "2":                    case "3":                    case "4":                        filingObj.expandByLevel(parseInt(tag));                        break;                    case "last":                        filingObj.expandByCustom(() => { return true; });                        break;                }                closeWaitingView();            }, 100);        });    })('a[name=showLevel]');});
 |