FormPanel.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. Ext.define('saas.view.sale.saleout.FormPanel', {
  2. extend: 'saas.view.core.form.FormPanel',
  3. xtype: 'sale-saleout-formpanel',
  4. controller: 'sale-saleout-formpanel',
  5. viewModel: 'sale-saleout-formpanel',
  6. viewName: 'sale-saleout-formpanel',
  7. caller:'SaleOut',
  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/sale/prodinout/read/',
  16. _saveUrl:'/api/sale/prodinout/save/',
  17. _auditUrl:'/api/sale/prodinout/audit/',
  18. _unAuditUrl:'/api/sale/prodinout/unAudit/',
  19. _deleteUrl:'/api/sale/prodinout/delete/',
  20. _turnInUrl:'/api/sale/prodinout/turnProdIn/',
  21. initId:0,
  22. toolBtns: [{
  23. xtype: 'button',
  24. text: '转销售验退',
  25. handler: 'turnProdIn',
  26. bind: {
  27. hidden: '{pi_statuscode!="AUDITED"}'
  28. }
  29. }],
  30. defaultItems: [{
  31. xtype: 'hidden',
  32. name: 'id',
  33. fieldLabel: 'id'
  34. }, {
  35. xtype : "textfield",
  36. name : "pi_class",
  37. fieldLabel : "单据类型",
  38. readOnly:true,
  39. allowBlank : false,
  40. defaultValue:'出货单'
  41. }, {
  42. xtype : "hidden",
  43. name : "pi_custid",
  44. fieldLabel : "客户ID"
  45. }, {
  46. xtype : "hidden",
  47. name : "pi_custcode",
  48. fieldLabel : "客户编号"
  49. }, {
  50. xtype : "dbfindtrigger",
  51. name : "pi_custname",
  52. fieldLabel : "客户名称",
  53. allowBlank:false,
  54. }, {
  55. xtype : "textfield",
  56. name : "pi_address",
  57. fieldLabel : "交货地址",
  58. columnWidth : 0.5
  59. }, {
  60. name : "detailGridField",
  61. xtype : "detailGridField",
  62. detnoColumn: 'pd_pdno',
  63. storeModel:'saas.model.sale.ProdIODetail',
  64. deleteDetailUrl:'/api/sale/prodinout/deleteDetail/',
  65. columns : [
  66. {
  67. text : "id",
  68. dataIndex : "id",
  69. xtype : "numbercolumn",
  70. width:0
  71. }, {
  72. text : "物料id",
  73. dataIndex : "pd_prodid",
  74. width : 0
  75. }, {
  76. text : "物料编号",
  77. width : 200.0,
  78. dataIndex : "pd_prodcode",
  79. xtype : "",
  80. items : null,
  81. allowBlank:false,
  82. editor : {
  83. displayField : "display",
  84. editable : true,
  85. format : "",
  86. hideTrigger : false,
  87. maxLength : 100.0,
  88. minValue : null,
  89. positiveNum : false,
  90. queryMode : "local",
  91. store : null,
  92. valueField : "value",
  93. xtype : "multidbfindtrigger"
  94. }
  95. }, {
  96. text : "名称",
  97. dataIndex : "pr_detail",
  98. ignore:true,
  99. width : 150.0,
  100. renderer: function (v, m, r) {
  101. return r.data["productDTO"]?r.data["productDTO"][m.column.dataIndex]:v;
  102. }
  103. }, {
  104. text : "规格",
  105. dataIndex : "pr_spec",
  106. ignore:true,
  107. width : 150.0,
  108. renderer: function (v, m, r) {
  109. return r.data["productDTO"]?r.data["productDTO"][m.column.dataIndex]:v;
  110. }
  111. }, {
  112. text : "出货数量",
  113. dataIndex : "pd_outqty",
  114. width : 120.0,
  115. allowBlank:false,
  116. editor : {
  117. xtype : "numberfield",
  118. decimalPrecision: 8
  119. },
  120. renderer : function(v) {
  121. var arr = (v + '.').split('.');
  122. var xr = (new Array(arr[1].length)).fill('0');
  123. var format = '0.' + xr.join();
  124. return Ext.util.Format.number(v, format);
  125. },
  126. summaryType: 'sum',
  127. summaryRenderer: function(v) {
  128. var arr = (v + '.').split('.');
  129. var xr = (new Array(arr[1].length)).fill('0');
  130. var format = '0.' + xr.join();
  131. return Ext.util.Format.number(v, format);
  132. }
  133. }, {
  134. text : "仓库ID",
  135. dataIndex : "pd_whid",
  136. width : 0
  137. }, {
  138. text : "仓库",
  139. dataIndex : "pd_whcode",
  140. hidden :true
  141. }, {
  142. text : "仓库",
  143. dataIndex : "pd_whname",
  144. width : 120.0,
  145. items : null,
  146. allowBlank:false,
  147. editor : {
  148. displayField : "display",
  149. editable : true,
  150. format : "",
  151. hideTrigger : false,
  152. maxLength : 100.0,
  153. minValue : null,
  154. positiveNum : false,
  155. queryMode : "local",
  156. store : null,
  157. valueField : "value",
  158. xtype : "dbfindtrigger"
  159. }
  160. },
  161. {
  162. text : "单价",
  163. dataIndex : "pd_sendprice",
  164. width : 120.0,
  165. editor : {
  166. xtype : "numberfield",
  167. decimalPrecision: 8
  168. },
  169. renderer : function(v) {
  170. var arr = (v + '.').split('.');
  171. var xr = (new Array(arr[1].length)).fill('0');
  172. var format = '0,000.' + xr.join();
  173. return Ext.util.Format.number(v, format);
  174. },
  175. },
  176. {
  177. text : "含税金额",
  178. dataIndex : "pd_total",
  179. width : 120.0,
  180. editor : {
  181. xtype : "numberfield",
  182. decimalPrecision: 2
  183. },
  184. renderer : function(v) {
  185. var arr = (v + '.').split('.');
  186. var xr = (new Array(arr[1].length)).fill('0');
  187. var format = '0,000.' + 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)).fill('0');
  194. var format = '0,000.' + xr.join();
  195. return Ext.util.Format.number(v, format);
  196. }
  197. }, {
  198. text : "税率",
  199. dataIndex : "pd_taxrate",
  200. width : 120.0,
  201. editor : {
  202. xtype : "numberfield",
  203. decimalPrecision: 0,
  204. minValue: 0,
  205. maxValue: 100
  206. }
  207. },
  208. {
  209. text : "未含税金额",
  210. dataIndex : "pd_nettotal",
  211. editor : {
  212. xtype : "numberfield",
  213. decimalPrecision: 2
  214. },
  215. renderer : function(v) {
  216. var arr = (v + '.').split('.');
  217. var xr = (new Array(arr[1].length)).fill('0');
  218. var format = '0,000.' + xr.join();
  219. return Ext.util.Format.number(v, format);
  220. },
  221. summaryType: 'sum',
  222. summaryRenderer: function(v) {
  223. var arr = (v + '.').split('.');
  224. var xr = (new Array(arr[1].length)).fill('0');
  225. var format = '0,000.' + xr.join();
  226. return Ext.util.Format.number(v, format);
  227. }
  228. },
  229. {
  230. text : "销售单号",
  231. dataIndex : "pd_ordercode",
  232. width : 200.0
  233. },{
  234. text : "销售序号",
  235. dataIndex : "pd_orderdetno",
  236. xtype : "numbercolumn",
  237. width : 120.0,
  238. format: '0',
  239. renderer: function(v) {
  240. return v ? v : null;
  241. }
  242. }
  243. ]
  244. }, {
  245. xtype : "textfield",
  246. name : "pi_total",
  247. fieldLabel : "总额",
  248. readOnly: true
  249. }, {
  250. xtype : "textfield",
  251. name : "pi_recordman",
  252. fieldLabel : "录入人",
  253. readOnly:true
  254. }, {
  255. xtype : "datefield",
  256. name : "pi_recorddate",
  257. fieldLabel : "录入日期",
  258. readOnly:true
  259. }, {
  260. xtype : "textfield",
  261. name : "pi_auditman",
  262. fieldLabel : "审核人",
  263. readOnly:true
  264. }, {
  265. xtype : "datefield",
  266. name : "pi_auditdate",
  267. fieldLabel : "审核日期",
  268. readOnly:true
  269. }]
  270. });