| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162 | 'use strict';/** * * * @author Mai * @date 2018/5/30 * @version */function getTenderId() {    return window.location.pathname.split('/')[2];}function checkTzMeasureType () {    return tender.measure_type === measureType.tz.value;}$(document).ready(() => {    autoFlashHeight();    const ledgerSpread = SpreadJsObj.createNewSpread($('#ledger-spread')[0]);    const ledgerTree = createNewPathTree('base', {        id: 'ledger_id',        pid: 'ledger_pid',        order: 'order',        level: 'level',        rootId: -1,        keys: ['id', 'tender_id', 'ledger_id'],        preUrl: '/ledger'    });    ledgerTree.loadDatas(ledger);    SpreadJsObj.initSheet(ledgerSpread.getActiveSheet(), ledgerSpreadSetting);    SpreadJsObj.loadSheetData(ledgerSpread.getActiveSheet(), 'tree', ledgerTree);    // 初始化 部位明细    const pos = new PosData({        id: 'id', ledgerId: 'lid',    });    const posSpread = SpreadJsObj.createNewSpread($('#pos-spread')[0]);    // 台账模式加载部位明细数据    if (checkTzMeasureType()) {        $.divResizer({            select: '#main-resize',            callback: function () {                ledgerSpread.refresh();                let bcontent = $(".bcontent-wrap") ? $(".bcontent-wrap").height() : 0;                $(".sp-wrap").height(bcontent-40);                posSpread.refresh();            }        });        SpreadJsObj.initSheet(posSpread.getActiveSheet(), posSpreadSetting);        postData('/tender/' + getTenderId() + '/pos', null, function (data) {            pos.loadDatas(data);        });    }    ledgerSpread.bind(GC.Spread.Sheets.Events.SelectionChanged, function (e, info) {        const sheet = ledgerSpread.getActiveSheet();        let node;        if (!sheet || !sheet.zh_tree) {            node = null;        } else {            const sel = sheet.getSelections()[0];            node = sheet.zh_tree.nodes[sel.row];        }        if (node) {            const posData = pos.ledgerPos[itemsPre + node.id] || [];            SpreadJsObj.loadSheetData(posSpread.getActiveSheet(), 'data', posData);        } else {            SpreadJsObj.loadSheetData(posSpread.getActiveSheet(), 'data', []);        }    });    let dealBills;    $.divResizer({        select: '#right-spr',        callback: function () {            ledgerSpread.refresh();            if (posSpread) {                posSpread.refresh();            }            if (dealBills) {                dealBills.spread.refresh();            }        }    });    // 展开收起 签约清单|清单意见    $('a', '.side-menu').bind('click', function () {        const tab = $(this), tabPanel = $(tab.attr('content'));        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();            }        };        if (!tab.hasClass('active')) {            $('a', '#side-menu').removeClass('active');            tab.addClass('active');            $('.tab-content .tab-pane').removeClass('active');            tabPanel.addClass('active');            showSideTools(tab.hasClass('active'));            if (tab.attr('content') === '#deal-bills' && !dealBills) {                dealBills = new DealBills($('#deal-bills-spread')[0], {                    cols: [                        {title: '清单编号', field: 'code', width: 120, formatter: '@', readOnly: true},                        {title: '名称', field: 'name', width: 230, formatter: '@', readOnly: true},                        {title: '单位', field: 'unit', width: 50, formatter: '@', readOnly: true},                        {title: '单价', field: 'unit_price', width: 50, readOnly: true},                        {title: '数量', field: 'quantity', width: 50, readOnly: true},                    ],                    emptyRows: 0,                    headRows: 1,                    headRowHeight: [40],                    defaultRowHeight: 21,                });                dealBills.loadData();            }        } else {            tab.removeClass('active');            tabPanel.removeClass('active');            showSideTools(tab.hasClass('active'));        }        ledgerSpread.refresh();        if (posSpread) {            posSpread.refresh();        }    });    class DealBills {        constructor (obj, spreadSetting) {            this.obj = obj;            this.url = '/tender/' + getTenderId() + '/deal';            this.spreadSetting = spreadSetting;            this.spread = SpreadJsObj.createNewSpread(this.obj);            SpreadJsObj.initSheet(this.spread.getActiveSheet(), this.spreadSetting);        }        loadData () {            const self = this;            postData(this.url+'/get-data', {}, function (data) {                SpreadJsObj.loadSheetData(self.spread.getActiveSheet(), 'data', data);            });        }    }});
 |