glj_index.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297
  1. /**
  2. * 聊天室相关
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/15
  6. * @version
  7. */
  8. $(document).ready(function () {
  9. // excel
  10. let header = [
  11. {name: '编码', field: 'code', visible: true},
  12. {name: '名称', field: 'name', visible: true},
  13. {name: '规格型号', field: 'unit_price.specs', visible: true},
  14. {name: '单位', field: 'unit_price.unit', visible: true},
  15. {name: 'ID', field: 'id', visible: false},
  16. {name: '类型', field: 'unit_price.type', visible: false},
  17. {name: '总消耗量', field: '', visible: true},
  18. {name: '基价单价', field: "unit_price.base_price", visible: true},
  19. {name: '调整基价', field: 'adjust_price', visible: true},
  20. {name: '市场单价', field: "unit_price.market_price", visible: true, validator: 'number'},
  21. {name: '是否暂估', field: 'is_evaluate', visible: true, cellType: new GC.Spread.Sheets.CellTypes.CheckBox(), validator: 'boolean'},
  22. {name: '供货方式', field: 'supply', visible: true},
  23. {name: '甲供数量', field: 'supply_quantity', visible: true},
  24. {name: '交货方式', field: 'delivery', visible: true},
  25. {name: '送达地点', field: 'delivery_address', visible: true},
  26. {name: '不调价', field: 'is_adjust_price', visible: true, cellType: new GC.Spread.Sheets.CellTypes.CheckBox(), validator: 'boolean'},
  27. {name: 'UID', field: 'unit_price.id', visible: false},
  28. ];
  29. // 数据转换格式
  30. let sourceData = JSON.parse(jsonData);
  31. let setting = {
  32. header: []
  33. };
  34. for(let tmp of header) {
  35. setting.header.push({headerName: tmp.name, headerWidth: 120});
  36. }
  37. let spread = sheetCommonObj.buildSheet(document.getElementById("test"), setting, sourceData.length);
  38. spread.options.scrollbarShowMax = true;
  39. spread.options.scrollbarMaxAlign = true;
  40. spread.options.showHorizontalScrollbar = true;
  41. let sheet = spread.getActiveSheet();
  42. // 设置表单不可编辑
  43. sheet.options.isProtected = true;
  44. // 居中样式
  45. let centerStyleSetting = {hAlign: 1};
  46. sheet.setStyle(-1, 10, getStyle(centerStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  47. sheet.setStyle(-1, 15, getStyle(centerStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  48. sheet.setStyle(-1, 3, getStyle(centerStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  49. // 向右对齐样式
  50. let rightStyleSetting = {hAlign: GC.Spread.Sheets.HorizontalAlign.right};
  51. sheet.setStyle(-1, 6, getStyle(rightStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  52. sheet.setStyle(-1, 7, getStyle(rightStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  53. sheet.setStyle(-1, 8, getStyle(rightStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  54. sheet.setStyle(-1, 9, getStyle(rightStyleSetting), GC.Spread.Sheets.SheetArea.viewport);
  55. // 设置可编辑列
  56. sheet.getRange(-1, 9, -1, 1).locked(false);
  57. sheet.getRange(-1, 10, -1, 1).locked(false);
  58. sheet.getRange(-1, 15, -1, 1).locked(false);
  59. // 设置json数据
  60. let rowCounter = 0;
  61. for(let data of sourceData) {
  62. let columnCounter = 0;
  63. for(let columnInfo of header) {
  64. // 设置是否显示
  65. sheet.setColumnVisible(columnCounter, columnInfo.visible);
  66. let dataString = columnInfo.field !== '' && columnInfo.field !== undefined ?
  67. "data." + columnInfo.field : '';
  68. let cellData = eval(dataString);
  69. // 设置复选框
  70. if (columnInfo.cellType !== undefined) {
  71. let checkbox = new GC.Spread.Sheets.CellTypes.CheckBox();
  72. sheet.setCellType(rowCounter, columnCounter, checkbox, GC.Spread.Sheets.SheetArea.viewport);
  73. }
  74. // 如果不为材料“是否暂估列”根据条件显示
  75. if (columnInfo.field === 'is_evaluate' && materialIdList.indexOf(data.unit_price.type + '') < 0) {
  76. let string = new GC.Spread.Sheets.CellTypes.Text();
  77. sheet.setCellType(rowCounter, columnCounter, string, GC.Spread.Sheets.SheetArea.viewport);
  78. cellData = '';
  79. // 并且锁定该单元格
  80. sheet.getRange(rowCounter, columnCounter, 1, 1).locked(true);
  81. }
  82. // 如果类型为混凝土、砂浆、配合比、机械,则市场单价不能修改
  83. if (columnInfo.field === 'unit_price.market_price' && canNotChangeTypeId.indexOf(data.unit_price.type + '') >= 0) {
  84. // 锁定该单元格
  85. sheet.getRange(rowCounter, columnCounter, 1, 1).locked(true);
  86. }
  87. sheet.setValue(rowCounter, columnCounter, cellData, GC.Spread.Sheets.SheetArea.viewport);
  88. columnCounter++;
  89. }
  90. rowCounter++;
  91. }
  92. /*
  93. let socket = io('http://notify.smartcost.com.cn:3300');
  94. socket.on('connect', function () {
  95. socket.emit('join', project);
  96. console.log('连接成功');
  97. });
  98. // 接受到改变
  99. let changeInfo = [];
  100. socket.on('dataChange', function(data) {
  101. data = JSON.parse(data);
  102. if (data.newValue === undefined) {
  103. return false;
  104. }
  105. changeInfo.push(data);
  106. $("#message").html('基价单位已被修改,<a href="javascript:void(0);" id="load-data">点击加载</a>');
  107. $("#notify").slideDown('fast');
  108. initiativeChange = false;
  109. });
  110. // 是否主动更改数据
  111. let initiativeChange = false;
  112. $("#message").on('click', '#load-data', function() {
  113. $("#notify").slideUp('fast');
  114. if (changeInfo.length > 0) {
  115. for (let index in changeInfo) {
  116. let cell = sheet.getCell(changeInfo[index].row, changeInfo[index].col, GC.Spread.Sheets.SheetArea.viewport);
  117. cell.value(changeInfo[index].newValue);
  118. }
  119. }
  120. changeInfo = [];
  121. });
  122. // 进入单元格后设置为主动设置数据
  123. sheet.bind(GC.Spread.Sheets.Events.EditEnding, function (element, info) {
  124. initiativeChange = true;
  125. });
  126. */
  127. // 绑定事件
  128. let isChanging = false;
  129. sheet.bind(GC.Spread.Sheets.Events.ValueChanged, function (element, info) {
  130. // 获取修改的数据
  131. let column = info.col;
  132. let row = info.row;
  133. let model = 'glj';
  134. let idString = 'id';
  135. let field = header[column] !== undefined && header[column].field !== undefined ?
  136. header[column].field : '';
  137. if (field === '') {
  138. return false;
  139. }
  140. // 切割字段
  141. let fieldArray = field.split('.');
  142. idString = fieldArray.length > 1 ? 'unit_price.id' : idString;
  143. // 防止快速同时提交
  144. if (isChanging) {
  145. return false;
  146. }
  147. // 校验数据
  148. let validator = header[column].validator !== undefined ? header[column].validator : null;
  149. let value = info.newValue;
  150. if (validator && !checkData(validator, value)) {
  151. alert('数据格式错误,请重新输入!');
  152. sheet.setValue(row, column, info.oldValue);
  153. return false;
  154. }
  155. // 获取id
  156. let idColumn = getFieldColumn(header, idString);
  157. if (idColumn < 0) {
  158. return false;
  159. }
  160. let id = sheet.getValue(row, idColumn);
  161. $.ajax({
  162. url: '/glj/update',
  163. type: 'post',
  164. data: {id: id, field: field, value: value, model: model},
  165. dataType: 'json',
  166. error: function() {
  167. alert('数据传输有误!');
  168. isChanging = false;
  169. },
  170. beforeSend: function() {
  171. isChanging = true;
  172. },
  173. success: function(response) {
  174. isChanging = false;
  175. // 修改失败则恢复原值
  176. if (response.err !== 0) {
  177. sheet.setValue(row, column, info.oldValue);
  178. alert('更改数据失败!');
  179. } else {
  180. // 成功
  181. }
  182. }
  183. });
  184. /*
  185. // 如果修改了数据且为主动修改,先存库再广播给其他页面
  186. if (info.newValue !== undefined && info.oldValue !== undefined && initiativeChange) {
  187. let id = sheet.getCell(info.row, 0).value();
  188. $.ajax({
  189. url: '/save',
  190. type: 'post',
  191. data: {priceValue: info.newValue, id: id},
  192. error: function() {
  193. // @todo 替换为更好地错误提示
  194. alert('error');
  195. },
  196. beforeSend: function() {
  197. },
  198. success: function(response) {
  199. if (response.err === 0) {
  200. socket.emit('dataNotify', JSON.stringify(info));
  201. } else {
  202. // @todo 替换为更好地错误提示
  203. alert(response.msg);
  204. }
  205. }
  206. });
  207. }
  208. */
  209. });
  210. // 绑定双击事件
  211. sheet.bind(GC.Spread.Sheets.Events.CellDoubleClick, function (element, info) {
  212. console.log(info);
  213. });
  214. });
  215. /**
  216. * 生成样式
  217. *
  218. * @param {object} setting
  219. * @return {object}
  220. */
  221. function getStyle(setting) {
  222. let style = new GC.Spread.Sheets.Style();
  223. style.locked = setting.readOnly === undefined ? true : setting.readOnly;
  224. style.hAlign = setting.hAlign === undefined ? GC.Spread.Sheets.HorizontalAlign.center : setting.hAlign;
  225. return style;
  226. }
  227. /**
  228. * 查找指定字段的列index
  229. *
  230. * @param {object} data
  231. * @param {String} field
  232. * @return {Number}
  233. */
  234. function getFieldColumn(data, field) {
  235. let result = -1;
  236. if (data.length <= 0) {
  237. return result;
  238. }
  239. for (let tmp in data) {
  240. if (data[tmp].field === field) {
  241. result = tmp;
  242. break;
  243. }
  244. }
  245. return result;
  246. }
  247. /**
  248. * 校验数据
  249. *
  250. * @param {string} validator
  251. * @param {string} value
  252. * @return {boolean}
  253. */
  254. function checkData(validator, value) {
  255. let result = false;
  256. switch (validator) {
  257. case 'number':
  258. let regular = /^\d+(\.\d+)?$/;
  259. result = regular.test(value);
  260. break;
  261. case 'boolean':
  262. let booleanValue = [true, false];
  263. result = booleanValue.indexOf(value) >= 0;
  264. break;
  265. }
  266. return result;
  267. }