FormPanel.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594
  1. Ext.define('saas.view.money.verification.FormPanel', {
  2. extend: 'saas.view.core.form.FormPanel',
  3. // extend: 'Ext.panel.Panel',
  4. xtype: 'money-verification-formpanel',
  5. controller: 'money-verification-formpanel',
  6. viewModel: 'money-verification-formpanel',
  7. viewName: 'money-verification-formpanel',
  8. caller: 'Verification',
  9. //字段属性
  10. _title: '核销单',
  11. _idField: 'id',
  12. _codeField: 'vc_code',
  13. _statusField: 'vc_status',
  14. _statusCodeField: 'vc_statuscode',
  15. _readUrl: '/api/money/verification/read/',
  16. _saveUrl: '/api/money/verification/save/',
  17. _auditUrl: '/api/money/verification/audit/',
  18. _unAuditUrl: '/api/money/verification/unAudit/',
  19. _deleteUrl: '/api/money/verification/delete/',
  20. defatulType: 'receipts_offset_receivable',
  21. etc: {
  22. /**
  23. * 预收:receipts
  24. * 预付:prepaid
  25. * 应收:receivable
  26. * 应付:payable
  27. */
  28. // base
  29. base: [{
  30. xtype: 'combo',
  31. name: 'vc_kind',
  32. fieldLabel: '业务类型',
  33. editable: false,
  34. store: [
  35. ['receipts_offset_receivable', '预收冲应收'],
  36. ['prepaid_offset_payable', '预付冲应付'],
  37. ['receivable_offset_payable', '应收冲应付'],
  38. ['receivable_to_receivable', '应收转应收'],
  39. ['payable_to_payable', '应付转应付']
  40. ],
  41. listeners:{
  42. beforerender:function(f){
  43. f.firstLoad=true;
  44. },
  45. change:function(f){
  46. if(f.bindError){
  47. f.setValue(f.defaultValue);
  48. f.bindError = false
  49. }
  50. }
  51. }
  52. }],
  53. detail1: {
  54. xtype: "detailGridField",
  55. storeModel: 'saas.model.money.Verification1',
  56. detnoColumn: 'vd_detno',
  57. deleteDetailUrl: '/api/money/verification/deleteDetail1/',
  58. columnWidth: 1,
  59. columns: [{
  60. text: 'ID',
  61. dataIndex: 'id',
  62. hidden: true
  63. }, {
  64. text: '来源ID',
  65. dataIndex: 'vd_slid',
  66. hidden: true
  67. }, {
  68. text: '来源单号',
  69. dataIndex: 'vd_slcode',
  70. width: 150,
  71. editor:{
  72. displayField : "display",
  73. editable : true,
  74. format : "",
  75. hideTrigger : false,
  76. maxLength : 100.0,
  77. minValue : null,
  78. positiveNum : false,
  79. queryMode : "local",
  80. store : null,
  81. valueField : "value",
  82. xtype : "oriOrderMutiDbfindTrigger"
  83. }
  84. }, {
  85. text: '业务类型',
  86. dataIndex: "vd_slkind",
  87. width: 110
  88. }, {
  89. text: "单据日期",
  90. dataIndex: "vd_sldate",
  91. xtype: 'datecolumn',
  92. width: 110
  93. }, {
  94. text: "单据金额",
  95. xtype: 'numbercolumn',
  96. dataIndex: "vd_amount",
  97. width: 110,
  98. renderer : function(v) {
  99. var arr = (v + '.').split('.');
  100. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  101. var format = '0,000.' + xr.join();
  102. return Ext.util.Format.number(v, format);
  103. },
  104. summaryType: 'sum',
  105. summaryRenderer: function(v) {
  106. var arr = (v + '.').split('.');
  107. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  108. var format = '0,000.' + xr.join();
  109. return Ext.util.Format.number(v, format);
  110. }
  111. }, {
  112. text: "已核销金额",
  113. xtype: 'numbercolumn',
  114. dataIndex: "sl_yamount",
  115. width: 110,
  116. ignore:true,
  117. renderer : function(v) {
  118. var arr = (v + '.').split('.');
  119. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  120. var format = '0,000.' + xr.join();
  121. return Ext.util.Format.number(v, format);
  122. },
  123. summaryType: 'sum',
  124. summaryRenderer: 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. }, {
  131. text: "未核销金额",
  132. xtype: 'numbercolumn',
  133. dataIndex: "sl_namount",
  134. width: 110,
  135. ignore:true,
  136. renderer : function(v) {
  137. var arr = (v + '.').split('.');
  138. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  139. var format = '0,000.' + xr.join();
  140. return Ext.util.Format.number(v, format);
  141. },
  142. summaryType: 'sum',
  143. summaryRenderer: function(v) {
  144. var arr = (v + '.').split('.');
  145. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  146. var format = '0,000.' + xr.join();
  147. return Ext.util.Format.number(v, format);
  148. }
  149. }, {
  150. text: "本次核销金额",
  151. xtype: 'numbercolumn',
  152. dataIndex: "vd_nowbalance",
  153. width: 150,
  154. editor : {
  155. xtype : "numberfield",
  156. decimalPrecision: 2
  157. },
  158. allowBlank : false,
  159. renderer : function(v) {
  160. var arr = (v + '.').split('.');
  161. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  162. var format = '0,000.' + xr.join();
  163. return Ext.util.Format.number(v, format);
  164. },
  165. summaryType: 'sum',
  166. summaryRenderer: function(v) {
  167. var arr = (v + '.').split('.');
  168. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  169. var format = '0,000.' + xr.join();
  170. return Ext.util.Format.number(v, format);
  171. }
  172. }]
  173. },
  174. detail2: {
  175. xtype: "detailGridField",
  176. storeModel: 'saas.model.money.Verification1',
  177. detnoColumn: 'vcd_detno',
  178. deleteDetailUrl: '/api/money/verification/deleteDetail2/',
  179. columnWidth: 1,
  180. columns: [{
  181. text: 'ID',
  182. dataIndex: 'id',
  183. hidden: true
  184. }, {
  185. text: '来源ID',
  186. dataIndex: 'vcd_slid',
  187. hidden: true
  188. }, {
  189. text: '来源单号',
  190. dataIndex: 'vcd_slcode',
  191. width: 150,
  192. editor:{
  193. displayField : "display",
  194. editable : true,
  195. format : "",
  196. hideTrigger : false,
  197. maxLength : 100.0,
  198. minValue : null,
  199. positiveNum : false,
  200. queryMode : "local",
  201. store : null,
  202. valueField : "value",
  203. xtype : "oriOrderMutiDbfindTrigger"
  204. }
  205. }, {
  206. text: '业务类型',
  207. dataIndex: "vcd_slkind",
  208. width: 110
  209. }, {
  210. text: "单据日期",
  211. dataIndex: "vcd_sldate",
  212. xtype: 'datecolumn',
  213. width: 110
  214. }, {
  215. text: "单据金额",
  216. xtype: 'numbercolumn',
  217. dataIndex: "vcd_amount",
  218. width: 110,
  219. renderer : function(v) {
  220. var arr = (v + '.').split('.');
  221. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  222. var format = '0,000.' + xr.join();
  223. return Ext.util.Format.number(v, format);
  224. },
  225. summaryType: 'sum',
  226. summaryRenderer: 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. }, {
  233. text: "已核销金额",
  234. xtype: 'numbercolumn',
  235. dataIndex: "sl_yamount",
  236. width: 110,
  237. ignore:true,
  238. renderer : function(v) {
  239. var arr = (v + '.').split('.');
  240. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  241. var format = '0,000.' + xr.join();
  242. return Ext.util.Format.number(v, format);
  243. },
  244. summaryType: 'sum',
  245. summaryRenderer: 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. }, {
  252. text: "未核销金额",
  253. xtype: 'numbercolumn',
  254. dataIndex: "sl_namount",
  255. width: 110,
  256. ignore:true,
  257. renderer : function(v) {
  258. var arr = (v + '.').split('.');
  259. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  260. var format = '0,000.' + xr.join();
  261. return Ext.util.Format.number(v, format);
  262. },
  263. summaryType: 'sum',
  264. summaryRenderer: 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. }, {
  271. text: "本次核销金额",
  272. dataIndex: "vcd_nowbalance",
  273. xtype: 'numbercolumn',
  274. editor : {
  275. xtype : "numberfield",
  276. decimalPrecision: 2
  277. },
  278. width: 110,
  279. renderer : function(v) {
  280. var arr = (v + '.').split('.');
  281. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  282. var format = '0,000.' + xr.join();
  283. return Ext.util.Format.number(v, format);
  284. },
  285. summaryType: 'sum',
  286. summaryRenderer: function(v) {
  287. var arr = (v + '.').split('.');
  288. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  289. var format = '0,000.' + xr.join();
  290. return Ext.util.Format.number(v, format);
  291. }
  292. }]
  293. },
  294. other: [{
  295. fieldLabel: '备注',
  296. xtype: 'textfield',
  297. columnWidth: 1,
  298. name: 'vc_remark'
  299. }],
  300. // 预收冲应收
  301. receipts_offset_receivable : {
  302. main: [{
  303. xtype: 'hidden',
  304. fieldLabel: '客户名称',
  305. name: 'vc_custid',
  306. allowBlank : false,
  307. listeners: {
  308. change: 'clearDetails'
  309. }
  310. }, {
  311. fieldLabel: '客户编号',
  312. xtype: 'hidden',
  313. name: 'vc_custcode',
  314. }, {
  315. fieldLabel: '客户名称',
  316. xtype: 'customerDbfindTrigger',
  317. name: 'vc_custname',
  318. }, {
  319. fieldLabel: '日期',
  320. xtype: 'datefield',
  321. defaultValue: new Date(),
  322. allowBlank : false,
  323. name: 'vc_date'
  324. }, {
  325. xtype: 'hidden',
  326. name: 'vc_amount1',
  327. fieldLabel: '核销金额'
  328. }, {
  329. xtype: "hidden",
  330. name: "vc_amount2",
  331. fieldLabel: "未核销金额"
  332. },],
  333. details: ['detail1', 'detail2']
  334. },
  335. // 预付冲应付
  336. prepaid_offset_payable: {
  337. main: [{
  338. xtype: 'hidden',
  339. name: 'vc_vendid',
  340. fieldLabel: '供应商名称',
  341. allowBlank : false,
  342. listeners: {
  343. change: 'clearDetails'
  344. }
  345. }, {
  346. xtype: "hidden",
  347. name: "vc_vendcode",
  348. fieldLabel: "供应商编号"
  349. }, {
  350. xtype: "vendorDbfindTrigger",
  351. name: "vc_vendname",
  352. fieldLabel: "供应商名称",
  353. allowBlank : false
  354. }, {
  355. fieldLabel: '日期',
  356. xtype: 'datefield',
  357. defaultValue: new Date(),
  358. allowBlank : false,
  359. name: 'vc_date'
  360. }],
  361. details: ['detail1', 'detail2']
  362. },
  363. // 应收冲应付
  364. receivable_offset_payable: {
  365. main: [{
  366. fieldLabel: '客户名称',
  367. xtype: 'textfield',
  368. name: 'vc_custid',
  369. hidden: true,
  370. listeners: {
  371. change: 'clearDetail0'
  372. }
  373. }, {
  374. fieldLabel: '客户编号',
  375. xtype: 'textfield',
  376. name: 'vc_custcode',
  377. hidden: true
  378. }, {
  379. fieldLabel: '客户名称',
  380. xtype: 'customerDbfindTrigger',
  381. name: 'vc_custname'
  382. }, {
  383. xtype: 'hidden',
  384. name: 'vc_vendid',
  385. fieldLabel: '供应商ID',
  386. listeners: {
  387. change: 'clearDetail1'
  388. }
  389. }, {
  390. xtype: "hidden",
  391. name: "vc_vendcode",
  392. fieldLabel: "供应商编号"
  393. }, {
  394. xtype: "vendorDbfindTrigger",
  395. name: "vc_vendname",
  396. fieldLabel: "供应商名称",
  397. allowBlank : false
  398. }, {
  399. fieldLabel: '日期',
  400. xtype: 'datefield',
  401. defaultValue: new Date(),
  402. allowBlank : false,
  403. name: 'vc_date'
  404. }],
  405. details: ['detail1', 'detail2']
  406. },
  407. // 应收转应收
  408. receivable_to_receivable: {
  409. main: [{
  410. fieldLabel: '转出客户',
  411. xtype: 'textfield',
  412. name: 'vc_outcustid',
  413. hidden: true,
  414. listeners: {
  415. change: 'clearDetail0'
  416. }
  417. }, {
  418. fieldLabel: '转出客户编号',
  419. xtype: 'textfield',
  420. name: 'vc_outcustcode',
  421. hidden: true
  422. }, {
  423. fieldLabel: '转出客户',
  424. xtype: 'customerDbfindTrigger',
  425. name: 'vc_outcustname'
  426. }, {
  427. fieldLabel: '转入客户id',
  428. xtype: 'textfield',
  429. name: 'vc_turncustid',
  430. hidden: true
  431. }, {
  432. fieldLabel: '转入客户编号',
  433. xtype: 'textfield',
  434. name: 'vc_turncustcode',
  435. hidden: true
  436. }, {
  437. fieldLabel: '转入客户',
  438. xtype: 'customerDbfindTrigger',
  439. name: 'vc_turncustname',
  440. }, {
  441. fieldLabel: '日期',
  442. xtype: 'datefield',
  443. defaultValue: new Date(),
  444. allowBlank : false,
  445. name: 'vc_date'
  446. }],
  447. details: ['detail1']
  448. },
  449. // 应付转应付
  450. payable_to_payable: {
  451. main: [{
  452. fieldLabel: '转出供应商',
  453. xtype: 'textfield',
  454. name: 'vc_outvendid',
  455. hidden: true,
  456. listeners: {
  457. change: 'clearDetail0'
  458. }
  459. }, {
  460. fieldLabel: '转出供应商编号',
  461. xtype: 'textfield',
  462. name: 'vc_outvendcode',
  463. hidden: true
  464. }, {
  465. fieldLabel: '转出供应商',
  466. xtype: 'vendorDbfindTrigger',
  467. name: 'vc_outvendname'
  468. }, {
  469. fieldLabel: '转入供应商id',
  470. xtype: 'textfield',
  471. name: 'vc_turnvendid',
  472. hidden: true
  473. }, {
  474. fieldLabel: '转入供应商编号',
  475. xtype: 'textfield',
  476. name: 'vc_turnvendcode',
  477. hidden: true
  478. }, {
  479. fieldLabel: '转入供应商',
  480. xtype: 'vendorDbfindTrigger',
  481. name: 'vc_turnvendname',
  482. }, {
  483. fieldLabel: '日期',
  484. xtype: 'datefield',
  485. defaultValue: new Date(),
  486. allowBlank : false,
  487. name: 'vc_date'
  488. }],
  489. details: ['detail1']
  490. },
  491. defaultConditions: {
  492. receipts_offset_receivable: ['ifnull(sl_custid,0)={vc_custid} and ifnull(sl_preamount,0)<>0 and ifnull(sl_namount,0)<>0',
  493. 'ifnull(sl_custid,0)={vc_custid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0 and sl_kind in (\'期初余额\',\'出货单\',\'销售退货单\')'],
  494. prepaid_offset_payable: ['ifnull(sl_vendid,0)={vc_vendid} and ifnull(sl_preamount,0)<>0 and ifnull(sl_namount,0)<>0',
  495. 'ifnull(sl_vendid,0)={vc_vendid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0'],
  496. receivable_offset_payable: ['ifnull(sl_custid,0)={vc_custid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0',
  497. 'ifnull(sl_vendid,0)={vc_vendid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0'],
  498. receivable_to_receivable: ['ifnull(sl_custid,0)={vc_outcustid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0'],
  499. payable_to_payable: ['ifnull(sl_vendtid,0)={vc_outvendid} and ifnull(sl_preamount,0)=0 and ifnull(sl_namount,0)<>0']
  500. }
  501. },
  502. // initComponent: function() {
  503. // this.callParent(arguments);
  504. // },
  505. initFormItems: function() {
  506. var me = this,
  507. cusItems = me.cusItems,
  508. defaultItems = me.getAcitveItems(),
  509. FormUtil = saas.util.FormUtil;
  510. me.detailCount = 0;
  511. if(cusItems) {
  512. var items = defaultItems || [];
  513. Ext.Array.each(cusItems, function(cusItem) {
  514. var item = items.find(function(item) {
  515. return item.name == cusItem.name;
  516. });
  517. Ext.apply(item, cusItem);
  518. });
  519. items = FormUtil.applyDefaultItems(me, items);
  520. me.removeAll();
  521. me.addItems(items);
  522. FormUtil.loadData(me);
  523. }else {
  524. FormUtil.applyCusItemConfig(me)
  525. .then(function(res) {
  526. if(res.success) {
  527. var config = res.data || true, items = defaultItems || [];
  528. if(config) {
  529. cusItems = config.items || [];
  530. me.cusItems = cusItems;
  531. Ext.Array.each(cusItems, function(cusItem) {
  532. var item = items.find(function(item) {
  533. return item.name == cusItem.name;
  534. });
  535. Ext.apply(item, cusItem);
  536. });
  537. items = FormUtil.applyDefaultItems(me, items);
  538. }
  539. me.removeAll();
  540. return me.addItems(items);
  541. }
  542. })
  543. .then(function(items) {
  544. me.fireEvent('afterSetItems', me, items);
  545. })
  546. .then(function() {
  547. FormUtil.loadData(me);
  548. })
  549. .catch(function(response) {
  550. saas.util.BaseUtil.showToast('错误:' + response.message);
  551. console.error(response);
  552. });
  553. }
  554. },
  555. getAcitveItems: function() {
  556. var me = this,
  557. acitveType = me.acitveType || me.defatulType,
  558. etc = me.etc,
  559. acitveEtc = etc[acitveType],
  560. mainItems = acitveEtc.main,
  561. details = acitveEtc.details,
  562. base = etc.base,
  563. detail1 = etc.detail1,
  564. detail2 = etc.detail2,
  565. other = etc.other,
  566. items = [];
  567. base[0].defaultValue = acitveType;
  568. items = Ext.Array.merge(base, mainItems, (details[0] ? [detail1] : []), (details[1] ? [detail2] : []), other );
  569. return items;
  570. },
  571. });