material_controller.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. /**
  2. * Created by zhang on 2018/9/12.
  3. */
  4. let MaterialController = {
  5. subSpreadDivWidth:"",
  6. showItemText:false,
  7. //规则相关映射
  8. rule1: function (node) {
  9. let itemText = node.data.itemCharacterText;
  10. let name = this.getKeyString(itemText,"材质及规格:");
  11. if(name){
  12. return{name:name,specs:""}//规格型号变成空的
  13. }
  14. return null;
  15. },
  16. rule2:function (node) {
  17. let itemText = node.data.itemCharacterText;
  18. let name = this.getKeyString(itemText,"混凝土种类:");
  19. let specs = this.getKeyString(itemText,"混凝土强度等级:");
  20. if(name||specs){
  21. let doc ={};
  22. if(name) doc["name"] = name;
  23. if(specs) doc["specs"] = specs;
  24. return doc;
  25. }
  26. return null
  27. },
  28. replaceMaterial:function(nodes){
  29. let me = this;
  30. this.getMaterial(nodes,function (result) {
  31. if(!_.isEmpty(result)){
  32. me.startReplace(nodes,result);
  33. }
  34. });
  35. },
  36. startReplace:function (nodes,result) {//其实应该是批量修改工料机属性,与替换工料机不同
  37. let me = this,updateData = [];
  38. for(let n of nodes){
  39. let code = n.data.code;
  40. if(code.length >= 9){
  41. let r_list = this.eachNode(n,result[code.substr(0,9)]);
  42. if(r_list.length > 0) updateData.push(...r_list);
  43. }
  44. }
  45. me.postReplace(updateData);
  46. },
  47. postReplace:function (updateData) {
  48. let me = this;
  49. if(updateData.length == 0) return;
  50. $.bootstrapLoading.start();
  51. CommonAjax.post("/material/replace",updateData,function(result){
  52. $.bootstrapLoading.end();
  53. me.updateCacheAfterReplace(result)
  54. })
  55. },
  56. updateCacheAfterReplace:function (result){
  57. let nodes = [];
  58. for(let data of result){
  59. let node = projectObj.project.ration_glj.refreshRationNode(data.name,data.adjustState,data.rationID);//刷新定额名称和子目调整状态
  60. if(node) nodes.push(node);
  61. if(data.ration_gljs.length > 0) this.refreshRationGLJ(data.ration_gljs);
  62. }
  63. if(nodes.length >0){
  64. projectObj.project.projectGLJ.loadData(function () {
  65. projectObj.project.calcProgram.calcNodesAndSave(nodes,function(){
  66. installationFeeObj.calcInstallationFee();
  67. });
  68. gljOprObj.refreshView();
  69. })
  70. }
  71. },
  72. refreshRationGLJ:function(ration_gljs){
  73. let ration_glj_model = projectObj.project.ration_glj;
  74. for(let rg of ration_gljs){
  75. let glj = ration_glj_model.refreshByID(rg.ID,rg.doc);
  76. ration_glj_model.refreshTreeNodeIfNeeded(glj);//刷新造价书上的树节点(如果需要)
  77. }
  78. },
  79. eachNode:function (node,item) {
  80. let replaceDatas =[];
  81. if(item && item.bills.rule){
  82. let replace_property = this["rule"+item.bills.rule](node);//按清单设置的规则获取要修改的属性
  83. if(replace_property){
  84. replaceDatas = this.getReplaceData(node.data.ID,item.materialMap,replace_property);
  85. }
  86. }
  87. return replaceDatas;
  88. },
  89. getReplaceData:function (billsItemID,materialMap,replace_property) {
  90. let list = [];
  91. let replace_glj_list = this.findMatchRationGLJ(billsItemID,materialMap);//取出需要替换的工料机和对替换的材料内容
  92. for(let r of replace_glj_list){
  93. let doc = this.getDoc(r.glj,r.material,replace_property);//获取要修改的字段
  94. list.push({glj:gljOprObj.setGLJPrice(r.glj),doc:doc});
  95. }
  96. return list;
  97. },
  98. getDoc:function (glj,material,replace_property) {//取定额工料机中需要修改的内容
  99. let doc = {},keyList = ['name','specs','type','unit'];
  100. for(let key of keyList){
  101. if(glj[key] != material[key]) doc[key] = material[key];
  102. }
  103. for(let rkey in replace_property){
  104. doc[rkey] = replace_property[rkey]
  105. }
  106. return doc;
  107. },
  108. findMatchRationGLJ:function (billsItemID,materialMap) {//查找清单下匹配的需要替换的定额工料机
  109. let replaceList=[];
  110. for(let g of projectObj.project.ration_glj.datas){
  111. if(g.billsItemID == billsItemID && materialMap[g.original_code]) {
  112. replaceList.push({glj:g,material:materialMap[g.original_code]});
  113. }
  114. }
  115. return replaceList;
  116. },
  117. getMaterial:function (nodes,callback) {
  118. let data = [],materialMap= null;
  119. for(let n of nodes){
  120. let code = n.data.code;
  121. if(code.length >= 9 && n.data.billsLibId){
  122. let billCode = code.substr(0,9);
  123. data.push({code:billCode,billsLibId:n.data.billsLibId});
  124. }
  125. }
  126. if(data.length>0){
  127. //data 按编码去重
  128. let dataMap = _.indexBy(data,'code');
  129. CommonAjax.post("/material/getMaterial",dataMap,function (result) {
  130. callback(result);
  131. })
  132. }else {
  133. callback(null);
  134. }
  135. },
  136. getKeyString:function (itemText,matchStr) {//截取关键数据
  137. itemText = itemText.replace(/:/g, ":");//中文字符转换为英文字符
  138. itemText = itemText.replace(matchStr,"@$@");//用特殊符号取代关键字,方便截取
  139. let index = itemText.indexOf("@$@");
  140. if(index == -1) return null;
  141. let temString = itemText.substr(index+3);
  142. let strArray = temString.split(/\n/);
  143. let keyString = this.trim(strArray[0]);
  144. return keyString===""?null:keyString;
  145. },
  146. trim:function (str) {
  147. return str.replace(/(^\s*)|(\s*$)/g, "");
  148. },
  149. //--------------2018-10-08新加替换表格-----------------
  150. setting:{
  151. header:[
  152. {headerName: "项目特征", headerWidth: 120, dataCode: "character", dataType: "String"},
  153. {headerName: "内容", headerWidth: 240, dataCode: "context", dataType: "String"},
  154. {headerName: "名称", headerWidth: 50, dataCode: "name", dataType: "String",hAlign: "center",cellType:"replaceButton"},
  155. {headerName: "规格", headerWidth: 50, dataCode: "specs", dataType: "String",hAlign: "center",cellType:"replaceButton"},
  156. ],
  157. view: {
  158. lockColumns: [0,1,2,3],
  159. rowHeaderWidth:25
  160. }
  161. },
  162. spread:null,
  163. sheet:null,
  164. datas:[],
  165. showReplaceDiv:function (node) {
  166. if(!($('#linkGLJ').hasClass('active'))){
  167. return;
  168. }
  169. $("#subSpread").addClass("ration_glj_spread");
  170. $("#replaceM").show();
  171. $("#rgResize").show();// 拖动调整大小功能添加
  172. // 2018-11-07 需求变更,这个项目特征替换表格暂时隐藏不删除,以后可能还要用,先把项目初始化这句注释掉
  173. // if(node) this.showReplaceSpread(node);//如果不是只刷新页面
  174. this.showItemCharacterText(node);//只显示文本
  175. refreshSubSpread();
  176. },
  177. hideReplaceDiv:function(){
  178. $("#subSpread").removeClass("ration_glj_spread");
  179. $("#subSpread").css("width",""); //左右拖动调整表格大小的时候会设置css属性,所以隐藏这个div的时候也要把这个属性给去掉
  180. $("#replaceM").hide();
  181. refreshSubSpread();
  182. },
  183. showReplaceSpread:function(node){
  184. $("#replaceM").addClass("ovf-hidden");
  185. this.initSpread();
  186. this.showData(node);
  187. },
  188. initSpread:function () {
  189. if(!this.spread){
  190. this.spread = SheetDataHelper.createNewSpread($("#replaceM")[0]);
  191. sheetCommonObj.spreadDefaultStyle(this.spread);
  192. this.initSheet();
  193. }else {
  194. this.spread.refresh();
  195. }
  196. },
  197. initSheet:function(){
  198. this.sheet = this.spread .getSheet(0);
  199. sheetCommonObj.initSheet( this.sheet, this.setting);
  200. this.spread.bind(GC.Spread.Sheets.Events.ButtonClicked, this.onReplaceButtonClick);
  201. this.sheet.name('materialReplace');
  202. },
  203. showData:function(node){
  204. this.datas = [];
  205. let selected = node?node:projectObj.project.mainTree.selected;
  206. let parent = selected.parent;
  207. if(selected&&parent){
  208. this.getItems(parent.data.itemCharacterText);
  209. }
  210. sheetCommonObj.showData(this.sheet, this.setting,this.datas);
  211. this.sheet.setRowCount(this.datas.length);
  212. },
  213. showItemCharacterText:function (node) {
  214. let text="";
  215. let selected = node?node:projectObj.project.mainTree.selected;
  216. let parent = selected.parent;
  217. if(selected&&parent){
  218. text = parent.data.itemCharacterText?parent.data.itemCharacterText.replace(/\n/g,"<br>"):"";
  219. }
  220. if(text == "") {//为空的时候不显示
  221. $("#replaceM").hide();
  222. $("#subSpread").removeClass("ration_glj_spread");
  223. $('#subSpread').css('width','');
  224. return;
  225. }
  226. $('#replaceM').css('margin-top',0);
  227. this.toggleItemInit();
  228. $("#replaceText").html(text);
  229. },
  230. toggleItemInit:function () {
  231. if(this.showItemText == true){
  232. $("#replaceM").removeClass("ovf-hidden");
  233. $("#openItemText").hide();
  234. $("#replaceText").show();
  235. $("#closeItemText").show();
  236. $("#rgResize").show();
  237. let swidth = this.subSpreadDivWidth == ""? $("#bottom_div").width()*0.83:this.subSpreadDivWidth;
  238. swidth = parseFloat(swidth);
  239. $('#subSpread').css('width',swidth);
  240. $('#replaceM').css('width',$("#bottom_div").width()-$("#rgResize").width()-swidth);
  241. }else {
  242. $("#replaceM").addClass("ovf-hidden");
  243. $("#openItemText").show();
  244. $("#replaceText").hide();
  245. $("#closeItemText").hide();
  246. $("#rgResize").hide();
  247. $('#replaceM').css('width',30);
  248. $('#subSpread').css('width',$("#bottom_div").width()-30);
  249. }
  250. },
  251. getItems:function(characterText){
  252. if(!characterText) return;
  253. let strArray = characterText.split(/\n/);
  254. for(let tem of strArray){
  255. tem = tem.replace(/:/g, ":");//中文字符转换为英文字符
  256. if(tem.indexOf(":") != -1){//有:号才提取
  257. let proArr = tem.split(":");
  258. //如果内容为空的话也不提取
  259. let context = this.trim(proArr[1]);
  260. if(context!="") this.datas.push({character:proArr[0],context:context,name:"换",specs:"换"})
  261. }
  262. }
  263. },
  264. onReplaceButtonClick:function(e, args){
  265. //项目只读
  266. if(projectReadOnly) {
  267. return;
  268. }
  269. let me = MaterialController;
  270. let sheet = args.sheet, row = args.row, col = args.col;
  271. let dataCode = me.setting.header[col].dataCode, item = me.datas[row], doc = {};
  272. if(dataCode && item){
  273. doc[dataCode] = item.context;
  274. me.replaceByClick(doc);
  275. }
  276. },
  277. replaceByClick:function (tem) {
  278. let ration_glj = gljOprObj.getSelectedRationGlj();
  279. let doc = {};
  280. if(ration_glj && !ration_glj.isMixRatio){//有选中并且不是组成物
  281. if(gljOprObj.isExtraType(ration_glj.type)) return; //如果是“企业管理费”“利润”“一般风险费”类型,不能替换
  282. for(let key in tem){//检查属性是否做了改变,如果没有改变不用提交替换
  283. if(ration_glj[key] != tem[key]) doc[key] = tem[key]
  284. }
  285. if(!_.isEmpty(doc)) this.postReplace([{glj:ration_glj,doc:doc}]);
  286. }
  287. }
  288. };
  289. let rg_sideResizeEles = {};
  290. rg_sideResizeEles.id = 'tabRG';
  291. rg_sideResizeEles.resize = $('#rgResize');
  292. rg_sideResizeEles.nearElement = $('#subSpread');
  293. rg_sideResizeEles.farElement = $('#replaceM');
  294. rg_sideResizeEles.nav = null;
  295. slideResize(rg_sideResizeEles, {min: 100, max: $('#tabCon').width()-100}, 'width', function(){
  296. MaterialController.subSpreadDivWidth = $('#subSpread').css('width');
  297. refreshSubSpread();
  298. });
  299. $(function (){
  300. $("#openItemText").click(function () {
  301. MaterialController.showItemText = true;
  302. MaterialController.toggleItemInit();
  303. refreshSubSpread();
  304. });
  305. $("#closeItemText").click(function () {
  306. MaterialController.showItemText = false;
  307. MaterialController.toggleItemInit();
  308. refreshSubSpread();
  309. });
  310. })