| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908 |
- shr.defineClass("shr.customer.gtiit.BatchSubmitShemeBillMySubmissionEditEx", shr.compensation.BatchSubmitShemeBillMySubmissionEdit, {
- initalizeDOM: function () {
- shr.customer.gtiit.BatchSubmitShemeBillMySubmissionEditEx.superClass.initalizeDOM.call(this);
- },
- /**
- * 初始化表格头数据
- * @return {[type]} [description]
- */
- getEditGridColModel: function () {
- var _self = this;
- var submitSchemeId = '';
- var ctrlrole = $('#submitScheme').attr('ctrlrole');
- if (ctrlrole == 'promptBox') {
- submitSchemeId = $('#submitScheme').shrPromptBox('getValue').id;
- } else {
- submitSchemeId = $('#submitScheme').val();
- }
- var datasource = _self.getFieldValue('datasource');
- if (datasource == "") {
- datasource = 2;
- }
- //表格处理
- _self.remoteCall({
- method: "getEditGridColModel",
- param: {
- submitSchemeId: submitSchemeId,
- datasource: datasource
- },
- success: function (data) {
- var colModel = data.colModel;
- for (var i = 0; i < data.colNames.length; i++) {
- var colName = data.colNames[i];
- if (colName == "Contract Start Time(合同开始时间)") {
- data.colNames[i] = "Start Time开始时间)"
- } else if (colName == "Contract End Time(合同结束时间)") {
- data.colNames[i] = "End Time(结束时间)"
- }
- }
- _self.colNames = data.colNames;
- _self.colModel = data.colModel;
- if (colModel) {
- var col;
- // 初始化数值类型的列,并且获取到精度,用来做保存数据的格式化
- var reg = new RegExp('^[sS]\\d+');
- var decimalPrecision = 0;
- for (var i = 0, size = colModel.length; i < size; i++) {
- col = colModel[i];
- if (col.label == "Contract Start Time(合同开始时间)") {
- col.label = "Start Time开始时间)"
- }
- if (col.label == "Contract End Time(合同结束时间)") {
- col.label = "End Time(结束时间)"
- }
- if (col && col.name && col.name && reg.test(col.name) && "numberfield" == col.formatter) {
- decimalPrecision = col.editoptions.inputJson.decimalPrecision;
- _self.numTypeFieldMap[col.name] = decimalPrecision;
- }
- }
- }
- _self.setSubmitSchemeDescription(data.description);
- _self.renderGridHeader();
- }
- });
- },
- setGridNameEvent: function () {
- var _self = this;
- $entry = $('#entry');
- $entry.jqGrid("option", {
- afterSaveCell: function (rowid, cellname, value, iRow, iCol, rowData) {
- if (cellname == "startTime" || cellname == "endTime" || cellname == "restStartTime" || cellname == "restEndTime") {
- //发生日期
- var effectTime = $("#entry").jqGrid("getCell", rowid, "effectDate");
- var cellTime = $("#entry").jqGrid("getCell", rowid, cellname);
- if (effectTime && cellTime) {
- var effectDate = _self.convertTimeZone(effectTime);
- let year = effectDate.getFullYear(); // 获取年份(4位数)
- let month = effectDate.getMonth() + 1; // 获取月份(0-11,需要加1)
- let day = effectDate.getDate(); // 获取日期(1-31)
- // 格式化为年月日字符串
- let formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
- var cellTimeOfDate = new Date(cellTime);
- let hours = cellTimeOfDate.getHours(); // 获取小时(0-23)
- let minutes = cellTimeOfDate.getMinutes(); // 获取分钟(0-59)
- let formattedTime = `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}`;
- $("#entry").jqGrid("setCell", rowid, cellname, formattedDate + " " + formattedTime);
- }
- _self.countHourAndMultiple(rowid);
- }
- if (cellname == "effectDate") {
- //发生日期
- var effectTime = $("#entry").jqGrid("getCell", rowid, "effectDate");
- var effectDate = new Date();
- if (effectTime) {
- effectDate = new Date(effectTime);
- }
- effectDate = _self.convertTimeZone(effectTime);
- let year = effectDate.getFullYear(); // 获取年份(4位数)
- let month = effectDate.getMonth() + 1; // 获取月份(0-11,需要加1)
- let day = effectDate.getDate(); // 获取日期(1-31)
- // 格式化为年月日字符串
- let formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
- //开始时间
- var startTime = $("#entry").jqGrid("getCell", rowid, "startTime");
- //结束时间
- var endTime = $("#entry").jqGrid("getCell", rowid, "endTime");
- //休息开始时间
- var restStartTime = $("#entry").jqGrid("getCell", rowid, "restStartTime");
- //休息结束时间
- var restEndTime = $("#entry").jqGrid("getCell", rowid, "restEndTime");
- if (startTime) {
- var startTimeOfDate = new Date(startTime);
- let hours = startTimeOfDate.getHours(); // 获取小时(0-23)
- let minutes = startTimeOfDate.getMinutes(); // 获取分钟(0-59)
- let formattedTime = `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}`;
- $("#entry").jqGrid("setCell", rowid, "startTime", formattedDate + " " + formattedTime);
- }
- if (endTime) {
- var endTimeOfDate = new Date(endTime);
- let hours = endTimeOfDate.getHours(); // 获取小时(0-23)
- let minutes = endTimeOfDate.getMinutes(); // 获取分钟(0-59)
- let formattedTime = `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}`;
- $("#entry").jqGrid("setCell", rowid, "endTime", formattedDate + " " + formattedTime);
- }
- if (restStartTime) {
- var restStartTimeOfDate = new Date(restStartTime);
- let hours = restStartTimeOfDate.getHours(); // 获取小时(0-23)
- let minutes = restStartTimeOfDate.getMinutes(); // 获取分钟(0-59)
- let formattedTime = `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}`;
- $("#entry").jqGrid("setCell", rowid, "restStartTime", formattedDate + " " + formattedTime);
- }
- if (restEndTime) {
- var restEndTimeOfDate = new Date(restEndTime);
- let hours = restEndTimeOfDate.getHours(); // 获取小时(0-23)
- let minutes = restEndTimeOfDate.getMinutes(); // 获取分钟(0-59)
- let formattedTime = `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}`;
- $("#entry").jqGrid("setCell", rowid, "restEndTime", formattedDate + " " + formattedTime);
- }
- _self.countHourAndMultiple(rowid);
- }
- },
- "afterEditCell": function (rowid, colName, value, iRow, iCol, rowData) {
- if (colName === "person") {
- var id = "#" + iRow + "_person";
- var option = $(id).shrPromptBox("option");
- var subWidgetOptions = option.subWidgetOptions
- subWidgetOptions.multiselect = true;
- subWidgetOptions.filter = " hrOrgUnit.id = '" + $("#hrOrgUnit").shrPromptBox("getValue").id + "'";
- subWidgetOptions.otherParams = { adminOrgId: $("#adminOrg").shrPromptBox("getValue").id, hrOrgUnitId: $("#hrOrgUnit").shrPromptBox("getValue").id };
- $(id).shrPromptBox("option", {
- "subWidgetOptions": subWidgetOptions,
- "onchange": function (e, val) {
- var personData = val.current;
- var prevPersonData = val.previous;
- var length = personData.length;
- var newRowData = [];
- for (var i = 0; i < length; i++) {
- var item = personData[i];
- var updateItem = {};
- var oldData = $entry.wafGrid("getRowData", rowid);
- var startDate;
- var endDate;
- var isqw;
- if (item["empOrgRelation.assignType"].alias == "主要任职") {
- isqw = true;
- _self.remoteCall({
- method: "getDateTime",
- param: { personId: item["person.id"], type: "Full" },
- async: false,
- success: function (data) {
- startDate = data.startDate
- endDate = data.endDate
- },
- error: function (error) {
- console.log(error);
- }
- });
- } else if (item["empOrgRelation.assignType"].alias == "兼职任职") {
- isqw = false;
- _self.remoteCall({
- method: "getDateTime",
- param: {
- personId: item["person.id"],
- adminOrgId: item["adminOrg.id"],
- positionId: item["position.id"],
- hourlywage: item["empOrgRelation.hourlywage"],
- type: "Part"
- },
- async: false,
- success: function (data) {
- startDate = data.startDate
- endDate = data.endDate
- },
- error: function (error) {
- console.log(error);
- }
- });
- }
- if (i == 0) {
- // if(!prevPersonData || prevPersonData.id !== item["person.id"]){
- if (item.id !== oldData.cmpEmpORelation.id) {
- var beginContractDate, endContractDate;
- _self.remoteCall({
- method: "getContractDate",
- param: { positionId: item["position.id"] },
- async: false,
- success: function (data) {
- beginContractDate = data.beginContractDate;
- endContractDate = data.endContractDate;
- },
- error: function () { }
- });
- updateItem = {
- "number": item["person.number"],
- "adminOrgUnit": { id: item["adminOrg.id"], name: item["adminOrg.name"] },
- "position": { id: item["position.id"], name: item["position.name"] },
- "cmpEmpORelation": { id: item.id, name: item.id },
- "person": { id: item["person.id"], name: item["person.name"] },
- "submitElement": oldData.submitElement,
- "id": oldData.id,
- "tempId": oldData.tempId,
- "effectDate": oldData.effectDate,
- "currency": oldData.currency,
- "dealStatus": oldData.dealStatus,
- "superiorId": item["parentPerson.id"],
- "hourlyWage": item["empOrgRelation.hourlywage"],
- "beginContractDate": beginContractDate,
- "endContractDate": endContractDate,
- "superiorName": item["parentPerson.name"]
- }
- updateItem.beginContractDate = startDate
- updateItem.endContractDate = endDate
- var newData = _self.updateRow(updateItem, oldData);
- $entry.wafGrid("setRowData", rowid, newData);
- } else {
- oldData.beginContractDate = startDate
- oldData.endContractDate = endDate
- $entry.wafGrid("setRowData", rowid, oldData);
- }
- } else {
- var beginContractDate, endContractDate;
- _self.remoteCall({
- method: "getContractDate",
- param: { positionId: item["position.id"] },
- async: false,
- success: function (data) {
- beginContractDate = data.beginContractDate;
- endContractDate = data.endContractDate;
- },
- error: function () { }
- });
- var newData = _self.createNewEntryModel();
- newData.number = item["person.number"];
- newData.person = { id: item["person.id"], name: item["person.name"] };
- newData.adminOrgUnit = { id: item["adminOrg.id"], name: item["adminOrg.name"] };
- newData.position = { id: item["position.id"], name: item["position.name"] };
- newData.cmpEmpORelation = { id: item.id, name: item.id };
- newData.superiorId = item["parentPerson.id"];
- newData.hourlyWage = item["empOrgRelation.hourlywage"];
- newData.beginContractDate = beginContractDate;
- newData.endContractDate = endContractDate;
- newData.superiorName = item["parentPerson.name"];
- newData.beginContractDate = startDate
- newData.endContractDate = endDate
- newRowData.push(newData);
- }
- }
- if (newRowData.length) {
- $entry.jqGrid('addBlockData', 'id', newRowData);
- $("#entry").jqGrid('setGridHeight', 300);
- }
- setTimeout(function () {
- var frozenScrollTop = $(".frozen-bdiv").scrollTop();
- $("#entry").parents(".ui-jqgrid-bdiv").scrollTop(frozenScrollTop);
- })
- _self.countHourAmount();
- }
- })
- }
- }
- });
- $entry.delegate('input', 'focus', function () {
- _self.setCellLength();
- });
- },
- //计算分录的工时和总金额
- countHourAndMultiple: function (rowid) {
- //发生日期
- var effectTime = $("#entry").jqGrid("getCell", rowid, "effectDate");
- //开始时间
- var startTime = $("#entry").jqGrid("getCell", rowid, "startTime");
- //结束时间
- var endTime = $("#entry").jqGrid("getCell", rowid, "endTime");
- //休息开始时间
- var restStartTime = $("#entry").jqGrid("getCell", rowid, "restStartTime");
- //休息结束时间
- var restEndTime = $("#entry").jqGrid("getCell", rowid, "restEndTime");
- if (startTime != "" && endTime != "") {
- var startTimeOfDate = new Date(startTime);
- var endTimeOfDate = new Date(endTime);
- var times = 0;
- if (restStartTime != "" && restEndTime != "") {
- var restStartTimeOfDate = new Date(restStartTime);
- var restEndTimeOfDate = new Date(restEndTime);
- var times = restEndTimeOfDate.getTime() - restStartTimeOfDate.getTime();
- if (times < 0) {
- times = 0;
- }
- }
- var se = endTimeOfDate.getTime() - startTimeOfDate.getTime() - times;
- //工时
- var workHours = se / (3600 * 1000);
- workHours = workHours.toFixed(2);
- //时薪
- var hourlyWage = $("#entry").jqGrid("getCell", rowid, "hourlyWage");
- if (!hourlyWage) {
- hourlyWage = 0;
- }
- //倍数
- var multiple = 1;
- var note = null;
- //判断是否法定节假日和休息日
- if (effectTime) {
- let date = this.convertTimeZone(effectTime);
- let year = date.getFullYear(); // 获取年份(4位数)
- let month = date.getMonth() + 1; // 获取月份(0-11,需要加1)
- let day = date.getDate(); // 获取日期(1-31)
- // 格式化为年月日字符串
- let formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
- _self.remoteCall({
- type: "post",
- async: false,
- method: "workMultiple",
- param: { "otDate": formattedDate },
- success: function (res) {
- if (res.returnType) {
- if (res.returnType == "0") {
- //法定节假日
- multiple = 4;
- note = "Statuary Holiday,400%of basic salary";
- } else if (res.returnType == "1") {
- //休息日
- note = "Weekend";
- }
- }
- }
- });
- }
- var amount = workHours * hourlyWage * multiple;
- //工时
- $("#entry").jqGrid("setCell", rowid, "totalWorkHours", workHours);
- //总金额
- $("#entry").jqGrid("setCell", rowid, "totalAmount", amount.toFixed(2));
- //说明
- $("#entry").jqGrid("setCell", rowid, "explain", note);
- this.countHourAmount();
- }
- },
- convertTimeZone: function (date) {
- const inputDate = new Date(date);
- const beijingTime = new Date(inputDate.toLocaleString("en-US", { timeZone: "Asia/Shanghai" }));
- return beijingTime;
- },
- //计算单头的总工时和总金额
- countHourAmount: function () {
- var allRowData = $("#entry").jqGrid("getAllRowData");
- var totalWorkHours = 0;
- var totalAmount = 0;
- for (var i = 0; i < allRowData.length; i++) {
- var workHours = allRowData[i].totalWorkHours;
- var amount = allRowData[i].totalAmount;
- totalWorkHours = Number(totalWorkHours) + Number(workHours);
- totalAmount = Number(totalAmount) + Number(amount);
- }
- this.getField("totalWorkHours").shrNumberField("setValue", totalWorkHours);
- this.getField("totalAmount").shrNumberField("setValue", totalAmount);
- },
- verify: function () {
- //_self.setEntryAttr();
- var tds = $("#entry td[class*='dirty-cell']");
- for (var i = 0; i < tds.length; i++) {
- var cur = $(tds[i]);
- var value;
- if (cur.children().length > 0) {
- value = cur.children().attr('value');
- }
- var type = "NUMBER";
- if (!_self.checkNumValid(value, type)) {
- shr.showWarning({
- message: $.cmpIntegrateI18n.submitBill.label11 /* 请输入正确格式 */,
- hideAfter: 9
- });
- $(tds[i]).focus();
- $(tds[i]).css({
- "border": "solid 2px red"
- });
- return false;
- } else {
- $(tds[i]).css({
- "border": ""
- });
- }
- }
- //校验开始时间和结束时间不能有重叠
- var allRowData = $("#entry").jqGrid("getAllRowData");
- for (var i = 0; i < allRowData.length; i++) {
- var startTime = new Date(allRowData[i]["startTime"]);
- var endTime = new Date(allRowData[i]["endTime"]);
- for (var j = i + 1; j < allRowData.length; j++) {
- var nextStartTime = new Date(allRowData[j]["startTime"]);
- var nextEndTime = new Date(allRowData[j]["endTime"]);
- if (startTime < nextEndTime && nextStartTime < endTime) {
- shr.showWarning({ message: "Intersection between start and end times" });
- return false;
- }
- }
- }
- //校验分录只能有一种职位
- var positionSet = new Set();
- //校验分录只能是同一个直接上级
- var superiorSet = new Set();
- for (var i = 0; i < allRowData.length; i++) {
- if (allRowData[i].position) {
- positionSet.add(allRowData[i].position.id);
- } else {
- positionSet.add("");
- }
- if (allRowData[i].superiorId) {
- superiorSet.add(allRowData[i].superiorId);
- } else {
- superiorSet.add("");
- }
- }
- if (positionSet.size > 1) {
- shr.showWarning({ message: "Entries cannot have data from different positions" });
- return false;
- }
- if (superiorSet.size > 1) {
- shr.showWarning({ message: "The direct supervisor corresponding to the employee position in the entry must be consistent" });
- return false;
- }
- var calSchemeField = "submitScheme_el";
- if (_self.getOperateState() == 'VIEW') {
- calSchemeField = "submitScheme";
- }
- var calSchemeId = $("#" + calSchemeField).val();
- //是否勾选校验方案
- var isPlanCheck = true;
- _self.remoteCall({
- type: "post",
- async: false,
- method: "isTakeCheck",
- param: { calSchemeId: calSchemeId },
- success: function (res) {
- isPlanCheck = res.isPlanCheck;
- }
- });
- if (isPlanCheck) {
- for (var i = 0; i < allRowData.length; i++) {
- var beginContractDate = new Date(allRowData[i]["beginContractDate"]);
- var endContractDate = new Date(allRowData[i]["endContractDate"]);
- var effectDate = new Date(allRowData[i]["effectDate"]);
- if (beginContractDate && endContractDate) {
- //发生日期要在合同开始和结束日期之间
- if (effectDate < beginContractDate || effectDate > endContractDate) {
- shr.showWarning({ message: "The occurrence date should be between the start and end dates of the contract" });
- return false;
- }
- }
- }
- var flag = true;
- _self.remoteCall({
- type: "post",
- async: false,
- method: "getInductionDate",
- param: {},
- success: function (res) {
- if (res.enterDate) {
- var enterDate = new Date(res.enterDate);
- for (var i = 0; i < allRowData.length; i++) {
- var effectDate = new Date(allRowData[i]["effectDate"]);
- //发生日期不能小于入职日期
- if (effectDate < enterDate) {
- shr.showWarning({ message: "The occurrence date filled in by the employee cannot be earlier than the start date" });
- flag = false;
- }
- }
- }
- }
- });
- if (!flag) {
- return flag;
- }
- }
- return true;
- },
- /**
- * 删除行
- */
- deleteRowAction: function (event) {
- var $editGrid = this.getEditGrid(event.currentTarget);
- var submitSchemeId = '';
- var ctrlrole = $('#submitScheme').attr('ctrlrole');
- if (ctrlrole == 'promptBox') {
- submitSchemeId = $('#submitScheme').shrPromptBox('getValue').id;
- } else {
- submitSchemeId = $('#submitScheme').val();
- }
- var ids = $editGrid.jqGrid('getSelectedRows');
- if (!ids || ids.length === 0) {
- shr.showWarning({ message: $.cmpIntegrateI18n.common.selectRowMust /* 请先选择表格中的数据! */ });
- return;
- }
- var deleteRowIds = "";
- if (ids) {
- for (var i = ids.length - 1; i >= 0; i--) {
- deleteRowIds += ids[i] + ",";
- $editGrid.jqGrid('delRow', ids[i]);
- }
- //新增页面,清除缓存数据
- $("#entry")[0].p.data = [];
- this.clearDelEntryIdsFromDB(submitSchemeId, deleteRowIds);
- }
- var billId = $("#id").val();
- //删除分录时如果这条数据已在数据库中,则会直接删除数据库记录,所以要重新计算单头的总工时和总金额
- _self.remoteCall({
- type: "post",
- async: false,
- method: "countHourAmount",
- param: { "billId": billId },
- success: function (res) {
- }
- });
- this.countHourAmount();
- },
- submitAction: function (event) {
- var _self = this;
- if (_self.validate() && _self.verify()) {
- var allRowData = $("#entry").jqGrid("getAllRowData");
- // 获取当前日期
- let currentDate = new Date();
- // 获取本月的第一天
- let firstDayOfCurrentMonth = new Date(currentDate.getFullYear(), currentDate.getMonth(), 1);
- // 获取上个月的第一天
- let firstDayOfLastMonth = new Date(currentDate.getFullYear(), currentDate.getMonth() - 1, 1);
- if (currentDate.getMonth() === 0) {
- // 如果当前月份为1月,需要调整为上一年的12月
- firstDayOfLastMonth.setFullYear(currentDate.getFullYear() - 1);
- }
- var calSchemeField = "submitScheme_el";
- if (_self.getOperateState() == 'VIEW') {
- calSchemeField = "submitScheme";
- }
- var calSchemeId = $("#" + calSchemeField).val();
- var isPlanCheck = true;
- var isCurrentDepart = true;
- //获取是否勾选了 校验方案和离职方案
- _self.remoteCall({
- type: "post",
- async: false,
- method: "isTakeCheck",
- param: { calSchemeId: calSchemeId },
- success: function (res) {
- isPlanCheck = res.isPlanCheck;
- isCurrentDepart = res.isCurrentDepart;
- }
- });
- //勾选离职方案
- if (isCurrentDepart) {
- var isDepartMonth = true;
- var cmpOrgRelationId = "";
- for (var i = 0; i < allRowData.length; i++) {
- cmpOrgRelationId = allRowData[i].cmpEmpORelation.id;
- }
- //判断当月是否有离职生效日期或兼职失效日期在本月的数据
- _self.remoteCall({
- type: "post",
- async: false,
- method: "checkDepartDate",
- param: { cmpOrgRelationId: cmpOrgRelationId },
- success: function (res) {
- isDepartMonth = res.flag;
- }
- });
- //勾选离职方案后只能提交当月的数据
- if (isDepartMonth) {
- for (var i = 0; i < allRowData.length; i++) {
- var effectDate = new Date(allRowData[i]["effectDate"]);
- if (!(effectDate.getFullYear() == currentDate.getFullYear() && effectDate.getMonth() == currentDate.getMonth())) {
- shr.showWarning({ message: "Only allow submission of the occurrence date of the current month" });
- return false;
- }
- }
- } else {
- //当月没有离职或兼职失效数据时不允许提交
- shr.showWarning({ message: "The selected position does not have a resignation form that takes effect this month, or the expiration date of the part-time job is not within this month, so it cannot be submitted" });
- return false;
- }
- } else if (isPlanCheck) {
- //校验XX号之后不允许提交
- var submitDateMessage = '';
- _self.remoteCall({
- type: "post",
- async: false,
- method: "checkSumbitDate",
- param: {},
- success: function (res) {
- submitDateMessage = res.resultMessage;
- }
- });
- if (submitDateMessage) {
- shr.showWarning({ message: submitDateMessage });
- return false;
- }
- //勾选校验方案只能提交上月的数据
- for (var i = 0; i < allRowData.length; i++) {
- var effectDate = new Date(allRowData[i]["effectDate"]);
- if (!(effectDate >= firstDayOfLastMonth && effectDate < firstDayOfCurrentMonth)) {
- shr.showWarning({ message: "Only allow submission of work hours from the previous month" });
- return false;
- }
- }
- }
- _self.preVerify(function () {
- $.extend($.verifyRuleTool, _self.getVerifyOptions(submitNodeId))
- $.verifyRuleTool.afterVeriyCallBack = function () {
- shr.showConfirm($.shrI18n.common.tips.submitConfirm, function () {
- _self.doSubmit(event, 'submit');
- });
- };
- $.verifyRuleTool.verifyInto();
- $.verifyRuleTool.ip = "submitShemeBill"
- }, 'submit')
- }
- },
- initForm: function () {
- var _self = this;
- _self.assembleNewModelIdForAddNewOperate();
- _self.setInitData();
- _self.addCopyBtn();
- _self.ChangeSubmitScheme_event();
- _self.setSubmitSchemeState();
- _self.auditPageAdjust();
- shr.loadScript("/shr/addon/compensation/web/js/integrate/base/submitverify/cmpVerifyRuleTool.js")
- //编辑和查看状态下初始化表格
- if (_self.operateState == 'VIEW' || _self.operateState == 'EDIT') {
- _self.getEditGridColModel();
- _self.initF7TypeFieldArr();
- }
- if (_self.operateState == 'ADDNEW' || _self.operateState == 'EDIT') {
- _self.setSubmitSchemeF7Filter();
- _self.setDescriptionLength();
- }
- if (_self.operateState == 'ADDNEW' || _self.operateState == 'VIEW') {
- $("#availableBudget").hide();
- }
- if (_self.operateState == 'VIEW') {
- // 暂时先取消导出功能
- _self.addViewBtn();
- //排除员工自助提报的情景
- if ('1' != $("#datasource").val()) {
- _self.initJumpToPageButton();
- }
- }
- // 字段授权
- _self.checkNoPermFields();
- // 根据提报方案是否关联了预算额度模板,来决定费用承担组织、预算年度,费用类型是否展示
- _self.monitorBudget();
- },
- renderGridHeader: function (islocaldata) {
- var _self = this;
- var colModel = _self.colModel;
- var colNames = _self.colNames;
- var $entry = $('#entry');
- //如果表头没数据,默认展示序号
- if (!(colNames && colNames[0]) || !(colModel && colModel[0])) {
- colNames = ['id'];
- colModel = [{
- "name": "id",
- "label": "id",
- "frozen": false,
- "width": 150,
- "align": "left",
- "hidden": true,
- "key": true,
- "editable": false,
- "sorttype": "",
- "sortable": false,
- "classes": "disabled"
- }];
- }
- var ctrlrole = $entry.attr("ctrlrole");
- //表格已初始化,销毁
- if (ctrlrole) {
- $entry.jqGrid('gridUnload');
- }
- var columnModel = '';
- var hasFrozenColumn = false;
- //拼接columnModel字符串
- if (colModel && colModel[0]) {
- colModel.forEach(function (element, index) {
- if (element['frozen']) {
- hasFrozenColumn = true;
- }
- columnModel += element.name;
- if (index != colModel.length - 1) {
- columnModel += ',';
- }
- });
- }
- // var grid_readonly = _self.operateState == 'VIEW';
- var grid_readonly = _self.operateState === 'VIEW' || _self.operateState === 'EDIT' || _self.operateState === 'ADDNEW';
- var grid_celledit = _self.operateState === 'EDIT' || _self.operateState === 'ADDNEW';
- var url = _self.getGridDataRequestURL();
- var dataGrid_option = {
- url: url,
- datatype: islocaldata == '1' ? "local" : "json",
- colNames: colNames,
- jsonReader: {
- repeatitems: false
- },
- sorterItems: "",
- colModel: colModel,
- postData: $entry[0].p.postData,
- customPager: '#gridPager',
- hasPager: grid_readonly,
- cellEdit: grid_celledit,
- height: 'auto',
- rowList: [50, 100, 200, 500],
- autowidth: true,
- viewrecords: true,
- cellsubmit: "clientArray",
- multiselect: true,
- _type_: "EditGrid",
- shrinkToFit: false,
- mtype: "get",
- recordtext: '({0}-{1})/{2}',
- gridview: true,
- pginput: true,
- rownumbers: true,
- footerrow: true,
- userDataOnFooter: true,
- clientFooter: false,
- serverFooter: false,
- sumColModel: [],
- pagerpos: 'center',
- recordpos: 'left',
- pginputpos: 'right',
- keyOptions: {
- addNewRowForLastCell: false,
- loop: true
- }
- };
- //查看模式分页查询,编辑默认查全部
- if (grid_readonly) {
- dataGrid_option.rowNum = 50;
- } else {
- dataGrid_option.rowNum = 100000;
- }
- dataGrid_option.loadComplete = function (ret) {
- $("#entry")[0].__isDirty = false;
- if (grid_readonly) {
- //初始化分页
- if (!$("#gridPager")[0]) {
- var pagerDiv = '<div id="gridPager"></div>';
- if ($('.editGrid-toolbar')[0]) {
- $('.editGrid-toolbar').after(pagerDiv);
- } else {
- $('#entry_cont').prepend(pagerDiv);
- }
- $("#entry").setCustomPager("#gridPager");
- }
- var datas = $("#entry").jqGrid("getRowData");
- if (datas && datas.length > 8) { //表格数据超过一定数量,限制高度
- $("#entry").jqGrid('setGridHeight', 300);
- }
- shr.setIframeHeight();
- }
- };
- dataGrid_option.onPaging = function () {
- }
- dataGrid_option.beforeReloadGrid = function () {
- if (!grid_readonly) {
- waf("#entry").find('tr.selected-row').click();
- var data = waf("#entry").jqGrid('getGridParam', 'data');
- data.length = 0;
- waf("#entry").jqGrid('setGridParam', { data: $("#entry").jqGrid('getAllPageData'), datatype: 'local' });
- }
- shr.setIframeHeight();
- }
- //选择表格前设置姓名过滤条件
- dataGrid_option.beforeSelectRow = function () {
- _self.setNameF7Filter();
- }
- //审批时有滚动条时,把右侧DIV右移了一些挡住了列表的滚动条,现在先给列表的父标签一个右内边距,这样就不会被挡道。
- $('#entry_cont').css('padding-right', '20px')
- waf("#entry").jqGrid(dataGrid_option).jqGrid("setFrozenColumns");
- waf("#entry").jqGrid("resizeGrid", {
- base: waf("#entry"),
- offset: 0
- });
- waf(window).resize(function () {
- waf.ieHack.hackResize(function (e) {
- waf("#entry").jqGrid("resizeGrid", {
- base: waf("#entry"),
- offset: 0
- });
- }, waf("#entry"));
- });
- $entry.jqGrid(dataGrid_option).trigger('reloadGrid');
- //查看状态初始化分页
- if (grid_readonly) {
- _self.initPage();
- }
- if (_self.operateState == 'ADDNEW' || _self.operateState == 'EDIT') {
- _self.setGridNameEvent();
- }
- if (!$("#entry_searchBar").length) {
- _self.initCmpEntrySearchBar();
- }
- },
- /**
- * 分录增加复制按钮
- */
- addCopyBtn: function () {
- var _self = this;
- var str = [];
- str.push('<button id="copyRow" type="button" onclick="jsBinder.copyRowAction" name="copyRow" class="shrbtn">');
- str.push('Copy');
- str.push('</button>');
- str.push('<script>');
- str.push('$(function() {');
- str.push(' $("#copyRow").shrButton({');
- str.push(' actionBinding: "copyRowAction",');
- str.push(' subAction: "",');
- str.push(' customData: "",');
- str.push(' permItemId:""');
- str.push(' });');
- str.push('});');
- str.push('</script>');
- $("#deleteRow_entry").after(str.join(""));
- },
- copyRowAction: function (event) {
- var $editGrid = this.getEditGrid(event.currentTarget);
- var ids = $editGrid.jqGrid('getSelectedRows');
- if (!ids || ids.length === 0) {
- shr.showWarning({ message: $.cmpIntegrateI18n.common.selectRowMust /* 请先选择表格中的数据! */ });
- return;
- }
- for (var i = 0; i < ids.length; i++) {
- var getRowRealData = $("#entry").jqGrid("getRowRealData", ids[i]);
- getRowRealData.id = '';
- $("#entry").jqGrid("addRow", { data: getRowRealData });
- }
- }
- });
|