FormPanel.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423
  1. Ext.define('saas.view.money.payBalance.FormPanel', {
  2. extend: 'saas.view.core.form.FormPanel',
  3. xtype: 'money-paybalance-formpanel',
  4. controller: 'money-paybalance-formpanel',
  5. viewModel: 'money-paybalance-formpanel',
  6. viewName: 'money-paybalance-formpanel',
  7. caller: 'PayBalance',
  8. //字段属性
  9. _title: '付款单',
  10. _idField: 'id',
  11. _codeField: 'pb_code',
  12. _statusField: 'pb_status',
  13. _statusCodeField: 'pb_statuscode',
  14. _readUrl: '/api/money/paybalance/read/',
  15. _saveUrl: '/api/money/paybalance/save/',
  16. _auditUrl: '/api/money/paybalance/audit/',
  17. _unAuditUrl: '/api/money/paybalance/unAudit/',
  18. _deleteUrl: '/api/money/paybalance/delete/',
  19. initId: 0,
  20. toolBtns: [],
  21. defaultItems: [{
  22. xtype: 'hidden',
  23. name: 'id',
  24. fieldLabel: 'id'
  25. }, {
  26. xtype: 'textfield',
  27. name: 'pb_kind',
  28. fieldLabel: '单据类型',
  29. defaultValue: '付款单',
  30. readOnly: true
  31. }, {
  32. xtype: 'hidden',
  33. name: 'pb_vendid',
  34. fieldLabel: '供应商ID'
  35. }, {
  36. xtype: "hidden",
  37. name: "pb_vendcode",
  38. fieldLabel: "供应商编号"
  39. }, {
  40. xtype: "vendorDbfindTrigger",
  41. name: "pb_vendname",
  42. fieldLabel: "供应商名称",
  43. allowBlank : false
  44. },{
  45. xtype:"numberfield",
  46. name:"ve_leftamount",
  47. fieldLabel:"总欠款",
  48. ignore:true,
  49. readOnly: true
  50. },{
  51. xtype: "datefield",
  52. name: "pb_date",
  53. fieldLabel: "日期",
  54. defaultValue: new Date(),
  55. allowBlank : false
  56. },{
  57. xtype: 'textfield',
  58. name: 'pb_manname',
  59. fieldLabel: '付款人'
  60. }, {
  61. xtype: 'hidden',
  62. name: 'pb_pdamount',
  63. fieldLabel: '付款金额'
  64. }, {
  65. xtype: "hidden",
  66. name: "pb_pbdamount",
  67. fieldLabel: "本次核销金额"
  68. }, {
  69. xtype: "numberfield",
  70. name: "pb_preamount",
  71. fieldLabel: "本次预付款",
  72. readOnly: true
  73. }, {
  74. xtype: 'numberfield',
  75. name: 'pb_discounts',
  76. fieldLabel: '整单折扣',
  77. hidden: true
  78. }, {
  79. xtype: 'hidden',
  80. name: 'pb_havebalance',
  81. fieldLabel: '已核销金额'
  82. }, {
  83. xtype: "detailGridField",
  84. storeModel: 'saas.model.money.PayBalance1',
  85. detnoColumn: 'pd_detno',
  86. deleteDetailUrl: '/api/money/paybalance/deleteDetail1/',
  87. columns: [
  88. {
  89. text: 'ID',
  90. dataIndex: 'id',
  91. hidden: true
  92. }, {
  93. text: '期间',
  94. dataIndex: 'pd_ym',
  95. hidden:true,
  96. defaultValue: Ext.Date.format(new Date(), 'Ym'),
  97. // editor: {
  98. // xtype: 'hidden',
  99. // xtype: 'textfield,
  100. // xtype: 'datefield''
  101. // }
  102. }, {
  103. text: '结算账户ID',
  104. dataIndex: 'pd_bankid',
  105. hidden: true
  106. }, {
  107. text: '资金账户',
  108. dataIndex: 'pd_bankname',
  109. allowBlank : false,
  110. editor:{
  111. xtype:'bandinfoDbfindTrigger'
  112. }
  113. },{
  114. text: '资金账户编号',
  115. dataIndex: 'pd_bankcode',
  116. hidden: true
  117. }, {
  118. text: "付款金额",
  119. xtype: 'numbercolumn',
  120. dataIndex: "pd_amount",
  121. editor : {
  122. xtype : "numberfield",
  123. decimalPrecision: 2
  124. },
  125. renderer : function(v) {
  126. var arr = (v + '.').split('.');
  127. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  128. var format = '0,000.' + xr.join();
  129. return Ext.util.Format.number(v, format);
  130. },
  131. summaryType: 'sum',
  132. summaryRenderer: function(v) {
  133. var arr = (v + '.').split('.');
  134. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  135. var format = '0,000.' + xr.join();
  136. return Ext.util.Format.number(v, format);
  137. }
  138. }, {
  139. text: "结算方式",
  140. dataIndex: "pd_paymethod",
  141. editor : {
  142. xtype:'combo',
  143. queryMode: 'local',
  144. displayField: 'display',
  145. valueField: 'value',
  146. store:Ext.create('Ext.data.Store', {
  147. fields: ['value', 'display'],
  148. data : [
  149. {value:"信用卡", display:"信用卡"},
  150. {value:"支票", display:"支票"},
  151. {value:"汇票", display:"汇票"},
  152. {value:"现金", display:"现金"},
  153. {value:"银行转账", display:"银行转账"},
  154. {value:"支付宝转账", display:"支付宝转账"},
  155. {value:"微信转账", display:"微信转账"}
  156. ]
  157. })
  158. }
  159. }, {
  160. text: "结算号",
  161. dataIndex: "pd_paycode",
  162. editor:{
  163. xtype:'textfield'
  164. }
  165. }, {
  166. text: "备注",
  167. dataIndex: "pd_remark",
  168. width: 250,
  169. editor:{
  170. xtype: 'textfield'
  171. }
  172. }]
  173. },{
  174. xtype: "detailGridField",
  175. storeModel: 'saas.model.money.PayBalance2',
  176. detnoColumn: 'pbd_detno',
  177. allowEmpty: true,
  178. deleteDetailUrl: '/api/money/paybalance/deleteDetail2/',
  179. columns: [
  180. {
  181. text: 'ID',
  182. dataIndex: 'id',
  183. hidden: true
  184. }, {
  185. text: '期间',
  186. dataIndex: 'pbd_ym',
  187. hidden: true
  188. }, {
  189. text: '来源ID',
  190. dataIndex: 'pbd_slid',
  191. hidden: true
  192. }, {
  193. text: '来源单号',
  194. dataIndex: 'pbd_slcode',
  195. editor:{
  196. displayField : "display",
  197. editable : true,
  198. format : "",
  199. hideTrigger : false,
  200. maxLength : 100.0,
  201. minValue : null,
  202. positiveNum : false,
  203. queryMode : "local",
  204. store : null,
  205. valueField : "value",
  206. xtype : "multidbfindtrigger",
  207. listeners:{
  208. beforetriggerclick:'vendnamechange'
  209. }
  210. },
  211. }, {
  212. text: "业务类型",
  213. dataIndex: "pbd_slkind"
  214. }, {
  215. text: "单据日期",
  216. dataIndex: "pbd_sldate",
  217. xtype: 'datecolumn'
  218. }, {
  219. text: "单据金额",
  220. xtype: 'numbercolumn',
  221. dataIndex: "pbd_amount",
  222. // editor : {
  223. // xtype : "numberfield",
  224. // decimalPrecision: 2
  225. // },
  226. renderer : function(v) {
  227. var arr = (v + '.').split('.');
  228. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  229. var format = '0,000.' + xr.join();
  230. return Ext.util.Format.number(v, format);
  231. },
  232. summaryType: 'sum',
  233. summaryRenderer: function(v) {
  234. var arr = (v + '.').split('.');
  235. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  236. var format = '0,000.' + xr.join();
  237. return Ext.util.Format.number(v, format);
  238. }
  239. }, {
  240. text: "已核销金额",
  241. xtype: 'numbercolumn',
  242. dataIndex: "sl_yamount",
  243. ignore:true,
  244. // editor : {
  245. // xtype : "numberfield",
  246. // decimalPrecision: 2
  247. // },
  248. renderer : function(v) {
  249. var arr = (v + '.').split('.');
  250. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  251. var format = '0,000.' + xr.join();
  252. return Ext.util.Format.number(v, format);
  253. },
  254. summaryType: 'sum',
  255. summaryRenderer: function(v) {
  256. var arr = (v + '.').split('.');
  257. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  258. var format = '0,000.' + xr.join();
  259. return Ext.util.Format.number(v, format);
  260. }
  261. }, {
  262. text: "未核销金额",
  263. xtype: 'numbercolumn',
  264. dataIndex: "sl_namount",
  265. ignore:true,
  266. // editor : {
  267. // xtype : "numberfield",
  268. // decimalPrecision: 2
  269. // },
  270. renderer : function(v) {
  271. var arr = (v + '.').split('.');
  272. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  273. var format = '0,000.' + xr.join();
  274. return Ext.util.Format.number(v, format);
  275. },
  276. summaryType: 'sum',
  277. summaryRenderer: function(v) {
  278. var arr = (v + '.').split('.');
  279. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  280. var format = '0,000.' + xr.join();
  281. return Ext.util.Format.number(v, format);
  282. }
  283. }, {
  284. text: "本次核销金额",
  285. xtype: 'numbercolumn',
  286. dataIndex: "pbd_nowbalance",
  287. width: 150,
  288. editor : {
  289. xtype : "numberfield",
  290. decimalPrecision: 2
  291. },
  292. allowBlank : false,
  293. renderer : function(v) {
  294. var arr = (v + '.').split('.');
  295. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  296. var format = '0,000.' + xr.join();
  297. return Ext.util.Format.number(v, format);
  298. },
  299. summaryType: 'sum',
  300. summaryRenderer: function(v) {
  301. var arr = (v + '.').split('.');
  302. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  303. var format = '0,000.' + xr.join();
  304. return Ext.util.Format.number(v, format);
  305. }
  306. }, {
  307. text: '备注',
  308. dataIndex: 'pbd_remark',
  309. width: 250,
  310. hidden: true
  311. }]
  312. }, {
  313. xtype: 'textfield',
  314. name: 'pb_remark',
  315. columnWidth: 1,
  316. fieldLabel: '备注'
  317. }, {
  318. xtype : "hidden",
  319. name : "creatorId",
  320. fieldLabel : "录入人ID",
  321. readOnly:true
  322. },
  323. {
  324. xtype : "textfield",
  325. name : "creatorName",
  326. fieldLabel : "录入人",
  327. readOnly:true
  328. }, {
  329. xtype : "datefield",
  330. name : "createTime",
  331. fieldLabel : "录入日期",
  332. readOnly:true,
  333. defaultValue: new Date()
  334. },{
  335. xtype : "hidden",
  336. name : "updaterId",
  337. fieldLabel : "更新人ID",
  338. readOnly:true
  339. },{
  340. xtype : "hidden",
  341. name : "updaterName",
  342. fieldLabel : "更新人",
  343. readOnly:true
  344. }, {
  345. xtype : "hidden",
  346. name : "updateTime",
  347. fieldLabel : "更新日期",
  348. readOnly:true,
  349. defaultValue: new Date()
  350. },{
  351. xtype: 'textfield',
  352. name: 'pb_auditman',
  353. fieldLabel: '审核人',
  354. readOnly: true
  355. },{
  356. xtype: "datefield",
  357. name: "pb_auditdate",
  358. fieldLabel: "审核日期",
  359. readOnly: true
  360. }, {
  361. xtype: 'hidden',
  362. name: 'pb_text1',
  363. fieldLabel: '自定义字段1'
  364. }, {
  365. xtype: 'hidden',
  366. name: 'pb_text2',
  367. fieldLabel: '自定义字段2'
  368. }, {
  369. xtype: 'hidden',
  370. name: 'pb_text3',
  371. fieldLabel: '自定义字段3'
  372. }, {
  373. xtype: 'hidden',
  374. name: 'pb_text4',
  375. fieldLabel: '自定义字段4'
  376. }, {
  377. xtype: 'hidden',
  378. name: 'pb_text5',
  379. fieldLabel: '自定义字段5'
  380. }],
  381. beforeAudit: function() {
  382. var form = this,
  383. idField = form._idField,
  384. controller = form.getController(),
  385. viewModel = form.getViewModel(),
  386. id = viewModel.get(idField);
  387. store1 = viewModel.get('detail0').detailStore,
  388. store2 = viewModel.get('detail1').detailStore;
  389. // 已保存过的单据不进行此项校验
  390. if(id) {
  391. return true;
  392. }
  393. var sum_pd_amount = store1.sum('pd_amount'); // 付款金额合计
  394. var pb_discounts = viewModel.get('pb_discounts'); // 折扣金额
  395. var sum_pbd_nowbalance = store2.sum('pbd_nowbalance'); // 本次核销金额合计
  396. var flag = sum_pd_amount + pb_discounts - sum_pbd_nowbalance;
  397. viewModel.set("pb_preamount",flag);
  398. if(flag != 0) {
  399. var t = flag > 0 ? '大' : '小';
  400. saas.util.BaseUtil.showConfirm('提示', '付款金额' + t + '于本次折扣后核销金额,是否仍要保存并审核?')
  401. .then(function(y) {
  402. if(y == 'yes') {
  403. controller.audit();
  404. }
  405. });
  406. }else {
  407. controller.audit();
  408. }
  409. return false;
  410. }
  411. });