FormPanel.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417
  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. width : 110.0
  98. }, {
  99. text: '结算账户ID',
  100. dataIndex: 'pd_bankid',
  101. hidden: true
  102. }, {
  103. text: '资金账户',
  104. dataIndex: 'pd_bankname',
  105. width : 200.0,
  106. allowBlank : false,
  107. editor:{
  108. xtype:'bandinfoDbfindTrigger'
  109. }
  110. },{
  111. text: '资金账户编号',
  112. dataIndex: 'pd_bankcode',
  113. hidden: true
  114. }, {
  115. text: "付款金额",
  116. xtype: 'numbercolumn',
  117. dataIndex: "pd_amount",
  118. width : 110.0,
  119. editor : {
  120. xtype : "numberfield",
  121. decimalPrecision: 2
  122. },
  123. renderer : function(v) {
  124. var arr = (v + '.').split('.');
  125. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  126. var format = '0,000.' + xr.join();
  127. return Ext.util.Format.number(v, format);
  128. },
  129. summaryType: 'sum',
  130. summaryRenderer: function(v) {
  131. var arr = (v + '.').split('.');
  132. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  133. var format = '0,000.' + xr.join();
  134. return Ext.util.Format.number(v, format);
  135. }
  136. }, {
  137. text: "结算方式",
  138. dataIndex: "pd_paymethod",
  139. width :200.0,
  140. editor : {
  141. xtype:'combo',
  142. queryMode: 'local',
  143. displayField: 'display',
  144. valueField: 'value',
  145. store:Ext.create('Ext.data.Store', {
  146. fields: ['value', 'display'],
  147. data : [
  148. {value:"信用卡", display:"信用卡"},
  149. {value:"支票", display:"支票"},
  150. {value:"汇票", display:"汇票"},
  151. {value:"现金", display:"现金"},
  152. {value:"银行转账", display:"银行转账"},
  153. {value:"支付宝转账", display:"支付宝转账"},
  154. {value:"微信转账", display:"微信转账"}
  155. ]
  156. })
  157. }
  158. }, {
  159. text: "结算号",
  160. dataIndex: "pd_paycode",
  161. width : 150.0,
  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. width : 150,
  196. editor:{
  197. displayField : "display",
  198. editable : true,
  199. format : "",
  200. hideTrigger : false,
  201. maxLength : 100.0,
  202. minValue : null,
  203. positiveNum : false,
  204. queryMode : "local",
  205. store : null,
  206. valueField : "value",
  207. xtype : "oriOrderMutiDbfindTrigger",
  208. listeners:{
  209. beforetriggerclick:'vendnamechange'
  210. }
  211. },
  212. }, {
  213. text: "业务类型",
  214. dataIndex: "pbd_slkind",
  215. width : 110
  216. }, {
  217. text: "单据日期",
  218. dataIndex: "pbd_sldate",
  219. xtype: 'datecolumn',
  220. width : 110
  221. }, {
  222. text: "单据金额",
  223. xtype: 'numbercolumn',
  224. dataIndex: "pbd_amount",
  225. width : 110,
  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. width : 110,
  244. ignore:true,
  245. renderer : function(v) {
  246. var arr = (v + '.').split('.');
  247. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  248. var format = '0,000.' + xr.join();
  249. return Ext.util.Format.number(v, format);
  250. },
  251. summaryType: 'sum',
  252. summaryRenderer: function(v) {
  253. var arr = (v + '.').split('.');
  254. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  255. var format = '0,000.' + xr.join();
  256. return Ext.util.Format.number(v, format);
  257. }
  258. }, {
  259. text: "未核销金额",
  260. xtype: 'numbercolumn',
  261. dataIndex: "sl_namount",
  262. ignore:true,
  263. width : 110,
  264. renderer : function(v) {
  265. var arr = (v + '.').split('.');
  266. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  267. var format = '0,000.' + xr.join();
  268. return Ext.util.Format.number(v, format);
  269. },
  270. summaryType: 'sum',
  271. summaryRenderer: function(v) {
  272. var arr = (v + '.').split('.');
  273. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  274. var format = '0,000.' + xr.join();
  275. return Ext.util.Format.number(v, format);
  276. }
  277. }, {
  278. text: "本次核销金额",
  279. xtype: 'numbercolumn',
  280. dataIndex: "pbd_nowbalance",
  281. width: 120,
  282. editor : {
  283. xtype : "numberfield",
  284. decimalPrecision: 2
  285. },
  286. allowBlank : false,
  287. renderer : function(v) {
  288. var arr = (v + '.').split('.');
  289. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  290. var format = '0,000.' + xr.join();
  291. return Ext.util.Format.number(v, format);
  292. },
  293. summaryType: 'sum',
  294. summaryRenderer: function(v) {
  295. var arr = (v + '.').split('.');
  296. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  297. var format = '0,000.' + xr.join();
  298. return Ext.util.Format.number(v, format);
  299. }
  300. }, {
  301. text: '备注',
  302. dataIndex: 'pbd_remark',
  303. width: 250,
  304. hidden: true
  305. }]
  306. }, {
  307. xtype: 'textfield',
  308. name: 'pb_remark',
  309. columnWidth: 1,
  310. fieldLabel: '备注'
  311. }, {
  312. xtype : "hidden",
  313. name : "creatorId",
  314. fieldLabel : "录入人ID",
  315. readOnly:true
  316. },
  317. {
  318. xtype : "textfield",
  319. name : "creatorName",
  320. fieldLabel : "录入人",
  321. readOnly:true
  322. }, {
  323. xtype : "datefield",
  324. name : "createTime",
  325. fieldLabel : "录入日期",
  326. readOnly:true,
  327. defaultValue: new Date()
  328. },{
  329. xtype : "hidden",
  330. name : "updaterId",
  331. fieldLabel : "更新人ID",
  332. readOnly:true
  333. },{
  334. xtype : "hidden",
  335. name : "updaterName",
  336. fieldLabel : "更新人",
  337. readOnly:true
  338. }, {
  339. xtype : "hidden",
  340. name : "updateTime",
  341. fieldLabel : "更新日期",
  342. readOnly:true,
  343. defaultValue: new Date()
  344. },{
  345. xtype: 'textfield',
  346. name: 'pb_auditman',
  347. fieldLabel: '审核人',
  348. readOnly: true
  349. },{
  350. xtype: "datefield",
  351. name: "pb_auditdate",
  352. fieldLabel: "审核日期",
  353. readOnly: true
  354. }, {
  355. xtype: 'hidden',
  356. name: 'pb_text1',
  357. fieldLabel: '自定义字段1'
  358. }, {
  359. xtype: 'hidden',
  360. name: 'pb_text2',
  361. fieldLabel: '自定义字段2'
  362. }, {
  363. xtype: 'hidden',
  364. name: 'pb_text3',
  365. fieldLabel: '自定义字段3'
  366. }, {
  367. xtype: 'hidden',
  368. name: 'pb_text4',
  369. fieldLabel: '自定义字段4'
  370. }, {
  371. xtype: 'hidden',
  372. name: 'pb_text5',
  373. fieldLabel: '自定义字段5'
  374. }],
  375. beforeAudit: function() {
  376. var form = this,
  377. idField = form._idField,
  378. controller = form.getController(),
  379. viewModel = form.getViewModel(),
  380. id = viewModel.get(idField);
  381. store1 = viewModel.get('detail0').detailStore,
  382. store2 = viewModel.get('detail1').detailStore;
  383. // 已保存过的单据不进行此项校验
  384. if(id) {
  385. return true;
  386. }
  387. var sum_pd_amount = store1.sum('pd_amount'); // 付款金额合计
  388. var pb_discounts = viewModel.get('pb_discounts'); // 折扣金额
  389. var sum_pbd_nowbalance = store2.sum('pbd_nowbalance'); // 本次核销金额合计
  390. var flag = sum_pd_amount + pb_discounts - sum_pbd_nowbalance;
  391. viewModel.set("pb_preamount",flag);
  392. if(flag != 0) {
  393. var t = flag > 0 ? '大' : '小';
  394. saas.util.BaseUtil.showConfirm('提示', '付款金额' + t + '于本次折扣后核销金额,是否仍要保存并审核?')
  395. .then(function(y) {
  396. if(y == 'yes') {
  397. controller.audit();
  398. }
  399. });
  400. }else {
  401. controller.audit();
  402. }
  403. return false;
  404. }
  405. });