| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 | 'use strict';/** * * * @author Mai * @date * @version */function initSpreadSetting(settings, gatherTender) {    function setSpreadSettingCols(setting, fieldSufs, Roles) {        function addExtraCols(fieldSuf, Role) {            for (const ec of setting.extraCols) {                const col = JSON.parse(JSON.stringify(ec));                col.title = _.replace(col.title, '%s', Role);                col.field = _.replace(col.field, '%s', fieldSuf);                setting.cols.push(col);            }        }        setting.cols = [];        for (const col of setting.baseCols) {            setting.cols.push(col);        }        for (const index in fieldSufs) {            addExtraCols(fieldSufs[index], Roles[index]);        }    }    const fieldSufs = [], names = [];    for (let [i, t] of gatherTender.entries()) {        fieldSufs.push((i + 1) + '');        names.push(t.name);    }    fieldSufs.push('s');    names.push('汇总');    for (const s of settings) {        s.fieldSufs = fieldSufs;        setSpreadSettingCols(s, fieldSufs, names);    }}$(document).ready(function () {    autoFlashHeight();    // 根据设置整理Spread设置    const ledgerSpreadSetting = {        baseCols: [            { title: '项目节编号', colSpan: '1', rowSpan: '2', field: 'code', hAlign: 0, width: 150, formatter: '@', cellType: 'tree' },            { title: '清单编号', colSpan: '1', rowSpan: '2', field: 'b_code', hAlign: 0, width: 80, formatter: '@' },            { title: '名称', colSpan: '1', rowSpan: '2', field: 'name', hAlign: 0, width: 230, formatter: '@' },            { title: '单位', colSpan: '1', rowSpan: '2', field: 'unit', hAlign: 1, width: 50, formatter: '@', cellType: 'unit' },            { title: '单价', colSpan: '1', rowSpan: '2', field: 'unit_price', hAlign: 2, width: 60, type: 'Number' },        ],        extraCols: [            { title: '%s|数量', colSpan: '2|1', rowSpan: '1|1', field: 'qty_%s', hAlign: 2, width: 60, type: 'Number' },            { title: '|金额', colSpan: '|1', rowSpan: '|1', field: 'tp_%s', hAlign: 2, width: 60, type: 'Number' },        ],        emptyRows: 2,        headRows: 2,        headRowHeight: [35, 25],        defaultRowHeight: 21,        headerFont: '12px 微软雅黑',        font: '12px 微软雅黑',        readOnly: true,        localCache: {            key: 'spss-gather-tz-bills',            colWidth: true,        },        getColor: function (sheet, data, row, col, defaultColor) {            function checkDiffer(data) {                return !checkZero(data.qty_differ) && !checkZero(data.tp_differ);            }            return data && checkDiffer(data) ? '#F2DEDE' : defaultColor;        }    };    const posSpreadSetting = {        baseCols: [            { title: '计量单元', colSpan: '1', rowSpan: '2', field: 'name', hAlign: 0, width: 230, formatter: '@' },        ],        extraCols: [            { title: '%s|数量', colSpan: '1|1', rowSpan: '1|1', field: 'qty_%s', hAlign: 2, width: 80, type: 'Number' },        ],        emptyRows: 3,        headRows: 2,        headRowHeight: [25, 25],        defaultRowHeight: 21,        headerFont: '12px 微软雅黑',        font: '12px 微软雅黑',        readOnly: true,        localCache: {            key: 'spss-gather-tz-pos',            colWidth: true,        },        getColor: function (sheet, data, row, col, defaultColor) {            function checkDiffer(data) {                const fieldSufs = sheet.zh_setting.fieldSufs;                if (fieldSufs.length <= 1) return false;                const base = data['gather_qty' + fieldSufs[0]];                for (let i = 1; i < fieldSufs.length; i++) {                    const compare = data['gather_qty' + fieldSufs[i]];                    if ((base || compare) && (compare !== base)) return true;                }            }            return checkDiffer(data) ? '#F2DEDE' : defaultColor;        }    };    initSpreadSetting([ledgerSpreadSetting, posSpreadSetting], []);    // 初始化台账    const billsSpread = SpreadJsObj.createNewSpread($('#bills-spread')[0]);    const billsSheet = billsSpread.getActiveSheet();    SpreadJsObj.initSheet(billsSheet, ledgerSpreadSetting);    // 初始化部位    const posSpread = SpreadJsObj.createNewSpread($('#pos-spread')[0]);    const posSheet = posSpread.getActiveSheet();    SpreadJsObj.initSheet(posSheet, posSpreadSetting);    const billsTree = createNewPathTree('tree-gather', {        id: 'id',        pid: 'pid',        order: 'order',        level: 'level',        rootId: -1,        loadInfo: function (node, source, index) {            const endfix = '_' + index;            node['qty' + endfix] = source.quantity;            node['tp' + endfix] = source.total_price;        },        calcGather: function (node, count) {            node.qty_differ = 0;            for (let i = 1; i<= count; i++) {                node.qty_sum = ZhCalc.add(node.qty_sum, node['qty_' + i]);                node.tp_sum = ZhCalc.add(node.tp_sum, node['tp_' + 1]);            }        },    });    // // 获取部位明细数据    // function loadPosData(iRow) {    //     const node = billsSheet.zh_tree.nodes[iRow];    //     if (node) {    //         SpreadJsObj.loadSheetData(posSheet, SpreadJsObj.DataType.Data, node.pos);    //     } else {    //         SpreadJsObj.loadSheetData(posSheet, SpreadJsObj.DataType.Data, []);    //     }    //     SpreadJsObj.resetTopAndSelect(posSheet);    // }    // // 切换清单行,读取所属项目节数据    // billsSheet.bind(spreadNS.Events.SelectionChanged, function (e, info) {    //     if (info.newSelections) {    //         const iNewRow = info.newSelections[0].row;    //         if (info.oldSelections) {    //             const iOldRow = info.oldSelections[0].row;    //             if (iNewRow !== iOldRow) {    //                 loadPosData(iNewRow);    //             }    //         } else {    //             loadPosData(iNewRow);    //         }    //     }    // });    // 选择    $('#select-ok').click(function () {        let data = {tenders: []};        try {            const trs = $('tr[tid]');            for (const tr of trs) {                data.tenders.push({                    id: parseInt(tr.attributes['tid'].value)                });            }            if (data.tenders.length === 0) return;            postData(window.location.pathname + '/load', data, function (result) {                initSpreadSetting([ledgerSpreadSetting, posSpreadSetting], result);                SpreadJsObj.initSheet(billsSheet, ledgerSpreadSetting);                const tenderDatas = [];                const tenderTreeSetting = {                    id: 'ledger_id',                    pid: 'ledger_pid',                    order: 'order',                    level: 'level',                    rootId: -1,                    keys: ['id', 'tender_id', 'ledger_id'],                    calcFields: ['deal_tp', 'sgfh_tp', 'sjcl_tp', 'qtcl_tp', 'total_price'],                };                for (const [i, tender] of result.entries()) {                    const tenderData = {                        billsTree: createNewPathTree('ledger', tenderTreeSetting),                    };                    tenderData.billsTree.loadDatas(tender.bills);                    treeCalc.calculateAll(tenderData.billsTree);                    tenderDatas.push(tenderData);                }                billsTree.loadGatherData(tenderDatas);                SpreadJsObj.loadSheetData(billsSheet, SpreadJsObj.DataType.Tree, billsTree);                $('#data-select').modal('hide');            });        } catch (err) {            toastr.error('输入的标段ID非法');        }    });    // 显示层次    (function (select, sheet) {        $(select).click(function () {            if (!sheet.zh_tree) return;            const tag = $(this).attr('tag');            const tree = sheet.zh_tree;            switch (tag) {                case "1":                case "2":                case "3":                case "4":                case "5":                    tree.expandByLevel(parseInt(tag));                    SpreadJsObj.refreshTreeRowVisible(sheet);                    break;                case "last":                    tree.expandByCustom(() => { return true; });                    SpreadJsObj.refreshTreeRowVisible(sheet);                    break;                case "leafXmj":                    tree.expandToLeafXmj();                    SpreadJsObj.refreshTreeRowVisible(sheet);                    break;                case "curMeasure":                    tree.expandByCalcFields();                    SpreadJsObj.refreshTreeRowVisible(sheet);                    break;            }        });    })('a[name=showLevel]', billsSheet);    // 导航栏    $.subMenu({        menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',        toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',        key: 'menu.1.0.0',        miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',        callback: function (info) {            if (info.mini) {                $('.panel-title').addClass('fluid');                $('#sub-menu').removeClass('panel-sidebar');            } else {                $('.panel-title').removeClass('fluid');                $('#sub-menu').addClass('panel-sidebar');            }            autoFlashHeight();            billsSpread.refresh();            posSpread.refresh();        }    });    // 上下窗口resizer    $.divResizer({        select: '#main-resize',        callback: function () {            billsSpread.refresh();            let bcontent = $(".bcontent-wrap").length > 0 ? $(".bcontent-wrap").height() : 0;            $(".sp-wrap").height(bcontent - 30);            posSpread.refresh();        }    });    $('#add-t').click(function () {        const id = $('input[name=tid]').val();        const tr = $('tr[tid=' + id + ']');        if (tr && tr.length > 0) {            toastr.warning('请勿重复添加同一个标段');            return;        }        const html = '<tr tid="' + id + '">' +            '<td>' + id + '</td>' +            '<td><a href="javascript: void(0);" name="delete-t" class="btn btn-sm" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="删除"><i class="fa fa-remove text-danger" aria-hidden="true"></i></a></td>' +            '</tr>';        $('tbody').append(html);    });    $('body').on('click', 'a[name=delete-t]', function () {        $(this).parent().parent().remove();    });});
 |