jquery.propertygrid.js 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. /**
  2. * jQuery EasyUI 1.4.4
  3. *
  4. * Copyright (c) 2009-2015 www.jeasyui.com. All rights reserved.
  5. *
  6. * Licensed under the freeware license: http://www.jeasyui.com/license_freeware.php
  7. * To use it on other terms please contact us: info@jeasyui.com
  8. *
  9. */
  10. (function($){
  11. var _1;
  12. $(document).unbind(".propertygrid").bind("mousedown.propertygrid",function(e){
  13. var p=$(e.target).closest("div.datagrid-view,div.combo-panel");
  14. if(p.length){
  15. return;
  16. }
  17. _2(_1);
  18. _1=undefined;
  19. });
  20. function _3(_4){
  21. var _5=$.data(_4,"propertygrid");
  22. var _6=$.data(_4,"propertygrid").options;
  23. $(_4).datagrid($.extend({},_6,{cls:"propertygrid",view:(_6.showGroup?_6.groupView:_6.view),onBeforeEdit:function(_7,_8){
  24. if(_6.onBeforeEdit.call(_4,_7,_8)==false){
  25. return false;
  26. }
  27. var dg=$(this);
  28. var _8=dg.datagrid("getRows")[_7];
  29. var _9=dg.datagrid("getColumnOption","value");
  30. _9.editor=_8.editor;
  31. },onClickCell:function(_a,_b,_c){
  32. if(_1!=this){
  33. _2(_1);
  34. _1=this;
  35. }
  36. if(_6.editIndex!=_a){
  37. _2(_1);
  38. $(this).datagrid("beginEdit",_a);
  39. var ed=$(this).datagrid("getEditor",{index:_a,field:_b});
  40. if(!ed){
  41. ed=$(this).datagrid("getEditor",{index:_a,field:"value"});
  42. }
  43. if(ed){
  44. var t=$(ed.target);
  45. var _d=t.data("textbox")?t.textbox("textbox"):t;
  46. _d.focus();
  47. _6.editIndex=_a;
  48. }
  49. }
  50. _6.onClickCell.call(_4,_a,_b,_c);
  51. },loadFilter:function(_e){
  52. _2(this);
  53. return _6.loadFilter.call(this,_e);
  54. }}));
  55. };
  56. function _2(_f){
  57. var t=$(_f);
  58. if(!t.length){
  59. return;
  60. }
  61. var _10=$.data(_f,"propertygrid").options;
  62. _10.finder.getTr(_f,null,"editing").each(function(){
  63. var _11=parseInt($(this).attr("datagrid-row-index"));
  64. if(t.datagrid("validateRow",_11)){
  65. t.datagrid("endEdit",_11);
  66. }else{
  67. t.datagrid("cancelEdit",_11);
  68. }
  69. });
  70. _10.editIndex=undefined;
  71. };
  72. $.fn.propertygrid=function(_12,_13){
  73. if(typeof _12=="string"){
  74. var _14=$.fn.propertygrid.methods[_12];
  75. if(_14){
  76. return _14(this,_13);
  77. }else{
  78. return this.datagrid(_12,_13);
  79. }
  80. }
  81. _12=_12||{};
  82. return this.each(function(){
  83. var _15=$.data(this,"propertygrid");
  84. if(_15){
  85. $.extend(_15.options,_12);
  86. }else{
  87. var _16=$.extend({},$.fn.propertygrid.defaults,$.fn.propertygrid.parseOptions(this),_12);
  88. _16.frozenColumns=$.extend(true,[],_16.frozenColumns);
  89. _16.columns=$.extend(true,[],_16.columns);
  90. $.data(this,"propertygrid",{options:_16});
  91. }
  92. _3(this);
  93. });
  94. };
  95. $.fn.propertygrid.methods={options:function(jq){
  96. return $.data(jq[0],"propertygrid").options;
  97. }};
  98. $.fn.propertygrid.parseOptions=function(_17){
  99. return $.extend({},$.fn.datagrid.parseOptions(_17),$.parser.parseOptions(_17,[{showGroup:"boolean"}]));
  100. };
  101. var _18=$.extend({},$.fn.datagrid.defaults.view,{render:function(_19,_1a,_1b){
  102. var _1c=[];
  103. var _1d=this.groups;
  104. for(var i=0;i<_1d.length;i++){
  105. _1c.push(this.renderGroup.call(this,_19,i,_1d[i],_1b));
  106. }
  107. $(_1a).html(_1c.join(""));
  108. },renderGroup:function(_1e,_1f,_20,_21){
  109. var _22=$.data(_1e,"datagrid");
  110. var _23=_22.options;
  111. var _24=$(_1e).datagrid("getColumnFields",_21);
  112. var _25=[];
  113. _25.push("<div class=\"datagrid-group\" group-index="+_1f+">");
  114. if((_21&&(_23.rownumbers||_23.frozenColumns.length))||(!_21&&!(_23.rownumbers||_23.frozenColumns.length))){
  115. _25.push("<span class=\"datagrid-group-expander\">");
  116. _25.push("<span class=\"datagrid-row-expander datagrid-row-collapse\">&nbsp;</span>");
  117. _25.push("</span>");
  118. }
  119. if(!_21){
  120. _25.push("<span class=\"datagrid-group-title\">");
  121. _25.push(_23.groupFormatter.call(_1e,_20.value,_20.rows));
  122. _25.push("</span>");
  123. }
  124. _25.push("</div>");
  125. _25.push("<table class=\"datagrid-btable\" cellspacing=\"0\" cellpadding=\"0\" border=\"0\"><tbody>");
  126. var _26=_20.startIndex;
  127. for(var j=0;j<_20.rows.length;j++){
  128. var css=_23.rowStyler?_23.rowStyler.call(_1e,_26,_20.rows[j]):"";
  129. var _27="";
  130. var _28="";
  131. if(typeof css=="string"){
  132. _28=css;
  133. }else{
  134. if(css){
  135. _27=css["class"]||"";
  136. _28=css["style"]||"";
  137. }
  138. }
  139. var cls="class=\"datagrid-row "+(_26%2&&_23.striped?"datagrid-row-alt ":" ")+_27+"\"";
  140. var _29=_28?"style=\""+_28+"\"":"";
  141. var _2a=_22.rowIdPrefix+"-"+(_21?1:2)+"-"+_26;
  142. _25.push("<tr id=\""+_2a+"\" datagrid-row-index=\""+_26+"\" "+cls+" "+_29+">");
  143. _25.push(this.renderRow.call(this,_1e,_24,_21,_26,_20.rows[j]));
  144. _25.push("</tr>");
  145. _26++;
  146. }
  147. _25.push("</tbody></table>");
  148. return _25.join("");
  149. },bindEvents:function(_2b){
  150. var _2c=$.data(_2b,"datagrid");
  151. var dc=_2c.dc;
  152. var _2d=dc.body1.add(dc.body2);
  153. var _2e=($.data(_2d[0],"events")||$._data(_2d[0],"events")).click[0].handler;
  154. _2d.unbind("click").bind("click",function(e){
  155. var tt=$(e.target);
  156. var _2f=tt.closest("span.datagrid-row-expander");
  157. if(_2f.length){
  158. var _30=_2f.closest("div.datagrid-group").attr("group-index");
  159. if(_2f.hasClass("datagrid-row-collapse")){
  160. $(_2b).datagrid("collapseGroup",_30);
  161. }else{
  162. $(_2b).datagrid("expandGroup",_30);
  163. }
  164. }else{
  165. _2e(e);
  166. }
  167. e.stopPropagation();
  168. });
  169. },onBeforeRender:function(_31,_32){
  170. var _33=$.data(_31,"datagrid");
  171. var _34=_33.options;
  172. _35();
  173. var _36=[];
  174. for(var i=0;i<_32.length;i++){
  175. var row=_32[i];
  176. var _37=_38(row[_34.groupField]);
  177. if(!_37){
  178. _37={value:row[_34.groupField],rows:[row]};
  179. _36.push(_37);
  180. }else{
  181. _37.rows.push(row);
  182. }
  183. }
  184. var _39=0;
  185. var _3a=[];
  186. for(var i=0;i<_36.length;i++){
  187. var _37=_36[i];
  188. _37.startIndex=_39;
  189. _39+=_37.rows.length;
  190. _3a=_3a.concat(_37.rows);
  191. }
  192. _33.data.rows=_3a;
  193. this.groups=_36;
  194. var _3b=this;
  195. setTimeout(function(){
  196. _3b.bindEvents(_31);
  197. },0);
  198. function _38(_3c){
  199. for(var i=0;i<_36.length;i++){
  200. var _3d=_36[i];
  201. if(_3d.value==_3c){
  202. return _3d;
  203. }
  204. }
  205. return null;
  206. };
  207. function _35(){
  208. if(!$("#datagrid-group-style").length){
  209. $("head").append("<style id=\"datagrid-group-style\">"+".datagrid-group{height:"+_34.groupHeight+"px;overflow:hidden;font-weight:bold;border-bottom:1px solid #ccc;}"+".datagrid-group-title,.datagrid-group-expander{display:inline-block;vertical-align:bottom;height:100%;line-height:"+_34.groupHeight+"px;padding:0 4px;}"+".datagrid-group-expander{width:"+_34.expanderWidth+"px;text-align:center;padding:0}"+".datagrid-row-expander{margin:"+Math.floor((_34.groupHeight-16)/2)+"px 0;display:inline-block;width:16px;height:16px;cursor:pointer}"+"</style>");
  210. }
  211. };
  212. }});
  213. $.extend($.fn.datagrid.methods,{groups:function(jq){
  214. return jq.datagrid("options").view.groups;
  215. },expandGroup:function(jq,_3e){
  216. return jq.each(function(){
  217. var _3f=$.data(this,"datagrid").dc.view;
  218. var _40=_3f.find(_3e!=undefined?"div.datagrid-group[group-index=\""+_3e+"\"]":"div.datagrid-group");
  219. var _41=_40.find("span.datagrid-row-expander");
  220. if(_41.hasClass("datagrid-row-expand")){
  221. _41.removeClass("datagrid-row-expand").addClass("datagrid-row-collapse");
  222. _40.next("table").show();
  223. }
  224. $(this).datagrid("fixRowHeight");
  225. });
  226. },collapseGroup:function(jq,_42){
  227. return jq.each(function(){
  228. var _43=$.data(this,"datagrid").dc.view;
  229. var _44=_43.find(_42!=undefined?"div.datagrid-group[group-index=\""+_42+"\"]":"div.datagrid-group");
  230. var _45=_44.find("span.datagrid-row-expander");
  231. if(_45.hasClass("datagrid-row-collapse")){
  232. _45.removeClass("datagrid-row-collapse").addClass("datagrid-row-expand");
  233. _44.next("table").hide();
  234. }
  235. $(this).datagrid("fixRowHeight");
  236. });
  237. }});
  238. $.extend(_18,{refreshGroupTitle:function(_46,_47){
  239. var _48=$.data(_46,"datagrid");
  240. var _49=_48.options;
  241. var dc=_48.dc;
  242. var _4a=this.groups[_47];
  243. var _4b=dc.body2.children("div.datagrid-group[group-index="+_47+"]").find("span.datagrid-group-title");
  244. _4b.html(_49.groupFormatter.call(_46,_4a.value,_4a.rows));
  245. },insertRow:function(_4c,_4d,row){
  246. var _4e=$.data(_4c,"datagrid");
  247. var _4f=_4e.options;
  248. var dc=_4e.dc;
  249. var _50=null;
  250. var _51;
  251. if(!_4e.data.rows.length){
  252. $(_4c).datagrid("loadData",[row]);
  253. return;
  254. }
  255. for(var i=0;i<this.groups.length;i++){
  256. if(this.groups[i].value==row[_4f.groupField]){
  257. _50=this.groups[i];
  258. _51=i;
  259. break;
  260. }
  261. }
  262. if(_50){
  263. if(_4d==undefined||_4d==null){
  264. _4d=_4e.data.rows.length;
  265. }
  266. if(_4d<_50.startIndex){
  267. _4d=_50.startIndex;
  268. }else{
  269. if(_4d>_50.startIndex+_50.rows.length){
  270. _4d=_50.startIndex+_50.rows.length;
  271. }
  272. }
  273. $.fn.datagrid.defaults.view.insertRow.call(this,_4c,_4d,row);
  274. if(_4d>=_50.startIndex+_50.rows.length){
  275. _52(_4d,true);
  276. _52(_4d,false);
  277. }
  278. _50.rows.splice(_4d-_50.startIndex,0,row);
  279. }else{
  280. _50={value:row[_4f.groupField],rows:[row],startIndex:_4e.data.rows.length};
  281. _51=this.groups.length;
  282. dc.body1.append(this.renderGroup.call(this,_4c,_51,_50,true));
  283. dc.body2.append(this.renderGroup.call(this,_4c,_51,_50,false));
  284. this.groups.push(_50);
  285. _4e.data.rows.push(row);
  286. }
  287. this.refreshGroupTitle(_4c,_51);
  288. function _52(_53,_54){
  289. var _55=_54?1:2;
  290. var _56=_4f.finder.getTr(_4c,_53-1,"body",_55);
  291. var tr=_4f.finder.getTr(_4c,_53,"body",_55);
  292. tr.insertAfter(_56);
  293. };
  294. },updateRow:function(_57,_58,row){
  295. var _59=$.data(_57,"datagrid").options;
  296. $.fn.datagrid.defaults.view.updateRow.call(this,_57,_58,row);
  297. var tb=_59.finder.getTr(_57,_58,"body",2).closest("table.datagrid-btable");
  298. var _5a=parseInt(tb.prev().attr("group-index"));
  299. this.refreshGroupTitle(_57,_5a);
  300. },deleteRow:function(_5b,_5c){
  301. var _5d=$.data(_5b,"datagrid");
  302. var _5e=_5d.options;
  303. var dc=_5d.dc;
  304. var _5f=dc.body1.add(dc.body2);
  305. var tb=_5e.finder.getTr(_5b,_5c,"body",2).closest("table.datagrid-btable");
  306. var _60=parseInt(tb.prev().attr("group-index"));
  307. $.fn.datagrid.defaults.view.deleteRow.call(this,_5b,_5c);
  308. var _61=this.groups[_60];
  309. if(_61.rows.length>1){
  310. _61.rows.splice(_5c-_61.startIndex,1);
  311. this.refreshGroupTitle(_5b,_60);
  312. }else{
  313. _5f.children("div.datagrid-group[group-index="+_60+"]").remove();
  314. for(var i=_60+1;i<this.groups.length;i++){
  315. _5f.children("div.datagrid-group[group-index="+i+"]").attr("group-index",i-1);
  316. }
  317. this.groups.splice(_60,1);
  318. }
  319. var _5c=0;
  320. for(var i=0;i<this.groups.length;i++){
  321. var _61=this.groups[i];
  322. _61.startIndex=_5c;
  323. _5c+=_61.rows.length;
  324. }
  325. }});
  326. $.fn.propertygrid.defaults=$.extend({},$.fn.datagrid.defaults,{groupHeight:21,expanderWidth:16,singleSelect:true,remoteSort:false,fitColumns:true,loadMsg:"",frozenColumns:[[{field:"f",width:16,resizable:false}]],columns:[[{field:"name",title:"Name",width:100,sortable:true},{field:"value",title:"Value",width:100,resizable:false}]],showGroup:false,groupView:_18,groupField:"group",groupFormatter:function(_62,_63){
  327. return _62;
  328. }});
  329. })(jQuery);