VendorCheck.js 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. Ext.define('saas.view.money.report.VendorCheck', {
  2. extend: 'saas.view.core.report.ReportPanel',
  3. xtype: 'monry-report-vendorcheck',
  4. controller: 'money-report-vendorcheck',
  5. viewModel: 'money-report-vendorcheck',
  6. viewName: 'money-report-vendorcheck',
  7. // groupField: null,
  8. listUrl: '/api/money/report/vendorCheck',
  9. defaultCondition: null,
  10. reportTitle: '供应商对账单',
  11. QueryWidth:0.4,
  12. autoLoad:false,
  13. //筛选:供应商、日期(必填)
  14. searchItems: [ {
  15. xtype: 'vendorDbfindTrigger',
  16. name: 'pi_vendname',
  17. fieldLabel: '供应商名称',
  18. columnWidth: 0.2,
  19. allowBlank:false,
  20. listeners: {
  21. beforequery: function(f) {
  22. return !!f.value;
  23. }
  24. }
  25. }, {
  26. // xtype: 'monthdatefield',
  27. // name: 'ym',
  28. // fieldLabel: '期初日期',
  29. // columnWidth: 0.2
  30. // }, {
  31. xtype: 'condatefield',
  32. name: 'pi_date',
  33. fieldLabel: '单据日期',
  34. columnWidth: 0.4
  35. }],
  36. reportColumns: [{
  37. text: 'id',
  38. dataIndex: 'pi_id',
  39. hidden: true
  40. }, {
  41. text: '单据日期',
  42. dataIndex: 'pi_date',
  43. xtype:'datecolumn',
  44. width: 110
  45. }, {
  46. text: '单号',
  47. dataIndex: 'pi_inoutno',
  48. width: 150
  49. }, {
  50. text: '序号',
  51. xtype: 'numbercolumn',
  52. dataIndex: 'pd_pdno',
  53. exportFormat: 'Integer',
  54. width: 80
  55. },{
  56. text:'供应商编号',
  57. dataIndex:'pi_vendcode',
  58. width: 150,
  59. hidden:true
  60. },{
  61. text:'供应商名称',
  62. dataIndex:'pi_vendname',
  63. width: 250,
  64. hidden:true
  65. },{
  66. text: '物料编号',
  67. dataIndex: 'pr_code',
  68. width: 150
  69. }, {
  70. text: '物料名称',
  71. dataIndex: 'pr_detail',
  72. width: 200
  73. }, {
  74. text: '物料规格',
  75. dataIndex: 'pr_spec',
  76. width: 150
  77. }, {
  78. text: '单位',
  79. dataIndex: 'pd_unit',
  80. width: 80
  81. }, {
  82. text: '数量',
  83. dataIndex: 'qty',
  84. exportFormat: 'Quantity',
  85. xtype: 'numbercolumn',
  86. width: 110,
  87. renderer: function(v) {
  88. var arr = (v + '.').split('.');
  89. var xr = (new Array(arr[1].length > 3 ? 3 : arr[1].length)).fill('0');
  90. var format = '0.' + xr.join('');
  91. return Ext.util.Format.number(v, format);
  92. }
  93. }, {
  94. text: '单价(元)',
  95. dataIndex: 'pd_orderprice',
  96. exportFormat: 'Price',
  97. xtype: 'numbercolumn',
  98. width: 110,
  99. renderer: function(v) {
  100. var arr = (v + '.').split('.');
  101. var xr = (new Array(arr[1].length > 4 ? 4 : arr[1].length)).fill('0');
  102. var format = '0,000.' + xr.join('');
  103. return Ext.util.Format.number(v, format);
  104. }
  105. }, {
  106. text: '税率',
  107. dataIndex: 'pd_taxrate',
  108. exportFormat: 'Integer',
  109. xtype: 'numbercolumn',
  110. width: 80,
  111. renderer: function(v) {
  112. return Ext.util.Format.number(v, '0');
  113. }
  114. }, {
  115. text: '金额',
  116. xtype: 'numbercolumn',
  117. exportFormat: 'Amount',
  118. dataIndex: 'pd_total',
  119. width: 110,
  120. renderer : function(v) {
  121. var arr = (v + '.').split('.');
  122. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  123. var format = '0,000.' + xr.join('');
  124. return Ext.util.Format.number(v, format);
  125. },
  126. // summaryType: 'sum',
  127. // summaryRenderer: 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. }, {
  134. text: '不含税单价(元)',
  135. dataIndex: 'pd_netprice',
  136. exportFormat: 'Price',
  137. xtype: 'numbercolumn',
  138. width: 150,
  139. renderer: function(v) {
  140. var arr = (v + '.').split('.');
  141. var xr = (new Array(arr[1].length > 4 ? 4 : arr[1].length)).fill('0');
  142. var format = '0,000.' + xr.join('');
  143. return Ext.util.Format.number(v, format);
  144. }
  145. }, {
  146. text: '不含税金额',
  147. dataIndex: 'pd_nettotal',
  148. exportFormat: 'Amount',
  149. xtype: 'numbercolumn',
  150. width: 150,
  151. renderer : function(v) {
  152. var arr = (v + '.').split('.');
  153. var xr = (new Array(arr[1].length > 2 ? 2 : arr[1].length)).fill('0');
  154. var format = '0,000.' + xr.join('');
  155. return Ext.util.Format.number(v, format);
  156. },
  157. }, {
  158. text: '单据类型',
  159. dataIndex: 'pi_class',
  160. width: 110
  161. }, {
  162. text: '期初应付',
  163. dataIndex: 'beginamount',
  164. hidden: true,
  165. width: 0,
  166. summaryType: 'cus',
  167. }, {
  168. text: '增加应付',
  169. dataIndex: 'nowamount',
  170. hidden: true,
  171. width: 0,
  172. summaryType: 'cus',
  173. }, {
  174. text: '增加预付',
  175. dataIndex: 'nowpay',
  176. hidden: true,
  177. width: 0,
  178. summaryType: 'cus',
  179. }, {
  180. text: '应付余额',
  181. dataIndex: 'nowbalance',
  182. hidden: true,
  183. width: 0,
  184. summaryType: 'cus',
  185. }],
  186. listeners: {
  187. afterrender: function(panel) {
  188. panel.setLoadButtonDisabled(true);
  189. },
  190. },
  191. setLoadButtonDisabled: function (disabled) {
  192. var panel = this,
  193. grid = panel.down('grid'),
  194. p = grid.down('pagingtoolbar'),
  195. bs = p.query('button'),
  196. loadButton = Ext.Array.findBy(bs, function (b) {
  197. return b.iconCls == 'x-tbar-loading';
  198. });
  199. if (loadButton) {
  200. loadButton.setDisabled(disabled);
  201. }
  202. },
  203. applyParams: function(p) {
  204. var me = this,
  205. viewModel = me.getViewModel(),
  206. formData = viewModel.get('form'),
  207. ym = formData.ym;
  208. return Ext.Object.merge(p, {
  209. ym: ym
  210. });
  211. }
  212. });