From ff3f37587f086aa854d2aa67ebd17d6d878e6f44 Mon Sep 17 00:00:00 2001 From: weizhiqiang <598748873@qq.com> Date: Sun, 16 Jan 2022 12:29:33 +0800 Subject: [PATCH] =?UTF-8?q?=E8=B4=A2=E5=8A=A1=E6=98=8E=E7=BB=86=E8=B4=A6?= =?UTF-8?q?=E7=BC=96=E8=BE=91=E5=8A=9F=E8=83=BD=E5=AE=8C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../template/js/income/incomeEdit.js | 439 +++++++++--------- .../template/tpl/income/incomeEdit.html | 86 ++-- .../lib/layui/customer/voucher/voucherUtil.js | 23 +- 3 files changed, 283 insertions(+), 265 deletions(-) diff --git a/ifs/src/main/resources/template/js/income/incomeEdit.js b/ifs/src/main/resources/template/js/income/incomeEdit.js index 814561e2f..acbb60908 100644 --- a/ifs/src/main/resources/template/js/income/incomeEdit.js +++ b/ifs/src/main/resources/template/js/income/incomeEdit.js @@ -1,251 +1,262 @@ -var userReturnList = new Array();//选择用户返回的集合或者进行回显的集合 -var chooseOrNotMy = "1";//人员列表中是否包含自己--1.包含;其他参数不包含 -var chooseOrNotEmail = "2";//人员列表中是否必须绑定邮箱--1.必须;其他参数没必要 -var checkType = "2";//人员选择类型,1.多选;其他。单选 +// 兼容动态表单 +var layedit, form; layui.config({ base: basePath, version: skyeyeVersion }).extend({ window: 'js/winui.window' -}).define(['window', 'jquery', 'winui', 'laydate'], function(exports) { +}).define(['window', 'jquery', 'winui', 'laydate', 'tagEditor'].concat(dsFormUtil.mastHaveImport), function(exports) { winui.renderColor(); - layui.use(['form', 'tagEditor'], function(form) { - var index = parent.layer.getFrameIndex(window.name); - var $ = layui.$, - laydate = layui.laydate; - var rowNum = 1; //表格的序号 - var initemHtml = "";//收支项目 - - var beanTemplate = $("#beanTemplate").html(); - var usetableTemplate = $("#usetableTemplate").html(); - var selOption = getFileContent('tpl/template/select-option.tpl'); - var handsPersonList = new Array();//经手人员 - - //加载单据数据 - var orderObject = {}; - showGrid({ - id: "showForm", - url: reqBasePath + "income003", - params: {rowId: parent.rowId}, - pagination: false, - template: beanTemplate, - method: "GET", - ajaxSendAfter:function(json){ - //单据时间 - laydate.render({ - elem: '#operTime', - type: 'datetime', - trigger: 'click' - }); - orderObject = json; - // 客户信息赋值 - sysCustomerUtil.customerMation = { - id: json.bean.organId, - customName: json.bean.customName - } - initOtherMation(); - - var userNames = ""; - handsPersonList = json.bean.userInfo; - $.each(handsPersonList, function (i, item) { - userNames += item.name + ','; - }); - // 人员选择 - $('#handsPersonId').tagEditor({ - initialTags: userNames.split(','), - placeholder: '请选择经手人员', - editorTag: false, - beforeTagDelete: function(field, editor, tags, val) { - var inArray = -1; - $.each(handsPersonList, function(i, item) { - if(val === item.name) { - inArray = i; - return false; - } - }); - if(inArray != -1) { //如果该元素在集合中存在 - handsPersonList.splice(inArray, 1); - } - } - }); - } - }); + var index = parent.layer.getFrameIndex(window.name); + var $ = layui.$, + laydate = layui.laydate; + layedit = layui.layedit, + form = layui.form; - function initOtherMation() { - // 初始化账户 - systemCommonUtil.getSysAccountListByType(function(json){ - // 加载账户数据 - $("#accountId").html(getDataUseHandlebars(selOption, json)); - }); + // 获取单据提交类型 + var submitType = ""; - // 初始化收入项目 - systemCommonUtil.getSysInoutitemListByType(1, function(json){ - // 加载收入项目数据 - initemHtml = getDataUseHandlebars(selOption, json); - // 渲染数据到页面 - initDataToShow(); - }); - } + var beanTemplate = $("#beanTemplate").html(); + var selOption = getFileContent('tpl/template/select-option.tpl'); + var handsPersonList = new Array();//经手人员 - //渲染数据到页面 - function initDataToShow(){ - $("#accountId").val(orderObject.bean.accountId);//账户 - - //渲染列表项 - $.each(orderObject.bean.items, function(i, item){ - addRow(); - $("#initemId" + (rowNum - 1)).val(item.initemId);//收入项目回显 - $("#initemMoney" + (rowNum - 1)).val(item.initemMoney.toFixed(2));//金额回显 - $("#remark" + (rowNum - 1)).val(item.remark);//备注回显 - //设置标识 - $("tr[trcusid='tr" + (rowNum - 1) + "']").attr("thisid", item.id); + showGrid({ + id: "showForm", + url: reqBasePath + "income003", + params: {rowId: parent.rowId}, + pagination: false, + template: beanTemplate, + method: "GET", + ajaxSendAfter:function(json){ + submitType = json.bean.submitType; + // 单据时间 + laydate.render({ + elem: '#operTime', + type: 'datetime', + trigger: 'click' }); - matchingLanguage(); - form.render(); - } - form.on('submit(formEditBean)', function(data) { - if(winui.verifyForm(data.elem)) { - var rowTr = $("#useTable tr"); - if(rowTr.length == 0) { - winui.window.msg('请选择收入项目.', {icon: 2, time: 2000}); - return false; + // 往来单位 + $("#correspondentUnitType").val(json.bean.organType); + if(json.bean.organType == 1){ + // 供应商 + sysSupplierUtil.supplierMation = { + id: json.bean.organId, + supplierName: json.bean.supplierName } - var tableData = new Array(); - var noError = false; //循环遍历表格数据时,是否有其他错误信息 - $.each(rowTr, function(i, item) { - //获取行编号 - var rowNum = $(item).attr("trcusid").replace("tr", ""); - if(judgeInPoingArr(tableData, "initemId", $("#initemId" + rowNum).val())){ - $("#initemId" + rowNum).addClass("layui-form-danger"); - $("#initemId" + rowNum).focus(); - winui.window.msg('一张单中不允许出现相同收支项目信息.', {icon: 2, time: 2000}); - noError = true; - return false; - } - var row = { - initemId: $("#initemId" + rowNum).val(), - initemMoney: $("#initemMoney" +rowNum).val(), - remark: $("#remark" + rowNum).val() - }; - tableData.push(row); - }); - if(noError) { - return false; + }else if(json.bean.organType == 1){ + // 客户信息 + sysCustomerUtil.customerMation = { + id: json.bean.organId, + customName: json.bean.supplierName } - - var params = { - rowId: parent.rowId, - organId: sysCustomerUtil.customerMation.id, - handsPersonId: handsPersonList[0].id, - operTime: $("#operTime").val(), - accountId: $("#accountId").val(), - remark: $("#remark").val(), - changeAmount: $("#changeAmount").val(), - initemStr: JSON.stringify(tableData) - }; - AjaxPostUtil.request({url: reqBasePath + "income004", params: params, type: 'json', method: "PUT", callback: function(json) { - if(json.returnCode == 0) { - parent.layer.close(index); - parent.refreshCode = '0'; - } else { - winui.window.msg(json.returnMessage, {icon: 2, time: 2000}); - } - }}); } - return false; - }); - $("body").on("input", ".rkMoney", function() { - calculatedTotalPrice(); - }); - $("body").on("change", ".rkMoney", function() { - calculatedTotalPrice(); - }); + // 账套 + sysIfsUtil.ifsSetOfBooksMation = { + id: json.bean.setOfBooksId, + name: json.bean.setOfBooksName + }; - // 计算总价 - function calculatedTotalPrice(){ - var rowTr = $("#useTable tr"); - var allPrice = 0; - $.each(rowTr, function(i, item) { - //获取行坐标 - var rowNum = $(item).attr("trcusid").replace("tr", ""); - //获取金额 - var initemMoney = parseFloat(isNull($("#initemMoney" + rowNum).val()) ? "0" : $("#initemMoney" + rowNum).val()); - //输出金额 - $("#initemMoney" + rowNum).html((initemMoney).toFixed(2)); - allPrice += initemMoney; - }); - $("#allPrice").html(allPrice.toFixed(2)); - } + // 类型 + dsFormUtil.dsFormObjectRelationChoose = { + id: json.bean.type, + name: json.bean.typeName + }; + + erpOrderUtil.orderEditPageSetBtnBySubmitType(submitType, json.bean.state); - // 人员选择 - $("body").on("click", "#toHandsPersonSelPeople", function(e){ - userReturnList = [].concat(handsPersonList); - systemCommonUtil.openSysUserStaffChoosePage(function (staffChooseList){ - // 移除所有tag - var tags = $('#handsPersonId').tagEditor('getTags')[0].tags; - for (i = 0; i < tags.length; i++) { - $('#handsPersonId').tagEditor('removeTag', tags[i]); + // 加载动态表单 + dsFormUtil.loadPageToEditByObjectId("dsFormShow", json.bean.id); + + initOtherMation(json); + + var userNames = ""; + handsPersonList = json.bean.userInfo; + $.each(handsPersonList, function (i, item) { + userNames += item.name + ','; + }); + // 人员选择 + $('#handsPersonId').tagEditor({ + initialTags: userNames.split(','), + placeholder: '请选择经手人员', + editorTag: false, + beforeTagDelete: function(field, editor, tags, val) { + var inArray = -1; + $.each(handsPersonList, function(i, item) { + if(val === item.name) { + inArray = i; + return false; + } + }); + if(inArray != -1) { //如果该元素在集合中存在 + handsPersonList.splice(inArray, 1); + } } - handsPersonList = [].concat(staffChooseList); - // 添加新的tag - $.each(handsPersonList, function(i, item){ - $('#handsPersonId').tagEditor('addTag', item.name); - }); }); - }); + } + }); - // 新增行 - $("body").on("click", "#addRow", function() { - addRow(); + function initOtherMation(data) { + // 初始化账户 + systemCommonUtil.getSysAccountListByType(function(json){ + // 加载账户数据 + $("#accountId").html(getDataUseHandlebars(selOption, json)); + $("#accountId").val(data.bean.accountId); }); - // 删除行 - $("body").on("click", "#deleteRow", function() { - deleteRow(); - }); + // 初始化列表项选择 + voucherUtil.initData('showVoucherUtilBox', data.bean.items); - //新增行 - function addRow() { - var par = { - id: "row" + rowNum.toString(), //checkbox的id - trId: "tr" + rowNum.toString(), //行的id - initemId: "initemId" + rowNum.toString(), //收入项目id - initemMoney: "initemMoney" + rowNum.toString(), //金额id - remark: "remark" + rowNum.toString() //备注id - }; - $("#useTable").append(getDataUseHandlebars(usetableTemplate, par)); - //赋值给收支项目 - $("#" + "initemId" + rowNum.toString()).html(initemHtml); - form.render('select'); - form.render('checkbox'); - rowNum++; + matchingLanguage(); + form.render(); + } + + // 保存为草稿 + form.on('submit(formEditBean)', function(data) { + if(winui.verifyForm(data.elem)) { + saveData('1', ""); + } + return false; + }); + + // 走工作流的提交审批 + form.on('submit(formSubOneBean)', function(data) { + if(winui.verifyForm(data.elem)) { + activitiUtil.startProcess(sysActivitiModel["incomeOrder"]["key"], function (approvalId) { + saveData("2", approvalId); + }); + } + return false; + }); + + // 不走工作流的提交 + form.on('submit(formSubTwoBean)', function(data) { + if(winui.verifyForm(data.elem)) { + saveData('2', ""); + } + return false; + }); + + // 工作流中保存 + form.on('submit(save)', function(data) { + if(winui.verifyForm(data.elem)) { + saveData('3', ""); } + return false; + }); - //删除行 - function deleteRow() { - var checkRow = $("#useTable input[type='checkbox'][name='tableCheckRow']:checked"); - if(checkRow.length > 0) { - $.each(checkRow, function(i, item) { - $(item).parent().parent().remove(); - }); + function saveData(subType, approvalId){ + var result = voucherUtil.getData(); + if(result.length < 2){ + return false; + } + var params = { + organType: $("#correspondentUnitType").val(), + organId: getOrganId(), + type: dsFormUtil.dsFormObjectRelationChoose.id, + handsPersonId: handsPersonList[0].id, + operTime: $("#operTime").val(), + accountId: $("#accountId").val(), + remark: $("#remark").val(), + setOfBooksId: sysIfsUtil.ifsSetOfBooksMation.id, + initemStr: JSON.stringify(result), + submitType: submitType, + subType: subType, + approvalId: approvalId, + rowId: parent.rowId + }; + AjaxPostUtil.request({url: reqBasePath + "income004", params: params, type: 'json', method: "PUT", callback: function(json) { + if(json.returnCode == 0) { + dsFormUtil.savePageData("dsFormShow", json.bean.id); + parent.layer.close(index); + parent.refreshCode = '0'; } else { - winui.window.msg('请选择要删除的行', {icon: 2, time: 2000}); + winui.window.msg(json.returnMessage, {icon: 2, time: 2000}); } + }}); + } + + function getOrganId(){ + var correspondentUnitType = $("#correspondentUnitType").val(); + if(correspondentUnitType == 1){ + // 供应商 + return sysSupplierUtil.supplierMation.id; + } else if (correspondentUnitType == 2){ + // 客户 + return sysCustomerUtilcustomerMation; } - - // 客户选择 - $("body").on("click", "#customMationSel", function(e){ + } + + // 往来单位变化监听 + form.on('select(correspondentUnitType)', function(data){ + $("#customName").val(""); + }); + + // 人员选择 + $("body").on("click", "#toHandsPersonSelPeople", function(e){ + systemCommonUtil.userReturnList = [].concat(handsPersonList); + systemCommonUtil.chooseOrNotMy = "2"; // 人员列表中是否包含自己--1.包含;其他参数不包含 + systemCommonUtil.chooseOrNotEmail = "2"; // 人员列表中是否必须绑定邮箱--1.必须;其他参数没必要 + systemCommonUtil.checkType = "2"; // 人员选择类型,1.多选;其他。单选 + systemCommonUtil.openSysUserStaffChoosePage(function (staffChooseList){ + // 移除所有tag + var tags = $('#handsPersonId').tagEditor('getTags')[0].tags; + for (i = 0; i < tags.length; i++) { + $('#handsPersonId').tagEditor('removeTag', tags[i]); + } + handsPersonList = [].concat(staffChooseList); + // 添加新的tag + $.each(handsPersonList, function(i, item){ + $('#handsPersonId').tagEditor('addTag', item.name); + }); + }); + }); + + // 新增行 + $("body").on("click", "#addRow", function() { + voucherUtil.addItem(); + }); + + // 往来单位选择 + $("body").on("click", "#customMationSel", function(e){ + var correspondentUnitType = $("#correspondentUnitType").val(); + if(correspondentUnitType == 1){ + // 供应商 + sysSupplierUtil.openSysSupplierChoosePage(function (supplierMation){ + $("#customName").val(supplierMation.supplierName); + }); + } else if (correspondentUnitType == 2){ + // 客户 sysCustomerUtil.openSysCustomerChoosePage(function (customerMation){ $("#customName").val(customerMation.customName); }); - }); + } - $("body").on("click", "#cancle", function() { - parent.layer.close(index); + }); + + // 选择账套 + $("body").on("click", "#chooseSetOfBooksBtn", function(e){ + var _this = $(this); + sysIfsUtil.openIfsSetOfBooksListChoosePage(function (ifsSetOfBooksMation){ + _this.parent().find("input").val(ifsSetOfBooksMation.name); }); }); + + // 选择单据类型 + $("body").on("click", "#chooseOrderTypeBtn", function(e){ + var _this = $(this); + dsFormUtil.openDsFormObjectRelationChooseByFirstTypeCodeChoosePage("IFS", function (dsFormObjectRelationChoose){ + _this.parent().find("input").val(dsFormObjectRelationChoose.name); + $("#dsFormShow").html(""); + // 加载动态表单 + dsFormUtil.loadPageByCode("dsFormShow", null, dsFormObjectRelationChoose.id); + }); + }); + + $("body").on("click", "#cancle", function() { + parent.layer.close(index); + }); }); \ No newline at end of file diff --git a/ifs/src/main/resources/template/tpl/income/incomeEdit.html b/ifs/src/main/resources/template/tpl/income/incomeEdit.html index 3782a7862..06db24fd6 100644 --- a/ifs/src/main/resources/template/tpl/income/incomeEdit.html +++ b/ifs/src/main/resources/template/tpl/income/incomeEdit.html @@ -5,6 +5,7 @@