ProcessGrid.js 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. Ext.define('erp.view.crm.chance.ProcessGrid',{
  2. extend: 'Ext.grid.Panel',
  3. alias: 'widget.processgrid',
  4. layout: 'fit',
  5. id:'processgrid',
  6. hideBorders: true,
  7. store: [],
  8. columns: [],
  9. columnLines:true,
  10. autoScroll:true,
  11. viewConfig: {
  12. stripeRows: true
  13. },
  14. initComponent : function(){
  15. var me=this,param=new Object();
  16. param.condition='1=1';
  17. me.getGridColumnsAndStore(this, 'crm/business/getProcessInfoByCondition.action', param, 1)
  18. me.callParent(arguments);
  19. },
  20. getGridColumnsAndStore: function(grid, url, param, no){
  21. var me = this;
  22. grid.setLoading(true);
  23. Ext.Ajax.request({//拿到grid的columns
  24. url : basePath + url,
  25. params: param,
  26. async: (grid.sync ? false : true),
  27. method : 'get',
  28. callback : function(options,success,response){
  29. grid.setLoading(false);
  30. if (!response) return;
  31. var res = new Ext.decode(response.responseText);
  32. if(res.exceptionInfo){
  33. showError(res.exceptionInfo);return;
  34. }
  35. if(res.columns){
  36. grid.stages=res.stages;
  37. var limits = res.limits, limitArr = new Array();
  38. if(limits != null && limits.length > 0) {//权限外字段
  39. limitArr = Ext.Array.pluck(limits, 'lf_field');
  40. }
  41. Ext.each(res.columns, function(column, y){
  42. // column有取别名
  43. if(column.dataIndex.indexOf(' ') > -1) {
  44. column.dataIndex = column.dataIndex.split(' ')[1];
  45. }
  46. //power
  47. if(limitArr.length > 0 && Ext.Array.contains(limitArr, column.dataIndex)) {
  48. column.hidden = true;
  49. }
  50. if(column.logic=='process'){
  51. column.renderer=function(val,meta,record){
  52. var rendercolor=val?me.getStageColor(grid,column.text):'';
  53. meta.tdCls='x-grid-cell-process';
  54. var detno=column.dataIndex.substring(6);
  55. return '<div style="width: 100%; height:16px; margin:5px 0px 5px 0px;font-family: Verdana,sans-serif;padding-top:3px;padding-left:2px; font-size: 11px;vertical-align: top; background-color: #'+rendercolor+'; line-height: 10px; color:white; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;">'+val+'</div>';
  56. }
  57. }
  58. me.setLogicType(grid, column, {
  59. headerColor: res.necessaryFieldColor
  60. });
  61. });
  62. //data
  63. var data = [];
  64. if(!res.data || res.data.length == 2){
  65. if (grid.buffered) {
  66. me.add10EmptyData(grid.detno, data);
  67. me.add10EmptyData(grid.detno, data);//添加20条空白数据
  68. } else {
  69. grid.on('reconfigure', function(){// 改为Grid加载后再添加空行,节约200~700ms
  70. me.add10EmptyItems(grid, 40, false);
  71. });
  72. }
  73. } else {
  74. data = Ext.decode(res.data.replace(/,}/g, '}').replace(/,]/g, ']'));
  75. }
  76. //store
  77. var store = me.setStore(grid, res.fields, data, grid.groupField, grid.necessaryField);
  78. if(grid.selModel && grid.selModel.views == null){
  79. grid.selModel.views = [];
  80. }
  81. //dbfind
  82. if(res.dbfinds && res.dbfinds.length > 0){
  83. grid.dbfinds = res.dbfinds;
  84. }
  85. console.log(res.columns);
  86. //reconfigure
  87. if(grid.sync) {//同步加载的Grid
  88. grid.reconfigure(store, res.columns);
  89. grid.on('afterrender', function(){
  90. me.setToolbar(grid, grid.columns, grid.necessaryField, limitArr);
  91. });
  92. } else {
  93. grid.reconfigure(store, res.columns);
  94. }
  95. if(grid.buffered) {//缓冲数据的Grid
  96. grid.verticalScroller = Ext.create('Ext.grid.PagingScroller', {
  97. activePrefetch: false,
  98. store: store
  99. });
  100. store.guaranteeRange(0, Math.min(store.pageSize, store.prefetchData.length) - 1);
  101. }
  102. var form = Ext.ComponentQuery.query('form');
  103. if(form && form.length > 0){
  104. grid.readOnly = form[0].readOnly;//grid不可编辑
  105. }
  106. }
  107. }
  108. });
  109. },
  110. setRenderer: function(grid, column){
  111. if(!column.haveRendered && column.renderer != null && column.renderer != ""){
  112. if(!grid.RenderUtil){
  113. grid.RenderUtil = Ext.create('erp.util.RenderUtil');
  114. }
  115. var renderName = column.renderer;
  116. if(contains(column.renderer, ':', true)){
  117. var args = new Array();
  118. Ext.each(column.renderer.split(':'), function(a, index){
  119. if(index == 0){
  120. renderName = a;
  121. } else {
  122. args.push(a);
  123. }
  124. });
  125. if(!grid.RenderUtil.args[renderName]){
  126. grid.RenderUtil.args[renderName] = new Object();
  127. }
  128. grid.RenderUtil.args[renderName][column.dataIndex] = args;
  129. }
  130. column.renderer = grid.RenderUtil[renderName];
  131. column.haveRendered = true;
  132. }
  133. },
  134. setLogicType: function(grid, column, headerCss){
  135. var logic = column.logic;
  136. if(logic != null){
  137. if(logic == 'detno'){
  138. grid.detno = column.dataIndex;
  139. column.width = 40;
  140. column.align = 'center';
  141. column.renderer = function(val, meta) {
  142. meta.tdCls = Ext.baseCSSPrefix + 'grid-cell-special';
  143. return val;
  144. };
  145. } else if(logic == 'keyField'){
  146. grid.keyField = column.dataIndex;
  147. } else if(logic == 'mainField'){
  148. grid.mainField = column.dataIndex;
  149. }else if(logic == 'orNecessField'){
  150. if(!grid.orNecessField){
  151. grid.orNecessField = new Array();
  152. }
  153. grid.orNecessField.push(column.dataIndex);
  154. }else if(logic == 'necessaryField'){
  155. grid.necessaryField = column.dataIndex;
  156. if(!grid.necessaryFields){
  157. grid.necessaryFields = new Array();
  158. }
  159. grid.necessaryFields.push(column.dataIndex);
  160. if(!column.haveRendered){
  161. column.renderer = function(val, meta, record, x, y, store, view){
  162. var c = this.columns[y];
  163. if(val != null && val.toString().trim() != ''){
  164. if(c.xtype == 'datecolumn' && typeof val === 'object'){
  165. val = Ext.Date.format(val, 'Y-m-d');
  166. } else if(c.xtype == 'numbercolumn') {
  167. val = Ext.util.Format.number(val, c.format || '0,000.00');
  168. }
  169. return val;
  170. } else {
  171. if(c.xtype == 'datecolumn'){
  172. val = '';
  173. }
  174. return '<img src="' + basePath + 'resource/images/icon/need.png" title="必填字段">' +
  175. '<span style="color:blue;padding-left:2px;" title="必填字段">' + val + '</span>';
  176. }
  177. };
  178. }
  179. if(headerCss.headerColor)
  180. column.style = 'color:#' + headerCss.headerColor;
  181. } else if(logic == 'groupField'){
  182. grid.groupField = column.dataIndex;
  183. }
  184. }
  185. },
  186. setStore: function(grid, fields, data, groupField, necessaryField){
  187. Ext.each(fields, function(f){
  188. if(f.name.indexOf(' ') > -1) {// column有取别名
  189. f.name = f.name.split(' ')[1];
  190. }
  191. if(!Ext.isChrome){
  192. if(f.type == 'date'){
  193. f.dateFormat = 'Y-m-d H:m:s';
  194. }
  195. }
  196. });
  197. var modelName = 'ext-model-' + grid.id;
  198. Ext.define(modelName, {
  199. extend: 'Ext.data.Model',
  200. fields: fields
  201. });
  202. var config = {
  203. model: modelName,
  204. groupField: groupField,
  205. getSum: function(records, field) {
  206. if (arguments.length < 2) {
  207. return 0;
  208. }
  209. var total = 0,
  210. i = 0,
  211. len = records.length;
  212. if(necessaryField) {
  213. for (; i < len; ++i) {//重写getSum,grid在合计时,只合计填写了必要信息的行
  214. var necessary = records[i].get(necessaryField);
  215. if(necessary != null && necessary != ''){
  216. total += records[i].get(field);
  217. }
  218. }
  219. } else {
  220. for (; i < len; ++i) {
  221. total += records[i].get(field);
  222. }
  223. }
  224. return total;
  225. },
  226. getCount: function() {
  227. if(necessaryField) {
  228. var count = 0;
  229. Ext.each(this.data.items, function(item){//重写getCount,grid在合计时,只合计填写了必要信息的行
  230. if(item.data[necessaryField] != null && item.data[necessaryField] != ''){
  231. count++;
  232. }
  233. });
  234. return count;
  235. }
  236. return this.data.items.length;
  237. }
  238. };
  239. if(grid.buffered) {//grid数据缓存
  240. config.buffered = true;
  241. config.pageSize = 200;
  242. config.purgePageCount = 0;
  243. config.proxy = {
  244. type: 'memory'
  245. };
  246. } else {
  247. config.data = data;
  248. }
  249. var store = Ext.create('Ext.data.Store', config);
  250. store.each(function(item, x){
  251. item.index = x;
  252. });
  253. if(grid.buffered) {
  254. var ln = data.length, records = [], i = 0;
  255. for (; i < ln; i++) {
  256. records.push(Ext.create(modelName, data[i]));
  257. }
  258. store.cacheRecords(records);
  259. }
  260. return store;
  261. },
  262. getStageColor:function(grid,title){
  263. var c;
  264. Ext.Array.each(grid.stages,function(s){
  265. if(s['bs_name']==title) c=s['bs_color'];
  266. });
  267. return c;
  268. },
  269. loadNewData:function(grid,condition){
  270. var grid = Ext.getCmp('processgrid');
  271. grid.setLoading(true);
  272. Ext.Ajax.request({
  273. url: basePath + 'crm/business/getProcessDataByCondition.action',
  274. params: {
  275. condition: condition
  276. },
  277. method:'get',
  278. callback: function(opt, s, r) {
  279. var res = new Ext.decode(r.responseText);
  280. if(grid && res.data) {
  281. grid.store.loadData(Ext.decode(res.data));
  282. grid.setLoading(false);
  283. }
  284. }
  285. });
  286. }
  287. });