FormPanel.js 13 KB

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