|
@@ -274,9 +274,11 @@ var pageOprObj = {
|
|
|
},
|
|
|
onCellEditEnd: function(sender, args) {
|
|
|
var me = repositoryGljObj, rObj = sheetCommonObj.combineRowData(me.workBook.getSheet(0), me.setting, args.row, me),
|
|
|
- updateArr = [], addArr = [];
|
|
|
+ updateArr = [], addArr = [], updateBasePrcArr = [];
|
|
|
me.editingRowIdx = args.row;
|
|
|
rObj.basePrice = rObj.basePrice ? rObj.basePrice : 0;
|
|
|
+ console.log(`rObj`);
|
|
|
+ console.log(rObj);
|
|
|
if (me.currentEditingGlj["ID"]) {
|
|
|
rObj["ID"] = me.currentEditingGlj["ID"];
|
|
|
rObj.gljClass = me.currentEditingGlj.gljClass;
|
|
@@ -301,13 +303,15 @@ var pageOprObj = {
|
|
|
}
|
|
|
let gljBasePrcObj = {gljId: me.currentEditingGlj.ID, gljType: gljType, basePrice: rObj.basePrice};
|
|
|
if(gljBasePrcObj.gljType !== -1){
|
|
|
- me.updateRationBasePrcRq(gljBasePrcObj);
|
|
|
+ updateBasePrcArr.push(gljBasePrcObj);
|
|
|
+ me.updateRationBasePrcRq(updateBasePrcArr);
|
|
|
}
|
|
|
}
|
|
|
//update basePrice of ration when editting gljType of glj
|
|
|
if(me.currentEditingGlj.gljType !== rObj.gljType){
|
|
|
let gljTypeObj = {gljId: me.currentEditingGlj.ID, gljType: rObj.gljType, basePrice: rObj.basePrice};
|
|
|
- me.updateRationBasePrcRq(gljTypeObj);
|
|
|
+ updateBasePrcArr.push(gljTypeObj);
|
|
|
+ me.updateRationBasePrcRq(updateBasePrcArr);
|
|
|
}
|
|
|
} else {
|
|
|
me.addGljObj = rObj;
|
|
@@ -325,6 +329,8 @@ var pageOprObj = {
|
|
|
}
|
|
|
if(updateArr.length >0 || addArr.length >0){
|
|
|
me.currentEditingGlj = null;
|
|
|
+ //me.workBook.getSheet(0).setValue(11, 5, "人工");
|
|
|
+ console.log(addArr);
|
|
|
me.mixUpdateRequest(updateArr, addArr, []);
|
|
|
}
|
|
|
},
|
|
@@ -447,41 +453,220 @@ var pageOprObj = {
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
- onClipboardPasting: function(sender, args) {
|
|
|
- var me = repositoryGljObj;
|
|
|
- if (args.cellRange.colCount != me.setting.header.length || me.gljCurTypeId < 0 || me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]) {
|
|
|
- args.cancel = true;
|
|
|
- }
|
|
|
- },
|
|
|
+ validUpdateObj: function (pasteObj, rowIdx) {
|
|
|
+ let rst = {}, backUpObj = {},
|
|
|
+ me = repositoryGljObj,
|
|
|
+ tempObj = me.currentCache[rowIdx],
|
|
|
+ reCalBasePrc = false, isValid = true;
|
|
|
+ //备份原始数据
|
|
|
+ for(let atr in tempObj){
|
|
|
+ backUpObj[atr] = tempObj[atr];
|
|
|
+ }
|
|
|
+ if(typeof pasteObj.code !== 'undefined'){
|
|
|
+ if(pasteObj.code.trim().length !== 0){
|
|
|
+ let isExist = false;
|
|
|
+ for(let i = 0; i < me.gljList.length; i++){
|
|
|
+ if(me.gljList[i].code === pasteObj.code){
|
|
|
+ isExist = true;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(!isExist){
|
|
|
+ tempObj.code = pasteObj.code;
|
|
|
+ }
|
|
|
+ else isValid = false;
|
|
|
+ }
|
|
|
+ else isValid = false;
|
|
|
+ }
|
|
|
+ if(typeof pasteObj.name !== 'undefined'){
|
|
|
+ if(pasteObj.name.trim().length === 0) isValid = false;
|
|
|
+ else tempObj.name = pasteObj.name;
|
|
|
+ }
|
|
|
+ if(typeof pasteObj.specs !== 'undefined'){
|
|
|
+ tempObj.specs = pasteObj.specs;
|
|
|
+ }
|
|
|
+ if(typeof pasteObj.unit !== 'undefined'){
|
|
|
+ tempObj.unit = pasteObj.unit;
|
|
|
+ }
|
|
|
+ if(typeof pasteObj.gljType !== 'undefined'){
|
|
|
+ let isExsit = false;
|
|
|
+ for(let i = 0; i < me.distTypeTree.comboDatas.length; i++){
|
|
|
+ if(pasteObj.gljType === me.distTypeTree.comboDatas[i].text){
|
|
|
+ isExsit = true;
|
|
|
+ reCalBasePrc = true;
|
|
|
+ tempObj.gljType = me.distTypeTree.comboDatas[i].value;
|
|
|
+ tempObj.shortName = me.distTypeTree.distTypes[me.distTypeTree.prefix + tempObj.gljType].data.shortName;
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(!isExsit) isValid = false;
|
|
|
+ }
|
|
|
+ //
|
|
|
+ pasteObj.basePrice = !isNaN(parseFloat(pasteObj.basePrice)) && (pasteObj.basePrice && typeof pasteObj.basePrice !== 'undefined') ? parseFloat(pasteObj.basePrice) :
|
|
|
+ me.currentCache[rowIdx].basePrice;
|
|
|
+ if(pasteObj.basePrice !== me.currentCache[rowIdx].basePrice){
|
|
|
+ reCalBasePrc = true;
|
|
|
+ tempObj.basePrice = pasteObj.basePrice;
|
|
|
+ }
|
|
|
+ if(isValid){
|
|
|
+ rst.updateGlj = tempObj;
|
|
|
+ if(reCalBasePrc){
|
|
|
+ //重新计算定额基价对象
|
|
|
+ rst.updateBasePrc = {gljId: tempObj.ID, gljType: tempObj.gljType, basePrice: tempObj.basePrice};
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ for(let attr in backUpObj){
|
|
|
+ tempObj[attr] = backUpObj[attr];
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return rst;
|
|
|
+ },
|
|
|
+ //粘贴的数据是否是可添加的数据,只有含有编号,名称,类型才可添加
|
|
|
+ isValidObj: function(pasteObj) {
|
|
|
+ let me = repositoryGljObj;
|
|
|
+ if(!(pasteObj.code && typeof pasteObj.code !== 'undefined') || !(pasteObj.name && typeof pasteObj.name !== 'undefined') ||
|
|
|
+ !(pasteObj.gljType && typeof pasteObj.gljType !== 'undefined')){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ if(pasteObj.gljType && typeof pasteObj.gljType !== 'undefined'){
|
|
|
+ let isExist = false;
|
|
|
+ for(let i = 0; i < me.distTypeTree.comboDatas.length; i++){
|
|
|
+ if(me.distTypeTree.comboDatas[i].text === pasteObj.gljType){
|
|
|
+ isExist = true;
|
|
|
+ pasteObj.gljType = me.distTypeTree.comboDatas[i].value;
|
|
|
+ pasteObj.shortName = me.distTypeTree.distTypes[me.distTypeTree.prefix + pasteObj.gljType].data.shortName;
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(!isExist){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(pasteObj.code && typeof pasteObj.code !== 'undefined'){
|
|
|
+ for(let i = 0; i < me.gljList.length; i++){
|
|
|
+ if(me.gljList[i].code === pasteObj.code){
|
|
|
+ return false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ pasteObj.basePrice = !isNaN(parseFloat(pasteObj.basePrice)) && (pasteObj.basePrice && typeof pasteObj.basePrice !== 'undefined') ? parseFloat(pasteObj.basePrice) : 0;
|
|
|
+ pasteObj.gljClass = me.gljCurTypeId;
|
|
|
+ return true;
|
|
|
+ },
|
|
|
+ onClipboardPasting: function(sender, args) {
|
|
|
+ var me = repositoryGljObj;
|
|
|
+ /*if (args.cellRange.colCount != me.setting.header.length || me.gljCurTypeId < 0 || me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]) {
|
|
|
+ args.cancel = true;
|
|
|
+ }*/
|
|
|
+ if (me.gljCurTypeId < 0 ) {
|
|
|
+ args.cancel = true;
|
|
|
+ }
|
|
|
+ },
|
|
|
onClipboardPasted: function(e, info) {
|
|
|
var me = repositoryGljObj;
|
|
|
var updateArr = [], addArr = [];
|
|
|
var items = sheetCommonObj.analyzePasteData(me.setting, info);
|
|
|
- var hasCacheItem = false;
|
|
|
- for (var i = 0; i < items.length; i++) {
|
|
|
- for (var j = 0; j < me.gljList.length; j++) {
|
|
|
- if (me.gljList[j][me.setting.header[0].dataCode] == items[i][me.setting.header[0].dataCode]) {
|
|
|
- hasCacheItem = true;
|
|
|
- items[i]["ID"] = me.gljList[j]["ID"];
|
|
|
- break;
|
|
|
+ let beginRow = info.cellRange.row, endRow = info.cellRange.row + info.cellRange.rowCount - 1,
|
|
|
+ maxRow = me.currentCache.length - 1, updateItems = [], addItems = [], updateBasePrcArr = [] , updateCount, resumeArr = [];
|
|
|
+ if(endRow <= maxRow){
|
|
|
+ //updateItems = items;
|
|
|
+ for(let i = 0; i < items.length; i++){
|
|
|
+ let updateObj = me.validUpdateObj(items[i], info.cellRange.row + i);
|
|
|
+ if(updateObj && typeof updateObj.updateGlj !== 'undefined'){
|
|
|
+ updateArr.push(updateObj.updateGlj);
|
|
|
+ if(typeof updateObj.updateBasePrc !== 'undefined'){
|
|
|
+ updateBasePrcArr.push(updateObj.updateBasePrc);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else if(beginRow <= maxRow && endRow > maxRow){
|
|
|
+ updateCount = maxRow - beginRow + 1;
|
|
|
+ for(let i = 0; i < updateCount; i++){
|
|
|
+ let updateObj = me.validUpdateObj(items[i], info.cellRange.row + i);
|
|
|
+ if(updateObj && typeof updateObj.updateGlj !== 'undefined'){
|
|
|
+ updateArr.push(updateObj.updateGlj);
|
|
|
+ if(typeof updateObj.updateBasePrc !== 'undefined'){
|
|
|
+ updateBasePrcArr.push(updateObj.updateBasePrc);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if(info.cellRange.colCount === me.setting.header.length){
|
|
|
+ for(let i = updateCount ; i < items.length; i++){
|
|
|
+ if(me.isValidObj(items[i])){
|
|
|
+ addItems.push(items[i]);
|
|
|
+ addArr.push(items[i]);
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ for(let i = updateCount ; i < items.length; i++){
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ if(info.cellRange.colCount === me.setting.header.length){
|
|
|
+ for(let i = 0; i < items.length; i++){
|
|
|
+ if(me.isValidObj(items[i])){
|
|
|
+ addArr.push(items[i]);
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
- if (!hasCacheItem) {
|
|
|
- items[i].gljType = me.gljCurTypeId;
|
|
|
- addArr.push(items[i]);
|
|
|
- } else {
|
|
|
- updateArr.push(items[i]);
|
|
|
+ else{
|
|
|
+ for(let i = 0; i < items.length; i++){
|
|
|
+ resumeArr.push(info.cellRange.row + i);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ //repaint
|
|
|
+ if(resumeArr.length > 0){
|
|
|
+ info.sheet.suspendPaint();
|
|
|
+ for(let i = 0; i < resumeArr.length ; i++){
|
|
|
+ if(resumeArr[i] < me.currentCache.length){
|
|
|
+ for(let col = 0; col < me.setting.header.length; col++){
|
|
|
+ if(me.setting.header[col].dataCode === 'gljType'){
|
|
|
+ let gljType = me.currentCache[resumeArr[i]][me.setting.header[col].dataCode];
|
|
|
+ info.sheet.setValue(resumeArr[i], col, me.distTypeTree.distTypes["gljType" + gljType].data.fullName);
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ info.sheet.setValue(resumeArr[i], col, me.currentCache[resumeArr[i]][me.setting.header[col].dataCode]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ for(let col = 0; col < me.setting.header.length; col++){
|
|
|
+ info.sheet.setValue(resumeArr[i], col, '');
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
+ info.sheet.resumePaint();
|
|
|
}
|
|
|
if (updateArr.length > 0 || addArr.length > 0) {
|
|
|
- me.mixUpdateRequest(updateArr, addArr, []);
|
|
|
+ me.mixUpdateRequest(updateArr, addArr, []);
|
|
|
+ }
|
|
|
+ if(updateBasePrcArr.length > 0){
|
|
|
+ me.updateRationBasePrcRq(updateBasePrcArr);
|
|
|
}
|
|
|
},
|
|
|
- updateRationBasePrcRq: function (gljObj) {
|
|
|
+ updateRationBasePrcRq: function (basePrcArr) {
|
|
|
$.ajax({
|
|
|
type: 'post',
|
|
|
url: 'api/updateRationBasePrc',
|
|
|
- data:{data: JSON.stringify({repId: pageOprObj.rationLibId, lastOpr: userAccount, gljId: gljObj.gljId, basePrice: gljObj.basePrice, gljType: gljObj.gljType})},
|
|
|
+ data:{data: JSON.stringify({repId: pageOprObj.rationLibId, lastOpr: userAccount, basePrcArr: basePrcArr})},
|
|
|
dataType: 'json',
|
|
|
success: function (result) {
|
|
|
if(result.error){
|
|
@@ -518,10 +703,14 @@ var pageOprObj = {
|
|
|
alert(result.message);
|
|
|
me.getRationItems(me.currentRepositoryId);
|
|
|
} else {
|
|
|
- console.log(`enterSc`);
|
|
|
me.updateCache(addArr, updateArr, removeIds, result);
|
|
|
me.sortGlj();
|
|
|
- me.currentCache = me.getCache();
|
|
|
+ if(me.currentOprParent === 1){
|
|
|
+ me.currentCache = me.getParentCache(me.parentNodeIds["_pNodeId_" + me.gljCurTypeId]);
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ me.currentCache = me.getCache();
|
|
|
+ }
|
|
|
me.showGljItems(me.gljList, me.gljCurTypeId);
|
|
|
}
|
|
|
},
|
|
@@ -530,6 +719,21 @@ var pageOprObj = {
|
|
|
}
|
|
|
})
|
|
|
},
|
|
|
+ getParentCache: function (nodes) {
|
|
|
+ let me = repositoryGljObj, rst = [];
|
|
|
+ for(let i = 0; i < me.gljList.length; i++){
|
|
|
+ if(nodes.indexOf(me.gljList[i].gljClass) !== -1){
|
|
|
+ rst.push(me.gljList[i]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ rst.sort(function (a, b) {
|
|
|
+ let rst = 0;
|
|
|
+ if(a.code > b.code) rst = 1;
|
|
|
+ else if(a.code < b.code)rst = -1;
|
|
|
+ return rst;
|
|
|
+ });
|
|
|
+ return rst;
|
|
|
+ },
|
|
|
getCache: function() {
|
|
|
var me = this, rst = [];
|
|
|
for (var i = 0; i < me.gljList.length; i++) {
|
|
@@ -591,13 +795,16 @@ var gljTypeTreeOprObj = {
|
|
|
var me = repositoryGljObj,
|
|
|
gljTypeId = treeNode.ID;
|
|
|
me.gljCurTypeId = treeNode.ID;
|
|
|
- me.currentCache = me.getCache();
|
|
|
+ //me.currentCache = me.getCache();
|
|
|
me.showGljItems(me.gljList, gljTypeId);
|
|
|
- console.log(me.gljCurTypeId);
|
|
|
if (me.parentNodeIds["_pNodeId_" + treeNode.ID]) {
|
|
|
+ me.currentOprParent = 1;
|
|
|
+ me.currentCache = me.getParentCache(me.parentNodeIds["_pNodeId_" + treeNode.ID]);
|
|
|
sheetCommonObj.lockCodeCells(me.workBook.getSheet(0), me.gljList.length);
|
|
|
//sheetCommonObj.shieldAllCells(me.workBook.getSheet(0), me.setting);
|
|
|
} else {
|
|
|
+ me.currentOprParent = 0;
|
|
|
+ me.currentCache = me.getCache();
|
|
|
sheetCommonObj.unShieldAllCells(me.workBook.getSheet(0));
|
|
|
}
|
|
|
},
|