123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- 'use strict';
- /**
- *
- *
- * @author Ellisran
- * @date 2020/10/09
- * @version
- */
- $(document).ready(function () {
- let timer = null;
- let oldSearchVal = null;
- const needYB = ['ledger', 'revise', 'change'];
- $('body').on('input propertychange', '.gr-search', function(e) {
- oldSearchVal = e.target.value;
- timer && clearTimeout(timer);
- timer = setTimeout(() => {
- const newVal = $(this).val();
- const code = $(this).attr('data-code');
- let html = '';
- if (newVal && newVal === oldSearchVal) {
- accountList.filter(item => item && (item.id !== cur_uid || (item.id === cur_uid && needYB.indexOf(code) !== -1)) && (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>`
- });
- $('#' + code + '_dropdownMenu .book-list').empty();
- $('#' + code + '_dropdownMenu .book-list').append(html);
- } else {
- if (!$('#' + code + '_dropdownMenu .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}">`;
- group.groupList.forEach(item => {
- if ((item.id !== cur_uid || (item.id === cur_uid && needYB.indexOf(code) !== -1))) {
- 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>';
- });
- $('#' + code + '_dropdownMenu .book-list').empty();
- $('#' + code + '_dropdownMenu .book-list').append(html);
- }
- }
- }, 400);
- });
- // 添加审批流程按钮逻辑
- $('body').on('click', '.book-list 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;
- });
- // 更改审批流程状态
- $('.form-check input').on('change', function () {
- // 获取所有审批的checked值并更新
- const this_status = parseInt($(this).val());
- const this_code = $(this).data('code');
- const spt = sp_status_list[this_status];
- $(this).parents('.form-group').siblings('.alert-warning').text(spt.name + ':' + spt.msg);
- // 拼接post json
- const prop = {
- code: this_code,
- status: this_status
- };
- const _self = $(this);
- const tenderId = window.location.pathname.split('/')[2];
- postData('/tender/' + tenderId + '/shenpi/save', prop, function (data) {
- if (this_status === sp_status.sqspr) {
- _self.parents('.form-group').siblings('.lc-show').html('');
- } else if (this_status === sp_status.gdspl) {
- let addhtml = '<ul class="list-unstyled">\n';
- if (data.length !== 0) {
- for(const [i, audit] of data.entries()) {
- addhtml += makeAudit(audit, transFormToChinese(i+1));
- }
- addhtml += '<li class="pl-3"><a href="javascript:void(0);" class="add-audit"><i class="fa fa-plus"></i> 添加流程</a></li>';
- } else {
- addhtml += makeSelectAudit(this_code, '一');
- }
- addhtml += '</ul>\n';
- _self.parents('.form-group').siblings('.lc-show').html(addhtml);
- } else if (this_status === sp_status.gdzs) {
- let addhtml = '<ul class="list-unstyled">\n' +
- ' <li class="d-flex justify-content-start mb-3">\n' +
- ' <span class="col-auto">授权审批人</span>\n' +
- ' <span class="col-7">\n' +
- ' <span class="d-inline-block"></span>\n' +
- ' </span>\n' +
- ' </li>\n';
- addhtml += data ? makeAudit(data) : makeSelectAudit(this_code);
- addhtml += '</ul>\n';
- _self.parents('.form-group').siblings('.lc-show').html(addhtml);
- }
- });
- });
- // 选中审批人
- $('body').on('click', 'dl dd', function () {
- const id = parseInt($(this).data('id'));
- if (id) {
- const user = _.find(accountList, function (item) {
- return item.id === id;
- });
- const this_status = parseInt($(this).parents('.lc-show').siblings('.form-group').find('input:checked').val());
- const this_code = $(this).parents('.lc-show').siblings('.form-group').find('input:checked').data('code');
- if (this_status === sp_status.gdspl) {
- // 判断是否已存在审批人
- const aid_num = $(this).parents('ul').find('.remove-audit').length;
- for (let i = 0; i < aid_num; i++) {
- const aid = parseInt($(this).parents('ul').find('.remove-audit').eq(i).data('id'));
- if (aid === id) {
- toastr.warning('该审核人已存在,请勿重复添加');
- return;
- }
- }
- }
- const prop = {
- status: this_status,
- code: sp_type[this_code],
- audit_id: id,
- type: 'add',
- };
- const _self = $(this);
- const tenderId = window.location.pathname.split('/')[2];
- postData('/tender/' + tenderId + '/shenpi/audit/save', prop, function (data) {
- if (this_status === sp_status.gdspl) {
- _self.parents('ul').append('<li class="pl-3"><a href="javascript:void(0);" class="add-audit"><i class="fa fa-plus"></i> 添加流程</a></li>');
- }
- _self.parents('.spr-span').html('<span class="d-inline-block"></span>\n' +
- '<span class="d-inline-block"><span class="badge badge-light">'+ user.name +' <a href="javascript:void(0);" class="remove-audit btn-sm text-danger px-1" title="移除" data-id="'+ user.id +'"><i class="fa fa-remove"></i></a></span> </span>');
- });
- }
- });
- // 移除审批人
- $('body').on('click', '.remove-audit', function () {
- const id = parseInt($(this).data('id'));
- const this_status = parseInt($(this).parents('.lc-show').siblings('.form-group').find('input:checked').val());
- const this_code = $(this).parents('.lc-show').siblings('.form-group').find('input:checked').data('code');
- const prop = {
- status: this_status,
- code: sp_type[this_code],
- audit_id: id,
- type: 'del',
- };
- const _self = $(this);
- const tenderId = window.location.pathname.split('/')[2];
- postData('/tender/' + tenderId + '/shenpi/audit/save', prop, function (data) {
- if (this_status === sp_status.gdspl) {
- const _selflc = _self.parents('.lc-show');
- _self.parents('li').remove();
- const aid_num = parseInt(_selflc.children('ul').find('li.d-flex').length);
- if (aid_num === 0) {
- let addhtml = '<ul class="list-unstyled">\n';
- addhtml += makeSelectAudit(this_code, '一');
- addhtml += '</ul>\n';
- _selflc.html(addhtml);
- } else {
- for (let i = 0; i < aid_num; i++) {
- _selflc.find('li.d-flex').eq(i).find('.col-auto').text(transFormToChinese(i+1) + '审');
- }
- }
- } else if (this_status === sp_status.gdzs) {
- let addhtml = '<ul class="list-unstyled">\n' +
- ' <li class="d-flex justify-content-start mb-3">\n' +
- ' <span class="col-auto">授权审批人</span>\n' +
- ' <span class="col-7">\n' +
- ' <span class="d-inline-block"></span>\n' +
- ' </span>\n' +
- ' </li>\n';
- addhtml += makeSelectAudit(this_code);
- addhtml += '</ul>\n';
- _self.parents('.lc-show').html(addhtml);
- }
- })
- });
- // 固定审批流-添加流程
- $('body').on('click', '.add-audit', function () {
- const num = $(this).parents('ul').children('li').length;
- const this_code = $(this).parents('.lc-show').siblings('.form-group').find('input:checked').data('code');
- const addhtml = makeSelectAudit(this_code, transFormToChinese(num));
- $(this).parents('ul').append(addhtml);
- $(this).parents('li').remove();
- });
- // 审批流程-审批人html 生成
- function makeAudit(audit, i = '终') {
- return '<li class="d-flex justify-content-start mb-3">\n' +
- ' <span class="col-auto">'+ i +'审</span>\n' +
- ' <span class="col-7 spr-span">\n' +
- ' <span class="d-inline-block"></span>\n' +
- ' <span class="d-inline-block"><span class="badge badge-light">'+ audit.name +' <a href="javascript:void(0);" class="remove-audit btn-sm text-danger px-1" title="移除" data-id="'+ audit.audit_id +'"><i class="fa fa-remove"></i></a></span> </span>\n' +
- ' </span>\n' +
- ' </li>';
- }
- // 审批流程-选择审批人html 生成
- function makeSelectAudit(code, i = '终') {
- let divhtml = '';
- accountGroup.forEach((group, idx) => {
- let didivhtml = '';
- if(group) {
- group.groupList.forEach(item => {
- didivhtml += (item.id !== cur_uid || (item.id === cur_uid && needYB.indexOf(code) !== -1)) ? '<dd class="border-bottom p-2 mb-0 " data-id="' + item.id + '" >\n' +
- '<p class="mb-0 d-flex"><span class="text-primary">' + item.name + '</span><span\n' +
- ' class="ml-auto">' + item.mobile + '</span></p>\n' +
- ' <span class="text-muted">' + item.role + '</span>\n' +
- ' </dd>\n' : '';
- });
- divhtml += '<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>\n' +
- ' <div class="dd-content" data-toggleid="' + idx + '">\n' + didivhtml +
- ' </div>\n';
- }
- });
- let html = '<li class="d-flex justify-content-start mb-3">\n' +
- ' <span class="col-auto">' + i + '审</span>\n' +
- ' <span class="col-7 spr-span">\n' +
- ' <span class="d-inline-block">\n' +
- ' <div class="dropdown text-right">\n' +
- ' <button class="btn btn-outline-primary btn-sm dropdown-toggle" type="button" id="' + code + '_dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">\n' +
- ' 选择审批人\n' +
- ' </button>\n' +
- ' <div class="dropdown-menu dropdown-menu-right" id="' + code + '_dropdownMenu" aria-labelledby="' + code + '_dropdownMenuButton" style="width:220px">\n' +
- ' <div class="mb-2 p-2"><input class="form-control form-control-sm gr-search"\n' +
- ' placeholder="姓名/手机 检索" autocomplete="off" data-code="' + code + '"></div>\n' +
- ' <dl class="list-unstyled book-list">\n' + divhtml +
- ' </dl>\n' +
- ' </div>\n' +
- ' </div>\n' +
- ' </span>\n' +
- ' </span>\n' +
- ' </li>';
- return html;
- }
- });
|