| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514 | /** * Created by Zhong on 2017/12/20. *///附注let annotationOprObj = {    workBook: null,    container: $('#editAnnoCodeSpread'),    situations: {ALL: 'ALL', PARTIAL: 'PARTIAL', NONE: 'NONE'},    currentSituation: null,//本项适用情况    radios: $("input[name = 'fzRadios']"),    fzTableAll: $('#fzTableAll'),    fzTablePartial: $('#fzTablePartial'),    currentOprTr: null,    currentAnnotation: null,    addCon: $('#fzAddCon'),//勾选编码模态框    updateCon: $('#fzUpdateCon'),//编辑编码模态框    setting: {        header:[            {headerName:"编码",headerWidth:240,dataCode:"code", dataType: "String", formatter: "@", hAlign: "left", vAlign: "center"},            {headerName:"选择",headerWidth:40,dataCode:"select", hAlign: "center", vAlign: "center"},        ],    },    buildSheet: function () {        let me = this;        me.workBook = sheetCommonObj.buildSheet(me.container[0], me.setting, 30);        me.workBook.options.showDragFillSmartTag = false;        me.workBook.options.defaultDragFillType = GC.Spread.Sheets.Fill.AutoFillType.fillWithoutFormatting;        me.workBook.refresh();        me.workBook.bind(GC.Spread.Sheets.Events.ButtonClicked, me.onButtonClick);        let sheet = me.workBook.getSheet(0);        sheet.options.isProtected = true;        sheet.getRange(-1, 0, -1, 1).locked(true);        sheet.getRange(-1, 1, -1, 1).locked(false);    },    renderSheet: function (func) {        let me = this;        let sheet = me.workBook.getSheet(0);        sheet.suspendPaint();        sheet.suspendEvent();        if (func) {            func();        }        sheet.resumePaint();        sheet.resumeEvent();    },    onButtonClick: function (sender, args) {        if (args.sheet.isEditing()) {            args.sheet.endEdit();        }    },    showData: function (datas) {        let me = this,            sheet = me.workBook.getSheet(0),            headers = me.setting.header;        let fuc = function () {            sheet.setRowCount(datas.length);            //复选框            let checkBoxType = new GC.Spread.Sheets.CellTypes.CheckBox();            sheet.setCellType(-1, 1, checkBoxType);            for(let col = 0, cLen = headers.length; col < cLen; col++){                if(headers[col].formatter){                    sheet.setFormatter(-1, col, headers[col].formatter);                }                sheet.getRange(-1, col, -1, 1).hAlign(GC.Spread.Sheets.HorizontalAlign[headers[col]['hAlign']]);                sheet.getRange(-1, col, -1, 1).vAlign(GC.Spread.Sheets.VerticalAlign[headers[col]['vAlign']]);                for(let row = 0, rLen = datas.length; row < rLen; row++){                    sheet.setValue(row, col, datas[row][headers[col]['dataCode']]);                }            }        };        me.renderSheet(fuc);    },    clickUpdate: function (txtarea) {//解决编辑完后在未失去焦点的时候直接定额章节树        let me = annotationOprObj;        if(txtarea.is(':focus')){            let annotation = txtarea.val();            if(annotation !== me.currentAnnotation){                jobContentOprObj.preTreeNode.data.annotation = annotation;                me.unbindEvents(txtarea);                txtarea.blur();                let updateCodes = [];                for(let i = 0, len = jobContentOprObj.currentRationItems.length; i < len; i++){                    updateCodes.push(jobContentOprObj.currentRationItems[i].code);                    jobContentOprObj.currentRationItems[i].annotation = annotation;                }                me.updateAnnotation(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, annotation), function () {                    me.bindAllEvents(txtarea);                });            }            else {                txtarea.blur();            }        }    },    getGroup: function (rationItems) {        let rst = [];//rst = [{jobContent: String, items: Array}]        for(let i = 0, len = rationItems.length; i < len; i++){            if(typeof rationItems[i].annotation !== 'undefined' && rationItems[i].annotation.toString().trim().length > 0){                let isExist = false;                for(let j = 0, jLen = rst.length; j < jLen; j++){                    if(rst[j].annotation === rationItems[i].annotation){                        isExist = true;                        rst[j].items.push(rationItems[i].code);                        break;                    }                }                if(!isExist){                    rst.push({annotation: rationItems[i].annotation, items: [rationItems[i].code]});                }            }        }        return rst;    },    hideTable: function (tableAll, tablePartial) {        if(tableAll){            tableAll.hide();        }        if(tablePartial){            tablePartial.hide();        }    },    //建table    buildTablePartial: function (table, group) {        let me = annotationOprObj;        table.empty();        let $thead = $("<thead><tr><th></th><th>编码</th><th>附注</th>/tr></thead>");        let $tbody = $("<tbody></tbody>");        let count = 1;        for(let i = 0, len = group.length; i < len; i++){            let $newTr = me.getNewTr($tbody, group[i].items, group[i].annotation);            $tbody.append($newTr);            count++;        }        let $trEnd = $("<tr><td>"+ count +"</td><td><a href data-toggle='modal' data-target='#fzEditBianma' class='m-0'>点击勾选编码</a></td><td><textarea class='form-control'></textarea></td></tr>");//勾选行        $($trEnd.children().children()[0]).bind('click', function () {            me.onclickFuncAdd($(this));            me.currentOprTr = $trEnd;            me.currentAnnotation = $(me.currentOprTr.children()[2]).children().val();        });        $tbody.append($trEnd);        table.append($thead);        table.append($tbody);    },    //新增一行tr    getNewTr: function (tbody, codes, jobContent) {        let me = annotationOprObj;        let count = tbody.children().length > 0 ? tbody.children().length : 1;        let $textTd = $("<td></td>");        let $textarea = $("<textarea class='form-control'></textarea>");        $textarea.val(jobContent);        $textTd.append($textarea);        let $tr = $("<tr><td>" + count + "</td><td><a href data-toggle='modal' data-target='#fzEditBianmaQ' class='m-0'>编辑编码</a></td></tr>");        $tr.children().children().bind('click', function () {            me.currentOprTr = $tr;            me.currentAnnotation = $(me.currentOprTr.children()[2]).children().val();            me.onclickFuncEdit($(this));        });        //文本变化;        $textarea.bind('change', function () {            let codes = me.getUpdateCodes($($(this).parent().parent().children()[1]).children());            let annotation = $(this).val();            me.updateAnnotation(pageOprObj.rationLibId, me.getUpdateArr(codes, annotation), function () {                if(annotation.trim().length === 0){                    me.buildTablePartial(me.fzTablePartial, me.getGroup(jobContentOprObj.currentRationItems));                }            });        });        $tr.append($textTd);        for(let i = 0, len = codes.length; i < len; i ++){            let $p = $("<p class='m-0'>" + codes[i] + "</p>");            $tr.children()[1].append($p[0]);        }        me.setTextareaHeight($textarea, codes.length + 1);        return $tr[0];    },    onclickFuncAdd: function (obj) {        let me = annotationOprObj;        let txtarea = $(obj.parent().parent().children().children()[1]);        let annotation = txtarea.val();        if(annotation.trim().length > 0){            /*let codesObj = me.getAddCodes(jobContentOprObj.currentRationItems);            me.buildCheckCodesCon(me.addCon, codesObj.checkedCodes, codesObj.disabledCodes)*/            obj.attr('data-target', '#fzEditBianmaQ');            if (!me.workBook) {                setTimeout(function () {                    me.buildSheet();                    me.showData(me.getShowDatas(jobContentOprObj.currentRationItems, []));                    me.workBook.getSheet(0).setActiveCell(0, 0);                }, 200);            } else {                me.showData(me.getShowDatas(jobContentOprObj.currentRationItems, []));                me.workBook.getSheet(0).setActiveCell(0, 0);            }        }        else{            obj.attr('data-target', '');            alert("附注不能为空!");        }    },    onclickFuncEdit: function (obj) {        let me = annotationOprObj;        //me.buildEditableCodesCon(jobContentOprObj.currentRationItems, me.updateCon, me.getUpdateCodes(obj));        if (!me.workBook) {            setTimeout(function () {                me.buildSheet();                me.showData(me.getShowDatas(jobContentOprObj.currentRationItems, me.getUpdateCodes(obj)));                me.workBook.getSheet(0).setActiveCell(0, 0);            }, 200);        } else {            me.showData(me.getShowDatas(jobContentOprObj.currentRationItems, me.getUpdateCodes(obj)));            me.workBook.getSheet(0).setActiveCell(0, 0);        }    },    //获取弹出选择编码的数据    getShowDatas: function (rationItems, codes) {        let rst = [];        for(let i = 0, len = codes.length; i < len; i++){            rst.push({code: codes[i], select: true});        }        for(let i = 0, len = rationItems.length; i < len; i++){            if(!codes.includes(rationItems[i].code)){                if (typeof rationItems[i].annotation === 'undefined' || rationItems[i].annotation.toString().trim().length <= 0) {                    rst.push({code: rationItems[i].code, select: false});                }            }        }        return rst;    },    //获取编码td中的编码    getUpdateCodes: function (jq) {        let rst = [];        let nodes = jq.parent().children();        for(let i = 1, len = nodes.length; i < len; i++){            rst.push(nodes[i].textContent);        }        return rst;    },    //建一个编码checkbox Div    buildCodeOption: function (code, attr) {        let $div = $("<div class='col'><label class='form-check-label'><input class='form-check-input' type='checkbox' value= "+ code +"> "+ code +"</label></div>");        let $checkBox = $div.children().children();        if(attr){            $checkBox.attr(attr, true);        }        return $div;    },    //建修改编码弹窗    buildEditableCodesCon: function (rationItems, container, codes) {        let me = annotationOprObj;        let codeDivs = [];        container.empty();        for(let i = 0, len = codes.length; i < len; i++){            codeDivs.push({code: codes[i], attr: 'checked'});        }        for(let i = 0, len = rationItems.length; i < len; i++){            if(codes.indexOf(rationItems[i].code) === -1){                if(typeof rationItems[i].annotation !== 'undefined' && rationItems[i].annotation.toString().trim().length > 0){                    codeDivs.push({code: rationItems[i].code, attr: 'disabled'});                }                else{                    codeDivs.push({code: rationItems[i].code, attr: ''});                }            }        }        //排序        codeDivs.sort(function (a, b) {            let rst = 0;            if(a.code > b.code) rst = 1;            else if(a.code < b.code) rst = -1;            return rst;        });        for(let i = 0, len = codeDivs.length; i < len; i++){            container.append(me.buildCodeOption(codeDivs[i].code, codeDivs[i].attr));        }    },    //建勾选编码弹窗    buildCheckCodesCon: function (container, checkedCodes, disabledCodes) {        let me = annotationOprObj;        container.empty();        for(let i = 0, len = checkedCodes.length; i < len; i++){            let $codeDiv = me.buildCodeOption(checkedCodes[i], 'checked');            container.append($codeDiv);        }        for(let i = 0, len = disabledCodes.length; i < len; i++){            let $codeDiv = me.buildCodeOption(disabledCodes[i], 'disabled');            container.append($codeDiv);        }    },    getAddCodes: function (rationItems) {        let me = annotationOprObj;        let rst = {checkedCodes: [], disabledCodes: []};        for(let i = 0, len = rationItems.length; i < len; i++){            if(typeof rationItems[i].annotation !== 'undefined' && rationItems[i].annotation.toString().trim().length > 0){                rst.disabledCodes.push(rationItems[i].code);            }            else{                rst.checkedCodes.push(rationItems[i].code);            }        }        return rst;    },    //获取选择后的编码窗口的编码及状态    getCodesAfterS: function () {        let rst = {checked: [], unchecked: []};        let sheet = this.workBook.getSheet(0);        for(let i = 0; i < sheet.getRowCount(); i++){            let code = sheet.getValue(i, 0),                checked = sheet.getValue(i, 1);            if (checked) {                rst.checked.push(code);            } else {                rst.unchecked.push(code);            }        }        return rst;    },   /* getCodesAfterS: function (checkNodes) {        let rst = {checked: [], unchecked: []};        for(let i = 0, len = checkNodes.length; i < len; i++){            if(checkNodes[i].checked){                rst.checked.push(checkNodes[i].value);            }            else if(!checkNodes[i].checked && !checkNodes[i].disabled){                rst.unchecked.push(checkNodes[i].value);            }        }        return rst;    },*/    setRadiosChecked: function (situation, radios) {        let me = annotationOprObj;        if(situation === me.situations.ALL){            radios[0].checked = true;            radios[1].checked = false;            $('#fzTxtareaAll').val(jobContentOprObj.currentRationItems.length > 0 ? jobContentOprObj.currentRationItems[0].annotation : '');            me.currentAnnotation = jobContentOprObj.currentRationItems.length > 0 ? jobContentOprObj.currentRationItems[0].annotation : '';            me.fzTableAll.show();            me.fzTablePartial.hide();        }        else if(situation === me.situations.PARTIAL){            radios[0].checked = false;            radios[1].checked = true;            me.fzTableAll.hide();            me.fzTablePartial.show();        }        else if(situation === me.situations.NONE){            radios[0].checked = false;            radios[1].checked = false;            me.fzTableAll.hide();            me.fzTablePartial.hide();        }    },    //radios是否可用,只有在定额章节树的底层节点才可用    setRadiosDisabled: function (val, radios) {        let me =annotationOprObj;        if(val){            radios[0].checked = false;            radios[1].checked = false;            me.currentSituation = me.situations.NONE;        }        radios.attr('disabled', val);    },    radiosChange: function (radios, tableAll, tablePartial) {        let me = annotationOprObj;        radios.change(function () {            let val = $("input[name = 'fzRadios']:checked").val();            let selectedNode = sectionTreeObj.tree.selected;            me.updateAnnoSituation(pageOprObj.rationLibId, selectedNode.getID(), val, function () {                selectedNode.data.annotationSituation = val;                me.currentSituation = val;                if(val === me.situations.ALL){                    let updateCodes = [];                    for(let i = 0, len = jobContentOprObj.currentRationItems.length; i < len; i++){                        updateCodes.push(jobContentOprObj.currentRationItems[i].code);                    }                    me.updateAnnotation(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, ''), function () {                        me.currentAnnotation = '';                        $('#fzTxtareaAll').val('');                        tableAll.show();                        tablePartial.hide();                    });                }                else{                    me.buildTablePartial(me.fzTablePartial, me.getGroup(jobContentOprObj.currentRationItems));                    tableAll.hide();                    tablePartial.show();                }            });        });    },    setTextareaHeight: function (textarea, nodesCount) {        const perHeight = 21.6;        textarea.height(nodesCount * 21.6);    },    bindEvents: function (txtarea) {        let me = annotationOprObj;        txtarea.bind('change', function () {            let annotation = txtarea.val();            let jqNodes = txtarea.parent().parent().children()[1].children;            let updateCodes = me.getUpdateCodes(jqNodes);            txtarea.attr('disabled', true);            me.updateAnnotation(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, annotation), function () {                txtarea.attr('disabled', false);            });        });    },    bindAllEvents: function (txtarea) {        let me = annotationOprObj;        txtarea.bind('change', function () {            let met = this;            let annotation = $(met).val();            $(met).attr('disabled', true);            let updateCodes = [];            for(let i = 0, len = jobContentOprObj.currentRationItems.length; i < len; i++){                updateCodes.push(jobContentOprObj.currentRationItems[i].code);                jobContentOprObj.currentRationItems[i].annotation = annotation;            }            me.currentAnnotation = annotation;            me.updateAnnotation(pageOprObj.rationLibId, me.getUpdateArr(updateCodes, annotation), function () {                $(met).attr('disabled', false);            });        });    },    unbindEvents: function (txtarea) {        txtarea.unbind();    },    //定额工作内容相关操作    rationAnnotationOpr: function (rationItems) {        let me = annotationOprObj;        me.setRadiosDisabled(sectionTreeObj.tree.selected.children.length === 0 ? false : true, me.radios);        me.setRadiosChecked(me.currentSituation, me.radios);        me.buildTablePartial(me.fzTablePartial, me.getGroup(rationItems));    },    getUpdateArr: function (updateCodes, annotation) {        let rst = [];        for(let i = 0, len = updateCodes.length; i < len; i++){            rst.push({code: updateCodes[i], annotation: annotation});        }        return rst;    },    bindAddConBtn: function () {        let me = annotationOprObj;        return function () {            let codesObj = me.getCodesAfterS(me.addCon.children().children().children());            let $tbody = $('#fzTablePartial tbody');            let lastEle = $tbody[0].lastElementChild;            let txtare = lastEle.lastElementChild.children[0];            if(me.currentAnnotation.trim().length > 0){//工作内容不为空才可添加编码                let updateArr = me.getUpdateArr(codesObj.checked, me.currentAnnotation);                me.updateAnnotation(pageOprObj.rationLibId, updateArr, function () {                    me.buildTablePartial(me.fzTablePartial, me.getGroup(jobContentOprObj.currentRationItems));                    $(txtare).val('');                });            }            else{                alert("附注不能为空!");            }        }    },    bindUpdateConBtn: function () {        let me = annotationOprObj;        return function () {            let codesObj = me.getCodesAfterS(me.updateCon.children().children().children());            let updateC = me.getUpdateArr(codesObj.checked, me.currentAnnotation),                updateUnC = me.getUpdateArr(codesObj.unchecked, ''),                updateArr = updateC.concat(updateUnC);            me.updateAnnotation(pageOprObj.rationLibId, updateArr, function () {                me.buildTablePartial(me.fzTablePartial, me.getGroup(jobContentOprObj.currentRationItems));            });        }    },    //更新缓存的定额    updateRationItem: function (rationItems, updateArr) {        for(let i = 0, len = rationItems.length; i < len; i++){            for(let j = 0, jLen = updateArr.length; j < jLen; j++){                if(rationItems[i].code === updateArr[j].code){                    rationItems[i].annotation = updateArr[j].annotation;                    break;                }            }        }    },    updateAnnotation: function (repId, updateArr, callback){        let me = annotationOprObj;        $.ajax({            type: 'post',            url: 'api/updateAnnotation',            data: {lastOpr: userAccount, repId: repId, updateArr: JSON.stringify(updateArr)},            dataType: 'json',            success: function (result) {                if(!result.error){                    me.updateRationItem(jobContentOprObj.currentRationItems, updateArr);                    callback();                }            }        });    },    updateAnnoSituation: function (repId, nodeId, situation, callback) {        let me = annotationOprObj;        $.ajax({            type: 'post',            url: 'api/updateAnnoSituation',            data: {lastOpr: userAccount, repId: repId, nodeId: nodeId, situation: situation},            dataType: 'json',            success: function (result) {                if(!result.error){                    if(callback){                        callback();                    }                }            }        })    }};
 |