| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398 | <!--分类管理 --><div class="modal fade" id="sort" data-backdrop="static">    <div class="modal-dialog" role="document">        <div class="modal-content">            <div class="modal-header">                <h5 class="modal-title">决策大屏标段管理</h5>            </div>            <div class="modal-body">                <div class="mb-2">                    <span>新增的标段是否默认展示到决策大屏:</span>                    <a class="btn btn-sm btn-light">                        <div class="custom-control custom-checkbox">                            <input type="radio" name="add_datacollect" class="custom-control-input" value="1" <% if (ctx.subProject.page_show.addDataCollect === 1) { %>checked<% } %> id="yes_datacollect">                            <label class="custom-control-label text-primary" for="yes_datacollect">是</label>                        </div>                    </a>                    <a class="btn btn-sm btn-light">                        <div class="custom-control custom-checkbox">                            <input type="radio" name="add_datacollect" class="custom-control-input" value="0" <% if (ctx.subProject.page_show.addDataCollect === 0) { %>checked<% } %> id="no_datacollect">                            <label class="custom-control-label text-primary" for="no_datacollect">否</label>                        </div>                    </a>                </div>                <div class="alert alert-warning mb-1">已勾选的标段将展示到决策大屏中</div>                <div class="zTreeDemoBackground left modal-height-500" style="overflow: auto">                    <table class="table table-hover table-bordered">                        <thead>                        <tr>                            <th>名称</th>                            <th width="40"><input style="vertical-align: middle" type="checkbox" id="select-tender-all"></th>                        </tr>                        </thead>                        <tbody id="copyModalContent">                        </tbody>                    </table>                </div>            </div>            <div class="modal-footer">                <button type="button" class="btn btn-sm btn-secondary" data-dismiss="modal">取消</button>                <button type="button" class="btn btn-sm btn-primary" id="tender_dataCollect_btn">确定</button>            </div>        </div>    </div></div><!--权限管理 --><div class="modal fade" id="power" data-backdrop="static">    <div class="modal-dialog" role="document">        <div class="modal-content">            <div class="modal-header">                <h5 class="modal-title">权限管理</h5>            </div>            <div class="modal-body">                <!--<div class="form-check">-->                    <!--<input class="form-check-input" type="radio" name="exampleRadios" id="exampleRadios1" value="option1">-->                    <!--<label class="form-check-label" for="exampleRadios1">-->                        <!--仅自己可见(只有管理员自己可以看到)-->                    <!--</label>-->                <!--</div>-->                <div class="form-check">                    <!--<input class="form-check-input" type="radio" name="exampleRadios" id="exampleRadios2" value="option2" checked>-->                    <label class="form-check-label" for="exampleRadios2">                        指定成员可见(只有指定的成员可以访问当前数据大屏)                    </label>                </div>                <div class="px-3 py-2">                    <div class="">                        <!--<div class="input-group">-->                            <!--<input class="form-control" placeholder="搜索用户组、成员" type="text">-->                            <!--<div class="input-group-append">-->                                <!--<button class="btn btn-outline-secondary" type="button"><i class="fa fa-search"></i></button>-->                            <!--</div>-->                        <!--</div>-->                        <button class="btn btn-outline-primary btn-sm dropdown-toggle" type="button" id="dropdownMenuButton"                                data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">                            添加成员                        </button>                        <div class="dropdown-menu dropdown-menu-left" aria-labelledby="dropdownMenuButton" style="width:220px">                            <div class="mb-2 p-2"><input class="form-control form-control-sm" placeholder="姓名/手机 检索"                                                         id="gr-search" autocomplete="off"></div>                            <dl class="list-unstyled book-list">                                <% accountGroup.forEach((group, idx) => { %>                                    <dt><a href="javascript: void(0);" class="acc-btn" data-groupid="<%- idx %>"                                           data-type="hide"><i class="fa fa-plus-square"></i></a> <%- group.groupName %></dt>                                    <div class="dd-content" data-toggleid="<%- idx %>">                                        <dd class="border-bottom p-2 mb-0" data-groupname="<%- group.groupName %>"><p class="mb-0 d-flex"><span class="text-primary">该单位下所有组员</span></p></dd>                                        <% group.groupList.forEach(item => { %>                                            <% if (item.id !== ctx.session.sessionUser.accountId) { %>                                                <dd class="border-bottom p-2 mb-0 " data-id="<%- item.id %>">                                                    <p class="mb-0 d-flex"><span class="text-primary"><%- item.name %></span><span                                                                class="ml-auto"><%- item.mobile %></span></p>                                                    <span class="text-muted"><%- item.role %></span>                                                </dd>                                            <% } %>                                        <% });%>                                    </div>                                <% }) %>                            </dl>                        </div>                        <div class="card mt-1">                            <ul class="list-unstyled modal-height-500" id="audit-list" style="overflow: auto">                                <% for (const audit of dataCollectAudits) { %>                                <li class="border-bottom p-2 mb-0">                                    <a href="javascript:void(0)" class="text-danger pull-right" data-id="<%- audit.uid %>" data-type="audit">                                        <i class="fa fa-remove text-danger remove-audit"></i></a><%- audit.name %>                                    <small class="text-muted ml-1"><%- audit.company %></small>                                </li>                                <% } %>                            </ul>                        </div>                    </div>                </div>            </div>            <div class="modal-footer">                <button type="button" class="btn btn-sm btn-secondary" data-dismiss="modal">关闭</button>                <!--<button type="button" class="btn btn-sm btn-primary">确定</button>-->            </div>        </div>    </div></div><% if (is_dz2) { %><!--决策大屏六设置--><div class="modal fade" id="dpsix-set" data-backdrop="static">    <div class="modal-dialog" role="document">        <div class="modal-content">            <div class="modal-header">                <h5 class="modal-title">数据统计设置</h5>            </div>            <div class="modal-body">                <ul class="list-unstyled">                    <li class="d-flex justify-content-start align-items-center mb-3">                        <span class="col-auto">工程收入:</span>                        <span class="mr-2">                            <select class="form-control form-control-sm" id="sr_cate_select">                                <option value="0">请选择分类</option>                                <% for (const c of categoryData) { %>                                    <option value="<%- c.id %>"><%- c.name %></option>                                <% } %>                            </select>                          </span>                        <span>                            <select class="form-control form-control-sm" id="sr_cate_value_select">                                <option value="0">请选择值</option>                            </select>                          </span>                    </li>                    <li class="d-flex justify-content-start align-items-center mb-3">                        <span class="col-auto">工程成本:</span>                        <span class="mr-2">                            <select class="form-control form-control-sm" id="cb_cate_select">                                <option value="0">请选择分类</option>                                <% for (const c of categoryData) { %>                                    <option value="<%- c.id %>"><%- c.name %></option>                                <% } %>                            </select>                          </span>                        <span>                            <select class="form-control form-control-sm" id="cb_cate_value_select">                                <option value="0">请选择值</option>                            </select>                          </span>                    </li>                    <li class="d-flex justify-content-start align-items-center mb-1">                        <span class="col-auto">工程成本费用分类(最多只能选择4个,界面只有4个):</span>                        <span class="mr-2">                            <div class="dropdown show">                                <button class="btn btn-sm  dropdown-toggle text-primary" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="true">请选择值</button>                                <div class="dropdown-menu pb-1" aria-labelledby="dropdownMenuButton" x-placement="bottom-start" >                                    <div class="px-3" id="cb_show_select">                                        <% const xmgl = categoryData.find(item => item.name === '管理类别'); %>                                        <% if (xmgl && xmgl.value && xmgl.value.length !== 0) { %>                                        <% for (const v of xmgl.value) { %>                                        <div class="form-check py-1">                                            <input class="form-check-input" type="checkbox" id="xmgl_value_<%- v.id %>" value="<%- v.id %>">                                            <label class="form-check-label" for="xmgl_value_<%- v.id %>"><%- v.value %></label>                                        </div>                                        <% } %>                                        <% } %>                                    </div>                                </div>                            </div>                        </span>                    </li>                    <li class="d-flex justify-content-start align-items-center mb-3">                        <span class="col-auto" id="show_xmgl"></span>                    </li>                </ul>            </div>            <div class="modal-footer">                <button type="button" class="btn btn-sm btn-secondary" data-dismiss="modal">取消</button>                <button type="button" class="btn btn-sm btn-primary" id="dp06_save_btn">确定</button>            </div>        </div>    </div></div><script>    const daPing06Set = JSON.parse(unescape('<%- escape(JSON.stringify(daPing06Set)) %>'));    $(function () {        $('#sr_cate_select').change(function () {            const val = $(this).val()            const cate = category.find(item => item.id === parseInt(val))            $('#sr_cate_value_select').html(cate ? cate.value.map(item => `<option value="${item.id}">${item.value}</option>`).join('') : '<option value="0">请选择值</option>');        })        $('#cb_cate_select').change(function () {            const val = $(this).val()            const cate = category.find(item => item.id === parseInt(val))            $('#cb_cate_value_select').html(cate ? cate.value.map(item => `<option value="${item.id}">${item.value}</option>`).join('') : '<option value="0">请选择值</option>');        });        $('#dpsix-set').on('show.bs.modal', function (e) {            console.log(daPing06Set);            if (daPing06Set.sr) {                $('#sr_cate_select').val(daPing06Set.sr);                $('#sr_cate_value_select').html(category.find(item => item.id === parseInt(daPing06Set.sr)).value.map(item => `<option value="${item.id}" ${daPing06Set.sr_value === item.id ? 'selected' : ''}>${item.value}</option>`).join(''));            } else {                $('#sr_cate_value_select').html('<option value="0">请选择值</option>')            }            if (daPing06Set.cb) {                $('#cb_cate_select').val(daPing06Set.cb);                $('#cb_cate_value_select').html(category.find(item => item.id === parseInt(daPing06Set.cb)).value.map(item => `<option value="${item.id}" ${daPing06Set.cb_value === item.id ? 'selected' : ''}>${item.value}</option>`).join(''));            } else {                $('#cb_cate_value_select').html('<option value="0">请选择值</option>')            }            $('#cb_show_select').find('input').prop('checked', false);            const show_xmgl_array = [];            $('#cb_show_select').find('input').each(function () {                if (daPing06Set.cb_show && daPing06Set.cb_show.length > 0 && daPing06Set.cb_show.includes(parseInt($(this).val()))) {                    $(this).prop('checked', true);                    show_xmgl_array.push($(this).next().text());                }            });            $('#show_xmgl').text(show_xmgl_array.join('、'));        });        $('#cb_show_select').on('click', function (e) {            e.stopPropagation();        });        $('#cb_show_select input').on('click', function () {            const checked = $('#cb_show_select input:checked');            if (checked.length > 4) {                $(this).prop('checked', false);                toastr.warning('最多只能选择4个');                return;            }            const show_xmgl_array = [];            $('#cb_show_select').find('input').each(function () {                if ($(this).is(':checked')) {                    show_xmgl_array.push($(this).next().text());                }            });            $('#show_xmgl').text(show_xmgl_array.join('、'));        });        $('#dp06_save_btn').click(function () {            if ($('#sr_cate_select').val() === '0') {                toastr.warning('请选择工程收入分类');                return;            }            if ($('#sr_cate_value_select').val() === '0') {                toastr.warning('请选择工程收入分类值');                return;            }            if ($('#cb_cate_select').val() === '0') {                toastr.warning('请选择工程成本费用分类');                return;            }            if ($('#cb_cate_value_select').val() === '0') {                toastr.warning('请选择工程成本费用分类值');                return;            }            // if ($('#cb_show_select input:checked').length === 0) {            //     toastr.warning('请选择要展示的列');            //     return;            // }            daPing06Set.sr = parseInt($('#sr_cate_select').val());            daPing06Set.sr_value = parseInt($('#sr_cate_value_select').val());            daPing06Set.cb = parseInt($('#cb_cate_select').val());            daPing06Set.cb_value = parseInt($('#cb_cate_value_select').val());            daPing06Set.cb_show = $('#cb_show_select input:checked').map((index, item) => parseInt($(item).val())).get();            console.log(daPing06Set);            postData('/sp/' + spid + '/setting/datacollect/save', { type: 'save-dp06', daPing06Set }, function (result) {                toastr.success('设置成功');                $('#dpsix-set').modal('hide');            })        });    })</script><% } %><script>    $(function () {        let timer = null        let oldSearchVal = null        const accountGroup = JSON.parse(unescape('<%- escape(JSON.stringify(accountGroup)) %>'));        const accountList = JSON.parse(unescape('<%- escape(JSON.stringify(accountList)) %>'));        let dataCollectAudits = JSON.parse(unescape('<%- escape(JSON.stringify(dataCollectAudits)) %>'));        const cur_uid = parseInt(<%- ctx.session.sessionUser.accountId %>);        $('#gr-search').bind('input propertychange', function(e) {            oldSearchVal = e.target.value            timer && clearTimeout(timer)            timer = setTimeout(() => {                const newVal = $('#gr-search').val()                let html = ''                if (newVal && newVal === oldSearchVal) {                    accountList.filter(item => item && cur_uid !== item.id && (item.name.indexOf(newVal) !== -1 || (item.mobile && item.mobile.indexOf(newVal) !== -1))).forEach(item => {                        html += `<dd class="border-bottom p-2 mb-0 " data-id="${item.id}" >                        <p class="mb-0 d-flex"><span class="text-primary">${item.name}</span><span                                class="ml-auto">${item.mobile || ''}</span></p>                        <span class="text-muted">${item.role || ''}</span>                    </dd>`                    })                    $('.book-list').empty()                    $('.book-list').append(html)                } else {                    if (!$('.acc-btn').length) {                        accountGroup.forEach((group, idx) => {                            if (!group) return                            html += `<dt><a href="javascript: void(0);" class="acc-btn" data-groupid="${idx}" data-type="hide"><i class="fa fa-plus-square"></i>                        </a> ${group.groupName}</dt>                        <div class="dd-content" data-toggleid="${idx}">                        <dd class="border-bottom p-2 mb-0" data-groupname="${group.groupName}"><p class="mb-0 d-flex"><span class="text-primary">该单位下所有组员</span></p></dd>`                            group.groupList.forEach(item => {                                if (item.id !== cur_uid) {                                    html += `<dd class="border-bottom p-2 mb-0 " data-id="${item.id}" >                                    <p class="mb-0 d-flex"><span class="text-primary">${item.name}</span><span                                            class="ml-auto">${item.mobile || ''}</span></p>                                    <span class="text-muted">${item.role || ''}</span>                                </dd>`                                }                            });                            html += '</div>'                        })                        $('.book-list').empty()                        $('.book-list').append(html)                    }                }            }, 400);        });        // 添加到成员中        $('.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 id = parseInt($(this).data('id'));            const groupName = $(this).data('groupname');            if (!isNaN(id) && id !== 0) {                postData('/sp/' + spid + '/setting/datacollect/save', { type: 'add-audit', id }, function (result) {                    dataCollectAudits = result;                    setList(dataCollectAudits);                })            } else if (groupName && groupName !== '') {                const groupAuditList = _.filter(accountList, { company: groupName });                const groupAidList = _.map(groupAuditList, 'id');                const groupDAList = _.map(dataCollectAudits, 'uid');                const addAidList = _.difference(groupAidList, groupDAList);                console.log(groupAidList, groupDAList, addAidList);                if (addAidList.length > 0) {                    postData('/sp/' + spid + '/setting/datacollect/save', { type: 'add-audit', id: addAidList }, function (result) {                        // toastr.success(`成功添加 位用户`);                        dataCollectAudits = result;                        setList(dataCollectAudits);                    })                } else {                    toastr.warning('暂无用户添加');                }            }        });        // 删除审批人        $('body').on('click', '#audit-list li>a', function () {            console.log($(this).attr('data-id'), $(this).attr('data-type'));            if ($(this).attr('data-type') === 'audit') {                postData('/sp/' + spid + '/setting/datacollect/save', { type: 'del-audit', id: $(this).attr('data-id') }, function (result) {                    dataCollectAudits = result;                    setList(dataCollectAudits);                })            }        });        function setList(datas) {            let list = '';            for (const audit of datas) {                list += '<li class="border-bottom p-2 mb-0"><a href="javascript:void(0)" class="text-danger pull-right" data-id="'+ audit.uid +'"' + ' data-type="audit">' +                    '<i class="fa fa-remove text-danger remove-audit"></i></a>'+ audit.name +'<small class="text-muted ml-1">'+ audit.company +'</small></li>';            }            $('#audit-list').html(list);        }    })</script>
 |