FormPanel.js 13 KB

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