jquery.combobox.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446
  1. /**
  2. * jQuery EasyUI 1.4.1
  3. *
  4. * Copyright (c) 2009-2014 www.jeasyui.com. All rights reserved.
  5. *
  6. * Licensed under the GPL license: http://www.gnu.org/licenses/gpl.txt
  7. * To use it on other terms please contact us at info@jeasyui.com
  8. *
  9. */
  10. (function($){
  11. var _1=0;
  12. function _2(_3,_4){
  13. var _5=$.data(_3,"combobox");
  14. var _6=_5.options;
  15. var _7=_5.data;
  16. for(var i=0;i<_7.length;i++){
  17. if(_7[i][_6.valueField]==_4){
  18. return i;
  19. }
  20. }
  21. return -1;
  22. };
  23. function _8(_9,_a){
  24. var _b=$.data(_9,"combobox").options;
  25. var _c=$(_9).combo("panel");
  26. var _d=_b.finder.getEl(_9,_a);
  27. if(_d.length){
  28. if(_d.position().top<=0){
  29. var h=_c.scrollTop()+_d.position().top;
  30. _c.scrollTop(h);
  31. }else{
  32. if(_d.position().top+_d.outerHeight()>_c.height()){
  33. var h=_c.scrollTop()+_d.position().top+_d.outerHeight()-_c.height();
  34. _c.scrollTop(h);
  35. }
  36. }
  37. }
  38. };
  39. function _e(_f,dir){
  40. var _10=$.data(_f,"combobox").options;
  41. var _11=$(_f).combobox("panel");
  42. var _12=_11.children("div.combobox-item-hover");
  43. if(!_12.length){
  44. _12=_11.children("div.combobox-item-selected");
  45. }
  46. _12.removeClass("combobox-item-hover");
  47. var _13="div.combobox-item:visible:not(.combobox-item-disabled):first";
  48. var _14="div.combobox-item:visible:not(.combobox-item-disabled):last";
  49. if(!_12.length){
  50. _12=_11.children(dir=="next"?_13:_14);
  51. }else{
  52. if(dir=="next"){
  53. _12=_12.nextAll(_13);
  54. if(!_12.length){
  55. _12=_11.children(_13);
  56. }
  57. }else{
  58. _12=_12.prevAll(_13);
  59. if(!_12.length){
  60. _12=_11.children(_14);
  61. }
  62. }
  63. }
  64. if(_12.length){
  65. _12.addClass("combobox-item-hover");
  66. var row=_10.finder.getRow(_f,_12);
  67. if(row){
  68. _8(_f,row[_10.valueField]);
  69. if(_10.selectOnNavigation){
  70. _15(_f,row[_10.valueField]);
  71. }
  72. }
  73. }
  74. };
  75. function _15(_16,_17){
  76. var _18=$.data(_16,"combobox").options;
  77. var _19=$(_16).combo("getValues");
  78. if($.inArray(_17+"",_19)==-1){
  79. if(_18.multiple){
  80. _19.push(_17);
  81. }else{
  82. _19=[_17];
  83. }
  84. _1a(_16,_19);
  85. _18.onSelect.call(_16,_18.finder.getRow(_16,_17));
  86. }
  87. };
  88. function _1b(_1c,_1d){
  89. var _1e=$.data(_1c,"combobox").options;
  90. var _1f=$(_1c).combo("getValues");
  91. var _20=$.inArray(_1d+"",_1f);
  92. if(_20>=0){
  93. _1f.splice(_20,1);
  94. _1a(_1c,_1f);
  95. _1e.onUnselect.call(_1c,_1e.finder.getRow(_1c,_1d));
  96. }
  97. };
  98. function _1a(_21,_22,_23){
  99. var _24=$.data(_21,"combobox").options;
  100. var _25=$(_21).combo("panel");
  101. if(!$.isArray(_22)){
  102. _22=_22.split(_24.separator);
  103. }
  104. _25.find("div.combobox-item-selected").removeClass("combobox-item-selected");
  105. var vv=[],ss=[];
  106. for(var i=0;i<_22.length;i++){
  107. var v=_22[i];
  108. var s=v;
  109. _24.finder.getEl(_21,v).addClass("combobox-item-selected");
  110. var row=_24.finder.getRow(_21,v);
  111. if(row){
  112. s=row[_24.textField];
  113. }
  114. vv.push(v);
  115. ss.push(s);
  116. }
  117. $(_21).combo("setValues",vv);
  118. if(!_23){
  119. $(_21).combo("setText",ss.join(_24.separator));
  120. }
  121. };
  122. function _26(_27,_28,_29){
  123. var _2a=$.data(_27,"combobox");
  124. var _2b=_2a.options;
  125. _2a.data=_2b.loadFilter.call(_27,_28);
  126. _2a.groups=[];
  127. _28=_2a.data;
  128. var _2c=$(_27).combobox("getValues");
  129. var dd=[];
  130. var _2d=undefined;
  131. for(var i=0;i<_28.length;i++){
  132. var row=_28[i];
  133. var v=row[_2b.valueField]+"";
  134. var s=row[_2b.textField];
  135. var g=row[_2b.groupField];
  136. if(g){
  137. if(_2d!=g){
  138. _2d=g;
  139. _2a.groups.push(g);
  140. dd.push("<div id=\""+(_2a.groupIdPrefix+"_"+(_2a.groups.length-1))+"\" class=\"combobox-group\">");
  141. dd.push(_2b.groupFormatter?_2b.groupFormatter.call(_27,g):g);
  142. dd.push("</div>");
  143. }
  144. }else{
  145. _2d=undefined;
  146. }
  147. var cls="combobox-item"+(row.disabled?" combobox-item-disabled":"")+(g?" combobox-gitem":"");
  148. dd.push("<div id=\""+(_2a.itemIdPrefix+"_"+i)+"\" class=\""+cls+"\">");
  149. dd.push(_2b.formatter?_2b.formatter.call(_27,row):s);
  150. dd.push("</div>");
  151. if(row["selected"]&&$.inArray(v,_2c)==-1){
  152. _2c.push(v);
  153. }
  154. }
  155. $(_27).combo("panel").html(dd.join(""));
  156. if(_2b.multiple){
  157. _1a(_27,_2c,_29);
  158. }else{
  159. _1a(_27,_2c.length?[_2c[_2c.length-1]]:[],_29);
  160. }
  161. _2b.onLoadSuccess.call(_27,_28);
  162. };
  163. function _2e(_2f,url,_30,_31){
  164. var _32=$.data(_2f,"combobox").options;
  165. if(url){
  166. _32.url=url;
  167. }
  168. _30=_30||{};
  169. if(_32.onBeforeLoad.call(_2f,_30)==false){
  170. return;
  171. }
  172. _32.loader.call(_2f,_30,function(_33){
  173. _26(_2f,_33,_31);
  174. },function(){
  175. _32.onLoadError.apply(this,arguments);
  176. });
  177. };
  178. function _34(_35,q){
  179. var _36=$.data(_35,"combobox");
  180. var _37=_36.options;
  181. if(_37.multiple&&!q){
  182. _1a(_35,[],true);
  183. }else{
  184. _1a(_35,[q],true);
  185. }
  186. if(_37.mode=="remote"){
  187. _2e(_35,null,{q:q},true);
  188. }else{
  189. var _38=$(_35).combo("panel");
  190. _38.find("div.combobox-item-selected,div.combobox-item-hover").removeClass("combobox-item-selected combobox-item-hover");
  191. _38.find("div.combobox-item,div.combobox-group").hide();
  192. var _39=_36.data;
  193. var vv=[];
  194. var qq=_37.multiple?q.split(_37.separator):[q];
  195. $.map(qq,function(q){
  196. q=$.trim(q);
  197. var _3a=undefined;
  198. for(var i=0;i<_39.length;i++){
  199. var row=_39[i];
  200. if(_37.filter.call(_35,q,row)){
  201. var v=row[_37.valueField];
  202. var s=row[_37.textField];
  203. var g=row[_37.groupField];
  204. var _3b=_37.finder.getEl(_35,v).show();
  205. if(s.toLowerCase()==q.toLowerCase()){
  206. vv.push(v);
  207. _3b.addClass("combobox-item-selected");
  208. }
  209. if(_37.groupField&&_3a!=g){
  210. $("#"+_36.groupIdPrefix+"_"+$.inArray(g,_36.groups)).show();
  211. _3a=g;
  212. }
  213. }
  214. }
  215. });
  216. _1a(_35,vv,true);
  217. }
  218. };
  219. function _3c(_3d){
  220. var t=$(_3d);
  221. var _3e=t.combobox("options");
  222. var _3f=t.combobox("panel");
  223. var _40=_3f.children("div.combobox-item-hover");
  224. if(_40.length){
  225. var row=_3e.finder.getRow(_3d,_40);
  226. var _41=row[_3e.valueField];
  227. if(_3e.multiple){
  228. if(_40.hasClass("combobox-item-selected")){
  229. t.combobox("unselect",_41);
  230. }else{
  231. t.combobox("select",_41);
  232. }
  233. }else{
  234. t.combobox("select",_41);
  235. }
  236. }
  237. var vv=[];
  238. $.map(t.combobox("getValues"),function(v){
  239. if(_2(_3d,v)>=0){
  240. vv.push(v);
  241. }
  242. });
  243. t.combobox("setValues",vv);
  244. if(!_3e.multiple){
  245. t.combobox("hidePanel");
  246. }
  247. };
  248. function _42(_43){
  249. var _44=$.data(_43,"combobox");
  250. var _45=_44.options;
  251. _1++;
  252. _44.itemIdPrefix="_easyui_combobox_i"+_1;
  253. _44.groupIdPrefix="_easyui_combobox_g"+_1;
  254. $(_43).addClass("combobox-f");
  255. $(_43).combo($.extend({},_45,{onShowPanel:function(){
  256. $(_43).combo("panel").find("div.combobox-item,div.combobox-group").show();
  257. _8(_43,$(_43).combobox("getValue"));
  258. _45.onShowPanel.call(_43);
  259. }}));
  260. $(_43).combo("panel").unbind().bind("mouseover",function(e){
  261. $(this).children("div.combobox-item-hover").removeClass("combobox-item-hover");
  262. var _46=$(e.target).closest("div.combobox-item");
  263. if(!_46.hasClass("combobox-item-disabled")){
  264. _46.addClass("combobox-item-hover");
  265. }
  266. e.stopPropagation();
  267. }).bind("mouseout",function(e){
  268. $(e.target).closest("div.combobox-item").removeClass("combobox-item-hover");
  269. e.stopPropagation();
  270. }).bind("click",function(e){
  271. var _47=$(e.target).closest("div.combobox-item");
  272. if(!_47.length||_47.hasClass("combobox-item-disabled")){
  273. return;
  274. }
  275. var row=_45.finder.getRow(_43,_47);
  276. if(!row){
  277. return;
  278. }
  279. var _48=row[_45.valueField];
  280. if(_45.multiple){
  281. if(_47.hasClass("combobox-item-selected")){
  282. _1b(_43,_48);
  283. }else{
  284. _15(_43,_48);
  285. }
  286. }else{
  287. _15(_43,_48);
  288. $(_43).combo("hidePanel");
  289. }
  290. e.stopPropagation();
  291. });
  292. };
  293. $.fn.combobox=function(_49,_4a){
  294. if(typeof _49=="string"){
  295. var _4b=$.fn.combobox.methods[_49];
  296. if(_4b){
  297. return _4b(this,_4a);
  298. }else{
  299. return this.combo(_49,_4a);
  300. }
  301. }
  302. _49=_49||{};
  303. return this.each(function(){
  304. var _4c=$.data(this,"combobox");
  305. if(_4c){
  306. $.extend(_4c.options,_49);
  307. _42(this);
  308. }else{
  309. _4c=$.data(this,"combobox",{options:$.extend({},$.fn.combobox.defaults,$.fn.combobox.parseOptions(this),_49),data:[]});
  310. _42(this);
  311. var _4d=$.fn.combobox.parseData(this);
  312. if(_4d.length){
  313. _26(this,_4d);
  314. }
  315. }
  316. if(_4c.options.data){
  317. _26(this,_4c.options.data);
  318. }
  319. _2e(this);
  320. });
  321. };
  322. $.fn.combobox.methods={options:function(jq){
  323. var _4e=jq.combo("options");
  324. return $.extend($.data(jq[0],"combobox").options,{width:_4e.width,height:_4e.height,originalValue:_4e.originalValue,disabled:_4e.disabled,readonly:_4e.readonly});
  325. },getData:function(jq){
  326. return $.data(jq[0],"combobox").data;
  327. },setValues:function(jq,_4f){
  328. return jq.each(function(){
  329. _1a(this,_4f);
  330. });
  331. },setValue:function(jq,_50){
  332. return jq.each(function(){
  333. _1a(this,[_50]);
  334. });
  335. },clear:function(jq){
  336. return jq.each(function(){
  337. $(this).combo("clear");
  338. var _51=$(this).combo("panel");
  339. _51.find("div.combobox-item-selected").removeClass("combobox-item-selected");
  340. });
  341. },reset:function(jq){
  342. return jq.each(function(){
  343. var _52=$(this).combobox("options");
  344. if(_52.multiple){
  345. $(this).combobox("setValues",_52.originalValue);
  346. }else{
  347. $(this).combobox("setValue",_52.originalValue);
  348. }
  349. });
  350. },loadData:function(jq,_53){
  351. return jq.each(function(){
  352. _26(this,_53);
  353. });
  354. },reload:function(jq,url){
  355. return jq.each(function(){
  356. _2e(this,url);
  357. });
  358. },select:function(jq,_54){
  359. return jq.each(function(){
  360. _15(this,_54);
  361. });
  362. },unselect:function(jq,_55){
  363. return jq.each(function(){
  364. _1b(this,_55);
  365. });
  366. }};
  367. $.fn.combobox.parseOptions=function(_56){
  368. var t=$(_56);
  369. return $.extend({},$.fn.combo.parseOptions(_56),$.parser.parseOptions(_56,["valueField","textField","groupField","mode","method","url"]));
  370. };
  371. $.fn.combobox.parseData=function(_57){
  372. var _58=[];
  373. var _59=$(_57).combobox("options");
  374. $(_57).children().each(function(){
  375. if(this.tagName.toLowerCase()=="optgroup"){
  376. var _5a=$(this).attr("label");
  377. $(this).children().each(function(){
  378. _5b(this,_5a);
  379. });
  380. }else{
  381. _5b(this);
  382. }
  383. });
  384. return _58;
  385. function _5b(el,_5c){
  386. var t=$(el);
  387. var row={};
  388. row[_59.valueField]=t.attr("value")!=undefined?t.attr("value"):t.text();
  389. row[_59.textField]=t.text();
  390. row["selected"]=t.is(":selected");
  391. row["disabled"]=t.is(":disabled");
  392. if(_5c){
  393. _59.groupField=_59.groupField||"group";
  394. row[_59.groupField]=_5c;
  395. }
  396. _58.push(row);
  397. };
  398. };
  399. $.fn.combobox.defaults=$.extend({},$.fn.combo.defaults,{valueField:"value",textField:"text",groupField:null,groupFormatter:function(_5d){
  400. return _5d;
  401. },mode:"local",method:"post",url:null,data:null,keyHandler:{up:function(e){
  402. _e(this,"prev");
  403. e.preventDefault();
  404. },down:function(e){
  405. _e(this,"next");
  406. e.preventDefault();
  407. },left:function(e){
  408. },right:function(e){
  409. },enter:function(e){
  410. _3c(this);
  411. },query:function(q,e){
  412. _34(this,q);
  413. }},filter:function(q,row){
  414. var _5e=$(this).combobox("options");
  415. return row[_5e.textField].toLowerCase().indexOf(q.toLowerCase())==0;
  416. },formatter:function(row){
  417. var _5f=$(this).combobox("options");
  418. return row[_5f.textField];
  419. },loader:function(_60,_61,_62){
  420. var _63=$(this).combobox("options");
  421. if(!_63.url){
  422. return false;
  423. }
  424. $.ajax({type:_63.method,url:_63.url,data:_60,dataType:"json",success:function(_64){
  425. _61(_64);
  426. },error:function(){
  427. _62.apply(this,arguments);
  428. }});
  429. },loadFilter:function(_65){
  430. return _65;
  431. },finder:{getEl:function(_66,_67){
  432. var _68=_2(_66,_67);
  433. var id=$.data(_66,"combobox").itemIdPrefix+"_"+_68;
  434. return $("#"+id);
  435. },getRow:function(_69,p){
  436. var _6a=$.data(_69,"combobox");
  437. var _6b=(p instanceof jQuery)?p.attr("id").substr(_6a.itemIdPrefix.length+1):_2(_69,p);
  438. return _6a.data[parseInt(_6b)];
  439. }},onBeforeLoad:function(_6c){
  440. },onLoadSuccess:function(){
  441. },onLoadError:function(){
  442. },onSelect:function(_6d){
  443. },onUnselect:function(_6e){
  444. }});
  445. })(jQuery);