FormPanel.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418
  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. allowBlank : false,
  120. editor : {
  121. xtype : "numberfield",
  122. decimalPrecision: 2
  123. },
  124. renderer : function(v) {
  125. var arr = (v + '.').split('.');
  126. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  127. var format = '0,000.' + xr.join();
  128. return Ext.util.Format.number(v, format);
  129. },
  130. summaryType: 'sum',
  131. summaryRenderer: function(v) {
  132. var arr = (v + '.').split('.');
  133. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  134. var format = '0,000.' + xr.join();
  135. return Ext.util.Format.number(v, format);
  136. }
  137. }, {
  138. text: "结算方式",
  139. dataIndex: "pd_paymethod",
  140. width :200.0,
  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. width : 150.0,
  163. editor:{
  164. xtype:'textfield'
  165. }
  166. }, {
  167. text: "备注",
  168. dataIndex: "pd_remark",
  169. width: 250,
  170. editor:{
  171. xtype: 'textfield'
  172. }
  173. }]
  174. },{
  175. xtype: "detailGridField",
  176. storeModel: 'saas.model.money.PayBalance2',
  177. detnoColumn: 'pbd_detno',
  178. allowEmpty: true,
  179. deleteDetailUrl: '/api/money/paybalance/deleteDetail2',
  180. columns: [
  181. {
  182. text: 'ID',
  183. dataIndex: 'id',
  184. hidden: true
  185. }, {
  186. text: '期间',
  187. dataIndex: 'pbd_ym',
  188. hidden: true
  189. }, {
  190. text: '来源ID',
  191. dataIndex: 'pbd_slid',
  192. hidden: true
  193. }, {
  194. text: '来源单号',
  195. dataIndex: 'pbd_slcode',
  196. width : 150,
  197. editor:{
  198. displayField : "display",
  199. editable : true,
  200. format : "",
  201. hideTrigger : false,
  202. maxLength : 100.0,
  203. minValue : null,
  204. positiveNum : false,
  205. queryMode : "local",
  206. store : null,
  207. valueField : "value",
  208. xtype : "oriOrderMutiDbfindTrigger",
  209. listeners:{
  210. beforetriggerclick:'vendnamechange'
  211. }
  212. },
  213. }, {
  214. text: "业务类型",
  215. dataIndex: "pbd_slkind",
  216. width : 110
  217. }, {
  218. text: "单据日期",
  219. dataIndex: "pbd_sldate",
  220. xtype: 'datecolumn',
  221. width : 110
  222. }, {
  223. text: "单据金额",
  224. xtype: 'numbercolumn',
  225. dataIndex: "pbd_amount",
  226. width : 110,
  227. renderer : function(v) {
  228. var arr = (v + '.').split('.');
  229. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  230. var format = '0,000.' + xr.join();
  231. return Ext.util.Format.number(v, format);
  232. },
  233. summaryType: 'sum',
  234. summaryRenderer: function(v) {
  235. var arr = (v + '.').split('.');
  236. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  237. var format = '0,000.' + xr.join();
  238. return Ext.util.Format.number(v, format);
  239. }
  240. }, {
  241. text: "已核销金额",
  242. xtype: 'numbercolumn',
  243. dataIndex: "sl_yamount",
  244. width : 110,
  245. ignore:true,
  246. renderer : function(v) {
  247. var arr = (v + '.').split('.');
  248. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  249. var format = '0,000.' + xr.join();
  250. return Ext.util.Format.number(v, format);
  251. },
  252. summaryType: 'sum',
  253. summaryRenderer: function(v) {
  254. var arr = (v + '.').split('.');
  255. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  256. var format = '0,000.' + xr.join();
  257. return Ext.util.Format.number(v, format);
  258. }
  259. }, {
  260. text: "未核销金额",
  261. xtype: 'numbercolumn',
  262. dataIndex: "sl_namount",
  263. ignore:true,
  264. width : 110,
  265. renderer : function(v) {
  266. var arr = (v + '.').split('.');
  267. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  268. var format = '0,000.' + xr.join();
  269. return Ext.util.Format.number(v, format);
  270. },
  271. summaryType: 'sum',
  272. summaryRenderer: function(v) {
  273. var arr = (v + '.').split('.');
  274. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  275. var format = '0,000.' + xr.join();
  276. return Ext.util.Format.number(v, format);
  277. }
  278. }, {
  279. text: "本次核销金额",
  280. xtype: 'numbercolumn',
  281. dataIndex: "pbd_nowbalance",
  282. width: 140,
  283. editor : {
  284. xtype : "numberfield",
  285. decimalPrecision: 2
  286. },
  287. allowBlank : false,
  288. renderer : function(v) {
  289. var arr = (v + '.').split('.');
  290. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  291. var format = '0,000.' + xr.join();
  292. return Ext.util.Format.number(v, format);
  293. },
  294. summaryType: 'sum',
  295. summaryRenderer: function(v) {
  296. var arr = (v + '.').split('.');
  297. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  298. var format = '0,000.' + xr.join();
  299. return Ext.util.Format.number(v, format);
  300. }
  301. }, {
  302. text: '备注',
  303. dataIndex: 'pbd_remark',
  304. width: 250,
  305. hidden: true
  306. }]
  307. }, {
  308. xtype: 'textfield',
  309. name: 'pb_remark',
  310. columnWidth: 1,
  311. fieldLabel: '备注'
  312. }, {
  313. xtype : "hidden",
  314. name : "creatorId",
  315. fieldLabel : "录入人ID",
  316. readOnly:true
  317. },
  318. {
  319. xtype : "textfield",
  320. name : "creatorName",
  321. fieldLabel : "录入人",
  322. readOnly:true
  323. }, {
  324. xtype : "datefield",
  325. name : "createTime",
  326. fieldLabel : "录入日期",
  327. readOnly:true,
  328. defaultValue: new Date()
  329. },{
  330. xtype : "hidden",
  331. name : "updaterId",
  332. fieldLabel : "更新人ID",
  333. readOnly:true
  334. },{
  335. xtype : "hidden",
  336. name : "updaterName",
  337. fieldLabel : "更新人",
  338. readOnly:true
  339. }, {
  340. xtype : "hidden",
  341. name : "updateTime",
  342. fieldLabel : "更新日期",
  343. readOnly:true,
  344. defaultValue: new Date()
  345. },{
  346. xtype: 'textfield',
  347. name: 'pb_auditman',
  348. fieldLabel: '审核人',
  349. readOnly: true
  350. },{
  351. xtype: "datefield",
  352. name: "pb_auditdate",
  353. fieldLabel: "审核日期",
  354. readOnly: true
  355. }, {
  356. xtype: 'hidden',
  357. name: 'pb_text1',
  358. fieldLabel: '自定义字段1'
  359. }, {
  360. xtype: 'hidden',
  361. name: 'pb_text2',
  362. fieldLabel: '自定义字段2'
  363. }, {
  364. xtype: 'hidden',
  365. name: 'pb_text3',
  366. fieldLabel: '自定义字段3'
  367. }, {
  368. xtype: 'hidden',
  369. name: 'pb_text4',
  370. fieldLabel: '自定义字段4'
  371. }, {
  372. xtype: 'hidden',
  373. name: 'pb_text5',
  374. fieldLabel: '自定义字段5'
  375. }],
  376. beforeAudit: function() {
  377. var form = this,
  378. idField = form._idField,
  379. controller = form.getController(),
  380. viewModel = form.getViewModel(),
  381. id = viewModel.get(idField);
  382. store1 = viewModel.get('detail0').detailStore,
  383. store2 = viewModel.get('detail1').detailStore;
  384. // 已保存过的单据不进行此项校验
  385. if(id) {
  386. return true;
  387. }
  388. var sum_pd_amount = store1.sum('pd_amount'); // 付款金额合计
  389. var pb_discounts = viewModel.get('pb_discounts'); // 折扣金额
  390. var sum_pbd_nowbalance = store2.sum('pbd_nowbalance'); // 本次核销金额合计
  391. var flag = sum_pd_amount + pb_discounts - sum_pbd_nowbalance;
  392. viewModel.set("pb_preamount",flag);
  393. if(flag != 0) {
  394. var t = flag > 0 ? '大' : '小';
  395. saas.util.BaseUtil.showConfirm('提示', '付款金额' + t + '于本次折扣后核销金额,是否仍要保存并审核?')
  396. .then(function(y) {
  397. if(y == 'yes') {
  398. controller.audit();
  399. }
  400. });
  401. }else {
  402. controller.audit();
  403. }
  404. return false;
  405. }
  406. });