| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343 | /** * Created by Tony on 2019/9/25. */'use strict'let rptSignatureHelper = {    currentSelectedESignAccDom: null,    currentSelectedESignAccName: null,    buildSelectableAccount: function () {        //PRJ_ACCOUNT_LIST        //1. 清理所有选择项        // $("#project_account_select_div").empty();        let accDiv = $('#project_account_select_div');        let accSelect = $('#project_account_select_dom'); //绑定成员        accDiv.empty();        accSelect.empty();        //2. 一个个加可选用户项        const prj_accounts = [];        const prj_sel_option_accounts = [];        const acc_role_keys = [];        for (let accIdx = 0; accIdx < PRJ_ACCOUNT_LIST.length; accIdx++) {            const prjAccount = PRJ_ACCOUNT_LIST[accIdx];            let companyKey = prjAccount.company;            let roleKey = prjAccount.role;            if (companyKey === '') {                companyKey = '其他单位';            }            if (roleKey === '') {                roleKey = '工程师';            }            let keyIdx = acc_role_keys.indexOf(companyKey);            if (keyIdx < 0) {                acc_role_keys.push(companyKey);                prj_accounts.push([]);                prj_sel_option_accounts.push([]);                keyIdx = prj_accounts.length - 1;                //这里先push一些 html prefix,在后面统一在push html suffix                prj_accounts[keyIdx].push('<ul class="list-group">');                prj_accounts[keyIdx].push('<li class="px-2 text-muted"><i class="fa fa-caret-down"></i> ' + companyKey + '</li>');                prj_sel_option_accounts[keyIdx].push('<optgroup label=" ' + companyKey + '">');            }            //push item            prj_accounts[keyIdx].push('<li class="add-sign-list-item"><a href="javascript:void(0)" onclick="rptSignatureHelper.createEsignatureByAccIdx(' + accIdx + ')" class="btn-link pull-right" title="添加" data-dismiss="modal"><i class="fa fa-plus"></i></a>' +                prjAccount.name + '-<small class="text-muted">' + roleKey + '</small></li>');            prj_sel_option_accounts[keyIdx].push('<option value="' + accIdx + '">' + prjAccount.name + '-' + roleKey + '</option>');        }        for (const prjAccList of prj_accounts) {            prjAccList.push('</ul>');        }        for (const prjAccList of prj_sel_option_accounts) {            prjAccList.push('</optgroup>');        }        for (let idx = 0; idx < prj_accounts.length; idx++) {            prj_accounts[idx] = prj_accounts[idx].join('');            prj_sel_option_accounts[idx] = prj_sel_option_accounts[idx].join('');        }        accDiv.append(prj_accounts.join(''));        accSelect.append(prj_sel_option_accounts.join(''));    },    drawEsignature: function (accIdx) {        let dftSignSrc = '/public/images/user-sign.PNG';        if (PRJ_ACCOUNT_LIST[accIdx].sign_path !== '') {            dftSignSrc = '/public/images/' + PRJ_ACCOUNT_LIST[accIdx].sign_path;        }        //找到相关签名地方,stamp!        if (rptSignatureHelper.currentSelectedESignAccName !== null) {            for (const page of zTreeOprObj.currentRptPageRst.items) {                if (page.signature_cells) {                    for (const sCell of page.signature_cells) {                        if (sCell.signature_name === rptSignatureHelper.currentSelectedESignAccName) {                            sCell.pre_path = dftSignSrc;                        }                    }                }            }            // 1. 删除不需要的child dom            $(rptSignatureHelper.currentSelectedESignAccDom).empty();            // 2. 创建已选择签名相关 dom            const canvasWidth = 60;            const canvasHeight = 30;            // 2.1 canvas / X            const elementsStrArr = [];            elementsStrArr.push('<p class=" d-flex justify-content-between m-0"><canvas id="signCanvas' + accIdx + '" width="' + canvasWidth + '" height="' + canvasHeight + '"></canvas><a onclick="rptSignatureHelper.removeSignature(this)" class="text-danger"><i class="fa fa-remove" title="移除签名"></i></a></p>');            $(rptSignatureHelper.currentSelectedESignAccDom).append(elementsStrArr.join(' '));            let imgObj = new Image();            imgObj.src = dftSignSrc;            imgObj.onload = function(){                let canvasNode = document.getElementById('signCanvas' + accIdx);                let ctx = canvasNode.getContext('2d');                ctx.drawImage(this, 0, 0, canvasWidth, canvasHeight);            }            //.appendChild(pNode);            //*/            // 2.2 date-picker        }    },    createEsignatureByAccIdx: function (accIdx) {        rptSignatureHelper.createPreSelectedSignature(PRJ_ACCOUNT_LIST[accIdx], null);    },    createEsignatureByRoleIdx: function (roleIdx) {        rptSignatureHelper.createPreSelectedSignature(null, ROLE_LIST[roleIdx]);    },    createPreSelectedSignature: function (directAcc, roleAcc) {        let dftSignSrc = '/public/images/user-sign.PNG';        let userAcc = directAcc;        if (roleAcc) {            userAcc = rptSignatureHelper.getUserAccount(roleAcc.bind_acc_id);        }        if (userAcc.sign_path !== '') {            dftSignSrc = '/public/images/' + userAcc.sign_path;        }        if (rptSignatureHelper.currentSelectedESignAccName !== null) {            for (const page of zTreeOprObj.currentRptPageRst.items) {                if (page.signature_cells) {                    for (const sCell of page.signature_cells) {                        if (sCell.signature_name === rptSignatureHelper.currentSelectedESignAccName) {                            sCell.pre_path = dftSignSrc;                        }                    }                }            }            // 1. 删除不需要的child dom            $(rptSignatureHelper.currentSelectedESignAccDom).empty();            // 2. 创建已选择签名相关 dom            rptSignatureHelper.cleanOldSignature(rptSignatureHelper.currentSelectedESignAccName);            // 2.1 dom element            const elementsStrArr = [];            if (directAcc) {                rptSignatureHelper.pushDomElementByUser(elementsStrArr, userAcc.name, userAcc.role);                // 还有ROLE_REL_LIST                let roleRelObj = {};                roleRelObj.signature_name = rptSignatureHelper.currentSelectedESignAccName;                roleRelObj.sign_path = dftSignSrc;                roleRelObj.user_name = userAcc.name;                roleRelObj.type = '用户';                roleRelObj.role = (userAcc.role === '')?"工程师":userAcc.role;                ROLE_REL_LIST.push(roleRelObj);            } else if (roleAcc) {                // 创建相关dom元素                rptSignatureHelper.pushDomElementByRole(elementsStrArr, roleAcc.name, userAcc.name);                // 还有ROLE_REL_LIST                let roleRelObj = {};                roleRelObj.signature_name = rptSignatureHelper.currentSelectedESignAccName;                roleRelObj.sign_path = dftSignSrc;                roleRelObj.user_name = userAcc.name;                roleRelObj.type = '角色';                roleRelObj.role = (userAcc.role === '')?"工程师":userAcc.role;                roleRelObj.role_name = roleAcc.name;                ROLE_REL_LIST.push(roleRelObj);            }            // elementsStrArr.push('');            $(rptSignatureHelper.currentSelectedESignAccDom).append(elementsStrArr.join(' '));            //.appendChild(pNode);            //*/            // 2.2 date-picker        }    },    cleanOldSignature: function (signature_name) {        // 清掉ROLE_REL_LIST原有的签名        for (let idx = ROLE_REL_LIST.length - 1; idx >= 0 ; idx--) {            if (ROLE_REL_LIST[idx].signature_name === signature_name) {                ROLE_REL_LIST.splice(idx, 1);            }        }    },    resetESignature: function (pageRst) {        let body = $('#eSignatureBodyDiv');        body.empty();        const signature_cells = [];        const singatureNameArr = [];        for (const page of pageRst.items) {            if (page.signature_cells) {                for (const sCell of page.signature_cells) {                    if (singatureNameArr.indexOf(sCell.signature_name) < 0) {                        signature_cells.push(sCell);                        singatureNameArr.push(sCell.signature_name);                    }                }            }        }        if (signature_cells.length > 0) {            const elementsStrArr = [];            for (let scIdx = 0; scIdx < signature_cells.length; scIdx++) {                const sCell = signature_cells[scIdx];                elementsStrArr.push('<div class="form-group row">');                elementsStrArr.push('<label for="staticEmail" class="col-sm-3 col-form-label pr-0">' + sCell.signature_name + '</label>');                elementsStrArr.push('<div class="col-sm-9">');                elementsStrArr.push('<ul class="list-group">');                elementsStrArr.push('<li class="list-group-item">');                if (sCell.path || sCell.pic) {                    for (const role_rel of ROLE_REL_LIST) {                        if (role_rel.signature_name === sCell.signature_name) {                            if (role_rel.type === '用户') {                                rptSignatureHelper.pushDomElementByUser(elementsStrArr, role_rel.user_name, role_rel.role);                            } else {                                //角色                                rptSignatureHelper.pushDomElementByRole(elementsStrArr, role_rel.role_name, role_rel.user_name);                            }                            break;                        }                    }                } else {                    elementsStrArr.push('<a href="#add-sign" onclick="rptSignatureHelper.currentSelectedESignAccDom = this.parentNode; rptSignatureHelper.currentSelectedESignAccName = \'' + sCell.signature_name + '\'" data-toggle="modal" data-target="#add-sign"><i class="fa fa-plus"></i> 添加签名</a>');                }                elementsStrArr.push('</li>');                elementsStrArr.push('</ul>');                elementsStrArr.push('</div>');                elementsStrArr.push('</div>');            }            body.append(elementsStrArr.join(' '));        }    },    pushDomElementByUser: function (elementsStrArr, userName, userRole) {        elementsStrArr.push('<p class=" d-flex justify-content-between m-0"><span>' + userName +            '-<small class="text-muted">' + ((userRole === '')?"工程师":userRole) +            '</small></span><a onclick="rptSignatureHelper.removeSignature(this)" class="text-danger"><i class="fa fa-remove" title="移除签名"></i></a></p>')    },    pushDomElementByRole: function (elementsStrArr, roleName, userName) {        elementsStrArr.push('<p class=" d-flex justify-content-between m-0"><span><i class="fa fa-user" title="角色"> ' + roleName +            '</i>-<small class="text-muted">' + userName +            '</small></span><a onclick="rptSignatureHelper.removeSignature(this)" class="text-danger"><i class="fa fa-remove" title="移除签名"></i></a></p>')    },    removeSignature: function (dom) {        let accTxtName = $(dom.parentNode.parentNode.parentNode.parentNode.parentNode).find('label')[0].innerText;        let jDom = $(dom.parentNode.parentNode);        jDom.empty();        jDom.append('<a href="#add-sign" onclick="rptSignatureHelper.currentSelectedESignAccDom = this.parentNode; rptSignatureHelper.currentSelectedESignAccName = \'' +            accTxtName + '\'" data-toggle="modal" data-target="#add-sign"><i class="fa fa-plus"></i> 添加签名</a>');        // 要记得清空相关pre_path属性        for (const page of zTreeOprObj.currentRptPageRst.items) {            if (page.signature_cells) {                for (const sCell of page.signature_cells) {                    if (sCell.signature_name === accTxtName) {                        sCell.pre_path = '';                    }                }            }        }        // 还有ROLE_REL_LIST        for (let idx = 0; idx < ROLE_REL_LIST.length; idx++) {            //        }    },    removeSelectSignature: function () {        for (const page of zTreeOprObj.currentRptPageRst.items) {            if (page.signature_cells) {                for (const sCell of page.signature_cells) {                    if (sCell.hasOwnProperty('pre_path')) {                        delete sCell.pre_path;                    }                }            }        }        zTreeOprObj.showPage(zTreeOprObj.currentPage, zTreeOprObj.canvas);    },    setupAfterSelectSignature: function () {        for (const page of zTreeOprObj.currentRptPageRst.items) {            if (page.signature_cells) {                for (const sCell of page.signature_cells) {                    if (sCell.hasOwnProperty('pre_path')) {                        sCell.path = sCell.pre_path;                        delete sCell.pre_path;                    }                }            }        }        zTreeOprObj.showPage(zTreeOprObj.currentPage, zTreeOprObj.canvas);    },    switchAddRoleDiv: function (dom) {        if (dom.nextElementSibling.children[0].style.display === 'none') {            dom.nextElementSibling.children[0].style.display = '';        } else {            dom.nextElementSibling.children[0].style.display = 'none';        }    },    createNewRole: function (dom) {        if ($('#acc_role_name')[0].value !== '') {            const params = {};            params.name = $('#acc_role_name')[0].value;            const selectedAcc = PRJ_ACCOUNT_LIST[$('#project_account_select_dom')[0].selectedOptions[0].value];            const roleName = (selectedAcc.role === '')?'工程师':selectedAcc.role;            params.bind_acc_id = selectedAcc.id;            params.prj_id = PROJECT_ID;            params.tender_id = TENDER_ID;            CommonAjax.postXsrfEx("/tender/report_api/createSignatureRole", params, 10000, true, getCookie('csrfToken'),                function(result){                    console.log(result);                    const domArr = [];                    domArr.push('<li class="add-sign-list-item">');                    //1. apply签名                    domArr.push('<a href="javascript:void(0)" onclick="rptSignatureHelper.drawEsignature(' + $('#project_account_select_dom')[0].selectedIndex + ')" class="btn-link pull-right" title="添加" data-dismiss="modal">');                    domArr.push('<i class="fa fa-plus"></i>');                    domArr.push('</a>');                    //2. 编辑角色(暂缓)                    // domArr.push('<a href="" class="btn-link pull-right mr-1" title="编辑">');                    // domArr.push('<i class="fa fa-pencil-square-o"></i>');                    // domArr.push('</a>');                    //3. 显示名称                    domArr.push('<i class="fa fa-user"></i> ' + $('#acc_role_name')[0].value + '<p>' + selectedAcc.name + '-<small class="text-muted">' + roleName + '</small></p>');                    $('#existed_roles_ul').append(domArr.join(' '));                }, function(err){                    // hintBox.unWaitBox();                }, function(ex){                    // hintBox.unWaitBox();                }            );        } else {            alert('请输入合适的名称!');        }    },    buildRoleDom: function (roleList) {        const ulDom = $('#existed_roles_ul');        ulDom.empty();        for (let domIdx = 0; domIdx < roleList.length; domIdx++) {            const role = roleList[domIdx];            const domArr = [];            domArr.push('<li class="add-sign-list-item">');            //1. apply签名            domArr.push('<a href="javascript:void(0)" onclick="rptSignatureHelper.createEsignatureByRoleIdx(' + domIdx + ')" class="btn-link pull-right" title="添加" data-dismiss="modal">');            domArr.push('<i class="fa fa-plus"></i>');            domArr.push('</a>');            //2. 编辑角色(暂缓)            domArr.push('<a href="javascript:void(0)" onclick="" class="btn-link pull-right mr-1" title="编辑">');            domArr.push('<i class="fa fa-pencil-square-o"></i>');            domArr.push('</a>');            //3. 显示名称            let acc = rptSignatureHelper.getUserAccount(role.bind_acc_id);            domArr.push('<i class="fa fa-user"></i> ' + role.name + '<p>' + acc.name + '-<small class="text-muted">' + ((acc.role === '')?"工程师":acc.role) + '</small></p>');            ulDom.append(domArr.join(' '));        }    },    getUserAccount: function (accId) {        let rst = null;        for (const acc of PRJ_ACCOUNT_LIST) {            if (acc.id === accId) {                rst = acc;                break;            }        }        return rst;    }}
 |