composition.js 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /**
  2. * 配合比相关
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/7/10
  6. * @version
  7. */
  8. let compositionSpread = null;
  9. let mixRatioSheet = null;
  10. let machineSheet = null;
  11. let mixRatioRightClickTarget = null;
  12. let isDeleting = false;
  13. $(document).ready(function() {
  14. compositionSpread = new CompositionSpread();
  15. compositionSpread.successCallback = mixRatioSuccess;
  16. // 切换tab触发refresh
  17. $('a[data-toggle="tab"]').on('shown.bs.tab', function (e) {
  18. currentTag = $(e.target).data('name');
  19. // 获取工料机当前选中的行号
  20. let projectGLJId = 0;
  21. if (currentTag === "mix-ratio") {
  22. mixRatioSheet = mixRatioSheet === null ? compositionSpread.init(currentTag) : mixRatioSheet;
  23. compositionSpread.initRightClick();
  24. // 筛选数据显示(显示混凝土、砂浆、配合比)
  25. projectGLJSheet.filterData('unit_price.type', [GLJTypeConst.CONCRETE, GLJTypeConst.MORTAR, GLJTypeConst.MIX_RATIO]);
  26. projectGLJSheet.selectRow(projectGLJSpread.firstMixRatioRow);
  27. projectGLJId = projectGLJSheet.getActiveDataByField('id');
  28. // 获取数据
  29. compositionSpread.getRatioData(projectGLJId);
  30. }
  31. if (currentTag === "machine") {
  32. machineSheet = machineSheet === null ? compositionSpread.init(currentTag) : machineSheet;
  33. compositionSpread.initRightClick();
  34. // 筛选数据显示(显示普通机械)
  35. projectGLJSheet.filterData('unit_price.type', [GLJTypeConst.GENERAL_MACHINE]);
  36. projectGLJSheet.selectRow(projectGLJSpread.firstMachineRow);
  37. projectGLJId = projectGLJSheet.getActiveDataByField('id');
  38. // 获取数据
  39. compositionSpread.getRatioData(projectGLJId);
  40. }
  41. });
  42. });
  43. /**
  44. * 成功事件
  45. *
  46. * @param {object} info
  47. * @return {void}
  48. */
  49. function mixRatioSuccess(info) {
  50. // 成功则对相应的总消耗量进行设置
  51. projectGLJSheet.setCellByField('quantity', info.change, true);
  52. // 设置父级3个价格
  53. projectGLJSheet.setCellByField('unit_price.market_price', info.parentMarketPrice, false);
  54. projectGLJSheet.setCellByField('unit_price.base_price', info.parentBasePrice, false);
  55. projectGLJSheet.setCellByField('adjust_price', info.parentMarketPrice, false);
  56. }