glj_controller.js 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. /**
  2. * 工料机相关控制器
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/22
  6. * @version
  7. */
  8. import BaseController from "../../common/base/base_controller";
  9. import GLJListModel from "../models/glj_list_model";
  10. import UnitPriceModel from "../models/unit_price_model";
  11. import UnitPriceFileModel from "../models/unit_price_file_model";
  12. class GLJController extends BaseController {
  13. /**
  14. * 构造函数
  15. *
  16. * @return {void}
  17. */
  18. constructor() {
  19. let parent = super();
  20. parent.title = '工料机';
  21. }
  22. /**
  23. * 工料机汇总页
  24. *
  25. * @param {object} request
  26. * @param {object} response
  27. * @return {void}
  28. */
  29. async index(request, response) {
  30. // 标段id
  31. let projectId = request.query.project;
  32. projectId = parseInt(projectId);
  33. try {
  34. if (isNaN(projectId) || projectId <= 0) {
  35. throw '标段id有误';
  36. }
  37. // 先获取对应标段的项目工料机数据
  38. let gljListModel = new GLJListModel();
  39. let gljList = await gljListModel.getListByProjectId(projectId);
  40. console.log(gljList);
  41. let renderData = {
  42. gljList: JSON.stringify(gljList),
  43. materialIdList: gljListModel.materialIdList
  44. };
  45. response.render('glj/html/glj_index', renderData);
  46. } catch (error) {
  47. response.status(404).send('404 Error');
  48. }
  49. }
  50. /**
  51. * 更新数据
  52. *
  53. * @param {object} request
  54. * @param {object} response
  55. * @return {void}
  56. */
  57. async updateData(request, response) {
  58. let field = request.body.field;
  59. let value = request.body.value;
  60. value = value === 'true' ? 1 : value;
  61. value = value === 'false' ? 0 : value;
  62. let id = request.body.id;
  63. let responseData = {
  64. err: 0,
  65. msg: ''
  66. };
  67. try {
  68. // 可编辑的字段
  69. let editableField = ['is_evaluate', 'unit_price.market_price', 'is_adjust_price'];
  70. if (editableField.indexOf(field) < 0) {
  71. throw '对应字段不能编辑';
  72. }
  73. let modelString = 'glj';
  74. // 切割字段
  75. let fieldArray = field.split('.');
  76. modelString = fieldArray.length > 1 ? fieldArray[0] : modelString;
  77. field = fieldArray.length > 1 ? fieldArray[1] : field;
  78. let model = null;
  79. switch (modelString) {
  80. case 'glj':
  81. model = new GLJListModel();
  82. break;
  83. case 'unit_price':
  84. model = new UnitPriceModel();
  85. break;
  86. }
  87. if (!model) {
  88. throw '创建模块失败!';
  89. }
  90. // 组合数据
  91. let updateData = new Object();
  92. updateData[field] = value;
  93. // 更新数据
  94. let result = await model.updateById(id, updateData);
  95. if (!result) {
  96. throw '更新失败';
  97. }
  98. } catch (error) {
  99. console.log('error:' + error);
  100. responseData.err = 1;
  101. }
  102. response.json(responseData);
  103. }
  104. /**
  105. * 模拟定额插入
  106. *
  107. * @param {object} request
  108. * @param {object} response
  109. * @return {void}
  110. */
  111. async test(request, response) {
  112. // 从定额库获取的数据
  113. let data = {
  114. glj_repository_id: 3,
  115. project_id: 1,
  116. code: '01010101',
  117. name: '水泥',
  118. specs: '32.5',
  119. unit: 'kg',
  120. type: 5,
  121. type_of_work: 5,
  122. base_price: 28.76,
  123. market_price: 28.76
  124. };
  125. try {
  126. let gljListModel = new GLJListModel();
  127. let result = await gljListModel.addList(data);
  128. console.log(result);
  129. } catch (error) {
  130. console.log(error);
  131. }
  132. response.end('success');
  133. }
  134. /**
  135. * 模拟定额修改单价
  136. *
  137. * @param {object} request
  138. * @param {object} response
  139. * @return {void}
  140. */
  141. async testModify(request, response) {
  142. let projectId = request.query.project;
  143. // 修改数据
  144. let updateData = {
  145. code: '01010101',
  146. market_price: '40',
  147. name: '水泥',
  148. project_id: projectId
  149. };
  150. try {
  151. // 获取标段对应的单价文件id
  152. let unitPriceFileModel = new UnitPriceFileModel();
  153. let unitPriceFile = await unitPriceFileModel.getDataByProject(projectId);
  154. if (!unitPriceFile) {
  155. throw '没有对应的单价文件';
  156. }
  157. let unitPriceFileId = unitPriceFile.id;
  158. let unitPriceModel = new UnitPriceModel();
  159. let result = await unitPriceModel.updateUnitPrice(updateData, unitPriceFileId);
  160. console.log(result);
  161. } catch (error) {
  162. console.log(error);
  163. }
  164. response.end('success');
  165. }
  166. /**
  167. * 测试删除
  168. *
  169. * @param {object} request
  170. * @param {object} response
  171. * @return {void}
  172. */
  173. async delete(request, response) {
  174. try {
  175. let gljListModel = new GLJListModel();
  176. let result = await gljListModel.deleteById(63);
  177. console.log(result);
  178. } catch (error) {
  179. console.log(error);
  180. }
  181. response.end('success');
  182. }
  183. }
  184. export default GLJController;