FormPanel.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. Ext.define('saas.view.money.recBalance.FormPanel', {
  2. extend: 'saas.view.core.form.FormPanel',
  3. xtype: 'money-recbalance-formpanel',
  4. controller: 'money-recbalance-formpanel',
  5. viewModel: 'money-recbalance-formpanel',
  6. viewName: 'money-recbalance-formpanel',
  7. caller: 'RecBalance',
  8. //字段属性
  9. _title: '收款单',
  10. _idField: 'id',
  11. _codeField: 'rb_code',
  12. _statusField: 'rb_status',
  13. _statusCodeField: 'rb_statuscode',
  14. _auditmanField: 'rb_auditman',
  15. _auditdateField:'rb_auditdate',
  16. _readUrl: '/api/money/recbalance/read',
  17. _saveUrl: '/api/money/recbalance/save',
  18. _auditUrl: '/api/money/recbalance/audit',
  19. _unAuditUrl: '/api/money/recbalance/unAudit',
  20. _deleteUrl: '/api/money/recbalance/delete',
  21. initId: 0,
  22. defaultItems: [{
  23. xtype: 'hidden',
  24. name: 'id',
  25. fieldLabel: 'id'
  26. }, {
  27. xtype: 'hidden',
  28. name: 'rb_custid',
  29. fieldLabel: '客户ID'
  30. }, {
  31. xtype: 'textfield',
  32. name: 'rb_kind',
  33. fieldLabel: '单据类型',
  34. defaultValue: '收款单',
  35. readOnly: true
  36. }, {
  37. xtype: 'hidden',
  38. name: 'rb_custcode',
  39. fieldLabel: '客户编号'
  40. }, {
  41. xtype: "customerDbfindTrigger",
  42. name: "rb_custname",
  43. fieldLabel: "客户名称",
  44. allowBlank : false
  45. }, {
  46. xtype: "numberfield",
  47. name: "cu_leftamount",
  48. fieldLabel: "总欠款",
  49. ignore: true,
  50. readOnly: true
  51. }, {
  52. xtype: 'hidden',
  53. name: 'rb_rbdamount',
  54. fieldLabel: '本次核销金额'
  55. },{
  56. xtype: 'hidden',
  57. name: 'rb_rdamount',
  58. fieldLabel: '本次付款金额',
  59. }, {
  60. xtype: "datefield",
  61. name: "rb_date",
  62. fieldLabel: "日期",
  63. defaultValue: new Date(),
  64. allowBlank : false
  65. }, {
  66. xtype: "textfield",
  67. name: "rb_manname",
  68. fieldLabel: "收款人"
  69. }, {
  70. xtype: "numberfield",
  71. name: "rb_discounts",
  72. fieldLabel: "整单折扣",
  73. hidden: true
  74. }, {
  75. xtype: 'numberfield',
  76. name: 'rb_preamount',
  77. fieldLabel : '本次预收款',
  78. readOnly: true
  79. }, {
  80. xtype: 'hidden',
  81. name: 'rb_havebalance',
  82. fieldLabel: '已核销金额'
  83. }, {
  84. xtype: "detailGridField",
  85. storeModel: 'saas.model.money.RecBalance1',
  86. detnoColumn: 'rd_detno',
  87. deleteDetailUrl: '/api/money/recbalance/deleteDetail1',
  88. columns: [{
  89. text: 'ID',
  90. dataIndex: 'id',
  91. hidden: true
  92. }, {
  93. text: '期间',
  94. dataIndex: 'rd_ym',
  95. defaultValue: Ext.Date.format(new Date(), 'Ym'),
  96. width : 110,
  97. hidden: true
  98. }, {
  99. text: '资金账户ID',
  100. dataIndex: 'rd_bankid',
  101. editor: {
  102. xtype: 'numberfield'
  103. },
  104. hidden: true
  105. }, {
  106. text: '资金账户编号',
  107. dataIndex: 'rd_bankcode',
  108. editor: {
  109. xtype: 'textfield'
  110. },
  111. hidden: true
  112. }, {
  113. text: '资金账户',
  114. dataIndex: 'rd_bankname',
  115. allowBlank : false,
  116. width: 200,
  117. editor:{
  118. xtype:'bandinfoDbfindTrigger'
  119. }
  120. }, {
  121. text: "收款金额",
  122. xtype: 'numbercolumn',
  123. dataIndex: "rd_amount",
  124. width : 110.0,
  125. allowBlank : false,
  126. editor : {
  127. xtype : "numberfield",
  128. decimalPrecision: 2
  129. },
  130. renderer : 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. summaryType: 'sum',
  137. summaryRenderer: function(v) {
  138. var arr = (v + '.').split('.');
  139. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  140. var format = '0,000.' + xr.join();
  141. return Ext.util.Format.number(v, format);
  142. }
  143. }, {
  144. text: "结算方式",
  145. dataIndex: "rd_paymethod",
  146. width : 150.0,
  147. editor : {
  148. xtype:'combo',
  149. queryMode: 'local',
  150. displayField: 'display',
  151. valueField: 'value',
  152. store:Ext.create('Ext.data.Store', {
  153. fields: ['value', 'display'],
  154. data : [
  155. {value:"信用卡", display:"信用卡"},
  156. {value:"支票", display:"支票"},
  157. {value:"汇票", display:"汇票"},
  158. {value:"现金", display:"现金"},
  159. {value:"银行转账", display:"银行转账"},
  160. {value:"支付宝转账", display:"支付宝转账"},
  161. {value:"微信转账", display:"微信转账"}
  162. ]
  163. })
  164. }
  165. }, {
  166. text: "结算号",
  167. dataIndex: "rd_paycode",
  168. editor: {
  169. xtype: 'textfield'
  170. }
  171. }, {
  172. text: "备注",
  173. dataIndex: "rd_remark",
  174. width: 250,
  175. editor: {
  176. xtype: 'textfield'
  177. }
  178. }]
  179. },{
  180. xtype: "detailGridField",
  181. storeModel: 'saas.model.money.RecBalance2',
  182. detnoColumn: 'rbd_detno',
  183. allowEmpty: true,
  184. deleteDetailUrl: '/api/money/recbalance/deleteDetail2',
  185. columns: [{
  186. text: 'ID',
  187. dataIndex: 'id',
  188. hidden: true
  189. }, {
  190. text: '期间',
  191. dataIndex: 'rbd_ym',
  192. editor: {
  193. xtype: 'numberfield'
  194. },
  195. hidden: true
  196. }, {
  197. text: '来源ID',
  198. dataIndex: 'rbd_slid',
  199. editor: {
  200. xtype: 'numberfield'
  201. },
  202. hidden: true
  203. }, {
  204. text: '来源单号',
  205. dataIndex: 'rbd_slcode',
  206. width: 200,
  207. editor:{
  208. displayField : "display",
  209. editable : true,
  210. format : "",
  211. hideTrigger : false,
  212. maxLength : 100.0,
  213. minValue : null,
  214. positiveNum : false,
  215. queryMode : "local",
  216. store : null,
  217. valueField : "value",
  218. xtype : "oriOrderMutiDbfindTrigger",
  219. listeners:{
  220. beforetriggerclick:'custnamechange'
  221. }
  222. }
  223. }, {
  224. text: "业务类型",
  225. dataIndex: "rbd_slkind",
  226. width:110
  227. }, {
  228. text: "单据日期",
  229. dataIndex: "rbd_sldate",
  230. xtype: 'datecolumn',
  231. width:110
  232. }, {
  233. text: "单据金额",
  234. xtype: 'numbercolumn',
  235. dataIndex: "rbd_amount",
  236. width:110,
  237. renderer : 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. summaryType: 'sum',
  244. summaryRenderer: function(v) {
  245. var arr = (v + '.').split('.');
  246. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  247. var format = '0,000.' + xr.join();
  248. return Ext.util.Format.number(v, format);
  249. }
  250. }, {
  251. text: "已核销金额",
  252. xtype: 'numbercolumn',
  253. dataIndex: "sl_yamount",
  254. width:110,
  255. ignore:true,
  256. renderer : 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. summaryType: 'sum',
  263. summaryRenderer: function(v) {
  264. var arr = (v + '.').split('.');
  265. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  266. var format = '0,000.' + xr.join();
  267. return Ext.util.Format.number(v, format);
  268. }
  269. }, {
  270. text: "未核销金额",
  271. xtype: 'numbercolumn',
  272. dataIndex: "sl_namount",
  273. width:110,
  274. ignore:true,
  275. renderer : 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. summaryType: 'sum',
  282. summaryRenderer: function(v) {
  283. var arr = (v + '.').split('.');
  284. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  285. var format = '0,000.' + xr.join();
  286. return Ext.util.Format.number(v, format);
  287. }
  288. }, {
  289. text: "本次核销金额",
  290. xtype: 'numbercolumn',
  291. dataIndex: "rbd_nowbalance",
  292. width:140,
  293. editor : {
  294. xtype : "numberfield",
  295. decimalPrecision: 2
  296. },
  297. allowBlank : false,
  298. renderer : 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. summaryType: 'sum',
  305. summaryRenderer: function(v) {
  306. var arr = (v + '.').split('.');
  307. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  308. var format = '0,000.' + xr.join();
  309. return Ext.util.Format.number(v, format);
  310. }
  311. }]
  312. }, {
  313. xtype: 'textfield',
  314. name: 'rb_remark',
  315. fieldLabel: '备注',
  316. columnWidth: 1
  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: 'rb_auditman',
  353. fieldLabel: '审核人',
  354. readOnly: true
  355. },{
  356. xtype: "datefield",
  357. name: "rb_auditdate",
  358. fieldLabel: "审核日期",
  359. readOnly: true
  360. }],
  361. beforeAudit: function() {
  362. var form = this,
  363. idField = form._idField,
  364. controller = form.getController(),
  365. viewModel = form.getViewModel(),
  366. id = viewModel.get(idField);
  367. store1 = viewModel.get('detail0').detailStore,
  368. store2 = viewModel.get('detail1').detailStore;
  369. // 已保存过的单据不进行此项校验
  370. if(id) {
  371. return true;
  372. }
  373. var sum_rd_amount = store1.sum('rd_amount'); // 付款金额合计
  374. var rb_discounts = viewModel.get('rb_discounts'); // 折扣金额
  375. var sum_rbd_nowbalance = store2.sum('rbd_nowbalance'); // 本次核销金额合计
  376. var flag = sum_rd_amount + rb_discounts - sum_rbd_nowbalance;
  377. viewModel.set("rb_preamount",flag);
  378. if(flag != 0) {
  379. var t = flag > 0 ? '大' : '小';
  380. saas.util.BaseUtil.showConfirm('提示', '付款金额' + t + '于本次折扣后核销金额,是否仍要保存并审核?')
  381. .then(function(y) {
  382. if(y == 'yes') {
  383. controller.audit();
  384. }
  385. });
  386. }else {
  387. controller.audit();
  388. }
  389. return false;
  390. }
  391. });