FormPanel.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403
  1. Ext.define('saas.view.purchase.purchaseIn.FormPanel', {
  2. extend: 'saas.view.core.form.FormPanel',
  3. xtype: 'purchase-purchasein-formpanel',
  4. controller: 'purchase-purchasein-formpanel',
  5. viewModel: 'purchase-purchasein-formpanel',
  6. viewName: 'purchase-purchasein-formpanel',
  7. caller:'PurchaseIn',
  8. //字段属性
  9. _title:'采购验收单',
  10. _idField: 'id',
  11. _codeField: 'pi_inoutno',
  12. _statusField: 'pi_status',
  13. _statusCodeField: 'pi_statuscode',
  14. _relationColumn: 'pd_piid',
  15. _readUrl:'/api/purchase/prodinout/read/',
  16. _saveUrl:'/api/purchase/prodinout/save',
  17. _auditUrl:'/api/purchase/prodinout/audit',
  18. _unAuditUrl:'/api/purchase/prodinout/unAudit/',
  19. _deleteUrl:'/api/purchase/prodinout/delete/',
  20. _turnOutUrl:'/api/purchase/prodinout/turnProdOut/',
  21. initId:0,
  22. toolBtns: [{
  23. xtype: 'button',
  24. text: '转采购验退单',
  25. bind: {
  26. hidden: '{turnHidden}'
  27. },
  28. handler: 'turnOut'
  29. }],
  30. defaultItems: [{
  31. xtype: 'hidden',
  32. name: 'id',
  33. fieldLabel: 'id',
  34. allowBlank: true,
  35. columnWidth: 0
  36. },{
  37. xtype : "textfield",
  38. name : "pi_class",
  39. fieldLabel : "单据类型",
  40. readOnly:true,
  41. allowBlank : true,
  42. columnWidth : 0.25
  43. }, {
  44. xtype : "hidden",
  45. name : "pi_vendid",
  46. fieldLabel : "供应商ID",
  47. allowBlank : true,
  48. columnWidth : 0.0
  49. },{
  50. xtype: 'hidden',
  51. name: 'pi_vendcode',
  52. fieldLabel: '供应商编号'
  53. }, {
  54. xtype: 'dbfindtrigger',
  55. name: 'pi_vendname',
  56. fieldLabel: '供应商名称',
  57. allowBlank : false,
  58. },{
  59. xtype : "datefield",
  60. name : "pi_date",
  61. fieldLabel : "单据日期",
  62. allowBlank : false,
  63. columnWidth : 0.25,
  64. defaultValue: new Date()
  65. },{
  66. xtype : "textfield",
  67. name : "pi_total",
  68. fieldLabel : "总额",
  69. allowBlank : true,
  70. readOnly: true,
  71. columnWidth : 0.25
  72. }, {
  73. xtype : "hidden",
  74. name : "pi_puid",
  75. fieldLabel : "采购单id",
  76. allowBlank : true,
  77. columnWidth : 0.25
  78. },{
  79. xtype : "hidden",
  80. name : "pi_pucode",
  81. fieldLabel : "采购单号",
  82. allowBlank : true,
  83. columnWidth : 0.25
  84. }, {
  85. name : "detailGridField",
  86. xtype : "detailGridField",
  87. storeModel:'saas.model.purchase.ProdIODetail',
  88. deleteDetailUrl:'/api/purchase/prodinout/deleteDetail/',
  89. detnoColumn: 'pd_pdno',
  90. columns : [
  91. {
  92. text : "id",
  93. dataIndex : "id",
  94. xtype : "numbercolumn",
  95. hidden:true
  96. },{
  97. text : "物料id",
  98. dataIndex : "pd_prodid",
  99. xtype : "numbercolumn",
  100. hidden:true
  101. },
  102. {
  103. text : "物料编号",
  104. width : 200.0,
  105. dataIndex : "pd_prodcode",
  106. xtype : "",
  107. items : null,
  108. allowBlank : false,
  109. editor : {
  110. displayField : "display",
  111. editable : true,
  112. format : "",
  113. hideTrigger : false,
  114. maxLength : 100.0,
  115. minValue : null,
  116. positiveNum : false,
  117. queryMode : "local",
  118. store : null,
  119. valueField : "value",
  120. xtype : "multidbfindtrigger"
  121. }
  122. },{
  123. text: 'model映射需要',
  124. dataIndex: 'productDTO',
  125. hidden: true,
  126. },
  127. {
  128. text : "名称",
  129. dataIndex : "pr_detail",
  130. ignore:true,
  131. renderer: function (v, m, r) {
  132. if(!v){
  133. return r.data["productDTO"]?r.data["productDTO"][m.column.dataIndex]:null;
  134. }
  135. return v;
  136. }
  137. },
  138. {
  139. text : "规格",
  140. dataIndex : "pr_spec",
  141. ignore:true,
  142. renderer: function (v, m, r) {
  143. if(!v){
  144. return r.data["productDTO"]?r.data["productDTO"][m.column.dataIndex]:null;
  145. }
  146. return v;
  147. }
  148. },
  149. {
  150. text : "数量",
  151. dataIndex : "pd_inqty",
  152. xtype: 'numbercolumn',
  153. width : 120.0,
  154. allowBlank : false,
  155. editor : {
  156. xtype : "numberfield",
  157. decimalPrecision: 3,
  158. minValue:0
  159. },
  160. renderer : function(v) {
  161. var arr = (v + '.').split('.');
  162. var xr = (new Array(arr[1].length > 3 ? 3 : arr[1].length)).fill('0');
  163. var format = '0.' + xr.join();
  164. return Ext.util.Format.number(v, format);
  165. },
  166. summaryType: 'sum',
  167. summaryRenderer: function(v) {
  168. var arr = (v + '.').split('.');
  169. var xr = (new Array(arr[1].length > 3 ? 3 : arr[1].length)).fill('0');
  170. var format = '0.' + xr.join();
  171. return Ext.util.Format.number(v, format);
  172. }
  173. }, {
  174. text : "已转数",
  175. dataIndex : "pd_yqty",
  176. xtype: 'numbercolumn',
  177. hidden:true,
  178. width : 120.0,
  179. editor : {
  180. xtype : "numberfield",
  181. decimalPrecision: 3,
  182. editable : false
  183. },
  184. renderer : function(v) {
  185. var arr = (v + '.').split('.');
  186. var xr = (new Array(arr[1].length > 3 ? 3 : arr[1].length)).fill('0');
  187. var format = '0.' + xr.join();
  188. return Ext.util.Format.number(v, format);
  189. },
  190. summaryType: 'sum',
  191. summaryRenderer: function(v) {
  192. var arr = (v + '.').split('.');
  193. var xr = (new Array(arr[1].length > 3 ? 3 : arr[1].length)).fill('0');
  194. var format = '0.' + xr.join();
  195. return Ext.util.Format.number(v, format);
  196. }
  197. },{
  198. text : "仓库id",
  199. dataIndex : "pd_whid",
  200. xtype : "numbercolumn",
  201. hidden:true
  202. },
  203. {
  204. text : "仓库编号",
  205. dataIndex : "pd_whcode",
  206. hidden:true
  207. },
  208. {
  209. text : "仓库",
  210. dataIndex : "pd_whname",
  211. width : 120.0,
  212. allowBlank : false,
  213. editor : {
  214. displayField : "display",
  215. editable : true,
  216. format : "",
  217. hideTrigger : false,
  218. maxLength : 100.0,
  219. minValue : null,
  220. positiveNum : false,
  221. queryMode : "local",
  222. store : null,
  223. valueField : "value",
  224. xtype : "dbfindtrigger"
  225. }
  226. },
  227. {
  228. text : "单价",
  229. xtype: 'numbercolumn',
  230. editor : {
  231. xtype : "numberfield",
  232. decimalPrecision: 8,
  233. minValue:0
  234. },
  235. dataIndex : "pd_orderprice",
  236. width : 120.0,
  237. renderer : function(v) {
  238. var arr = (v + '.').split('.');
  239. var xr = (new Array(arr[1].length > 8 ? 8 : arr[1].length)).fill('0');
  240. var format = '0,000.' + xr.join();
  241. return Ext.util.Format.number(v, format);
  242. },
  243. }, {
  244. xtype: 'numbercolumn',
  245. text : "税率",
  246. dataIndex : "pd_taxrate",
  247. width : 120.0,
  248. editor : {
  249. xtype : "numberfield",
  250. decimalPrecision: 0,
  251. minValue: 0,
  252. maxValue: 100
  253. },
  254. renderer : function(v) {
  255. return Ext.util.Format.number(v, '0');
  256. },
  257. },{
  258. text : "含税金额",
  259. xtype: 'numbercolumn',
  260. dataIndex : "pd_total",
  261. width : 120.0,
  262. editor : {
  263. xtype : "numberfield",
  264. decimalPrecision: 2,
  265. editable : false
  266. },
  267. renderer : function(v) {
  268. var arr = (v + '.').split('.');
  269. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  270. var format = '0,000.' + xr.join();
  271. return Ext.util.Format.number(v, format);
  272. },
  273. summaryType: 'sum',
  274. summaryRenderer: function(v) {
  275. var arr = (v + '.').split('.');
  276. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  277. var format = '0,000.' + xr.join();
  278. return Ext.util.Format.number(v, format);
  279. }
  280. },
  281. {
  282. text : "未税金额",
  283. xtype: 'numbercolumn',
  284. dataIndex : "pd_nettotal",
  285. editor : {
  286. xtype : "numberfield",
  287. decimalPrecision: 2,
  288. editable : false
  289. },
  290. renderer : function(v) {
  291. var arr = (v + '.').split('.');
  292. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  293. var format = '0,000.' + xr.join();
  294. return Ext.util.Format.number(v, format);
  295. },
  296. summaryType: 'sum',
  297. summaryRenderer: function(v) {
  298. var arr = (v + '.').split('.');
  299. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  300. var format = '0,000.' + xr.join();
  301. return Ext.util.Format.number(v, format);
  302. }
  303. },
  304. {
  305. text : "采购单明细id",
  306. dataIndex : "pd_orderid",
  307. width : 120.0,
  308. hidden:true
  309. },
  310. {
  311. text : "采购单号",
  312. dataIndex : "pd_ordercode",
  313. width : 120.0
  314. },{
  315. text : "采购序号",
  316. dataIndex : "pd_orderdetno",
  317. xtype : "numbercolumn",
  318. width : 120.0,
  319. format: '0',
  320. renderer: function(v) {
  321. return v ? v : null;
  322. }
  323. },{
  324. text : "备注",
  325. dataIndex : "pd_remark",
  326. width : 250,
  327. items : null,
  328. editor : {
  329. xtype : "textfield"
  330. },
  331. }
  332. ]
  333. },{
  334. xtype : "textfield",
  335. name : "pi_remark",
  336. fieldLabel : "备注",
  337. columnWidth : 1
  338. },
  339. {
  340. xtype : "hidden",
  341. name : "creatorId",
  342. fieldLabel : "录入人ID",
  343. readOnly:true
  344. },
  345. {
  346. xtype : "textfield",
  347. name : "creator",
  348. fieldLabel : "录入人",
  349. readOnly:true
  350. }, {
  351. xtype : "datefield",
  352. name : "createtime",
  353. fieldLabel : "录入日期",
  354. readOnly:true,
  355. defaultValue: new Date()
  356. },{
  357. xtype : "hidden",
  358. name : "updaterId",
  359. fieldLabel : "更新人ID",
  360. readOnly:true
  361. },{
  362. xtype : "hidden",
  363. name : "updater",
  364. fieldLabel : "更新人",
  365. readOnly:true
  366. }, {
  367. xtype : "hidden",
  368. name : "updatetime",
  369. fieldLabel : "更新日期",
  370. readOnly:true,
  371. defaultValue: new Date()
  372. }, {
  373. xtype : "textfield",
  374. name : "pi_auditman",
  375. fieldLabel : "审核人",
  376. readOnly:true
  377. }, {
  378. xtype : "datefield",
  379. name : "pi_auditdate",
  380. fieldLabel : "审核日期",
  381. readOnly:true
  382. }],
  383. beforeAudit:function(){
  384. var me = this,
  385. viewModel = me.getViewModel(),
  386. grid = me.down('detailGridField'),
  387. data = grid.getTrueData();
  388. Ext.Array.each(data,function(item){
  389. if(item.pd_orderprice==0){
  390. saas.util.BaseUtil.showToast(item.pd_pdno+'行'+item.pd_prodcode+'物料单价为0');
  391. }
  392. });
  393. return true;
  394. }
  395. });