You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

16296 lines
826 KiB

4 days ago
  1. /**
  2. *
  3. * @license Guriddo jqGrid JS - v5.1.0 - 2016-05-12
  4. * Copyright(c) 2008, Tony Tomov, tony@trirand.com
  5. *
  6. * License: http://guriddo.net/?page_id=103334
  7. */
  8. (function (factory) {
  9. "use strict";
  10. if (typeof define === "function" && define.amd) {
  11. // AMD. Register as an anonymous module.
  12. define([
  13. "jquery"
  14. ], factory);
  15. } else {
  16. // Browser globals
  17. factory(jQuery);
  18. }
  19. }(function ($) {
  20. "use strict";
  21. //module begin
  22. $.jgrid = $.jgrid || {};
  23. if (!$.jgrid.hasOwnProperty("defaults")) {
  24. $.jgrid.defaults = {};
  25. }
  26. $.extend($.jgrid, {
  27. version: "5.1.0",
  28. htmlDecode: function (value) {
  29. if (value && (value === ' ' || value === ' ' || (value.length === 1 && value.charCodeAt(0) === 160))) { return ""; }
  30. return !value ? value : String(value).replace(/&gt;/g, ">").replace(/&lt;/g, "<").replace(/&quot;/g, '"').replace(/&amp;/g, "&");
  31. },
  32. htmlEncode: function (value) {
  33. return !value ? value : String(value).replace(/&/g, "&amp;").replace(/\"/g, "&quot;").replace(/</g, "&lt;").replace(/>/g, "&gt;");
  34. },
  35. template: function (format) { //jqgformat
  36. var args = $.makeArray(arguments).slice(1), j, al = args.length;
  37. if (format == null) { format = ""; }
  38. return format.replace(/\{([\w\-]+)(?:\:([\w\.]*)(?:\((.*?)?\))?)?\}/g, function (m, i) {
  39. if (!isNaN(parseInt(i, 10))) {
  40. return args[parseInt(i, 10)];
  41. }
  42. for (j = 0; j < al; j++) {
  43. if ($.isArray(args[j])) {
  44. var nmarr = args[j],
  45. k = nmarr.length;
  46. while (k--) {
  47. if (i === nmarr[k].nm) {
  48. return nmarr[k].v;
  49. }
  50. }
  51. }
  52. }
  53. });
  54. },
  55. msie: navigator.appName === 'Microsoft Internet Explorer',
  56. msiever: function () {
  57. var rv = -1;
  58. var ua = navigator.userAgent;
  59. var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
  60. if (re.exec(ua) != null) {
  61. rv = parseFloat(RegExp.$1);
  62. }
  63. return rv;
  64. },
  65. getCellIndex: function (cell) {
  66. var c = $(cell);
  67. if (c.is('tr')) { return -1; }
  68. c = (!c.is('td') && !c.is('th') ? c.closest("td,th") : c)[0];
  69. if ($.jgrid.msie) { return $.inArray(c, c.parentNode.cells); }
  70. return c.cellIndex;
  71. },
  72. stripHtml: function (v) {
  73. v = String(v);
  74. var regexp = /<("[^"]*"|'[^']*'|[^'">])*>/gi;
  75. if (v) {
  76. v = v.replace(regexp, "");
  77. return (v && v !== '&nbsp;' && v !== '&#160;') ? v.replace(/\"/g, "'") : "";
  78. }
  79. return v;
  80. },
  81. stripPref: function (pref, id) {
  82. var obj = $.type(pref);
  83. if (obj === "string" || obj === "number") {
  84. pref = String(pref);
  85. id = pref !== "" ? String(id).replace(String(pref), "") : id;
  86. }
  87. return id;
  88. },
  89. useJSON: true,
  90. parse: function (jsonString) {
  91. var js = jsonString;
  92. if (js.substr(0, 9) === "while(1);") { js = js.substr(9); }
  93. if (js.substr(0, 2) === "/*") { js = js.substr(2, js.length - 4); }
  94. if (!js) { js = "{}"; }
  95. return ($.jgrid.useJSON === true && typeof JSON === 'object' && typeof JSON.parse === 'function') ?
  96. JSON.parse(js) :
  97. eval('(' + js + ')');
  98. },
  99. parseDate: function (format, date, newformat, opts) {
  100. var token = /\\.|[dDjlNSwzWFmMntLoYyaABgGhHisueIOPTZcrU]/g,
  101. timezone = /\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g,
  102. timezoneClip = /[^-+\dA-Z]/g,
  103. msDateRegExp = new RegExp("^\/Date\\((([-+])?[0-9]+)(([-+])([0-9]{2})([0-9]{2}))?\\)\/$"),
  104. msMatch = ((typeof date === 'string') ? date.match(msDateRegExp) : null),
  105. pad = function (value, length) {
  106. value = String(value);
  107. length = parseInt(length, 10) || 2;
  108. while (value.length < length) { value = '0' + value; }
  109. return value;
  110. },
  111. ts = { m: 1, d: 1, y: 1970, h: 0, i: 0, s: 0, u: 0 },
  112. timestamp = 0, dM, k, hl,
  113. h12to24 = function (ampm, h) {
  114. if (ampm === 0) { if (h === 12) { h = 0; } }
  115. else { if (h !== 12) { h += 12; } }
  116. return h;
  117. },
  118. offset = 0;
  119. if (opts === undefined) {
  120. opts = $.jgrid.getRegional(this, "formatter.date");//$.jgrid.formatter.date;
  121. }
  122. // old lang files
  123. if (opts.parseRe === undefined) {
  124. opts.parseRe = /[#%\\\/:_;.,\t\s-]/;
  125. }
  126. if (opts.masks.hasOwnProperty(format)) { format = opts.masks[format]; }
  127. if (date && date != null) {
  128. if (!isNaN(date - 0) && String(format).toLowerCase() === "u") {
  129. //Unix timestamp
  130. timestamp = new Date(parseFloat(date) * 1000);
  131. } else if (date.constructor === Date) {
  132. timestamp = date;
  133. // Microsoft date format support
  134. } else if (msMatch !== null) {
  135. timestamp = new Date(parseInt(msMatch[1], 10));
  136. if (msMatch[3]) {
  137. offset = Number(msMatch[5]) * 60 + Number(msMatch[6]);
  138. offset *= ((msMatch[4] === '-') ? 1 : -1);
  139. offset -= timestamp.getTimezoneOffset();
  140. timestamp.setTime(Number(Number(timestamp) + (offset * 60 * 1000)));
  141. }
  142. } else {
  143. //Support ISO8601Long that have Z at the end to indicate UTC timezone
  144. if (opts.srcformat === 'ISO8601Long' && date.charAt(date.length - 1) === 'Z') {
  145. offset -= (new Date()).getTimezoneOffset();
  146. }
  147. date = String(date).replace(/\T/g, "#").replace(/\t/, "%").split(opts.parseRe);
  148. format = format.replace(/\T/g, "#").replace(/\t/, "%").split(opts.parseRe);
  149. // parsing for month names
  150. for (k = 0, hl = format.length; k < hl; k++) {
  151. switch (format[k]) {
  152. case 'M':
  153. dM = $.inArray(date[k], opts.monthNames);
  154. if (dM !== -1 && dM < 12) { date[k] = dM + 1; ts.m = date[k]; }
  155. break;
  156. case 'F':
  157. dM = $.inArray(date[k], opts.monthNames, 12);
  158. if (dM !== -1 && dM > 11) { date[k] = dM + 1 - 12; ts.m = date[k]; }
  159. break;
  160. case 'n':
  161. format[k] = 'm';
  162. break;
  163. case 'j':
  164. format[k] = 'd';
  165. break;
  166. case 'a':
  167. dM = $.inArray(date[k], opts.AmPm);
  168. if (dM !== -1 && dM < 2 && date[k] === opts.AmPm[dM]) {
  169. date[k] = dM;
  170. ts.h = h12to24(date[k], ts.h);
  171. }
  172. break;
  173. case 'A':
  174. dM = $.inArray(date[k], opts.AmPm);
  175. if (dM !== -1 && dM > 1 && date[k] === opts.AmPm[dM]) {
  176. date[k] = dM - 2;
  177. ts.h = h12to24(date[k], ts.h);
  178. }
  179. break;
  180. case 'g':
  181. ts.h = parseInt(date[k], 10);
  182. break;
  183. }
  184. if (date[k] !== undefined) {
  185. ts[format[k].toLowerCase()] = parseInt(date[k], 10);
  186. }
  187. }
  188. if (ts.f) { ts.m = ts.f; }
  189. if (ts.m === 0 && ts.y === 0 && ts.d === 0) {
  190. return "&#160;";
  191. }
  192. ts.m = parseInt(ts.m, 10) - 1;
  193. var ty = ts.y;
  194. if (ty >= 70 && ty <= 99) { ts.y = 1900 + ts.y; }
  195. else if (ty >= 0 && ty <= 69) { ts.y = 2000 + ts.y; }
  196. timestamp = new Date(ts.y, ts.m, ts.d, ts.h, ts.i, ts.s, ts.u);
  197. //Apply offset to show date as local time.
  198. if (offset > 0) {
  199. timestamp.setTime(Number(Number(timestamp) + (offset * 60 * 1000)));
  200. }
  201. }
  202. } else {
  203. timestamp = new Date(ts.y, ts.m, ts.d, ts.h, ts.i, ts.s, ts.u);
  204. }
  205. if (opts.userLocalTime && offset === 0) {
  206. offset -= (new Date()).getTimezoneOffset();
  207. if (offset > 0) {
  208. timestamp.setTime(Number(Number(timestamp) + (offset * 60 * 1000)));
  209. }
  210. }
  211. if (newformat === undefined) {
  212. return timestamp;
  213. }
  214. if (opts.masks.hasOwnProperty(newformat)) {
  215. newformat = opts.masks[newformat];
  216. } else if (!newformat) {
  217. newformat = 'Y-m-d';
  218. }
  219. var
  220. G = timestamp.getHours(),
  221. i = timestamp.getMinutes(),
  222. j = timestamp.getDate(),
  223. n = timestamp.getMonth() + 1,
  224. o = timestamp.getTimezoneOffset(),
  225. s = timestamp.getSeconds(),
  226. u = timestamp.getMilliseconds(),
  227. w = timestamp.getDay(),
  228. Y = timestamp.getFullYear(),
  229. N = (w + 6) % 7 + 1,
  230. z = (new Date(Y, n - 1, j) - new Date(Y, 0, 1)) / 86400000,
  231. flags = {
  232. // Day
  233. d: pad(j),
  234. D: opts.dayNames[w],
  235. j: j,
  236. l: opts.dayNames[w + 7],
  237. N: N,
  238. S: opts.S(j),
  239. //j < 11 || j > 13 ? ['st', 'nd', 'rd', 'th'][Math.min((j - 1) % 10, 3)] : 'th',
  240. w: w,
  241. z: z,
  242. // Week
  243. W: N < 5 ? Math.floor((z + N - 1) / 7) + 1 : Math.floor((z + N - 1) / 7) || ((new Date(Y - 1, 0, 1).getDay() + 6) % 7 < 4 ? 53 : 52),
  244. // Month
  245. F: opts.monthNames[n - 1 + 12],
  246. m: pad(n),
  247. M: opts.monthNames[n - 1],
  248. n: n,
  249. t: '?',
  250. // Year
  251. L: '?',
  252. o: '?',
  253. Y: Y,
  254. y: String(Y).substring(2),
  255. // Time
  256. a: G < 12 ? opts.AmPm[0] : opts.AmPm[1],
  257. A: G < 12 ? opts.AmPm[2] : opts.AmPm[3],
  258. B: '?',
  259. g: G % 12 || 12,
  260. G: G,
  261. h: pad(G % 12 || 12),
  262. H: pad(G),
  263. i: pad(i),
  264. s: pad(s),
  265. u: u,
  266. // Timezone
  267. e: '?',
  268. I: '?',
  269. O: (o > 0 ? "-" : "+") + pad(Math.floor(Math.abs(o) / 60) * 100 + Math.abs(o) % 60, 4),
  270. P: '?',
  271. T: (String(timestamp).match(timezone) || [""]).pop().replace(timezoneClip, ""),
  272. Z: '?',
  273. // Full Date/Time
  274. c: '?',
  275. r: '?',
  276. U: Math.floor(timestamp / 1000)
  277. };
  278. return newformat.replace(token, function ($0) {
  279. return flags.hasOwnProperty($0) ? flags[$0] : $0.substring(1);
  280. });
  281. },
  282. jqID: function (sid) {
  283. return String(sid).replace(/[!"#$%&'()*+,.\/:; <=>?@\[\\\]\^`{|}~]/g, "\\$&");
  284. },
  285. guid: 1,
  286. uidPref: 'jqg',
  287. randId: function (prefix) {
  288. return (prefix || $.jgrid.uidPref) + ($.jgrid.guid++);
  289. },
  290. getAccessor: function (obj, expr) {
  291. var ret, p, prm = [], i;
  292. if (typeof expr === 'function') { return expr(obj); }
  293. ret = obj[expr];
  294. if (ret === undefined) {
  295. try {
  296. if (typeof expr === 'string') {
  297. prm = expr.split('.');
  298. }
  299. i = prm.length;
  300. if (i) {
  301. ret = obj;
  302. while (ret && i--) {
  303. p = prm.shift();
  304. ret = ret[p];
  305. }
  306. }
  307. } catch (e) { }
  308. }
  309. return ret;
  310. },
  311. getXmlData: function (obj, expr, returnObj) {
  312. var ret, m = typeof expr === 'string' ? expr.match(/^(.*)\[(\w+)\]$/) : null;
  313. if (typeof expr === 'function') { return expr(obj); }
  314. if (m && m[2]) {
  315. // m[2] is the attribute selector
  316. // m[1] is an optional element selector
  317. // examples: "[id]", "rows[page]"
  318. return m[1] ? $(m[1], obj).attr(m[2]) : $(obj).attr(m[2]);
  319. }
  320. ret = $(expr, obj);
  321. if (returnObj) { return ret; }
  322. //$(expr, obj).filter(':last'); // we use ':last' to be more compatible with old version of jqGrid
  323. return ret.length > 0 ? $(ret).text() : undefined;
  324. },
  325. cellWidth: function () {
  326. var $testDiv = $("<div class='ui-jqgrid' style='left:10000px'><table class='ui-jqgrid-btable ui-common-table' style='width:5px;'><tr class='jqgrow'><td style='width:5px;display:block;'></td></tr></table></div>"),
  327. testCell = $testDiv.appendTo("body")
  328. .find("td")
  329. .width();
  330. $testDiv.remove();
  331. return Math.abs(testCell - 5) > 0.1;
  332. },
  333. isLocalStorage: function () {
  334. try {
  335. return 'localStorage' in window && window.localStorage !== null;
  336. } catch (e) {
  337. return false;
  338. }
  339. },
  340. getRegional: function (inst, param, def_val) {
  341. var ret;
  342. if (def_val !== undefined) {
  343. return def_val;
  344. }
  345. if (inst.p && inst.p.regional && $.jgrid.regional) {
  346. ret = $.jgrid.getAccessor($.jgrid.regional[inst.p.regional] || {}, param);
  347. }
  348. if (ret === undefined) {
  349. ret = $.jgrid.getAccessor($.jgrid, param);
  350. }
  351. return ret;
  352. },
  353. isMobile: function () {
  354. try {
  355. if (/Android|webOS|iPhone|iPad|iPod|pocket|psp|kindle|avantgo|blazer|midori|Tablet|Palm|maemo|plucker|phone|BlackBerry|symbian|IEMobile|mobile|ZuneWP7|Windows Phone|Opera Mini/i.test(navigator.userAgent)) {
  356. return true;
  357. }
  358. return false;
  359. } catch (e) {
  360. return false;
  361. }
  362. },
  363. cell_width: true,
  364. ajaxOptions: {},
  365. from: function (source) {
  366. // Original Author Hugo Bonacci
  367. // License MIT http://jlinq.codeplex.com/license
  368. var $t = this,
  369. QueryObject = function (d, q) {
  370. if (typeof d === "string") {
  371. d = $.data(d);
  372. }
  373. var self = this,
  374. _data = d,
  375. _usecase = true,
  376. _trim = false,
  377. _query = q,
  378. _stripNum = /[\$,%]/g,
  379. _lastCommand = null,
  380. _lastField = null,
  381. _orDepth = 0,
  382. _negate = false,
  383. _queuedOperator = "",
  384. _sorting = [],
  385. _useProperties = true;
  386. if (typeof d === "object" && d.push) {
  387. if (d.length > 0) {
  388. if (typeof d[0] !== "object") {
  389. _useProperties = false;
  390. } else {
  391. _useProperties = true;
  392. }
  393. }
  394. } else {
  395. throw "提供的数据不是数组";
  396. }
  397. this._hasData = function () {
  398. return _data === null ? false : _data.length === 0 ? false : true;
  399. };
  400. this._getStr = function (s) {
  401. var phrase = [];
  402. if (_trim) {
  403. phrase.push("jQuery.trim(");
  404. }
  405. phrase.push("String(" + s + ")");
  406. if (_trim) {
  407. phrase.push(")");
  408. }
  409. if (!_usecase) {
  410. phrase.push(".toLowerCase()");
  411. }
  412. return phrase.join("");
  413. };
  414. this._strComp = function (val) {
  415. if (typeof val === "string") {
  416. return ".toString()";
  417. }
  418. return "";
  419. };
  420. this._group = function (f, u) {
  421. return ({ field: f.toString(), unique: u, items: [] });
  422. };
  423. this._toStr = function (phrase) {
  424. if (_trim) {
  425. phrase = $.trim(phrase);
  426. }
  427. phrase = phrase.toString().replace(/\\/g, '\\\\').replace(/\"/g, '\\"');
  428. return _usecase ? phrase : phrase.toLowerCase();
  429. };
  430. this._funcLoop = function (func) {
  431. var results = [];
  432. $.each(_data, function (i, v) {
  433. results.push(func(v));
  434. });
  435. return results;
  436. };
  437. this._append = function (s) {
  438. var i;
  439. if (_query === null) {
  440. _query = "";
  441. } else {
  442. _query += _queuedOperator === "" ? " && " : _queuedOperator;
  443. }
  444. for (i = 0; i < _orDepth; i++) {
  445. _query += "(";
  446. }
  447. if (_negate) {
  448. _query += "!";
  449. }
  450. _query += "(" + s + ")";
  451. _negate = false;
  452. _queuedOperator = "";
  453. _orDepth = 0;
  454. };
  455. this._setCommand = function (f, c) {
  456. _lastCommand = f;
  457. _lastField = c;
  458. };
  459. this._resetNegate = function () {
  460. _negate = false;
  461. };
  462. this._repeatCommand = function (f, v) {
  463. if (_lastCommand === null) {
  464. return self;
  465. }
  466. if (f !== null && v !== null) {
  467. return _lastCommand(f, v);
  468. }
  469. if (_lastField === null) {
  470. return _lastCommand(f);
  471. }
  472. if (!_useProperties) {
  473. return _lastCommand(f);
  474. }
  475. return _lastCommand(_lastField, f);
  476. };
  477. this._equals = function (a, b) {
  478. return (self._compare(a, b, 1) === 0);
  479. };
  480. this._compare = function (a, b, d) {
  481. var toString = Object.prototype.toString;
  482. if (d === undefined) { d = 1; }
  483. if (a === undefined) { a = null; }
  484. if (b === undefined) { b = null; }
  485. if (a === null && b === null) {
  486. return 0;
  487. }
  488. if (a === null && b !== null) {
  489. return 1;
  490. }
  491. if (a !== null && b === null) {
  492. return -1;
  493. }
  494. if (toString.call(a) === '[object Date]' && toString.call(b) === '[object Date]') {
  495. if (a < b) { return -d; }
  496. if (a > b) { return d; }
  497. return 0;
  498. }
  499. if (!_usecase && typeof a !== "number" && typeof b !== "number") {
  500. a = String(a);
  501. b = String(b);
  502. }
  503. if (a < b) { return -d; }
  504. if (a > b) { return d; }
  505. return 0;
  506. };
  507. this._performSort = function () {
  508. if (_sorting.length === 0) { return; }
  509. _data = self._doSort(_data, 0);
  510. };
  511. this._doSort = function (d, q) {
  512. var by = _sorting[q].by,
  513. dir = _sorting[q].dir,
  514. type = _sorting[q].type,
  515. dfmt = _sorting[q].datefmt,
  516. sfunc = _sorting[q].sfunc;
  517. if (q === _sorting.length - 1) {
  518. return self._getOrder(d, by, dir, type, dfmt, sfunc);
  519. }
  520. q++;
  521. var values = self._getGroup(d, by, dir, type, dfmt), results = [], i, j, sorted;
  522. for (i = 0; i < values.length; i++) {
  523. sorted = self._doSort(values[i].items, q);
  524. for (j = 0; j < sorted.length; j++) {
  525. results.push(sorted[j]);
  526. }
  527. }
  528. return results;
  529. };
  530. this._getOrder = function (data, by, dir, type, dfmt, sfunc) {
  531. var sortData = [], _sortData = [], newDir = dir === "a" ? 1 : -1, i, ab, j,
  532. findSortKey;
  533. if (type === undefined) { type = "text"; }
  534. if (type === 'float' || type === 'number' || type === 'currency' || type === 'numeric') {
  535. findSortKey = function ($cell) {
  536. var key = parseFloat(String($cell).replace(_stripNum, ''));
  537. return isNaN(key) ? Number.NEGATIVE_INFINITY : key;
  538. };
  539. } else if (type === 'int' || type === 'integer') {
  540. findSortKey = function ($cell) {
  541. return $cell ? parseFloat(String($cell).replace(_stripNum, '')) : Number.NEGATIVE_INFINITY;
  542. };
  543. } else if (type === 'date' || type === 'datetime') {
  544. findSortKey = function ($cell) {
  545. return $.jgrid.parseDate.call($t, dfmt, $cell).getTime();
  546. };
  547. } else if ($.isFunction(type)) {
  548. findSortKey = type;
  549. } else {
  550. findSortKey = function ($cell) {
  551. $cell = $cell ? $.trim(String($cell)) : "";
  552. return _usecase ? $cell : $cell.toLowerCase();
  553. };
  554. }
  555. $.each(data, function (i, v) {
  556. ab = by !== "" ? $.jgrid.getAccessor(v, by) : v;
  557. if (ab === undefined) { ab = ""; }
  558. ab = findSortKey(ab, v);
  559. _sortData.push({ 'vSort': ab, 'index': i });
  560. });
  561. if ($.isFunction(sfunc)) {
  562. _sortData.sort(function (a, b) {
  563. return sfunc.call(this, a.vSort, b.vSort, newDir, a, b);
  564. });
  565. } else {
  566. _sortData.sort(function (a, b) {
  567. return self._compare(a.vSort, b.vSort, newDir);
  568. });
  569. }
  570. j = 0;
  571. var nrec = data.length;
  572. // overhead, but we do not change the original data.
  573. while (j < nrec) {
  574. i = _sortData[j].index;
  575. sortData.push(data[i]);
  576. j++;
  577. }
  578. return sortData;
  579. };
  580. this._getGroup = function (data, by, dir, type, dfmt) {
  581. var results = [],
  582. group = null,
  583. last = null, val;
  584. $.each(self._getOrder(data, by, dir, type, dfmt), function (i, v) {
  585. val = $.jgrid.getAccessor(v, by);
  586. if (val == null) { val = ""; }
  587. if (!self._equals(last, val)) {
  588. last = val;
  589. if (group !== null) {
  590. results.push(group);
  591. }
  592. group = self._group(by, val);
  593. }
  594. group.items.push(v);
  595. });
  596. if (group !== null) {
  597. results.push(group);
  598. }
  599. return results;
  600. };
  601. this.ignoreCase = function () {
  602. _usecase = false;
  603. return self;
  604. };
  605. this.useCase = function () {
  606. _usecase = true;
  607. return self;
  608. };
  609. this.trim = function () {
  610. _trim = true;
  611. return self;
  612. };
  613. this.noTrim = function () {
  614. _trim = false;
  615. return self;
  616. };
  617. this.execute = function () {
  618. var match = _query, results = [];
  619. if (match === null) {
  620. return self;
  621. }
  622. $.each(_data, function () {
  623. if (eval(match)) { results.push(this); }
  624. });
  625. _data = results;
  626. return self;
  627. };
  628. this.data = function () {
  629. return _data;
  630. };
  631. this.select = function (f) {
  632. self._performSort();
  633. if (!self._hasData()) { return []; }
  634. self.execute();
  635. if ($.isFunction(f)) {
  636. var results = [];
  637. $.each(_data, function (i, v) {
  638. results.push(f(v));
  639. });
  640. return results;
  641. }
  642. return _data;
  643. };
  644. this.hasMatch = function () {
  645. if (!self._hasData()) { return false; }
  646. self.execute();
  647. return _data.length > 0;
  648. };
  649. this.andNot = function (f, v, x) {
  650. _negate = !_negate;
  651. return self.and(f, v, x);
  652. };
  653. this.orNot = function (f, v, x) {
  654. _negate = !_negate;
  655. return self.or(f, v, x);
  656. };
  657. this.not = function (f, v, x) {
  658. return self.andNot(f, v, x);
  659. };
  660. this.and = function (f, v, x) {
  661. _queuedOperator = " && ";
  662. if (f === undefined) {
  663. return self;
  664. }
  665. return self._repeatCommand(f, v, x);
  666. };
  667. this.or = function (f, v, x) {
  668. _queuedOperator = " || ";
  669. if (f === undefined) { return self; }
  670. return self._repeatCommand(f, v, x);
  671. };
  672. this.orBegin = function () {
  673. _orDepth++;
  674. return self;
  675. };
  676. this.orEnd = function () {
  677. if (_query !== null) {
  678. _query += ")";
  679. }
  680. return self;
  681. };
  682. this.isNot = function (f) {
  683. _negate = !_negate;
  684. return self.is(f);
  685. };
  686. this.is = function (f) {
  687. self._append('this.' + f);
  688. self._resetNegate();
  689. return self;
  690. };
  691. this._compareValues = function (func, f, v, how, t) {
  692. var fld;
  693. if (_useProperties) {
  694. fld = 'jQuery.jgrid.getAccessor(this,\'' + f + '\')';
  695. } else {
  696. fld = 'this';
  697. }
  698. if (v === undefined) { v = null; }
  699. //var val=v===null?f:v,
  700. var val = v,
  701. swst = t.stype === undefined ? "text" : t.stype;
  702. if (v !== null) {
  703. switch (swst) {
  704. case 'int':
  705. case 'integer':
  706. val = (isNaN(Number(val)) || val === "") ? '0' : val; // To be fixed with more inteligent code
  707. fld = 'parseInt(' + fld + ',10)';
  708. val = 'parseInt(' + val + ',10)';
  709. break;
  710. case 'float':
  711. case 'number':
  712. case 'numeric':
  713. val = String(val).replace(_stripNum, '');
  714. val = (isNaN(Number(val)) || val === "") ? '0' : val; // To be fixed with more inteligent code
  715. fld = 'parseFloat(' + fld + ')';
  716. val = 'parseFloat(' + val + ')';
  717. break;
  718. case 'date':
  719. case 'datetime':
  720. val = String($.jgrid.parseDate.call($t, t.srcfmt || 'Y-m-d', val).getTime());
  721. fld = 'jQuery.jgrid.parseDate.call(jQuery("#' + $.jgrid.jqID($t.p.id) + '")[0],"' + t.srcfmt + '",' + fld + ').getTime()';
  722. break;
  723. default:
  724. fld = self._getStr(fld);
  725. val = self._getStr('"' + self._toStr(val) + '"');
  726. }
  727. }
  728. self._append(fld + ' ' + how + ' ' + val);
  729. self._setCommand(func, f);
  730. self._resetNegate();
  731. return self;
  732. };
  733. this.equals = function (f, v, t) {
  734. return self._compareValues(self.equals, f, v, "==", t);
  735. };
  736. this.notEquals = function (f, v, t) {
  737. return self._compareValues(self.equals, f, v, "!==", t);
  738. };
  739. this.isNull = function (f, v, t) {
  740. return self._compareValues(self.equals, f, null, "===", t);
  741. };
  742. this.greater = function (f, v, t) {
  743. return self._compareValues(self.greater, f, v, ">", t);
  744. };
  745. this.less = function (f, v, t) {
  746. return self._compareValues(self.less, f, v, "<", t);
  747. };
  748. this.greaterOrEquals = function (f, v, t) {
  749. return self._compareValues(self.greaterOrEquals, f, v, ">=", t);
  750. };
  751. this.lessOrEquals = function (f, v, t) {
  752. return self._compareValues(self.lessOrEquals, f, v, "<=", t);
  753. };
  754. this.startsWith = function (f, v) {
  755. var val = (v == null) ? f : v,
  756. length = _trim ? $.trim(val.toString()).length : val.toString().length;
  757. if (_useProperties) {
  758. self._append(self._getStr('jQuery.jgrid.getAccessor(this,\'' + f + '\')') + '.substr(0,' + length + ') == ' + self._getStr('"' + self._toStr(v) + '"'));
  759. } else {
  760. if (v != null) { length = _trim ? $.trim(v.toString()).length : v.toString().length; }
  761. self._append(self._getStr('this') + '.substr(0,' + length + ') == ' + self._getStr('"' + self._toStr(f) + '"'));
  762. }
  763. self._setCommand(self.startsWith, f);
  764. self._resetNegate();
  765. return self;
  766. };
  767. this.endsWith = function (f, v) {
  768. var val = (v == null) ? f : v,
  769. length = _trim ? $.trim(val.toString()).length : val.toString().length;
  770. if (_useProperties) {
  771. self._append(self._getStr('jQuery.jgrid.getAccessor(this,\'' + f + '\')') + '.substr(' + self._getStr('jQuery.jgrid.getAccessor(this,\'' + f + '\')') + '.length-' + length + ',' + length + ') == "' + self._toStr(v) + '"');
  772. } else {
  773. self._append(self._getStr('this') + '.substr(' + self._getStr('this') + '.length-"' + self._toStr(f) + '".length,"' + self._toStr(f) + '".length) == "' + self._toStr(f) + '"');
  774. }
  775. self._setCommand(self.endsWith, f); self._resetNegate();
  776. return self;
  777. };
  778. this.contains = function (f, v) {
  779. if (_useProperties) {
  780. self._append(self._getStr('jQuery.jgrid.getAccessor(this,\'' + f + '\')') + '.indexOf("' + self._toStr(v) + '",0) > -1');
  781. } else {
  782. self._append(self._getStr('this') + '.indexOf("' + self._toStr(f) + '",0) > -1');
  783. }
  784. self._setCommand(self.contains, f);
  785. self._resetNegate();
  786. return self;
  787. };
  788. this.groupBy = function (by, dir, type, datefmt) {
  789. if (!self._hasData()) {
  790. return null;
  791. }
  792. return self._getGroup(_data, by, dir, type, datefmt);
  793. };
  794. this.orderBy = function (by, dir, stype, dfmt, sfunc) {
  795. dir = dir == null ? "a" : $.trim(dir.toString().toLowerCase());
  796. if (stype == null) { stype = "text"; }
  797. if (dfmt == null) { dfmt = "Y-m-d"; }
  798. if (sfunc == null) { sfunc = false; }
  799. if (dir === "desc" || dir === "descending") { dir = "d"; }
  800. if (dir === "asc" || dir === "ascending") { dir = "a"; }
  801. _sorting.push({ by: by, dir: dir, type: stype, datefmt: dfmt, sfunc: sfunc });
  802. return self;
  803. };
  804. return self;
  805. };
  806. return new QueryObject(source, null);
  807. },
  808. getMethod: function (name) {
  809. return this.getAccessor($.fn.jqGrid, name);
  810. },
  811. extend: function (methods) {
  812. $.extend($.fn.jqGrid, methods);
  813. if (!this.no_legacy_api) {
  814. $.fn.extend(methods);
  815. }
  816. },
  817. clearBeforeUnload: function (jqGridId) {
  818. var $t = $("#" + $.jgrid.jqID(jqGridId))[0], grid;
  819. if (!$t.grid) { return; }
  820. grid = $t.grid;
  821. if ($.isFunction(grid.emptyRows)) {
  822. grid.emptyRows.call($t, true, true); // this work quick enough and reduce the size of memory leaks if we have someone
  823. }
  824. $(document).unbind("mouseup.jqGrid" + $t.p.id);
  825. $(grid.hDiv).unbind("mousemove"); // TODO add namespace
  826. $($t).unbind();
  827. var i, l = grid.headers.length,
  828. removevents = ['formatCol', 'sortData', 'updatepager', 'refreshIndex', 'setHeadCheckBox', 'constructTr', 'formatter', 'addXmlData', 'addJSONData', 'grid', 'p'];
  829. for (i = 0; i < l; i++) {
  830. grid.headers[i].el = null;
  831. }
  832. for (i in grid) {
  833. if (grid.hasOwnProperty(i)) {
  834. grid[i] = null;
  835. }
  836. }
  837. // experimental
  838. for (i in $t.p) {
  839. if ($t.p.hasOwnProperty(i)) {
  840. $t.p[i] = $.isArray($t.p[i]) ? [] : null;
  841. }
  842. }
  843. l = removevents.length;
  844. for (i = 0; i < l; i++) {
  845. if ($t.hasOwnProperty(removevents[i])) {
  846. $t[removevents[i]] = null;
  847. delete ($t[removevents[i]]);
  848. }
  849. }
  850. },
  851. gridUnload: function (jqGridId) {
  852. if (!jqGridId) { return; }
  853. jqGridId = $.trim(jqGridId);
  854. if (jqGridId.indexOf("#") === 0) {
  855. jqGridId = jqGridId.substring(1);
  856. }
  857. var $t = $("#" + $.jgrid.jqID(jqGridId))[0];
  858. if (!$t.grid) { return; }
  859. var defgrid = { id: $($t).attr('id'), cl: $($t).attr('class') };
  860. if ($t.p.pager) {
  861. $($t.p.pager).unbind().empty().removeClass("ui-state-default ui-jqgrid-pager ui-corner-bottom");
  862. }
  863. var newtable = document.createElement('table');
  864. newtable.className = defgrid.cl;
  865. var gid = $.jgrid.jqID($t.id);
  866. $(newtable).removeClass("ui-jqgrid-btable ui-common-table").insertBefore("#gbox_" + gid);
  867. if ($($t.p.pager).parents("#gbox_" + gid).length === 1) {
  868. $($t.p.pager).insertBefore("#gbox_" + gid);
  869. }
  870. $.jgrid.clearBeforeUnload(jqGridId);
  871. $("#gbox_" + gid).remove();
  872. $(newtable).attr({ id: defgrid.id });
  873. $("#alertmod_" + $.jgrid.jqID(jqGridId)).remove();
  874. },
  875. gridDestroy: function (jqGridId) {
  876. if (!jqGridId) { return; }
  877. jqGridId = $.trim(jqGridId);
  878. if (jqGridId.indexOf("#") === 0) {
  879. jqGridId = jqGridId.substring(1);
  880. }
  881. var $t = $("#" + $.jgrid.jqID(jqGridId))[0];
  882. if (!$t.grid) { return; }
  883. if ($t.p.pager) { // if not part of grid
  884. $($t.p.pager).remove();
  885. }
  886. try {
  887. $.jgrid.clearBeforeUnload(jqGridId);
  888. $("#gbox_" + $.jgrid.jqID(jqGridId)).remove();
  889. } catch (_) { }
  890. },
  891. styleUI: {
  892. jQueryUI: {
  893. common: {
  894. disabled: "ui-state-disabled",
  895. highlight: "ui-state-highlight",
  896. hover: "ui-state-hover",
  897. cornerall: "ui-corner-all",
  898. cornertop: "ui-corner-top",
  899. cornerbottom: "ui-corner-bottom",
  900. hidden: "ui-helper-hidden",
  901. icon_base: "ui-icon",
  902. overlay: "ui-widget-overlay",
  903. active: "ui-state-active",
  904. error: "ui-state-error",
  905. button: "ui-state-default ui-corner-all",
  906. content: "ui-widget-content"
  907. },
  908. base: {
  909. entrieBox: "ui-widget ui-widget-content ui-corner-all", // entrie div incl everthing
  910. viewBox: "", // view diw
  911. headerTable: "",
  912. headerBox: "ui-state-default",
  913. rowTable: "",
  914. rowBox: "ui-widget-content",
  915. footerTable: "",
  916. footerBox: "ui-widget-content",
  917. headerDiv: "ui-state-default",
  918. gridtitleBox: "ui-widget-header ui-corner-top ui-helper-clearfix",
  919. customtoolbarBox: "ui-state-default",
  920. //overlayBox: "ui-widget-overlay",
  921. loadingBox: "ui-state-default ui-state-active",
  922. rownumBox: "ui-state-default",
  923. scrollBox: "ui-widget-content",
  924. multiBox: "",
  925. pagerBox: "ui-state-default ui-corner-bottom",
  926. pagerTable: "",
  927. toppagerBox: "ui-state-default",
  928. pgInput: "ui-corner-all",
  929. pgSelectBox: "ui-widget-content ui-corner-all",
  930. pgButtonBox: "ui-corner-all",
  931. icon_first: "ui-icon-seek-first",
  932. icon_prev: "ui-icon-seek-prev",
  933. icon_next: "ui-icon-seek-next",
  934. icon_end: "ui-icon-seek-end",
  935. icon_asc: "ui-icon-triangle-1-n",
  936. icon_desc: "ui-icon-triangle-1-s",
  937. icon_caption_open: "ui-icon-circle-triangle-n",
  938. icon_caption_close: "ui-icon-circle-triangle-s"
  939. },
  940. modal: {
  941. modal: "ui-widget ui-widget-content ui-corner-all ui-dialog",
  942. header: "ui-widget-header ui-corner-all ui-helper-clearfix",
  943. content: "ui-widget-content",
  944. resizable: "ui-resizable-handle ui-resizable-se",
  945. icon_close: "ui-icon-closethick",
  946. icon_resizable: "ui-icon-gripsmall-diagonal-se"
  947. },
  948. celledit: {
  949. inputClass: "ui-widget-content ui-corner-all"
  950. },
  951. inlinedit: {
  952. inputClass: "ui-widget-content ui-corner-all",
  953. icon_edit_nav: "ui-icon-pencil",
  954. icon_add_nav: "ui-icon-plus",
  955. icon_save_nav: "ui-icon-disk",
  956. icon_cancel_nav: "ui-icon-cancel"
  957. },
  958. formedit: {
  959. inputClass: "ui-widget-content ui-corner-all",
  960. icon_prev: "ui-icon-triangle-1-w",
  961. icon_next: "ui-icon-triangle-1-e",
  962. icon_save: "ui-icon-disk",
  963. icon_close: "ui-icon-close",
  964. icon_del: "ui-icon-scissors",
  965. icon_cancel: "ui-icon-cancel"
  966. },
  967. navigator: {
  968. icon_edit_nav: "ui-icon-pencil",
  969. icon_add_nav: "ui-icon-plus",
  970. icon_del_nav: "ui-icon-trash",
  971. icon_search_nav: "ui-icon-search",
  972. icon_refresh_nav: "ui-icon-refresh",
  973. icon_view_nav: "ui-icon-document",
  974. icon_newbutton_nav: "ui-icon-newwin"
  975. },
  976. grouping: {
  977. icon_plus: 'ui-icon-circlesmall-plus',
  978. icon_minus: 'ui-icon-circlesmall-minus'
  979. },
  980. filter: {
  981. table_widget: 'ui-widget ui-widget-content',
  982. srSelect: 'ui-widget-content ui-corner-all',
  983. srInput: 'ui-widget-content ui-corner-all',
  984. menu_widget: 'ui-widget ui-widget-content ui-corner-all',
  985. icon_search: 'ui-icon-search',
  986. icon_reset: 'ui-icon-arrowreturnthick-1-w',
  987. icon_query: 'ui-icon-comment'
  988. },
  989. subgrid: {
  990. icon_plus: 'ui-icon-plus',
  991. icon_minus: 'ui-icon-minus',
  992. icon_open: 'ui-icon-carat-1-sw'
  993. },
  994. treegrid: {
  995. icon_plus: 'ui-icon-triangle-1-',
  996. icon_minus: 'ui-icon-triangle-1-s',
  997. icon_leaf: 'ui-icon-radio-off'
  998. },
  999. fmatter: {
  1000. icon_edit: "ui-icon-pencil",
  1001. icon_add: "ui-icon-plus",
  1002. icon_save: "ui-icon-disk",
  1003. icon_cancel: "ui-icon-cancel",
  1004. icon_del: "ui-icon-trash"
  1005. },
  1006. colmenu: {
  1007. menu_widget: 'ui-widget ui-widget-content ui-corner-all',
  1008. input_checkbox: "ui-widget ui-widget-content",
  1009. filter_select: "ui-widget-content ui-corner-all",
  1010. filter_input: "ui-widget-content ui-corner-all",
  1011. icon_menu: "ui-icon-comment",
  1012. icon_sort_asc: "ui-icon-arrow-1-n",
  1013. icon_sort_desc: "ui-icon-arrow-1-s",
  1014. icon_columns: "ui-icon-extlink",
  1015. icon_filter: "ui-icon-calculator",
  1016. icon_group: "ui-icon-grip-solid-horizontal",
  1017. icon_freeze: "ui-icon-grip-solid-vertical",
  1018. icon_move: "ui-icon-arrow-4"
  1019. }
  1020. },
  1021. Bootstrap: {
  1022. common: {
  1023. disabled: "ui-disabled",
  1024. highlight: "success",
  1025. hover: "active",
  1026. cornerall: "",
  1027. cornertop: "",
  1028. cornerbottom: "",
  1029. hidden: "",
  1030. icon_base: "glyphicon",
  1031. overlay: "ui-overlay",
  1032. active: "active",
  1033. error: "bg-danger",
  1034. button: "btn btn-default",
  1035. content: ""
  1036. },
  1037. base: {
  1038. entrieBox: "",
  1039. viewBox: "table-responsive",
  1040. headerTable: "table table-bordered",
  1041. headerBox: "",
  1042. rowTable: "table table-bordered",
  1043. rowBox: "",
  1044. footerTable: "table table-bordered",
  1045. footerBox: "",
  1046. headerDiv: "",
  1047. gridtitleBox: "",
  1048. customtoolbarBox: "",
  1049. //overlayBox: "ui-overlay",
  1050. loadingBox: "row",
  1051. rownumBox: "",
  1052. scrollBox: "",
  1053. multiBox: "checkbox",
  1054. pagerBox: "",
  1055. pagerTable: "table",
  1056. toppagerBox: "",
  1057. pgInput: "form-control",
  1058. pgSelectBox: "form-control",
  1059. pgButtonBox: "",
  1060. icon_first: "glyphicon-step-backward",
  1061. icon_prev: "glyphicon-backward",
  1062. icon_next: "glyphicon-forward",
  1063. icon_end: "glyphicon-step-forward",
  1064. icon_asc: "glyphicon-triangle-top",
  1065. icon_desc: "glyphicon-triangle-bottom",
  1066. icon_caption_open: "glyphicon-circle-arrow-up",
  1067. icon_caption_close: "glyphicon-circle-arrow-down"
  1068. },
  1069. modal: {
  1070. modal: "modal-content",
  1071. header: "modal-header",
  1072. title: "modal-title",
  1073. content: "modal-body",
  1074. resizable: "ui-resizable-handle ui-resizable-se",
  1075. icon_close: "glyphicon-remove-circle",
  1076. icon_resizable: "glyphicon-import"
  1077. },
  1078. celledit: {
  1079. inputClass: 'form-control'
  1080. },
  1081. inlinedit: {
  1082. inputClass: 'form-control',
  1083. icon_edit_nav: "glyphicon-edit",
  1084. icon_add_nav: "glyphicon-plus",
  1085. icon_save_nav: "glyphicon-save",
  1086. icon_cancel_nav: "glyphicon-remove-circle"
  1087. },
  1088. formedit: {
  1089. inputClass: "form-control",
  1090. icon_prev: "glyphicon-step-backward",
  1091. icon_next: "glyphicon-step-forward",
  1092. icon_save: "glyphicon-save",
  1093. icon_close: "glyphicon-remove-circle",
  1094. icon_del: "glyphicon-trash",
  1095. icon_cancel: "glyphicon-remove-circle"
  1096. },
  1097. navigator: {
  1098. icon_edit_nav: "glyphicon-edit",
  1099. icon_add_nav: "glyphicon-plus",
  1100. icon_del_nav: "glyphicon-trash",
  1101. icon_search_nav: "glyphicon-search",
  1102. icon_refresh_nav: "glyphicon-refresh",
  1103. icon_view_nav: "glyphicon-info-sign",
  1104. icon_newbutton_nav: "glyphicon-new-window"
  1105. },
  1106. grouping: {
  1107. icon_plus: 'glyphicon-triangle-right',
  1108. icon_minus: 'glyphicon-triangle-bottom'
  1109. },
  1110. filter: {
  1111. table_widget: 'table table-condensed',
  1112. srSelect: 'form-control',
  1113. srInput: 'form-control',
  1114. menu_widget: '',
  1115. icon_search: 'glyphicon-search',
  1116. icon_reset: 'glyphicon-refresh',
  1117. icon_query: 'glyphicon-comment'
  1118. },
  1119. subgrid: {
  1120. icon_plus: 'glyphicon-triangle-right',
  1121. icon_minus: 'glyphicon-triangle-bottom',
  1122. icon_open: 'glyphicon-indent-left'
  1123. },
  1124. treegrid: {
  1125. icon_plus: 'glyphicon-triangle-right',
  1126. icon_minus: 'glyphicon-triangle-bottom',
  1127. icon_leaf: 'glyphicon-unchecked'
  1128. },
  1129. fmatter: {
  1130. icon_edit: "glyphicon-edit",
  1131. icon_add: "glyphicon-plus",
  1132. icon_save: "glyphicon-save",
  1133. icon_cancel: "glyphicon-remove-circle",
  1134. icon_del: "glyphicon-trash"
  1135. },
  1136. colmenu: {
  1137. menu_widget: '',
  1138. input_checkbox: "",
  1139. filter_select: "form-control",
  1140. filter_input: "form-control",
  1141. icon_menu: "glyphicon-menu-hamburger",
  1142. icon_sort_asc: "glyphicon-sort-by-alphabet",
  1143. icon_sort_desc: "glyphicon-sort-by-alphabet-alt",
  1144. icon_columns: "glyphicon-list-alt",
  1145. icon_filter: "glyphicon-filter",
  1146. icon_group: "glyphicon-align-left",
  1147. icon_freeze: "glyphicon-object-align-horizontal",
  1148. icon_move: "glyphicon-move"
  1149. }
  1150. }
  1151. }
  1152. });
  1153. $.fn.jqGrid = function (pin) {
  1154. if (typeof pin === 'string') {
  1155. var fn = $.jgrid.getMethod(pin);
  1156. if (!fn) {
  1157. throw ("jqGrid - No such method: " + pin);
  1158. }
  1159. var args = $.makeArray(arguments).slice(1);
  1160. return fn.apply(this, args);
  1161. }
  1162. return this.each(function () {
  1163. if (this.grid) { return; }
  1164. var localData;
  1165. if (pin != null && pin.data !== undefined) {
  1166. localData = pin.data;
  1167. pin.data = [];
  1168. }
  1169. var p = $.extend(true, {
  1170. unwritten: true,
  1171. url: "",
  1172. height: 150,
  1173. page: 1,
  1174. rowNum: 20,
  1175. rowTotal: null,
  1176. records: 0,
  1177. pager: "",
  1178. pgbuttons: true,
  1179. pginput: true,
  1180. colModel: [],
  1181. rowList: [20,50, 100, 150,200,500,1000],
  1182. colNames: [],
  1183. sortorder: "asc",
  1184. sortname: "",
  1185. datatype: "xml",
  1186. mtype: "GET",
  1187. altRows: false,
  1188. selarrrow: [],
  1189. savedRow: [],
  1190. shrinkToFit: true,
  1191. xmlReader: {},
  1192. jsonReader: {},
  1193. subGrid: false,
  1194. subGridModel: [],
  1195. reccount: 0,
  1196. lastpage: 0,
  1197. lastsort: 0,
  1198. selrow: null,
  1199. beforeSelectRow: null,
  1200. onSelectRow: null,
  1201. onSortCol: null,
  1202. ondblClickRow: null,
  1203. onRightClickRow: null,
  1204. onPaging: null,
  1205. onSelectAll: null,
  1206. onInitGrid: null,
  1207. loadComplete: null,
  1208. gridComplete: null,
  1209. loadError: null,
  1210. loadBeforeSend: null,
  1211. afterInsertRow: null,
  1212. beforeRequest: null,
  1213. beforeProcessing: null,
  1214. onHeaderClick: null,
  1215. viewrecords: false,
  1216. loadonce: false,
  1217. multiselect: false,
  1218. multikey: false,
  1219. editurl: null,
  1220. search: false,
  1221. caption: "",
  1222. hidegrid: false,
  1223. hiddengrid: false,
  1224. postData: {},
  1225. userData: {},
  1226. treeGrid: false,
  1227. treeGridModel: 'nested',
  1228. treeReader: {},
  1229. treeANode: -1,
  1230. ExpandColumn: null,
  1231. tree_root_level: 0,
  1232. prmNames: {
  1233. page: "page",
  1234. rows: "rows",
  1235. sort: "sidx",
  1236. order: "sord",
  1237. search: "_search",
  1238. nd: "nd",
  1239. id: "id",
  1240. oper: "oper",
  1241. editoper: "edit",
  1242. addoper: "add",
  1243. deloper: "del",
  1244. subgridid: "id",
  1245. npage: null,
  1246. totalrows: "totalrows"
  1247. },
  1248. forceFit: false,
  1249. gridstate: "visible",
  1250. cellEdit: false,
  1251. cellsubmit: "remote",
  1252. nv: 0,
  1253. loadui: "enable",
  1254. toolbar: [false, ""],
  1255. scroll: false,
  1256. multiboxonly: false,
  1257. deselectAfterSort: true,
  1258. scrollrows: false,
  1259. autowidth: false,
  1260. scrollOffset: 18,
  1261. cellLayout: 5,
  1262. subGridWidth: 20,
  1263. multiselectWidth: 30,
  1264. gridview: true,
  1265. rownumWidth: 28,
  1266. rownumbers: false,
  1267. pagerpos: 'center',
  1268. recordpos: 'right',
  1269. footerrow: false,
  1270. userDataOnFooter: false,
  1271. hoverrows: true,
  1272. altclass: 'ui-priority-secondary',
  1273. viewsortcols: [false, 'vertical', true],
  1274. resizeclass: '',
  1275. autoencode: false,
  1276. remapColumns: [],
  1277. ajaxGridOptions: {},
  1278. direction: "ltr",
  1279. toppager: false,
  1280. headertitles: false,
  1281. scrollTimeout: 40,
  1282. data: [],
  1283. _index: {},
  1284. grouping: false,
  1285. groupingView: {
  1286. groupField: [],
  1287. groupOrder: [],
  1288. groupText: [],
  1289. groupColumnShow: [],
  1290. groupSummary: [],
  1291. showSummaryOnHide: false,
  1292. sortitems: [],
  1293. sortnames: [],
  1294. summary: [],
  1295. summaryval: [],
  1296. plusicon: '',
  1297. minusicon: '',
  1298. displayField: [],
  1299. groupSummaryPos: [],
  1300. formatDisplayField: [],
  1301. _locgr: false
  1302. },
  1303. ignoreCase: true,
  1304. cmTemplate: {},
  1305. idPrefix: "",
  1306. multiSort: false,
  1307. minColWidth: 33,
  1308. scrollPopUp: false,
  1309. scrollTopOffset: 0, // pixel
  1310. scrollLeftOffset: "100%", //percent
  1311. storeNavOptions: false,
  1312. regional: "en",
  1313. styleUI: "Bootstrap",
  1314. responsive: false,
  1315. restoreCellonFail: true,
  1316. colFilters: {},
  1317. colMenu: false
  1318. }, $.jgrid.defaults, pin);
  1319. if (localData !== undefined) {
  1320. p.data = localData;
  1321. pin.data = localData;
  1322. }
  1323. var ts = this, grid = {
  1324. headers: [],
  1325. cols: [],
  1326. footers: [],
  1327. dragStart: function (i, x, y) {
  1328. var gridLeftPos = $(this.bDiv).offset().left;
  1329. this.resizing = { idx: i, startX: x.pageX, sOL: x.pageX - gridLeftPos };
  1330. this.hDiv.style.cursor = "col-resize";
  1331. this.curGbox = $("#rs_m" + $.jgrid.jqID(p.id), "#gbox_" + $.jgrid.jqID(p.id));
  1332. this.curGbox.css({ display: "block", left: x.pageX - gridLeftPos, top: y[1], height: y[2] });
  1333. $(ts).triggerHandler("jqGridResizeStart", [x, i]);
  1334. if ($.isFunction(p.resizeStart)) { p.resizeStart.call(ts, x, i); }
  1335. document.onselectstart = function () { return false; };
  1336. },
  1337. dragMove: function (x) {
  1338. if (this.resizing) {
  1339. var diff = x.pageX - this.resizing.startX,
  1340. h = this.headers[this.resizing.idx],
  1341. newWidth = p.direction === "ltr" ? h.width + diff : h.width - diff, hn, nWn;
  1342. if (newWidth > 33) {
  1343. this.curGbox.css({ left: this.resizing.sOL + diff });
  1344. if (p.forceFit === true) {
  1345. hn = this.headers[this.resizing.idx + p.nv];
  1346. nWn = p.direction === "ltr" ? hn.width - diff : hn.width + diff;
  1347. if (nWn > p.minColWidth) {
  1348. h.newWidth = newWidth;
  1349. hn.newWidth = nWn;
  1350. }
  1351. } else {
  1352. this.newWidth = p.direction === "ltr" ? p.tblwidth + diff : p.tblwidth - diff;
  1353. h.newWidth = newWidth;
  1354. }
  1355. }
  1356. }
  1357. },
  1358. dragEnd: function (events) {
  1359. this.hDiv.style.cursor = "default";
  1360. if (this.resizing) {
  1361. var idx = this.resizing.idx,
  1362. nw = this.headers[idx].newWidth || this.headers[idx].width;
  1363. nw = parseInt(nw, 10);
  1364. this.resizing = false;
  1365. $("#rs_m" + $.jgrid.jqID(p.id)).css("display", "none");
  1366. p.colModel[idx].width = nw;
  1367. this.headers[idx].width = nw;
  1368. this.headers[idx].el.style.width = nw + "px";
  1369. this.cols[idx].style.width = nw + "px";
  1370. if (this.footers.length > 0) { this.footers[idx].style.width = nw + "px"; }
  1371. if (p.forceFit === true) {
  1372. nw = this.headers[idx + p.nv].newWidth || this.headers[idx + p.nv].width;
  1373. this.headers[idx + p.nv].width = nw;
  1374. this.headers[idx + p.nv].el.style.width = nw + "px";
  1375. this.cols[idx + p.nv].style.width = nw + "px";
  1376. if (this.footers.length > 0) { this.footers[idx + p.nv].style.width = nw + "px"; }
  1377. p.colModel[idx + p.nv].width = nw;
  1378. } else {
  1379. p.tblwidth = this.newWidth || p.tblwidth;
  1380. $('table:first', this.bDiv).css("width", p.tblwidth + "px");
  1381. $('table:first', this.hDiv).css("width", p.tblwidth + "px");
  1382. this.hDiv.scrollLeft = this.bDiv.scrollLeft;
  1383. if (p.footerrow) {
  1384. $('table:first', this.sDiv).css("width", p.tblwidth + "px");
  1385. this.sDiv.scrollLeft = this.bDiv.scrollLeft;
  1386. }
  1387. }
  1388. if (events) {
  1389. $(ts).triggerHandler("jqGridResizeStop", [nw, idx]);
  1390. if ($.isFunction(p.resizeStop)) { p.resizeStop.call(ts, nw, idx); }
  1391. }
  1392. }
  1393. this.curGbox = null;
  1394. document.onselectstart = function () { return true; };
  1395. },
  1396. populateVisible: function () {
  1397. if (grid.timer) { clearTimeout(grid.timer); }
  1398. grid.timer = null;
  1399. var dh = $(grid.bDiv).height();
  1400. if (!dh) { return; }
  1401. var table = $("table:first", grid.bDiv);
  1402. var rows, rh;
  1403. if (table[0].rows.length) {
  1404. try {
  1405. rows = table[0].rows[1];
  1406. rh = rows ? $(rows).outerHeight() || grid.prevRowHeight : grid.prevRowHeight;
  1407. } catch (pv) {
  1408. rh = grid.prevRowHeight;
  1409. }
  1410. }
  1411. if (!rh) { return; }
  1412. grid.prevRowHeight = rh;
  1413. var rn = p.rowNum;
  1414. var scrollTop = grid.scrollTop = grid.bDiv.scrollTop;
  1415. var ttop = Math.round(table.position().top) - scrollTop;
  1416. var tbot = ttop + table.height();
  1417. var div = rh * rn;
  1418. var page, npage, empty;
  1419. if (tbot < dh && ttop <= 0 &&
  1420. (p.lastpage === undefined || (parseInt((tbot + scrollTop + div - 1) / div, 10) || 0) <= p.lastpage)) {
  1421. npage = parseInt((dh - tbot + div - 1) / div, 10) || 1;
  1422. if (tbot >= 0 || npage < 2 || p.scroll === true) {
  1423. page = (Math.round((tbot + scrollTop) / div) || 0) + 1;
  1424. ttop = -1;
  1425. } else {
  1426. ttop = 1;
  1427. }
  1428. }
  1429. if (ttop > 0) {
  1430. page = (parseInt(scrollTop / div, 10) || 0) + 1;
  1431. npage = (parseInt((scrollTop + dh) / div, 10) || 0) + 2 - page;
  1432. empty = true;
  1433. }
  1434. if (npage) {
  1435. if (p.lastpage && (page > p.lastpage || p.lastpage === 1 || (page === p.page && page === p.lastpage))) {
  1436. return;
  1437. }
  1438. if (grid.hDiv.loading) {
  1439. grid.timer = setTimeout(grid.populateVisible, p.scrollTimeout);
  1440. } else {
  1441. p.page = page;
  1442. if (empty) {
  1443. grid.selectionPreserver(table[0]);
  1444. grid.emptyRows.call(table[0], false, false);
  1445. }
  1446. grid.populate(npage);
  1447. }
  1448. if (p.scrollPopUp && p.lastpage != null) {
  1449. $("#scroll_g" + p.id).show().html($.jgrid.template($.jgrid.getRegional(ts, "defaults.pgtext", p.pgtext), p.page, p.lastpage)).css({ "top": p.scrollTopOffset + scrollTop * ((parseInt(p.height, 10) - 45) / (parseInt(rh, 10) * parseInt(p.records, 10))) + "px", "left": p.scrollLeftOffset });
  1450. $(this).mouseout(function () {
  1451. $("#scroll_g" + p.id).hide();
  1452. });
  1453. }
  1454. }
  1455. },
  1456. scrollGrid: function (e) {
  1457. if (p.scroll) {
  1458. var scrollTop = grid.bDiv.scrollTop;
  1459. if (grid.scrollTop === undefined) { grid.scrollTop = 0; }
  1460. if (scrollTop !== grid.scrollTop) {
  1461. grid.scrollTop = scrollTop;
  1462. if (grid.timer) { clearTimeout(grid.timer); }
  1463. grid.timer = setTimeout(grid.populateVisible, p.scrollTimeout);
  1464. }
  1465. }
  1466. grid.hDiv.scrollLeft = grid.bDiv.scrollLeft;
  1467. if (p.footerrow) {
  1468. grid.sDiv.scrollLeft = grid.bDiv.scrollLeft;
  1469. }
  1470. if (p.frozenColumns) {
  1471. $(grid.fbDiv).scrollTop(grid.bDiv.scrollTop);
  1472. }
  1473. if (e) { e.stopPropagation(); }
  1474. },
  1475. selectionPreserver: function (ts) {
  1476. var p = ts.p,
  1477. sr = p.selrow, sra = p.selarrrow ? $.makeArray(p.selarrrow) : null,
  1478. left = ts.grid.bDiv.scrollLeft,
  1479. restoreSelection = function () {
  1480. var i;
  1481. p.selrow = null;
  1482. p.selarrrow = [];
  1483. if (p.multiselect && sra && sra.length > 0) {
  1484. for (i = 0; i < sra.length; i++) {
  1485. if (sra[i] !== sr) {
  1486. $(ts).jqGrid("setSelection", sra[i], false, null);
  1487. }
  1488. }
  1489. }
  1490. if (sr) {
  1491. $(ts).jqGrid("setSelection", sr, false, null);
  1492. }
  1493. ts.grid.bDiv.scrollLeft = left;
  1494. $(ts).unbind('.selectionPreserver', restoreSelection);
  1495. };
  1496. $(ts).bind('jqGridGridComplete.selectionPreserver', restoreSelection);
  1497. }
  1498. };
  1499. if (this.tagName.toUpperCase() !== 'TABLE' || this.id == null) {
  1500. alert("元素不是表或没有id!");
  1501. return;
  1502. }
  1503. if (document.documentMode !== undefined) { // IE only
  1504. if (document.documentMode <= 5) {
  1505. alert("Grid can not be used in this ('quirks') mode!");
  1506. return;
  1507. }
  1508. }
  1509. var i = 0, lr, lk, dir;
  1510. for (lk in $.jgrid.regional) {
  1511. if ($.jgrid.regional.hasOwnProperty(lk)) {
  1512. if (i === 0) { lr = lk; }
  1513. i++;
  1514. }
  1515. }
  1516. if (i === 1 && lr !== p.regional) {
  1517. p.regional = lr;
  1518. }
  1519. $(this).empty().attr("tabindex", "0");
  1520. this.p = p;
  1521. this.p.useProp = !!$.fn.prop;
  1522. if (this.p.colNames.length === 0) {
  1523. for (i = 0; i < this.p.colModel.length; i++) {
  1524. this.p.colNames[i] = this.p.colModel[i].label || this.p.colModel[i].name;
  1525. }
  1526. }
  1527. if (this.p.colNames.length !== this.p.colModel.length) {
  1528. alert($.jgrid.getRegional(this, "errors.model"));
  1529. return;
  1530. }
  1531. var getstyle = $.jgrid.getMethod("getStyleUI"),
  1532. stylemodule = ts.p.styleUI + ".common",
  1533. disabled = getstyle(stylemodule, 'disabled', true),
  1534. highlight = getstyle(stylemodule, 'highlight', true),
  1535. hover = getstyle(stylemodule, 'hover', true),
  1536. cornerall = getstyle(stylemodule, 'cornerall', true),
  1537. iconbase = getstyle(stylemodule, 'icon_base', true),
  1538. colmenustyle = $.jgrid.styleUI[(ts.p.styleUI || 'jQueryUI')].colmenu,
  1539. isMSIE = $.jgrid.msie,
  1540. gv, sortarr = [], sortord = [], sotmp = [];
  1541. stylemodule = ts.p.styleUI + ".base";
  1542. gv = $("<div " + getstyle(stylemodule, 'viewBox', false, 'ui-jqgrid-view') + " role='grid'></div>");
  1543. ts.p.direction = $.trim(ts.p.direction.toLowerCase());
  1544. ts.p._ald = false;
  1545. if ($.inArray(ts.p.direction, ["ltr", "rtl"]) === -1) { ts.p.direction = "ltr"; }
  1546. dir = ts.p.direction;
  1547. $(gv).insertBefore(this);
  1548. $(this).appendTo(gv);
  1549. var eg = $("<div " + getstyle(stylemodule, 'entrieBox', false, 'ui-jqgrid') + "></div>");
  1550. $(eg).attr({ "id": "gbox_" + this.id, "dir": dir }).insertBefore(gv);
  1551. $(gv).attr("id", "gview_" + this.id).appendTo(eg);
  1552. $("<div " + getstyle(ts.p.styleUI + '.common', 'overlay', false, 'jqgrid-overlay') + " id='lui_" + this.id + "'></div>").insertBefore(gv);
  1553. $("<div " + getstyle(stylemodule, 'loadingBox', false, 'loading') + " id='load_" + this.id + "'>" + $.jgrid.getRegional(ts, "defaults.loadtext", this.p.loadtext) + "</div>").insertBefore(gv);
  1554. $(this).attr({ role: "presentation", "aria-multiselectable": !!this.p.multiselect, "aria-labelledby": "gbox_" + this.id });
  1555. var sortkeys = ["shiftKey", "altKey", "ctrlKey"],
  1556. intNum = function (val, defval) {
  1557. val = parseInt(val, 10);
  1558. if (isNaN(val)) { return defval || 0; }
  1559. return val;
  1560. },
  1561. formatCol = function (pos, rowInd, tv, rawObject, rowId, rdata) {
  1562. var cm = ts.p.colModel[pos], cellAttrFunc,
  1563. ral = cm.align, result = "style=\"", clas = cm.classes, nm = cm.name, celp, acp = [];
  1564. if (ral) { result += "text-align:" + ral + ";"; }
  1565. if (cm.hidden === true) { result += "display:none;"; }
  1566. if (rowInd === 0) {
  1567. result += "width: " + grid.headers[pos].width + "px;";
  1568. } else if ($.isFunction(cm.cellattr) || (typeof cm.cellattr === "string" && $.jgrid.cellattr != null && $.isFunction($.jgrid.cellattr[cm.cellattr]))) {
  1569. cellAttrFunc = $.isFunction(cm.cellattr) ? cm.cellattr : $.jgrid.cellattr[cm.cellattr];
  1570. celp = cellAttrFunc.call(ts, rowId, tv, rawObject, cm, rdata);
  1571. if (celp && typeof celp === "string") {
  1572. celp = celp.replace(/style/i, 'style').replace(/title/i, 'title');
  1573. if (celp.indexOf('title') > -1) { cm.title = false; }
  1574. if (celp.indexOf('class') > -1) { clas = undefined; }
  1575. acp = celp.replace(/\-style/g, '-sti').split(/style/);
  1576. if (acp.length === 2) {
  1577. acp[1] = $.trim(acp[1].replace(/\-sti/g, '-style').replace("=", ""));
  1578. if (acp[1].indexOf("'") === 0 || acp[1].indexOf('"') === 0) {
  1579. acp[1] = acp[1].substring(1);
  1580. }
  1581. result += acp[1].replace(/'/gi, '"');
  1582. } else {
  1583. result += "\"";
  1584. }
  1585. }
  1586. }
  1587. if (!acp.length) { acp[0] = ""; result += "\""; }
  1588. result += (clas !== undefined ? (" class=\"" + clas + "\"") : "") + ((cm.title && tv) ? (" title=\"" + $.jgrid.stripHtml(tv) + "\"") : "");
  1589. result += " aria-describedby=\"" + ts.p.id + "_" + nm + "\"";
  1590. return result + acp[0];
  1591. },
  1592. cellVal = function (val) {
  1593. return val == null || val === "" ? "&#160;" : (ts.p.autoencode ? $.jgrid.htmlEncode(val) : String(val));
  1594. },
  1595. formatter = function (rowId, cellval, colpos, rwdat, _act) {
  1596. var cm = ts.p.colModel[colpos], v;
  1597. if (cm.formatter !== undefined) {
  1598. rowId = String(ts.p.idPrefix) !== "" ? $.jgrid.stripPref(ts.p.idPrefix, rowId) : rowId;
  1599. var opts = { rowId: rowId, colModel: cm, gid: ts.p.id, pos: colpos, styleUI: ts.p.styleUI };
  1600. if ($.isFunction(cm.formatter)) {
  1601. v = cm.formatter.call(ts, cellval, opts, rwdat, _act);
  1602. } else if ($.fmatter) {
  1603. v = $.fn.fmatter.call(ts, cm.formatter, cellval, opts, rwdat, _act);
  1604. } else {
  1605. v = cellVal(cellval);
  1606. }
  1607. } else {
  1608. v = cellVal(cellval);
  1609. }
  1610. return v;
  1611. },
  1612. addCell = function (rowId, cell, pos, irow, srvr, rdata) {
  1613. var v, prp;
  1614. v = formatter(rowId, cell, pos, srvr, 'add');
  1615. prp = formatCol(pos, irow, v, srvr, rowId, rdata);
  1616. return "<td role=\"gridcell\" " + prp + ">" + v + "</td>";
  1617. },
  1618. addMulti = function (rowid, pos, irow, checked, uiclass) {
  1619. var v = "<input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + ts.p.id + "_" + rowid + "\" " + uiclass + " name=\"jqg_" + ts.p.id + "_" + rowid + "\"" + (checked ? "checked=\"checked\"" : "") + "/>",
  1620. prp = formatCol(pos, irow, '', null, rowid, true);
  1621. return "<td role=\"gridcell\" " + prp + ">" + v + "</td>";
  1622. },
  1623. addRowNum = function (pos, irow, pG, rN, uiclass) {
  1624. var v = (parseInt(pG, 10) - 1) * parseInt(rN, 10) + 1 + irow,
  1625. prp = formatCol(pos, irow, v, null, irow, true);
  1626. return "<td role=\"gridcell\" " + uiclass + " " + prp + ">" + v + "</td>";
  1627. },
  1628. reader = function (datatype) {
  1629. var field, f = [], j = 0, i;
  1630. for (i = 0; i < ts.p.colModel.length; i++) {
  1631. field = ts.p.colModel[i];
  1632. if (field.name !== 'cb' && field.name !== 'subgrid' && field.name !== 'rn') {
  1633. f[j] = datatype === "local" ?
  1634. field.name :
  1635. ((datatype === "xml" || datatype === "xmlstring") ? field.xmlmap || field.name : field.jsonmap || field.name);
  1636. if (ts.p.keyName !== false && field.key === true) {
  1637. ts.p.keyName = f[j];
  1638. }
  1639. j++;
  1640. }
  1641. }
  1642. return f;
  1643. },
  1644. orderedCols = function (offset) {
  1645. var order = ts.p.remapColumns;
  1646. if (!order || !order.length) {
  1647. order = $.map(ts.p.colModel, function (v, i) { return i; });
  1648. }
  1649. if (offset) {
  1650. order = $.map(order, function (v) { return v < offset ? null : v - offset; });
  1651. }
  1652. return order;
  1653. },
  1654. emptyRows = function (scroll, locdata) {
  1655. var firstrow;
  1656. if (this.p.deepempty) {
  1657. $(this.rows).slice(1).remove();
  1658. } else {
  1659. firstrow = this.rows.length > 0 ? this.rows[0] : null;
  1660. $(this.firstChild).empty().append(firstrow);
  1661. }
  1662. if (scroll && this.p.scroll) {
  1663. $(this.grid.bDiv.firstChild).css({ height: "auto" });
  1664. $(this.grid.bDiv.firstChild.firstChild).css({ height: "0px", display: "none" });
  1665. if (this.grid.bDiv.scrollTop !== 0) {
  1666. this.grid.bDiv.scrollTop = 0;
  1667. }
  1668. }
  1669. if (locdata === true && this.p.treeGrid && !this.p.loadonce) {
  1670. this.p.data = []; this.p._index = {};
  1671. }
  1672. },
  1673. normalizeData = function () {
  1674. var p = ts.p, data = p.data, dataLength = data.length, i, j, cur, idn, idr, ccur, v, rd,
  1675. localReader = p.localReader,
  1676. colModel = p.colModel,
  1677. cellName = localReader.cell,
  1678. iOffset = (p.multiselect === true ? 1 : 0) + (p.subGrid === true ? 1 : 0) + (p.rownumbers === true ? 1 : 0),
  1679. br = p.scroll ? $.jgrid.randId() : 1,
  1680. arrayReader, objectReader, rowReader;
  1681. if (p.datatype !== "local" || localReader.repeatitems !== true) {
  1682. return; // nothing to do
  1683. }
  1684. arrayReader = orderedCols(iOffset);
  1685. objectReader = reader("local");
  1686. // read ALL input items and convert items to be read by
  1687. // $.jgrid.getAccessor with column name as the second parameter
  1688. idn = p.keyIndex === false ?
  1689. ($.isFunction(localReader.id) ? localReader.id.call(ts, data) : localReader.id) :
  1690. p.keyIndex;
  1691. for (i = 0; i < dataLength; i++) {
  1692. cur = data[i];
  1693. // read id in the same way like addJSONData do
  1694. // probably it would be better to start with "if (cellName) {...}"
  1695. // but the goal of the current implementation was just have THE SAME
  1696. // id values like in addJSONData ...
  1697. idr = $.jgrid.getAccessor(cur, idn);
  1698. if (idr === undefined) {
  1699. if (typeof idn === "number" && colModel[idn + iOffset] != null) {
  1700. // reread id by name
  1701. idr = $.jgrid.getAccessor(cur, colModel[idn + iOffset].name);
  1702. }
  1703. if (idr === undefined) {
  1704. idr = br + i;
  1705. if (cellName) {
  1706. ccur = $.jgrid.getAccessor(cur, cellName) || cur;
  1707. idr = ccur != null && ccur[idn] !== undefined ? ccur[idn] : idr;
  1708. ccur = null;
  1709. }
  1710. }
  1711. }
  1712. rd = {};
  1713. rd[localReader.id] = idr;
  1714. if (cellName) {
  1715. cur = $.jgrid.getAccessor(cur, cellName) || cur;
  1716. }
  1717. rowReader = $.isArray(cur) ? arrayReader : objectReader;
  1718. for (j = 0; j < rowReader.length; j++) {
  1719. v = $.jgrid.getAccessor(cur, rowReader[j]);
  1720. rd[colModel[j + iOffset].name] = v;
  1721. }
  1722. $.extend(true, data[i], rd);
  1723. }
  1724. },
  1725. refreshIndex = function () {
  1726. var datalen = ts.p.data.length, idname, i, val;
  1727. if (ts.p.keyName === false || ts.p.loadonce === true) {
  1728. idname = ts.p.localReader.id;
  1729. } else {
  1730. idname = ts.p.keyName;
  1731. }
  1732. ts.p._index = [];
  1733. for (i = 0; i < datalen; i++) {
  1734. val = $.jgrid.getAccessor(ts.p.data[i], idname);
  1735. if (val === undefined) { val = String(i + 1); }
  1736. ts.p._index[val] = i;
  1737. }
  1738. },
  1739. constructTr = function (id, hide, classes, rd, cur) {
  1740. var tabindex = '-1', restAttr = '', attrName, style = hide ? 'display:none;' : '',
  1741. //classes = getstyle(stylemodule, 'rowBox', true) + ts.p.direction + (altClass ? ' ' + altClass : '') + (selected ? ' ' + highlight : ''),
  1742. rowAttrObj = $(ts).triggerHandler("jqGridRowAttr", [rd, cur, id]);
  1743. if (typeof rowAttrObj !== "object") {
  1744. rowAttrObj = $.isFunction(ts.p.rowattr) ? ts.p.rowattr.call(ts, rd, cur, id) :
  1745. (typeof ts.p.rowattr === "string" && $.jgrid.rowattr != null && $.isFunction($.jgrid.rowattr[ts.p.rowattr]) ?
  1746. $.jgrid.rowattr[ts.p.rowattr].call(ts, rd, cur, id) : {});
  1747. }
  1748. if (!$.isEmptyObject(rowAttrObj)) {
  1749. if (rowAttrObj.hasOwnProperty("id")) {
  1750. id = rowAttrObj.id;
  1751. delete rowAttrObj.id;
  1752. }
  1753. if (rowAttrObj.hasOwnProperty("tabindex")) {
  1754. tabindex = rowAttrObj.tabindex;
  1755. delete rowAttrObj.tabindex;
  1756. }
  1757. if (rowAttrObj.hasOwnProperty("style")) {
  1758. style += rowAttrObj.style;
  1759. delete rowAttrObj.style;
  1760. }
  1761. if (rowAttrObj.hasOwnProperty("class")) {
  1762. classes += ' ' + rowAttrObj['class'];
  1763. delete rowAttrObj['class'];
  1764. }
  1765. // dot't allow to change role attribute
  1766. try { delete rowAttrObj.role; } catch (ra) { }
  1767. for (attrName in rowAttrObj) {
  1768. if (rowAttrObj.hasOwnProperty(attrName)) {
  1769. restAttr += ' ' + attrName + '=' + rowAttrObj[attrName];
  1770. }
  1771. }
  1772. }
  1773. return '<tr role="row" id="' + id + '" tabindex="' + tabindex + '" class="' + classes + '"' +
  1774. (style === '' ? '' : ' style="' + style + '"') + restAttr + '>';
  1775. },
  1776. addXmlData = function (xml, rcnt, more, adjust) {
  1777. var startReq = new Date(),
  1778. locdata = (ts.p.datatype !== "local" && ts.p.loadonce) || ts.p.datatype === "xmlstring",
  1779. xmlid = "_id_", xmlRd = ts.p.xmlReader,
  1780. frd = ts.p.datatype === "local" ? "local" : "xml";
  1781. if (locdata) {
  1782. ts.p.data = [];
  1783. ts.p._index = {};
  1784. ts.p.localReader.id = xmlid;
  1785. }
  1786. ts.p.reccount = 0;
  1787. if ($.isXMLDoc(xml)) {
  1788. if (ts.p.treeANode === -1 && !ts.p.scroll) {
  1789. emptyRows.call(ts, false, true);
  1790. rcnt = 1;
  1791. } else { rcnt = rcnt > 1 ? rcnt : 1; }
  1792. } else { return; }
  1793. var self = $(ts), i, fpos, ir = 0, v, gi = ts.p.multiselect === true ? 1 : 0, si = 0, addSubGridCell, ni = ts.p.rownumbers === true ? 1 : 0, idn, getId, f = [], F, rd = {},
  1794. xmlr, rid, rowData = [], cn = (ts.p.altRows === true) ? ts.p.altclass : "",
  1795. cn1 = getstyle(stylemodule, 'rowBox', true, 'jqgrow ui-row-' + ts.p.direction), classes;
  1796. if (ts.p.subGrid === true) {
  1797. si = 1;
  1798. addSubGridCell = $.jgrid.getMethod("addSubGridCell");
  1799. }
  1800. if (!xmlRd.repeatitems) { f = reader(frd); }
  1801. if (ts.p.keyName === false) {
  1802. idn = $.isFunction(xmlRd.id) ? xmlRd.id.call(ts, xml) : xmlRd.id;
  1803. } else {
  1804. idn = ts.p.keyName;
  1805. }
  1806. if (String(idn).indexOf("[") === -1) {
  1807. if (f.length) {
  1808. getId = function (trow, k) { return $(idn, trow).text() || k; };
  1809. } else {
  1810. getId = function (trow, k) { return $(xmlRd.cell, trow).eq(idn).text() || k; };
  1811. }
  1812. }
  1813. else {
  1814. getId = function (trow, k) { return trow.getAttribute(idn.replace(/[\[\]]/g, "")) || k; };
  1815. }
  1816. ts.p.userData = {};
  1817. ts.p.page = intNum($.jgrid.getXmlData(xml, xmlRd.page), ts.p.page);
  1818. ts.p.lastpage = intNum($.jgrid.getXmlData(xml, xmlRd.total), 1);
  1819. ts.p.records = intNum($.jgrid.getXmlData(xml, xmlRd.records));
  1820. if ($.isFunction(xmlRd.userdata)) {
  1821. ts.p.userData = xmlRd.userdata.call(ts, xml) || {};
  1822. } else {
  1823. $.jgrid.getXmlData(xml, xmlRd.userdata, true).each(function () { ts.p.userData[this.getAttribute("name")] = $(this).text(); });
  1824. }
  1825. var gxml = $.jgrid.getXmlData(xml, xmlRd.root, true);
  1826. gxml = $.jgrid.getXmlData(gxml, xmlRd.row, true);
  1827. if (!gxml) { gxml = []; }
  1828. var gl = gxml.length, j = 0, grpdata = [], rn = parseInt(ts.p.rowNum, 10), br = ts.p.scroll ? $.jgrid.randId() : 1, altr,
  1829. tablebody = $("#" + $.jgrid.jqID(ts.p.id) + " tbody:first");
  1830. if (gl > 0 && ts.p.page <= 0) { ts.p.page = 1; }
  1831. if (gxml && gl) {
  1832. if (adjust) { rn *= adjust + 1; }
  1833. var afterInsRow = $.isFunction(ts.p.afterInsertRow), hiderow = false, groupingPrepare,
  1834. rnc = ni ? getstyle(stylemodule, 'rownumBox', false, 'jqgrid-rownum') : "",
  1835. mlc = gi ? getstyle(stylemodule, 'multiBox', false, 'cbox') : "";
  1836. if (ts.p.grouping) {
  1837. hiderow = ts.p.groupingView.groupCollapse === true;
  1838. groupingPrepare = $.jgrid.getMethod("groupingPrepare");
  1839. }
  1840. while (j < gl) {
  1841. xmlr = gxml[j];
  1842. rid = getId(xmlr, br + j);
  1843. rid = ts.p.idPrefix + rid;
  1844. altr = rcnt === 0 ? 0 : rcnt + 1;
  1845. classes = cn1 + ((altr + j) % 2 === 1 ? ' ' + cn : '');
  1846. var iStartTrTag = rowData.length;
  1847. rowData.push("");
  1848. if (ni) {
  1849. rowData.push(addRowNum(0, j, ts.p.page, ts.p.rowNum, rnc));
  1850. }
  1851. if (gi) {
  1852. rowData.push(addMulti(rid, ni, j, false, mlc));
  1853. }
  1854. if (si) {
  1855. rowData.push(addSubGridCell.call(self, gi + ni, j + rcnt));
  1856. }
  1857. if (xmlRd.repeatitems) {
  1858. if (!F) { F = orderedCols(gi + si + ni); }
  1859. var cells = $.jgrid.getXmlData(xmlr, xmlRd.cell, true);
  1860. $.each(F, function (k) {
  1861. var cell = cells[this];
  1862. if (!cell) { return false; }
  1863. v = cell.textContent || cell.text;
  1864. rd[ts.p.colModel[k + gi + si + ni].name] = v;
  1865. rowData.push(addCell(rid, v, k + gi + si + ni, j + rcnt, xmlr, rd));
  1866. });
  1867. } else {
  1868. for (i = 0; i < f.length; i++) {
  1869. v = $.jgrid.getXmlData(xmlr, f[i]);
  1870. rd[ts.p.colModel[i + gi + si + ni].name] = v;
  1871. rowData.push(addCell(rid, v, i + gi + si + ni, j + rcnt, xmlr, rd));
  1872. }
  1873. }
  1874. rowData[iStartTrTag] = constructTr(rid, hiderow, classes, rd, xmlr);
  1875. rowData.push("</tr>");
  1876. if (ts.p.grouping) {
  1877. grpdata.push(rowData);
  1878. if (!ts.p.groupingView._locgr) {
  1879. groupingPrepare.call(self, rd, j);
  1880. }
  1881. rowData = [];
  1882. }
  1883. if (locdata || (ts.p.treeGrid === true && !(ts.p._ald))) {
  1884. rd[xmlid] = $.jgrid.stripPref(ts.p.idPrefix, rid);
  1885. ts.p.data.push(rd);
  1886. ts.p._index[rd[xmlid]] = ts.p.data.length - 1;
  1887. }
  1888. if (ts.p.gridview === false) {
  1889. tablebody.append(rowData.join(''));
  1890. self.triggerHandler("jqGridAfterInsertRow", [rid, rd, xmlr]);
  1891. if (afterInsRow) { ts.p.afterInsertRow.call(ts, rid, rd, xmlr); }
  1892. rowData = [];
  1893. }
  1894. rd = {};
  1895. ir++;
  1896. j++;
  1897. if (ir === rn) { break; }
  1898. }
  1899. }
  1900. if (ts.p.gridview === true) {
  1901. fpos = ts.p.treeANode > -1 ? ts.p.treeANode : 0;
  1902. if (ts.p.grouping) {
  1903. if (!locdata) {
  1904. self.jqGrid('groupingRender', grpdata, ts.p.colModel.length, ts.p.page, rn);
  1905. grpdata = null;
  1906. }
  1907. } else if (ts.p.treeGrid === true && fpos > 0) {
  1908. $(ts.rows[fpos]).after(rowData.join(''));
  1909. } else {
  1910. //$("tbody:first",t).append(rowData.join(''));
  1911. tablebody.append(rowData.join(''));
  1912. ts.grid.cols = ts.rows[0].cells; // update cached first row
  1913. }
  1914. }
  1915. ts.p.totaltime = new Date() - startReq;
  1916. rowData = null;
  1917. if (ts.p.subGrid === true) {
  1918. try { self.jqGrid("addSubGrid", gi + ni); } catch (_) { }
  1919. }
  1920. if (ir > 0) { if (ts.p.records === 0) { ts.p.records = gl; } }
  1921. if (ts.p.treeGrid === true) {
  1922. try { self.jqGrid("setTreeNode", fpos + 1, ir + fpos + 1); } catch (e) { }
  1923. }
  1924. //if(!ts.p.treeGrid && !ts.p.scroll) {ts.grid.bDiv.scrollTop = 0;}
  1925. ts.p.reccount = ir;
  1926. ts.p.treeANode = -1;
  1927. if (ts.p.userDataOnFooter) { self.jqGrid("footerData", "set", ts.p.userData, true); }
  1928. if (locdata) {
  1929. ts.p.records = gl;
  1930. ts.p.lastpage = Math.ceil(gl / rn);
  1931. }
  1932. if (!more) { ts.updatepager(false, true); }
  1933. if (locdata) {
  1934. while (ir < gl) {
  1935. xmlr = gxml[ir];
  1936. rid = getId(xmlr, ir + br);
  1937. rid = ts.p.idPrefix + rid;
  1938. if (xmlRd.repeatitems) {
  1939. if (!F) { F = orderedCols(gi + si + ni); }
  1940. var cells2 = $.jgrid.getXmlData(xmlr, xmlRd.cell, true);
  1941. $.each(F, function (k) {
  1942. var cell = cells2[this];
  1943. if (!cell) { return false; }
  1944. v = cell.textContent || cell.text;
  1945. rd[ts.p.colModel[k + gi + si + ni].name] = v;
  1946. });
  1947. } else {
  1948. for (i = 0; i < f.length; i++) {
  1949. v = $.jgrid.getXmlData(xmlr, f[i]);
  1950. rd[ts.p.colModel[i + gi + si + ni].name] = v;
  1951. }
  1952. }
  1953. rd[xmlid] = $.jgrid.stripPref(ts.p.idPrefix, rid);
  1954. if (ts.p.grouping) {
  1955. groupingPrepare.call(self, rd, ir);
  1956. }
  1957. ts.p.data.push(rd);
  1958. ts.p._index[rd[xmlid]] = ts.p.data.length - 1;
  1959. rd = {};
  1960. ir++;
  1961. }
  1962. if (ts.p.grouping) {
  1963. ts.p.groupingView._locgr = true;
  1964. self.jqGrid('groupingRender', grpdata, ts.p.colModel.length, ts.p.page, rn);
  1965. grpdata = null;
  1966. }
  1967. }
  1968. },
  1969. addJSONData = function (data, rcnt, more, adjust) {
  1970. var startReq = new Date();
  1971. if (data) {
  1972. if (ts.p.treeANode === -1 && !ts.p.scroll) {
  1973. emptyRows.call(ts, false, true);
  1974. rcnt = 1;
  1975. } else { rcnt = rcnt > 1 ? rcnt : 1; }
  1976. } else { return; }
  1977. var dReader, locid = "_id_", frd,
  1978. locdata = (ts.p.datatype !== "local" && ts.p.loadonce) || ts.p.datatype === "jsonstring";
  1979. if (locdata) { ts.p.data = []; ts.p._index = {}; ts.p.localReader.id = locid; }
  1980. ts.p.reccount = 0;
  1981. if (ts.p.datatype === "local") {
  1982. dReader = ts.p.localReader;
  1983. frd = 'local';
  1984. } else {
  1985. dReader = ts.p.jsonReader;
  1986. frd = 'json';
  1987. }
  1988. var self = $(ts), ir = 0, v, i, j, f = [], cur, gi = ts.p.multiselect ? 1 : 0, si = ts.p.subGrid === true ? 1 : 0, addSubGridCell, ni = ts.p.rownumbers === true ? 1 : 0, arrayReader = orderedCols(gi + si + ni), objectReader = reader(frd), rowReader, len, drows, idn, rd = {}, fpos, idr, rowData = [], cn = (ts.p.altRows === true) ? ts.p.altclass : "",
  1989. cn1 = getstyle(stylemodule, 'rowBox', true, 'jqgrow ui-row-' + ts.p.direction), classes;
  1990. ts.p.page = intNum($.jgrid.getAccessor(data, dReader.page), ts.p.page);
  1991. ts.p.lastpage = intNum($.jgrid.getAccessor(data, dReader.total), 1);
  1992. ts.p.records = intNum($.jgrid.getAccessor(data, dReader.records));
  1993. ts.p.userData = $.jgrid.getAccessor(data, dReader.userdata) || {};
  1994. if (si) {
  1995. addSubGridCell = $.jgrid.getMethod("addSubGridCell");
  1996. }
  1997. if (ts.p.keyName === false) {
  1998. idn = $.isFunction(dReader.id) ? dReader.id.call(ts, data) : dReader.id;
  1999. } else {
  2000. idn = ts.p.keyName;
  2001. }
  2002. drows = $.jgrid.getAccessor(data, dReader.root);
  2003. if (drows == null && $.isArray(data)) { drows = data; }
  2004. if (!drows) { drows = []; }
  2005. len = drows.length; i = 0;
  2006. if (len > 0 && ts.p.page <= 0) { ts.p.page = 1; }
  2007. var rn = parseInt(ts.p.rowNum, 10), br = ts.p.scroll ? $.jgrid.randId() : 1, altr, selected = false, selr;
  2008. if (adjust) { rn *= adjust + 1; }
  2009. if (ts.p.datatype === "local" && !ts.p.deselectAfterSort) {
  2010. selected = true;
  2011. }
  2012. var afterInsRow = $.isFunction(ts.p.afterInsertRow), grpdata = [], hiderow = false, groupingPrepare,
  2013. tablebody = $("#" + $.jgrid.jqID(ts.p.id) + " tbody:first"),
  2014. rnc = ni ? getstyle(stylemodule, 'rownumBox', false, 'jqgrid-rownum') : "",
  2015. mlc = gi ? getstyle(stylemodule, 'multiBox', false, 'cbox') : "";
  2016. if (ts.p.grouping) {
  2017. hiderow = ts.p.groupingView.groupCollapse === true;
  2018. groupingPrepare = $.jgrid.getMethod("groupingPrepare");
  2019. }
  2020. while (i < len) {
  2021. cur = drows[i];
  2022. idr = $.jgrid.getAccessor(cur, idn);
  2023. if (idr === undefined) {
  2024. if (typeof idn === "number" && ts.p.colModel[idn + gi + si + ni] != null) {
  2025. // reread id by name
  2026. idr = $.jgrid.getAccessor(cur, ts.p.colModel[idn + gi + si + ni].name);
  2027. }
  2028. if (idr === undefined) {
  2029. idr = br + i;
  2030. if (f.length === 0) {
  2031. if (dReader.cell) {
  2032. var ccur = $.jgrid.getAccessor(cur, dReader.cell) || cur;
  2033. idr = ccur != null && ccur[idn] !== undefined ? ccur[idn] : idr;
  2034. ccur = null;
  2035. }
  2036. }
  2037. }
  2038. }
  2039. idr = ts.p.idPrefix + idr;
  2040. altr = rcnt === 1 ? 0 : rcnt;
  2041. classes = cn1 + ((altr + i) % 2 === 1 ? ' ' + cn : '');
  2042. if (selected) {
  2043. if (ts.p.multiselect) {
  2044. selr = ($.inArray(idr, ts.p.selarrrow) !== -1);
  2045. } else {
  2046. selr = (idr === ts.p.selrow);
  2047. }
  2048. }
  2049. var iStartTrTag = rowData.length;
  2050. rowData.push("");
  2051. if (ni) {
  2052. rowData.push(addRowNum(0, i, ts.p.page, ts.p.rowNum, rnc));
  2053. }
  2054. if (gi) {
  2055. rowData.push(addMulti(idr, ni, i, selr, mlc));
  2056. }
  2057. if (si) {
  2058. rowData.push(addSubGridCell.call(self, gi + ni, i + rcnt));
  2059. }
  2060. rowReader = objectReader;
  2061. if (dReader.repeatitems) {
  2062. if (dReader.cell) { cur = $.jgrid.getAccessor(cur, dReader.cell) || cur; }
  2063. if ($.isArray(cur)) { rowReader = arrayReader; }
  2064. }
  2065. for (j = 0; j < rowReader.length; j++) {
  2066. v = $.jgrid.getAccessor(cur, rowReader[j]);
  2067. rd[ts.p.colModel[j + gi + si + ni].name] = v;
  2068. rowData.push(addCell(idr, v, j + gi + si + ni, i + rcnt, cur, rd));
  2069. }
  2070. classes += (selr ? ' ' + highlight : '');
  2071. rowData[iStartTrTag] = constructTr(idr, hiderow, classes, rd, cur);
  2072. rowData.push("</tr>");
  2073. if (ts.p.grouping) {
  2074. grpdata.push(rowData);
  2075. if (!ts.p.groupingView._locgr) {
  2076. groupingPrepare.call(self, rd, i);
  2077. }
  2078. rowData = [];
  2079. }
  2080. if (locdata || (ts.p.treeGrid === true && !(ts.p._ald))) {
  2081. rd[locid] = $.jgrid.stripPref(ts.p.idPrefix, idr);
  2082. ts.p.data.push(rd);
  2083. ts.p._index[rd[locid]] = ts.p.data.length - 1;
  2084. }
  2085. if (ts.p.gridview === false) {
  2086. tablebody.append(rowData.join(''));
  2087. self.triggerHandler("jqGridAfterInsertRow", [idr, rd, cur]);
  2088. if (afterInsRow) { ts.p.afterInsertRow.call(ts, idr, rd, cur); }
  2089. rowData = [];//ari=0;
  2090. }
  2091. rd = {};
  2092. ir++;
  2093. i++;
  2094. if (ir === rn) { break; }
  2095. }
  2096. if (ts.p.gridview === true) {
  2097. fpos = ts.p.treeANode > -1 ? ts.p.treeANode : 0;
  2098. if (ts.p.grouping) {
  2099. if (!locdata) {
  2100. self.jqGrid('groupingRender', grpdata, ts.p.colModel.length, ts.p.page, rn);
  2101. grpdata = null;
  2102. }
  2103. } else if (ts.p.treeGrid === true && fpos > 0) {
  2104. $(ts.rows[fpos]).after(rowData.join(''));
  2105. } else {
  2106. tablebody.append(rowData.join(''));
  2107. ts.grid.cols = ts.rows[0].cells;
  2108. }
  2109. }
  2110. ts.p.totaltime = new Date() - startReq;
  2111. rowData = null;
  2112. if (ts.p.subGrid === true) {
  2113. try { self.jqGrid("addSubGrid", gi + ni); } catch (_) { }
  2114. }
  2115. if (ir > 0) {
  2116. if (ts.p.records === 0) { ts.p.records = len; }
  2117. }
  2118. if (ts.p.treeGrid === true) {
  2119. try { self.jqGrid("setTreeNode", fpos + 1, ir + fpos + 1); } catch (e) { }
  2120. }
  2121. //if(!ts.p.treeGrid && !ts.p.scroll) {ts.grid.bDiv.scrollTop = 0;}
  2122. ts.p.reccount = ir;
  2123. ts.p.treeANode = -1;
  2124. if (ts.p.userDataOnFooter) { self.jqGrid("footerData", "set", ts.p.userData, true); }
  2125. if (locdata) {
  2126. ts.p.records = len;
  2127. ts.p.lastpage = Math.ceil(len / rn);
  2128. }
  2129. if (!more) { ts.updatepager(false, true); }
  2130. if (locdata) {
  2131. while (ir < len && drows[ir]) {
  2132. cur = drows[ir];
  2133. idr = $.jgrid.getAccessor(cur, idn);
  2134. if (idr === undefined) {
  2135. if (typeof idn === "number" && ts.p.colModel[idn + gi + si + ni] != null) {
  2136. // reread id by name
  2137. idr = $.jgrid.getAccessor(cur, ts.p.colModel[idn + gi + si + ni].name);
  2138. }
  2139. if (idr === undefined) {
  2140. idr = br + ir;
  2141. if (f.length === 0) {
  2142. if (dReader.cell) {
  2143. var ccur2 = $.jgrid.getAccessor(cur, dReader.cell) || cur;
  2144. idr = ccur2 != null && ccur2[idn] !== undefined ? ccur2[idn] : idr;
  2145. ccur2 = null;
  2146. }
  2147. }
  2148. }
  2149. }
  2150. if (cur) {
  2151. idr = ts.p.idPrefix + idr;
  2152. rowReader = objectReader;
  2153. if (dReader.repeatitems) {
  2154. if (dReader.cell) { cur = $.jgrid.getAccessor(cur, dReader.cell) || cur; }
  2155. if ($.isArray(cur)) { rowReader = arrayReader; }
  2156. }
  2157. for (j = 0; j < rowReader.length; j++) {
  2158. rd[ts.p.colModel[j + gi + si + ni].name] = $.jgrid.getAccessor(cur, rowReader[j]);
  2159. }
  2160. rd[locid] = $.jgrid.stripPref(ts.p.idPrefix, idr);
  2161. if (ts.p.grouping) {
  2162. groupingPrepare.call(self, rd, ir);
  2163. }
  2164. ts.p.data.push(rd);
  2165. ts.p._index[rd[locid]] = ts.p.data.length - 1;
  2166. rd = {};
  2167. }
  2168. ir++;
  2169. }
  2170. if (ts.p.grouping) {
  2171. ts.p.groupingView._locgr = true;
  2172. self.jqGrid('groupingRender', grpdata, ts.p.colModel.length, ts.p.page, rn);
  2173. grpdata = null;
  2174. }
  2175. }
  2176. },
  2177. addLocalData = function () {
  2178. var st = ts.p.multiSort ? [] : "", sto = [], fndsort = false, cmtypes = {}, grtypes = [], grindexes = [], srcformat, sorttype, newformat, sfld;
  2179. if (!$.isArray(ts.p.data)) {
  2180. return;
  2181. }
  2182. var grpview = ts.p.grouping ? ts.p.groupingView : false, lengrp, gin, si;
  2183. $.each(ts.p.colModel, function () {
  2184. sorttype = this.sorttype || "text";
  2185. si = this.index || this.name;
  2186. if (sorttype === "date" || sorttype === "datetime") {
  2187. if (this.formatter && typeof this.formatter === 'string' && this.formatter === 'date') {
  2188. if (this.formatoptions && this.formatoptions.srcformat) {
  2189. srcformat = this.formatoptions.srcformat;
  2190. } else {
  2191. srcformat = $.jgrid.getRegional(ts, "formatter.date.srcformat");
  2192. }
  2193. if (this.formatoptions && this.formatoptions.newformat) {
  2194. newformat = this.formatoptions.newformat;
  2195. } else {
  2196. newformat = $.jgrid.getRegional(ts, "formatter.date.newformat");
  2197. }
  2198. } else {
  2199. srcformat = newformat = this.datefmt || "Y-m-d";
  2200. }
  2201. cmtypes[si] = { "stype": sorttype, "srcfmt": srcformat, "newfmt": newformat, "sfunc": this.sortfunc || null };
  2202. } else {
  2203. cmtypes[si] = { "stype": sorttype, "srcfmt": '', "newfmt": '', "sfunc": this.sortfunc || null };
  2204. }
  2205. if (ts.p.grouping) {
  2206. for (gin = 0, lengrp = grpview.groupField.length; gin < lengrp; gin++) {
  2207. if (this.name === grpview.groupField[gin]) {
  2208. grtypes[gin] = cmtypes[si];
  2209. grindexes[gin] = si;
  2210. }
  2211. }
  2212. }
  2213. if (!ts.p.multiSort) {
  2214. if (!fndsort && (si === ts.p.sortname)) {
  2215. st = si;
  2216. fndsort = true;
  2217. }
  2218. }
  2219. });
  2220. if (ts.p.multiSort) {
  2221. st = sortarr;
  2222. sto = sortord;
  2223. }
  2224. if (ts.p.treeGrid && ts.p._sort) {
  2225. $(ts).jqGrid("SortTree", st, ts.p.sortorder, cmtypes[st].stype || 'text', cmtypes[st].srcfmt || '');
  2226. return;
  2227. }
  2228. var compareFnMap = {
  2229. 'eq': function (queryObj) { return queryObj.equals; },
  2230. 'ne': function (queryObj) { return queryObj.notEquals; },
  2231. 'lt': function (queryObj) { return queryObj.less; },
  2232. 'le': function (queryObj) { return queryObj.lessOrEquals; },
  2233. 'gt': function (queryObj) { return queryObj.greater; },
  2234. 'ge': function (queryObj) { return queryObj.greaterOrEquals; },
  2235. 'cn': function (queryObj) { return queryObj.contains; },
  2236. 'nc': function (queryObj, op) { return op === "OR" ? queryObj.orNot().contains : queryObj.andNot().contains; },
  2237. 'bw': function (queryObj) { return queryObj.startsWith; },
  2238. 'bn': function (queryObj, op) { return op === "OR" ? queryObj.orNot().startsWith : queryObj.andNot().startsWith; },
  2239. 'en': function (queryObj, op) { return op === "OR" ? queryObj.orNot().endsWith : queryObj.andNot().endsWith; },
  2240. 'ew': function (queryObj) { return queryObj.endsWith; },
  2241. 'ni': function (queryObj, op) { return op === "OR" ? queryObj.orNot().equals : queryObj.andNot().equals; },
  2242. 'in': function (queryObj) { return queryObj.equals; },
  2243. 'nu': function (queryObj) { return queryObj.isNull; },
  2244. 'nn': function (queryObj, op) { return op === "OR" ? queryObj.orNot().isNull : queryObj.andNot().isNull; }
  2245. },
  2246. query = $.jgrid.from.call(ts, ts.p.data);
  2247. if (ts.p.ignoreCase) { query = query.ignoreCase(); }
  2248. function tojLinq(group) {
  2249. var s = 0, index, gor, ror, opr, rule, fld;
  2250. if (group.groups != null) {
  2251. gor = group.groups.length && group.groupOp.toString().toUpperCase() === "OR";
  2252. if (gor) {
  2253. query.orBegin();
  2254. }
  2255. for (index = 0; index < group.groups.length; index++) {
  2256. if (s > 0 && gor) {
  2257. query.or();
  2258. }
  2259. try {
  2260. tojLinq(group.groups[index]);
  2261. } catch (e) { alert(e); }
  2262. s++;
  2263. }
  2264. if (gor) {
  2265. query.orEnd();
  2266. }
  2267. }
  2268. if (group.rules != null) {
  2269. //if(s>0) {
  2270. // var result = query.select();
  2271. // query = $.jgrid.from( result);
  2272. // if (ts.p.ignoreCase) { query = query.ignoreCase(); }
  2273. //}
  2274. try {
  2275. ror = group.rules.length && group.groupOp.toString().toUpperCase() === "OR";
  2276. if (ror) {
  2277. query.orBegin();
  2278. }
  2279. for (index = 0; index < group.rules.length; index++) {
  2280. rule = group.rules[index];
  2281. opr = group.groupOp.toString().toUpperCase();
  2282. if (compareFnMap[rule.op] && rule.field) {
  2283. if (s > 0 && opr && opr === "OR") {
  2284. query = query.or();
  2285. }
  2286. fld = cmtypes[rule.field];
  2287. if (fld.stype === 'date') {
  2288. if (fld.srcfmt && fld.newfmt && fld.srcfmt !== fld.newfmt) {
  2289. rule.data = $.jgrid.parseDate.call(ts, fld.newfmt, rule.data, fld.srcfmt);
  2290. }
  2291. }
  2292. query = compareFnMap[rule.op](query, opr)(rule.field, rule.data, cmtypes[rule.field]);
  2293. }
  2294. s++;
  2295. }
  2296. if (ror) {
  2297. query.orEnd();
  2298. }
  2299. } catch (g) { alert(g); }
  2300. }
  2301. }
  2302. if (ts.p.search === true) {
  2303. var srules = ts.p.postData.filters;
  2304. if (srules) {
  2305. if (typeof srules === "string") { srules = $.jgrid.parse(srules); }
  2306. tojLinq(srules);
  2307. } else {
  2308. try {
  2309. sfld = cmtypes[ts.p.postData.searchField];
  2310. if (sfld.stype === 'date') {
  2311. if (sfld.srcfmt && sfld.newfmt && sfld.srcfmt !== sfld.newfmt) {
  2312. ts.p.postData.searchString = $.jgrid.parseDate.call(ts, sfld.newfmt, ts.p.postData.searchString, sfld.srcfmt);
  2313. }
  2314. }
  2315. query = compareFnMap[ts.p.postData.searchOper](query)(ts.p.postData.searchField, ts.p.postData.searchString, cmtypes[ts.p.postData.searchField]);
  2316. } catch (se) { }
  2317. }
  2318. } else {
  2319. if (ts.p.treeGrid && ts.p.treeGridModel === "nested") {
  2320. query.orderBy(ts.p.treeReader.left_field, 'asc', 'integer', '', null);
  2321. }
  2322. }
  2323. if (ts.p.treeGrid && ts.p.treeGridModel === "adjacency") {
  2324. lengrp = 0;
  2325. st = null;
  2326. }
  2327. if (ts.p.grouping) {
  2328. for (gin = 0; gin < lengrp; gin++) {
  2329. query.orderBy(grindexes[gin], grpview.groupOrder[gin], grtypes[gin].stype, grtypes[gin].srcfmt);
  2330. }
  2331. }
  2332. if (ts.p.multiSort) {
  2333. $.each(st, function (i) {
  2334. query.orderBy(this, sto[i], cmtypes[this].stype, cmtypes[this].srcfmt, cmtypes[this].sfunc);
  2335. });
  2336. } else {
  2337. if (st && ts.p.sortorder && fndsort) {
  2338. // to be fixed in case sortname has more than one field
  2339. if (ts.p.sortorder.toUpperCase() === "DESC") {
  2340. query.orderBy(ts.p.sortname, "d", cmtypes[st].stype, cmtypes[st].srcfmt, cmtypes[st].sfunc);
  2341. } else {
  2342. query.orderBy(ts.p.sortname, "a", cmtypes[st].stype, cmtypes[st].srcfmt, cmtypes[st].sfunc);
  2343. }
  2344. }
  2345. }
  2346. var queryResults = query.select(),
  2347. recordsperpage = parseInt(ts.p.rowNum, 10),
  2348. total = queryResults.length,
  2349. page = parseInt(ts.p.page, 10),
  2350. totalpages = Math.ceil(total / recordsperpage),
  2351. retresult = {};
  2352. if ((ts.p.search || ts.p.resetsearch) && ts.p.grouping && ts.p.groupingView._locgr) {
  2353. ts.p.groupingView.groups = [];
  2354. var j, grPrepare = $.jgrid.getMethod("groupingPrepare"), key, udc;
  2355. if (ts.p.footerrow && ts.p.userDataOnFooter) {
  2356. for (key in ts.p.userData) {
  2357. if (ts.p.userData.hasOwnProperty(key)) {
  2358. ts.p.userData[key] = 0;
  2359. }
  2360. }
  2361. udc = true;
  2362. }
  2363. for (j = 0; j < total; j++) {
  2364. if (udc) {
  2365. for (key in ts.p.userData) {
  2366. if (ts.p.userData.hasOwnProperty(key)) {
  2367. ts.p.userData[key] += parseFloat(queryResults[j][key] || 0);
  2368. }
  2369. }
  2370. }
  2371. grPrepare.call($(ts), queryResults[j], j, recordsperpage);
  2372. }
  2373. }
  2374. if (ts.p.treeGrid && ts.p.search) {
  2375. queryResults = $(ts).jqGrid("searchTree", queryResults);
  2376. } else {
  2377. queryResults = queryResults.slice((page - 1) * recordsperpage, page * recordsperpage);
  2378. }
  2379. query = null;
  2380. cmtypes = null;
  2381. retresult[ts.p.localReader.total] = totalpages;
  2382. retresult[ts.p.localReader.page] = page;
  2383. retresult[ts.p.localReader.records] = total;
  2384. retresult[ts.p.localReader.root] = queryResults;
  2385. retresult[ts.p.localReader.userdata] = ts.p.userData;
  2386. queryResults = null;
  2387. return retresult;
  2388. },
  2389. updatepager = function (rn, dnd) {
  2390. var cp, last, base, from, to, tot, fmt, pgboxes = "", sppg,
  2391. pgid = ts.p.pager ? $.jgrid.jqID(ts.p.pager.substr(1)) : "",
  2392. tspg = pgid ? "_" + pgid : "",
  2393. tspg_t = ts.p.toppager ? "_" + ts.p.toppager.substr(1) : "";
  2394. base = parseInt(ts.p.page, 10) - 1;
  2395. if (base < 0) { base = 0; }
  2396. base = base * parseInt(ts.p.rowNum, 10);
  2397. to = base + ts.p.reccount;
  2398. if (ts.p.scroll) {
  2399. var rows = $("tbody:first > tr:gt(0)", ts.grid.bDiv);
  2400. base = to - rows.length;
  2401. ts.p.reccount = rows.length;
  2402. var rh = rows.outerHeight() || ts.grid.prevRowHeight;
  2403. if (rh) {
  2404. var top = base * rh;
  2405. var height = parseInt(ts.p.records, 10) * rh;
  2406. $(">div:first", ts.grid.bDiv).css({ height: height }).children("div:first").css({ height: top, display: top ? "" : "none" });
  2407. if (ts.grid.bDiv.scrollTop === 0 && ts.p.page > 1) {
  2408. ts.grid.bDiv.scrollTop = ts.p.rowNum * (ts.p.page - 1) * rh;
  2409. }
  2410. }
  2411. ts.grid.bDiv.scrollLeft = ts.grid.hDiv.scrollLeft;
  2412. }
  2413. pgboxes = ts.p.pager || "";
  2414. pgboxes += ts.p.toppager ? (pgboxes ? "," + ts.p.toppager : ts.p.toppager) : "";
  2415. if (pgboxes) {
  2416. fmt = $.jgrid.getRegional(ts, "formatter.integer");
  2417. cp = intNum(ts.p.page);
  2418. last = intNum(ts.p.lastpage);
  2419. $(".selbox", pgboxes)[this.p.useProp ? 'prop' : 'attr']("disabled", false);
  2420. if (ts.p.pginput === true) {
  2421. $("#input" + tspg).html($.jgrid.template($.jgrid.getRegional(ts, "defaults.pgtext", ts.p.pgtext) || "", "<input " + getstyle(stylemodule, 'pgInput', false, 'ui-pg-input') + " type='text' size='2' maxlength='7' value='0' role='textbox'/>", "<span id='sp_1_" + $.jgrid.jqID(pgid) + "'></span>"));
  2422. if (ts.p.toppager) {
  2423. $("#input_t" + tspg_t).html($.jgrid.template($.jgrid.getRegional(ts, "defaults.pgtext", ts.p.pgtext) || "", "<input " + getstyle(stylemodule, 'pgInput', false, 'ui-pg-input') + " type='text' size='2' maxlength='7' value='0' role='textbox'/>", "<span id='sp_1_" + $.jgrid.jqID(pgid) + "_toppager'></span>"));
  2424. }
  2425. $('.ui-pg-input', pgboxes).val(ts.p.page);
  2426. sppg = ts.p.toppager ? '#sp_1' + tspg + ",#sp_1" + tspg + "_toppager" : '#sp_1' + tspg;
  2427. $(sppg).html($.fmatter ? $.fmatter.util.NumberFormat(ts.p.lastpage, fmt) : ts.p.lastpage);
  2428. }
  2429. if (ts.p.viewrecords) {
  2430. if (ts.p.reccount === 0) {
  2431. $(".ui-paging-info", pgboxes).html($.jgrid.getRegional(ts, "defaults.emptyrecords", ts.p.emptyrecords));
  2432. } else {
  2433. from = base + 1;
  2434. tot = ts.p.records;
  2435. if ($.fmatter) {
  2436. from = $.fmatter.util.NumberFormat(from, fmt);
  2437. to = $.fmatter.util.NumberFormat(to, fmt);
  2438. tot = $.fmatter.util.NumberFormat(tot, fmt);
  2439. }
  2440. var rt = $.jgrid.getRegional(ts, "defaults.recordtext", ts.p.recordtext);
  2441. $(".ui-paging-info", pgboxes).html($.jgrid.template(rt, from, to, tot));
  2442. }
  2443. }
  2444. if (ts.p.pgbuttons === true) {
  2445. if (cp <= 0) { cp = last = 0; }
  2446. if (cp === 1 || cp === 0) {
  2447. $("#first" + tspg + ", #prev" + tspg).addClass(disabled).removeClass(hover);
  2448. if (ts.p.toppager) { $("#first_t" + tspg_t + ", #prev_t" + tspg_t).addClass(disabled).removeClass(hover); }
  2449. } else {
  2450. $("#first" + tspg + ", #prev" + tspg).removeClass(disabled);
  2451. if (ts.p.toppager) { $("#first_t" + tspg_t + ", #prev_t" + tspg_t).removeClass(disabled); }
  2452. }
  2453. if (cp === last || cp === 0) {
  2454. $("#next" + tspg + ", #last" + tspg).addClass(disabled).removeClass(hover);
  2455. if (ts.p.toppager) { $("#next_t" + tspg_t + ", #last_t" + tspg_t).addClass(disabled).removeClass(hover); }
  2456. } else {
  2457. $("#next" + tspg + ", #last" + tspg).removeClass(disabled);
  2458. if (ts.p.toppager) { $("#next_t" + tspg_t + ", #last_t" + tspg_t).removeClass(disabled); }
  2459. }
  2460. }
  2461. }
  2462. if (rn === true && ts.p.rownumbers === true) {
  2463. $(">td.jqgrid-rownum", ts.rows).each(function (i) {
  2464. $(this).html(base + 1 + i);
  2465. });
  2466. }
  2467. if (dnd && ts.p.jqgdnd) { $(ts).jqGrid('gridDnD', 'updateDnD'); }
  2468. $(ts).triggerHandler("jqGridGridComplete");
  2469. if ($.isFunction(ts.p.gridComplete)) { ts.p.gridComplete.call(ts); }
  2470. $(ts).triggerHandler("jqGridAfterGridComplete");
  2471. },
  2472. beginReq = function () {
  2473. window.setTimeout(function () {
  2474. $.loading(true);
  2475. top.$("#loadingPage").find('.loading-content').attr('isTableLoading', 'true');
  2476. }, 0);
  2477. ts.grid.hDiv.loading = true;
  2478. if (ts.p.hiddengrid) { return; }
  2479. },
  2480. endReq = function () {
  2481. window.setTimeout(function () {
  2482. top.$("#loadingPage").find('.loading-content').removeAttr('isTableLoading');
  2483. $.loading(false);
  2484. }, 0);
  2485. ts.grid.hDiv.loading = false;
  2486. if (ts.p.unwritten) {
  2487. $("#" + ts.p.id).parents('.ui-jqgrid-bdiv').find(".unwritten").remove();
  2488. if ($("#" + ts.p.id).find('tbody tr').length == 1) {
  2489. $("#" + ts.p.id).parents('.ui-jqgrid-bdiv').append('<div class="unwritten" style="color:red;padding:7px;border-bottom:#ddd 1px solid;">暂无数据!</div>')
  2490. }
  2491. }
  2492. },
  2493. populate = function (npage) {
  2494. if (!ts.grid.hDiv.loading) {
  2495. var pvis = ts.p.scroll && npage === false,
  2496. prm = {}, dt, dstr, pN = ts.p.prmNames;
  2497. if (ts.p.page <= 0) { ts.p.page = Math.min(1, ts.p.lastpage); }
  2498. if (pN.search !== null) { prm[pN.search] = ts.p.search; } if (pN.nd !== null) { prm[pN.nd] = new Date().getTime(); }
  2499. if (pN.rows !== null) { prm[pN.rows] = ts.p.rowNum; } if (pN.page !== null) { prm[pN.page] = ts.p.page; }
  2500. if (pN.sort !== null) { prm[pN.sort] = ts.p.sortname; } if (pN.order !== null) { prm[pN.order] = ts.p.sortorder; }
  2501. if (ts.p.rowTotal !== null && pN.totalrows !== null) { prm[pN.totalrows] = ts.p.rowTotal; }
  2502. var lcf = $.isFunction(ts.p.loadComplete), lc = lcf ? ts.p.loadComplete : null;
  2503. var adjust = 0;
  2504. npage = npage || 1;
  2505. if (npage > 1) {
  2506. if (pN.npage !== null) {
  2507. prm[pN.npage] = npage;
  2508. adjust = npage - 1;
  2509. npage = 1;
  2510. } else {
  2511. lc = function (req) {
  2512. ts.p.page++;
  2513. ts.grid.hDiv.loading = false;
  2514. if (lcf) {
  2515. ts.p.loadComplete.call(ts, req);
  2516. }
  2517. populate(npage - 1);
  2518. };
  2519. }
  2520. } else if (pN.npage !== null) {
  2521. delete ts.p.postData[pN.npage];
  2522. }
  2523. if (ts.p.grouping) {
  2524. $(ts).jqGrid('groupingSetup');
  2525. var grp = ts.p.groupingView, gi, gs = "";
  2526. for (gi = 0; gi < grp.groupField.length; gi++) {
  2527. var index = grp.groupField[gi];
  2528. $.each(ts.p.colModel, function (cmIndex, cmValue) {
  2529. if (cmValue.name === index && cmValue.index) {
  2530. index = cmValue.index;
  2531. }
  2532. });
  2533. gs += index + " " + grp.groupOrder[gi] + ", ";
  2534. }
  2535. prm[pN.sort] = gs + prm[pN.sort];
  2536. }
  2537. $.extend(ts.p.postData, prm);
  2538. var rcnt = !ts.p.scroll ? 1 : ts.rows.length - 1;
  2539. var bfr = $(ts).triggerHandler("jqGridBeforeRequest");
  2540. if (bfr === false || bfr === 'stop') { return; }
  2541. if ($.isFunction(ts.p.datatype)) { ts.p.datatype.call(ts, ts.p.postData, "load_" + ts.p.id, rcnt, npage, adjust); return; }
  2542. if ($.isFunction(ts.p.beforeRequest)) {
  2543. bfr = ts.p.beforeRequest.call(ts);
  2544. if (bfr === undefined) { bfr = true; }
  2545. if (bfr === false) { return; }
  2546. }
  2547. dt = ts.p.datatype.toLowerCase();
  2548. switch (dt) {
  2549. case "json":
  2550. case "jsonp":
  2551. case "xml":
  2552. case "script":
  2553. $.ajax($.extend({
  2554. url: ts.p.url,
  2555. type: ts.p.mtype,
  2556. dataType: dt,
  2557. data: $.isFunction(ts.p.serializeGridData) ? ts.p.serializeGridData.call(ts, ts.p.postData) : ts.p.postData,
  2558. success: function (data, st, xhr) {
  2559. if ($.isFunction(ts.p.beforeProcessing)) {
  2560. if (ts.p.beforeProcessing.call(ts, data, st, xhr) === false) {
  2561. endReq();
  2562. return;
  2563. }
  2564. }
  2565. if (dt === "xml") { addXmlData(data, rcnt, npage > 1, adjust); }
  2566. else { addJSONData(data, rcnt, npage > 1, adjust); }
  2567. $(ts).triggerHandler("jqGridLoadComplete", [data]);
  2568. if (lc) { lc.call(ts, data); }
  2569. $(ts).triggerHandler("jqGridAfterLoadComplete", [data]);
  2570. if (pvis) { ts.grid.populateVisible(); }
  2571. if (ts.p.loadonce || ts.p.treeGrid) { ts.p.datatype = "local"; }
  2572. data = null;
  2573. if (npage === 1) { endReq(); }
  2574. },
  2575. error: function (xhr, st, err) {
  2576. if ($.isFunction(ts.p.loadError)) { ts.p.loadError.call(ts, xhr, st, err); }
  2577. if (npage === 1) { endReq(); }
  2578. xhr = null;
  2579. },
  2580. beforeSend: function (xhr, settings) {
  2581. var gotoreq = true;
  2582. if ($.isFunction(ts.p.loadBeforeSend)) {
  2583. gotoreq = ts.p.loadBeforeSend.call(ts, xhr, settings);
  2584. }
  2585. if (gotoreq === undefined) { gotoreq = true; }
  2586. if (gotoreq === false) {
  2587. return false;
  2588. }
  2589. beginReq();
  2590. }
  2591. }, $.jgrid.ajaxOptions, ts.p.ajaxGridOptions));
  2592. break;
  2593. case "xmlstring":
  2594. beginReq();
  2595. dstr = typeof ts.p.datastr !== 'string' ? ts.p.datastr : $.parseXML(ts.p.datastr);
  2596. addXmlData(dstr);
  2597. $(ts).triggerHandler("jqGridLoadComplete", [dstr]);
  2598. if (lcf) { ts.p.loadComplete.call(ts, dstr); }
  2599. $(ts).triggerHandler("jqGridAfterLoadComplete", [dstr]);
  2600. ts.p.datatype = "local";
  2601. ts.p.datastr = null;
  2602. endReq();
  2603. break;
  2604. case "jsonstring":
  2605. beginReq();
  2606. if (typeof ts.p.datastr === 'string') { dstr = $.jgrid.parse(ts.p.datastr); }
  2607. else { dstr = ts.p.datastr; }
  2608. addJSONData(dstr);
  2609. $(ts).triggerHandler("jqGridLoadComplete", [dstr]);
  2610. if (lcf) { ts.p.loadComplete.call(ts, dstr); }
  2611. $(ts).triggerHandler("jqGridAfterLoadComplete", [dstr]);
  2612. ts.p.datatype = "local";
  2613. ts.p.datastr = null;
  2614. endReq();
  2615. break;
  2616. case "local":
  2617. case "clientside":
  2618. beginReq();
  2619. ts.p.datatype = "local";
  2620. ts.p._ald = true;
  2621. var req = addLocalData();
  2622. addJSONData(req, rcnt, npage > 1, adjust);
  2623. $(ts).triggerHandler("jqGridLoadComplete", [req]);
  2624. if (lc) { lc.call(ts, req); }
  2625. $(ts).triggerHandler("jqGridAfterLoadComplete", [req]);
  2626. if (pvis) { ts.grid.populateVisible(); }
  2627. endReq();
  2628. ts.p._ald = false;
  2629. break;
  2630. }
  2631. ts.p._sort = false;
  2632. }
  2633. },
  2634. setHeadCheckBox = function (checked) {
  2635. $('#cb_' + $.jgrid.jqID(ts.p.id), ts.grid.hDiv)[ts.p.useProp ? 'prop' : 'attr']("checked", checked);
  2636. var fid = ts.p.frozenColumns ? ts.p.id + "_frozen" : "";
  2637. if (fid) {
  2638. $('#cb_' + $.jgrid.jqID(ts.p.id), ts.grid.fhDiv)[ts.p.useProp ? 'prop' : 'attr']("checked", checked);
  2639. }
  2640. },
  2641. setPager = function (pgid, tp) {
  2642. // TBD - consider escaping pgid with pgid = $.jgrid.jqID(pgid);
  2643. var sep = "<td class='ui-pg-button " + disabled + "'><span class='ui-separator'></span></td>",
  2644. pginp = "",
  2645. pgl = "<table class='ui-pg-table ui-common-table ui-paging-pager'><tbody><tr>",
  2646. str = "", pgcnt, lft, cent, rgt, twd, tdw, i,
  2647. clearVals = function (onpaging, thus) {
  2648. var ret;
  2649. if ($.isFunction(ts.p.onPaging)) { ret = ts.p.onPaging.call(ts, onpaging, thus); }
  2650. if (ret === 'stop') { return false; }
  2651. ts.p.selrow = null;
  2652. if (ts.p.multiselect) { ts.p.selarrrow = []; setHeadCheckBox(false); }
  2653. ts.p.savedRow = [];
  2654. return true;
  2655. };
  2656. pgid = pgid.substr(1);
  2657. tp += "_" + pgid;
  2658. pgcnt = "pg_" + pgid;
  2659. lft = pgid + "_left"; cent = pgid + "_center"; rgt = pgid + "_right";
  2660. $("#" + $.jgrid.jqID(pgid))
  2661. .append("<div id='" + pgcnt + "' class='ui-pager-control' role='group'><table " + getstyle(stylemodule, 'pagerTable', false, 'ui-pg-table ui-common-table ui-pager-table') + "><tbody><tr><td id='" + cent + "' style='white-space:pre;'></td><td id='" + lft + "' align='left'></td><td id='" + rgt + "' align='right'></td></tr></tbody></table></div>")
  2662. .attr("dir", "ltr"); //explicit setting
  2663. if (ts.p.rowList.length > 0) {
  2664. str = "<td dir=\"" + dir + "\">";
  2665. str += "<select " + getstyle(stylemodule, 'pgSelectBox', false, 'ui-pg-selbox') + " role=\"listbox\" title=\"" + ($.jgrid.getRegional(ts, "defaults.pgrecs", ts.p.pgrecs) || "") + "\">";
  2666. var strnm;
  2667. for (i = 0; i < ts.p.rowList.length; i++) {
  2668. strnm = ts.p.rowList[i].toString().split(":");
  2669. if (strnm.length === 1) {
  2670. strnm[1] = strnm[0];
  2671. }
  2672. str += "<option role=\"option\" value=\"" + strnm[0] + "\"" + ((intNum(ts.p.rowNum, 0) === intNum(strnm[0], 0)) ? " selected=\"selected\"" : "") + ">" + strnm[1] + "</option>";
  2673. }
  2674. str += "</select></td>";
  2675. }
  2676. if (dir === "rtl") { pgl += str; }
  2677. if (ts.p.pginput === true) {
  2678. pginp = "<td id='input" + tp + "' dir='" + dir + "'>" + $.jgrid.template($.jgrid.getRegional(ts, "defaults.pgtext", ts.p.pgtext) || "", "<input class='ui-pg-input' type='text' size='2' maxlength='7' value='0' role='textbox'/>", "<span id='sp_1_" + $.jgrid.jqID(pgid) + "'></span>") + "</td>";
  2679. }
  2680. if (ts.p.pgbuttons === true) {
  2681. var po = ["first" + tp, "prev" + tp, "next" + tp, "last" + tp], btc = getstyle(stylemodule, 'pgButtonBox', true, 'ui-pg-button'),
  2682. pot = [($.jgrid.getRegional(ts, "defaults.pgfirst", ts.p.pgfirst) || ""),
  2683. ($.jgrid.getRegional(ts, "defaults.pgprev", ts.p.pgprev) || ""),
  2684. ($.jgrid.getRegional(ts, "defaults.pgnext", ts.p.pgnext) || ""),
  2685. ($.jgrid.getRegional(ts, "defaults.pglast", ts.p.pglast) || "")];
  2686. if (dir === "rtl") {
  2687. po.reverse();
  2688. pot.reverse();
  2689. }
  2690. pgl += "<td id='" + po[0] + "' class='" + btc + "' title='" + pot[0] + "'" + "><span " + getstyle(stylemodule, 'icon_first', false, iconbase) + "></span></td>";
  2691. pgl += "<td id='" + po[1] + "' class='" + btc + "' title='" + pot[1] + "'" + "><span " + getstyle(stylemodule, 'icon_prev', false, iconbase) + "></span></td>";
  2692. pgl += pginp !== "" ? sep + pginp + sep : "";
  2693. pgl += "<td id='" + po[2] + "' class='" + btc + "' title='" + pot[2] + "'" + "><span " + getstyle(stylemodule, 'icon_next', false, iconbase) + "></span></td>";
  2694. pgl += "<td id='" + po[3] + "' class='" + btc + "' title='" + pot[3] + "'" + "><span " + getstyle(stylemodule, 'icon_end', false, iconbase) + "></span></td>";
  2695. } else if (pginp !== "") {
  2696. pgl += pginp;
  2697. }
  2698. if (dir === "ltr") {
  2699. pgl += str;
  2700. }
  2701. pgl += "</tr></tbody></table>";
  2702. if (ts.p.viewrecords === true) {
  2703. $("td#" + pgid + "_" + ts.p.recordpos, "#" + pgcnt).append("<div dir='" + dir + "' style='text-align:" + ts.p.recordpos + "' class='ui-paging-info'></div>");
  2704. }
  2705. $("td#" + pgid + "_" + ts.p.pagerpos, "#" + pgcnt).append(pgl);
  2706. tdw = $("#gbox_" + $.jgrid.jqID(ts.p.id)).css("font-size") || "11px";
  2707. $("#gbox_" + $.jgrid.jqID(ts.p.id)).append("<div id='testpg' " + getstyle(stylemodule, 'entrieBox', false, 'ui-jqgrid') + " style='font-size:" + tdw + ";visibility:hidden;' ></div>");
  2708. twd = $(pgl).clone().appendTo("#testpg").width();
  2709. $("#testpg").remove();
  2710. if (twd > 0) {
  2711. if (pginp !== "") { twd += 50; } //should be param
  2712. $("td#" + pgid + "_" + ts.p.pagerpos, "#" + pgcnt).width(twd);
  2713. }
  2714. ts.p._nvtd = [];
  2715. ts.p._nvtd[0] = twd ? Math.floor((ts.p.width - twd) / 2) : Math.floor(ts.p.width / 3);
  2716. ts.p._nvtd[1] = 0;
  2717. pgl = null;
  2718. $('.ui-pg-selbox', "#" + pgcnt).bind('change', function () {
  2719. if (!clearVals('records', this)) { return false; }
  2720. ts.p.page = Math.round(ts.p.rowNum * (ts.p.page - 1) / this.value - 0.5) + 1;
  2721. ts.p.rowNum = this.value;
  2722. if (ts.p.pager) { $('.ui-pg-selbox', ts.p.pager).val(this.value); }
  2723. if (ts.p.toppager) { $('.ui-pg-selbox', ts.p.toppager).val(this.value); }
  2724. populate();
  2725. return false;
  2726. });
  2727. if (ts.p.pgbuttons === true) {
  2728. $(".ui-pg-button", "#" + pgcnt).hover(function () {
  2729. if ($(this).hasClass(disabled)) {
  2730. this.style.cursor = 'default';
  2731. } else {
  2732. $(this).addClass(hover);
  2733. this.style.cursor = 'pointer';
  2734. }
  2735. }, function () {
  2736. if (!$(this).hasClass(disabled)) {
  2737. $(this).removeClass(hover);
  2738. this.style.cursor = "default";
  2739. }
  2740. });
  2741. $("#first" + $.jgrid.jqID(tp) + ", #prev" + $.jgrid.jqID(tp) + ", #next" + $.jgrid.jqID(tp) + ", #last" + $.jgrid.jqID(tp)).click(function () {
  2742. if ($(this).hasClass(disabled)) {
  2743. return false;
  2744. }
  2745. var cp = intNum(ts.p.page, 1),
  2746. last = intNum(ts.p.lastpage, 1), selclick = false,
  2747. fp = true, pp = true, np = true, lp = true;
  2748. if (last === 0 || last === 1) {
  2749. fp = false;
  2750. pp = false;
  2751. np = false;
  2752. lp = false;
  2753. } else if (last > 1 && cp >= 1) {
  2754. if (cp === 1) {
  2755. fp = false;
  2756. pp = false;
  2757. } else if (cp === last) {
  2758. np = false;
  2759. lp = false;
  2760. }
  2761. } else if (last > 1 && cp === 0) {
  2762. np = false;
  2763. lp = false;
  2764. cp = last - 1;
  2765. }
  2766. if (!clearVals(this.id.split("_")[0], this)) { return false; }
  2767. if (this.id === 'first' + tp && fp) { ts.p.page = 1; selclick = true; }
  2768. if (this.id === 'prev' + tp && pp) { ts.p.page = (cp - 1); selclick = true; }
  2769. if (this.id === 'next' + tp && np) { ts.p.page = (cp + 1); selclick = true; }
  2770. if (this.id === 'last' + tp && lp) { ts.p.page = last; selclick = true; }
  2771. if (selclick) {
  2772. populate();
  2773. }
  2774. return false;
  2775. });
  2776. }
  2777. if (ts.p.pginput === true) {
  2778. $("#" + pgcnt).on('keypress', 'input.ui-pg-input', function (e) {
  2779. var key = e.charCode || e.keyCode || 0;
  2780. if (key === 13) {
  2781. if (!clearVals('user', this)) { return false; }
  2782. $(this).val(intNum($(this).val(), 1));
  2783. ts.p.page = ($(this).val() > 0) ? $(this).val() : ts.p.page;
  2784. populate();
  2785. return false;
  2786. }
  2787. return this;
  2788. });
  2789. }
  2790. },
  2791. multiSort = function (iCol, obj, sor) {
  2792. var cm = ts.p.colModel,
  2793. selTh = ts.p.frozenColumns ? obj : ts.grid.headers[iCol].el, so = "", sn;
  2794. $("span.ui-grid-ico-sort", selTh).addClass(disabled);
  2795. $(selTh).attr("aria-selected", "false");
  2796. sn = (cm[iCol].index || cm[iCol].name);
  2797. if (typeof sor == "undefined") {
  2798. if (cm[iCol].lso) {
  2799. if (cm[iCol].lso === "asc") {
  2800. cm[iCol].lso += "-desc";
  2801. so = "desc";
  2802. } else if (cm[iCol].lso === "desc") {
  2803. cm[iCol].lso += "-asc";
  2804. so = "asc";
  2805. } else if (cm[iCol].lso === "asc-desc" || cm[iCol].lso === "desc-asc") {
  2806. cm[iCol].lso = "";
  2807. }
  2808. } else {
  2809. cm[iCol].lso = so = cm[iCol].firstsortorder || 'asc';
  2810. }
  2811. }
  2812. else {
  2813. cm[iCol].lso = so = sor;
  2814. }
  2815. if (so) {
  2816. $("span.s-ico", selTh).show();
  2817. $("span.ui-icon-" + so, selTh).removeClass(disabled);
  2818. $(selTh).attr("aria-selected", "true");
  2819. } else {
  2820. if (!ts.p.viewsortcols[0]) {
  2821. $("span.s-ico", selTh).hide();
  2822. }
  2823. }
  2824. var isn = sortarr.indexOf(sn);
  2825. if (isn === -1) {
  2826. sortarr.push(sn);
  2827. sortord.push(so);
  2828. } else {
  2829. if (so) {
  2830. sortord[isn] = so;
  2831. } else {
  2832. sortord.splice(isn, 1);
  2833. sortarr.splice(isn, 1);
  2834. }
  2835. }
  2836. ts.p.sortorder = "";
  2837. ts.p.sortname = "";
  2838. for (var i = 0, len = sortarr.length; i < len ; i++) {
  2839. if (i > 0) {
  2840. ts.p.sortname += ", ";
  2841. }
  2842. ts.p.sortname += sortarr[i];
  2843. if (i !== len - 1) {
  2844. ts.p.sortname += " " + sortord[i];
  2845. }
  2846. }
  2847. ts.p.sortorder = sortord[len - 1];
  2848. /*
  2849. $.each(cm, function(i){
  2850. if(this.lso) {
  2851. if(i>0 && fs) {
  2852. sort += ", ";
  2853. }
  2854. splas = this.lso.split("-");
  2855. sort += cm[i].index || cm[i].name;
  2856. sort += " "+splas[splas.length-1];
  2857. fs = true;
  2858. ts.p.sortorder = splas[splas.length-1];
  2859. }
  2860. });
  2861. ls = sort.lastIndexOf(ts.p.sortorder);
  2862. sort = sort.substring(0, ls);
  2863. ts.p.sortname = sort;
  2864. */
  2865. },
  2866. sortData = function (index, idxcol, reload, sor, obj) {
  2867. if (!ts.p.colModel[idxcol].sortable) { return; }
  2868. if (ts.p.savedRow.length > 0) { return; }
  2869. if (!reload) {
  2870. if (ts.p.lastsort === idxcol && ts.p.sortname !== "") {
  2871. if (ts.p.sortorder === 'asc') {
  2872. ts.p.sortorder = 'desc';
  2873. } else if (ts.p.sortorder === 'desc') { ts.p.sortorder = 'asc'; }
  2874. } else { ts.p.sortorder = ts.p.colModel[idxcol].firstsortorder || 'asc'; }
  2875. ts.p.page = 1;
  2876. }
  2877. if (ts.p.multiSort) {
  2878. multiSort(idxcol, obj, sor);
  2879. } else {
  2880. if (sor) {
  2881. if (ts.p.lastsort === idxcol && ts.p.sortorder === sor && !reload) { return; }
  2882. ts.p.sortorder = sor;
  2883. }
  2884. var previousSelectedTh = ts.grid.headers[ts.p.lastsort] ? ts.grid.headers[ts.p.lastsort].el : null, newSelectedTh = ts.p.frozenColumns ? obj : ts.grid.headers[idxcol].el,
  2885. //sortrule = $.trim(ts.p.viewsortcols[1] === 'single' ? hidden : disabled);
  2886. usehide = ts.p.viewsortcols[1] === 'single' ? true : false, tmpicon;
  2887. tmpicon = $(previousSelectedTh).find("span.ui-grid-ico-sort");
  2888. tmpicon.addClass(disabled);
  2889. if (usehide) {
  2890. $(tmpicon).css("display", "none");
  2891. }
  2892. $(previousSelectedTh).attr("aria-selected", "false");
  2893. if (ts.p.frozenColumns) {
  2894. tmpicon = ts.grid.fhDiv.find("span.ui-grid-ico-sort");
  2895. tmpicon.addClass(disabled);
  2896. if (usehide) { tmpicon.css("display", "none"); }
  2897. ts.grid.fhDiv.find("th").attr("aria-selected", "false");
  2898. }
  2899. tmpicon = $(newSelectedTh).find("span.ui-icon-" + ts.p.sortorder);
  2900. tmpicon.removeClass(disabled);
  2901. if (usehide) { tmpicon.css("display", ""); }
  2902. $(newSelectedTh).attr("aria-selected", "true");
  2903. if (!ts.p.viewsortcols[0]) {
  2904. if (ts.p.lastsort !== idxcol) {
  2905. if (ts.p.frozenColumns) {
  2906. ts.grid.fhDiv.find("span.s-ico").hide();
  2907. }
  2908. $("span.s-ico", previousSelectedTh).hide();
  2909. $("span.s-ico", newSelectedTh).show();
  2910. } else if (ts.p.sortname === "") { // if ts.p.lastsort === idxcol but ts.p.sortname === ""
  2911. $("span.s-ico", newSelectedTh).show();
  2912. }
  2913. }
  2914. index = index.substring(5 + ts.p.id.length + 1); // bad to be changed!?!
  2915. ts.p.sortname = ts.p.colModel[idxcol].index || index;
  2916. }
  2917. if ($(ts).triggerHandler("jqGridSortCol", [ts.p.sortname, idxcol, ts.p.sortorder]) === 'stop') {
  2918. ts.p.lastsort = idxcol;
  2919. return;
  2920. }
  2921. if ($.isFunction(ts.p.onSortCol)) { if (ts.p.onSortCol.call(ts, ts.p.sortname, idxcol, ts.p.sortorder) === 'stop') { ts.p.lastsort = idxcol; return; } }
  2922. if (ts.p.datatype === "local") {
  2923. if (ts.p.deselectAfterSort) { $(ts).jqGrid("resetSelection"); }
  2924. } else {
  2925. ts.p.selrow = null;
  2926. if (ts.p.multiselect) { setHeadCheckBox(false); }
  2927. ts.p.selarrrow = [];
  2928. ts.p.savedRow = [];
  2929. }
  2930. if (ts.p.scroll) {
  2931. var sscroll = ts.grid.bDiv.scrollLeft;
  2932. emptyRows.call(ts, true, false);
  2933. ts.grid.hDiv.scrollLeft = sscroll;
  2934. }
  2935. if (ts.p.subGrid && ts.p.datatype === 'local') {
  2936. $("td.sgexpanded", "#" + $.jgrid.jqID(ts.p.id)).each(function () {
  2937. $(this).trigger("click");
  2938. });
  2939. }
  2940. ts.p._sort = true;
  2941. populate();
  2942. ts.p.lastsort = idxcol;
  2943. if (ts.p.sortname !== index && idxcol) { ts.p.lastsort = idxcol; }
  2944. },
  2945. setColWidth = function () {
  2946. var initwidth = 0, brd = $.jgrid.cell_width ? 0 : intNum(ts.p.cellLayout, 0), vc = 0, lvc, scw = intNum(ts.p.scrollOffset, 0), cw, hs = false, aw, gw = 0, cr;
  2947. $.each(ts.p.colModel, function () {
  2948. if (this.hidden === undefined) { this.hidden = false; }
  2949. if (ts.p.grouping && ts.p.autowidth) {
  2950. var ind = $.inArray(this.name, ts.p.groupingView.groupField);
  2951. if (ind >= 0 && ts.p.groupingView.groupColumnShow.length > ind) {
  2952. this.hidden = !ts.p.groupingView.groupColumnShow[ind];
  2953. }
  2954. }
  2955. this.widthOrg = cw = intNum(this.width, 0);
  2956. if (this.hidden === false) {
  2957. initwidth += cw + brd;
  2958. if (this.fixed) {
  2959. gw += cw + brd;
  2960. } else {
  2961. vc++;
  2962. }
  2963. }
  2964. });
  2965. if (isNaN(ts.p.width)) {
  2966. ts.p.width = initwidth + ((ts.p.shrinkToFit === false && !isNaN(ts.p.height)) ? scw : 0);
  2967. }
  2968. grid.width = parseInt(ts.p.width, 10);
  2969. ts.p.tblwidth = initwidth;
  2970. if (ts.p.shrinkToFit === false && ts.p.forceFit === true) { ts.p.forceFit = false; }
  2971. if (ts.p.shrinkToFit === true && vc > 0) {
  2972. aw = grid.width - brd * vc - gw;
  2973. if (!isNaN(ts.p.height)) {
  2974. aw -= scw;
  2975. hs = true;
  2976. }
  2977. initwidth = 0;
  2978. $.each(ts.p.colModel, function (i) {
  2979. if (this.hidden === false && !this.fixed) {
  2980. cw = Math.round(aw * this.width / (ts.p.tblwidth - brd * vc - gw));
  2981. this.width = cw;
  2982. initwidth += cw;
  2983. lvc = i;
  2984. }
  2985. });
  2986. cr = 0;
  2987. if (hs) {
  2988. if (grid.width - gw - (initwidth + brd * vc) !== scw) {
  2989. cr = grid.width - gw - (initwidth + brd * vc) - scw;
  2990. }
  2991. } else if (!hs && Math.abs(grid.width - gw - (initwidth + brd * vc)) !== 1) {
  2992. cr = grid.width - gw - (initwidth + brd * vc);
  2993. }
  2994. ts.p.colModel[lvc].width += cr;
  2995. ts.p.tblwidth = initwidth + cr + brd * vc + gw;
  2996. if (ts.p.tblwidth > ts.p.width) {
  2997. ts.p.colModel[lvc].width -= (ts.p.tblwidth - parseInt(ts.p.width, 10));
  2998. ts.p.tblwidth = ts.p.width;
  2999. }
  3000. }
  3001. },
  3002. nextVisible = function (iCol) {
  3003. var ret = iCol, j = iCol, i;
  3004. for (i = iCol + 1; i < ts.p.colModel.length; i++) {
  3005. if (ts.p.colModel[i].hidden !== true) {
  3006. j = i; break;
  3007. }
  3008. }
  3009. return j - ret;
  3010. },
  3011. getOffset = function (iCol) {
  3012. var $th = $(ts.grid.headers[iCol].el), ret = [$th.position().left + $th.outerWidth()];
  3013. if (ts.p.direction === "rtl") { ret[0] = ts.p.width - ret[0]; }
  3014. ret[0] -= ts.grid.bDiv.scrollLeft;
  3015. ret.push($(ts.grid.hDiv).position().top);
  3016. ret.push($(ts.grid.bDiv).offset().top - $(ts.grid.hDiv).offset().top + $(ts.grid.bDiv).height());
  3017. return ret;
  3018. },
  3019. getColumnHeaderIndex = function (th) {
  3020. var i, headers = ts.grid.headers, ci = $.jgrid.getCellIndex(th);
  3021. for (i = 0; i < headers.length; i++) {
  3022. if (th === headers[i].el) {
  3023. ci = i;
  3024. break;
  3025. }
  3026. }
  3027. return ci;
  3028. },
  3029. buildColItems = function (top, left, parent) {
  3030. var cm = ts.p.colModel, len = cm.length, i, cols = [], disp,
  3031. texts = $.jgrid.getRegional(ts, "colmenu"),
  3032. str1 = '<ul id="col_menu" class="ui-search-menu ui-col-menu modal-content" role="menu" tabindex="0" style="left:' + left + 'px;top:' + top + 'px;">';
  3033. for (i = 0; i < len; i++) {
  3034. //if(!cm[i].hidedlg) { // column chooser
  3035. var hid = !cm[i].hidden ? "checked" : "", nm = cm[i].name, lb = ts.p.colNames[i];
  3036. disp = (nm === 'cb' || nm === 'subgrid' || nm === 'rn' || cm[i].hidedlg) ? "style='display:none'" : "";
  3037. str1 += '<li ' + disp + ' class="ui-menu-item" role="presentation" draggable="true"><a class="g-menu-item" tabindex="0" role="menuitem" ><table class="ui-common-table" ><tr><td class="menu_icon" title="' + texts.reorder + '"><span class="' + iconbase + ' ' + colmenustyle.icon_move + ' notclick"></span></td><td class="menu_icon"><input class="' + colmenustyle.input_checkbox + '" type="checkbox" name="' + nm + '" ' + hid + '></td><td class="menu_text">' + lb + '</td></tr></table></a></li>';
  3038. cols.push(i);
  3039. }
  3040. str1 += "</ul>";
  3041. $(parent).append(str1);
  3042. $("#col_menu").addClass("ui-menu " + colmenustyle.menu_widget);
  3043. if ($.fn.html5sortable()) {
  3044. $("#col_menu").html5sortable({
  3045. handle: 'span',
  3046. forcePlaceholderSize: true
  3047. }
  3048. ).bind('sortupdate', function (e, ui) {
  3049. cols.splice(ui.startindex, 1);
  3050. cols.splice(ui.endindex, 0, ui.startindex);
  3051. $(ts).jqGrid("destroyFrozenColumns");
  3052. $(ts).jqGrid("remapColumns", cols, true);
  3053. $(ts).jqGrid("setFrozenColumns");
  3054. for (i = 0; i < len; i++) {
  3055. cols[i] = i;
  3056. }
  3057. });
  3058. } // NO jQuery UI
  3059. $("#col_menu > li > a").on("click", function (e) {
  3060. var checked;
  3061. if ($(e.target).hasClass('notclick')) {
  3062. return;
  3063. }
  3064. if ($(e.target).is(":input")) {
  3065. checked = $(e.target).is(":checked");
  3066. } else {
  3067. checked = !$("input", this).is(":checked");
  3068. $("input", this).prop("checked", checked);
  3069. }
  3070. if (!checked) {
  3071. $(ts).jqGrid('hideCol', $("input", this).attr('name'));
  3072. $(this).parent().attr("draggable", "false");
  3073. } else {
  3074. $(ts).jqGrid('showCol', $("input", this).attr('name'));
  3075. $(this).parent().attr("draggable", "true");
  3076. }
  3077. }).hover(function () {
  3078. $(this).addClass(hover);
  3079. }, function () {
  3080. $(this).removeClass(hover);
  3081. });
  3082. },
  3083. buildSearchBox = function (index, top, left, parent) {
  3084. var cm = ts.p.colModel[index], rules, o1 = '', v1 = '', r1 = '', o2 = '', v2 = '', so, op, repstr = '', selected, elem,
  3085. numopts = ['eq', 'ne', 'lt', 'le', 'gt', 'ge', 'nu', 'nn', 'in', 'ni'],
  3086. stropts = ['eq', 'ne', 'bw', 'bn', 'ew', 'en', 'cn', 'nc', 'nu', 'nn', 'in', 'ni'],
  3087. texts = $.jgrid.getRegional(ts, "search"),
  3088. common = $.jgrid.styleUI[(ts.p.styleUI || 'jQueryUI')].common;
  3089. if (!cm) {
  3090. return;
  3091. }
  3092. rules = ts.p.colFilters && ts.p.colFilters[cm.name] ? ts.p.colFilters[cm.name] : false;
  3093. if (rules && !$.isEmptyObject(rules)) {
  3094. o1 = rules.oper1;
  3095. v1 = rules.value1;
  3096. r1 = rules.rule;
  3097. o2 = rules.oper2;
  3098. v2 = rules.value2;
  3099. }
  3100. if (!cm.searchoptions) {
  3101. cm.searchoptions = {};
  3102. }
  3103. if (cm.searchoptions.sopt) {
  3104. so = cm.searchoptions.sopt;
  3105. } else if (cm.sorttype === 'text') {
  3106. so = stropts;
  3107. } else {
  3108. so = numopts;
  3109. }
  3110. if (cm.searchoptions.operands) {
  3111. op = cm.searchoptions.operands;
  3112. } else {
  3113. op = texts.groupOps;
  3114. }
  3115. //elem = $('<ul id="search_menu" class="ui-search-menu modal-content" role="menu" tabindex="0" style="left:'+left+'px;top:'+top+'px;"></ul>');
  3116. elem = $('<form></form>');
  3117. var str1 = '<div>' + $.jgrid.getRegional(ts, "colmenu.searchTitle") + '</div>';
  3118. str1 += '<div><select id="oper1" class="' + colmenustyle.filter_select + '">';
  3119. $.each(texts.odata, function (i, n) {
  3120. selected = n.oper === o1 ? 'selected="selected"' : '';
  3121. if ($.inArray(n.oper, so) !== -1) {
  3122. repstr += '<option value="' + n.oper + '" ' + selected + '>' + n.text + '</option>';
  3123. }
  3124. });
  3125. str1 += repstr;
  3126. str1 += '</select></div>';
  3127. elem.append(str1);
  3128. var df = "";
  3129. if (cm.searchoptions.defaultValue) {
  3130. df = $.isFunction(cm.searchoptions.defaultValue) ? cm.searchoptions.defaultValue.call(ts) : cm.searchoptions.defaultValue;
  3131. }
  3132. //overwrite default value if restore from filters
  3133. if (v1) {
  3134. df = v1;
  3135. }
  3136. var soptions = $.extend(cm.searchoptions, { name: cm.index || cm.name, id: "sval1_" + ts.p.idPrefix + cm.name, oper: 'search' })
  3137. var input = $.jgrid.createEl.call(ts, cm.stype, soptions, df, false, $.extend({}, $.jgrid.ajaxOptions, ts.p.ajaxSelectOptions || {}));
  3138. $(input).addClass(colmenustyle.filter_input);
  3139. str1 = $('<div></div>').append(input);
  3140. elem.append(str1);
  3141. // and/or
  3142. str1 = '<div><select id="operand" class="' + colmenustyle.filter_select + '">';
  3143. $.each(op, function (i, n) {
  3144. selected = n.op === r1 ? 'selected="selected"' : '';
  3145. str1 += "<option value='" + n.op + "' " + selected + ">" + n.text + "</option>";
  3146. });
  3147. str1 += '</select></div>';
  3148. elem.append(str1);
  3149. //oper2
  3150. repstr = '';
  3151. $.each(texts.odata, function (i, n) {
  3152. selected = n.oper === o2 ? 'selected="selected"' : '';
  3153. if ($.inArray(n.oper, so) !== -1) {
  3154. repstr += '<option value="' + n.oper + '" ' + selected + '>' + n.text + '</option>';
  3155. }
  3156. });
  3157. str1 = '<div><select id="oper2" class="' + colmenustyle.filter_select + '">' + repstr + '</select></div>';
  3158. elem.append(str1);
  3159. // value2
  3160. if (v2) {
  3161. df = v2;
  3162. } else {
  3163. df = "";
  3164. }
  3165. soptions = $.extend(cm.searchoptions, { name: cm.index || cm.name, id: "sval2_" + ts.p.idPrefix + cm.name, oper: 'search' });
  3166. input = $.jgrid.createEl.call(ts, cm.stype, soptions, df, false, $.extend({}, $.jgrid.ajaxOptions, ts.p.ajaxSelectOptions || {}));
  3167. $(input).addClass(colmenustyle.filter_input);
  3168. str1 = $('<div></div>').append(input);
  3169. elem.append(str1);
  3170. // buttons
  3171. str1 = "<div>";
  3172. str1 += "<div class='search_buttons'><a tabindex='0' id='bs_reset' class='fm-button " + common.button + " ui-reset'>" + texts.Reset + "</a></div>";
  3173. str1 += "<div class='search_buttons'><a tabindex='0' id='bs_search' class='fm-button " + common.button + " ui-search'>" + texts.Find + "</a></div>";
  3174. str1 += "</div>";
  3175. elem.append(str1);
  3176. elem = $('<li class="ui-menu-item" role="presentation"></li>').append(elem);
  3177. elem = $('<ul id="search_menu" class="ui-search-menu modal-content" role="menu" tabindex="0" style="left:' + left + 'px;top:' + top + 'px;"></ul>').append(elem);
  3178. $(parent).append(elem);
  3179. $("#search_menu").addClass("ui-menu " + colmenustyle.menu_widget);
  3180. $("#bs_reset, #bs_search", "#search_menu").hover(function () {
  3181. $(this).addClass(hover);
  3182. }, function () {
  3183. $(this).removeClass(hover);
  3184. });
  3185. $(elem).find("#bs_reset").click(function (e) {
  3186. ts.p.colFilters[cm.name] = {};
  3187. ts.p.postData.filters = buildFilters();
  3188. ts.p.search = true;
  3189. $(ts).trigger("reloadGrid");
  3190. $("#column_menu").remove();
  3191. return false;
  3192. });
  3193. $(elem).find("#bs_search").click(function (e) {
  3194. ts.p.colFilters[cm.name] = {
  3195. oper1: $("#oper1", "#search_menu").val(),
  3196. value1: $("#sval1_" + ts.p.idPrefix + cm.name, "#search_menu").val(),
  3197. rule: $("#operand", "#search_menu").val(),
  3198. oper2: $("#oper2", "#search_menu").val(),
  3199. value2: $("#sval2_" + ts.p.idPrefix + cm.name, "#search_menu").val()
  3200. };
  3201. ts.p.postData.filters = buildFilters();
  3202. ts.p.search = true;
  3203. $(ts).trigger("reloadGrid");
  3204. $("#column_menu").remove();
  3205. return false;
  3206. });
  3207. },
  3208. buildFilters = function () {
  3209. var go = "AND",
  3210. filters = "{\"groupOp\":\"" + go + "\",\"rules\":[], \"groups\" : [", i = 0;
  3211. for (var item in ts.p.colFilters) {
  3212. if (ts.p.colFilters.hasOwnProperty(item)) {
  3213. var si = ts.p.colFilters[item];
  3214. if (!$.isEmptyObject(si)) {
  3215. if (i > 0) {
  3216. filters += ",";
  3217. }
  3218. filters += "{\"groupOp\": \"" + si.rule + "\", \"rules\" : [";
  3219. filters += "{\"field\":\"" + item + "\",";
  3220. filters += "\"op\":\"" + si.oper1 + "\",";
  3221. si.value1 += "";
  3222. filters += "\"data\":\"" + si.value1.replace(/\\/g, '\\\\').replace(/\"/g, '\\"') + "\"}";
  3223. if (si.value2) {
  3224. filters += ",{\"field\":\"" + item + "\",";
  3225. filters += "\"op\":\"" + si.oper2 + "\",";
  3226. si.value2 += "";
  3227. filters += "\"data\":\"" + si.value2.replace(/\\/g, '\\\\').replace(/\"/g, '\\"') + "\"}";
  3228. }
  3229. filters += "]}";
  3230. i++;
  3231. } else {
  3232. //console.log('empty object');
  3233. }
  3234. }
  3235. }
  3236. filters += "]}";
  3237. return filters;
  3238. },
  3239. buildGrouping = function (index, isgroup) {
  3240. var cm = ts.p.colModel[index],
  3241. group = ts.p.groupingView;
  3242. if (isgroup !== -1) {
  3243. group.groupField.splice(isgroup, 1);
  3244. } else {
  3245. group.groupField.push(cm.name);
  3246. }
  3247. $(ts).jqGrid('groupingGroupBy', group.groupField);
  3248. if (ts.p.frozenColumns) {
  3249. $(ts).jqGrid("destroyFrozenColumns");
  3250. $(ts).jqGrid("setFrozenColumns");
  3251. }
  3252. },
  3253. buildFreeze = function (index, isfreeze) {
  3254. var cols = [], i, len = ts.p.colModel.length, lastfrozen = -1, cm = ts.p.colModel;;
  3255. for (i = 0; i < len; i++) {
  3256. if (cm[i].frozen) {
  3257. lastfrozen = i;
  3258. }
  3259. cols.push(i);
  3260. }
  3261. // from position index to lastfrozen+1
  3262. cols.splice(index, 1);
  3263. cols.splice(lastfrozen + (isfreeze ? 1 : 0), 0, index);
  3264. cm[index].frozen = isfreeze;
  3265. $(ts).jqGrid("destroyFrozenColumns");
  3266. $(ts).jqGrid("remapColumns", cols, true);
  3267. $(ts).jqGrid("setFrozenColumns");
  3268. },
  3269. buildColMenu = function (index, left, top) {
  3270. //$("#sopt_menu").remove();
  3271. left = parseInt(left, 10);
  3272. top = parseInt(top, 10) + 25;
  3273. var fs = $('.ui-jqgrid-view').css('font-size') || '11px';
  3274. var str = '<ul id="column_menu" class="ui-search-menu modal-content column-menu" role="menu" tabindex="0" style="font-size:' + fs + ';left:' + left + 'px;top:' + top + 'px;">',
  3275. cm = ts.p.colModel[index], op = $.extend({ sorting: true, columns: true, filtering: true, seraching: true, grouping: true, freeze: true }, cm.coloptions),
  3276. texts = $.jgrid.getRegional(ts, "colmenu"),
  3277. isgroup, isfreeze; // ???
  3278. // sorting
  3279. if (op.sorting) {
  3280. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="sortasc"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_sort_asc + '"></span></td><td class="menu_text">' + texts.sortasc + '</td></tr></table></a></li>';
  3281. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="sortdesc"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_sort_desc + '"></span></td><td class="menu_text">' + texts.sortdesc + '</td></tr></table></a></li>';
  3282. }
  3283. if (op.columns) {
  3284. str += '<li class="ui-menu-item divider" role="separator"></li>';
  3285. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="columns"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_columns + '"></span></td><td class="menu_text">' + texts.columns + '</td></tr></table></a></li>';
  3286. }
  3287. if (op.filtering) {
  3288. str += '<li class="ui-menu-item divider" role="separator"></li>';
  3289. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="filtering"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_filter + '"></span></td><td class="menu_text">' + texts.filter + ' ' + (cm.label || cm.name) + '</td></tr></table></a></li>';
  3290. }
  3291. if (op.grouping) {
  3292. isgroup = $.inArray(cm.name, ts.p.groupingView.groupField);
  3293. str += '<li class="ui-menu-item divider" role="separator"></li>';
  3294. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="grouping"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_group + '"></span></td><td class="menu_text">' + (isgroup !== -1 ? texts.ungrouping : texts.grouping + ' ' + (cm.label || cm.name)) + '</td></tr></table></a></li>';
  3295. }
  3296. if (op.freeze) {
  3297. isfreeze = (cm.frozen && ts.p.frozenColumns) ? false : true;
  3298. str += '<li class="ui-menu-item divider" role="separator"></li>';
  3299. str += '<li class="ui-menu-item" role="presentation"><a class="g-menu-item" tabindex="0" role="menuitem" value="freeze"><table class="ui-common-table"><tr><td class="menu_icon"><span class="' + iconbase + ' ' + colmenustyle.icon_freeze + '"></span></td><td class="menu_text">' + (isfreeze ? (texts.freeze + " " + (cm.label || cm.name)) : texts.unfreeze) + '</td></tr></table></a></li>';
  3300. }
  3301. str += "</ul>";
  3302. $('body').append(str);
  3303. $("#column_menu").addClass("ui-menu " + colmenustyle.menu_widget);
  3304. $("#column_menu > li > a").hover(
  3305. function () {
  3306. $("#col_menu").remove();
  3307. $("#search_menu").remove();
  3308. if ($(this).attr("value") === 'columns') {
  3309. var left1 = $(this).parent().width() + 18,
  3310. top1 = $(this).parent().position().top - 5;
  3311. buildColItems(top1, left1, $(this).parent());
  3312. }
  3313. if ($(this).attr("value") === 'filtering') {
  3314. var left1 = $(this).parent().width() + 18,
  3315. top1 = $(this).parent().position().top - 5;
  3316. buildSearchBox(index, top1, left1, $(this).parent());
  3317. }
  3318. $(this).addClass(hover);
  3319. },
  3320. function () { $(this).removeClass(hover); }
  3321. ).click(function () {
  3322. var v = $(this).attr("value"),
  3323. sobj = ts.grid.headers[index].el;
  3324. if (v === 'sortasc') {
  3325. sortData("jqgh_" + ts.p.id + "_" + cm.name, index, true, 'asc', sobj);
  3326. } else if (v === 'sortdesc') {
  3327. sortData("jqgh_" + ts.p.id + "_" + cm.name, index, true, 'desc', sobj);
  3328. } else if (v === 'grouping') {
  3329. buildGrouping(index, isgroup);
  3330. } else if (v === 'freeze') {
  3331. buildFreeze(index, isfreeze);
  3332. }
  3333. if (v.indexOf('sort') !== -1 || v === 'grouping' || v === 'freeze') {
  3334. $(this).remove();
  3335. }
  3336. });
  3337. },
  3338. colTemplate;
  3339. if (ts.p.colMenu) {
  3340. $("body").on('click', function (e) {
  3341. if (!$(e.target).closest(".column-menu").length) {
  3342. $("#column_menu").remove();
  3343. }
  3344. });
  3345. }
  3346. this.p.id = this.id;
  3347. if ($.inArray(ts.p.multikey, sortkeys) === -1) { ts.p.multikey = false; }
  3348. ts.p.keyName = false;
  3349. for (i = 0; i < ts.p.colModel.length; i++) {
  3350. colTemplate = typeof ts.p.colModel[i].template === "string" ?
  3351. ($.jgrid.cmTemplate != null && typeof $.jgrid.cmTemplate[ts.p.colModel[i].template] === "object" ? $.jgrid.cmTemplate[ts.p.colModel[i].template] : {}) :
  3352. ts.p.colModel[i].template;
  3353. ts.p.colModel[i] = $.extend(true, {}, ts.p.cmTemplate, colTemplate || {}, ts.p.colModel[i]);
  3354. if (ts.p.keyName === false && ts.p.colModel[i].key === true) {
  3355. ts.p.keyName = ts.p.colModel[i].name;
  3356. }
  3357. }
  3358. ts.p.sortorder = ts.p.sortorder.toLowerCase();
  3359. $.jgrid.cell_width = $.jgrid.cellWidth();
  3360. if (ts.p.grouping === true) {
  3361. ts.p.scroll = false;
  3362. ts.p.rownumbers = false;
  3363. //ts.p.subGrid = false; expiremental
  3364. ts.p.treeGrid = false;
  3365. ts.p.gridview = true;
  3366. }
  3367. if (this.p.treeGrid === true) {
  3368. try { $(this).jqGrid("setTreeGrid"); } catch (_) { }
  3369. if (ts.p.datatype !== "local") { ts.p.localReader = { id: "_id_" }; }
  3370. }
  3371. if (this.p.subGrid) {
  3372. try { $(ts).jqGrid("setSubGrid"); } catch (s) { }
  3373. }
  3374. if (this.p.multiselect) {
  3375. this.p.colNames.unshift("<div class=\"ckbox\"><input role=\"checkbox\" type=\"checkbox\"" + " id=\"cb_" + this.p.id + "\"><label for=\"cb_" + this.p.id + "\"></label></div>");
  3376. this.p.colModel.unshift({ name: 'cb', width: $.jgrid.cell_width ? ts.p.multiselectWidth + ts.p.cellLayout : ts.p.multiselectWidth, sortable: false, resizable: false, hidedlg: true, search: false, align: 'center', fixed: true, frozen: true });
  3377. }
  3378. if (this.p.rownumbers) {
  3379. this.p.colNames.unshift("");
  3380. this.p.colModel.unshift({ name: 'rn', width: ts.p.rownumWidth, sortable: false, resizable: false, hidedlg: true, search: false, align: 'center', fixed: true, frozen: true });
  3381. }
  3382. ts.p.xmlReader = $.extend(true, {
  3383. root: "rows",
  3384. row: "row",
  3385. page: "rows>page",
  3386. total: "rows>total",
  3387. records: "rows>records",
  3388. repeatitems: true,
  3389. cell: "cell",
  3390. id: "[id]",
  3391. userdata: "userdata",
  3392. subgrid: { root: "rows", row: "row", repeatitems: true, cell: "cell" }
  3393. }, ts.p.xmlReader);
  3394. ts.p.jsonReader = $.extend(true, {
  3395. root: "rows",
  3396. page: "page",
  3397. total: "total",
  3398. records: "records",
  3399. repeatitems: true,
  3400. cell: "cell",
  3401. id: "id",
  3402. userdata: "userdata",
  3403. subgrid: { root: "rows", repeatitems: true, cell: "cell" }
  3404. }, ts.p.jsonReader);
  3405. ts.p.localReader = $.extend(true, {
  3406. root: "rows",
  3407. page: "page",
  3408. total: "total",
  3409. records: "records",
  3410. repeatitems: false,
  3411. cell: "cell",
  3412. id: "id",
  3413. userdata: "userdata",
  3414. subgrid: { root: "rows", repeatitems: true, cell: "cell" }
  3415. }, ts.p.localReader);
  3416. if (ts.p.scroll) {
  3417. ts.p.pgbuttons = false; ts.p.pginput = false; ts.p.rowList = [];
  3418. }
  3419. if (ts.p.data.length) { normalizeData(); refreshIndex(); }
  3420. var thead = "<thead><tr class='ui-jqgrid-labels' role='row'>",
  3421. tdc, idn, w, res, sort = "",
  3422. td, ptr, tbody, imgs, iac = "", idc = "", tmpcm;
  3423. if (ts.p.shrinkToFit === true && ts.p.forceFit === true) {
  3424. for (i = ts.p.colModel.length - 1; i >= 0; i--) {
  3425. if (!ts.p.colModel[i].hidden) {
  3426. ts.p.colModel[i].resizable = false;
  3427. break;
  3428. }
  3429. }
  3430. }
  3431. if (ts.p.viewsortcols[1] === 'horizontal') {
  3432. iac = " ui-i-asc";
  3433. idc = " ui-i-desc";
  3434. } else if (ts.p.viewsortcols[1] === "single") {
  3435. iac = " ui-single-sort-asc";
  3436. idc = " ui-single-sort-desc";
  3437. sort = " style='display:none'";
  3438. ts.p.viewsortcols[0] = false;
  3439. }
  3440. tdc = isMSIE ? "class='ui-th-div-ie'" : "";
  3441. imgs = "<span class='s-ico' style='display:none'>";
  3442. imgs += "<span sort='asc' class='ui-grid-ico-sort ui-icon-asc" + iac + " ui-sort-" + dir + " " + disabled + " " + iconbase + " " + getstyle(stylemodule, 'icon_asc', true) + "'" + sort + "></span>";
  3443. imgs += "<span sort='desc' class='ui-grid-ico-sort ui-icon-desc" + idc + " ui-sort-" + dir + " " + disabled + " " + iconbase + " " + getstyle(stylemodule, 'icon_desc', true) + "'" + sort + "></span></span>";
  3444. if (ts.p.multiSort) {
  3445. if (ts.p.sortname) {
  3446. sortarr = ts.p.sortname.split(",");
  3447. for (i = 0; i < sortarr.length; i++) {
  3448. sotmp = $.trim(sortarr[i]).split(" ");
  3449. sortarr[i] = $.trim(sotmp[0]);
  3450. sortord[i] = sotmp[1] ? $.trim(sotmp[1]) : ts.p.sortorder || "asc";
  3451. }
  3452. }
  3453. }
  3454. //扩展
  3455. var _used_width = 0;
  3456. var _colNo = 0;
  3457. for (i = 0; i < this.p.colNames.length; i++) {
  3458. var _hidden = ts.p.colModel[i].hidden;
  3459. if (ts.p.colModel[i].autowidth == true) {
  3460. _colNo = i;
  3461. break;
  3462. }
  3463. if (_hidden == undefined) {
  3464. _colNo = i;
  3465. }
  3466. }
  3467. for (i = 0; i < this.p.colNames.length; i++) {
  3468. var tooltip = ts.p.headertitles ? (" title=\"" + $.jgrid.stripHtml(ts.p.colNames[i]) + "\"") : "";
  3469. tmpcm = ts.p.colModel[i];
  3470. //扩展
  3471. var _hidden = tmpcm.hidden;
  3472. var _width = tmpcm.width;
  3473. if (_hidden != undefined) {
  3474. _width = 0;
  3475. } else {
  3476. _used_width += _width + 8;
  3477. }
  3478. if (i == _colNo) {
  3479. if ($("#gview_" + ts.p.id).width() > _used_width) {
  3480. if (tmpcm.autowidth == true || tmpcm.autowidth == undefined) {
  3481. _width = _width + $("#gview_" + ts.p.id).width() - _used_width - 22;
  3482. }
  3483. }
  3484. }
  3485. if (!tmpcm.hasOwnProperty('colmenu')) {
  3486. tmpcm.colmenu = (tmpcm.name === "rn" || tmpcm.name === "cb" || tmpcm.name === "subgrid") ? false : true;
  3487. }
  3488. thead += "<th id='" + ts.p.id + "_" + tmpcm.name + "' style='text-align:" + tmpcm.align + ";' role='columnheader' " + getstyle(stylemodule, 'headerBox', false, "ui-th-column ui-th-" + dir) + " " + tooltip + ">";
  3489. idn = tmpcm.index || tmpcm.name;
  3490. thead += "<div class='ui-th-div' id='jqgh_" + ts.p.id + "_" + tmpcm.name + "' " + tdc + ">" + ts.p.colNames[i];
  3491. tmpcm.width = _width ? parseInt(_width, 10) : 150
  3492. if (typeof tmpcm.title !== "boolean") {
  3493. tmpcm.title = true;
  3494. }
  3495. tmpcm.lso = "";
  3496. if (idn === ts.p.sortname) {
  3497. ts.p.lastsort = i;
  3498. }
  3499. if (ts.p.multiSort) {
  3500. sotmp = $.inArray(idn, sortarr);
  3501. if (sotmp !== -1) {
  3502. tmpcm.lso = sortord[sotmp];
  3503. }
  3504. }
  3505. thead += imgs;
  3506. if (ts.p.colMenu && tmpcm.colmenu) {
  3507. thead += "<a class='colmenu' href='#/'><span class='colmenuspan " + iconbase + ' ' + colmenustyle.icon_menu + "'></span></a>";
  3508. }
  3509. thead += "</div></th>";
  3510. }
  3511. thead += "</tr></thead>";
  3512. imgs = null;
  3513. tmpcm = null;
  3514. $(this).append(thead);
  3515. $("thead tr:first th", this).hover(
  3516. function () { $(this).addClass(hover); },
  3517. function () { $(this).removeClass(hover); }
  3518. );
  3519. if (this.p.multiselect) {
  3520. var emp = [], chk;
  3521. $('#cb_' + $.jgrid.jqID(ts.p.id), this).bind('click', function () {
  3522. ts.p.selarrrow = [];
  3523. var froz = ts.p.frozenColumns === true ? ts.p.id + "_frozen" : "";
  3524. if (this.checked) {
  3525. $(ts.rows).each(function (i) {
  3526. if (i > 0) {
  3527. if (!$(this).hasClass("ui-subgrid") && !$(this).hasClass("jqgroup") && !$(this).hasClass(disabled) && !$(this).hasClass("jqfoot")) {
  3528. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(this.id))[ts.p.useProp ? 'prop' : 'attr']("checked", true);
  3529. $(this).addClass(highlight).attr("aria-selected", "true");
  3530. ts.p.selarrrow.push(this.id);
  3531. ts.p.selrow = this.id;
  3532. if (froz) {
  3533. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(this.id), ts.grid.fbDiv)[ts.p.useProp ? 'prop' : 'attr']("checked", true);
  3534. $("#" + $.jgrid.jqID(this.id), ts.grid.fbDiv).addClass(highlight);
  3535. }
  3536. }
  3537. }
  3538. });
  3539. chk = true;
  3540. emp = [];
  3541. }
  3542. else {
  3543. $(ts.rows).each(function (i) {
  3544. if (i > 0) {
  3545. if (!$(this).hasClass("ui-subgrid") && !$(this).hasClass("jqgroup") && !$(this).hasClass(disabled) && !$(this).hasClass("jqfoot")) {
  3546. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(this.id))[ts.p.useProp ? 'prop' : 'attr']("checked", false);
  3547. $(this).removeClass(highlight).attr("aria-selected", "false");
  3548. emp.push(this.id);
  3549. if (froz) {
  3550. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(this.id), ts.grid.fbDiv)[ts.p.useProp ? 'prop' : 'attr']("checked", false);
  3551. $("#" + $.jgrid.jqID(this.id), ts.grid.fbDiv).removeClass(highlight);
  3552. }
  3553. }
  3554. }
  3555. });
  3556. ts.p.selrow = null;
  3557. chk = false;
  3558. }
  3559. $(ts).triggerHandler("jqGridSelectAll", [chk ? ts.p.selarrrow : emp, chk]);
  3560. if ($.isFunction(ts.p.onSelectAll)) { ts.p.onSelectAll.call(ts, chk ? ts.p.selarrrow : emp, chk); }
  3561. });
  3562. }
  3563. if (ts.p.autowidth === true) {
  3564. var pw = $(eg).innerWidth();
  3565. ts.p.width = pw > 0 ? pw : 'nw';
  3566. }
  3567. setColWidth();
  3568. $(eg).css("width", grid.width + "px").append("<div class='ui-jqgrid-resize-mark' id='rs_m" + ts.p.id + "'>&#160;</div>");
  3569. if (ts.p.scrollPopUp) {
  3570. $(eg).append("<div " + getstyle(stylemodule, 'scrollBox', false, 'loading ui-scroll-popup') + " id='scroll_g" + ts.p.id + "'></div>");
  3571. }
  3572. $(gv).css("width", grid.width + "px");
  3573. thead = $("thead:first", ts).get(0);
  3574. var tfoot = "";
  3575. if (ts.p.footerrow) { tfoot += "<table role='presentation' style='width:" + ts.p.tblwidth + "px' " + getstyle(stylemodule, 'footerTable', false, 'ui-jqgrid-ftable ui-common-table') + "><tbody><tr role='row' " + getstyle(stylemodule, 'footerBox', false, 'footrow footrow-' + dir) + ">"; }
  3576. var thr = $("tr:first", thead),
  3577. firstr = "<tr class='jqgfirstrow' role='row'>";
  3578. ts.p.disableClick = false;
  3579. $("th", thr).each(function (j) {
  3580. tmpcm = ts.p.colModel[j];
  3581. w = tmpcm.width;
  3582. if (tmpcm.resizable === undefined) {
  3583. tmpcm.resizable = true;
  3584. }
  3585. if (tmpcm.resizable) {
  3586. res = document.createElement("span");
  3587. $(res).html("&#160;").addClass('ui-jqgrid-resize ui-jqgrid-resize-' + dir)
  3588. .css("cursor", "col-resize");
  3589. $(this).addClass(ts.p.resizeclass);
  3590. } else {
  3591. res = "";
  3592. }
  3593. $(this).css("width", w + "px").prepend(res);
  3594. res = null;
  3595. var hdcol = "";
  3596. if (tmpcm.hidden) {
  3597. $(this).css("display", "none");
  3598. hdcol = "display:none;";
  3599. }
  3600. firstr += "<td role='gridcell' style='height:0px;width:" + w + "px;" + hdcol + "'></td>";
  3601. grid.headers[j] = { width: w, el: this };
  3602. sort = tmpcm.sortable;
  3603. if (typeof sort !== 'boolean') {
  3604. tmpcm.sortable = true;
  3605. sort = true;
  3606. }
  3607. var nm = tmpcm.name;
  3608. if (!(nm === 'cb' || nm === 'subgrid' || nm === 'rn')) {
  3609. if (ts.p.viewsortcols[2]) {
  3610. $(">div", this).addClass('ui-jqgrid-sortable');
  3611. }
  3612. }
  3613. if (sort) {
  3614. if (ts.p.multiSort) {
  3615. if (ts.p.viewsortcols[0]) {
  3616. $("div span.s-ico", this).show();
  3617. if (ts.p.colModel[j].lso) {
  3618. $("div span.ui-icon-" + tmpcm.lso, this).removeClass(disabled).css("display", "");
  3619. }
  3620. } else if (ts.p.colModel[j].lso) {
  3621. $("div span.s-ico", this).show();
  3622. $("div span.ui-icon-" + tmpcm.lso, this).removeClass(disabled).css("display", "");
  3623. }
  3624. } else {
  3625. if (ts.p.viewsortcols[0]) {
  3626. $("div span.s-ico", this).show();
  3627. if (j === ts.p.lastsort) {
  3628. $("div span.ui-icon-" + ts.p.sortorder, this).removeClass(disabled).css("display", "");
  3629. }
  3630. } else if (j === ts.p.lastsort && ts.p.sortname !== "") {
  3631. $("div span.s-ico", this).show();
  3632. $("div span.ui-icon-" + ts.p.sortorder, this).removeClass(disabled).css("display", "");
  3633. }
  3634. }
  3635. }
  3636. if (ts.p.footerrow) {
  3637. tfoot += "<td role='gridcell' " + formatCol(j, 0, '', null, '', false) + ">&#160;</td>";
  3638. }
  3639. }).mousedown(function (e) {
  3640. if ($(e.target).closest("th>span.ui-jqgrid-resize").length !== 1) { return; }
  3641. var ci = getColumnHeaderIndex(this);
  3642. if (ts.p.forceFit === true) { ts.p.nv = nextVisible(ci); }
  3643. grid.dragStart(ci, e, getOffset(ci));
  3644. return false;
  3645. }).click(function (e) {
  3646. if (ts.p.disableClick) {
  3647. ts.p.disableClick = false;
  3648. return false;
  3649. }
  3650. var s = "th>div.ui-jqgrid-sortable", r, d;
  3651. if (!ts.p.viewsortcols[2]) { s = "th>div>span>span.ui-grid-ico-sort"; }
  3652. var t = $(e.target).closest(s);
  3653. if (t.length !== 1) { return; }
  3654. var ci;
  3655. if (ts.p.frozenColumns) {
  3656. var tid = $(this)[0].id.substring(ts.p.id.length + 1);
  3657. $(ts.p.colModel).each(function (i) {
  3658. if (this.name === tid) {
  3659. ci = i; return false;
  3660. }
  3661. });
  3662. } else {
  3663. ci = getColumnHeaderIndex(this);
  3664. }
  3665. //
  3666. if ($(e.target).hasClass('colmenuspan')) {
  3667. if ($("#column_menu")[0] != null) {
  3668. $("#column_menu").remove();
  3669. }
  3670. var colindex = $.jgrid.getCellIndex(e.target);
  3671. if (colindex === -1) { return; }
  3672. var offset = $(this).offset(),
  3673. left = (offset.left),
  3674. top = (offset.top);
  3675. buildColMenu(colindex, left, top, t);
  3676. e.stopPropagation();
  3677. return;
  3678. }
  3679. //
  3680. if (!ts.p.viewsortcols[2]) { r = true; d = t.attr("sort"); }
  3681. if (ci != null) {
  3682. sortData($('div', this)[0].id, ci, r, d, this);
  3683. }
  3684. return false;
  3685. });
  3686. tmpcm = null;
  3687. if (ts.p.sortable && $.fn.sortable) {
  3688. try {
  3689. $(ts).jqGrid("sortableColumns", thr);
  3690. } catch (e) { }
  3691. }
  3692. if (ts.p.footerrow) { tfoot += "</tr></tbody></table>"; }
  3693. firstr += "</tr>";
  3694. tbody = document.createElement("tbody");
  3695. //$(this).append(firstr);
  3696. this.appendChild(tbody);
  3697. $(this).addClass(getstyle(stylemodule, "rowTable", true, 'ui-jqgrid-btable ui-common-table')).append(firstr);
  3698. //$(firstr).insertAfter(this);
  3699. firstr = null;
  3700. var hTable = $("<table " + getstyle(stylemodule, 'headerTable', false, 'ui-jqgrid-htable ui-common-table') + " style='width:" + ts.p.tblwidth + "px' role='presentation' aria-labelledby='gbox_" + this.id + "'></table>").append(thead),
  3701. hg = (ts.p.caption && ts.p.hiddengrid === true) ? true : false,
  3702. hb = $("<div class='ui-jqgrid-hbox" + (dir === "rtl" ? "-rtl" : "") + "'></div>"),
  3703. bstw = ts.p.styleUI === 'Bootstrap' ? 2 : 0;
  3704. thead = null;
  3705. grid.hDiv = document.createElement("div");
  3706. grid.hDiv.style.width = (grid.width - bstw) + "px";
  3707. grid.hDiv.className = getstyle(stylemodule, 'headerDiv', true, 'ui-jqgrid-hdiv');
  3708. $(grid.hDiv).append(hb);
  3709. $(hb).append(hTable);
  3710. hTable = null;
  3711. if (hg) { $(grid.hDiv).hide(); }
  3712. if (ts.p.pager) {
  3713. // TBD -- escape ts.p.pager here?
  3714. if (typeof ts.p.pager === "string") { if (ts.p.pager.substr(0, 1) !== "#") { ts.p.pager = "#" + ts.p.pager; } }
  3715. else { ts.p.pager = "#" + $(ts.p.pager).attr("id"); }
  3716. $(ts.p.pager).css({ width: grid.width + "px" }).addClass(getstyle(stylemodule, 'pagerBox', true, 'ui-jqgrid-pager')).appendTo(eg);
  3717. if (hg) { $(ts.p.pager).hide(); }
  3718. setPager(ts.p.pager, '');
  3719. }
  3720. if (ts.p.cellEdit === false && ts.p.hoverrows === true) {
  3721. $(ts).bind('mouseover', function (e) {
  3722. ptr = $(e.target).closest("tr.jqgrow");
  3723. if ($(ptr).attr("class") !== "ui-subgrid") {
  3724. $(ptr).addClass(hover);
  3725. }
  3726. }).bind('mouseout', function (e) {
  3727. ptr = $(e.target).closest("tr.jqgrow");
  3728. $(ptr).removeClass(hover);
  3729. });
  3730. }
  3731. var ri, ci, tdHtml;
  3732. $(ts).before(grid.hDiv).click(function (e) {
  3733. td = e.target;
  3734. ptr = $(td, ts.rows).closest("tr.jqgrow");
  3735. if ($(ptr).length === 0 || ptr[0].className.indexOf(disabled) > -1 || ($(td, ts).closest("table.ui-jqgrid-btable").attr('id') || '').replace("_frozen", "") !== ts.id) {
  3736. return this;
  3737. }
  3738. var scb = $(td).filter(":enabled").hasClass("cbox"),
  3739. cSel = $(ts).triggerHandler("jqGridBeforeSelectRow", [ptr[0].id, e]);
  3740. cSel = (cSel === false || cSel === 'stop') ? false : true;
  3741. if ($.isFunction(ts.p.beforeSelectRow)) {
  3742. var allowRowSelect = ts.p.beforeSelectRow.call(ts, ptr[0].id, e);
  3743. if (allowRowSelect === false || allowRowSelect === 'stop') {
  3744. cSel = false;
  3745. }
  3746. }
  3747. if (td.tagName === 'A' || ((td.tagName === 'INPUT' || td.tagName === 'TEXTAREA' || td.tagName === 'OPTION' || td.tagName === 'SELECT') && !scb)) { return; }
  3748. ri = ptr[0].id;
  3749. td = $(td).closest("tr.jqgrow>td");
  3750. if (td.length > 0) {
  3751. ci = $.jgrid.getCellIndex(td);
  3752. tdHtml = $(td).closest("td,th").html();
  3753. $(ts).triggerHandler("jqGridCellSelect", [ri, ci, tdHtml, e]);
  3754. if ($.isFunction(ts.p.onCellSelect)) {
  3755. ts.p.onCellSelect.call(ts, ri, ci, tdHtml, e);
  3756. }
  3757. }
  3758. if (ts.p.cellEdit === true) {
  3759. if (ts.p.multiselect && scb && cSel) {
  3760. $(ts).jqGrid("setSelection", ri, true, e);
  3761. } else if (td.length > 0) {
  3762. try {
  3763. $(ts).jqGrid("editCell", ptr[0].rowIndex, ci, true);
  3764. } catch (_) { }
  3765. }
  3766. return;
  3767. }
  3768. if (!cSel) {
  3769. return;
  3770. }
  3771. if (!ts.p.multikey) {
  3772. if (ts.p.multiselect && ts.p.multiboxonly) {
  3773. if (scb) { $(ts).jqGrid("setSelection", ri, true, e); }
  3774. else {
  3775. var frz = ts.p.frozenColumns ? ts.p.id + "_frozen" : "";
  3776. $(ts.p.selarrrow).each(function (i, n) {
  3777. var trid = $(ts).jqGrid('getGridRowById', n);
  3778. if (trid) { $(trid).removeClass(highlight); }
  3779. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(n))[ts.p.useProp ? 'prop' : 'attr']("checked", false);
  3780. if (frz) {
  3781. $("#" + $.jgrid.jqID(n), "#" + $.jgrid.jqID(frz)).removeClass(highlight);
  3782. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + $.jgrid.jqID(n), "#" + $.jgrid.jqID(frz))[ts.p.useProp ? 'prop' : 'attr']("checked", false);
  3783. }
  3784. });
  3785. ts.p.selarrrow = [];
  3786. $(ts).jqGrid("setSelection", ri, true, e);
  3787. }
  3788. } else {
  3789. $(ts).jqGrid("setSelection", ri, true, e);
  3790. }
  3791. } else {
  3792. if (e[ts.p.multikey]) {
  3793. $(ts).jqGrid("setSelection", ri, true, e);
  3794. } else if (ts.p.multiselect && scb) {
  3795. scb = $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + ri).is(":checked");
  3796. $("#jqg_" + $.jgrid.jqID(ts.p.id) + "_" + ri)[ts.p.useProp ? 'prop' : 'attr']("checked", !scb);
  3797. }
  3798. }
  3799. }).bind('reloadGrid', function (e, opts) {
  3800. if (ts.p.treeGrid === true) { ts.p.datatype = ts.p.treedatatype; }
  3801. opts = opts || {};
  3802. if (opts.current) {
  3803. ts.grid.selectionPreserver(ts);
  3804. }
  3805. if (ts.p.datatype === "local") { $(ts).jqGrid("resetSelection"); if (ts.p.data.length) { normalizeData(); refreshIndex(); } }
  3806. else if (!ts.p.treeGrid) {
  3807. ts.p.selrow = null;
  3808. if (ts.p.multiselect) { ts.p.selarrrow = []; setHeadCheckBox(false); }
  3809. ts.p.savedRow = [];
  3810. }
  3811. if (ts.p.scroll) { emptyRows.call(ts, true, false); }
  3812. if (opts.page) {
  3813. var page = opts.page;
  3814. if (page > ts.p.lastpage) { page = ts.p.lastpage; }
  3815. if (page < 1) { page = 1; }
  3816. ts.p.page = page;
  3817. if (ts.grid.prevRowHeight) {
  3818. ts.grid.bDiv.scrollTop = (page - 1) * ts.grid.prevRowHeight * ts.p.rowNum;
  3819. } else {
  3820. ts.grid.bDiv.scrollTop = 0;
  3821. }
  3822. }
  3823. if (ts.grid.prevRowHeight && ts.p.scroll && opts.page === undefined) {
  3824. delete ts.p.lastpage;
  3825. ts.grid.populateVisible();
  3826. } else {
  3827. ts.grid.populate();
  3828. }
  3829. if (ts.p.inlineNav === true) { $(ts).jqGrid('showAddEditButtons'); }
  3830. return false;
  3831. })
  3832. .dblclick(function (e) {
  3833. td = e.target;
  3834. ptr = $(td, ts.rows).closest("tr.jqgrow");
  3835. if ($(ptr).length === 0) { return; }
  3836. ri = ptr[0].rowIndex;
  3837. ci = $.jgrid.getCellIndex(td);
  3838. var dbcr = $(ts).triggerHandler("jqGridDblClickRow", [$(ptr).attr("id"), ri, ci, e]);
  3839. if (dbcr != null) { return dbcr; }
  3840. if ($.isFunction(ts.p.ondblClickRow)) {
  3841. dbcr = ts.p.ondblClickRow.call(ts, $(ptr).attr("id"), ri, ci, e);
  3842. if (dbcr != null) { return dbcr; }
  3843. }
  3844. })
  3845. .bind('contextmenu', function (e) {
  3846. td = e.target;
  3847. ptr = $(td, ts.rows).closest("tr.jqgrow");
  3848. if ($(ptr).length === 0) { return; }
  3849. if (!ts.p.multiselect) { $(ts).jqGrid("setSelection", ptr[0].id, true, e); }
  3850. ri = ptr[0].rowIndex;
  3851. ci = $.jgrid.getCellIndex(td);
  3852. var rcr = $(ts).triggerHandler("jqGridRightClickRow", [$(ptr).attr("id"), ri, ci, e]);
  3853. if (rcr != null) { return rcr; }
  3854. if ($.isFunction(ts.p.onRightClickRow)) {
  3855. rcr = ts.p.onRightClickRow.call(ts, $(ptr).attr("id"), ri, ci, e);
  3856. if (rcr != null) { return rcr; }
  3857. }
  3858. });
  3859. grid.bDiv = document.createElement("div");
  3860. if (isMSIE) { if (String(ts.p.height).toLowerCase() === "auto") { ts.p.height = "100%"; } }
  3861. $(grid.bDiv)
  3862. .append($('<div style="position:relative;"></div>').append('<div></div>').append(this))
  3863. .addClass("ui-jqgrid-bdiv")
  3864. .css({ height: ts.p.height + (isNaN(ts.p.height) ? "" : "px"), width: (grid.width - bstw) + "px" })
  3865. .scroll(grid.scrollGrid);
  3866. $("table:first", grid.bDiv).css({ width: ts.p.tblwidth + "px" });
  3867. if (!$.support.tbody) { //IE
  3868. if ($("tbody", this).length === 2) { $("tbody:gt(0)", this).remove(); }
  3869. }
  3870. if (ts.p.multikey) {
  3871. if ($.jgrid.msie) {
  3872. $(grid.bDiv).bind("selectstart", function () { return false; });
  3873. } else {
  3874. $(grid.bDiv).bind("mousedown", function () { return false; });
  3875. }
  3876. }
  3877. if (hg) { // hidden grid
  3878. $(grid.bDiv).hide();
  3879. }
  3880. var icoo = iconbase + " " + getstyle(stylemodule, 'icon_caption_open', true),
  3881. icoc = iconbase + " " + getstyle(stylemodule, 'icon_caption_close', true);
  3882. grid.cDiv = document.createElement("div");
  3883. var arf = ts.p.hidegrid === true ? $("<a role='link' class='ui-jqgrid-titlebar-close HeaderButton " + cornerall + "' title='" + ($.jgrid.getRegional(ts, "defaults.showhide", ts.p.showhide) || "") + "'" + " />").hover(
  3884. function () { arf.addClass(hover); },
  3885. function () { arf.removeClass(hover); })
  3886. .append("<span class='ui-jqgrid-headlink " + icoo + "'></span>").css((dir === "rtl" ? "left" : "right"), "0px") : "";
  3887. $(grid.cDiv).append(arf).append("<span class='ui-jqgrid-title'>" + ts.p.caption + "</span>")
  3888. .addClass("ui-jqgrid-titlebar ui-jqgrid-caption" + (dir === "rtl" ? "-rtl" : "") + " " + getstyle(stylemodule, 'gridtitleBox', true));
  3889. $(grid.cDiv).insertBefore(grid.hDiv);
  3890. if (ts.p.toolbar[0]) {
  3891. var tbstyle = getstyle(stylemodule, 'customtoolbarBox', true, 'ui-userdata');
  3892. grid.uDiv = document.createElement("div");
  3893. if (ts.p.toolbar[1] === "top") { $(grid.uDiv).insertBefore(grid.hDiv); }
  3894. else if (ts.p.toolbar[1] === "bottom") { $(grid.uDiv).insertAfter(grid.hDiv); }
  3895. if (ts.p.toolbar[1] === "both") {
  3896. grid.ubDiv = document.createElement("div");
  3897. $(grid.uDiv).addClass(tbstyle + " ui-userdata-top").attr("id", "t_" + this.id).insertBefore(grid.hDiv).width(grid.width - bstw);
  3898. $(grid.ubDiv).addClass(tbstyle + " ui-userdata-bottom").attr("id", "tb_" + this.id).insertAfter(grid.hDiv).width(grid.width - bstw);
  3899. if (hg) { $(grid.ubDiv).hide(); }
  3900. } else {
  3901. $(grid.uDiv).width(grid.width - bstw).addClass(tbstyle + " ui-userdata-top").attr("id", "t_" + this.id);
  3902. }
  3903. if (hg) { $(grid.uDiv).hide(); }
  3904. }
  3905. if (ts.p.toppager) {
  3906. ts.p.toppager = $.jgrid.jqID(ts.p.id) + "_toppager";
  3907. grid.topDiv = $("<div id='" + ts.p.toppager + "'></div>")[0];
  3908. ts.p.toppager = "#" + ts.p.toppager;
  3909. $(grid.topDiv).addClass(getstyle(stylemodule, 'toppagerBox', true, 'ui-jqgrid-toppager')).width(grid.width - bstw).insertBefore(grid.hDiv);
  3910. setPager(ts.p.toppager, '_t');
  3911. }
  3912. if (ts.p.footerrow) {
  3913. grid.sDiv = $("<div class='ui-jqgrid-sdiv'></div>")[0];
  3914. hb = $("<div class='ui-jqgrid-hbox" + (dir === "rtl" ? "-rtl" : "") + "'></div>");
  3915. $(grid.sDiv).append(hb).width(grid.width - bstw).insertAfter(grid.hDiv);
  3916. $(hb).append(tfoot);
  3917. grid.footers = $(".ui-jqgrid-ftable", grid.sDiv)[0].rows[0].cells;
  3918. if (ts.p.rownumbers) { grid.footers[0].className = getstyle(stylemodule, 'rownumBox', true, 'jqgrid-rownum'); }
  3919. if (hg) { $(grid.sDiv).hide(); }
  3920. }
  3921. hb = null;
  3922. if (ts.p.caption) {
  3923. var tdt = ts.p.datatype;
  3924. if (ts.p.hidegrid === true) {
  3925. $(".ui-jqgrid-titlebar-close", grid.cDiv).click(function (e) {
  3926. var onHdCl = $.isFunction(ts.p.onHeaderClick),
  3927. elems = ".ui-jqgrid-bdiv, .ui-jqgrid-hdiv, .ui-jqgrid-toppager, .ui-jqgrid-pager, .ui-jqgrid-sdiv",
  3928. counter, self = this;
  3929. if (ts.p.toolbar[0] === true) {
  3930. if (ts.p.toolbar[1] === 'both') {
  3931. elems += ', #' + $(grid.ubDiv).attr('id');
  3932. }
  3933. elems += ', #' + $(grid.uDiv).attr('id');
  3934. }
  3935. counter = $(elems, "#gview_" + $.jgrid.jqID(ts.p.id)).length;
  3936. if (ts.p.gridstate === 'visible') {
  3937. $(elems, "#gbox_" + $.jgrid.jqID(ts.p.id)).slideUp("fast", function () {
  3938. counter--;
  3939. if (counter === 0) {
  3940. $("span", self).removeClass(icoo).addClass(icoc);
  3941. ts.p.gridstate = 'hidden';
  3942. if ($("#gbox_" + $.jgrid.jqID(ts.p.id)).hasClass("ui-resizable")) { $(".ui-resizable-handle", "#gbox_" + $.jgrid.jqID(ts.p.id)).hide(); }
  3943. $(ts).triggerHandler("jqGridHeaderClick", [ts.p.gridstate, e]);
  3944. if (onHdCl) { if (!hg) { ts.p.onHeaderClick.call(ts, ts.p.gridstate, e); } }
  3945. }
  3946. });
  3947. } else if (ts.p.gridstate === 'hidden') {
  3948. $(elems, "#gbox_" + $.jgrid.jqID(ts.p.id)).slideDown("fast", function () {
  3949. counter--;
  3950. if (counter === 0) {
  3951. $("span", self).removeClass(icoc).addClass(icoo);
  3952. if (hg) { ts.p.datatype = tdt; populate(); hg = false; }
  3953. ts.p.gridstate = 'visible';
  3954. if ($("#gbox_" + $.jgrid.jqID(ts.p.id)).hasClass("ui-resizable")) { $(".ui-resizable-handle", "#gbox_" + $.jgrid.jqID(ts.p.id)).show(); }
  3955. $(ts).triggerHandler("jqGridHeaderClick", [ts.p.gridstate, e]);
  3956. if (onHdCl) { if (!hg) { ts.p.onHeaderClick.call(ts, ts.p.gridstate, e); } }
  3957. }
  3958. });
  3959. }
  3960. return false;
  3961. });
  3962. if (hg) { ts.p.datatype = "local"; $(".ui-jqgrid-titlebar-close", grid.cDiv).trigger("click"); }
  3963. }
  3964. } else {
  3965. $(grid.cDiv).hide();
  3966. if (!ts.p.toppager) {
  3967. $(grid.hDiv).addClass(getstyle(ts.p.styleUI + '.common', 'cornertop', true));
  3968. }
  3969. }
  3970. $(grid.hDiv).after(grid.bDiv)
  3971. .mousemove(function (e) {
  3972. if (grid.resizing) { grid.dragMove(e); return false; }
  3973. });
  3974. $(".ui-jqgrid-labels", grid.hDiv).bind("selectstart", function () { return false; });
  3975. $(document).bind("mouseup.jqGrid" + ts.p.id, function () {
  3976. if (grid.resizing) { grid.dragEnd(true); return false; }
  3977. return true;
  3978. });
  3979. ts.formatCol = formatCol;
  3980. ts.sortData = sortData;
  3981. ts.updatepager = updatepager;
  3982. ts.refreshIndex = refreshIndex;
  3983. ts.setHeadCheckBox = setHeadCheckBox;
  3984. ts.constructTr = constructTr;
  3985. ts.formatter = function (rowId, cellval, colpos, rwdat, act) { return formatter(rowId, cellval, colpos, rwdat, act); };
  3986. $.extend(grid, { populate: populate, emptyRows: emptyRows, beginReq: beginReq, endReq: endReq });
  3987. this.grid = grid;
  3988. ts.addXmlData = function (d) { addXmlData(d); };
  3989. ts.addJSONData = function (d) { addJSONData(d); };
  3990. this.grid.cols = this.rows[0].cells;
  3991. $(ts).triggerHandler("jqGridInitGrid");
  3992. if ($.isFunction(ts.p.onInitGrid)) { ts.p.onInitGrid.call(ts); }
  3993. populate();
  3994. ts.p.hiddengrid = false;
  3995. if (ts.p.responsive) {
  3996. var supportsOrientationChange = "onorientationchange" in window,
  3997. orientationEvent = supportsOrientationChange ? "orientationchange" : "resize";
  3998. $(window).on(orientationEvent, function () {
  3999. $(ts).jqGrid('resizeGrid');
  4000. });
  4001. }
  4002. });
  4003. };
  4004. $.jgrid.extend({
  4005. getGridParam: function (name, module) {
  4006. var $t = this[0], ret;
  4007. if (!$t || !$t.grid) { return; }
  4008. if (module === undefined && typeof module !== 'string') {
  4009. module = 'jqGrid'; //$t.p
  4010. }
  4011. ret = $t.p;
  4012. if (module !== 'jqGrid') {
  4013. try {
  4014. ret = $($t).data(module);
  4015. } catch (e) {
  4016. ret = $t.p;
  4017. }
  4018. }
  4019. if (!name) { return ret; }
  4020. return ret[name] !== undefined ? ret[name] : null;
  4021. },
  4022. setGridParam: function (newParams, overwrite) {
  4023. return this.each(function () {
  4024. if (overwrite == null) {
  4025. overwrite = false;
  4026. }
  4027. if (this.grid && typeof newParams === 'object') {
  4028. if (overwrite === true) {
  4029. var params = $.extend({}, this.p, newParams);
  4030. this.p = params;
  4031. } else {
  4032. $.extend(true, this.p, newParams);
  4033. }
  4034. }
  4035. });
  4036. },
  4037. getGridRowById: function (rowid) {
  4038. var row;
  4039. this.each(function () {
  4040. try {
  4041. //row = this.rows.namedItem( rowid );
  4042. var i = this.rows.length;
  4043. while (i--) {
  4044. if (rowid.toString() === this.rows[i].id) {
  4045. row = this.rows[i];
  4046. break;
  4047. }
  4048. }
  4049. } catch (e) {
  4050. row = $(this.grid.bDiv).find("#" + $.jgrid.jqID(rowid));
  4051. }
  4052. });
  4053. return row;
  4054. },
  4055. getDataIDs: function () {
  4056. var ids = [], i = 0, len, j = 0;
  4057. this.each(function () {
  4058. len = this.rows.length;
  4059. if (len && len > 0) {
  4060. while (i < len) {
  4061. if ($(this.rows[i]).hasClass('jqgrow')) {
  4062. ids[j] = this.rows[i].id;
  4063. j++;
  4064. }
  4065. i++;
  4066. }
  4067. }
  4068. });
  4069. return ids;
  4070. },
  4071. setSelection: function (selection, onsr, e) {
  4072. return this.each(function () {
  4073. var $t = this, stat, pt, ner, ia, tpsr, fid, csr,
  4074. getstyle = $.jgrid.getMethod("getStyleUI"),
  4075. highlight = getstyle($t.p.styleUI + '.common', 'highlight', true),
  4076. disabled = getstyle($t.p.styleUI + '.common', 'disabled', true);
  4077. if (selection === undefined) { return; }
  4078. onsr = onsr === false ? false : true;
  4079. pt = $($t).jqGrid('getGridRowById', selection);
  4080. if (!pt || !pt.className || pt.className.indexOf(disabled) > -1) { return; }
  4081. function scrGrid(iR) {
  4082. var ch = $($t.grid.bDiv)[0].clientHeight,
  4083. st = $($t.grid.bDiv)[0].scrollTop,
  4084. rpos = $($t.rows[iR]).position().top,
  4085. rh = $t.rows[iR].clientHeight;
  4086. if (rpos + rh >= ch + st) { $($t.grid.bDiv)[0].scrollTop = rpos - (ch + st) + rh + st; }
  4087. else if (rpos < ch + st) {
  4088. if (rpos < st) {
  4089. $($t.grid.bDiv)[0].scrollTop = rpos;
  4090. }
  4091. }
  4092. }
  4093. if ($t.p.scrollrows === true) {
  4094. ner = $($t).jqGrid('getGridRowById', selection).rowIndex;
  4095. if (ner >= 0) {
  4096. scrGrid(ner);
  4097. }
  4098. }
  4099. if ($t.p.frozenColumns === true) {
  4100. fid = $t.p.id + "_frozen";
  4101. }
  4102. if (!$t.p.multiselect) {
  4103. if (pt.className !== "ui-subgrid") {
  4104. if ($t.p.selrow !== pt.id) {
  4105. csr = $($t).jqGrid('getGridRowById', $t.p.selrow);
  4106. if (csr) {
  4107. $(csr).removeClass(highlight).attr({ "aria-selected": "false", "tabindex": "-1" });
  4108. }
  4109. $(pt).addClass(highlight).attr({ "aria-selected": "true", "tabindex": "0" });//.focus();
  4110. if (fid) {
  4111. $("#" + $.jgrid.jqID($t.p.selrow), "#" + $.jgrid.jqID(fid)).removeClass(highlight);
  4112. $("#" + $.jgrid.jqID(selection), "#" + $.jgrid.jqID(fid)).addClass(highlight);
  4113. }
  4114. stat = true;
  4115. } else {
  4116. stat = false;
  4117. }
  4118. $t.p.selrow = pt.id;
  4119. if (onsr) {
  4120. $($t).triggerHandler("jqGridSelectRow", [pt.id, stat, e]);
  4121. if ($t.p.onSelectRow) { $t.p.onSelectRow.call($t, pt.id, stat, e); }
  4122. }
  4123. }
  4124. } else {
  4125. //unselect selectall checkbox when deselecting a specific row
  4126. $t.setHeadCheckBox(false);
  4127. $t.p.selrow = pt.id;
  4128. ia = $.inArray($t.p.selrow, $t.p.selarrrow);
  4129. if (ia === -1) {
  4130. if (pt.className !== "ui-subgrid") { $(pt).addClass(highlight).attr("aria-selected", "true"); }
  4131. stat = true;
  4132. $t.p.selarrrow.push($t.p.selrow);
  4133. } else {
  4134. if (pt.className !== "ui-subgrid") { $(pt).removeClass(highlight).attr("aria-selected", "false"); }
  4135. stat = false;
  4136. $t.p.selarrrow.splice(ia, 1);
  4137. tpsr = $t.p.selarrrow[0];
  4138. $t.p.selrow = (tpsr === undefined) ? null : tpsr;
  4139. }
  4140. $("#jqg_" + $.jgrid.jqID($t.p.id) + "_" + $.jgrid.jqID(pt.id))[$t.p.useProp ? 'prop' : 'attr']("checked", stat);
  4141. if (fid) {
  4142. if (ia === -1) {
  4143. $("#" + $.jgrid.jqID(selection), "#" + $.jgrid.jqID(fid)).addClass(highlight);
  4144. } else {
  4145. $("#" + $.jgrid.jqID(selection), "#" + $.jgrid.jqID(fid)).removeClass(highlight);
  4146. }
  4147. $("#jqg_" + $.jgrid.jqID($t.p.id) + "_" + $.jgrid.jqID(selection), "#" + $.jgrid.jqID(fid))[$t.p.useProp ? 'prop' : 'attr']("checked", stat);
  4148. }
  4149. if (onsr) {
  4150. $($t).triggerHandler("jqGridSelectRow", [pt.id, stat, e]);
  4151. if ($t.p.onSelectRow) { $t.p.onSelectRow.call($t, pt.id, stat, e); }
  4152. }
  4153. }
  4154. });
  4155. },
  4156. resetSelection: function (rowid) {
  4157. return this.each(function () {
  4158. var t = this, sr, fid,
  4159. getstyle = $.jgrid.getMethod("getStyleUI"),
  4160. highlight = getstyle(t.p.styleUI + '.common', 'highlight', true),
  4161. hover = getstyle(t.p.styleUI + '.common', 'hover', true);
  4162. if (t.p.frozenColumns === true) {
  4163. fid = t.p.id + "_frozen";
  4164. }
  4165. if (rowid !== undefined) {
  4166. sr = rowid === t.p.selrow ? t.p.selrow : rowid;
  4167. $("#" + $.jgrid.jqID(t.p.id) + " tbody:first tr#" + $.jgrid.jqID(sr)).removeClass(highlight).attr("aria-selected", "false");
  4168. if (fid) { $("#" + $.jgrid.jqID(sr), "#" + $.jgrid.jqID(fid)).removeClass(highlight); }
  4169. if (t.p.multiselect) {
  4170. $("#jqg_" + $.jgrid.jqID(t.p.id) + "_" + $.jgrid.jqID(sr), "#" + $.jgrid.jqID(t.p.id))[t.p.useProp ? 'prop' : 'attr']("checked", false);
  4171. if (fid) { $("#jqg_" + $.jgrid.jqID(t.p.id) + "_" + $.jgrid.jqID(sr), "#" + $.jgrid.jqID(fid))[t.p.useProp ? 'prop' : 'attr']("checked", false); }
  4172. t.setHeadCheckBox(false);
  4173. var ia = $.inArray($.jgrid.jqID(sr), t.p.selarrrow);
  4174. if (ia !== -1) {
  4175. t.p.selarrrow.splice(ia, 1);
  4176. }
  4177. }
  4178. if (t.p.onUnSelectRow) { t.p.onUnSelectRow.call(t, sr); }
  4179. sr = null;
  4180. } else if (!t.p.multiselect) {
  4181. if (t.p.selrow) {
  4182. $("#" + $.jgrid.jqID(t.p.id) + " tbody:first tr#" + $.jgrid.jqID(t.p.selrow)).removeClass(highlight).attr("aria-selected", "false");
  4183. if (fid) { $("#" + $.jgrid.jqID(t.p.selrow), "#" + $.jgrid.jqID(fid)).removeClass(highlight); }
  4184. if (t.p.onUnSelectRow) { t.p.onUnSelectRow.call(t, t.p.selrow); }
  4185. t.p.selrow = null;
  4186. }
  4187. } else {
  4188. $(t.p.selarrrow).each(function (i, n) {
  4189. $($(t).jqGrid('getGridRowById', n)).removeClass(highlight).attr("aria-selected", "false");
  4190. $("#jqg_" + $.jgrid.jqID(t.p.id) + "_" + $.jgrid.jqID(n))[t.p.useProp ? 'prop' : 'attr']("checked", false);
  4191. if (fid) {
  4192. $("#" + $.jgrid.jqID(n), "#" + $.jgrid.jqID(fid)).removeClass(highlight);
  4193. $("#jqg_" + $.jgrid.jqID(t.p.id) + "_" + $.jgrid.jqID(n), "#" + $.jgrid.jqID(fid))[t.p.useProp ? 'prop' : 'attr']("checked", false);
  4194. }
  4195. if (t.p.onUnSelectRow) { t.p.onUnSelectRow.call(t, n); }
  4196. });
  4197. t.setHeadCheckBox(false);
  4198. t.p.selarrrow = [];
  4199. t.p.selrow = null;
  4200. }
  4201. if (t.p.cellEdit === true) {
  4202. if (parseInt(t.p.iCol, 10) >= 0 && parseInt(t.p.iRow, 10) >= 0) {
  4203. $("td:eq(" + t.p.iCol + ")", t.rows[t.p.iRow]).removeClass("edit-cell " + highlight);
  4204. $(t.rows[t.p.iRow]).removeClass("selected-row " + hover);
  4205. }
  4206. }
  4207. t.p.savedRow = [];
  4208. });
  4209. },
  4210. getRowData: function (rowid, usedata) {
  4211. var res = {}, resall, getall = false, len, j = 0;
  4212. this.each(function () {
  4213. var $t = this, nm, ind;
  4214. if (rowid == null) {
  4215. getall = true;
  4216. resall = [];
  4217. len = $t.rows.length - 1;
  4218. } else {
  4219. ind = $($t).jqGrid('getGridRowById', rowid);
  4220. if (!ind) { return res; }
  4221. len = 1;
  4222. }
  4223. if (!(usedata && usedata === true && $t.p.data.length > 0)) {
  4224. usedata = false;
  4225. }
  4226. while (j < len) {
  4227. if (getall) { ind = $t.rows[j]; }
  4228. if ($(ind).hasClass('jqgrow')) {
  4229. if (usedata) {
  4230. res = $t.p.data[$t.p._index[ind.id]];
  4231. } else {
  4232. $('td[role="gridcell"]', ind).each(function (i) {
  4233. nm = $t.p.colModel[i].name;
  4234. if (nm !== 'cb' && nm !== 'subgrid' && nm !== 'rn') {
  4235. if ($t.p.treeGrid === true && nm === $t.p.ExpandColumn) {
  4236. res[nm] = $.jgrid.htmlDecode($("span:first", this).html());
  4237. } else {
  4238. try {
  4239. res[nm] = $.unformat.call($t, this, { rowId: ind.id, colModel: $t.p.colModel[i] }, i);
  4240. } catch (e) {
  4241. res[nm] = $.jgrid.htmlDecode($(this).html());
  4242. }
  4243. }
  4244. }
  4245. });
  4246. }
  4247. if (getall) { resall.push(res); res = {}; }
  4248. }
  4249. j++;
  4250. }
  4251. });
  4252. return resall || res;
  4253. },
  4254. delRowData: function (rowid) {
  4255. var success = false, rowInd, ia, nextRow;
  4256. this.each(function () {
  4257. var $t = this;
  4258. rowInd = $($t).jqGrid('getGridRowById', rowid);
  4259. if (!rowInd) { return false; }
  4260. if ($t.p.subGrid) {
  4261. nextRow = $(rowInd).next();
  4262. if (nextRow.hasClass('ui-subgrid')) {
  4263. nextRow.remove();
  4264. }
  4265. }
  4266. $(rowInd).remove();
  4267. $t.p.records--;
  4268. $t.p.reccount--;
  4269. $t.updatepager(true, false);
  4270. success = true;
  4271. if ($t.p.multiselect) {
  4272. ia = $.inArray(rowid, $t.p.selarrrow);
  4273. if (ia !== -1) { $t.p.selarrrow.splice(ia, 1); }
  4274. }
  4275. if ($t.p.multiselect && $t.p.selarrrow.length > 0) {
  4276. $t.p.selrow = $t.p.selarrrow[$t.p.selarrrow.length - 1];
  4277. } else {
  4278. if ($t.p.selrow === rowid) {
  4279. $t.p.selrow = null;
  4280. }
  4281. }
  4282. if ($t.p.datatype === 'local') {
  4283. var id = $.jgrid.stripPref($t.p.idPrefix, rowid),
  4284. pos = $t.p._index[id];
  4285. if (pos !== undefined) {
  4286. $t.p.data.splice(pos, 1);
  4287. $t.refreshIndex();
  4288. }
  4289. }
  4290. if ($t.p.altRows === true && success) {
  4291. var cn = $t.p.altclass;
  4292. $($t.rows).each(function (i) {
  4293. if (i % 2 === 1) { $(this).addClass(cn); }
  4294. else { $(this).removeClass(cn); }
  4295. });
  4296. }
  4297. });
  4298. return success;
  4299. },
  4300. setRowData: function (rowid, data, cssp) {
  4301. var nm, success = true, title;
  4302. this.each(function () {
  4303. if (!this.grid) { return false; }
  4304. var t = this, vl, ind, cp = typeof cssp, lcdata = {};
  4305. ind = $(this).jqGrid('getGridRowById', rowid);
  4306. if (!ind) { return false; }
  4307. if (data) {
  4308. try {
  4309. $(this.p.colModel).each(function (i) {
  4310. nm = this.name;
  4311. var dval = $.jgrid.getAccessor(data, nm);
  4312. if (dval !== undefined) {
  4313. lcdata[nm] = this.formatter && typeof this.formatter === 'string' && this.formatter === 'date' ? $.unformat.date.call(t, dval, this) : dval;
  4314. vl = t.formatter(rowid, lcdata[nm], i, data, 'edit');
  4315. title = this.title ? { "title": $.jgrid.stripHtml(vl) } : {};
  4316. if (t.p.treeGrid === true && nm === t.p.ExpandColumn) {
  4317. $("td[role='gridcell']:eq(" + i + ") > span:first", ind).html(vl).attr(title);
  4318. } else {
  4319. $("td[role='gridcell']:eq(" + i + ")", ind).html(vl).attr(title);
  4320. }
  4321. }
  4322. });
  4323. if (t.p.datatype === 'local') {
  4324. var id = $.jgrid.stripPref(t.p.idPrefix, rowid),
  4325. pos = t.p._index[id], key;
  4326. if (t.p.treeGrid) {
  4327. for (key in t.p.treeReader) {
  4328. if (t.p.treeReader.hasOwnProperty(key)) {
  4329. delete lcdata[t.p.treeReader[key]];
  4330. }
  4331. }
  4332. }
  4333. if (pos !== undefined) {
  4334. t.p.data[pos] = $.extend(true, t.p.data[pos], lcdata);
  4335. }
  4336. lcdata = null;
  4337. }
  4338. } catch (e) {
  4339. success = false;
  4340. }
  4341. }
  4342. if (success) {
  4343. if (cp === 'string') { $(ind).addClass(cssp); } else if (cssp !== null && cp === 'object') { $(ind).css(cssp); }
  4344. $(t).triggerHandler("jqGridAfterGridComplete");
  4345. }
  4346. });
  4347. return success;
  4348. },
  4349. addRowData: function (rowid, rdata, pos, src) {
  4350. if ($.inArray(pos, ["first", "last", "before", "after"]) === -1) { pos = "last"; }
  4351. var success = false, nm, row, rnc = "", msc = "", gi, si, ni, sind, i, v, prp = "", aradd, cnm, cn, data, cm, id;
  4352. if (rdata) {
  4353. if ($.isArray(rdata)) {
  4354. aradd = true;
  4355. //pos = "last";
  4356. cnm = rowid;
  4357. } else {
  4358. rdata = [rdata];
  4359. aradd = false;
  4360. }
  4361. this.each(function () {
  4362. var t = this, datalen = rdata.length;
  4363. ni = t.p.rownumbers === true ? 1 : 0;
  4364. gi = t.p.multiselect === true ? 1 : 0;
  4365. si = t.p.subGrid === true ? 1 : 0;
  4366. if (!aradd) {
  4367. if (rowid !== undefined) { rowid = String(rowid); }
  4368. else {
  4369. rowid = $.jgrid.randId();
  4370. if (t.p.keyName !== false) {
  4371. cnm = t.p.keyName;
  4372. if (rdata[0][cnm] !== undefined) { rowid = rdata[0][cnm]; }
  4373. }
  4374. }
  4375. }
  4376. cn = t.p.altclass;
  4377. var k = 0, cna = $(t).jqGrid('getStyleUI', t.p.styleUI + ".base", 'rowBox', true, 'jqgrow ui-row-' + t.p.direction), lcdata = {}, classes,
  4378. air = $.isFunction(t.p.afterInsertRow) ? true : false;
  4379. if (ni) {
  4380. rnc = $(t).jqGrid('getStyleUI', t.p.styleUI + ".base", 'rownumBox', false, 'jqgrid-rownum');
  4381. }
  4382. if (gi) {
  4383. msc = $(t).jqGrid('getStyleUI', t.p.styleUI + ".base", 'multiBox', false, 'cbox');
  4384. }
  4385. while (k < datalen) {
  4386. data = rdata[k];
  4387. row = [];
  4388. classes = cna;
  4389. if (aradd) {
  4390. try {
  4391. rowid = data[cnm];
  4392. if (rowid === undefined) {
  4393. rowid = $.jgrid.randId();
  4394. }
  4395. }
  4396. catch (e) { rowid = $.jgrid.randId(); }
  4397. classes += (t.p.altRows === true ? (t.rows.length - 1) % 2 === 0 ? " " + cn : "" : "");
  4398. }
  4399. id = rowid;
  4400. rowid = t.p.idPrefix + rowid;
  4401. if (ni) {
  4402. prp = t.formatCol(0, 1, '', null, rowid, true);
  4403. row[row.length] = "<td role=\"gridcell\" " + rnc + " " + prp + ">0</td>";
  4404. }
  4405. if (gi) {
  4406. //v = "<input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + t.p.id + "_" + rowid + "\" " + msc + "/>";
  4407. //v = "<div class=\"ckbox\"><input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + t.p.id + "_" + rowid + "\"><label for=\"jqg_" + t.p.id + "_" + rowid + "\"></label></div>";
  4408. //prp = t.formatCol(ni, 1, '', null, rowid, true);
  4409. //row[row.length] = "<td role=\"gridcell\" " + prp + ">" + v + "</td>";
  4410. //v = "<input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + t.p.id + "_" + rowid + "\" " + msc + "/>";
  4411. v = "<input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + t.p.id + "_" + rowid + "\" " + msc + " name=\"jqg_" + t.p.id + "_" + rowid + "\" />";
  4412. // v = "<div class=\"ckbox\"><input role=\"checkbox\" type=\"checkbox\"" + " id=\"jqg_" + t.p.id + "_" + rowid + "\"><label for=\"jqg_" + t.p.id + "_" + rowid + "\"></label></div>";
  4413. prp = t.formatCol(ni, 1, '', null, rowid, true);
  4414. row[row.length] = "<td role=\"gridcell\" " + prp + ">" + v + "</td>";
  4415. }
  4416. if (si) {
  4417. row[row.length] = $(t).jqGrid("addSubGridCell", gi + ni, 1);
  4418. }
  4419. for (i = gi + si + ni; i < t.p.colModel.length; i++) {
  4420. cm = t.p.colModel[i];
  4421. nm = cm.name;
  4422. lcdata[nm] = data[nm];
  4423. v = t.formatter(rowid, $.jgrid.getAccessor(data, nm), i, data);
  4424. prp = t.formatCol(i, 1, v, data, rowid, lcdata);
  4425. row[row.length] = "<td role=\"gridcell\" " + prp + ">" + v + "</td>";
  4426. }
  4427. row.unshift(t.constructTr(rowid, false, classes, lcdata, data));
  4428. row[row.length] = "</tr>";
  4429. if (t.rows.length === 0) {
  4430. $("table:first", t.grid.bDiv).append(row.join(''));
  4431. } else {
  4432. switch (pos) {
  4433. case 'last':
  4434. $(t.rows[t.rows.length - 1]).after(row.join(''));
  4435. sind = t.rows.length - 1;
  4436. break;
  4437. case 'first':
  4438. $(t.rows[0]).after(row.join(''));
  4439. sind = 1;
  4440. break;
  4441. case 'after':
  4442. sind = $(t).jqGrid('getGridRowById', src);
  4443. if (sind) {
  4444. if ($(t.rows[sind.rowIndex + 1]).hasClass("ui-subgrid")) { $(t.rows[sind.rowIndex + 1]).after(row); }
  4445. else { $(sind).after(row.join('')); }
  4446. sind = sind.rowIndex + 1;
  4447. }
  4448. break;
  4449. case 'before':
  4450. sind = $(t).jqGrid('getGridRowById', src);
  4451. if (sind) {
  4452. $(sind).before(row.join(''));
  4453. sind = sind.rowIndex - 1;
  4454. }
  4455. break;
  4456. }
  4457. }
  4458. if (t.p.subGrid === true) {
  4459. $(t).jqGrid("addSubGrid", gi + ni, sind);
  4460. }
  4461. t.p.records++;
  4462. t.p.reccount++;
  4463. $(t).triggerHandler("jqGridAfterInsertRow", [rowid, data, data]);
  4464. if (air) { t.p.afterInsertRow.call(t, rowid, data, data); }
  4465. k++;
  4466. if (t.p.datatype === 'local') {
  4467. lcdata[t.p.localReader.id] = id;
  4468. t.p._index[id] = t.p.data.length;
  4469. t.p.data.push(lcdata);
  4470. lcdata = {};
  4471. }
  4472. }
  4473. if (t.p.altRows === true && !aradd) {
  4474. if (pos === "last") {
  4475. if ((t.rows.length - 1) % 2 === 0) { $(t.rows[t.rows.length - 1]).addClass(cn); }
  4476. } else {
  4477. $(t.rows).each(function (i) {
  4478. if (i % 2 === 0) { $(this).addClass(cn); }
  4479. else { $(this).removeClass(cn); }
  4480. });
  4481. }
  4482. }
  4483. t.updatepager(true, true);
  4484. success = true;
  4485. });
  4486. }
  4487. return success;
  4488. },
  4489. footerData: function (action, data, format) {
  4490. var nm, success = false, res = {}, title;
  4491. function isEmpty(obj) {
  4492. var i;
  4493. for (i in obj) {
  4494. if (obj.hasOwnProperty(i)) { return false; }
  4495. }
  4496. return true;
  4497. }
  4498. if (action === undefined) { action = "get"; }
  4499. if (typeof format !== "boolean") { format = true; }
  4500. action = action.toLowerCase();
  4501. this.each(function () {
  4502. var t = this, vl;
  4503. if (!t.grid || !t.p.footerrow) { return false; }
  4504. if (action === "set") { if (isEmpty(data)) { return false; } }
  4505. success = true;
  4506. $(this.p.colModel).each(function (i) {
  4507. nm = this.name;
  4508. if (action === "set") {
  4509. if (data[nm] !== undefined) {
  4510. vl = format ? t.formatter("", data[nm], i, data, 'edit') : data[nm];
  4511. title = this.title ? { "title": $.jgrid.stripHtml(vl) } : {};
  4512. $("tr.footrow td:eq(" + i + ")", t.grid.sDiv).html(vl).attr(title);
  4513. success = true;
  4514. }
  4515. } else if (action === "get") {
  4516. res[nm] = $("tr.footrow td:eq(" + i + ")", t.grid.sDiv).html();
  4517. }
  4518. });
  4519. });
  4520. return action === "get" ? res : success;
  4521. },
  4522. showHideCol: function (colname, show) {
  4523. return this.each(function () {
  4524. var $t = this, fndh = false, brd = $.jgrid.cell_width ? 0 : $t.p.cellLayout, cw;
  4525. if (!$t.grid) { return; }
  4526. if (typeof colname === 'string') { colname = [colname]; }
  4527. show = show !== "none" ? "" : "none";
  4528. var sw = show === "" ? true : false,
  4529. gh = $t.p.groupHeader && ($.isArray($t.p.groupHeader) || $.isFunction($t.p.groupHeader));
  4530. if (gh) { $($t).jqGrid('destroyGroupHeader', false); }
  4531. $(this.p.colModel).each(function (i) {
  4532. if ($.inArray(this.name, colname) !== -1 && this.hidden === sw) {
  4533. if ($t.p.frozenColumns === true && this.frozen === true) {
  4534. return true;
  4535. }
  4536. $("tr[role=row]", $t.grid.hDiv).each(function () {
  4537. $(this.cells[i]).css("display", show);
  4538. });
  4539. $($t.rows).each(function () {
  4540. if (!$(this).hasClass("jqgroup")) {
  4541. $(this.cells[i]).css("display", show);
  4542. }
  4543. });
  4544. if ($t.p.footerrow) { $("tr.footrow td:eq(" + i + ")", $t.grid.sDiv).css("display", show); }
  4545. cw = parseInt(this.width, 10);
  4546. if (show === "none") {
  4547. $t.p.tblwidth -= cw + brd;
  4548. } else {
  4549. $t.p.tblwidth += cw + brd;
  4550. }
  4551. this.hidden = !sw;
  4552. fndh = true;
  4553. $($t).triggerHandler("jqGridShowHideCol", [sw, this.name, i]);
  4554. }
  4555. });
  4556. if (fndh === true) {
  4557. if ($t.p.shrinkToFit === true && !isNaN($t.p.height)) { $t.p.tblwidth += parseInt($t.p.scrollOffset, 10); }
  4558. $($t).jqGrid("setGridWidth", $t.p.shrinkToFit === true ? $t.p.tblwidth : $t.p.width);
  4559. }
  4560. if (gh) {
  4561. var gHead = $.extend([], $t.p.groupHeader);
  4562. $t.p.groupHeader = null;
  4563. for (var k = 0; k < gHead.length; k++) {
  4564. $($t).jqGrid('setGroupHeaders', gHead[k]);
  4565. }
  4566. }
  4567. });
  4568. },
  4569. hideCol: function (colname) {
  4570. return this.each(function () { $(this).jqGrid("showHideCol", colname, "none"); });
  4571. },
  4572. showCol: function (colname) {
  4573. return this.each(function () { $(this).jqGrid("showHideCol", colname, ""); });
  4574. },
  4575. remapColumns: function (permutation, updateCells, keepHeader) {
  4576. function resortArray(a) {
  4577. var ac;
  4578. if (a.length) {
  4579. ac = $.makeArray(a);
  4580. } else {
  4581. ac = $.extend({}, a);
  4582. }
  4583. $.each(permutation, function (i) {
  4584. a[i] = ac[this];
  4585. });
  4586. }
  4587. var ts = this.get(0);
  4588. function resortRows(parent, clobj) {
  4589. $(">tr" + (clobj || ""), parent).each(function () {
  4590. var row = this;
  4591. var elems = $.makeArray(row.cells);
  4592. $.each(permutation, function () {
  4593. var e = elems[this];
  4594. if (e) {
  4595. row.appendChild(e);
  4596. }
  4597. });
  4598. });
  4599. }
  4600. resortArray(ts.p.colModel);
  4601. resortArray(ts.p.colNames);
  4602. resortArray(ts.grid.headers);
  4603. resortRows($("thead:first", ts.grid.hDiv), keepHeader && ":not(.ui-jqgrid-labels)");
  4604. if (updateCells) {
  4605. resortRows($("#" + $.jgrid.jqID(ts.p.id) + " tbody:first"), ".jqgfirstrow, tr.jqgrow, tr.jqfoot");
  4606. }
  4607. if (ts.p.footerrow) {
  4608. resortRows($("tbody:first", ts.grid.sDiv));
  4609. }
  4610. if (ts.p.remapColumns) {
  4611. if (!ts.p.remapColumns.length) {
  4612. ts.p.remapColumns = $.makeArray(permutation);
  4613. } else {
  4614. resortArray(ts.p.remapColumns);
  4615. }
  4616. }
  4617. ts.p.lastsort = $.inArray(ts.p.lastsort, permutation);
  4618. if (ts.p.treeGrid) { ts.p.expColInd = $.inArray(ts.p.expColInd, permutation); }
  4619. $(ts).triggerHandler("jqGridRemapColumns", [permutation, updateCells, keepHeader]);
  4620. },
  4621. setGridWidth: function (nwidth, shrink) {
  4622. return this.each(function () {
  4623. if (!this.grid) { return; }
  4624. var $t = this, cw,
  4625. initwidth = 0, brd = $.jgrid.cell_width ? 0 : $t.p.cellLayout, lvc, vc = 0, hs = false, scw = $t.p.scrollOffset, aw, gw = 0, cr, bstw = $t.p.styleUI === 'Bootstrap' ? 2 : 0;
  4626. if (typeof shrink !== 'boolean') {
  4627. shrink = $t.p.shrinkToFit;
  4628. }
  4629. if (isNaN(nwidth)) { return; }
  4630. nwidth = parseInt(nwidth, 10);
  4631. $t.grid.width = $t.p.width = nwidth;
  4632. $("#gbox_" + $.jgrid.jqID($t.p.id)).css("width", nwidth + "px");
  4633. $("#gview_" + $.jgrid.jqID($t.p.id)).css("width", nwidth + "px");
  4634. $($t.grid.bDiv).css("width", (nwidth - bstw) + "px");
  4635. $($t.grid.hDiv).css("width", (nwidth - bstw) + "px");
  4636. if ($t.p.pager) {
  4637. $($t.p.pager).css("width", nwidth + "px");
  4638. }
  4639. if ($t.p.toppager) {
  4640. $($t.p.toppager).css("width", (nwidth - bstw) + "px");
  4641. }
  4642. if ($t.p.toolbar[0] === true) {
  4643. $($t.grid.uDiv).css("width", (nwidth - bstw) + "px");
  4644. if ($t.p.toolbar[1] === "both") { $($t.grid.ubDiv).css("width", (nwidth - bstw) + "px"); }
  4645. }
  4646. if ($t.p.footerrow) {
  4647. $($t.grid.sDiv).css("width", (nwidth - bstw) + "px");
  4648. }
  4649. if (shrink === false && $t.p.forceFit === true) { $t.p.forceFit = false; }
  4650. if (shrink === true) {
  4651. $.each($t.p.colModel, function () {
  4652. if (this.hidden === false) {
  4653. cw = this.widthOrg;
  4654. initwidth += cw + brd;
  4655. if (this.fixed) {
  4656. gw += cw + brd;
  4657. } else {
  4658. vc++;
  4659. }
  4660. }
  4661. });
  4662. if (vc === 0) { return; }
  4663. $t.p.tblwidth = initwidth;
  4664. aw = nwidth - brd * vc - gw;
  4665. if (!isNaN($t.p.height)) {
  4666. if ($($t.grid.bDiv)[0].clientHeight < $($t.grid.bDiv)[0].scrollHeight || $t.rows.length === 1) {
  4667. hs = true;
  4668. aw -= scw;
  4669. }
  4670. }
  4671. initwidth = 0;
  4672. var cle = $t.grid.cols.length > 0;
  4673. $.each($t.p.colModel, function (i) {
  4674. if (this.hidden === false && !this.fixed) {
  4675. cw = this.widthOrg;
  4676. cw = Math.round(aw * cw / ($t.p.tblwidth - brd * vc - gw));
  4677. if (cw < 0) { return; }
  4678. this.width = cw;
  4679. initwidth += cw;
  4680. $t.grid.headers[i].width = cw;
  4681. $t.grid.headers[i].el.style.width = cw + "px";
  4682. if ($t.p.footerrow) { $t.grid.footers[i].style.width = cw + "px"; }
  4683. if (cle) { $t.grid.cols[i].style.width = cw + "px"; }
  4684. lvc = i;
  4685. }
  4686. });
  4687. if (!lvc) { return; }
  4688. cr = 0;
  4689. if (hs) {
  4690. if (nwidth - gw - (initwidth + brd * vc) !== scw) {
  4691. cr = nwidth - gw - (initwidth + brd * vc) - scw;
  4692. }
  4693. } else if (Math.abs(nwidth - gw - (initwidth + brd * vc)) !== 1) {
  4694. cr = nwidth - gw - (initwidth + brd * vc);
  4695. }
  4696. $t.p.colModel[lvc].width += cr;
  4697. $t.p.tblwidth = initwidth + cr + brd * vc + gw;
  4698. if ($t.p.tblwidth > nwidth) {
  4699. var delta = $t.p.tblwidth - parseInt(nwidth, 10);
  4700. $t.p.tblwidth = nwidth;
  4701. cw = $t.p.colModel[lvc].width = $t.p.colModel[lvc].width - delta;
  4702. } else {
  4703. cw = $t.p.colModel[lvc].width;
  4704. }
  4705. $t.grid.headers[lvc].width = cw;
  4706. $t.grid.headers[lvc].el.style.width = cw + "px";
  4707. if (cle) { $t.grid.cols[lvc].style.width = cw + "px"; }
  4708. if ($t.p.footerrow) {
  4709. $t.grid.footers[lvc].style.width = cw + "px";
  4710. }
  4711. }
  4712. if ($t.p.tblwidth) {
  4713. $('table:first', $t.grid.bDiv).css("width", $t.p.tblwidth + "px");
  4714. $('table:first', $t.grid.hDiv).css("width", $t.p.tblwidth + "px");
  4715. $t.grid.hDiv.scrollLeft = $t.grid.bDiv.scrollLeft;
  4716. if ($t.p.footerrow) {
  4717. $('table:first', $t.grid.sDiv).css("width", $t.p.tblwidth + "px");
  4718. }
  4719. }
  4720. });
  4721. },
  4722. setGridHeight: function (nh) {
  4723. return this.each(function () {
  4724. var $t = this;
  4725. if (!$t.grid) { return; }
  4726. var bDiv = $($t.grid.bDiv);
  4727. bDiv.css({ height: nh + (isNaN(nh) ? "" : "px") });
  4728. if ($t.p.frozenColumns === true) {
  4729. //follow the original set height to use 16, better scrollbar width detection
  4730. $('#' + $.jgrid.jqID($t.p.id) + "_frozen").parent().height(bDiv.height() - 16);
  4731. }
  4732. $t.p.height = nh;
  4733. if ($t.p.scroll) { $t.grid.populateVisible(); }
  4734. });
  4735. },
  4736. setCaption: function (newcap) {
  4737. return this.each(function () {
  4738. var ctop = $(this).jqGrid('getStyleUI', this.p.styleUI + ".common", 'cornertop', true);
  4739. this.p.caption = newcap;
  4740. $(".ui-jqgrid-title, .ui-jqgrid-title-rtl", this.grid.cDiv).html(newcap);
  4741. $(this.grid.cDiv).show();
  4742. $(this.grid.hDiv).removeClass(ctop);
  4743. });
  4744. },
  4745. setLabel: function (colname, nData, prop, attrp) {
  4746. return this.each(function () {
  4747. var $t = this, pos = -1;
  4748. if (!$t.grid) { return; }
  4749. if (colname != null) {
  4750. if (isNaN(colname)) {
  4751. $($t.p.colModel).each(function (i) {
  4752. if (this.name === colname) {
  4753. pos = i; return false;
  4754. }
  4755. });
  4756. } else {
  4757. pos = parseInt(colname, 10);
  4758. }
  4759. } else { return; }
  4760. if (pos >= 0) {
  4761. var thecol = $("tr.ui-jqgrid-labels th:eq(" + pos + ")", $t.grid.hDiv);
  4762. if (nData) {
  4763. var ico = $(".s-ico", thecol);
  4764. $("[id^=jqgh_]", thecol).empty().html(nData).append(ico);
  4765. $t.p.colNames[pos] = nData;
  4766. }
  4767. if (prop) {
  4768. if (typeof prop === 'string') { $(thecol).addClass(prop); } else { $(thecol).css(prop); }
  4769. }
  4770. if (typeof attrp === 'object') { $(thecol).attr(attrp); }
  4771. }
  4772. });
  4773. },
  4774. setCell: function (rowid, colname, nData, cssp, attrp, forceupd) {
  4775. return this.each(function () {
  4776. var $t = this, pos = -1, v, title;
  4777. if (!$t.grid) { return; }
  4778. if (isNaN(colname)) {
  4779. $($t.p.colModel).each(function (i) {
  4780. if (this.name === colname) {
  4781. pos = i; return false;
  4782. }
  4783. });
  4784. } else { pos = parseInt(colname, 10); }
  4785. if (pos >= 0) {
  4786. var ind = $($t).jqGrid('getGridRowById', rowid);
  4787. if (ind) {
  4788. var tcell = $("td:eq(" + pos + ")", ind), cl = 0, rawdat = [];
  4789. if (nData !== "" || forceupd === true) {
  4790. if (ind.cells !== undefined) {
  4791. while (cl < ind.cells.length) {
  4792. // slow down speed
  4793. rawdat.push(ind.cells[cl].innerHTML);
  4794. cl++;
  4795. }
  4796. }
  4797. v = $t.formatter(rowid, nData, pos, rawdat, 'edit');
  4798. title = $t.p.colModel[pos].title ? { "title": $.jgrid.stripHtml(v) } : {};
  4799. if ($t.p.treeGrid && $(".tree-wrap", $(tcell)).length > 0) {
  4800. $("span", $(tcell)).html(v).attr(title);
  4801. } else {
  4802. $(tcell).html(v).attr(title);
  4803. }
  4804. if ($t.p.datatype === "local") {
  4805. var cm = $t.p.colModel[pos], index;
  4806. nData = cm.formatter && typeof cm.formatter === 'string' && cm.formatter === 'date' ? $.unformat.date.call($t, nData, cm) : nData;
  4807. index = $t.p._index[$.jgrid.stripPref($t.p.idPrefix, rowid)];
  4808. if (index !== undefined) {
  4809. $t.p.data[index][cm.name] = nData;
  4810. }
  4811. }
  4812. }
  4813. if (typeof cssp === 'string') {
  4814. $(tcell).addClass(cssp);
  4815. } else if (cssp) {
  4816. $(tcell).css(cssp);
  4817. }
  4818. if (typeof attrp === 'object') { $(tcell).attr(attrp); }
  4819. }
  4820. }
  4821. });
  4822. },
  4823. getCell: function (rowid, col) {
  4824. var ret = false;
  4825. this.each(function () {
  4826. var $t = this, pos = -1;
  4827. if (!$t.grid) { return; }
  4828. if (isNaN(col)) {
  4829. $($t.p.colModel).each(function (i) {
  4830. if (this.name === col) {
  4831. pos = i; return false;
  4832. }
  4833. });
  4834. } else { pos = parseInt(col, 10); }
  4835. if (pos >= 0) {
  4836. var ind = $($t).jqGrid('getGridRowById', rowid);
  4837. if (ind) {
  4838. try {
  4839. ret = $.unformat.call($t, $("td:eq(" + pos + ")", ind), { rowId: ind.id, colModel: $t.p.colModel[pos] }, pos);
  4840. } catch (e) {
  4841. ret = $.jgrid.htmlDecode($("td:eq(" + pos + ")", ind).html());
  4842. }
  4843. }
  4844. }
  4845. });
  4846. return ret;
  4847. },
  4848. getCol: function (col, obj, mathopr) {
  4849. var ret = [], val, sum = 0, min, max, v;
  4850. obj = typeof obj !== 'boolean' ? false : obj;
  4851. if (mathopr === undefined) { mathopr = false; }
  4852. this.each(function () {
  4853. var $t = this, pos = -1;
  4854. if (!$t.grid) { return; }
  4855. if (isNaN(col)) {
  4856. $($t.p.colModel).each(function (i) {
  4857. if (this.name === col) {
  4858. pos = i; return false;
  4859. }
  4860. });
  4861. } else { pos = parseInt(col, 10); }
  4862. if (pos >= 0) {
  4863. var ln = $t.rows.length, i = 0, dlen = 0;
  4864. if (ln && ln > 0) {
  4865. while (i < ln) {
  4866. if ($($t.rows[i]).hasClass('jqgrow')) {
  4867. try {
  4868. val = $.unformat.call($t, $($t.rows[i].cells[pos]), { rowId: $t.rows[i].id, colModel: $t.p.colModel[pos] }, pos);
  4869. } catch (e) {
  4870. val = $.jgrid.htmlDecode($t.rows[i].cells[pos].innerHTML);
  4871. }
  4872. if (mathopr) {
  4873. v = parseFloat(val);
  4874. if (!isNaN(v)) {
  4875. sum += v;
  4876. if (max === undefined) { max = min = v; }
  4877. min = Math.min(min, v);
  4878. max = Math.max(max, v);
  4879. dlen++;
  4880. }
  4881. }
  4882. else if (obj) { ret.push({ id: $t.rows[i].id, value: val }); }
  4883. else { ret.push(val); }
  4884. }
  4885. i++;
  4886. }
  4887. if (mathopr) {
  4888. switch (mathopr.toLowerCase()) {
  4889. case 'sum': ret = sum; break;
  4890. case 'avg': ret = sum / dlen; break;
  4891. case 'count': ret = (ln - 1); break;
  4892. case 'min': ret = min; break;
  4893. case 'max': ret = max; break;
  4894. }
  4895. }
  4896. }
  4897. }
  4898. });
  4899. return ret;
  4900. },
  4901. clearGridData: function (clearfooter) {
  4902. return this.each(function () {
  4903. var $t = this;
  4904. if (!$t.grid) { return; }
  4905. if (typeof clearfooter !== 'boolean') { clearfooter = false; }
  4906. if ($t.p.deepempty) { $("#" + $.jgrid.jqID($t.p.id) + " tbody:first tr:gt(0)").remove(); }
  4907. else {
  4908. var trf = $("#" + $.jgrid.jqID($t.p.id) + " tbody:first tr:first")[0];
  4909. $("#" + $.jgrid.jqID($t.p.id) + " tbody:first").empty().append(trf);
  4910. }
  4911. if ($t.p.footerrow && clearfooter) { $(".ui-jqgrid-ftable td", $t.grid.sDiv).html("&#160;"); }
  4912. $t.p.selrow = null; $t.p.selarrrow = []; $t.p.savedRow = [];
  4913. $t.p.records = 0; $t.p.page = 1; $t.p.lastpage = 0; $t.p.reccount = 0;
  4914. $t.p.data = []; $t.p._index = {};
  4915. $t.updatepager(true, false);
  4916. });
  4917. },
  4918. getInd: function (rowid, rc) {
  4919. var ret = false, rw;
  4920. this.each(function () {
  4921. rw = $(this).jqGrid('getGridRowById', rowid);
  4922. if (rw) {
  4923. ret = rc === true ? rw : rw.rowIndex;
  4924. }
  4925. });
  4926. return ret;
  4927. },
  4928. bindKeys: function (settings) {
  4929. var o = $.extend({
  4930. onEnter: null,
  4931. onSpace: null,
  4932. onLeftKey: null,
  4933. onRightKey: null,
  4934. scrollingRows: true
  4935. }, settings || {});
  4936. return this.each(function () {
  4937. var $t = this;
  4938. if (!$('body').is('[role]')) { $('body').attr('role', 'application'); }
  4939. $t.p.scrollrows = o.scrollingRows;
  4940. $($t).keydown(function (event) {
  4941. var target = $($t).find('tr[tabindex=0]')[0], id, r, mind,
  4942. expanded = $t.p.treeReader.expanded_field;
  4943. //check for arrow keys
  4944. if (target) {
  4945. mind = $t.p._index[$.jgrid.stripPref($t.p.idPrefix, target.id)];
  4946. if (event.keyCode === 37 || event.keyCode === 38 || event.keyCode === 39 || event.keyCode === 40) {
  4947. // up key
  4948. if (event.keyCode === 38) {
  4949. r = target.previousSibling;
  4950. id = "";
  4951. if (r) {
  4952. if ($(r).is(":hidden")) {
  4953. while (r) {
  4954. r = r.previousSibling;
  4955. if (!$(r).is(":hidden") && $(r).hasClass('jqgrow')) { id = r.id; break; }
  4956. }
  4957. } else {
  4958. id = r.id;
  4959. }
  4960. }
  4961. $($t).jqGrid('setSelection', id, true, event);
  4962. event.preventDefault();
  4963. }
  4964. //if key is down arrow
  4965. if (event.keyCode === 40) {
  4966. r = target.nextSibling;
  4967. id = "";
  4968. if (r) {
  4969. if ($(r).is(":hidden")) {
  4970. while (r) {
  4971. r = r.nextSibling;
  4972. if (!$(r).is(":hidden") && $(r).hasClass('jqgrow')) { id = r.id; break; }
  4973. }
  4974. } else {
  4975. id = r.id;
  4976. }
  4977. }
  4978. $($t).jqGrid('setSelection', id, true, event);
  4979. event.preventDefault();
  4980. }
  4981. // left
  4982. if (event.keyCode === 37) {
  4983. if ($t.p.treeGrid && $t.p.data[mind][expanded]) {
  4984. $(target).find("div.treeclick").trigger('click');
  4985. }
  4986. $($t).triggerHandler("jqGridKeyLeft", [$t.p.selrow]);
  4987. if ($.isFunction(o.onLeftKey)) {
  4988. o.onLeftKey.call($t, $t.p.selrow);
  4989. }
  4990. }
  4991. // right
  4992. if (event.keyCode === 39) {
  4993. if ($t.p.treeGrid && !$t.p.data[mind][expanded]) {
  4994. $(target).find("div.treeclick").trigger('click');
  4995. }
  4996. $($t).triggerHandler("jqGridKeyRight", [$t.p.selrow]);
  4997. if ($.isFunction(o.onRightKey)) {
  4998. o.onRightKey.call($t, $t.p.selrow);
  4999. }
  5000. }
  5001. }
  5002. //check if enter was pressed on a grid or treegrid node
  5003. else if (event.keyCode === 13) {
  5004. $($t).triggerHandler("jqGridKeyEnter", [$t.p.selrow]);
  5005. if ($.isFunction(o.onEnter)) {
  5006. o.onEnter.call($t, $t.p.selrow);
  5007. }
  5008. } else if (event.keyCode === 32) {
  5009. $($t).triggerHandler("jqGridKeySpace", [$t.p.selrow]);
  5010. if ($.isFunction(o.onSpace)) {
  5011. o.onSpace.call($t, $t.p.selrow);
  5012. }
  5013. }
  5014. }
  5015. });
  5016. });
  5017. },
  5018. unbindKeys: function () {
  5019. return this.each(function () {
  5020. $(this).unbind('keydown');
  5021. });
  5022. },
  5023. getLocalRow: function (rowid) {
  5024. var ret = false, ind;
  5025. this.each(function () {
  5026. if (rowid !== undefined) {
  5027. ind = this.p._index[$.jgrid.stripPref(this.p.idPrefix, rowid)];
  5028. if (ind >= 0) {
  5029. ret = this.p.data[ind];
  5030. }
  5031. }
  5032. });
  5033. return ret;
  5034. },
  5035. progressBar: function (p) {
  5036. p = $.extend({
  5037. htmlcontent: "",
  5038. method: "hide",
  5039. loadtype: "disable"
  5040. }, p || {});
  5041. return this.each(function () {
  5042. var sh = p.method === "show" ? true : false,
  5043. loadDiv = $("#load_" + $.jgrid.jqID(this.p.id)),
  5044. offsetParent, top,
  5045. scrollTop = $(window).scrollTop();
  5046. if (p.htmlcontent !== "") {
  5047. loadDiv.html(p.htmlcontent);
  5048. }
  5049. switch (p.loadtype) {
  5050. case "disable":
  5051. break;
  5052. case "enable":
  5053. loadDiv.toggle(sh);
  5054. break;
  5055. case "block":
  5056. $("#lui_" + $.jgrid.jqID(this.p.id)).toggle(sh);
  5057. loadDiv.toggle(sh);
  5058. break;
  5059. }
  5060. if (loadDiv.is(':visible')) {
  5061. offsetParent = loadDiv.offsetParent();
  5062. loadDiv.css('top', '');
  5063. if (loadDiv.offset().top < scrollTop) {
  5064. top = Math.min(
  5065. 10 + scrollTop - offsetParent.offset().top,
  5066. offsetParent.height() - loadDiv.height()
  5067. );
  5068. loadDiv.css('top', top + 'px');
  5069. }
  5070. }
  5071. });
  5072. },
  5073. getColProp: function (colname) {
  5074. var ret = {}, $t = this[0];
  5075. if (!$t.grid) { return false; }
  5076. var cM = $t.p.colModel, i;
  5077. for (i = 0; i < cM.length; i++) {
  5078. if (cM[i].name === colname) {
  5079. ret = cM[i];
  5080. break;
  5081. }
  5082. }
  5083. return ret;
  5084. },
  5085. setColProp: function (colname, obj) {
  5086. //do not set width will not work
  5087. return this.each(function () {
  5088. if (this.grid) {
  5089. if (obj) {
  5090. var cM = this.p.colModel, i;
  5091. for (i = 0; i < cM.length; i++) {
  5092. if (cM[i].name === colname) {
  5093. $.extend(true, this.p.colModel[i], obj);
  5094. break;
  5095. }
  5096. }
  5097. }
  5098. }
  5099. });
  5100. },
  5101. sortGrid: function (colname, reload, sor) {
  5102. return this.each(function () {
  5103. var $t = this, idx = -1, i, sobj = false;
  5104. if (!$t.grid) { return; }
  5105. if (!colname) { colname = $t.p.sortname; }
  5106. for (i = 0; i < $t.p.colModel.length; i++) {
  5107. if ($t.p.colModel[i].index === colname || $t.p.colModel[i].name === colname) {
  5108. idx = i;
  5109. if ($t.p.frozenColumns === true && $t.p.colModel[i].frozen === true) {
  5110. sobj = $t.grid.fhDiv.find("#" + $t.p.id + "_" + colname);
  5111. }
  5112. break;
  5113. }
  5114. }
  5115. if (idx !== -1) {
  5116. var sort = $t.p.colModel[idx].sortable;
  5117. if (!sobj) {
  5118. sobj = $t.grid.headers[idx].el;
  5119. }
  5120. if (typeof sort !== 'boolean') { sort = true; }
  5121. if (typeof reload !== 'boolean') { reload = false; }
  5122. if (sort) { $t.sortData("jqgh_" + $t.p.id + "_" + colname, idx, reload, sor, sobj); }
  5123. }
  5124. });
  5125. },
  5126. setGridState: function (state) {
  5127. return this.each(function () {
  5128. if (!this.grid) { return; }
  5129. var $t = this,
  5130. open = $(this).jqGrid('getStyleUI', this.p.styleUI + ".base", 'icon_caption_open', true),
  5131. close = $(this).jqGrid('getStyleUI', this.p.styleUI + ".base", 'icon_caption_close', true);
  5132. if (state === 'hidden') {
  5133. $(".ui-jqgrid-bdiv, .ui-jqgrid-hdiv", "#gview_" + $.jgrid.jqID($t.p.id)).slideUp("fast");
  5134. if ($t.p.pager) { $($t.p.pager).slideUp("fast"); }
  5135. if ($t.p.toppager) { $($t.p.toppager).slideUp("fast"); }
  5136. if ($t.p.toolbar[0] === true) {
  5137. if ($t.p.toolbar[1] === 'both') {
  5138. $($t.grid.ubDiv).slideUp("fast");
  5139. }
  5140. $($t.grid.uDiv).slideUp("fast");
  5141. }
  5142. if ($t.p.footerrow) { $(".ui-jqgrid-sdiv", "#gbox_" + $.jgrid.jqID($t.p.id)).slideUp("fast"); }
  5143. $(".ui-jqgrid-headlink", $t.grid.cDiv).removeClass(open).addClass(close);
  5144. $t.p.gridstate = 'hidden';
  5145. } else if (state === 'visible') {
  5146. $(".ui-jqgrid-hdiv, .ui-jqgrid-bdiv", "#gview_" + $.jgrid.jqID($t.p.id)).slideDown("fast");
  5147. if ($t.p.pager) { $($t.p.pager).slideDown("fast"); }
  5148. if ($t.p.toppager) { $($t.p.toppager).slideDown("fast"); }
  5149. if ($t.p.toolbar[0] === true) {
  5150. if ($t.p.toolbar[1] === 'both') {
  5151. $($t.grid.ubDiv).slideDown("fast");
  5152. }
  5153. $($t.grid.uDiv).slideDown("fast");
  5154. }
  5155. if ($t.p.footerrow) { $(".ui-jqgrid-sdiv", "#gbox_" + $.jgrid.jqID($t.p.id)).slideDown("fast"); }
  5156. $(".ui-jqgrid-headlink", $t.grid.cDiv).removeClass(close).addClass(open);
  5157. $t.p.gridstate = 'visible';
  5158. }
  5159. });
  5160. },
  5161. setFrozenColumns: function () {
  5162. return this.each(function () {
  5163. if (!this.grid) { return; }
  5164. var $t = this, cm = $t.p.colModel, i = 0, len = cm.length, maxfrozen = -1, frozen = false,
  5165. hd = $($t).jqGrid('getStyleUI', $t.p.styleUI + ".base", 'headerDiv', true, 'ui-jqgrid-hdiv'),
  5166. hover = $($t).jqGrid('getStyleUI', $t.p.styleUI + ".common", 'hover', true);
  5167. // TODO treeGrid and grouping Support
  5168. if ($t.p.subGrid === true || $t.p.treeGrid === true || $t.p.cellEdit === true || $t.p.sortable || $t.p.scroll) {
  5169. return;
  5170. }
  5171. if ($t.p.rownumbers) { i++; }
  5172. if ($t.p.multiselect) { i++; }
  5173. // get the max index of frozen col
  5174. while (i < len) {
  5175. // from left, no breaking frozen
  5176. if (cm[i].frozen === true) {
  5177. frozen = true;
  5178. maxfrozen = i;
  5179. } else {
  5180. break;
  5181. }
  5182. i++;
  5183. }
  5184. if (maxfrozen >= 0 && frozen) {
  5185. var top = $t.p.caption ? $($t.grid.cDiv).outerHeight() : 0,
  5186. hth = $(".ui-jqgrid-htable", "#gview_" + $.jgrid.jqID($t.p.id)).height();
  5187. //headers
  5188. if ($t.p.toppager) {
  5189. top = top + $($t.grid.topDiv).outerHeight();
  5190. }
  5191. if ($t.p.toolbar[0] === true) {
  5192. if ($t.p.toolbar[1] !== "bottom") {
  5193. top = top + $($t.grid.uDiv).outerHeight();
  5194. }
  5195. }
  5196. $t.grid.fhDiv = $('<div style="position:absolute;' + ($t.p.direction === "rtl" ? 'right:0;' : 'left:0;') + 'top:' + top + 'px;height:' + hth + 'px;" class="frozen-div ' + hd + '"></div>');
  5197. $t.grid.fbDiv = $('<div style="position:absolute;' + ($t.p.direction === "rtl" ? 'right:0;' : 'left:0;') + 'top:' + (parseInt(top, 10) + parseInt(hth, 10) + 1) + 'px;overflow-y:hidden" class="frozen-bdiv ui-jqgrid-bdiv"></div>');
  5198. $("#gview_" + $.jgrid.jqID($t.p.id)).append($t.grid.fhDiv);
  5199. var htbl = $(".ui-jqgrid-htable", "#gview_" + $.jgrid.jqID($t.p.id)).clone(true);
  5200. // groupheader support - only if useColSpanstyle is false
  5201. if ($t.p.groupHeader) {
  5202. $("tr.jqg-first-row-header, tr.jqg-third-row-header", htbl).each(function () {
  5203. $("th:gt(" + maxfrozen + ")", this).remove();
  5204. });
  5205. var swapfroz = -1, fdel = -1, cs, rs;
  5206. $("tr.jqg-second-row-header th", htbl).each(function () {
  5207. cs = parseInt($(this).attr("colspan"), 10);
  5208. rs = parseInt($(this).attr("rowspan"), 10);
  5209. if (rs) {
  5210. swapfroz++;
  5211. fdel++;
  5212. }
  5213. if (cs) {
  5214. swapfroz = swapfroz + cs;
  5215. fdel++;
  5216. }
  5217. if (swapfroz === maxfrozen) {
  5218. fdel = maxfrozen;
  5219. return false;
  5220. }
  5221. });
  5222. if (swapfroz !== maxfrozen) {
  5223. fdel = maxfrozen;
  5224. }
  5225. $("tr.jqg-second-row-header", htbl).each(function () {
  5226. $("th:gt(" + fdel + ")", this).remove();
  5227. });
  5228. } else {
  5229. $("tr", htbl).each(function () {
  5230. $("th:gt(" + maxfrozen + ")", this).remove();
  5231. });
  5232. }
  5233. $(htbl).width(1);
  5234. if (!$.jgrid.msie) { $(htbl).css("height", "100%"); }
  5235. // resizing stuff
  5236. $($t.grid.fhDiv).append(htbl)
  5237. .mousemove(function (e) {
  5238. if ($t.grid.resizing) { $t.grid.dragMove(e); return false; }
  5239. });
  5240. if ($t.p.footerrow) {
  5241. var hbd = $(".ui-jqgrid-bdiv", "#gview_" + $.jgrid.jqID($t.p.id)).height();
  5242. $t.grid.fsDiv = $('<div style="position:absolute;left:0px;top:' + (parseInt(top, 10) + parseInt(hth, 10) + parseInt(hbd, 10) + 1) + 'px;" class="frozen-sdiv ui-jqgrid-sdiv"></div>');
  5243. $("#gview_" + $.jgrid.jqID($t.p.id)).append($t.grid.fsDiv);
  5244. var ftbl = $(".ui-jqgrid-ftable", "#gview_" + $.jgrid.jqID($t.p.id)).clone(true);
  5245. $("tr", ftbl).each(function () {
  5246. $("td:gt(" + maxfrozen + ")", this).remove();
  5247. });
  5248. $(ftbl).width(1);
  5249. $($t.grid.fsDiv).append(ftbl);
  5250. }
  5251. $($t).bind('jqGridResizeStop.setFrozenColumns', function (e, w, index) {
  5252. var rhth = $(".ui-jqgrid-htable", $t.grid.fhDiv);
  5253. $("th:eq(" + index + ")", rhth).width(w);
  5254. var btd = $(".ui-jqgrid-btable", $t.grid.fbDiv);
  5255. $("tr:first td:eq(" + index + ")", btd).width(w);
  5256. if ($t.p.footerrow) {
  5257. var ftd = $(".ui-jqgrid-ftable", $t.grid.fsDiv);
  5258. $("tr:first td:eq(" + index + ")", ftd).width(w);
  5259. }
  5260. });
  5261. // data stuff
  5262. //TODO support for setRowData
  5263. $("#gview_" + $.jgrid.jqID($t.p.id)).append($t.grid.fbDiv);
  5264. $($t.grid.fbDiv).bind('mousewheel DOMMouseScroll', function (e) {
  5265. var st = $($t.grid.bDiv).scrollTop();
  5266. if (e.originalEvent.wheelDelta > 0 || e.originalEvent.detail < 0) {
  5267. //up
  5268. $($t.grid.bDiv).scrollTop(st - 25);
  5269. } else {
  5270. //down
  5271. $($t.grid.bDiv).scrollTop(st + 25);
  5272. }
  5273. e.preventDefault();
  5274. });
  5275. if ($t.p.hoverrows === true) {
  5276. $("#" + $.jgrid.jqID($t.p.id)).unbind('mouseover').unbind('mouseout');
  5277. }
  5278. $($t).bind('jqGridAfterGridComplete.setFrozenColumns', function () {
  5279. $("#" + $.jgrid.jqID($t.p.id) + "_frozen").remove();
  5280. $($t.grid.fbDiv).height($($t.grid.bDiv).height() - 16);
  5281. var btbl = $("#" + $.jgrid.jqID($t.p.id)).clone(true);
  5282. $("tr[role=row]", btbl).each(function () {
  5283. $("td[role=gridcell]:gt(" + maxfrozen + ")", this).remove();
  5284. });
  5285. $(btbl).width(1).attr("id", $t.p.id + "_frozen");
  5286. $($t.grid.fbDiv).append(btbl);
  5287. if ($t.p.hoverrows === true) {
  5288. $("tr.jqgrow", btbl).hover(
  5289. function () { $(this).addClass(hover); $("#" + $.jgrid.jqID(this.id), "#" + $.jgrid.jqID($t.p.id)).addClass(hover); },
  5290. function () { $(this).removeClass(hover); $("#" + $.jgrid.jqID(this.id), "#" + $.jgrid.jqID($t.p.id)).removeClass(hover); }
  5291. );
  5292. $("tr.jqgrow", "#" + $.jgrid.jqID($t.p.id)).hover(
  5293. function () { $(this).addClass(hover); $("#" + $.jgrid.jqID(this.id), "#" + $.jgrid.jqID($t.p.id) + "_frozen").addClass(hover); },
  5294. function () { $(this).removeClass(hover); $("#" + $.jgrid.jqID(this.id), "#" + $.jgrid.jqID($t.p.id) + "_frozen").removeClass(hover); }
  5295. );
  5296. }
  5297. btbl = null;
  5298. });
  5299. if (!$t.grid.hDiv.loading) {
  5300. $($t).triggerHandler("jqGridAfterGridComplete");
  5301. }
  5302. $t.p.frozenColumns = true;
  5303. }
  5304. });
  5305. },
  5306. destroyFrozenColumns: function () {
  5307. return this.each(function () {
  5308. if (!this.grid) { return; }
  5309. if (this.p.frozenColumns === true) {
  5310. var $t = this,
  5311. hover = $($t).jqGrid('getStyleUI', $t.p.styleUI + ".common", 'hover', true);
  5312. $($t.grid.fhDiv).remove();
  5313. $($t.grid.fbDiv).remove();
  5314. $t.grid.fhDiv = null; $t.grid.fbDiv = null;
  5315. if ($t.p.footerrow) {
  5316. $($t.grid.fsDiv).remove();
  5317. $t.grid.fsDiv = null;
  5318. }
  5319. $(this).unbind('.setFrozenColumns');
  5320. if ($t.p.hoverrows === true) {
  5321. var ptr;
  5322. $("#" + $.jgrid.jqID($t.p.id)).bind('mouseover', function (e) {
  5323. ptr = $(e.target).closest("tr.jqgrow");
  5324. if ($(ptr).attr("class") !== "ui-subgrid") {
  5325. $(ptr).addClass(hover);
  5326. }
  5327. }).bind('mouseout', function (e) {
  5328. ptr = $(e.target).closest("tr.jqgrow");
  5329. $(ptr).removeClass(hover);
  5330. });
  5331. }
  5332. this.p.frozenColumns = false;
  5333. }
  5334. });
  5335. },
  5336. resizeColumn: function (iCol, newWidth) {
  5337. return this.each(function () {
  5338. var grid = this.grid, p = this.p, cm = p.colModel, i, cmLen = cm.length, diff, diffnv;
  5339. if (typeof iCol === "string") {
  5340. for (i = 0; i < cmLen; i++) {
  5341. if (cm[i].name === iCol) {
  5342. iCol = i;
  5343. break;
  5344. }
  5345. }
  5346. } else {
  5347. iCol = parseInt(iCol, 10);
  5348. }
  5349. newWidth = parseInt(newWidth, 10);
  5350. // filters
  5351. if (typeof iCol !== "number" || iCol < 0 || iCol > cm.length - 1 || typeof newWidth !== "number") {
  5352. return;
  5353. }
  5354. if (newWidth < p.minColWidth) { return; }
  5355. if (p.forceFit) {
  5356. p.nv = 0;
  5357. for (i = iCol + 1; i < cmLen; i++) {
  5358. if (cm[i].hidden !== true) {
  5359. p.nv = i - iCol;
  5360. break;
  5361. }
  5362. }
  5363. }
  5364. // use resize stuff
  5365. grid.resizing = { idx: iCol };
  5366. diff = newWidth - grid.headers[iCol].width;
  5367. if (p.forceFit) {
  5368. diffnv = grid.headers[iCol + p.nv].width - diff;
  5369. if (diffnv < p.minColWidth) { return; }
  5370. grid.headers[iCol + p.nv].newWidth = grid.headers[iCol + p.nv].width - diff;
  5371. }
  5372. grid.newWidth = p.tblwidth + diff;
  5373. grid.headers[iCol].newWidth = newWidth;
  5374. grid.dragEnd(false);
  5375. });
  5376. },
  5377. getStyleUI: function (styleui, classui, notclasstag, gridclass) {
  5378. try {
  5379. var ret = "", stylemod = styleui.split("."), q = "";
  5380. if (!notclasstag) {
  5381. ret = "class=";
  5382. q = "\"";
  5383. }
  5384. if (gridclass == null) {
  5385. gridclass = "";
  5386. }
  5387. switch (stylemod.length) {
  5388. case 1:
  5389. ret += q + $.trim(gridclass + " " + $.jgrid.styleUI[stylemod[0]][classui] + q);
  5390. break;
  5391. case 2:
  5392. ret += q + $.trim(gridclass + " " + $.jgrid.styleUI[stylemod[0]][stylemod[1]][classui] + q);
  5393. }
  5394. } catch (cls) {
  5395. ret = "";
  5396. }
  5397. return ret;
  5398. },
  5399. resizeGrid: function (timeout) {
  5400. return this.each(function () {
  5401. var $t = this;
  5402. if (timeout === undefined) {
  5403. timeout = 500;
  5404. }
  5405. setTimeout(function () {
  5406. try {
  5407. var winwidth = $(window).width(),
  5408. parentwidth = $("#gbox_" + $.jgrid.jqID($t.p.id)).parent().width(),
  5409. ww = $t.p.width;
  5410. if ((winwidth - parentwidth) > 3) {
  5411. ww = parentwidth;
  5412. } else {
  5413. ww = winwidth;
  5414. }
  5415. $("#" + $.jgrid.jqID($t.p.id)).jqGrid('setGridWidth', ww);
  5416. } catch (e) { }
  5417. }, timeout);
  5418. });
  5419. }
  5420. });
  5421. //module begin
  5422. $.jgrid.extend({
  5423. editCell: function (iRow, iCol, ed) {
  5424. return this.each(function () {
  5425. var $t = this, nm, tmp, cc, cm,
  5426. highlight = $(this).jqGrid('getStyleUI', $t.p.styleUI + '.common', 'highlight', true),
  5427. hover = $(this).jqGrid('getStyleUI', $t.p.styleUI + '.common', 'hover', true),
  5428. inpclass = $(this).jqGrid('getStyleUI', $t.p.styleUI + ".celledit", 'inputClass', true);
  5429. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5430. iCol = parseInt(iCol, 10);
  5431. // select the row that can be used for other methods
  5432. $t.p.selrow = $t.rows[iRow].id;
  5433. if (!$t.p.knv) { $($t).jqGrid("GridNav"); }
  5434. // check to see if we have already edited cell
  5435. if ($t.p.savedRow.length > 0) {
  5436. // prevent second click on that field and enable selects
  5437. if (ed === true) {
  5438. if (iRow == $t.p.iRow && iCol == $t.p.iCol) {
  5439. return;
  5440. }
  5441. }
  5442. // save the cell
  5443. $($t).jqGrid("saveCell", $t.p.savedRow[0].id, $t.p.savedRow[0].ic);
  5444. } else {
  5445. window.setTimeout(function () { $("#" + $.jgrid.jqID($t.p.knv)).attr("tabindex", "-1").focus(); }, 1);
  5446. }
  5447. cm = $t.p.colModel[iCol];
  5448. nm = cm.name;
  5449. if (nm === 'subgrid' || nm === 'cb' || nm === 'rn') { return; }
  5450. cc = $("td:eq(" + iCol + ")", $t.rows[iRow]);
  5451. if (cm.editable === true && ed === true && !cc.hasClass("not-editable-cell") && (!$.isFunction($t.p.isCellEditable) || $t.p.isCellEditable.call($t, nm, iRow, iCol))) {
  5452. if (parseInt($t.p.iCol, 10) >= 0 && parseInt($t.p.iRow, 10) >= 0) {
  5453. //$("td:eq("+$t.p.iCol+")",$t.rows[$t.p.iRow]).removeClass("edit-cell " + highlight);
  5454. $($t.rows[$t.p.iRow]).removeClass("selected-row " + hover).find("td:eq(" + $t.p.iCol + ")").removeClass("edit-cell " + highlight);
  5455. }
  5456. $(cc).addClass("edit-cell " + highlight);
  5457. $($t.rows[iRow]).addClass("selected-row " + hover);
  5458. try {
  5459. tmp = $.unformat.call($t, cc, { rowId: $t.rows[iRow].id, colModel: cm }, iCol);
  5460. } catch (_) {
  5461. tmp = (cm.edittype && cm.edittype === 'textarea') ? $(cc).text() : $(cc).html();
  5462. }
  5463. if ($t.p.autoencode) { tmp = $.jgrid.htmlDecode(tmp); }
  5464. if (!cm.edittype) { cm.edittype = "text"; }
  5465. $t.p.savedRow.push({ id: iRow, ic: iCol, name: nm, v: tmp });
  5466. if (tmp === "&nbsp;" || tmp === "&#160;" || (tmp.length === 1 && tmp.charCodeAt(0) === 160)) { tmp = ''; }
  5467. if ($.isFunction($t.p.formatCell)) {
  5468. var tmp2 = $t.p.formatCell.call($t, $t.rows[iRow].id, nm, tmp, iRow, iCol);
  5469. if (tmp2 !== undefined) { tmp = tmp2; }
  5470. }
  5471. $($t).triggerHandler("jqGridBeforeEditCell", [$t.rows[iRow].id, nm, tmp, iRow, iCol]);
  5472. if ($.isFunction($t.p.beforeEditCell)) {
  5473. $t.p.beforeEditCell.call($t, $t.rows[iRow].id, nm, tmp, iRow, iCol);
  5474. }
  5475. var opt = $.extend({}, cm.editoptions || {}, { id: iRow + "_" + nm, name: nm, rowId: $t.rows[iRow].id, oper: 'edit' });
  5476. var elc = $.jgrid.createEl.call($t, cm.edittype, opt, tmp, true, $.extend({}, $.jgrid.ajaxOptions, $t.p.ajaxSelectOptions || {}));
  5477. if ($.inArray(cm.edittype, ['text', 'textarea', 'password', 'select']) > -1) {
  5478. $(elc).addClass(inpclass);
  5479. }
  5480. $(cc).html("").append(elc).attr("tabindex", "0");
  5481. $.jgrid.bindEv.call($t, elc, opt);
  5482. window.setTimeout(function () { $(elc).focus(); }, 1);
  5483. $("input, select, textarea", cc).bind("keydown", function (e) {
  5484. if (e.keyCode === 27) {
  5485. if ($("input.hasDatepicker", cc).length > 0) {
  5486. if ($(".ui-datepicker").is(":hidden")) { $($t).jqGrid("restoreCell", iRow, iCol); }
  5487. else { $("input.hasDatepicker", cc).datepicker('hide'); }
  5488. } else {
  5489. $($t).jqGrid("restoreCell", iRow, iCol);
  5490. }
  5491. } //ESC
  5492. if (e.keyCode === 13 && !e.shiftKey) {
  5493. $($t).jqGrid("saveCell", iRow, iCol);
  5494. // Prevent default action
  5495. return false;
  5496. } //Enter
  5497. if (e.keyCode === 9) {
  5498. if (!$t.grid.hDiv.loading) {
  5499. if (e.shiftKey) { $($t).jqGrid("prevCell", iRow, iCol); } //Shift TAb
  5500. else { $($t).jqGrid("nextCell", iRow, iCol); } //Tab
  5501. } else {
  5502. return false;
  5503. }
  5504. }
  5505. e.stopPropagation();
  5506. });
  5507. $($t).triggerHandler("jqGridAfterEditCell", [$t.rows[iRow].id, nm, tmp, iRow, iCol]);
  5508. if ($.isFunction($t.p.afterEditCell)) {
  5509. $t.p.afterEditCell.call($t, $t.rows[iRow].id, nm, tmp, iRow, iCol);
  5510. }
  5511. } else {
  5512. if (parseInt($t.p.iCol, 10) >= 0 && parseInt($t.p.iRow, 10) >= 0) {
  5513. //$("td:eq("+$t.p.iCol+")",$t.rows[$t.p.iRow]).removeClass("edit-cell " + highlight);
  5514. $($t.rows[$t.p.iRow]).removeClass("selected-row " + hover).find("td:eq(" + $t.p.iCol + ")").removeClass("edit-cell " + highlight);
  5515. }
  5516. cc.addClass("edit-cell " + highlight);
  5517. $($t.rows[iRow]).addClass("selected-row " + hover);
  5518. tmp = cc.html().replace(/\&#160\;/ig, '');
  5519. $($t).triggerHandler("jqGridSelectCell", [$t.rows[iRow].id, nm, tmp, iRow, iCol]);
  5520. if ($.isFunction($t.p.onSelectCell)) {
  5521. $t.p.onSelectCell.call($t, $t.rows[iRow].id, nm, tmp, iRow, iCol);
  5522. }
  5523. }
  5524. $t.p.iCol = iCol; $t.p.iRow = iRow;
  5525. });
  5526. },
  5527. saveCell: function (iRow, iCol) {
  5528. return this.each(function () {
  5529. var $t = this, fr,
  5530. errors = $.jgrid.getRegional(this, 'errors'),
  5531. edit = $.jgrid.getRegional(this, 'edit');
  5532. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5533. if ($t.p.savedRow.length >= 1) { fr = 0; } else { fr = null; }
  5534. if (fr !== null) {
  5535. var cc = $("td:eq(" + iCol + ")", $t.rows[iRow]), v, v2,
  5536. cm = $t.p.colModel[iCol], nm = cm.name, nmjq = $.jgrid.jqID(nm),
  5537. p = $(cc).offset();
  5538. switch (cm.edittype) {
  5539. case "select":
  5540. if (!cm.editoptions.multiple) {
  5541. v = $("#" + iRow + "_" + nmjq + " option:selected", $t.rows[iRow]).val();
  5542. v2 = $("#" + iRow + "_" + nmjq + " option:selected", $t.rows[iRow]).text();
  5543. } else {
  5544. var sel = $("#" + iRow + "_" + nmjq, $t.rows[iRow]), selectedText = [];
  5545. v = $(sel).val();
  5546. if (v) { v.join(","); } else { v = ""; }
  5547. $("option:selected", sel).each(
  5548. function (i, selected) {
  5549. selectedText[i] = $(selected).text();
  5550. }
  5551. );
  5552. v2 = selectedText.join(",");
  5553. }
  5554. if (cm.formatter) { v2 = v; }
  5555. break;
  5556. case "checkbox":
  5557. var cbv = ["Yes", "No"];
  5558. if (cm.editoptions) {
  5559. cbv = cm.editoptions.value.split(":");
  5560. }
  5561. v = $("#" + iRow + "_" + nmjq, $t.rows[iRow]).is(":checked") ? cbv[0] : cbv[1];
  5562. v2 = v;
  5563. break;
  5564. case "password":
  5565. case "text":
  5566. case "textarea":
  5567. case "button":
  5568. v = $("#" + iRow + "_" + nmjq, $t.rows[iRow]).val();
  5569. v2 = v;
  5570. break;
  5571. case 'custom':
  5572. try {
  5573. if (cm.editoptions && $.isFunction(cm.editoptions.custom_value)) {
  5574. v = cm.editoptions.custom_value.call($t, $(".customelement", cc), 'get');
  5575. if (v === undefined) { throw "e2"; } else { v2 = v; }
  5576. } else { throw "e1"; }
  5577. } catch (e) {
  5578. if (e === "e1") { $.jgrid.info_dialog(errors.errcap, "function 'custom_value' " + edit.msg.nodefined, edit.bClose, { styleUI: $t.p.styleUI }); }
  5579. else if (e === "e2") { $.jgrid.info_dialog(errors.errcap, "function 'custom_value' " + edit.msg.novalue, edit.bClose, { styleUI: $t.p.styleUI }); }
  5580. else { $.jgrid.info_dialog(errors.errcap, e.message, edit.bClose, { styleUI: $t.p.styleUI }); }
  5581. }
  5582. break;
  5583. }
  5584. // The common approach is if nothing changed do not do anything
  5585. if (v2 !== $t.p.savedRow[fr].v) {
  5586. var vvv = $($t).triggerHandler("jqGridBeforeSaveCell", [$t.rows[iRow].id, nm, v, iRow, iCol]);
  5587. if (vvv) { v = vvv; v2 = vvv; }
  5588. if ($.isFunction($t.p.beforeSaveCell)) {
  5589. var vv = $t.p.beforeSaveCell.call($t, $t.rows[iRow].id, nm, v, iRow, iCol);
  5590. if (vv) { v = vv; v2 = vv; }
  5591. }
  5592. var cv = $.jgrid.checkValues.call($t, v, iCol), nuem = false;
  5593. if (cv[0] === true) {
  5594. var addpost = $($t).triggerHandler("jqGridBeforeSubmitCell", [$t.rows[iRow].id, nm, v, iRow, iCol]) || {};
  5595. if ($.isFunction($t.p.beforeSubmitCell)) {
  5596. addpost = $t.p.beforeSubmitCell.call($t, $t.rows[iRow].id, nm, v, iRow, iCol);
  5597. if (!addpost) { addpost = {}; }
  5598. }
  5599. if ($("input.hasDatepicker", cc).length > 0) { $("input.hasDatepicker", cc).datepicker('hide'); }
  5600. if ($t.p.cellsubmit === 'remote') {
  5601. if ($t.p.cellurl) {
  5602. var postdata = {};
  5603. if ($t.p.autoencode) { v = $.jgrid.htmlEncode(v); }
  5604. if (cm.editoptions && cm.editoptions.NullIfEmpty && v === "") {
  5605. v = 'null';
  5606. nuem = true;
  5607. }
  5608. postdata[nm] = v;
  5609. var idname, oper, opers;
  5610. opers = $t.p.prmNames;
  5611. idname = opers.id;
  5612. oper = opers.oper;
  5613. postdata[idname] = $.jgrid.stripPref($t.p.idPrefix, $t.rows[iRow].id);
  5614. postdata[oper] = opers.editoper;
  5615. postdata = $.extend(addpost, postdata);
  5616. $($t).jqGrid("progressBar", { method: "show", loadtype: $t.p.loadui, htmlcontent: $.jgrid.getRegional($t, 'defaults.savetext') });
  5617. $t.grid.hDiv.loading = true;
  5618. $.ajax($.extend({
  5619. url: $t.p.cellurl,
  5620. data: $.isFunction($t.p.serializeCellData) ? $t.p.serializeCellData.call($t, postdata, nm) : postdata,
  5621. type: "POST",
  5622. complete: function (result, stat) {
  5623. $($t).jqGrid("progressBar", { method: "hide", loadtype: $t.p.loadui });
  5624. $t.grid.hDiv.loading = false;
  5625. if (stat === 'success') {
  5626. var ret = $($t).triggerHandler("jqGridAfterSubmitCell", [$t, result, postdata.id, nm, v, iRow, iCol]) || [true, ''];
  5627. if (ret[0] === true && $.isFunction($t.p.afterSubmitCell)) {
  5628. ret = $t.p.afterSubmitCell.call($t, result, postdata.id, nm, v, iRow, iCol);
  5629. }
  5630. if (ret[0] === true) {
  5631. if (nuem) {
  5632. v = "";
  5633. }
  5634. $(cc).empty();
  5635. $($t).jqGrid("setCell", $t.rows[iRow].id, iCol, v2, false, false, true);
  5636. $(cc).addClass("dirty-cell");
  5637. $($t.rows[iRow]).addClass("edited");
  5638. $($t).triggerHandler("jqGridAfterSaveCell", [$t.rows[iRow].id, nm, v, iRow, iCol]);
  5639. if ($.isFunction($t.p.afterSaveCell)) {
  5640. $t.p.afterSaveCell.call($t, $t.rows[iRow].id, nm, v, iRow, iCol);
  5641. }
  5642. $t.p.savedRow.splice(0, 1);
  5643. } else {
  5644. $.jgrid.info_dialog(errors.errcap, ret[1], edit.bClose, { styleUI: $t.p.styleUI });
  5645. if ($t.p.restoreCellonFail) {
  5646. $($t).jqGrid("restoreCell", iRow, iCol);
  5647. }
  5648. }
  5649. }
  5650. },
  5651. error: function (res, stat, err) {
  5652. $("#lui_" + $.jgrid.jqID($t.p.id)).hide();
  5653. $t.grid.hDiv.loading = false;
  5654. $($t).triggerHandler("jqGridErrorCell", [res, stat, err]);
  5655. if ($.isFunction($t.p.errorCell)) {
  5656. $t.p.errorCell.call($t, res, stat, err);
  5657. } else {
  5658. $.jgrid.info_dialog(errors.errcap, res.status + " : " + res.statusText + "<br/>" + stat, edit.bClose, { styleUI: $t.p.styleUI });
  5659. }
  5660. if ($t.p.restoreCellonFail) {
  5661. $($t).jqGrid("restoreCell", iRow, iCol);
  5662. }
  5663. }
  5664. }, $.jgrid.ajaxOptions, $t.p.ajaxCellOptions || {}));
  5665. } else {
  5666. try {
  5667. $.jgrid.info_dialog(errors.errcap, errors.nourl, edit.bClose, { styleUI: $t.p.styleUI });
  5668. if ($t.p.restoreCellonFail) {
  5669. $($t).jqGrid("restoreCell", iRow, iCol);
  5670. }
  5671. } catch (e) { }
  5672. }
  5673. }
  5674. if ($t.p.cellsubmit === 'clientArray') {
  5675. $(cc).empty();
  5676. $($t).jqGrid("setCell", $t.rows[iRow].id, iCol, v2, false, false, true);
  5677. $(cc).addClass("dirty-cell");
  5678. $($t.rows[iRow]).addClass("edited");
  5679. $($t).triggerHandler("jqGridAfterSaveCell", [$t.rows[iRow].id, nm, v, iRow, iCol]);
  5680. if ($.isFunction($t.p.afterSaveCell)) {
  5681. $t.p.afterSaveCell.call($t, $t.rows[iRow].id, nm, v, iRow, iCol);
  5682. }
  5683. $t.p.savedRow.splice(0, 1);
  5684. }
  5685. } else {
  5686. try {
  5687. window.setTimeout(function () { $.jgrid.info_dialog(errors.errcap, v + " " + cv[1], edit.bClose, { styleUI: $t.p.styleUI, top: p.top + 40, left: p.left }); }, 100);
  5688. $($t).jqGrid("restoreCell", iRow, iCol);
  5689. } catch (e) { }
  5690. }
  5691. } else {
  5692. $($t).jqGrid("restoreCell", iRow, iCol);
  5693. }
  5694. }
  5695. window.setTimeout(function () { $("#" + $.jgrid.jqID($t.p.knv)).attr("tabindex", "-1").focus(); }, 0);
  5696. });
  5697. },
  5698. restoreCell: function (iRow, iCol) {
  5699. return this.each(function () {
  5700. var $t = this, fr;
  5701. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5702. if ($t.p.savedRow.length >= 1) { fr = 0; } else { fr = null; }
  5703. if (fr !== null) {
  5704. var cc = $("td:eq(" + iCol + ")", $t.rows[iRow]);
  5705. // datepicker fix
  5706. if ($.isFunction($.fn.datepicker)) {
  5707. try {
  5708. $("input.hasDatepicker", cc).datepicker('hide');
  5709. } catch (e) { }
  5710. }
  5711. $(cc).empty().attr("tabindex", "-1");
  5712. $($t).jqGrid("setCell", $t.rows[iRow].id, iCol, $t.p.savedRow[fr].v, false, false, true);
  5713. $($t).triggerHandler("jqGridAfterRestoreCell", [$t.rows[iRow].id, $t.p.savedRow[fr].v, iRow, iCol]);
  5714. if ($.isFunction($t.p.afterRestoreCell)) {
  5715. $t.p.afterRestoreCell.call($t, $t.rows[iRow].id, $t.p.savedRow[fr].v, iRow, iCol);
  5716. }
  5717. $t.p.savedRow.splice(0, 1);
  5718. }
  5719. window.setTimeout(function () { $("#" + $t.p.knv).attr("tabindex", "-1").focus(); }, 0);
  5720. });
  5721. },
  5722. nextCell: function (iRow, iCol) {
  5723. return this.each(function () {
  5724. var $t = this, nCol = false, i;
  5725. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5726. // try to find next editable cell
  5727. for (i = iCol + 1; i < $t.p.colModel.length; i++) {
  5728. if ($t.p.colModel[i].editable === true && (!$.isFunction($t.p.isCellEditable) || $t.p.isCellEditable.call($t, $t.p.colModel[i].name, iRow, i))) {
  5729. nCol = i; break;
  5730. }
  5731. }
  5732. if (nCol !== false) {
  5733. $($t).jqGrid("editCell", iRow, nCol, true);
  5734. } else {
  5735. if ($t.p.savedRow.length > 0) {
  5736. $($t).jqGrid("saveCell", iRow, iCol);
  5737. }
  5738. }
  5739. });
  5740. },
  5741. prevCell: function (iRow, iCol) {
  5742. return this.each(function () {
  5743. var $t = this, nCol = false, i;
  5744. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5745. // try to find next editable cell
  5746. for (i = iCol - 1; i >= 0; i--) {
  5747. if ($t.p.colModel[i].editable === true && (!$.isFunction($t.p.isCellEditable) || $t.p.isCellEditable.call($t, $t.p.colModel[i].name, iRow, i))) {
  5748. nCol = i; break;
  5749. }
  5750. }
  5751. if (nCol !== false) {
  5752. $($t).jqGrid("editCell", iRow, nCol, true);
  5753. } else {
  5754. if ($t.p.savedRow.length > 0) {
  5755. $($t).jqGrid("saveCell", iRow, iCol);
  5756. }
  5757. }
  5758. });
  5759. },
  5760. GridNav: function () {
  5761. return this.each(function () {
  5762. var $t = this;
  5763. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5764. // trick to process keydown on non input elements
  5765. $t.p.knv = $t.p.id + "_kn";
  5766. var selection = $("<div style='position:fixed;top:0px;width:1px;height:1px;' tabindex='0'><div tabindex='-1' style='width:1px;height:1px;' id='" + $t.p.knv + "'></div></div>"),
  5767. i, kdir;
  5768. function scrollGrid(iR, iC, tp) {
  5769. if (tp.substr(0, 1) === 'v') {
  5770. var ch = $($t.grid.bDiv)[0].clientHeight,
  5771. st = $($t.grid.bDiv)[0].scrollTop,
  5772. nROT = $t.rows[iR].offsetTop + $t.rows[iR].clientHeight,
  5773. pROT = $t.rows[iR].offsetTop;
  5774. if (tp === 'vd') {
  5775. if (nROT >= ch) {
  5776. $($t.grid.bDiv)[0].scrollTop = $($t.grid.bDiv)[0].scrollTop + $t.rows[iR].clientHeight;
  5777. }
  5778. }
  5779. if (tp === 'vu') {
  5780. if (pROT < st) {
  5781. $($t.grid.bDiv)[0].scrollTop = $($t.grid.bDiv)[0].scrollTop - $t.rows[iR].clientHeight;
  5782. }
  5783. }
  5784. }
  5785. if (tp === 'h') {
  5786. var cw = $($t.grid.bDiv)[0].clientWidth,
  5787. sl = $($t.grid.bDiv)[0].scrollLeft,
  5788. nCOL = $t.rows[iR].cells[iC].offsetLeft + $t.rows[iR].cells[iC].clientWidth,
  5789. pCOL = $t.rows[iR].cells[iC].offsetLeft;
  5790. if (nCOL >= cw + parseInt(sl, 10)) {
  5791. $($t.grid.bDiv)[0].scrollLeft = $($t.grid.bDiv)[0].scrollLeft + $t.rows[iR].cells[iC].clientWidth;
  5792. } else if (pCOL < sl) {
  5793. $($t.grid.bDiv)[0].scrollLeft = $($t.grid.bDiv)[0].scrollLeft - $t.rows[iR].cells[iC].clientWidth;
  5794. }
  5795. }
  5796. }
  5797. function findNextVisible(iC, act) {
  5798. var ind, i;
  5799. if (act === 'lft') {
  5800. ind = iC + 1;
  5801. for (i = iC; i >= 0; i--) {
  5802. if ($t.p.colModel[i].hidden !== true) {
  5803. ind = i;
  5804. break;
  5805. }
  5806. }
  5807. }
  5808. if (act === 'rgt') {
  5809. ind = iC - 1;
  5810. for (i = iC; i < $t.p.colModel.length; i++) {
  5811. if ($t.p.colModel[i].hidden !== true) {
  5812. ind = i;
  5813. break;
  5814. }
  5815. }
  5816. }
  5817. return ind;
  5818. }
  5819. $(selection).insertBefore($t.grid.cDiv);
  5820. $("#" + $t.p.knv)
  5821. .focus()
  5822. .keydown(function (e) {
  5823. kdir = e.keyCode;
  5824. if ($t.p.direction === "rtl") {
  5825. if (kdir === 37) { kdir = 39; }
  5826. else if (kdir === 39) { kdir = 37; }
  5827. }
  5828. switch (kdir) {
  5829. case 38:
  5830. if ($t.p.iRow - 1 > 0) {
  5831. scrollGrid($t.p.iRow - 1, $t.p.iCol, 'vu');
  5832. $($t).jqGrid("editCell", $t.p.iRow - 1, $t.p.iCol, false);
  5833. }
  5834. break;
  5835. case 40:
  5836. if ($t.p.iRow + 1 <= $t.rows.length - 1) {
  5837. scrollGrid($t.p.iRow + 1, $t.p.iCol, 'vd');
  5838. $($t).jqGrid("editCell", $t.p.iRow + 1, $t.p.iCol, false);
  5839. }
  5840. break;
  5841. case 37:
  5842. if ($t.p.iCol - 1 >= 0) {
  5843. i = findNextVisible($t.p.iCol - 1, 'lft');
  5844. scrollGrid($t.p.iRow, i, 'h');
  5845. $($t).jqGrid("editCell", $t.p.iRow, i, false);
  5846. }
  5847. break;
  5848. case 39:
  5849. if ($t.p.iCol + 1 <= $t.p.colModel.length - 1) {
  5850. i = findNextVisible($t.p.iCol + 1, 'rgt');
  5851. scrollGrid($t.p.iRow, i, 'h');
  5852. $($t).jqGrid("editCell", $t.p.iRow, i, false);
  5853. }
  5854. break;
  5855. case 13:
  5856. if (parseInt($t.p.iCol, 10) >= 0 && parseInt($t.p.iRow, 10) >= 0) {
  5857. $($t).jqGrid("editCell", $t.p.iRow, $t.p.iCol, true);
  5858. }
  5859. break;
  5860. default:
  5861. return true;
  5862. }
  5863. return false;
  5864. });
  5865. });
  5866. },
  5867. getChangedCells: function (mthd) {
  5868. var ret = [];
  5869. if (!mthd) { mthd = 'all'; }
  5870. this.each(function () {
  5871. var $t = this, nm;
  5872. if (!$t.grid || $t.p.cellEdit !== true) { return; }
  5873. $($t.rows).each(function (j) {
  5874. var res = {};
  5875. if ($(this).hasClass("edited")) {
  5876. $('td', this).each(function (i) {
  5877. nm = $t.p.colModel[i].name;
  5878. if (nm !== 'cb' && nm !== 'subgrid') {
  5879. if (mthd === 'dirty') {
  5880. if ($(this).hasClass('dirty-cell')) {
  5881. try {
  5882. res[nm] = $.unformat.call($t, this, { rowId: $t.rows[j].id, colModel: $t.p.colModel[i] }, i);
  5883. } catch (e) {
  5884. res[nm] = $.jgrid.htmlDecode($(this).html());
  5885. }
  5886. }
  5887. } else {
  5888. try {
  5889. res[nm] = $.unformat.call($t, this, { rowId: $t.rows[j].id, colModel: $t.p.colModel[i] }, i);
  5890. } catch (e) {
  5891. res[nm] = $.jgrid.htmlDecode($(this).html());
  5892. }
  5893. }
  5894. }
  5895. });
  5896. res.id = this.id;
  5897. ret.push(res);
  5898. }
  5899. });
  5900. });
  5901. return ret;
  5902. }
  5903. /// end cell editing
  5904. });
  5905. //module begin
  5906. $.extend($.jgrid, {
  5907. // Modal functions
  5908. showModal: function (h) {
  5909. h.w.show();
  5910. },
  5911. closeModal: function (h) {
  5912. h.w.hide().attr("aria-hidden", "true");
  5913. if (h.o) { h.o.remove(); }
  5914. },
  5915. hideModal: function (selector, o) {
  5916. o = $.extend({ jqm: true, gb: '', removemodal: false, formprop: false, form: '' }, o || {});
  5917. var thisgrid = o.gb && typeof o.gb === "string" && o.gb.substr(0, 6) === "#gbox_" ? $("#" + o.gb.substr(6))[0] : false;
  5918. if (o.onClose) {
  5919. var oncret = thisgrid ? o.onClose.call(thisgrid, selector) : o.onClose(selector);
  5920. if (typeof oncret === 'boolean' && !oncret) { return; }
  5921. }
  5922. if (o.formprop && thisgrid && o.form) {
  5923. var fh = $(selector)[0].style.height,
  5924. fw = $(selector)[0].style.width;
  5925. if (fh.indexOf("px") > -1) {
  5926. fh = parseFloat(fh);
  5927. }
  5928. if (fw.indexOf("px") > -1) {
  5929. fw = parseFloat(fw);
  5930. }
  5931. var frmgr, frmdata;
  5932. if (o.form === 'edit') {
  5933. frmgr = '#' + $.jgrid.jqID("FrmGrid_" + o.gb.substr(6));
  5934. frmdata = "formProp";
  5935. } else if (o.form === 'view') {
  5936. frmgr = '#' + $.jgrid.jqID("ViewGrid_" + o.gb.substr(6));
  5937. frmdata = "viewProp";
  5938. }
  5939. $(thisgrid).data(frmdata, {
  5940. top: parseFloat($(selector).css("top")),
  5941. left: parseFloat($(selector).css("left")),
  5942. width: fw,
  5943. height: fh,
  5944. dataheight: $(frmgr).height(),
  5945. datawidth: $(frmgr).width()
  5946. });
  5947. }
  5948. if ($.fn.jqm && o.jqm === true) {
  5949. $(selector).attr("aria-hidden", "true").jqmHide();
  5950. } else {
  5951. if (o.gb !== '') {
  5952. try { $(".jqgrid-overlay:first", o.gb).hide(); } catch (e) { }
  5953. }
  5954. $(selector).hide().attr("aria-hidden", "true");
  5955. }
  5956. if (o.removemodal) {
  5957. $(selector).remove();
  5958. }
  5959. },
  5960. //Helper functions
  5961. findPos: function (obj) {
  5962. var curleft = 0, curtop = 0;
  5963. if (obj.offsetParent) {
  5964. do {
  5965. curleft += obj.offsetLeft;
  5966. curtop += obj.offsetTop;
  5967. } while (obj = obj.offsetParent);
  5968. //do not change obj == obj.offsetParent
  5969. }
  5970. return [curleft, curtop];
  5971. },
  5972. createModal: function (aIDs, content, p, insertSelector, posSelector, appendsel, css) {
  5973. p = $.extend(true, {}, $.jgrid.jqModal || {}, p);
  5974. var self = this,
  5975. rtlsup = $(p.gbox).attr("dir") === "rtl" ? true : false,
  5976. classes = $.jgrid.styleUI[(p.styleUI || 'jQueryUI')].modal,
  5977. common = $.jgrid.styleUI[(p.styleUI || 'jQueryUI')].common,
  5978. mw = document.createElement('div');
  5979. css = $.extend({}, css || {});
  5980. mw.className = "ui-jqdialog " + classes.modal;
  5981. mw.id = aIDs.themodal;
  5982. var mh = document.createElement('div');
  5983. mh.className = "ui-jqdialog-titlebar " + classes.header;
  5984. mh.id = aIDs.modalhead;
  5985. $(mh).append("<span class='ui-jqdialog-title'>" + p.caption + "</span>");
  5986. var ahr = $("<a class='ui-jqdialog-titlebar-close " + common.cornerall + "'></a>")
  5987. .hover(function () { ahr.addClass(common.hover); },
  5988. function () { ahr.removeClass(common.hover); })
  5989. .append("<span class='" + common.icon_base + " " + classes.icon_close + "'></span>");
  5990. $(mh).append(ahr);
  5991. if (rtlsup) {
  5992. mw.dir = "rtl";
  5993. $(".ui-jqdialog-title", mh).css("float", "right");
  5994. $(".ui-jqdialog-titlebar-close", mh).css("left", 0.3 + "em");
  5995. } else {
  5996. mw.dir = "ltr";
  5997. $(".ui-jqdialog-title", mh).css("float", "left");
  5998. $(".ui-jqdialog-titlebar-close", mh).css("right", 0.3 + "em");
  5999. }
  6000. var mc = document.createElement('div');
  6001. $(mc).addClass("ui-jqdialog-content " + classes.content).attr("id", aIDs.modalcontent);
  6002. $(mc).append(content);
  6003. mw.appendChild(mc);
  6004. $(mw).prepend(mh);
  6005. if (appendsel === true) {
  6006. $('body').append(mw);
  6007. } //append as first child in body -for alert dialog
  6008. else if (typeof appendsel === "string") {
  6009. $(appendsel).append(mw);
  6010. } else {
  6011. $(mw).insertBefore(insertSelector);
  6012. }
  6013. $(mw).css(css);
  6014. if (p.jqModal === undefined) { p.jqModal = true; } // internal use
  6015. var coord = {};
  6016. if ($.fn.jqm && p.jqModal === true) {
  6017. if (p.left === 0 && p.top === 0 && p.overlay) {
  6018. var pos = [];
  6019. pos = $.jgrid.findPos(posSelector);
  6020. p.left = pos[0] + 4;
  6021. p.top = pos[1] + 4;
  6022. }
  6023. coord.top = p.top + "px";
  6024. coord.left = p.left;
  6025. } else if (p.left !== 0 || p.top !== 0) {
  6026. coord.left = p.left;
  6027. coord.top = p.top + "px";
  6028. }
  6029. $("a.ui-jqdialog-titlebar-close", mh).click(function () {
  6030. var oncm = $("#" + $.jgrid.jqID(aIDs.themodal)).data("onClose") || p.onClose;
  6031. var gboxclose = $("#" + $.jgrid.jqID(aIDs.themodal)).data("gbox") || p.gbox;
  6032. self.hideModal("#" + $.jgrid.jqID(aIDs.themodal), { gb: gboxclose, jqm: p.jqModal, onClose: oncm, removemodal: p.removemodal || false, formprop: !p.recreateForm || false, form: p.form || '' });
  6033. return false;
  6034. });
  6035. if (p.width === 0 || !p.width) { p.width = 300; }
  6036. if (p.height === 0 || !p.height) { p.height = 200; }
  6037. if (!p.zIndex) {
  6038. var parentZ = $(insertSelector).parents("*[role=dialog]").filter(':first').css("z-index");
  6039. if (parentZ) {
  6040. p.zIndex = parseInt(parentZ, 10) + 2;
  6041. } else {
  6042. p.zIndex = 950;
  6043. }
  6044. }
  6045. var rtlt = 0;
  6046. if (rtlsup && coord.left && !appendsel) {
  6047. rtlt = $(p.gbox).width() - (!isNaN(p.width) ? parseInt(p.width, 10) : 0) - 8; // to do
  6048. // just in case
  6049. coord.left = parseInt(coord.left, 10) + parseInt(rtlt, 10);
  6050. }
  6051. if (coord.left) { coord.left += "px"; }
  6052. $(mw).css($.extend({
  6053. width: isNaN(p.width) ? "auto" : p.width + "px",
  6054. height: isNaN(p.height) ? "auto" : p.height + "px",
  6055. zIndex: p.zIndex,
  6056. overflow: 'hidden'
  6057. }, coord))
  6058. .attr({ tabIndex: "-1", "role": "dialog", "aria-labelledby": aIDs.modalhead, "aria-hidden": "true" });
  6059. if (p.drag === undefined) { p.drag = true; }
  6060. if (p.resize === undefined) { p.resize = true; }
  6061. if (p.drag) {
  6062. $(mh).css('cursor', 'move');
  6063. if ($.fn.tinyDraggable) {
  6064. //$(mw).jqDrag(mh);
  6065. $(mw).tinyDraggable({ handle: "#" + $.jgrid.jqID(mh.id) });
  6066. } else {
  6067. try {
  6068. $(mw).draggable({ handle: $("#" + $.jgrid.jqID(mh.id)) });
  6069. } catch (e) { }
  6070. }
  6071. }
  6072. if (p.resize) {
  6073. if ($.fn.jqResize) {
  6074. $(mw).append("<div class='jqResize " + classes.resizable + " " + common.icon_base + " " + classes.icon_resizable + "'></div>");
  6075. $("#" + $.jgrid.jqID(aIDs.themodal)).jqResize(".jqResize", aIDs.scrollelm ? "#" + $.jgrid.jqID(aIDs.scrollelm) : false);
  6076. } else {
  6077. try {
  6078. $(mw).resizable({ handles: 'se, sw', alsoResize: aIDs.scrollelm ? "#" + $.jgrid.jqID(aIDs.scrollelm) : false });
  6079. } catch (r) { }
  6080. }
  6081. }
  6082. if (p.closeOnEscape === true) {
  6083. $(mw).keydown(function (e) {
  6084. if (e.which === 27) {
  6085. var cone = $("#" + $.jgrid.jqID(aIDs.themodal)).data("onClose") || p.onClose;
  6086. self.hideModal("#" + $.jgrid.jqID(aIDs.themodal), { gb: p.gbox, jqm: p.jqModal, onClose: cone, removemodal: p.removemodal || false, formprop: !p.recreateForm || false, form: p.form || '' });
  6087. }
  6088. });
  6089. }
  6090. },
  6091. viewModal: function (selector, o) {
  6092. o = $.extend({
  6093. toTop: true,
  6094. overlay: 10,
  6095. modal: false,
  6096. overlayClass: 'ui-widget-overlay', // to be fixed
  6097. onShow: $.jgrid.showModal,
  6098. onHide: $.jgrid.closeModal,
  6099. gbox: '',
  6100. jqm: true,
  6101. jqM: true
  6102. }, o || {});
  6103. if (o.focusField === undefined) {
  6104. o.focusField = 0;
  6105. }
  6106. if (typeof o.focusField === "number" && o.focusField >= 0) {
  6107. o.focusField = parseInt(o.focusField, 10);
  6108. } else if (typeof o.focusField === "boolean" && !o.focusField) {
  6109. o.focusField = false;
  6110. } else {
  6111. o.focusField = 0;
  6112. }
  6113. if ($.fn.jqm && o.jqm === true) {
  6114. if (o.jqM) { $(selector).attr("aria-hidden", "false").jqm(o).jqmShow(); }
  6115. else { $(selector).attr("aria-hidden", "false").jqmShow(); }
  6116. } else {
  6117. if (o.gbox !== '') {
  6118. $(".jqgrid-overlay:first", o.gbox).show();
  6119. $(selector).data("gbox", o.gbox);
  6120. }
  6121. $(selector).show().attr("aria-hidden", "false");
  6122. if (o.focusField >= 0) {
  6123. try { $(':input:visible', selector)[parseInt(o.focusField, 10)].focus(); } catch (_) { }
  6124. }
  6125. }
  6126. },
  6127. info_dialog: function (caption, content, c_b, modalopt) {
  6128. var mopt = {
  6129. width: 290,
  6130. height: 'auto',
  6131. dataheight: 'auto',
  6132. drag: true,
  6133. resize: false,
  6134. left: 250,
  6135. top: 170,
  6136. zIndex: 1000,
  6137. jqModal: true,
  6138. modal: false,
  6139. closeOnEscape: true,
  6140. align: 'center',
  6141. buttonalign: 'center',
  6142. buttons: []
  6143. // {text:'textbutt', id:"buttid", onClick : function(){...}}
  6144. // if the id is not provided we set it like info_button_+ the index in the array - i.e info_button_0,info_button_1...
  6145. };
  6146. $.extend(true, mopt, $.jgrid.jqModal || {}, { caption: "<b>" + caption + "</b>" }, modalopt || {});
  6147. var jm = mopt.jqModal, self = this,
  6148. classes = $.jgrid.styleUI[(mopt.styleUI || 'jQueryUI')].modal,
  6149. common = $.jgrid.styleUI[(mopt.styleUI || 'jQueryUI')].common;
  6150. if ($.fn.jqm && !jm) { jm = false; }
  6151. // in case there is no jqModal
  6152. var buttstr = "", i;
  6153. if (mopt.buttons.length > 0) {
  6154. for (i = 0; i < mopt.buttons.length; i++) {
  6155. if (mopt.buttons[i].id === undefined) { mopt.buttons[i].id = "info_button_" + i; }
  6156. buttstr += "<a id='" + mopt.buttons[i].id + "' class='fm-button " + common.button + "'>" + mopt.buttons[i].text + "</a>";
  6157. }
  6158. }
  6159. var dh = isNaN(mopt.dataheight) ? mopt.dataheight : mopt.dataheight + "px",
  6160. cn = "text-align:" + mopt.align + ";";
  6161. var cnt = "<div id='info_id'>";
  6162. cnt += "<div id='infocnt' style='margin:0px;padding-bottom:1em;width:100%;overflow:auto;position:relative;height:" + dh + ";" + cn + "'>" + content + "</div>";
  6163. cnt += c_b ? "<div class='" + classes.content + "' style='text-align:" + mopt.buttonalign + ";padding-bottom:0.8em;padding-top:0.5em;background-image: none;border-width: 1px 0 0 0;'><a id='closedialog' class='fm-button " + common.button + "'>" + c_b + "</a>" + buttstr + "</div>" :
  6164. buttstr !== "" ? "<div class='" + classes.content + "' style='text-align:" + mopt.buttonalign + ";padding-bottom:0.8em;padding-top:0.5em;background-image: none;border-width: 1px 0 0 0;'>" + buttstr + "</div>" : "";
  6165. cnt += "</div>";
  6166. try {
  6167. if ($("#info_dialog").attr("aria-hidden") === "false") {
  6168. $.jgrid.hideModal("#info_dialog", { jqm: jm });
  6169. }
  6170. $("#info_dialog").remove();
  6171. } catch (e) { }
  6172. $.jgrid.createModal({
  6173. themodal: 'info_dialog',
  6174. modalhead: 'info_head',
  6175. modalcontent: 'info_content',
  6176. scrollelm: 'infocnt'
  6177. },
  6178. cnt,
  6179. mopt,
  6180. '', '', true
  6181. );
  6182. // attach onclick after inserting into the dom
  6183. if (buttstr) {
  6184. $.each(mopt.buttons, function (i) {
  6185. $("#" + $.jgrid.jqID(this.id), "#info_id").bind('click', function () { mopt.buttons[i].onClick.call($("#info_dialog")); return false; });
  6186. });
  6187. }
  6188. $("#closedialog", "#info_id").click(function () {
  6189. self.hideModal("#info_dialog", {
  6190. jqm: jm,
  6191. onClose: $("#info_dialog").data("onClose") || mopt.onClose,
  6192. gb: $("#info_dialog").data("gbox") || mopt.gbox
  6193. });
  6194. return false;
  6195. });
  6196. $(".fm-button", "#info_dialog").hover(
  6197. function () { $(this).addClass(common.hover); },
  6198. function () { $(this).removeClass(common.hover); }
  6199. );
  6200. if ($.isFunction(mopt.beforeOpen)) { mopt.beforeOpen(); }
  6201. $.jgrid.viewModal("#info_dialog", {
  6202. onHide: function (h) {
  6203. h.w.hide().remove();
  6204. if (h.o) { h.o.remove(); }
  6205. },
  6206. modal: mopt.modal,
  6207. jqm: jm
  6208. });
  6209. if ($.isFunction(mopt.afterOpen)) { mopt.afterOpen(); }
  6210. try { $("#info_dialog").focus(); } catch (m) { }
  6211. },
  6212. bindEv: function (el, opt) {
  6213. var $t = this;
  6214. if ($.isFunction(opt.dataInit)) {
  6215. opt.dataInit.call($t, el, opt);
  6216. }
  6217. if (opt.dataEvents) {
  6218. $.each(opt.dataEvents, function () {
  6219. if (this.data !== undefined) {
  6220. $(el).bind(this.type, this.data, this.fn);
  6221. } else {
  6222. $(el).bind(this.type, this.fn);
  6223. }
  6224. });
  6225. }
  6226. },
  6227. // Form Functions
  6228. createEl: function (eltype, options, vl, autowidth, ajaxso) {
  6229. var elem = "", $t = this;
  6230. function setAttributes(elm, atr, exl) {
  6231. var exclude = ['dataInit', 'dataEvents', 'dataUrl', 'buildSelect', 'sopt', 'searchhidden', 'defaultValue', 'attr', 'custom_element', 'custom_value', 'oper'];
  6232. if (exl !== undefined && $.isArray(exl)) {
  6233. $.merge(exclude, exl);
  6234. }
  6235. $.each(atr, function (key, value) {
  6236. if ($.inArray(key, exclude) === -1) {
  6237. $(elm).attr(key, value);
  6238. }
  6239. });
  6240. if (!atr.hasOwnProperty('id')) {
  6241. $(elm).attr('id', $.jgrid.randId());
  6242. }
  6243. }
  6244. switch (eltype) {
  6245. case "textarea":
  6246. elem = document.createElement("textarea");
  6247. if (autowidth) {
  6248. if (!options.cols) { $(elem).css({ width: "98%" }); }
  6249. } else if (!options.cols) { options.cols = 20; }
  6250. if (!options.rows) { options.rows = 2; }
  6251. if (vl === '&nbsp;' || vl === '&#160;' || (vl.length === 1 && vl.charCodeAt(0) === 160)) { vl = ""; }
  6252. elem.value = vl;
  6253. setAttributes(elem, options);
  6254. $(elem).attr({ "role": "textbox", "multiline": "true" });
  6255. break;
  6256. case "checkbox": //what code for simple checkbox
  6257. elem = document.createElement("input");
  6258. elem.type = "checkbox";
  6259. if (!options.value) {
  6260. var vl1 = (vl + "").toLowerCase();
  6261. if (vl1.search(/(false|f|0|no|n|off|undefined)/i) < 0 && vl1 !== "") {
  6262. elem.checked = true;
  6263. elem.defaultChecked = true;
  6264. elem.value = vl;
  6265. } else {
  6266. elem.value = "on";
  6267. }
  6268. $(elem).attr("offval", "off");
  6269. } else {
  6270. var cbval = options.value.split(":");
  6271. if (vl === cbval[0]) {
  6272. elem.checked = true;
  6273. elem.defaultChecked = true;
  6274. }
  6275. elem.value = cbval[0];
  6276. $(elem).attr("offval", cbval[1]);
  6277. }
  6278. setAttributes(elem, options, ['value']);
  6279. $(elem).attr("role", "checkbox");
  6280. break;
  6281. case "select":
  6282. elem = document.createElement("select");
  6283. elem.setAttribute("role", "select");
  6284. var msl, ovm = [];
  6285. if (options.multiple === true) {
  6286. msl = true;
  6287. elem.multiple = "multiple";
  6288. $(elem).attr("aria-multiselectable", "true");
  6289. } else { msl = false; }
  6290. if (options.dataUrl != null) {
  6291. var rowid = null, postData = options.postData || ajaxso.postData;
  6292. try {
  6293. rowid = options.rowId;
  6294. } catch (e) { }
  6295. if ($t.p && $t.p.idPrefix) {
  6296. rowid = $.jgrid.stripPref($t.p.idPrefix, rowid);
  6297. }
  6298. $.ajax($.extend({
  6299. url: $.isFunction(options.dataUrl) ? options.dataUrl.call($t, rowid, vl, String(options.name)) : options.dataUrl,
  6300. type: "GET",
  6301. dataType: "html",
  6302. data: $.isFunction(postData) ? postData.call($t, rowid, vl, String(options.name)) : postData,
  6303. context: { elem: elem, options: options, vl: vl },
  6304. success: function (data) {
  6305. var ovm = [], elem = this.elem, vl = this.vl,
  6306. options = $.extend({}, this.options),
  6307. msl = options.multiple === true,
  6308. cU = options.cacheUrlData === true,
  6309. oV = '', txt,
  6310. a = $.isFunction(options.buildSelect) ? options.buildSelect.call($t, data) : data;
  6311. if (typeof a === 'string') {
  6312. a = $($.trim(a)).html();
  6313. }
  6314. if (a) {
  6315. $(elem).append(a);
  6316. setAttributes(elem, options, postData ? ['postData'] : undefined);
  6317. if (options.size === undefined) { options.size = msl ? 3 : 1; }
  6318. if (msl) {
  6319. ovm = vl.split(",");
  6320. ovm = $.map(ovm, function (n) { return $.trim(n); });
  6321. } else {
  6322. ovm[0] = $.trim(vl);
  6323. }
  6324. //$(elem).attr(options);
  6325. //setTimeout(function(){
  6326. $("option", elem).each(function (i) {
  6327. txt = $(this).text();
  6328. vl = $(this).val() || txt;
  6329. if (cU) {
  6330. oV += (i !== 0 ? ";" : "") + vl + ":" + txt;
  6331. }
  6332. //if(i===0) { this.selected = ""; }
  6333. // fix IE8/IE7 problem with selecting of the first item on multiple=true
  6334. if (i === 0 && elem.multiple) { this.selected = false; }
  6335. $(this).attr("role", "option");
  6336. if ($.inArray($.trim(txt), ovm) > -1 || $.inArray($.trim(vl), ovm) > -1) {
  6337. this.selected = "selected";
  6338. }
  6339. });
  6340. if (cU) {
  6341. if (options.oper === 'edit') {
  6342. $($t).jqGrid('setColProp', options.name, { editoptions: { buildSelect: null, dataUrl: null, value: oV } });
  6343. } else if (options.oper === 'search') {
  6344. $($t).jqGrid('setColProp', options.name, { searchoptions: { dataUrl: null, value: oV } });
  6345. } else if (options.oper === 'filter') {
  6346. if ($("#fbox_" + $t.p.id)[0].p) {
  6347. var cols = $("#fbox_" + $t.p.id)[0].p.columns, nm;
  6348. $.each(cols, function (i) {
  6349. nm = this.index || this.name;
  6350. if (options.name === nm) {
  6351. this.searchoptions.dataUrl = null;
  6352. this.searchoptions.value = oV;
  6353. return false;
  6354. }
  6355. });
  6356. }
  6357. }
  6358. }
  6359. $($t).triggerHandler("jqGridAddEditAfterSelectUrlComplete", [elem]);
  6360. //},0);
  6361. }
  6362. }
  6363. }, ajaxso || {}));
  6364. } else if (options.value) {
  6365. var i;
  6366. if (options.size === undefined) {
  6367. options.size = msl ? 3 : 1;
  6368. }
  6369. if (msl) {
  6370. ovm = vl.split(",");
  6371. ovm = $.map(ovm, function (n) { return $.trim(n); });
  6372. }
  6373. if (typeof options.value === 'function') { options.value = options.value(); }
  6374. var so, sv, ov, oSv, key, value,
  6375. sep = options.separator === undefined ? ":" : options.separator,
  6376. delim = options.delimiter === undefined ? ";" : options.delimiter;
  6377. if (typeof options.value === 'string') {
  6378. so = options.value.split(delim);
  6379. for (i = 0; i < so.length; i++) {
  6380. sv = so[i].split(sep);
  6381. if (sv.length > 2) {
  6382. sv[1] = $.map(sv, function (n, ii) { if (ii > 0) { return n; } }).join(sep);
  6383. }
  6384. ov = document.createElement("option");
  6385. ov.setAttribute("role", "option");
  6386. ov.value = sv[0]; ov.innerHTML = sv[1];
  6387. elem.appendChild(ov);
  6388. if (!msl && ($.trim(sv[0]) === $.trim(vl) || $.trim(sv[1]) === $.trim(vl))) { ov.selected = "selected"; }
  6389. if (msl && ($.inArray($.trim(sv[1]), ovm) > -1 || $.inArray($.trim(sv[0]), ovm) > -1)) { ov.selected = "selected"; }
  6390. }
  6391. } else if (Object.prototype.toString.call(options.value) === "[object Array]") {
  6392. oSv = options.value;
  6393. // array of arrays [[Key, Value], [Key, Value], ...]
  6394. for (i = 0; i < oSv.length; i++) {
  6395. if (oSv[i].length === 2) {
  6396. key = oSv[i][0];
  6397. value = oSv[i][1];
  6398. ov = document.createElement("option");
  6399. ov.setAttribute("role", "option");
  6400. ov.value = key; ov.innerHTML = value;
  6401. elem.appendChild(ov);
  6402. if (!msl && ($.trim(key) === $.trim(vl) || $.trim(value) === $.trim(vl))) { ov.selected = "selected"; }
  6403. if (msl && ($.inArray($.trim(value), ovm) > -1 || $.inArray($.trim(key), ovm) > -1)) { ov.selected = "selected"; }
  6404. }
  6405. }
  6406. } else if (typeof options.value === 'object') {
  6407. oSv = options.value;
  6408. for (key in oSv) {
  6409. if (oSv.hasOwnProperty(key)) {
  6410. ov = document.createElement("option");
  6411. ov.setAttribute("role", "option");
  6412. ov.value = key; ov.innerHTML = oSv[key];
  6413. elem.appendChild(ov);
  6414. if (!msl && ($.trim(key) === $.trim(vl) || $.trim(oSv[key]) === $.trim(vl))) { ov.selected = "selected"; }
  6415. if (msl && ($.inArray($.trim(oSv[key]), ovm) > -1 || $.inArray($.trim(key), ovm) > -1)) { ov.selected = "selected"; }
  6416. }
  6417. }
  6418. }
  6419. setAttributes(elem, options, ['value']);
  6420. }
  6421. break;
  6422. case "image":
  6423. case "file":
  6424. elem = document.createElement("input");
  6425. elem.type = eltype;
  6426. setAttributes(elem, options);
  6427. break;
  6428. case "custom":
  6429. elem = document.createElement("span");
  6430. try {
  6431. if ($.isFunction(options.custom_element)) {
  6432. var celm = options.custom_element.call($t, vl, options);
  6433. if (celm) {
  6434. celm = $(celm).addClass("customelement").attr({ id: options.id, name: options.name });
  6435. $(elem).empty().append(celm);
  6436. } else {
  6437. throw "e2";
  6438. }
  6439. } else {
  6440. throw "e1";
  6441. }
  6442. } catch (e) {
  6443. var errors = $.jgrid.getRegional($t, 'errors'),
  6444. edit = $.jgrid.getRegional($t, 'edit');
  6445. if (e === "e1") { $.jgrid.info_dialog(errors.errcap, "function 'custom_element' " + edit.msg.nodefined, edit.bClose, { styleUI: $t.p.styleUI }); }
  6446. else if (e === "e2") { $.jgrid.info_dialog(errors.errcap, "function 'custom_element' " + edit.msg.novalue, edit.bClose, { styleUI: $t.p.styleUI }); }
  6447. else { $.jgrid.info_dialog(errors.errcap, typeof e === "string" ? e : e.message, edit.bClose, { styleUI: $t.p.styleUI }); }
  6448. }
  6449. break;
  6450. default:
  6451. var role;
  6452. if (eltype === "button") { role = "button"; }
  6453. else { role = "textbox"; } // ???
  6454. elem = document.createElement("input");
  6455. elem.type = eltype;
  6456. elem.value = vl;
  6457. setAttributes(elem, options);
  6458. if (eltype !== "button") {
  6459. if (autowidth) {
  6460. if (!options.size) { $(elem).css({ width: "96%" }); }
  6461. } else if (!options.size) { options.size = 20; }
  6462. }
  6463. $(elem).attr("role", role);
  6464. }
  6465. return elem;
  6466. },
  6467. // Date Validation Javascript
  6468. checkDate: function (format, date) {
  6469. var daysInFebruary = function (year) {
  6470. // February has 29 days in any year evenly divisible by four,
  6471. // EXCEPT for centurial years which are not also divisible by 400.
  6472. return (((year % 4 === 0) && (year % 100 !== 0 || (year % 400 === 0))) ? 29 : 28);
  6473. },
  6474. tsp = {}, sep;
  6475. format = format.toLowerCase();
  6476. //we search for /,-,. for the date separator
  6477. if (format.indexOf("/") !== -1) {
  6478. sep = "/";
  6479. } else if (format.indexOf("-") !== -1) {
  6480. sep = "-";
  6481. } else if (format.indexOf(".") !== -1) {
  6482. sep = ".";
  6483. } else {
  6484. sep = "/";
  6485. }
  6486. format = format.split(sep);
  6487. date = date.split(sep);
  6488. if (date.length !== 3) { return false; }
  6489. var j = -1, yln, dln = -1, mln = -1, i;
  6490. for (i = 0; i < format.length; i++) {
  6491. var dv = isNaN(date[i]) ? 0 : parseInt(date[i], 10);
  6492. tsp[format[i]] = dv;
  6493. yln = format[i];
  6494. if (yln.indexOf("y") !== -1) { j = i; }
  6495. if (yln.indexOf("m") !== -1) { mln = i; }
  6496. if (yln.indexOf("d") !== -1) { dln = i; }
  6497. }
  6498. if (format[j] === "y" || format[j] === "yyyy") {
  6499. yln = 4;
  6500. } else if (format[j] === "yy") {
  6501. yln = 2;
  6502. } else {
  6503. yln = -1;
  6504. }
  6505. var daysInMonth = [0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
  6506. strDate;
  6507. if (j === -1) {
  6508. return false;
  6509. }
  6510. strDate = tsp[format[j]].toString();
  6511. if (yln === 2 && strDate.length === 1) { yln = 1; }
  6512. if (strDate.length !== yln || (tsp[format[j]] === 0 && date[j] !== "00")) {
  6513. return false;
  6514. }
  6515. if (mln === -1) {
  6516. return false;
  6517. }
  6518. strDate = tsp[format[mln]].toString();
  6519. if (strDate.length < 1 || tsp[format[mln]] < 1 || tsp[format[mln]] > 12) {
  6520. return false;
  6521. }
  6522. if (dln === -1) {
  6523. return false;
  6524. }
  6525. strDate = tsp[format[dln]].toString();
  6526. if (strDate.length < 1 || tsp[format[dln]] < 1 || tsp[format[dln]] > 31 || (tsp[format[mln]] === 2 && tsp[format[dln]] > daysInFebruary(tsp[format[j]])) || tsp[format[dln]] > daysInMonth[tsp[format[mln]]]) {
  6527. return false;
  6528. }
  6529. return true;
  6530. },
  6531. isEmpty: function (val) {
  6532. if (val.match(/^\s+$/) || val === "") {
  6533. return true;
  6534. }
  6535. return false;
  6536. },
  6537. checkTime: function (time) {
  6538. // checks only hh:ss (and optional am/pm)
  6539. var re = /^(\d{1,2}):(\d{2})([apAP][Mm])?$/, regs;
  6540. if (!$.jgrid.isEmpty(time)) {
  6541. regs = time.match(re);
  6542. if (regs) {
  6543. if (regs[3]) {
  6544. if (regs[1] < 1 || regs[1] > 12) { return false; }
  6545. } else {
  6546. if (regs[1] > 23) { return false; }
  6547. }
  6548. if (regs[2] > 59) {
  6549. return false;
  6550. }
  6551. } else {
  6552. return false;
  6553. }
  6554. }
  6555. return true;
  6556. },
  6557. checkValues: function (val, valref, customobject, nam) {
  6558. var edtrul, i, nm, dft, len, g = this, cm = g.p.colModel,
  6559. msg = $.jgrid.getRegional(this, 'edit.msg'), fmtdate;
  6560. if (customobject === undefined) {
  6561. if (typeof valref === 'string') {
  6562. for (i = 0, len = cm.length; i < len; i++) {
  6563. if (cm[i].name === valref) {
  6564. edtrul = cm[i].editrules;
  6565. valref = i;
  6566. if (cm[i].formoptions != null) { nm = cm[i].formoptions.label; }
  6567. break;
  6568. }
  6569. }
  6570. } else if (valref >= 0) {
  6571. edtrul = cm[valref].editrules;
  6572. }
  6573. } else {
  6574. edtrul = customobject;
  6575. nm = nam === undefined ? "_" : nam;
  6576. }
  6577. if (edtrul) {
  6578. if (!nm) { nm = g.p.colNames != null ? g.p.colNames[valref] : cm[valref].label; }
  6579. if (edtrul.required === true) {
  6580. if ($.jgrid.isEmpty(val)) { return [false, nm + ": " + msg.required, ""]; }
  6581. }
  6582. // force required
  6583. var rqfield = edtrul.required === false ? false : true;
  6584. if (edtrul.number === true) {
  6585. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6586. if (isNaN(val)) { return [false, nm + ": " + msg.number, ""]; }
  6587. }
  6588. }
  6589. if (edtrul.minValue !== undefined && !isNaN(edtrul.minValue)) {
  6590. if (parseFloat(val) < parseFloat(edtrul.minValue)) { return [false, nm + ": " + msg.minValue + " " + edtrul.minValue, ""]; }
  6591. }
  6592. if (edtrul.maxValue !== undefined && !isNaN(edtrul.maxValue)) {
  6593. if (parseFloat(val) > parseFloat(edtrul.maxValue)) { return [false, nm + ": " + msg.maxValue + " " + edtrul.maxValue, ""]; }
  6594. }
  6595. var filter;
  6596. if (edtrul.email === true) {
  6597. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6598. // taken from $ Validate plugin
  6599. filter = /^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i;
  6600. if (!filter.test(val)) { return [false, nm + ": " + msg.email, ""]; }
  6601. }
  6602. }
  6603. if (edtrul.integer === true) {
  6604. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6605. if (isNaN(val)) { return [false, nm + ": " + msg.integer, ""]; }
  6606. if ((val % 1 !== 0) || (val.indexOf('.') !== -1)) { return [false, nm + ": " + msg.integer, ""]; }
  6607. }
  6608. }
  6609. if (edtrul.date === true) {
  6610. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6611. if (cm[valref].formatoptions && cm[valref].formatoptions.newformat) {
  6612. dft = cm[valref].formatoptions.newformat;
  6613. fmtdate = $.jgrid.getRegional(g, 'formatter.date.masks');
  6614. if (fmtdate && fmtdate.hasOwnProperty(dft)) {
  6615. dft = fmtdate[dft];
  6616. }
  6617. } else {
  6618. dft = cm[valref].datefmt || "Y-m-d";
  6619. }
  6620. if (!$.jgrid.checkDate(dft, val)) { return [false, nm + ": " + msg.date + " - " + dft, ""]; }
  6621. }
  6622. }
  6623. if (edtrul.time === true) {
  6624. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6625. if (!$.jgrid.checkTime(val)) { return [false, nm + ": " + msg.date + " - hh:mm (am/pm)", ""]; }
  6626. }
  6627. }
  6628. if (edtrul.url === true) {
  6629. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6630. filter = /^(((https?)|(ftp)):\/\/([\-\w]+\.)+\w{2,3}(\/[%\-\w]+(\.\w{2,})?)*(([\w\-\.\?\\\/+@&#;`~=%!]*)(\.\w{2,})?)*\/?)/i;
  6631. if (!filter.test(val)) { return [false, nm + ": " + msg.url, ""]; }
  6632. }
  6633. }
  6634. if (edtrul.custom === true) {
  6635. if (!(rqfield === false && $.jgrid.isEmpty(val))) {
  6636. if ($.isFunction(edtrul.custom_func)) {
  6637. var ret = edtrul.custom_func.call(g, val, nm, valref);
  6638. return $.isArray(ret) ? ret : [false, msg.customarray, ""];
  6639. }
  6640. return [false, msg.customfcheck, ""];
  6641. }
  6642. }
  6643. }
  6644. return [true, "", ""];
  6645. }
  6646. });
  6647. //module begin
  6648. $.fn.jqFilter = function (arg) {
  6649. if (typeof arg === 'string') {
  6650. var fn = $.fn.jqFilter[arg];
  6651. if (!fn) {
  6652. throw ("jqFilter - No such method: " + arg);
  6653. }
  6654. var args = $.makeArray(arguments).slice(1);
  6655. return fn.apply(this, args);
  6656. }
  6657. var p = $.extend(true, {
  6658. filter: null,
  6659. columns: [],
  6660. sortStrategy: null,
  6661. onChange: null,
  6662. afterRedraw: null,
  6663. checkValues: null,
  6664. error: false,
  6665. errmsg: "",
  6666. errorcheck: true,
  6667. showQuery: true,
  6668. sopt: null,
  6669. ops: [],
  6670. operands: null,
  6671. numopts: ['eq', 'ne', 'lt', 'le', 'gt', 'ge', 'nu', 'nn', 'in', 'ni'],
  6672. stropts: ['eq', 'ne', 'bw', 'bn', 'ew', 'en', 'cn', 'nc', 'nu', 'nn', 'in', 'ni'],
  6673. strarr: ['text', 'string', 'blob'],
  6674. groupOps: [{ op: "AND", text: "AND" }, { op: "OR", text: "OR" }],
  6675. groupButton: true,
  6676. ruleButtons: true,
  6677. uniqueSearchFields: false,
  6678. direction: "ltr"
  6679. }, $.jgrid.filter, arg || {});
  6680. return this.each(function () {
  6681. if (this.filter) { return; }
  6682. this.p = p;
  6683. // setup filter in case if they is not defined
  6684. if (this.p.filter === null || this.p.filter === undefined) {
  6685. this.p.filter = {
  6686. groupOp: this.p.groupOps[0].op,
  6687. rules: [],
  6688. groups: []
  6689. };
  6690. }
  6691. // Sort the columns if the sort strategy is provided.
  6692. if (this.p.sortStrategy != null && $.isFunction(this.p.sortStrategy)) {
  6693. this.p.columns.sort(this.p.sortStrategy);
  6694. }
  6695. var i, len = this.p.columns.length, cl,
  6696. isIE = /msie/i.test(navigator.userAgent) && !window.opera;
  6697. // translating the options
  6698. this.p.initFilter = $.extend(true, {}, this.p.filter);
  6699. // set default values for the columns if they are not set
  6700. if (!len) { return; }
  6701. for (i = 0; i < len; i++) {
  6702. cl = this.p.columns[i];
  6703. if (cl.stype) {
  6704. // grid compatibility
  6705. cl.inputtype = cl.stype;
  6706. } else if (!cl.inputtype) {
  6707. cl.inputtype = 'text';
  6708. }
  6709. if (cl.sorttype) {
  6710. // grid compatibility
  6711. cl.searchtype = cl.sorttype;
  6712. } else if (!cl.searchtype) {
  6713. cl.searchtype = 'string';
  6714. }
  6715. if (cl.hidden === undefined) {
  6716. // jqGrid compatibility
  6717. cl.hidden = false;
  6718. }
  6719. if (!cl.label) {
  6720. cl.label = cl.name;
  6721. }
  6722. if (cl.index) {
  6723. cl.name = cl.index;
  6724. }
  6725. if (!cl.hasOwnProperty('searchoptions')) {
  6726. cl.searchoptions = {};
  6727. }
  6728. if (!cl.hasOwnProperty('searchrules')) {
  6729. cl.searchrules = {};
  6730. }
  6731. if (cl.search === undefined) {
  6732. cl.inlist = true;
  6733. } else {
  6734. cl.inlist = cl.search;
  6735. }
  6736. }
  6737. var getGrid = function () {
  6738. return $("#" + $.jgrid.jqID(p.id))[0] || null;
  6739. },
  6740. $tg = getGrid(),
  6741. classes = $.jgrid.styleUI[($tg.p.styleUI || 'jQueryUI')].filter,
  6742. common = $.jgrid.styleUI[($tg.p.styleUI || 'jQueryUI')].common;
  6743. if (this.p.showQuery) {
  6744. $(this).append("<table class='queryresult " + classes.table_widget + "' style='display:block;max-width:440px;border:0px none;' dir='" + this.p.direction + "'><tbody><tr><td class='query'></td></tr></tbody></table>");
  6745. }
  6746. /*
  6747. *Perform checking.
  6748. *
  6749. */
  6750. var checkData = function (val, colModelItem) {
  6751. var ret = [true, ""], $t = getGrid();
  6752. if ($.isFunction(colModelItem.searchrules)) {
  6753. ret = colModelItem.searchrules.call($t, val, colModelItem);
  6754. } else if ($.jgrid && $.jgrid.checkValues) {
  6755. try {
  6756. ret = $.jgrid.checkValues.call($t, val, -1, colModelItem.searchrules, colModelItem.label);
  6757. } catch (e) { }
  6758. }
  6759. if (ret && ret.length && ret[0] === false) {
  6760. p.error = !ret[0];
  6761. p.errmsg = ret[1];
  6762. }
  6763. };
  6764. /* moving to common
  6765. randId = function() {
  6766. return Math.floor(Math.random()*10000).toString();
  6767. };
  6768. */
  6769. this.onchange = function () {
  6770. // clear any error
  6771. this.p.error = false;
  6772. this.p.errmsg = "";
  6773. return $.isFunction(this.p.onChange) ? this.p.onChange.call(this, this.p) : false;
  6774. };
  6775. /*
  6776. * Redraw the filter every time when new field is added/deleted
  6777. * and field is changed
  6778. */
  6779. this.reDraw = function () {
  6780. $("table.group:first", this).remove();
  6781. var t = this.createTableForGroup(p.filter, null);
  6782. $(this).append(t);
  6783. if ($.isFunction(this.p.afterRedraw)) {
  6784. this.p.afterRedraw.call(this, this.p);
  6785. }
  6786. };
  6787. /*
  6788. * Creates a grouping data for the filter
  6789. * @param group - object
  6790. * @param parentgroup - object
  6791. */
  6792. this.createTableForGroup = function (group, parentgroup) {
  6793. var that = this, i;
  6794. // this table will hold all the group (tables) and rules (rows)
  6795. var table = $("<table class='group " + classes.table_widget + " ui-search-table' style='border:0px none;'><tbody></tbody></table>"),
  6796. // create error message row
  6797. align = "left";
  6798. if (this.p.direction === "rtl") {
  6799. align = "right";
  6800. table.attr("dir", "rtl");
  6801. }
  6802. if (parentgroup === null) {
  6803. table.append("<tr class='error' style='display:none;'><th colspan='5' class='" + common.error + "' align='" + align + "'></th></tr>");
  6804. }
  6805. var tr = $("<tr></tr>");
  6806. table.append(tr);
  6807. // this header will hold the group operator type and group action buttons for
  6808. // creating subgroup "+ {}", creating rule "+" or deleting the group "-"
  6809. var th = $("<th colspan='5' align='" + align + "'></th>");
  6810. tr.append(th);
  6811. if (this.p.ruleButtons === true) {
  6812. // dropdown for: choosing group operator type
  6813. var groupOpSelect = $("<select class='opsel " + classes.srSelect + "'></select>");
  6814. th.append(groupOpSelect);
  6815. // populate dropdown with all posible group operators: or, and
  6816. var str = "", selected;
  6817. for (i = 0; i < p.groupOps.length; i++) {
  6818. selected = group.groupOp === that.p.groupOps[i].op ? " selected='selected'" : "";
  6819. str += "<option value='" + that.p.groupOps[i].op + "'" + selected + ">" + that.p.groupOps[i].text + "</option>";
  6820. }
  6821. groupOpSelect
  6822. .append(str)
  6823. .bind('change', function () {
  6824. group.groupOp = $(groupOpSelect).val();
  6825. that.onchange(); // signals that the filter has changed
  6826. });
  6827. }
  6828. // button for adding a new subgroup
  6829. var inputAddSubgroup = "<span></span>";
  6830. if (this.p.groupButton) {
  6831. inputAddSubgroup = $("<input type='button' value='+ {}' title='Add subgroup' class='add-group " + common.button + "'/>");
  6832. inputAddSubgroup.bind('click', function () {
  6833. if (group.groups === undefined) {
  6834. group.groups = [];
  6835. }
  6836. group.groups.push({
  6837. groupOp: p.groupOps[0].op,
  6838. rules: [],
  6839. groups: []
  6840. }); // adding a new group
  6841. that.reDraw(); // the html has changed, force reDraw
  6842. that.onchange(); // signals that the filter has changed
  6843. return false;
  6844. });
  6845. }
  6846. th.append(inputAddSubgroup);
  6847. if (this.p.ruleButtons === true) {
  6848. // button for adding a new rule
  6849. var inputAddRule = $("<input type='button' value='+' title='Add rule' class='add-rule ui-add " + common.button + "'/>"), cm;
  6850. inputAddRule.bind('click', function () {
  6851. //if(!group) { group = {};}
  6852. if (group.rules === undefined) {
  6853. group.rules = [];
  6854. }
  6855. for (i = 0; i < that.p.columns.length; i++) {
  6856. // but show only serchable and serchhidden = true fields
  6857. var searchable = (that.p.columns[i].search === undefined) ? true : that.p.columns[i].search,
  6858. hidden = (that.p.columns[i].hidden === true),
  6859. ignoreHiding = (that.p.columns[i].searchoptions.searchhidden === true);
  6860. if ((ignoreHiding && searchable) || (searchable && !hidden)) {
  6861. cm = that.p.columns[i];
  6862. break;
  6863. }
  6864. }
  6865. if (!cm) {
  6866. return false;
  6867. }
  6868. var opr;
  6869. if (cm.searchoptions.sopt) { opr = cm.searchoptions.sopt; }
  6870. else if (that.p.sopt) { opr = that.p.sopt; }
  6871. else if ($.inArray(cm.searchtype, that.p.strarr) !== -1) { opr = that.p.stropts; }
  6872. else { opr = that.p.numopts; }
  6873. group.rules.push({
  6874. field: cm.name,
  6875. op: opr[0],
  6876. data: ""
  6877. }); // adding a new rule
  6878. that.reDraw(); // the html has changed, force reDraw
  6879. // for the moment no change have been made to the rule, so
  6880. // this will not trigger onchange event
  6881. return false;
  6882. });
  6883. th.append(inputAddRule);
  6884. }
  6885. // button for delete the group
  6886. if (parentgroup !== null) { // ignore the first group
  6887. var inputDeleteGroup = $("<input type='button' value='-' title='Delete group' class='delete-group " + common.button + "'/>");
  6888. th.append(inputDeleteGroup);
  6889. inputDeleteGroup.bind('click', function () {
  6890. // remove group from parent
  6891. for (i = 0; i < parentgroup.groups.length; i++) {
  6892. if (parentgroup.groups[i] === group) {
  6893. parentgroup.groups.splice(i, 1);
  6894. break;
  6895. }
  6896. }
  6897. that.reDraw(); // the html has changed, force reDraw
  6898. that.onchange(); // signals that the filter has changed
  6899. return false;
  6900. });
  6901. }
  6902. // append subgroup rows
  6903. if (group.groups !== undefined) {
  6904. for (i = 0; i < group.groups.length; i++) {
  6905. var trHolderForSubgroup = $("<tr></tr>");
  6906. table.append(trHolderForSubgroup);
  6907. var tdFirstHolderForSubgroup = $("<td class='first'></td>");
  6908. trHolderForSubgroup.append(tdFirstHolderForSubgroup);
  6909. var tdMainHolderForSubgroup = $("<td colspan='4'></td>");
  6910. tdMainHolderForSubgroup.append(this.createTableForGroup(group.groups[i], group));
  6911. trHolderForSubgroup.append(tdMainHolderForSubgroup);
  6912. }
  6913. }
  6914. if (group.groupOp === undefined) {
  6915. group.groupOp = that.p.groupOps[0].op;
  6916. }
  6917. // append rules rows
  6918. var suni = that.p.ruleButtons && that.p.uniqueSearchFields;
  6919. if (suni) {
  6920. for (var ii = 0; ii < that.p.columns.length; ii++) {
  6921. if (that.p.columns[ii].inlist) {
  6922. that.p.columns[ii].search = true;
  6923. }
  6924. }
  6925. }
  6926. if (group.rules !== undefined) {
  6927. for (i = 0; i < group.rules.length; i++) {
  6928. table.append(
  6929. this.createTableRowForRule(group.rules[i], group)
  6930. );
  6931. if (suni) {
  6932. var field = group.rules[i].field;
  6933. for (var ii = 0; ii < that.p.columns.length; ii++) {
  6934. if (field === that.p.columns[ii].name) {
  6935. that.p.columns[ii].search = false;
  6936. break;
  6937. }
  6938. }
  6939. }
  6940. }
  6941. }
  6942. return table;
  6943. };
  6944. /*
  6945. * Create the rule data for the filter
  6946. */
  6947. this.createTableRowForRule = function (rule, group) {
  6948. // save current entity in a variable so that it could
  6949. // be referenced in anonimous method calls
  6950. var that = this, $t = getGrid(), tr = $("<tr></tr>"),
  6951. //document.createElement("tr"),
  6952. // first column used for padding
  6953. //tdFirstHolderForRule = document.createElement("td"),
  6954. i, op, trpar, cm, str = "", selected;
  6955. //tdFirstHolderForRule.setAttribute("class", "first");
  6956. tr.append("<td class='first'></td>");
  6957. // create field container
  6958. var ruleFieldTd = $("<td class='columns'></td>");
  6959. tr.append(ruleFieldTd);
  6960. // dropdown for: choosing field
  6961. var ruleFieldSelect = $("<select class='" + classes.srSelect + "'></select>"), ina, aoprs = [];
  6962. ruleFieldTd.append(ruleFieldSelect);
  6963. ruleFieldSelect.bind('change', function () {
  6964. rule.field = $(ruleFieldSelect).val();
  6965. trpar = $(this).parents("tr:first");
  6966. $(".data", trpar).empty();
  6967. for (i = 0; i < that.p.columns.length; i++) {
  6968. if (that.p.columns[i].name === rule.field) {
  6969. cm = that.p.columns[i];
  6970. break;
  6971. }
  6972. }
  6973. if (!cm) { return; }
  6974. cm.searchoptions.id = $.jgrid.randId();
  6975. cm.searchoptions.name = rule.field;
  6976. cm.searchoptions.oper = 'filter';
  6977. if (isIE && cm.inputtype === "text") {
  6978. if (!cm.searchoptions.size) {
  6979. cm.searchoptions.size = 10;
  6980. }
  6981. }
  6982. var elm = $.jgrid.createEl.call($t, cm.inputtype, cm.searchoptions, "", true, that.p.ajaxSelectOptions || {}, true);
  6983. $(elm).addClass("input-elm " + classes.srInput);
  6984. //that.createElement(rule, "");
  6985. if (cm.searchoptions.sopt) { op = cm.searchoptions.sopt; }
  6986. else if (that.p.sopt) { op = that.p.sopt; }
  6987. else if ($.inArray(cm.searchtype, that.p.strarr) !== -1) { op = that.p.stropts; }
  6988. else { op = that.p.numopts; }
  6989. // operators
  6990. var s = "", so = 0;
  6991. aoprs = [];
  6992. $.each(that.p.ops, function () { aoprs.push(this.oper); });
  6993. for (i = 0 ; i < op.length; i++) {
  6994. ina = $.inArray(op[i], aoprs);
  6995. if (ina !== -1) {
  6996. if (so === 0) {
  6997. rule.op = that.p.ops[ina].oper;
  6998. }
  6999. s += "<option value='" + that.p.ops[ina].oper + "'>" + that.p.ops[ina].text + "</option>";
  7000. so++;
  7001. }
  7002. }
  7003. $(".selectopts", trpar).empty().append(s);
  7004. $(".selectopts", trpar)[0].selectedIndex = 0;
  7005. if ($.jgrid.msie && $.jgrid.msiever() < 9) {
  7006. var sw = parseInt($("select.selectopts", trpar)[0].offsetWidth, 10) + 1;
  7007. $(".selectopts", trpar).width(sw);
  7008. $(".selectopts", trpar).css("width", "auto");
  7009. }
  7010. // data
  7011. $(".data", trpar).append(elm);
  7012. $.jgrid.bindEv.call($t, elm, cm.searchoptions);
  7013. $(".input-elm", trpar).bind('change', function (e) {
  7014. var elem = e.target;
  7015. rule.data = elem.nodeName.toUpperCase() === "SPAN" && cm.searchoptions && $.isFunction(cm.searchoptions.custom_value) ?
  7016. cm.searchoptions.custom_value.call($t, $(elem).children(".customelement:first"), 'get') : elem.value;
  7017. that.onchange(); // signals that the filter has changed
  7018. });
  7019. setTimeout(function () { //IE, Opera, Chrome
  7020. rule.data = $(elm).val();
  7021. that.onchange(); // signals that the filter has changed
  7022. }, 0);
  7023. });
  7024. // populate drop down with user provided column definitions
  7025. var j = 0;
  7026. for (i = 0; i < that.p.columns.length; i++) {
  7027. // but show only serchable and serchhidden = true fields
  7028. var searchable = (that.p.columns[i].search === undefined) ? true : that.p.columns[i].search,
  7029. hidden = (that.p.columns[i].hidden === true),
  7030. ignoreHiding = (that.p.columns[i].searchoptions.searchhidden === true);
  7031. if ((ignoreHiding && searchable) || (searchable && !hidden)) {
  7032. selected = "";
  7033. if (rule.field === that.p.columns[i].name) {
  7034. selected = " selected='selected'";
  7035. j = i;
  7036. }
  7037. str += "<option value='" + that.p.columns[i].name + "'" + selected + ">" + that.p.columns[i].label + "</option>";
  7038. }
  7039. }
  7040. ruleFieldSelect.append(str);
  7041. // create operator container
  7042. var ruleOperatorTd = $("<td class='operators'></td>");
  7043. tr.append(ruleOperatorTd);
  7044. cm = p.columns[j];
  7045. // create it here so it can be referentiated in the onchange event
  7046. //var RD = that.createElement(rule, rule.data);
  7047. cm.searchoptions.id = $.jgrid.randId();
  7048. if (isIE && cm.inputtype === "text") {
  7049. if (!cm.searchoptions.size) {
  7050. cm.searchoptions.size = 10;
  7051. }
  7052. }
  7053. cm.searchoptions.name = rule.field;
  7054. cm.searchoptions.oper = 'filter';
  7055. var ruleDataInput = $.jgrid.createEl.call($t, cm.inputtype, cm.searchoptions, rule.data, true, that.p.ajaxSelectOptions || {}, true);
  7056. if (rule.op === 'nu' || rule.op === 'nn') {
  7057. $(ruleDataInput).attr('readonly', 'true');
  7058. $(ruleDataInput).attr('disabled', 'true');
  7059. } //retain the state of disabled text fields in case of null ops
  7060. // dropdown for: choosing operator
  7061. var ruleOperatorSelect = $("<select class='selectopts " + classes.srSelect + "'></select>");
  7062. ruleOperatorTd.append(ruleOperatorSelect);
  7063. ruleOperatorSelect.bind('change', function () {
  7064. rule.op = $(ruleOperatorSelect).val();
  7065. trpar = $(this).parents("tr:first");
  7066. var rd = $(".input-elm", trpar)[0];
  7067. if (rule.op === "nu" || rule.op === "nn") { // disable for operator "is null" and "is not null"
  7068. rule.data = "";
  7069. if (rd.tagName.toUpperCase() !== 'SELECT') { rd.value = ""; }
  7070. rd.setAttribute("readonly", "true");
  7071. rd.setAttribute("disabled", "true");
  7072. } else {
  7073. if (rd.tagName.toUpperCase() === 'SELECT') { rule.data = rd.value; }
  7074. rd.removeAttribute("readonly");
  7075. rd.removeAttribute("disabled");
  7076. }
  7077. that.onchange(); // signals that the filter has changed
  7078. });
  7079. // populate drop down with all available operators
  7080. if (cm.searchoptions.sopt) { op = cm.searchoptions.sopt; }
  7081. else if (that.p.sopt) { op = that.p.sopt; }
  7082. else if ($.inArray(cm.searchtype, that.p.strarr) !== -1) { op = that.p.stropts; }
  7083. else { op = that.p.numopts; }
  7084. str = "";
  7085. $.each(that.p.ops, function () { aoprs.push(this.oper); });
  7086. for (i = 0; i < op.length; i++) {
  7087. ina = $.inArray(op[i], aoprs);
  7088. if (ina !== -1) {
  7089. selected = rule.op === that.p.ops[ina].oper ? " selected='selected'" : "";
  7090. str += "<option value='" + that.p.ops[ina].oper + "'" + selected + ">" + that.p.ops[ina].text + "</option>";
  7091. }
  7092. }
  7093. ruleOperatorSelect.append(str);
  7094. // create data container
  7095. var ruleDataTd = $("<td class='data'></td>");
  7096. tr.append(ruleDataTd);
  7097. // textbox for: data
  7098. // is created previously
  7099. //ruleDataInput.setAttribute("type", "text");
  7100. ruleDataTd.append(ruleDataInput);
  7101. $.jgrid.bindEv.call($t, ruleDataInput, cm.searchoptions);
  7102. $(ruleDataInput)
  7103. .addClass("input-elm " + classes.srInput)
  7104. .bind('change', function () {
  7105. rule.data = cm.inputtype === 'custom' ? cm.searchoptions.custom_value.call($t, $(this).children(".customelement:first"), 'get') : $(this).val();
  7106. that.onchange(); // signals that the filter has changed
  7107. });
  7108. // create action container
  7109. var ruleDeleteTd = $("<td></td>");
  7110. tr.append(ruleDeleteTd);
  7111. // create button for: delete rule
  7112. if (this.p.ruleButtons === true) {
  7113. var ruleDeleteInput = $("<input type='button' value='-' title='Delete rule' class='delete-rule ui-del " + common.button + "'/>");
  7114. ruleDeleteTd.append(ruleDeleteInput);
  7115. //$(ruleDeleteInput).html("").height(20).width(30).button({icons: { primary: "ui-icon-minus", text:false}});
  7116. ruleDeleteInput.bind('click', function () {
  7117. // remove rule from group
  7118. for (i = 0; i < group.rules.length; i++) {
  7119. if (group.rules[i] === rule) {
  7120. group.rules.splice(i, 1);
  7121. break;
  7122. }
  7123. }
  7124. that.reDraw(); // the html has changed, force reDraw
  7125. that.onchange(); // signals that the filter has changed
  7126. return false;
  7127. });
  7128. }
  7129. return tr;
  7130. };
  7131. this.getStringForGroup = function (group) {
  7132. var s = "(", index;
  7133. if (group.groups !== undefined) {
  7134. for (index = 0; index < group.groups.length; index++) {
  7135. if (s.length > 1) {
  7136. s += " " + group.groupOp + " ";
  7137. }
  7138. try {
  7139. s += this.getStringForGroup(group.groups[index]);
  7140. } catch (eg) { alert(eg); }
  7141. }
  7142. }
  7143. if (group.rules !== undefined) {
  7144. try {
  7145. for (index = 0; index < group.rules.length; index++) {
  7146. if (s.length > 1) {
  7147. s += " " + group.groupOp + " ";
  7148. }
  7149. s += this.getStringForRule(group.rules[index]);
  7150. }
  7151. } catch (e) { alert(e); }
  7152. }
  7153. s += ")";
  7154. if (s === "()") {
  7155. return ""; // ignore groups that don't have rules
  7156. }
  7157. return s;
  7158. };
  7159. this.getStringForRule = function (rule) {
  7160. var opUF = "", opC = "", i, cm, ret, val,
  7161. numtypes = ['int', 'integer', 'float', 'number', 'currency']; // jqGrid
  7162. for (i = 0; i < this.p.ops.length; i++) {
  7163. if (this.p.ops[i].oper === rule.op) {
  7164. opUF = this.p.operands.hasOwnProperty(rule.op) ? this.p.operands[rule.op] : "";
  7165. opC = this.p.ops[i].oper;
  7166. break;
  7167. }
  7168. }
  7169. for (i = 0; i < this.p.columns.length; i++) {
  7170. if (this.p.columns[i].name === rule.field) {
  7171. cm = this.p.columns[i];
  7172. break;
  7173. }
  7174. }
  7175. if (cm === undefined) { return ""; }
  7176. val = rule.data;
  7177. if (opC === 'bw' || opC === 'bn') { val = val + "%"; }
  7178. if (opC === 'ew' || opC === 'en') { val = "%" + val; }
  7179. if (opC === 'cn' || opC === 'nc') { val = "%" + val + "%"; }
  7180. if (opC === 'in' || opC === 'ni') { val = " (" + val + ")"; }
  7181. if (p.errorcheck) { checkData(rule.data, cm); }
  7182. if ($.inArray(cm.searchtype, numtypes) !== -1 || opC === 'nn' || opC === 'nu') { ret = rule.field + " " + opUF + " " + val; }
  7183. else { ret = rule.field + " " + opUF + " \"" + val + "\""; }
  7184. return ret;
  7185. };
  7186. this.resetFilter = function () {
  7187. this.p.filter = $.extend(true, {}, this.p.initFilter);
  7188. this.reDraw();
  7189. this.onchange();
  7190. };
  7191. this.hideError = function () {
  7192. $("th." + common.error, this).html("");
  7193. $("tr.error", this).hide();
  7194. };
  7195. this.showError = function () {
  7196. $("th." + common.error, this).html(this.p.errmsg);
  7197. $("tr.error", this).show();
  7198. };
  7199. this.toUserFriendlyString = function () {
  7200. return this.getStringForGroup(p.filter);
  7201. };
  7202. this.toString = function () {
  7203. // this will obtain a string that can be used to match an item.
  7204. var that = this;
  7205. function getStringRule(rule) {
  7206. if (that.p.errorcheck) {
  7207. var i, cm;
  7208. for (i = 0; i < that.p.columns.length; i++) {
  7209. if (that.p.columns[i].name === rule.field) {
  7210. cm = that.p.columns[i];
  7211. break;
  7212. }
  7213. }
  7214. if (cm) { checkData(rule.data, cm); }
  7215. }
  7216. return rule.op + "(item." + rule.field + ",'" + rule.data + "')";
  7217. }
  7218. function getStringForGroup(group) {
  7219. var s = "(", index;
  7220. if (group.groups !== undefined) {
  7221. for (index = 0; index < group.groups.length; index++) {
  7222. if (s.length > 1) {
  7223. if (group.groupOp === "OR") {
  7224. s += " || ";
  7225. }
  7226. else {
  7227. s += " && ";
  7228. }
  7229. }
  7230. s += getStringForGroup(group.groups[index]);
  7231. }
  7232. }
  7233. if (group.rules !== undefined) {
  7234. for (index = 0; index < group.rules.length; index++) {
  7235. if (s.length > 1) {
  7236. if (group.groupOp === "OR") {
  7237. s += " || ";
  7238. }
  7239. else {
  7240. s += " && ";
  7241. }
  7242. }
  7243. s += getStringRule(group.rules[index]);
  7244. }
  7245. }
  7246. s += ")";
  7247. if (s === "()") {
  7248. return ""; // ignore groups that don't have rules
  7249. }
  7250. return s;
  7251. }
  7252. return getStringForGroup(this.p.filter);
  7253. };
  7254. // Here we init the filter
  7255. this.reDraw();
  7256. if (this.p.showQuery) {
  7257. this.onchange();
  7258. }
  7259. // mark is as created so that it will not be created twice on this element
  7260. this.filter = true;
  7261. });
  7262. };
  7263. $.extend($.fn.jqFilter, {
  7264. /*
  7265. * Return SQL like string. Can be used directly
  7266. */
  7267. toSQLString: function () {
  7268. var s = "";
  7269. this.each(function () {
  7270. s = this.toUserFriendlyString();
  7271. });
  7272. return s;
  7273. },
  7274. /*
  7275. * Return filter data as object.
  7276. */
  7277. filterData: function () {
  7278. var s;
  7279. this.each(function () {
  7280. s = this.p.filter;
  7281. });
  7282. return s;
  7283. },
  7284. getParameter: function (param) {
  7285. if (param !== undefined) {
  7286. if (this.p.hasOwnProperty(param)) {
  7287. return this.p[param];
  7288. }
  7289. }
  7290. return this.p;
  7291. },
  7292. resetFilter: function () {
  7293. return this.each(function () {
  7294. this.resetFilter();
  7295. });
  7296. },
  7297. addFilter: function (pfilter) {
  7298. if (typeof pfilter === "string") {
  7299. pfilter = $.jgrid.parse(pfilter);
  7300. }
  7301. this.each(function () {
  7302. this.p.filter = pfilter;
  7303. this.reDraw();
  7304. this.onchange();
  7305. });
  7306. }
  7307. });
  7308. $.jgrid.extend({
  7309. filterToolbar: function (p) {
  7310. var regional = $.jgrid.getRegional(this[0], 'search');
  7311. p = $.extend({
  7312. autosearch: true,
  7313. autosearchDelay: 500,
  7314. searchOnEnter: true,
  7315. beforeSearch: null,
  7316. afterSearch: null,
  7317. beforeClear: null,
  7318. afterClear: null,
  7319. onClearSearchValue: null,
  7320. searchurl: '',
  7321. stringResult: false,
  7322. groupOp: 'AND',
  7323. defaultSearch: "bw",
  7324. searchOperators: false,
  7325. resetIcon: "x",
  7326. splitSelect: ",",
  7327. groupOpSelect: "OR",
  7328. operands: { "eq": "==", "ne": "!", "lt": "<", "le": "<=", "gt": ">", "ge": ">=", "bw": "^", "bn": "!^", "in": "=", "ni": "!=", "ew": "|", "en": "!@", "cn": "~", "nc": "!~", "nu": "#", "nn": "!#", "bt": "..." }
  7329. }, regional, p || {});
  7330. return this.each(function () {
  7331. var $t = this;
  7332. if ($t.p.filterToolbar) { return; }
  7333. if (!$($t).data('filterToolbar')) {
  7334. $($t).data('filterToolbar', p);
  7335. }
  7336. if ($t.p.force_regional) {
  7337. p = $.extend(p, regional);
  7338. }
  7339. var classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].filter,
  7340. common = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].common,
  7341. base = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].base,
  7342. triggerToolbar = function () {
  7343. var sdata = {}, j = 0, v, nm, sopt = {}, so, ms = false, ssfield = [], bbt = false, sop;
  7344. $.each($t.p.colModel, function () {
  7345. var $elem = $("#gs_" + $t.p.idPrefix + $.jgrid.jqID(this.name), (this.frozen === true && $t.p.frozenColumns === true) ? $t.grid.fhDiv : $t.grid.hDiv);
  7346. nm = this.index || this.name;
  7347. sop = this.searchoptions || {};
  7348. if (p.searchOperators && sop.searchOperMenu) {
  7349. so = $elem.parent().prev().children("a").attr("soper") || p.defaultSearch;
  7350. } else {
  7351. so = (sop.sopt) ? sop.sopt[0] : this.stype === 'select' ? 'eq' : p.defaultSearch;
  7352. }
  7353. v = this.stype === "custom" && $.isFunction(sop.custom_value) && $elem.length > 0 && $elem[0].nodeName.toUpperCase() === "SPAN" ?
  7354. sop.custom_value.call($t, $elem.children(".customelement:first"), "get") :
  7355. $elem.val();
  7356. // detect multiselect
  7357. if (this.stype === 'select' && sop.multiple && $.isArray(v) && v.length) {
  7358. ms = true;
  7359. ssfield.push(nm);
  7360. v = v.length === 1 ? v[0] : v;
  7361. }
  7362. if (so === "bt") {
  7363. bbt = true;
  7364. }
  7365. if (v || so === "nu" || so === "nn") {
  7366. sdata[nm] = v;
  7367. sopt[nm] = so;
  7368. j++;
  7369. } else {
  7370. try {
  7371. delete $t.p.postData[nm];
  7372. } catch (z) { }
  7373. }
  7374. });
  7375. var sd = j > 0 ? true : false;
  7376. if (p.stringResult === true || $t.p.datatype === "local" || p.searchOperators === true) {
  7377. var ruleGroup = "{\"groupOp\":\"" + p.groupOp + "\",\"rules\":[";
  7378. var gi = 0;
  7379. $.each(sdata, function (i, n) {
  7380. if (gi > 0) { ruleGroup += ","; }
  7381. ruleGroup += "{\"field\":\"" + i + "\",";
  7382. ruleGroup += "\"op\":\"" + sopt[i] + "\",";
  7383. n += "";
  7384. ruleGroup += "\"data\":\"" + n.replace(/\\/g, '\\\\').replace(/\"/g, '\\"') + "\"}";
  7385. gi++;
  7386. });
  7387. ruleGroup += "]}";
  7388. // multiselect
  7389. var filters, rules, k, str, rule, ssdata, group;
  7390. if (ms) {
  7391. filters = $.jgrid.parse(ruleGroup);//, rules, k,str, rule, ssdata, group;
  7392. if (filters.rules && filters.rules.length) {
  7393. rules = filters.rules;
  7394. for (k = 0; k < rules.length; k++) {
  7395. rule = rules[k];
  7396. if ($.inArray(rule.filed, ssfield)) {
  7397. ssdata = rule.data.split(p.splitSelect);
  7398. if (ssdata.length > 1) {
  7399. if (filters.groups === undefined) {
  7400. filters.groups = [];
  7401. }
  7402. group = { groupOp: p.groupOpSelect, groups: [], rules: [] };
  7403. filters.groups.push(group);
  7404. $.each(ssdata, function (l) {
  7405. str = ssdata[l];
  7406. if (str) {
  7407. group.rules.push({ data: ssdata[l], op: rule.op, field: rule.field });
  7408. }
  7409. });
  7410. rules.splice(k, 1);
  7411. k--;
  7412. }
  7413. }
  7414. }
  7415. }
  7416. //ruleGroup = JSON.stringify( filters );
  7417. }
  7418. if (bbt) {
  7419. if (!$.isPlainObject(filters)) {
  7420. filters = $.jgrid.parse(ruleGroup);
  7421. }
  7422. if (filters.rules && filters.rules.length) {
  7423. rules = filters.rules;
  7424. for (k = 0; k < rules.length; k++) {
  7425. rule = rules[k];
  7426. if (rule.op === "bt") {
  7427. ssdata = rule.data.split("...");
  7428. if (ssdata.length > 1) {
  7429. if (filters.groups === undefined) {
  7430. filters.groups = [];
  7431. }
  7432. group = { groupOp: 'AND', groups: [], rules: [] };
  7433. filters.groups.push(group);
  7434. $.each(ssdata, function (l) {
  7435. var btop = l === 0 ? 'ge' : 'le';
  7436. str = ssdata[l];
  7437. if (str) {
  7438. group.rules.push({ data: ssdata[l], op: btop, field: rule.field });
  7439. }
  7440. });
  7441. rules.splice(k, 1);
  7442. k--;
  7443. }
  7444. }
  7445. }
  7446. }
  7447. }
  7448. if (bbt || ms) {
  7449. ruleGroup = JSON.stringify(filters);
  7450. }
  7451. $.extend($t.p.postData, { filters: ruleGroup });
  7452. $.each(['searchField', 'searchString', 'searchOper'], function (i, n) {
  7453. if ($t.p.postData.hasOwnProperty(n)) { delete $t.p.postData[n]; }
  7454. });
  7455. } else {
  7456. $.extend($t.p.postData, sdata);
  7457. }
  7458. var saveurl;
  7459. if ($t.p.searchurl) {
  7460. saveurl = $t.p.url;
  7461. $($t).jqGrid("setGridParam", { url: $t.p.searchurl });
  7462. }
  7463. var bsr = $($t).triggerHandler("jqGridToolbarBeforeSearch") === 'stop' ? true : false;
  7464. if (!bsr && $.isFunction(p.beforeSearch)) { bsr = p.beforeSearch.call($t); }
  7465. if (!bsr) { $($t).jqGrid("setGridParam", { search: sd }).trigger("reloadGrid", [{ page: 1 }]); }
  7466. if (saveurl) { $($t).jqGrid("setGridParam", { url: saveurl }); }
  7467. $($t).triggerHandler("jqGridToolbarAfterSearch");
  7468. if ($.isFunction(p.afterSearch)) { p.afterSearch.call($t); }
  7469. },
  7470. clearToolbar = function (trigger) {
  7471. var sdata = {}, j = 0, nm;
  7472. trigger = (typeof trigger !== 'boolean') ? true : trigger;
  7473. $.each($t.p.colModel, function () {
  7474. var v, $elem = $("#gs_" + $t.p.idPrefix + $.jgrid.jqID(this.name), (this.frozen === true && $t.p.frozenColumns === true) ? $t.grid.fhDiv : $t.grid.hDiv);
  7475. if (this.searchoptions && this.searchoptions.defaultValue !== undefined) {
  7476. v = this.searchoptions.defaultValue;
  7477. }
  7478. nm = this.index || this.name;
  7479. switch (this.stype) {
  7480. case 'select':
  7481. $elem.find("option").each(function (i) {
  7482. if (i === 0) { this.selected = true; }
  7483. if ($(this).val() === v) {
  7484. this.selected = true;
  7485. return false;
  7486. }
  7487. });
  7488. if (v !== undefined) {
  7489. // post the key and not the text
  7490. sdata[nm] = v;
  7491. j++;
  7492. } else {
  7493. try {
  7494. delete $t.p.postData[nm];
  7495. } catch (e) { }
  7496. }
  7497. break;
  7498. case 'text':
  7499. $elem.val(v || "");
  7500. if (v !== undefined) {
  7501. sdata[nm] = v;
  7502. j++;
  7503. } else {
  7504. try {
  7505. delete $t.p.postData[nm];
  7506. } catch (y) { }
  7507. }
  7508. break;
  7509. case 'custom':
  7510. if ($.isFunction(this.searchoptions.custom_value) && $elem.length > 0 && $elem[0].nodeName.toUpperCase() === "SPAN") {
  7511. this.searchoptions.custom_value.call($t, $elem.children(".customelement:first"), "set", v || "");
  7512. }
  7513. break;
  7514. }
  7515. });
  7516. var sd = j > 0 ? true : false;
  7517. $t.p.resetsearch = true;
  7518. if (p.stringResult === true || $t.p.datatype === "local") {
  7519. var ruleGroup = "{\"groupOp\":\"" + p.groupOp + "\",\"rules\":[";
  7520. var gi = 0;
  7521. $.each(sdata, function (i, n) {
  7522. if (gi > 0) { ruleGroup += ","; }
  7523. ruleGroup += "{\"field\":\"" + i + "\",";
  7524. ruleGroup += "\"op\":\"" + "eq" + "\",";
  7525. n += "";
  7526. ruleGroup += "\"data\":\"" + n.replace(/\\/g, '\\\\').replace(/\"/g, '\\"') + "\"}";
  7527. gi++;
  7528. });
  7529. ruleGroup += "]}";
  7530. $.extend($t.p.postData, { filters: ruleGroup });
  7531. $.each(['searchField', 'searchString', 'searchOper'], function (i, n) {
  7532. if ($t.p.postData.hasOwnProperty(n)) { delete $t.p.postData[n]; }
  7533. });
  7534. } else {
  7535. $.extend($t.p.postData, sdata);
  7536. }
  7537. var saveurl;
  7538. if ($t.p.searchurl) {
  7539. saveurl = $t.p.url;
  7540. $($t).jqGrid("setGridParam", { url: $t.p.searchurl });
  7541. }
  7542. var bcv = $($t).triggerHandler("jqGridToolbarBeforeClear") === 'stop' ? true : false;
  7543. if (!bcv && $.isFunction(p.beforeClear)) { bcv = p.beforeClear.call($t); }
  7544. if (!bcv) {
  7545. if (trigger) {
  7546. $($t).jqGrid("setGridParam", { search: sd }).trigger("reloadGrid", [{ page: 1 }]);
  7547. }
  7548. }
  7549. if (saveurl) { $($t).jqGrid("setGridParam", { url: saveurl }); }
  7550. $($t).triggerHandler("jqGridToolbarAfterClear");
  7551. if ($.isFunction(p.afterClear)) { p.afterClear(); }
  7552. },
  7553. toggleToolbar = function () {
  7554. var trow = $("tr.ui-search-toolbar", $t.grid.hDiv),
  7555. trow2 = $t.p.frozenColumns === true ? $("tr.ui-search-toolbar", $t.grid.fhDiv) : false;
  7556. if (trow.css("display") === 'none') {
  7557. trow.show();
  7558. if (trow2) {
  7559. trow2.show();
  7560. }
  7561. } else {
  7562. trow.hide();
  7563. if (trow2) {
  7564. trow2.hide();
  7565. }
  7566. }
  7567. },
  7568. buildRuleMenu = function (elem, left, top) {
  7569. $("#sopt_menu").remove();
  7570. left = parseInt(left, 10);
  7571. top = parseInt(top, 10) + 18;
  7572. var fs = $('.ui-jqgrid-view').css('font-size') || '11px';
  7573. var str = '<ul id="sopt_menu" class="ui-search-menu modal-content" role="menu" tabindex="0" style="font-size:' + fs + ';left:' + left + 'px;top:' + top + 'px;">',
  7574. selected = $(elem).attr("soper"), selclass,
  7575. aoprs = [], ina;
  7576. var i = 0, nm = $(elem).attr("colname"), len = $t.p.colModel.length;
  7577. while (i < len) {
  7578. if ($t.p.colModel[i].name === nm) {
  7579. break;
  7580. }
  7581. i++;
  7582. }
  7583. var cm = $t.p.colModel[i], options = $.extend({}, cm.searchoptions);
  7584. if (!options.sopt) {
  7585. options.sopt = [];
  7586. options.sopt[0] = cm.stype === 'select' ? 'eq' : p.defaultSearch;
  7587. }
  7588. $.each(p.odata, function () { aoprs.push(this.oper); });
  7589. for (i = 0 ; i < options.sopt.length; i++) {
  7590. ina = $.inArray(options.sopt[i], aoprs);
  7591. if (ina !== -1) {
  7592. selclass = selected === p.odata[ina].oper ? common.highlight : "";
  7593. str += '<li class="ui-menu-item ' + selclass + '" role="presentation"><a class="' + common.cornerall + ' g-menu-item" tabindex="0" role="menuitem" value="' + p.odata[ina].oper + '" oper="' + p.operands[p.odata[ina].oper] + '"><table class="ui-common-table"><tr><td width="25px">' + p.operands[p.odata[ina].oper] + '</td><td>' + p.odata[ina].text + '</td></tr></table></a></li>';
  7594. }
  7595. }
  7596. str += "</ul>";
  7597. $('body').append(str);
  7598. $("#sopt_menu").addClass("ui-menu " + classes.menu_widget);
  7599. $("#sopt_menu > li > a").hover(
  7600. function () { $(this).addClass(common.hover); },
  7601. function () { $(this).removeClass(common.hover); }
  7602. ).click(function () {
  7603. var v = $(this).attr("value"),
  7604. oper = $(this).attr("oper");
  7605. $($t).triggerHandler("jqGridToolbarSelectOper", [v, oper, elem]);
  7606. $("#sopt_menu").hide();
  7607. $(elem).text(oper).attr("soper", v);
  7608. if (p.autosearch === true) {
  7609. var inpelm = $(elem).parent().next().children()[0];
  7610. if ($(inpelm).val() || v === "nu" || v === "nn") {
  7611. triggerToolbar();
  7612. }
  7613. }
  7614. });
  7615. };
  7616. // create the row
  7617. var tr = $("<tr class='ui-search-toolbar' role='row'></tr>"),
  7618. timeoutHnd, rules, filterobj;
  7619. if (p.restoreFromFilters) {
  7620. filterobj = $t.p.postData.filters;
  7621. if (filterobj) {
  7622. if (typeof filterobj === "string") {
  7623. filterobj = $.jgrid.parse(filterobj);
  7624. }
  7625. rules = filterobj.rules.length ? filterobj.rules : false;
  7626. }
  7627. }
  7628. $.each($t.p.colModel, function (ci) {
  7629. var cm = this, soptions, select = "", sot = "=", so, i, st, csv, df, elem, restores,
  7630. th = $("<th role='columnheader' class='" + base.headerBox + " ui-th-" + $t.p.direction + "' id='gsh_" + $t.p.id + "_" + cm.name + "' ></th>"),
  7631. thd = $("<div></div>"),
  7632. stbl = $("<table class='ui-search-table' cellspacing='0'><tr><td class='ui-search-oper' headers=''></td><td class='ui-search-input' headers=''></td><td class='ui-search-clear' headers=''></td></tr></table>");
  7633. if (this.hidden === true) { $(th).css("display", "none"); }
  7634. this.search = this.search === false ? false : true;
  7635. if (this.stype === undefined) { this.stype = 'text'; }
  7636. this.searchoptions = this.searchoptions || {};
  7637. if (this.searchoptions.searchOperMenu === undefined) {
  7638. this.searchoptions.searchOperMenu = true;
  7639. }
  7640. soptions = $.extend({}, this.searchoptions, { name: cm.index || cm.name, id: "gs_" + $t.p.idPrefix + cm.name, oper: 'search' });
  7641. if (this.search) {
  7642. if (p.restoreFromFilters && rules) {
  7643. restores = false;
  7644. for (var is = 0; is < rules.length; is++) {
  7645. if (rules[is].field) {
  7646. var snm = cm.index || cm.name;
  7647. if (snm === rules[is].field) {
  7648. restores = rules[is];
  7649. break;
  7650. }
  7651. }
  7652. }
  7653. }
  7654. if (p.searchOperators) {
  7655. so = (soptions.sopt) ? soptions.sopt[0] : cm.stype === 'select' ? 'eq' : p.defaultSearch;
  7656. // overwrite search operators
  7657. if (p.restoreFromFilters && restores) {
  7658. so = restores.op;
  7659. }
  7660. for (i = 0; i < p.odata.length; i++) {
  7661. if (p.odata[i].oper === so) {
  7662. sot = p.operands[so] || "";
  7663. break;
  7664. }
  7665. }
  7666. st = soptions.searchtitle != null ? soptions.searchtitle : p.operandTitle;
  7667. select = this.searchoptions.searchOperMenu ? "<a title='" + st + "' style='padding-right: 0.5em;' soper='" + so + "' class='soptclass' colname='" + this.name + "'>" + sot + "</a>" : "";
  7668. }
  7669. $("td:eq(0)", stbl).attr("colindex", ci).append(select);
  7670. if (soptions.clearSearch === undefined) {
  7671. soptions.clearSearch = true;
  7672. }
  7673. if (soptions.clearSearch) {
  7674. csv = p.resetTitle || 'Clear Search Value';
  7675. $("td:eq(2)", stbl).append("<a title='" + csv + "' style='padding-right: 0.3em;padding-left: 0.3em;' class='clearsearchclass'>" + p.resetIcon + "</a>");
  7676. } else {
  7677. $("td:eq(2)", stbl).hide();
  7678. }
  7679. if (this.surl) {
  7680. soptions.dataUrl = this.surl;
  7681. }
  7682. df = "";
  7683. if (soptions.defaultValue) {
  7684. df = $.isFunction(soptions.defaultValue) ? soptions.defaultValue.call($t) : soptions.defaultValue;
  7685. }
  7686. //overwrite default value if restore from filters
  7687. if (p.restoreFromFilters && restores) {
  7688. df = restores.data;
  7689. }
  7690. elem = $.jgrid.createEl.call($t, this.stype, soptions, df, false, $.extend({}, $.jgrid.ajaxOptions, $t.p.ajaxSelectOptions || {}));
  7691. $(elem).addClass(classes.srInput);
  7692. $("td:eq(1)", stbl).append(elem);
  7693. $(thd).append(stbl);
  7694. if (soptions.dataEvents == null) {
  7695. soptions.dataEvents = [];
  7696. }
  7697. switch (this.stype) {
  7698. case "select":
  7699. if (p.autosearch === true) {
  7700. soptions.dataEvents.push({
  7701. type: "change",
  7702. fn: function () {
  7703. triggerToolbar();
  7704. return false;
  7705. }
  7706. });
  7707. }
  7708. break;
  7709. case "text":
  7710. if (p.autosearch === true) {
  7711. if (p.searchOnEnter) {
  7712. soptions.dataEvents.push({
  7713. type: "keypress",
  7714. fn: function (e) {
  7715. var key = e.charCode || e.keyCode || 0;
  7716. if (key === 13) {
  7717. triggerToolbar();
  7718. return false;
  7719. }
  7720. return this;
  7721. }
  7722. });
  7723. } else {
  7724. soptions.dataEvents.push({
  7725. type: "keydown",
  7726. fn: function (e) {
  7727. var key = e.which;
  7728. switch (key) {
  7729. case 13:
  7730. return false;
  7731. case 9:
  7732. case 16:
  7733. case 37:
  7734. case 38:
  7735. case 39:
  7736. case 40:
  7737. case 27:
  7738. break;
  7739. default:
  7740. if (timeoutHnd) { clearTimeout(timeoutHnd); }
  7741. timeoutHnd = setTimeout(function () { triggerToolbar(); }, p.autosearchDelay);
  7742. }
  7743. }
  7744. });
  7745. }
  7746. }
  7747. break;
  7748. }
  7749. $.jgrid.bindEv.call($t, elem, soptions);
  7750. }
  7751. $(th).append(thd);
  7752. $(tr).append(th);
  7753. if (!p.searchOperators || select === "") {
  7754. $("td:eq(0)", stbl).hide();
  7755. }
  7756. });
  7757. $("table thead", $t.grid.hDiv).append(tr);
  7758. if (p.searchOperators) {
  7759. $(".soptclass", tr).click(function (e) {
  7760. var offset = $(this).offset(),
  7761. left = (offset.left),
  7762. top = (offset.top);
  7763. buildRuleMenu(this, left, top);
  7764. e.stopPropagation();
  7765. });
  7766. $("body").on('click', function (e) {
  7767. if (e.target.className !== "soptclass") {
  7768. $("#sopt_menu").remove();
  7769. }
  7770. });
  7771. }
  7772. $(".clearsearchclass", tr).click(function () {
  7773. var ptr = $(this).parents("tr:first"),
  7774. coli = parseInt($("td.ui-search-oper", ptr).attr('colindex'), 10),
  7775. sval = $.extend({}, $t.p.colModel[coli].searchoptions || {}),
  7776. dval = sval.defaultValue ? sval.defaultValue : "",
  7777. elem;
  7778. if ($t.p.colModel[coli].stype === "select") {
  7779. elem = $("td.ui-search-input select", ptr);
  7780. if (dval) {
  7781. elem.val(dval);
  7782. } else {
  7783. elem[0].selectedIndex = 0;
  7784. }
  7785. } else {
  7786. elem = $("td.ui-search-input input", ptr);
  7787. elem.val(dval);
  7788. }
  7789. $($t).triggerHandler("jqGridToolbarClearVal", [elem[0], coli, sval, dval]);
  7790. if ($.isFunction(p.onClearSearchValue)) {
  7791. p.onClearSearchValue.call($t, elem[0], coli, sval, dval);
  7792. }
  7793. // ToDo custom search type
  7794. if (p.autosearch === true) {
  7795. triggerToolbar();
  7796. }
  7797. });
  7798. this.p.filterToolbar = true;
  7799. this.triggerToolbar = triggerToolbar;
  7800. this.clearToolbar = clearToolbar;
  7801. this.toggleToolbar = toggleToolbar;
  7802. });
  7803. },
  7804. destroyFilterToolbar: function () {
  7805. return this.each(function () {
  7806. if (!this.p.filterToolbar) {
  7807. return;
  7808. }
  7809. this.triggerToolbar = null;
  7810. this.clearToolbar = null;
  7811. this.toggleToolbar = null;
  7812. this.p.filterToolbar = false;
  7813. $(this.grid.hDiv).find("table thead tr.ui-search-toolbar").remove();
  7814. });
  7815. },
  7816. refreshFilterToolbar: function (p) {
  7817. p = $.extend(true, {
  7818. filters: "",
  7819. onClearVal: null,
  7820. onSetVal: null
  7821. }, p || {});
  7822. return this.each(function () {
  7823. var $t = this, cm = $t.p.colModel, i, l = $t.p.colModel.length,
  7824. searchitem, filters, rules, rule, ssfield = [], ia;
  7825. // clear the values on toolbar.
  7826. // do not call clearToolbar
  7827. if (!$t.p.filterToolbar) {
  7828. return;
  7829. }
  7830. for (i = 0; i < l; i++) {
  7831. ssfield.push(cm[i].name);
  7832. searchitem = $("#gs_" + $t.p.idPrefix + $.jgrid.jqID(cm[i].name));
  7833. switch (cm[i].stype) {
  7834. case 'select':
  7835. case 'text':
  7836. searchitem.val("");
  7837. break;
  7838. }
  7839. if ($.isFunction(p.onClearVal)) {
  7840. p.onClearVal.call($t, searchitem, cm[i].name);
  7841. }
  7842. }
  7843. function setrules(filter) {
  7844. if (filter && filter.rules) { // condition to exit
  7845. rules = filter.rules;
  7846. l = rules.length;
  7847. for (i = 0; i < l; i++) {
  7848. rule = rules[i];
  7849. ia = $.inArray(rule.field, ssfield);
  7850. if (ia !== -1) {
  7851. searchitem = $("#gs_" + $t.p.idPrefix + $.jgrid.jqID(cm[ia].name));
  7852. // problem for between operator
  7853. if (searchitem.length > 0) {
  7854. if (cm[ia].stype === "select") {
  7855. searchitem.find("option[value='" + $.jgrid.jqID(rule.data) + "']").prop('selected', true);
  7856. } else if (cm[ia].stype === "text") {
  7857. searchitem.val(rule.data);
  7858. }
  7859. if ($.isFunction(p.onSetVal)) {
  7860. p.onSetVal.call($t, searchitem, cm[ia].name);
  7861. }
  7862. }
  7863. }
  7864. }
  7865. if (filter.groups) {
  7866. for (var k = 0; k < filter.groups.length; k++) {
  7867. setrules(filter.groups[k]);
  7868. }
  7869. }
  7870. }
  7871. }
  7872. if (typeof (p.filters) === "string" && p.filters.length) {
  7873. filters = $.jgrid.parse(p.filters);
  7874. // flat filters only
  7875. }
  7876. if ($.isPlainObject(filters)) {
  7877. setrules(filters);
  7878. }
  7879. });
  7880. },
  7881. searchGrid: function (p) {
  7882. var regional = $.jgrid.getRegional(this[0], 'search');
  7883. p = $.extend(true, {
  7884. recreateFilter: false,
  7885. drag: true,
  7886. sField: 'searchField',
  7887. sValue: 'searchString',
  7888. sOper: 'searchOper',
  7889. sFilter: 'filters',
  7890. loadDefaults: true, // this options activates loading of default filters from grid's postData for Multipe Search only.
  7891. beforeShowSearch: null,
  7892. afterShowSearch: null,
  7893. onInitializeSearch: null,
  7894. afterRedraw: null,
  7895. afterChange: null,
  7896. sortStrategy: null,
  7897. closeAfterSearch: false,
  7898. closeAfterReset: false,
  7899. closeOnEscape: false,
  7900. searchOnEnter: false,
  7901. multipleSearch: false,
  7902. multipleGroup: false,
  7903. //cloneSearchRowOnAdd: true,
  7904. top: 0,
  7905. left: 0,
  7906. jqModal: true,
  7907. modal: false,
  7908. resize: true,
  7909. width: 450,
  7910. height: 'auto',
  7911. dataheight: 'auto',
  7912. showQuery: false,
  7913. errorcheck: true,
  7914. sopt: null,
  7915. stringResult: undefined,
  7916. onClose: null,
  7917. onSearch: null,
  7918. onReset: null,
  7919. toTop: true,
  7920. overlay: 30,
  7921. columns: [],
  7922. tmplNames: null,
  7923. tmplFilters: null,
  7924. tmplLabel: ' Template: ',
  7925. showOnLoad: false,
  7926. layer: null,
  7927. operands: { "eq": "=", "ne": "<>", "lt": "<", "le": "<=", "gt": ">", "ge": ">=", "bw": "LIKE", "bn": "NOT LIKE", "in": "IN", "ni": "NOT IN", "ew": "LIKE", "en": "NOT LIKE", "cn": "LIKE", "nc": "NOT LIKE", "nu": "IS NULL", "nn": "ISNOT NULL" }
  7928. }, regional, p || {});
  7929. return this.each(function () {
  7930. var $t = this;
  7931. if (!$t.grid) { return; }
  7932. var fid = "fbox_" + $t.p.id,
  7933. showFrm = true,
  7934. mustReload = true,
  7935. IDs = { themodal: 'searchmod' + fid, modalhead: 'searchhd' + fid, modalcontent: 'searchcnt' + fid, scrollelm: fid },
  7936. defaultFilters = $t.p.postData[p.sFilter],
  7937. fl,
  7938. classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].filter,
  7939. common = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].common;
  7940. p.styleUI = $t.p.styleUI;
  7941. if (typeof defaultFilters === "string") {
  7942. defaultFilters = $.jgrid.parse(defaultFilters);
  7943. }
  7944. if (p.recreateFilter === true) {
  7945. $("#" + $.jgrid.jqID(IDs.themodal)).remove();
  7946. }
  7947. function showFilter(_filter) {
  7948. showFrm = $($t).triggerHandler("jqGridFilterBeforeShow", [_filter]);
  7949. if (showFrm === undefined) {
  7950. showFrm = true;
  7951. }
  7952. if (showFrm && $.isFunction(p.beforeShowSearch)) {
  7953. showFrm = p.beforeShowSearch.call($t, _filter);
  7954. }
  7955. if (showFrm) {
  7956. $.jgrid.viewModal("#" + $.jgrid.jqID(IDs.themodal), { gbox: "#gbox_" + $.jgrid.jqID(fid), jqm: p.jqModal, modal: p.modal, overlay: p.overlay, toTop: p.toTop });
  7957. $($t).triggerHandler("jqGridFilterAfterShow", [_filter]);
  7958. if ($.isFunction(p.afterShowSearch)) {
  7959. p.afterShowSearch.call($t, _filter);
  7960. }
  7961. }
  7962. }
  7963. if ($("#" + $.jgrid.jqID(IDs.themodal))[0] !== undefined) {
  7964. showFilter($("#fbox_" + $.jgrid.jqID($t.p.id)));
  7965. } else {
  7966. var fil = $("<div><div id='" + fid + "' class='searchFilter' style='overflow:auto'></div></div>").insertBefore("#gview_" + $.jgrid.jqID($t.p.id)),
  7967. align = "left", butleft = "";
  7968. if ($t.p.direction === "rtl") {
  7969. align = "right";
  7970. butleft = " style='text-align:left'";
  7971. fil.attr("dir", "rtl");
  7972. }
  7973. var columns = $.extend([], $t.p.colModel),
  7974. bS = "<a id='" + fid + "_search' class='fm-button " + common.button + " fm-button-icon-right ui-search'><span class='" + common.icon_base + " " + classes.icon_search + "'></span>" + p.Find + "</a>",
  7975. bC = "<a id='" + fid + "_reset' class='fm-button " + common.button + " fm-button-icon-left ui-reset'><span class='" + common.icon_base + " " + classes.icon_reset + "'></span>" + p.Reset + "</a>",
  7976. bQ = "", tmpl = "", colnm, found = false, bt, cmi = -1;
  7977. if (p.showQuery) {
  7978. bQ = "<a id='" + fid + "_query' class='fm-button " + common.button + " fm-button-icon-left'><span class='" + common.icon_base + " " + classes.icon_query + "'></span>Query</a>";
  7979. }
  7980. if (!p.columns.length) {
  7981. $.each(columns, function (i, n) {
  7982. if (!n.label) {
  7983. n.label = $t.p.colNames[i];
  7984. }
  7985. // find first searchable column and set it if no default filter
  7986. if (!found) {
  7987. var searchable = (n.search === undefined) ? true : n.search,
  7988. hidden = (n.hidden === true),
  7989. ignoreHiding = (n.searchoptions && n.searchoptions.searchhidden === true);
  7990. if ((ignoreHiding && searchable) || (searchable && !hidden)) {
  7991. found = true;
  7992. colnm = n.index || n.name;
  7993. cmi = i;
  7994. }
  7995. }
  7996. });
  7997. } else {
  7998. columns = p.columns;
  7999. cmi = 0;
  8000. colnm = columns[0].index || columns[0].name;
  8001. }
  8002. // old behaviour
  8003. if ((!defaultFilters && colnm) || p.multipleSearch === false) {
  8004. var cmop = "eq";
  8005. if (cmi >= 0 && columns[cmi].searchoptions && columns[cmi].searchoptions.sopt) {
  8006. cmop = columns[cmi].searchoptions.sopt[0];
  8007. } else if (p.sopt && p.sopt.length) {
  8008. cmop = p.sopt[0];
  8009. }
  8010. defaultFilters = { groupOp: "AND", rules: [{ field: colnm, op: cmop, data: "" }] };
  8011. }
  8012. found = false;
  8013. if (p.tmplNames && p.tmplNames.length) {
  8014. found = true;
  8015. tmpl = "<tr><td class='ui-search-label'>" + p.tmplLabel + "</td>";
  8016. tmpl += "<td><select class='ui-template " + classes.srSelect + "'>";
  8017. tmpl += "<option value='default'>Default</option>";
  8018. $.each(p.tmplNames, function (i, n) {
  8019. tmpl += "<option value='" + i + "'>" + n + "</option>";
  8020. });
  8021. tmpl += "</select></td></tr>";
  8022. }
  8023. bt = "<table class='EditTable' style='border:0px none;margin-top:5px' id='" + fid + "_2'><tbody><tr><td colspan='2'><hr class='" + common.content + "' style='margin:1px'/></td></tr>" + tmpl + "<tr><td class='EditButton' style='text-align:" + align + "'>" + bC + "</td><td class='EditButton' " + butleft + ">" + bQ + bS + "</td></tr></tbody></table>";
  8024. fid = $.jgrid.jqID(fid);
  8025. $("#" + fid).jqFilter({
  8026. columns: columns,
  8027. sortStrategy: p.sortStrategy,
  8028. filter: p.loadDefaults ? defaultFilters : null,
  8029. showQuery: p.showQuery,
  8030. errorcheck: p.errorcheck,
  8031. sopt: p.sopt,
  8032. groupButton: p.multipleGroup,
  8033. ruleButtons: p.multipleSearch,
  8034. uniqueSearchFields: p.uniqueSearchFields,
  8035. afterRedraw: p.afterRedraw,
  8036. ops: p.odata,
  8037. operands: p.operands,
  8038. ajaxSelectOptions: $t.p.ajaxSelectOptions,
  8039. groupOps: p.groupOps,
  8040. onChange: function () {
  8041. if (this.p.showQuery) {
  8042. $('.query', this).html(this.toUserFriendlyString());
  8043. }
  8044. if ($.isFunction(p.afterChange)) {
  8045. p.afterChange.call($t, $("#" + fid), p);
  8046. }
  8047. },
  8048. direction: $t.p.direction,
  8049. id: $t.p.id
  8050. });
  8051. fil.append(bt);
  8052. if (found && p.tmplFilters && p.tmplFilters.length) {
  8053. $(".ui-template", fil).bind('change', function () {
  8054. var curtempl = $(this).val();
  8055. if (curtempl === "default") {
  8056. $("#" + fid).jqFilter('addFilter', defaultFilters);
  8057. } else {
  8058. $("#" + fid).jqFilter('addFilter', p.tmplFilters[parseInt(curtempl, 10)]);
  8059. }
  8060. return false;
  8061. });
  8062. }
  8063. if (p.multipleGroup === true) { p.multipleSearch = true; }
  8064. $($t).triggerHandler("jqGridFilterInitialize", [$("#" + fid)]);
  8065. if ($.isFunction(p.onInitializeSearch)) {
  8066. p.onInitializeSearch.call($t, $("#" + fid));
  8067. }
  8068. p.gbox = "#gbox_" + fid;
  8069. if (p.layer) {
  8070. $.jgrid.createModal(IDs, fil, p, "#gview_" + $.jgrid.jqID($t.p.id), $("#gbox_" + $.jgrid.jqID($t.p.id))[0], "#" + $.jgrid.jqID(p.layer), { position: "relative" });
  8071. } else {
  8072. $.jgrid.createModal(IDs, fil, p, "#gview_" + $.jgrid.jqID($t.p.id), $("#gbox_" + $.jgrid.jqID($t.p.id))[0]);
  8073. }
  8074. if (p.searchOnEnter || p.closeOnEscape) {
  8075. $("#" + $.jgrid.jqID(IDs.themodal)).keydown(function (e) {
  8076. var $target = $(e.target);
  8077. if (p.searchOnEnter && e.which === 13 && // 13 === $.ui.keyCode.ENTER
  8078. !$target.hasClass('add-group') && !$target.hasClass('add-rule') &&
  8079. !$target.hasClass('delete-group') && !$target.hasClass('delete-rule') &&
  8080. (!$target.hasClass("fm-button") || !$target.is("[id$=_query]"))) {
  8081. $("#" + fid + "_search").click();
  8082. return false;
  8083. }
  8084. if (p.closeOnEscape && e.which === 27) { // 27 === $.ui.keyCode.ESCAPE
  8085. $("#" + $.jgrid.jqID(IDs.modalhead)).find(".ui-jqdialog-titlebar-close").click();
  8086. return false;
  8087. }
  8088. });
  8089. }
  8090. if (bQ) {
  8091. $("#" + fid + "_query").bind('click', function () {
  8092. $(".queryresult", fil).toggle();
  8093. return false;
  8094. });
  8095. }
  8096. if (p.stringResult === undefined) {
  8097. // to provide backward compatibility, inferring stringResult value from multipleSearch
  8098. p.stringResult = p.multipleSearch;
  8099. }
  8100. $("#" + fid + "_search").bind('click', function () {
  8101. var sdata = {}, res, filters;
  8102. fl = $("#" + fid);
  8103. fl.find(".input-elm:focus").change();
  8104. filters = fl.jqFilter('filterData');
  8105. if (p.errorcheck) {
  8106. fl[0].hideError();
  8107. if (!p.showQuery) { fl.jqFilter('toSQLString'); }
  8108. if (fl[0].p.error) {
  8109. fl[0].showError();
  8110. return false;
  8111. }
  8112. }
  8113. if (p.stringResult) {
  8114. try {
  8115. res = JSON.stringify(filters);
  8116. } catch (e2) { }
  8117. if (typeof res === "string") {
  8118. sdata[p.sFilter] = res;
  8119. $.each([p.sField, p.sValue, p.sOper], function () { sdata[this] = ""; });
  8120. }
  8121. } else {
  8122. if (p.multipleSearch) {
  8123. sdata[p.sFilter] = filters;
  8124. $.each([p.sField, p.sValue, p.sOper], function () { sdata[this] = ""; });
  8125. } else {
  8126. sdata[p.sField] = filters.rules[0].field;
  8127. sdata[p.sValue] = filters.rules[0].data;
  8128. sdata[p.sOper] = filters.rules[0].op;
  8129. sdata[p.sFilter] = "";
  8130. }
  8131. }
  8132. $t.p.search = true;
  8133. $.extend($t.p.postData, sdata);
  8134. mustReload = $($t).triggerHandler("jqGridFilterSearch");
  8135. if (mustReload === undefined) {
  8136. mustReload = true;
  8137. }
  8138. if (mustReload && $.isFunction(p.onSearch)) {
  8139. mustReload = p.onSearch.call($t, $t.p.filters);
  8140. }
  8141. if (mustReload !== false) {
  8142. $($t).trigger("reloadGrid", [{ page: 1 }]);
  8143. }
  8144. if (p.closeAfterSearch) {
  8145. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: p.jqModal, onClose: p.onClose });
  8146. }
  8147. return false;
  8148. });
  8149. $("#" + fid + "_reset").bind('click', function () {
  8150. var sdata = {},
  8151. fl = $("#" + fid);
  8152. $t.p.search = false;
  8153. $t.p.resetsearch = true;
  8154. if (p.multipleSearch === false) {
  8155. sdata[p.sField] = sdata[p.sValue] = sdata[p.sOper] = "";
  8156. } else {
  8157. sdata[p.sFilter] = "";
  8158. }
  8159. fl[0].resetFilter();
  8160. if (found) {
  8161. $(".ui-template", fil).val("default");
  8162. }
  8163. $.extend($t.p.postData, sdata);
  8164. mustReload = $($t).triggerHandler("jqGridFilterReset");
  8165. if (mustReload === undefined) {
  8166. mustReload = true;
  8167. }
  8168. if (mustReload && $.isFunction(p.onReset)) {
  8169. mustReload = p.onReset.call($t);
  8170. }
  8171. if (mustReload !== false) {
  8172. $($t).trigger("reloadGrid", [{ page: 1 }]);
  8173. }
  8174. if (p.closeAfterReset) {
  8175. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: p.jqModal, onClose: p.onClose });
  8176. }
  8177. return false;
  8178. });
  8179. showFilter($("#" + fid));
  8180. $(".fm-button:not(." + common.disabled + ")", fil).hover(
  8181. function () { $(this).addClass(common.hover); },
  8182. function () { $(this).removeClass(common.hover); }
  8183. );
  8184. }
  8185. });
  8186. },
  8187. filterInput: function (val, p) {
  8188. p = $.extend(true, {
  8189. defaultSearch: 'cn',
  8190. groupOp: 'OR',
  8191. searchAll: false,
  8192. beforeSearch: null,
  8193. afterSearch: null
  8194. }, p || {});
  8195. return this.each(function () {
  8196. var $t = this;
  8197. if (!$t.grid) { return; }
  8198. var nm, sop, ruleGroup = "{\"groupOp\":\"" + p.groupOp + "\",\"rules\":[", gi = 0, so;
  8199. val += "";
  8200. if (!$t.p.datatype === 'local') { return; }
  8201. $.each($t.p.colModel, function () {
  8202. nm = this.index || this.name;
  8203. sop = this.searchoptions || {};
  8204. so = p.defaultSearch ? p.defaultSearch : (sop.sopt) ? sop.sopt[0] : p.defaultSearch;
  8205. this.search = this.search === false ? false : true;
  8206. if (this.search || p.searchAll) {
  8207. if (gi > 0) { ruleGroup += ","; }
  8208. ruleGroup += "{\"field\":\"" + nm + "\",";
  8209. ruleGroup += "\"op\":\"" + so + "\",";
  8210. ruleGroup += "\"data\":\"" + val.replace(/\\/g, '\\\\').replace(/\"/g, '\\"') + "\"}";
  8211. gi++;
  8212. }
  8213. });
  8214. ruleGroup += "]}";
  8215. $.extend($t.p.postData, { filters: ruleGroup });
  8216. $.each(['searchField', 'searchString', 'searchOper'], function (i, n) {
  8217. if ($t.p.postData.hasOwnProperty(n)) { delete $t.p.postData[n]; }
  8218. });
  8219. var bsr = $($t).triggerHandler("jqGridFilterInputBeforeSearch") === 'stop' ? true : false;
  8220. if (!bsr && $.isFunction(p.beforeSearch)) { bsr = p.beforeSearch.call($t); }
  8221. if (!bsr) { $($t).jqGrid("setGridParam", { search: true }).trigger("reloadGrid", [{ page: 1 }]); }
  8222. $($t).triggerHandler("jqGridFilterInputAfterSearch");
  8223. if ($.isFunction(p.afterSearch)) { p.afterSearch.call($t); }
  8224. });
  8225. }
  8226. });
  8227. //module begin
  8228. var rp_ge = {};
  8229. $.jgrid.extend({
  8230. editGridRow: function (rowid, p) {
  8231. var regional = $.jgrid.getRegional(this[0], 'edit'),
  8232. currstyle = this[0].p.styleUI,
  8233. styles = $.jgrid.styleUI[currstyle].formedit,
  8234. commonstyle = $.jgrid.styleUI[currstyle].common;
  8235. p = $.extend(true, {
  8236. top: 0,
  8237. left: 0,
  8238. width: '500',
  8239. datawidth: 'auto',
  8240. height: 'auto',
  8241. dataheight: 'auto',
  8242. modal: false,
  8243. overlay: 30,
  8244. drag: true,
  8245. resize: true,
  8246. url: null,
  8247. mtype: "POST",
  8248. clearAfterAdd: true,
  8249. closeAfterEdit: false,
  8250. reloadAfterSubmit: true,
  8251. onInitializeForm: null,
  8252. beforeInitData: null,
  8253. beforeShowForm: null,
  8254. afterShowForm: null,
  8255. beforeSubmit: null,
  8256. afterSubmit: null,
  8257. onclickSubmit: null,
  8258. afterComplete: null,
  8259. onclickPgButtons: null,
  8260. afterclickPgButtons: null,
  8261. editData: {},
  8262. recreateForm: false,
  8263. jqModal: true,
  8264. closeOnEscape: false,
  8265. addedrow: "first",
  8266. topinfo: '',
  8267. bottominfo: '',
  8268. saveicon: [],
  8269. closeicon: [],
  8270. savekey: [false, 13],
  8271. navkeys: [false, 38, 40],
  8272. checkOnSubmit: false,
  8273. checkOnUpdate: false,
  8274. processing: false,
  8275. onClose: null,
  8276. ajaxEditOptions: {},
  8277. serializeEditData: null,
  8278. viewPagerButtons: true,
  8279. overlayClass: commonstyle.overlay,
  8280. removemodal: true,
  8281. form: 'edit',
  8282. template: null,
  8283. focusField: true,
  8284. editselected: false
  8285. }, regional, p || {});
  8286. rp_ge[$(this)[0].p.id] = p;
  8287. return this.each(function () {
  8288. var $t = this;
  8289. if (!$t.grid || !rowid) { return; }
  8290. $t.p.savedData = {};
  8291. var gID = $t.p.id,
  8292. frmgr = "FrmGrid_" + gID, frmtborg = "TblGrid_" + gID, frmtb = "#" + $.jgrid.jqID(frmtborg), frmtb2,
  8293. IDs = { themodal: 'editmod' + gID, modalhead: 'edithd' + gID, modalcontent: 'editcnt' + gID, scrollelm: frmgr },
  8294. showFrm = true, maxCols = 1, maxRows = 0, postdata, diff, frmoper,
  8295. templ = typeof rp_ge[$t.p.id].template === "string" && rp_ge[$t.p.id].template.length > 0,
  8296. errors = $.jgrid.getRegional(this, 'errors');
  8297. rp_ge[$t.p.id].styleUI = $t.p.styleUI || 'jQueryUI';
  8298. if ($.jgrid.isMobile()) {
  8299. rp_ge[$t.p.id].resize = false;
  8300. }
  8301. if (rowid === "new") {
  8302. rowid = "_empty";
  8303. frmoper = "add";
  8304. p.caption = rp_ge[$t.p.id].addCaption;
  8305. } else {
  8306. p.caption = rp_ge[$t.p.id].editCaption;
  8307. frmoper = "edit";
  8308. }
  8309. if (!p.recreateForm) {
  8310. if ($($t).data("formProp")) {
  8311. $.extend(rp_ge[$(this)[0].p.id], $($t).data("formProp"));
  8312. }
  8313. }
  8314. var closeovrl = true;
  8315. if (p.checkOnUpdate && p.jqModal && !p.modal) {
  8316. closeovrl = false;
  8317. }
  8318. function getFormData() {
  8319. var a2 = {}, i;
  8320. $(frmtb).find(".FormElement").each(function () {
  8321. var celm = $(".customelement", this);
  8322. if (celm.length) {
  8323. var elem = celm[0], nm = $(elem).attr('name');
  8324. $.each($t.p.colModel, function () {
  8325. if (this.name === nm && this.editoptions && $.isFunction(this.editoptions.custom_value)) {
  8326. try {
  8327. postdata[nm] = this.editoptions.custom_value.call($t, $("#" + $.jgrid.jqID(nm), frmtb), 'get');
  8328. if (postdata[nm] === undefined) { throw "e1"; }
  8329. } catch (e) {
  8330. if (e === "e1") { $.jgrid.info_dialog(errors.errcap, "function 'custom_value' " + rp_ge[$(this)[0]].p.msg.novalue, rp_ge[$(this)[0]].p.bClose, { styleUI: rp_ge[$(this)[0]].p.styleUI }); }
  8331. else { $.jgrid.info_dialog(errors.errcap, e.message, rp_ge[$(this)[0]].p.bClose, { styleUI: rp_ge[$(this)[0]].p.styleUI }); }
  8332. }
  8333. return true;
  8334. }
  8335. });
  8336. } else {
  8337. switch ($(this).get(0).type) {
  8338. case "checkbox":
  8339. if ($(this).is(":checked")) {
  8340. postdata[this.name] = $(this).val();
  8341. } else {
  8342. var ofv = $(this).attr("offval");
  8343. postdata[this.name] = ofv;
  8344. }
  8345. break;
  8346. case "select-one":
  8347. postdata[this.name] = $(this).val();
  8348. break;
  8349. case "select-multiple":
  8350. postdata[this.name] = $(this).val();
  8351. postdata[this.name] = postdata[this.name] ? postdata[this.name].join(",") : "";
  8352. break;
  8353. case "password":
  8354. case "text":
  8355. case "textarea":
  8356. case "button":
  8357. postdata[this.name] = $(this).val();
  8358. break;
  8359. case "radio":
  8360. if (a2.hasOwnProperty(this.name)) {
  8361. return true;
  8362. } else {
  8363. a2[this.name] = ($(this).attr("offval") === undefined) ? "off" : $(this).attr("offval");
  8364. }
  8365. break;
  8366. }
  8367. if ($t.p.autoencode) {
  8368. postdata[this.name] = $.jgrid.htmlEncode(postdata[this.name]);
  8369. }
  8370. }
  8371. });
  8372. for (i in a2) {
  8373. if (a2.hasOwnProperty(i)) {
  8374. var val = $('input[name="' + i + '"]:checked', frmtb).val();
  8375. postdata[i] = (val !== undefined) ? val : a2[i];
  8376. if ($t.p.autoencode) {
  8377. postdata[i] = $.jgrid.htmlEncode(postdata[i]);
  8378. }
  8379. }
  8380. }
  8381. return true;
  8382. }
  8383. function createData(rowid, obj, tb, maxcols) {
  8384. var nm, hc, trdata, cnt = 0, tmp, dc, elc, retpos = [], ind = false,
  8385. tdtmpl = "<td class='CaptionTD'>&#160;</td><td class='DataTD'>&#160;</td>", tmpl = "", i, ffld; //*2
  8386. for (i = 1; i <= maxcols; i++) {
  8387. tmpl += tdtmpl;
  8388. }
  8389. if (rowid !== '_empty') {
  8390. ind = $(obj).jqGrid("getInd", rowid);
  8391. }
  8392. $(obj.p.colModel).each(function (i) {
  8393. nm = this.name;
  8394. // hidden fields are included in the form
  8395. if (this.editrules && this.editrules.edithidden === true) {
  8396. hc = false;
  8397. } else {
  8398. hc = this.hidden === true ? true : false;
  8399. }
  8400. dc = hc ? "style='display:none'" : "";
  8401. if (nm !== 'cb' && nm !== 'subgrid' && this.editable === true && nm !== 'rn') {
  8402. if (ind === false) {
  8403. tmp = "";
  8404. } else {
  8405. if (nm === obj.p.ExpandColumn && obj.p.treeGrid === true) {
  8406. tmp = $("td[role='gridcell']:eq(" + i + ")", obj.rows[ind]).text();
  8407. } else {
  8408. try {
  8409. tmp = $.unformat.call(obj, $("td[role='gridcell']:eq(" + i + ")", obj.rows[ind]), { rowId: rowid, colModel: this }, i);
  8410. } catch (_) {
  8411. tmp = (this.edittype && this.edittype === "textarea") ? $("td[role='gridcell']:eq(" + i + ")", obj.rows[ind]).text() : $("td[role='gridcell']:eq(" + i + ")", obj.rows[ind]).html();
  8412. }
  8413. if (!tmp || tmp === "&nbsp;" || tmp === "&#160;" || (tmp.length === 1 && tmp.charCodeAt(0) === 160)) { tmp = ''; }
  8414. }
  8415. }
  8416. var opt = $.extend({}, this.editoptions || {}, { id: nm, name: nm, rowId: rowid, oper: 'edit' }),
  8417. frmopt = $.extend({}, { elmprefix: '', elmsuffix: '', rowabove: false, rowcontent: '' }, this.formoptions || {}),
  8418. rp = parseInt(frmopt.rowpos, 10) || cnt + 1,
  8419. cp = parseInt((parseInt(frmopt.colpos, 10) || 1) * 2, 10);
  8420. if (rowid === "_empty" && opt.defaultValue) {
  8421. tmp = $.isFunction(opt.defaultValue) ? opt.defaultValue.call($t) : opt.defaultValue;
  8422. }
  8423. if (!this.edittype) { this.edittype = "text"; }
  8424. if ($t.p.autoencode) { tmp = $.jgrid.htmlDecode(tmp); }
  8425. elc = $.jgrid.createEl.call($t, this.edittype, opt, tmp, false, $.extend({}, $.jgrid.ajaxOptions, obj.p.ajaxSelectOptions || {}));
  8426. //if(tmp === "" && this.edittype == "checkbox") {tmp = $(elc).attr("offval");}
  8427. //if(tmp === "" && this.edittype == "select") {tmp = $("option:eq(0)",elc).text();}
  8428. if (this.edittype === "select") {
  8429. tmp = $(elc).val();
  8430. if ($(elc).get(0).type === 'select-multiple' && tmp) {
  8431. tmp = tmp.join(",");
  8432. }
  8433. }
  8434. if (this.edittype === 'checkbox') {
  8435. if ($(elc).is(":checked")) {
  8436. tmp = $(elc).val();
  8437. } else {
  8438. tmp = $(elc).attr("offval");
  8439. }
  8440. }
  8441. $(elc).addClass("FormElement");
  8442. if ($.inArray(this.edittype, ['text', 'textarea', 'password', 'select']) > -1) {
  8443. $(elc).addClass(styles.inputClass);
  8444. }
  8445. ffld = true;
  8446. if (templ) {
  8447. var ftmplfld = $(frm).find("#" + nm);
  8448. if (ftmplfld.length) {
  8449. ftmplfld.replaceWith(elc);
  8450. } else {
  8451. ffld = false;
  8452. }
  8453. } else {
  8454. //--------------------
  8455. trdata = $(tb).find("tr[rowpos=" + rp + "]");
  8456. if (frmopt.rowabove) {
  8457. var newdata = $("<tr><td class='contentinfo' colspan='" + (maxcols * 2) + "'>" + frmopt.rowcontent + "</td></tr>");
  8458. $(tb).append(newdata);
  8459. newdata[0].rp = rp;
  8460. }
  8461. if (trdata.length === 0) {
  8462. trdata = $("<tr " + dc + " rowpos='" + rp + "'></tr>").addClass("FormData").attr("id", "tr_" + nm);
  8463. $(trdata).append(tmpl);
  8464. $(tb).append(trdata);
  8465. trdata[0].rp = rp;
  8466. }
  8467. $("td:eq(" + (cp - 2) + ")", trdata[0]).html("<label for='" + nm + "'>" + (frmopt.label === undefined ? obj.p.colNames[i] : frmopt.label) + "</label>");
  8468. $("td:eq(" + (cp - 1) + ")", trdata[0]).append(frmopt.elmprefix).append(elc).append(frmopt.elmsuffix);
  8469. //-------------------------
  8470. }
  8471. if ((rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) && ffld) {
  8472. $t.p.savedData[nm] = tmp;
  8473. }
  8474. if (this.edittype === 'custom' && $.isFunction(opt.custom_value)) {
  8475. opt.custom_value.call($t, $("#" + nm, frmgr), 'set', tmp);
  8476. }
  8477. $.jgrid.bindEv.call($t, elc, opt);
  8478. retpos[cnt] = i;
  8479. cnt++;
  8480. }
  8481. });
  8482. if (cnt > 0) {
  8483. var idrow;
  8484. if (templ) {
  8485. idrow = "<div class='FormData' style='display:none'><input class='FormElement' id='id_g' type='text' name='" + obj.p.id + "_id' value='" + rowid + "'/>";
  8486. $(frm).append(idrow);
  8487. } else {
  8488. idrow = $("<tr class='FormData' style='display:none'><td class='CaptionTD'></td><td colspan='" + (maxcols * 2 - 1) + "' class='DataTD'><input class='FormElement' id='id_g' type='text' name='" + obj.p.id + "_id' value='" + rowid + "'/></td></tr>");
  8489. idrow[0].rp = cnt + 999;
  8490. $(tb).append(idrow);
  8491. }
  8492. //$(tb).append(idrow);
  8493. if (rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) {
  8494. $t.p.savedData[obj.p.id + "_id"] = rowid;
  8495. }
  8496. }
  8497. return retpos;
  8498. }
  8499. function fillData(rowid, obj, fmid) {
  8500. var nm, cnt = 0, tmp, fld, opt, vl, vlc;
  8501. if (rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) {
  8502. $t.p.savedData = {};
  8503. $t.p.savedData[obj.p.id + "_id"] = rowid;
  8504. }
  8505. var cm = obj.p.colModel;
  8506. if (rowid === '_empty') {
  8507. $(cm).each(function () {
  8508. nm = this.name;
  8509. opt = $.extend({}, this.editoptions || {});
  8510. fld = $("#" + $.jgrid.jqID(nm), fmid);
  8511. if (fld && fld.length && fld[0] !== null) {
  8512. vl = "";
  8513. if (this.edittype === 'custom' && $.isFunction(opt.custom_value)) {
  8514. opt.custom_value.call($t, $("#" + nm, fmid), 'set', vl);
  8515. } else if (opt.defaultValue) {
  8516. vl = $.isFunction(opt.defaultValue) ? opt.defaultValue.call($t) : opt.defaultValue;
  8517. if (fld[0].type === 'checkbox') {
  8518. vlc = vl.toLowerCase();
  8519. if (vlc.search(/(false|f|0|no|n|off|undefined)/i) < 0 && vlc !== "") {
  8520. fld[0].checked = true;
  8521. fld[0].defaultChecked = true;
  8522. fld[0].value = vl;
  8523. } else {
  8524. fld[0].checked = false;
  8525. fld[0].defaultChecked = false;
  8526. }
  8527. } else { fld.val(vl); }
  8528. } else {
  8529. if (fld[0].type === 'checkbox') {
  8530. fld[0].checked = false;
  8531. fld[0].defaultChecked = false;
  8532. vl = $(fld).attr("offval");
  8533. } else if (fld[0].type && fld[0].type.substr(0, 6) === 'select') {
  8534. fld[0].selectedIndex = 0;
  8535. } else {
  8536. fld.val(vl);
  8537. }
  8538. }
  8539. if (rp_ge[$t.p.id].checkOnSubmit === true || rp_ge[$t.p.id].checkOnUpdate) {
  8540. $t.p.savedData[nm] = vl;
  8541. }
  8542. }
  8543. });
  8544. $("#id_g", fmid).val(rowid);
  8545. return;
  8546. }
  8547. var tre = $(obj).jqGrid("getInd", rowid, true);
  8548. if (!tre) { return; }
  8549. $('td[role="gridcell"]', tre).each(function (i) {
  8550. nm = cm[i].name;
  8551. // hidden fields are included in the form
  8552. if (nm !== 'cb' && nm !== 'subgrid' && nm !== 'rn' && cm[i].editable === true) {
  8553. if (nm === obj.p.ExpandColumn && obj.p.treeGrid === true) {
  8554. tmp = $(this).text();
  8555. } else {
  8556. try {
  8557. tmp = $.unformat.call(obj, $(this), { rowId: rowid, colModel: cm[i] }, i);
  8558. } catch (_) {
  8559. tmp = cm[i].edittype === "textarea" ? $(this).text() : $(this).html();
  8560. }
  8561. }
  8562. if ($t.p.autoencode) { tmp = $.jgrid.htmlDecode(tmp); }
  8563. if (rp_ge[$t.p.id].checkOnSubmit === true || rp_ge[$t.p.id].checkOnUpdate) {
  8564. $t.p.savedData[nm] = tmp;
  8565. }
  8566. nm = $.jgrid.jqID(nm);
  8567. switch (cm[i].edittype) {
  8568. case "password":
  8569. case "text":
  8570. case "button":
  8571. case "image":
  8572. case "textarea":
  8573. if (tmp === "&nbsp;" || tmp === "&#160;" || (tmp.length === 1 && tmp.charCodeAt(0) === 160)) { tmp = ''; }
  8574. $("#" + nm, fmid).val(tmp);
  8575. break;
  8576. case "select":
  8577. var opv = tmp.split(",");
  8578. opv = $.map(opv, function (n) { return $.trim(n); });
  8579. $("#" + nm + " option", fmid).each(function () {
  8580. if (!cm[i].editoptions.multiple && ($.trim(tmp) === $.trim($(this).text()) || opv[0] === $.trim($(this).text()) || opv[0] === $.trim($(this).val()))) {
  8581. this.selected = true;
  8582. } else if (cm[i].editoptions.multiple) {
  8583. if ($.inArray($.trim($(this).text()), opv) > -1 || $.inArray($.trim($(this).val()), opv) > -1) {
  8584. this.selected = true;
  8585. } else {
  8586. this.selected = false;
  8587. }
  8588. } else {
  8589. this.selected = false;
  8590. }
  8591. });
  8592. if (rp_ge[$t.p.id].checkOnSubmit === true || rp_ge[$t.p.id].checkOnUpdate) {
  8593. tmp = $("#" + nm, fmid).val();
  8594. if (cm[i].editoptions.multiple) {
  8595. tmp = tmp.join(",");
  8596. }
  8597. $t.p.savedData[nm] = tmp;
  8598. }
  8599. break;
  8600. case "checkbox":
  8601. tmp = String(tmp);
  8602. if (cm[i].editoptions && cm[i].editoptions.value) {
  8603. var cb = cm[i].editoptions.value.split(":");
  8604. if (cb[0] === tmp) {
  8605. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']({ "checked": true, "defaultChecked": true });
  8606. } else {
  8607. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']({ "checked": false, "defaultChecked": false });
  8608. }
  8609. } else {
  8610. tmp = tmp.toLowerCase();
  8611. if (tmp.search(/(false|f|0|no|n|off|undefined)/i) < 0 && tmp !== "") {
  8612. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']("checked", true);
  8613. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']("defaultChecked", true); //ie
  8614. } else {
  8615. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']("checked", false);
  8616. $("#" + nm, fmid)[$t.p.useProp ? 'prop' : 'attr']("defaultChecked", false); //ie
  8617. }
  8618. }
  8619. if (rp_ge[$t.p.id].checkOnSubmit === true || rp_ge[$t.p.id].checkOnUpdate) {
  8620. if ($("#" + nm, fmid).is(":checked")) {
  8621. tmp = $("#" + nm, fmid).val();
  8622. } else {
  8623. tmp = $("#" + nm, fmid).attr("offval");
  8624. }
  8625. $t.p.savedData[nm] = tmp;
  8626. }
  8627. break;
  8628. case 'custom':
  8629. try {
  8630. if (cm[i].editoptions && $.isFunction(cm[i].editoptions.custom_value)) {
  8631. cm[i].editoptions.custom_value.call($t, $("#" + nm, fmid), 'set', tmp);
  8632. } else { throw "e1"; }
  8633. } catch (e) {
  8634. if (e === "e1") { $.jgrid.info_dialog(errors.errcap, "function 'custom_value' " + rp_ge[$(this)[0]].p.msg.nodefined, $.rp_ge[$(this)[0]].p.bClose, { styleUI: rp_ge[$(this)[0]].p.styleUI }); }
  8635. else { $.jgrid.info_dialog(errors.errcap, e.message, $.rp_ge[$(this)[0]].p.bClose, { styleUI: rp_ge[$(this)[0]].p.styleUI }); }
  8636. }
  8637. break;
  8638. }
  8639. cnt++;
  8640. }
  8641. });
  8642. if (cnt > 0) {
  8643. $("#id_g", frmtb).val(rowid);
  8644. if (rp_ge[$t.p.id].checkOnSubmit === true || rp_ge[$t.p.id].checkOnUpdate) {
  8645. $t.p.savedData[obj.p.id + "_id"] = rowid;
  8646. }
  8647. }
  8648. }
  8649. function setNulls() {
  8650. $.each($t.p.colModel, function (i, n) {
  8651. if (n.editoptions && n.editoptions.NullIfEmpty === true) {
  8652. if (postdata.hasOwnProperty(n.name) && postdata[n.name] === "") {
  8653. postdata[n.name] = 'null';
  8654. }
  8655. }
  8656. });
  8657. }
  8658. function postIt() {
  8659. var copydata, ret = [true, "", ""], onCS = {}, opers = $t.p.prmNames, idname, oper, key, selr, i, url;
  8660. var retvals = $($t).triggerHandler("jqGridAddEditBeforeCheckValues", [$(frmgr), frmoper]);
  8661. if (retvals && typeof retvals === 'object') { postdata = retvals; }
  8662. if ($.isFunction(rp_ge[$t.p.id].beforeCheckValues)) {
  8663. retvals = rp_ge[$t.p.id].beforeCheckValues.call($t, postdata, $(frmgr), frmoper);
  8664. if (retvals && typeof retvals === 'object') { postdata = retvals; }
  8665. }
  8666. for (key in postdata) {
  8667. if (postdata.hasOwnProperty(key)) {
  8668. ret = $.jgrid.checkValues.call($t, postdata[key], key);
  8669. if (ret[0] === false) { break; }
  8670. }
  8671. }
  8672. setNulls();
  8673. if (ret[0]) {
  8674. onCS = $($t).triggerHandler("jqGridAddEditClickSubmit", [rp_ge[$t.p.id], postdata, frmoper]);
  8675. if (onCS === undefined && $.isFunction(rp_ge[$t.p.id].onclickSubmit)) {
  8676. onCS = rp_ge[$t.p.id].onclickSubmit.call($t, rp_ge[$t.p.id], postdata, frmoper) || {};
  8677. }
  8678. ret = $($t).triggerHandler("jqGridAddEditBeforeSubmit", [postdata, $(frmgr), frmoper]);
  8679. if (ret === undefined) {
  8680. ret = [true, "", ""];
  8681. }
  8682. if (ret[0] && $.isFunction(rp_ge[$t.p.id].beforeSubmit)) {
  8683. ret = rp_ge[$t.p.id].beforeSubmit.call($t, postdata, $(frmgr), frmoper);
  8684. }
  8685. }
  8686. if (ret[0] && !rp_ge[$t.p.id].processing) {
  8687. rp_ge[$t.p.id].processing = true;
  8688. $("#sData", frmtb + "_2").addClass(commonstyle.active);
  8689. url = rp_ge[$t.p.id].url || $($t).jqGrid('getGridParam', 'editurl');
  8690. oper = opers.oper;
  8691. idname = url === 'clientArray' ? $t.p.keyName : opers.id;
  8692. // we add to pos data array the action - the name is oper
  8693. postdata[oper] = ($.trim(postdata[$t.p.id + "_id"]) === "_empty") ? opers.addoper : opers.editoper;
  8694. if (postdata[oper] !== opers.addoper) {
  8695. postdata[idname] = postdata[$t.p.id + "_id"];
  8696. } else {
  8697. // check to see if we have allredy this field in the form and if yes lieve it
  8698. if (postdata[idname] === undefined) { postdata[idname] = postdata[$t.p.id + "_id"]; }
  8699. }
  8700. delete postdata[$t.p.id + "_id"];
  8701. postdata = $.extend(postdata, rp_ge[$t.p.id].editData, onCS);
  8702. if ($t.p.treeGrid === true) {
  8703. if (postdata[oper] === opers.addoper) {
  8704. selr = $($t).jqGrid("getGridParam", 'selrow');
  8705. var tr_par_id = $t.p.treeGridModel === 'adjacency' ? $t.p.treeReader.parent_id_field : 'parent_id';
  8706. postdata[tr_par_id] = selr;
  8707. }
  8708. for (i in $t.p.treeReader) {
  8709. if ($t.p.treeReader.hasOwnProperty(i)) {
  8710. var itm = $t.p.treeReader[i];
  8711. if (postdata.hasOwnProperty(itm)) {
  8712. if (postdata[oper] === opers.addoper && i === 'parent_id_field') { continue; }
  8713. delete postdata[itm];
  8714. }
  8715. }
  8716. }
  8717. }
  8718. postdata[idname] = $.jgrid.stripPref($t.p.idPrefix, postdata[idname]);
  8719. var ajaxOptions = $.extend({
  8720. url: url,
  8721. type: rp_ge[$t.p.id].mtype,
  8722. data: $.isFunction(rp_ge[$t.p.id].serializeEditData) ? rp_ge[$t.p.id].serializeEditData.call($t, postdata) : postdata,
  8723. complete: function (data, status) {
  8724. var key;
  8725. $("#sData", frmtb + "_2").removeClass(commonstyle.active);
  8726. postdata[idname] = $t.p.idPrefix + postdata[idname];
  8727. if (data.status >= 300 && data.status !== 304) {
  8728. ret[0] = false;
  8729. ret[1] = $($t).triggerHandler("jqGridAddEditErrorTextFormat", [data, frmoper]);
  8730. if ($.isFunction(rp_ge[$t.p.id].errorTextFormat)) {
  8731. ret[1] = rp_ge[$t.p.id].errorTextFormat.call($t, data, frmoper);
  8732. } else {
  8733. ret[1] = status + " Status: '" + data.statusText + "'. Error code: " + data.status;
  8734. }
  8735. } else {
  8736. // data is posted successful
  8737. // execute aftersubmit with the returned data from server
  8738. ret = $($t).triggerHandler("jqGridAddEditAfterSubmit", [data, postdata, frmoper]);
  8739. if (ret === undefined) {
  8740. ret = [true, "", ""];
  8741. }
  8742. if (ret[0] && $.isFunction(rp_ge[$t.p.id].afterSubmit)) {
  8743. ret = rp_ge[$t.p.id].afterSubmit.call($t, data, postdata, frmoper);
  8744. }
  8745. }
  8746. if (ret[0] === false) {
  8747. $(".FormError", frmgr).html(ret[1]);
  8748. $(".FormError", frmgr).show();
  8749. } else {
  8750. if ($t.p.autoencode) {
  8751. $.each(postdata, function (n, v) {
  8752. postdata[n] = $.jgrid.htmlDecode(v);
  8753. });
  8754. }
  8755. //rp_ge[$t.p.id].reloadAfterSubmit = rp_ge[$t.p.id].reloadAfterSubmit && $t.p.datatype != "local";
  8756. // the action is add
  8757. if (postdata[oper] === opers.addoper) {
  8758. //id processing
  8759. // user not set the id ret[2]
  8760. if (!ret[2]) { ret[2] = $.jgrid.randId(); }
  8761. if (postdata[idname] == null || postdata[idname] === "_empty") {
  8762. postdata[idname] = ret[2];
  8763. } else {
  8764. ret[2] = postdata[idname];
  8765. }
  8766. if (rp_ge[$t.p.id].reloadAfterSubmit) {
  8767. $($t).trigger("reloadGrid");
  8768. } else {
  8769. if ($t.p.treeGrid === true) {
  8770. $($t).jqGrid("addChildNode", ret[2], selr, postdata);
  8771. } else {
  8772. $($t).jqGrid("addRowData", ret[2], postdata, p.addedrow);
  8773. }
  8774. }
  8775. if (rp_ge[$t.p.id].closeAfterAdd) {
  8776. if ($t.p.treeGrid !== true) {
  8777. $($t).jqGrid("setSelection", ret[2]);
  8778. }
  8779. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  8780. } else if (rp_ge[$t.p.id].clearAfterAdd) {
  8781. fillData("_empty", $t, frmgr);
  8782. }
  8783. } else {
  8784. // the action is update
  8785. if (rp_ge[$t.p.id].reloadAfterSubmit) {
  8786. $($t).trigger("reloadGrid");
  8787. if (!rp_ge[$t.p.id].closeAfterEdit) { setTimeout(function () { $($t).jqGrid("setSelection", postdata[idname]); }, 1000); }
  8788. } else {
  8789. if ($t.p.treeGrid === true) {
  8790. $($t).jqGrid("setTreeRow", postdata[idname], postdata);
  8791. } else {
  8792. $($t).jqGrid("setRowData", postdata[idname], postdata);
  8793. }
  8794. }
  8795. if (rp_ge[$t.p.id].closeAfterEdit) { $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form }); }
  8796. }
  8797. if ($.isFunction(rp_ge[$t.p.id].afterComplete)) {
  8798. copydata = data;
  8799. setTimeout(function () {
  8800. $($t).triggerHandler("jqGridAddEditAfterComplete", [copydata, postdata, $(frmgr), frmoper]);
  8801. rp_ge[$t.p.id].afterComplete.call($t, copydata, postdata, $(frmgr), frmoper);
  8802. copydata = null;
  8803. }, 500);
  8804. }
  8805. if (rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) {
  8806. $(frmgr).data("disabled", false);
  8807. if ($t.p.savedData[$t.p.id + "_id"] !== "_empty") {
  8808. for (key in $t.p.savedData) {
  8809. if ($t.p.savedData.hasOwnProperty(key) && postdata[key]) {
  8810. $t.p.savedData[key] = postdata[key];
  8811. }
  8812. }
  8813. }
  8814. }
  8815. }
  8816. rp_ge[$t.p.id].processing = false;
  8817. try { $(':input:visible', frmgr)[0].focus(); } catch (e) { }
  8818. }
  8819. }, $.jgrid.ajaxOptions, rp_ge[$t.p.id].ajaxEditOptions);
  8820. if (!ajaxOptions.url && !rp_ge[$t.p.id].useDataProxy) {
  8821. if ($.isFunction($t.p.dataProxy)) {
  8822. rp_ge[$t.p.id].useDataProxy = true;
  8823. } else {
  8824. ret[0] = false; ret[1] += " " + errors.nourl;
  8825. }
  8826. }
  8827. if (ret[0]) {
  8828. if (rp_ge[$t.p.id].useDataProxy) {
  8829. var dpret = $t.p.dataProxy.call($t, ajaxOptions, "set_" + $t.p.id);
  8830. if (dpret === undefined) {
  8831. dpret = [true, ""];
  8832. }
  8833. if (dpret[0] === false) {
  8834. ret[0] = false;
  8835. ret[1] = dpret[1] || "Error deleting the selected row!";
  8836. } else {
  8837. if (ajaxOptions.data.oper === opers.addoper && rp_ge[$t.p.id].closeAfterAdd) {
  8838. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  8839. }
  8840. if (ajaxOptions.data.oper === opers.editoper && rp_ge[$t.p.id].closeAfterEdit) {
  8841. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  8842. }
  8843. }
  8844. } else {
  8845. if (ajaxOptions.url === "clientArray") {
  8846. rp_ge[$t.p.id].reloadAfterSubmit = false;
  8847. postdata = ajaxOptions.data;
  8848. ajaxOptions.complete({ status: 200, statusText: '' }, '');
  8849. } else {
  8850. $.ajax(ajaxOptions);
  8851. }
  8852. }
  8853. }
  8854. }
  8855. if (ret[0] === false) {
  8856. $(".FormError", frmgr).html(ret[1]);
  8857. $(".FormError", frmgr).show();
  8858. // return;
  8859. }
  8860. }
  8861. function compareData(nObj, oObj) {
  8862. var ret = false, key;
  8863. ret = !($.isPlainObject(nObj) && $.isPlainObject(oObj)
  8864. && Object.getOwnPropertyNames(nObj).length === Object.getOwnPropertyNames(oObj).length);
  8865. if (!ret) {
  8866. for (key in oObj) {
  8867. if (oObj.hasOwnProperty(key)) {
  8868. if (nObj.hasOwnProperty(key)) {
  8869. if (nObj[key] !== oObj[key]) {
  8870. ret = true;
  8871. break
  8872. }
  8873. } else {
  8874. ret = true;
  8875. break;
  8876. }
  8877. }
  8878. }
  8879. }
  8880. return ret;
  8881. }
  8882. function checkUpdates() {
  8883. var stat = true;
  8884. $(".FormError", frmgr).hide();
  8885. if (rp_ge[$t.p.id].checkOnUpdate) {
  8886. postdata = {};
  8887. getFormData();
  8888. diff = compareData(postdata, $t.p.savedData);
  8889. if (diff) {
  8890. $(frmgr).data("disabled", true);
  8891. $(".confirm", "#" + IDs.themodal).show();
  8892. stat = false;
  8893. }
  8894. }
  8895. return stat;
  8896. }
  8897. function restoreInline() {
  8898. var i;
  8899. if (rowid !== "_empty" && $t.p.savedRow !== undefined && $t.p.savedRow.length > 0 && $.isFunction($.fn.jqGrid.restoreRow)) {
  8900. for (i = 0; i < $t.p.savedRow.length; i++) {
  8901. if ($t.p.savedRow[i].id === rowid) {
  8902. $($t).jqGrid('restoreRow', rowid);
  8903. break;
  8904. }
  8905. }
  8906. }
  8907. }
  8908. function updateNav(cr, posarr) {
  8909. var totr = posarr[1].length - 1;
  8910. if (cr === 0) {
  8911. $("#pData", frmtb2).addClass(commonstyle.disabled);
  8912. } else if (posarr[1][cr - 1] !== undefined && $("#" + $.jgrid.jqID(posarr[1][cr - 1])).hasClass(commonstyle.disabled)) {
  8913. $("#pData", frmtb2).addClass(commonstyle.disabled);
  8914. } else {
  8915. $("#pData", frmtb2).removeClass(commonstyle.disabled);
  8916. }
  8917. if (cr === totr) {
  8918. $("#nData", frmtb2).addClass(commonstyle.disabled);
  8919. } else if (posarr[1][cr + 1] !== undefined && $("#" + $.jgrid.jqID(posarr[1][cr + 1])).hasClass(commonstyle.disabled)) {
  8920. $("#nData", frmtb2).addClass(commonstyle.disabled);
  8921. } else {
  8922. $("#nData", frmtb2).removeClass(commonstyle.disabled);
  8923. }
  8924. }
  8925. function getCurrPos() {
  8926. var rowsInGrid = $($t).jqGrid("getDataIDs"),
  8927. selrow = $("#id_g", frmtb).val(), pos;
  8928. if ($t.p.multiselect && rp_ge[$t.p.id].editselected) {
  8929. var arr = [];
  8930. for (var i = 0, len = rowsInGrid.length; i < len; i++) {
  8931. if ($.inArray(rowsInGrid[i], $t.p.selarrrow) !== -1) {
  8932. arr.push(rowsInGrid[i]);
  8933. }
  8934. }
  8935. pos = $.inArray(selrow, arr);
  8936. return [pos, arr];
  8937. } else {
  8938. pos = $.inArray(selrow, rowsInGrid);
  8939. }
  8940. return [pos, rowsInGrid];
  8941. }
  8942. function parseTemplate(template) {
  8943. var tmpl = "";
  8944. if (typeof template === "string") {
  8945. tmpl = template.replace(/\{([\w\-]+)(?:\:([\w\.]*)(?:\((.*?)?\))?)?\}/g, function (m, i) {
  8946. return '<span id="' + i + '" ></span>';
  8947. });
  8948. }
  8949. return tmpl;
  8950. }
  8951. function syncSavedData() {
  8952. if (rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) {
  8953. var a1 = [], a2 = {};
  8954. a1 = $.map($t.p.savedData, function (v, i) {
  8955. return i;
  8956. });
  8957. $(".FormElement", frm).each(function () {
  8958. if (a1.indexOf(this.name) === -1) {
  8959. var tv = $(this).val(), tt = $(this).get(0).type;
  8960. if (tt === 'checkbox') {
  8961. if (!$(this).is(":checked")) {
  8962. tv = $(this).attr("offval");
  8963. }
  8964. } else if (tt === 'select-multiple') {
  8965. tv = tv.join(",");
  8966. } else if (tt === 'radio') {
  8967. if (a2.hasOwnProperty(this.name)) {
  8968. return true;
  8969. } else {
  8970. a2[this.name] = ($(this).attr("offval") === undefined) ? "off" : $(this).attr("offval");
  8971. }
  8972. }
  8973. $t.p.savedData[this.name] = tv;
  8974. }
  8975. });
  8976. for (var i in a2) {
  8977. if (a2.hasOwnProperty(i)) {
  8978. var val = $('input[name="' + i + '"]:checked', frm).val();
  8979. $t.p.savedData[i] = (val !== undefined) ? val : a2[i];
  8980. }
  8981. }
  8982. }
  8983. }
  8984. var dh = isNaN(rp_ge[$(this)[0].p.id].dataheight) ? rp_ge[$(this)[0].p.id].dataheight : rp_ge[$(this)[0].p.id].dataheight + "px",
  8985. dw = isNaN(rp_ge[$(this)[0].p.id].datawidth) ? rp_ge[$(this)[0].p.id].datawidth : rp_ge[$(this)[0].p.id].datawidth + "px",
  8986. frm = $("<form name='FormPost' id='" + frmgr + "' class='FormGrid' onSubmit='return false;' style='width:" + dw + ";height:" + dh + ";'></form>").data("disabled", false),
  8987. tbl;
  8988. if (templ) {
  8989. tbl = parseTemplate(rp_ge[$(this)[0].p.id].template);
  8990. frmtb2 = frmtb;
  8991. } else {
  8992. tbl = $("<table id='" + frmtborg + "' class='EditTable ui-common-table'><tbody></tbody></table>");
  8993. frmtb2 = frmtb + "_2";
  8994. }
  8995. frmgr = "#" + $.jgrid.jqID(frmgr);
  8996. // errors
  8997. $(frm).append("<div class='FormError " + commonstyle.error + "' style='display:none;'></div>");
  8998. // topinfo
  8999. $(frm).append("<div class='tinfo topinfo'>" + rp_ge[$t.p.id].topinfo + "</div>");
  9000. $($t.p.colModel).each(function () {
  9001. var fmto = this.formoptions;
  9002. maxCols = Math.max(maxCols, fmto ? fmto.colpos || 0 : 0);
  9003. maxRows = Math.max(maxRows, fmto ? fmto.rowpos || 0 : 0);
  9004. });
  9005. $(frm).append(tbl);
  9006. showFrm = $($t).triggerHandler("jqGridAddEditBeforeInitData", [frm, frmoper]);
  9007. if (showFrm === undefined) {
  9008. showFrm = true;
  9009. }
  9010. if (showFrm && $.isFunction(rp_ge[$t.p.id].beforeInitData)) {
  9011. showFrm = rp_ge[$t.p.id].beforeInitData.call($t, frm, frmoper);
  9012. }
  9013. if (showFrm === false) { return; }
  9014. restoreInline();
  9015. // set the id.
  9016. // use carefull only to change here colproperties.
  9017. // create data
  9018. createData(rowid, $t, tbl, maxCols);
  9019. // buttons at footer
  9020. var rtlb = $t.p.direction === "rtl" ? true : false,
  9021. bp = rtlb ? "nData" : "pData",
  9022. bn = rtlb ? "pData" : "nData";
  9023. var bP = "<a id='" + bp + "' class='fm-button " + commonstyle.button + "'><span class='" + commonstyle.icon_base + " " + styles.icon_prev + "'></span></a>",
  9024. bN = "<a id='" + bn + "' class='fm-button " + commonstyle.button + "'><span class='" + commonstyle.icon_base + " " + styles.icon_next + "'></span></a>",
  9025. bS = "<a id='sData' class='fm-button " + commonstyle.button + "'>" + p.bSubmit + "</a>",
  9026. bC = "<a id='cData' class='fm-button " + commonstyle.button + "'>" + p.bCancel + "</a>";
  9027. var bt = "<table style='height:auto' class='EditTable ui-common-table' id='" + frmtborg + "_2'><tbody><tr><td colspan='2'><hr class='" + commonstyle.content + "' style='margin:1px'/></td></tr><tr id='Act_Buttons'><td class='navButton'>" + (rtlb ? bN + bP : bP + bN) + "</td><td class='EditButton'>" + bS + bC + "</td></tr>";
  9028. //bt += "<tr style='display:none' class='binfo'><td class='bottominfo' colspan='2'>"+rp_ge[$t.p.id].bottominfo+"</td></tr>";
  9029. bt += "</tbody></table>";
  9030. if (maxRows > 0) {
  9031. var sd = [];
  9032. $.each($(tbl)[0].rows, function (i, r) {
  9033. sd[i] = r;
  9034. });
  9035. sd.sort(function (a, b) {
  9036. if (a.rp > b.rp) { return 1; }
  9037. if (a.rp < b.rp) { return -1; }
  9038. return 0;
  9039. });
  9040. $.each(sd, function (index, row) {
  9041. $('tbody', tbl).append(row);
  9042. });
  9043. }
  9044. p.gbox = "#gbox_" + $.jgrid.jqID(gID);
  9045. var cle = false;
  9046. if (p.closeOnEscape === true) {
  9047. p.closeOnEscape = false;
  9048. cle = true;
  9049. }
  9050. var tms;
  9051. if (templ) {
  9052. $(frm).find("#pData").replaceWith(bP);
  9053. $(frm).find("#nData").replaceWith(bN);
  9054. $(frm).find("#sData").replaceWith(bS);
  9055. $(frm).find("#cData").replaceWith(bC);
  9056. tms = $("<div id=" + frmtborg + "></div>").append(frm);
  9057. } else {
  9058. tms = $("<div></div>").append(frm).append(bt);
  9059. }
  9060. $(frm).append("<div class='binfo topinfo bottominfo'>" + rp_ge[$t.p.id].bottominfo + "</div>");
  9061. $.jgrid.createModal(IDs, tms, rp_ge[$(this)[0].p.id], "#gview_" + $.jgrid.jqID($t.p.id), $("#gbox_" + $.jgrid.jqID($t.p.id))[0]);
  9062. if (rtlb) {
  9063. $("#pData, #nData", frmtb + "_2").css("float", "right");
  9064. $(".EditButton", frmtb + "_2").css("text-align", "left");
  9065. }
  9066. if (rp_ge[$t.p.id].topinfo) { $(".tinfo", frmgr).show(); }
  9067. if (rp_ge[$t.p.id].bottominfo) { $(".binfo", frmgr).show(); }
  9068. tms = null; bt = null;
  9069. $("#" + $.jgrid.jqID(IDs.themodal)).keydown(function (e) {
  9070. var wkey = e.target;
  9071. if ($(frmgr).data("disabled") === true) { return false; }//??
  9072. if (rp_ge[$t.p.id].savekey[0] === true && e.which === rp_ge[$t.p.id].savekey[1]) { // save
  9073. if (wkey.tagName !== "TEXTAREA") {
  9074. $("#sData", frmtb + "_2").trigger("click");
  9075. return false;
  9076. }
  9077. }
  9078. if (e.which === 27) {
  9079. if (!checkUpdates()) { return false; }
  9080. if (cle) { $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: p.gbox, jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form }); }
  9081. return false;
  9082. }
  9083. if (rp_ge[$t.p.id].navkeys[0] === true) {
  9084. if ($("#id_g", frmtb).val() === "_empty") { return true; }
  9085. if (e.which === rp_ge[$t.p.id].navkeys[1]) { //up
  9086. $("#pData", frmtb2).trigger("click");
  9087. return false;
  9088. }
  9089. if (e.which === rp_ge[$t.p.id].navkeys[2]) { //down
  9090. $("#nData", frmtb2).trigger("click");
  9091. return false;
  9092. }
  9093. }
  9094. });
  9095. if (p.checkOnUpdate) {
  9096. $("a.ui-jqdialog-titlebar-close span", "#" + $.jgrid.jqID(IDs.themodal)).removeClass("jqmClose");
  9097. $("a.ui-jqdialog-titlebar-close", "#" + $.jgrid.jqID(IDs.themodal)).unbind("click")
  9098. .click(function () {
  9099. if (!checkUpdates()) { return false; }
  9100. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  9101. return false;
  9102. });
  9103. }
  9104. p.saveicon = $.extend([true, "left", styles.icon_save], p.saveicon);
  9105. p.closeicon = $.extend([true, "left", styles.icon_close], p.closeicon);
  9106. // beforeinitdata after creation of the form
  9107. if (p.saveicon[0] === true) {
  9108. $("#sData", frmtb2).addClass(p.saveicon[1] === "right" ? 'fm-button-icon-right' : 'fm-button-icon-left')
  9109. .append("<span class='" + commonstyle.icon_base + " " + p.saveicon[2] + "'></span>");
  9110. }
  9111. if (p.closeicon[0] === true) {
  9112. $("#cData", frmtb2).addClass(p.closeicon[1] === "right" ? 'fm-button-icon-right' : 'fm-button-icon-left')
  9113. .append("<span class='" + commonstyle.icon_base + " " + p.closeicon[2] + "'></span>");
  9114. }
  9115. if (rp_ge[$t.p.id].checkOnSubmit || rp_ge[$t.p.id].checkOnUpdate) {
  9116. bS = "<a id='sNew' class='fm-button " + commonstyle.button + "' style='z-index:1002'>" + p.bYes + "</a>";
  9117. bN = "<a id='nNew' class='fm-button " + commonstyle.button + "' style='z-index:1002;margin-left:5px'>" + p.bNo + "</a>";
  9118. bC = "<a id='cNew' class='fm-button " + commonstyle.button + "' style='z-index:1002;margin-left:5px;'>" + p.bExit + "</a>";
  9119. var zI = p.zIndex || 999; zI++;
  9120. $("<div class='" + p.overlayClass + " jqgrid-overlay confirm' style='z-index:" + zI + ";display:none;'>&#160;" + "</div><div class='confirm ui-jqconfirm " + commonstyle.content + "' style='z-index:" + (zI + 1) + "'>" + p.saveData + "<br/><br/>" + bS + bN + bC + "</div>").insertAfter(frmgr);
  9121. $("#sNew", "#" + $.jgrid.jqID(IDs.themodal)).click(function () {
  9122. postIt();
  9123. $(frmgr).data("disabled", false);
  9124. $(".confirm", "#" + $.jgrid.jqID(IDs.themodal)).hide();
  9125. return false;
  9126. });
  9127. $("#nNew", "#" + $.jgrid.jqID(IDs.themodal)).click(function () {
  9128. $(".confirm", "#" + $.jgrid.jqID(IDs.themodal)).hide();
  9129. $(frmgr).data("disabled", false);
  9130. setTimeout(function () { $(":input:visible", frmgr)[0].focus(); }, 0);
  9131. return false;
  9132. });
  9133. $("#cNew", "#" + $.jgrid.jqID(IDs.themodal)).click(function () {
  9134. $(".confirm", "#" + $.jgrid.jqID(IDs.themodal)).hide();
  9135. $(frmgr).data("disabled", false);
  9136. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  9137. return false;
  9138. });
  9139. }
  9140. // here initform - only once
  9141. $($t).triggerHandler("jqGridAddEditInitializeForm", [$(frmgr), frmoper]);
  9142. if ($.isFunction(rp_ge[$t.p.id].onInitializeForm)) { rp_ge[$t.p.id].onInitializeForm.call($t, $(frmgr), frmoper); }
  9143. if (rowid === "_empty" || !rp_ge[$t.p.id].viewPagerButtons) { $("#pData,#nData", frmtb2).hide(); } else { $("#pData,#nData", frmtb2).show(); }
  9144. $($t).triggerHandler("jqGridAddEditBeforeShowForm", [$(frmgr), frmoper]);
  9145. if ($.isFunction(rp_ge[$t.p.id].beforeShowForm)) { rp_ge[$t.p.id].beforeShowForm.call($t, $(frmgr), frmoper); }
  9146. syncSavedData();
  9147. $("#" + $.jgrid.jqID(IDs.themodal)).data("onClose", rp_ge[$t.p.id].onClose);
  9148. $.jgrid.viewModal("#" + $.jgrid.jqID(IDs.themodal), {
  9149. gbox: "#gbox_" + $.jgrid.jqID(gID),
  9150. jqm: p.jqModal,
  9151. overlay: p.overlay,
  9152. modal: p.modal,
  9153. overlayClass: p.overlayClass,
  9154. focusField: p.focusField,
  9155. onHide: function (h) {
  9156. var fh = $('#editmod' + gID)[0].style.height,
  9157. fw = $('#editmod' + gID)[0].style.width;
  9158. if (fh.indexOf("px") > -1) {
  9159. fh = parseFloat(fh);
  9160. }
  9161. if (fw.indexOf("px") > -1) {
  9162. fw = parseFloat(fw);
  9163. }
  9164. $($t).data("formProp", {
  9165. top: parseFloat($(h.w).css("top")),
  9166. left: parseFloat($(h.w).css("left")),
  9167. width: fw,
  9168. height: fh,
  9169. dataheight: $(frmgr).height(),
  9170. datawidth: $(frmgr).width()
  9171. });
  9172. h.w.remove();
  9173. if (h.o) { h.o.remove(); }
  9174. }
  9175. });
  9176. if (!closeovrl) {
  9177. $("." + $.jgrid.jqID(p.overlayClass)).click(function () {
  9178. if (!checkUpdates()) { return false; }
  9179. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  9180. return false;
  9181. });
  9182. }
  9183. $(".fm-button", "#" + $.jgrid.jqID(IDs.themodal)).hover(
  9184. function () { $(this).addClass(commonstyle.hover); },
  9185. function () { $(this).removeClass(commonstyle.hover); }
  9186. );
  9187. $("#sData", frmtb2).click(function () {
  9188. postdata = {};
  9189. $(".FormError", frmgr).hide();
  9190. // all depend on ret array
  9191. //ret[0] - succes
  9192. //ret[1] - msg if not succes
  9193. //ret[2] - the id that will be set if reload after submit false
  9194. getFormData();
  9195. if (postdata[$t.p.id + "_id"] === "_empty") { postIt(); }
  9196. else if (p.checkOnSubmit === true) {
  9197. diff = compareData(postdata, $t.p.savedData);
  9198. if (diff) {
  9199. $(frmgr).data("disabled", true);
  9200. $(".confirm", "#" + $.jgrid.jqID(IDs.themodal)).show();
  9201. } else {
  9202. postIt();
  9203. }
  9204. } else {
  9205. postIt();
  9206. }
  9207. return false;
  9208. });
  9209. $("#cData", frmtb2).click(function () {
  9210. if (!checkUpdates()) { return false; }
  9211. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  9212. return false;
  9213. });
  9214. $("#nData", frmtb2).click(function () {
  9215. if (!checkUpdates()) { return false; }
  9216. $(".FormError", frmgr).hide();
  9217. var npos = getCurrPos();
  9218. npos[0] = parseInt(npos[0], 10);
  9219. if (npos[0] !== -1 && npos[1][npos[0] + 1]) {
  9220. $($t).triggerHandler("jqGridAddEditClickPgButtons", ['next', $(frmgr), npos[1][npos[0]]]);
  9221. var nposret;
  9222. if ($.isFunction(p.onclickPgButtons)) {
  9223. nposret = p.onclickPgButtons.call($t, 'next', $(frmgr), npos[1][npos[0]]);
  9224. if (nposret !== undefined && nposret === false) { return false; }
  9225. }
  9226. if ($("#" + $.jgrid.jqID(npos[1][npos[0] + 1])).hasClass(commonstyle.disabled)) { return false; }
  9227. fillData(npos[1][npos[0] + 1], $t, frmgr);
  9228. if (!($t.p.multiselect && rp_ge[$t.p.id].editselected)) {
  9229. $($t).jqGrid("setSelection", npos[1][npos[0] + 1]);
  9230. }
  9231. $($t).triggerHandler("jqGridAddEditAfterClickPgButtons", ['next', $(frmgr), npos[1][npos[0]]]);
  9232. if ($.isFunction(p.afterclickPgButtons)) {
  9233. p.afterclickPgButtons.call($t, 'next', $(frmgr), npos[1][npos[0] + 1]);
  9234. }
  9235. syncSavedData();
  9236. updateNav(npos[0] + 1, npos);
  9237. }
  9238. return false;
  9239. });
  9240. $("#pData", frmtb2).click(function () {
  9241. if (!checkUpdates()) { return false; }
  9242. $(".FormError", frmgr).hide();
  9243. var ppos = getCurrPos();
  9244. if (ppos[0] !== -1 && ppos[1][ppos[0] - 1]) {
  9245. $($t).triggerHandler("jqGridAddEditClickPgButtons", ['prev', $(frmgr), ppos[1][ppos[0]]]);
  9246. var pposret;
  9247. if ($.isFunction(p.onclickPgButtons)) {
  9248. pposret = p.onclickPgButtons.call($t, 'prev', $(frmgr), ppos[1][ppos[0]]);
  9249. if (pposret !== undefined && pposret === false) { return false; }
  9250. }
  9251. if ($("#" + $.jgrid.jqID(ppos[1][ppos[0] - 1])).hasClass(commonstyle.disabled)) { return false; }
  9252. fillData(ppos[1][ppos[0] - 1], $t, frmgr);
  9253. if (!($t.p.multiselect && rp_ge[$t.p.id].editselected)) {
  9254. $($t).jqGrid("setSelection", ppos[1][ppos[0] - 1]);
  9255. }
  9256. $($t).triggerHandler("jqGridAddEditAfterClickPgButtons", ['prev', $(frmgr), ppos[1][ppos[0]]]);
  9257. if ($.isFunction(p.afterclickPgButtons)) {
  9258. p.afterclickPgButtons.call($t, 'prev', $(frmgr), ppos[1][ppos[0] - 1]);
  9259. }
  9260. syncSavedData();
  9261. updateNav(ppos[0] - 1, ppos);
  9262. }
  9263. return false;
  9264. });
  9265. $($t).triggerHandler("jqGridAddEditAfterShowForm", [$(frmgr), frmoper]);
  9266. if ($.isFunction(rp_ge[$t.p.id].afterShowForm)) { rp_ge[$t.p.id].afterShowForm.call($t, $(frmgr), frmoper); }
  9267. var posInit = getCurrPos();
  9268. updateNav(posInit[0], posInit);
  9269. });
  9270. },
  9271. viewGridRow: function (rowid, p) {
  9272. var regional = $.jgrid.getRegional(this[0], 'view'),
  9273. currstyle = this[0].p.styleUI,
  9274. styles = $.jgrid.styleUI[currstyle].formedit,
  9275. commonstyle = $.jgrid.styleUI[currstyle].common;
  9276. p = $.extend(true, {
  9277. top: 0,
  9278. left: 0,
  9279. width: 500,
  9280. datawidth: 'auto',
  9281. height: 'auto',
  9282. dataheight: 'auto',
  9283. modal: false,
  9284. overlay: 30,
  9285. drag: true,
  9286. resize: true,
  9287. jqModal: true,
  9288. closeOnEscape: false,
  9289. labelswidth: '30%',
  9290. closeicon: [],
  9291. navkeys: [false, 38, 40],
  9292. onClose: null,
  9293. beforeShowForm: null,
  9294. beforeInitData: null,
  9295. viewPagerButtons: true,
  9296. recreateForm: false,
  9297. removemodal: true,
  9298. form: 'view'
  9299. }, regional, p || {});
  9300. rp_ge[$(this)[0].p.id] = p;
  9301. return this.each(function () {
  9302. var $t = this;
  9303. if (!$t.grid || !rowid) { return; }
  9304. var gID = $t.p.id,
  9305. frmgr = "ViewGrid_" + $.jgrid.jqID(gID), frmtb = "ViewTbl_" + $.jgrid.jqID(gID),
  9306. frmgr_id = "ViewGrid_" + gID, frmtb_id = "ViewTbl_" + gID,
  9307. IDs = { themodal: 'viewmod' + gID, modalhead: 'viewhd' + gID, modalcontent: 'viewcnt' + gID, scrollelm: frmgr },
  9308. onBeforeInit = $.isFunction(rp_ge[$t.p.id].beforeInitData) ? rp_ge[$t.p.id].beforeInitData : false,
  9309. showFrm = true,
  9310. maxCols = 1, maxRows = 0;
  9311. rp_ge[$t.p.id].styleUI = $t.p.styleUI || 'jQueryUI';
  9312. if (!p.recreateForm) {
  9313. if ($($t).data("viewProp")) {
  9314. $.extend(rp_ge[$(this)[0].p.id], $($t).data("viewProp"));
  9315. }
  9316. }
  9317. function focusaref() { //Sfari 3 issues
  9318. if (rp_ge[$t.p.id].closeOnEscape === true || rp_ge[$t.p.id].navkeys[0] === true) {
  9319. setTimeout(function () { $(".ui-jqdialog-titlebar-close", "#" + $.jgrid.jqID(IDs.modalhead)).attr("tabindex", "-1").focus(); }, 0);
  9320. }
  9321. }
  9322. function createData(rowid, obj, tb, maxcols) {
  9323. var nm, hc, trdata, cnt = 0, tmp, dc, retpos = [], ind = false, i,
  9324. tdtmpl = "<td class='CaptionTD form-view-label " + commonstyle.content + "' width='" + p.labelswidth + "'>&#160;</td><td class='DataTD form-view-data ui-helper-reset " + commonstyle.content + "'>&#160;</td>", tmpl = "",
  9325. tdtmpl2 = "<td class='CaptionTD form-view-label " + commonstyle.content + "'>&#160;</td><td class='DataTD form-view-data " + commonstyle.content + "'>&#160;</td>",
  9326. fmtnum = ['integer', 'number', 'currency'], max1 = 0, max2 = 0, maxw, setme, viewfld;
  9327. for (i = 1; i <= maxcols; i++) {
  9328. tmpl += i === 1 ? tdtmpl : tdtmpl2;
  9329. }
  9330. // find max number align rigth with property formatter
  9331. $(obj.p.colModel).each(function () {
  9332. if (this.editrules && this.editrules.edithidden === true) {
  9333. hc = false;
  9334. } else {
  9335. hc = this.hidden === true ? true : false;
  9336. }
  9337. if (!hc && this.align === 'right') {
  9338. if (this.formatter && $.inArray(this.formatter, fmtnum) !== -1) {
  9339. max1 = Math.max(max1, parseInt(this.width, 10));
  9340. } else {
  9341. max2 = Math.max(max2, parseInt(this.width, 10));
  9342. }
  9343. }
  9344. });
  9345. maxw = max1 !== 0 ? max1 : max2 !== 0 ? max2 : 0;
  9346. ind = $(obj).jqGrid("getInd", rowid);
  9347. $(obj.p.colModel).each(function (i) {
  9348. nm = this.name;
  9349. setme = false;
  9350. // hidden fields are included in the form
  9351. if (this.editrules && this.editrules.edithidden === true) {
  9352. hc = false;
  9353. } else {
  9354. hc = this.hidden === true ? true : false;
  9355. }
  9356. dc = hc ? "style='display:none'" : "";
  9357. viewfld = (typeof this.viewable !== 'boolean') ? true : this.viewable;
  9358. if (nm !== 'cb' && nm !== 'subgrid' && nm !== 'rn' && viewfld) {
  9359. if (ind === false) {
  9360. tmp = "";
  9361. } else {
  9362. if (nm === obj.p.ExpandColumn && obj.p.treeGrid === true) {
  9363. tmp = $("td:eq(" + i + ")", obj.rows[ind]).text();
  9364. } else {
  9365. tmp = $("td:eq(" + i + ")", obj.rows[ind]).html();
  9366. }
  9367. }
  9368. setme = this.align === 'right' && maxw !== 0 ? true : false;
  9369. var frmopt = $.extend({}, { rowabove: false, rowcontent: '' }, this.formoptions || {}),
  9370. rp = parseInt(frmopt.rowpos, 10) || cnt + 1,
  9371. cp = parseInt((parseInt(frmopt.colpos, 10) || 1) * 2, 10);
  9372. if (frmopt.rowabove) {
  9373. var newdata = $("<tr><td class='contentinfo' colspan='" + (maxcols * 2) + "'>" + frmopt.rowcontent + "</td></tr>");
  9374. $(tb).append(newdata);
  9375. newdata[0].rp = rp;
  9376. }
  9377. trdata = $(tb).find("tr[rowpos=" + rp + "]");
  9378. if (trdata.length === 0) {
  9379. trdata = $("<tr " + dc + " rowpos='" + rp + "'></tr>").addClass("FormData").attr("id", "trv_" + nm);
  9380. $(trdata).append(tmpl);
  9381. $(tb).append(trdata);
  9382. trdata[0].rp = rp;
  9383. }
  9384. $("td:eq(" + (cp - 2) + ")", trdata[0]).html('<b>' + (frmopt.label === undefined ? obj.p.colNames[i] : frmopt.label) + '</b>');
  9385. $("td:eq(" + (cp - 1) + ")", trdata[0]).append("<span>" + tmp + "</span>").attr("id", "v_" + nm);
  9386. if (setme) {
  9387. $("td:eq(" + (cp - 1) + ") span", trdata[0]).css({ 'text-align': 'right', width: maxw + "px" });
  9388. }
  9389. retpos[cnt] = i;
  9390. cnt++;
  9391. }
  9392. });
  9393. if (cnt > 0) {
  9394. var idrow = $("<tr class='FormData' style='display:none'><td class='CaptionTD'></td><td colspan='" + (maxcols * 2 - 1) + "' class='DataTD'><input class='FormElement' id='id_g' type='text' name='id' value='" + rowid + "'/></td></tr>");
  9395. idrow[0].rp = cnt + 99;
  9396. $(tb).append(idrow);
  9397. }
  9398. return retpos;
  9399. }
  9400. function fillData(rowid, obj) {
  9401. var nm, hc, cnt = 0, tmp, trv;
  9402. trv = $(obj).jqGrid("getInd", rowid, true);
  9403. if (!trv) { return; }
  9404. $('td', trv).each(function (i) {
  9405. nm = obj.p.colModel[i].name;
  9406. // hidden fields are included in the form
  9407. if (obj.p.colModel[i].editrules && obj.p.colModel[i].editrules.edithidden === true) {
  9408. hc = false;
  9409. } else {
  9410. hc = obj.p.colModel[i].hidden === true ? true : false;
  9411. }
  9412. if (nm !== 'cb' && nm !== 'subgrid' && nm !== 'rn') {
  9413. if (nm === obj.p.ExpandColumn && obj.p.treeGrid === true) {
  9414. tmp = $(this).text();
  9415. } else {
  9416. tmp = $(this).html();
  9417. }
  9418. nm = $.jgrid.jqID("v_" + nm);
  9419. $("#" + nm + " span", "#" + frmtb).html(tmp);
  9420. if (hc) { $("#" + nm, "#" + frmtb).parents("tr:first").hide(); }
  9421. cnt++;
  9422. }
  9423. });
  9424. if (cnt > 0) { $("#id_g", "#" + frmtb).val(rowid); }
  9425. }
  9426. function updateNav(cr, posarr) {
  9427. var totr = posarr[1].length - 1;
  9428. if (cr === 0) {
  9429. $("#pData", "#" + frmtb + "_2").addClass(commonstyle.disabled);
  9430. } else if (posarr[1][cr - 1] !== undefined && $("#" + $.jgrid.jqID(posarr[1][cr - 1])).hasClass(commonstyle.disabled)) {
  9431. $("#pData", frmtb + "_2").addClass(commonstyle.disabled);
  9432. } else {
  9433. $("#pData", "#" + frmtb + "_2").removeClass(commonstyle.disabled);
  9434. }
  9435. if (cr === totr) {
  9436. $("#nData", "#" + frmtb + "_2").addClass(commonstyle.disabled);
  9437. } else if (posarr[1][cr + 1] !== undefined && $("#" + $.jgrid.jqID(posarr[1][cr + 1])).hasClass(commonstyle.disabled)) {
  9438. $("#nData", frmtb + "_2").addClass(commonstyle.disabled);
  9439. } else {
  9440. $("#nData", "#" + frmtb + "_2").removeClass(commonstyle.disabled);
  9441. }
  9442. }
  9443. function getCurrPos() {
  9444. var rowsInGrid = $($t).jqGrid("getDataIDs"),
  9445. selrow = $("#id_g", "#" + frmtb).val(),
  9446. pos = $.inArray(selrow, rowsInGrid);
  9447. return [pos, rowsInGrid];
  9448. }
  9449. var dh = isNaN(rp_ge[$(this)[0].p.id].dataheight) ? rp_ge[$(this)[0].p.id].dataheight : rp_ge[$(this)[0].p.id].dataheight + "px",
  9450. dw = isNaN(rp_ge[$(this)[0].p.id].datawidth) ? rp_ge[$(this)[0].p.id].datawidth : rp_ge[$(this)[0].p.id].datawidth + "px",
  9451. frm = $("<form name='FormPost' id='" + frmgr_id + "' class='FormGrid' style='width:" + dw + ";height:" + dh + ";'></form>"),
  9452. tbl = $("<table id='" + frmtb_id + "' class='EditTable ViewTable'><tbody></tbody></table>");
  9453. $($t.p.colModel).each(function () {
  9454. var fmto = this.formoptions;
  9455. maxCols = Math.max(maxCols, fmto ? fmto.colpos || 0 : 0);
  9456. maxRows = Math.max(maxRows, fmto ? fmto.rowpos || 0 : 0);
  9457. });
  9458. // set the id.
  9459. $(frm).append(tbl);
  9460. if (onBeforeInit) {
  9461. showFrm = onBeforeInit.call($t, frm);
  9462. if (showFrm === undefined) {
  9463. showFrm = true;
  9464. }
  9465. }
  9466. if (showFrm === false) { return; }
  9467. createData(rowid, $t, tbl, maxCols);
  9468. var rtlb = $t.p.direction === "rtl" ? true : false,
  9469. bp = rtlb ? "nData" : "pData",
  9470. bn = rtlb ? "pData" : "nData",
  9471. // buttons at footer
  9472. bP = "<a id='" + bp + "' class='fm-button " + commonstyle.button + "'><span class='" + commonstyle.icon_base + " " + styles.icon_prev + "'></span></a>",
  9473. bN = "<a id='" + bn + "' class='fm-button " + commonstyle.button + "'><span class='" + commonstyle.icon_base + " " + styles.icon_next + "'></span></a>",
  9474. bC = "<a id='cData' class='fm-button " + commonstyle.button + "'>" + p.bClose + "</a>";
  9475. if (maxRows > 0) {
  9476. var sd = [];
  9477. $.each($(tbl)[0].rows, function (i, r) {
  9478. sd[i] = r;
  9479. });
  9480. sd.sort(function (a, b) {
  9481. if (a.rp > b.rp) { return 1; }
  9482. if (a.rp < b.rp) { return -1; }
  9483. return 0;
  9484. });
  9485. $.each(sd, function (index, row) {
  9486. $('tbody', tbl).append(row);
  9487. });
  9488. }
  9489. p.gbox = "#gbox_" + $.jgrid.jqID(gID);
  9490. var bt = $("<div></div>").append(frm).append("<table border='0' class='EditTable' id='" + frmtb + "_2'><tbody><tr id='Act_Buttons'><td class='navButton' width='" + p.labelswidth + "'>" + (rtlb ? bN + bP : bP + bN) + "</td><td class='EditButton'>" + bC + "</td></tr></tbody></table>");
  9491. $.jgrid.createModal(IDs, bt, rp_ge[$(this)[0].p.id], "#gview_" + $.jgrid.jqID($t.p.id), $("#gview_" + $.jgrid.jqID($t.p.id))[0]);
  9492. if (rtlb) {
  9493. $("#pData, #nData", "#" + frmtb + "_2").css("float", "right");
  9494. $(".EditButton", "#" + frmtb + "_2").css("text-align", "left");
  9495. }
  9496. if (!p.viewPagerButtons) { $("#pData, #nData", "#" + frmtb + "_2").hide(); }
  9497. bt = null;
  9498. $("#" + IDs.themodal).keydown(function (e) {
  9499. if (e.which === 27) {
  9500. if (rp_ge[$t.p.id].closeOnEscape) { $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: p.gbox, jqm: p.jqModal, onClose: p.onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form }); }
  9501. return false;
  9502. }
  9503. if (p.navkeys[0] === true) {
  9504. if (e.which === p.navkeys[1]) { //up
  9505. $("#pData", "#" + frmtb + "_2").trigger("click");
  9506. return false;
  9507. }
  9508. if (e.which === p.navkeys[2]) { //down
  9509. $("#nData", "#" + frmtb + "_2").trigger("click");
  9510. return false;
  9511. }
  9512. }
  9513. });
  9514. p.closeicon = $.extend([true, "left", styles.icon_close], p.closeicon);
  9515. if (p.closeicon[0] === true) {
  9516. $("#cData", "#" + frmtb + "_2").addClass(p.closeicon[1] === "right" ? 'fm-button-icon-right' : 'fm-button-icon-left')
  9517. .append("<span class='" + commonstyle.icon_base + " " + p.closeicon[2] + "'></span>");
  9518. }
  9519. if ($.isFunction(p.beforeShowForm)) { p.beforeShowForm.call($t, $("#" + frmgr)); }
  9520. $.jgrid.viewModal("#" + $.jgrid.jqID(IDs.themodal), {
  9521. gbox: "#gbox_" + $.jgrid.jqID(gID),
  9522. jqm: p.jqModal,
  9523. overlay: p.overlay,
  9524. modal: p.modal,
  9525. onHide: function (h) {
  9526. $($t).data("viewProp", {
  9527. top: parseFloat($(h.w).css("top")),
  9528. left: parseFloat($(h.w).css("left")),
  9529. width: $(h.w).width(),
  9530. height: $(h.w).height(),
  9531. dataheight: $("#" + frmgr).height(),
  9532. datawidth: $("#" + frmgr).width()
  9533. });
  9534. h.w.remove();
  9535. if (h.o) { h.o.remove(); }
  9536. }
  9537. });
  9538. $(".fm-button:not(." + commonstyle.disabled + ")", "#" + frmtb + "_2").hover(
  9539. function () { $(this).addClass(commonstyle.hover); },
  9540. function () { $(this).removeClass(commonstyle.hover); }
  9541. );
  9542. focusaref();
  9543. $("#cData", "#" + frmtb + "_2").click(function () {
  9544. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: p.onClose, removemodal: rp_ge[$t.p.id].removemodal, formprop: !rp_ge[$t.p.id].recreateForm, form: rp_ge[$t.p.id].form });
  9545. return false;
  9546. });
  9547. $("#nData", "#" + frmtb + "_2").click(function () {
  9548. $("#FormError", "#" + frmtb).hide();
  9549. var npos = getCurrPos();
  9550. npos[0] = parseInt(npos[0], 10);
  9551. if (npos[0] !== -1 && npos[1][npos[0] + 1]) {
  9552. if ($.isFunction(p.onclickPgButtons)) {
  9553. p.onclickPgButtons.call($t, 'next', $("#" + frmgr), npos[1][npos[0]]);
  9554. }
  9555. fillData(npos[1][npos[0] + 1], $t);
  9556. $($t).jqGrid("setSelection", npos[1][npos[0] + 1]);
  9557. if ($.isFunction(p.afterclickPgButtons)) {
  9558. p.afterclickPgButtons.call($t, 'next', $("#" + frmgr), npos[1][npos[0] + 1]);
  9559. }
  9560. updateNav(npos[0] + 1, npos);
  9561. }
  9562. focusaref();
  9563. return false;
  9564. });
  9565. $("#pData", "#" + frmtb + "_2").click(function () {
  9566. $("#FormError", "#" + frmtb).hide();
  9567. var ppos = getCurrPos();
  9568. if (ppos[0] !== -1 && ppos[1][ppos[0] - 1]) {
  9569. if ($.isFunction(p.onclickPgButtons)) {
  9570. p.onclickPgButtons.call($t, 'prev', $("#" + frmgr), ppos[1][ppos[0]]);
  9571. }
  9572. fillData(ppos[1][ppos[0] - 1], $t);
  9573. $($t).jqGrid("setSelection", ppos[1][ppos[0] - 1]);
  9574. if ($.isFunction(p.afterclickPgButtons)) {
  9575. p.afterclickPgButtons.call($t, 'prev', $("#" + frmgr), ppos[1][ppos[0] - 1]);
  9576. }
  9577. updateNav(ppos[0] - 1, ppos);
  9578. }
  9579. focusaref();
  9580. return false;
  9581. });
  9582. var posInit = getCurrPos();
  9583. updateNav(posInit[0], posInit);
  9584. });
  9585. },
  9586. delGridRow: function (rowids, p) {
  9587. var regional = $.jgrid.getRegional(this[0], 'del'),
  9588. currstyle = this[0].p.styleUI,
  9589. styles = $.jgrid.styleUI[currstyle].formedit,
  9590. commonstyle = $.jgrid.styleUI[currstyle].common;
  9591. p = $.extend(true, {
  9592. top: 0,
  9593. left: 0,
  9594. width: 240,
  9595. height: 'auto',
  9596. dataheight: 'auto',
  9597. modal: false,
  9598. overlay: 30,
  9599. drag: true,
  9600. resize: true,
  9601. url: '',
  9602. mtype: "POST",
  9603. reloadAfterSubmit: true,
  9604. beforeShowForm: null,
  9605. beforeInitData: null,
  9606. afterShowForm: null,
  9607. beforeSubmit: null,
  9608. onclickSubmit: null,
  9609. afterSubmit: null,
  9610. jqModal: true,
  9611. closeOnEscape: false,
  9612. delData: {},
  9613. delicon: [],
  9614. cancelicon: [],
  9615. onClose: null,
  9616. ajaxDelOptions: {},
  9617. processing: false,
  9618. serializeDelData: null,
  9619. useDataProxy: false
  9620. }, regional, p || {});
  9621. rp_ge[$(this)[0].p.id] = p;
  9622. return this.each(function () {
  9623. var $t = this;
  9624. if (!$t.grid) { return; }
  9625. if (!rowids) { return; }
  9626. var onBeforeShow = $.isFunction(rp_ge[$t.p.id].beforeShowForm),
  9627. onAfterShow = $.isFunction(rp_ge[$t.p.id].afterShowForm),
  9628. onBeforeInit = $.isFunction(rp_ge[$t.p.id].beforeInitData) ? rp_ge[$t.p.id].beforeInitData : false,
  9629. gID = $t.p.id, onCS = {},
  9630. showFrm = true,
  9631. dtbl = "DelTbl_" + $.jgrid.jqID(gID), postd, idname, opers, oper,
  9632. dtbl_id = "DelTbl_" + gID,
  9633. IDs = { themodal: 'delmod' + gID, modalhead: 'delhd' + gID, modalcontent: 'delcnt' + gID, scrollelm: dtbl };
  9634. rp_ge[$t.p.id].styleUI = $t.p.styleUI || 'jQueryUI';
  9635. if ($.isArray(rowids)) { rowids = rowids.join(); }
  9636. if ($("#" + $.jgrid.jqID(IDs.themodal))[0] !== undefined) {
  9637. if (onBeforeInit) {
  9638. showFrm = onBeforeInit.call($t, $("#" + dtbl));
  9639. if (showFrm === undefined) {
  9640. showFrm = true;
  9641. }
  9642. }
  9643. if (showFrm === false) { return; }
  9644. $("#DelData>td", "#" + dtbl).text(rowids);
  9645. $("#DelError", "#" + dtbl).hide();
  9646. if (rp_ge[$t.p.id].processing === true) {
  9647. rp_ge[$t.p.id].processing = false;
  9648. $("#dData", "#" + dtbl).removeClass(commonstyle.active);
  9649. }
  9650. if (onBeforeShow) { rp_ge[$t.p.id].beforeShowForm.call($t, $("#" + dtbl)); }
  9651. $.jgrid.viewModal("#" + $.jgrid.jqID(IDs.themodal), { gbox: "#gbox_" + $.jgrid.jqID(gID), jqm: rp_ge[$t.p.id].jqModal, jqM: false, overlay: rp_ge[$t.p.id].overlay, modal: rp_ge[$t.p.id].modal });
  9652. if (onAfterShow) { rp_ge[$t.p.id].afterShowForm.call($t, $("#" + dtbl)); }
  9653. } else {
  9654. var dh = isNaN(rp_ge[$t.p.id].dataheight) ? rp_ge[$t.p.id].dataheight : rp_ge[$t.p.id].dataheight + "px",
  9655. dw = isNaN(p.datawidth) ? p.datawidth : p.datawidth + "px",
  9656. tbl = "<div id='" + dtbl_id + "' class='formdata' style='width:" + dw + ";overflow:auto;position:relative;height:" + dh + ";'>";
  9657. tbl += "<table class='DelTable'><tbody>";
  9658. // error data
  9659. tbl += "<tr id='DelError' style='display:none'><td class='" + commonstyle.error + "'></td></tr>";
  9660. tbl += "<tr id='DelData' style='display:none'><td >" + rowids + "</td></tr>";
  9661. tbl += "<tr><td class=\"delmsg\" style=\"white-space:pre;\">" + rp_ge[$t.p.id].msg + "</td></tr><tr><td >&#160;</td></tr>";
  9662. // buttons at footer
  9663. tbl += "</tbody></table></div>";
  9664. var bS = "<a id='dData' class='fm-button " + commonstyle.button + "'>" + p.bSubmit + "</a>",
  9665. bC = "<a id='eData' class='fm-button " + commonstyle.button + "'>" + p.bCancel + "</a>";
  9666. tbl += "<table class='EditTable ui-common-table' id='" + dtbl + "_2'><tbody><tr><td><hr class='" + commonstyle.content + "' style='margin:1px'/></td></tr><tr><td class='DelButton EditButton'>" + bS + "&#160;" + bC + "</td></tr></tbody></table>";
  9667. p.gbox = "#gbox_" + $.jgrid.jqID(gID);
  9668. $.jgrid.createModal(IDs, tbl, rp_ge[$t.p.id], "#gview_" + $.jgrid.jqID($t.p.id), $("#gview_" + $.jgrid.jqID($t.p.id))[0]);
  9669. if (onBeforeInit) {
  9670. showFrm = onBeforeInit.call($t, $(tbl));
  9671. if (showFrm === undefined) {
  9672. showFrm = true;
  9673. }
  9674. }
  9675. if (showFrm === false) { return; }
  9676. $(".fm-button", "#" + dtbl + "_2").hover(
  9677. function () { $(this).addClass(commonstyle.hover); },
  9678. function () { $(this).removeClass(commonstyle.hover); }
  9679. );
  9680. p.delicon = $.extend([true, "left", styles.icon_del], rp_ge[$t.p.id].delicon);
  9681. p.cancelicon = $.extend([true, "left", styles.icon_cancel], rp_ge[$t.p.id].cancelicon);
  9682. if (p.delicon[0] === true) {
  9683. $("#dData", "#" + dtbl + "_2").addClass(p.delicon[1] === "right" ? 'fm-button-icon-right' : 'fm-button-icon-left')
  9684. .append("<span class='" + commonstyle.icon_base + " " + p.delicon[2] + "'></span>");
  9685. }
  9686. if (p.cancelicon[0] === true) {
  9687. $("#eData", "#" + dtbl + "_2").addClass(p.cancelicon[1] === "right" ? 'fm-button-icon-right' : 'fm-button-icon-left')
  9688. .append("<span class='" + commonstyle.icon_base + " " + p.cancelicon[2] + "'></span>");
  9689. }
  9690. $("#dData", "#" + dtbl + "_2").click(function () {
  9691. var ret = [true, ""], pk,
  9692. postdata = $("#DelData>td", "#" + dtbl).text(); //the pair is name=val1,val2,...
  9693. onCS = {};
  9694. if ($.isFunction(rp_ge[$t.p.id].onclickSubmit)) { onCS = rp_ge[$t.p.id].onclickSubmit.call($t, rp_ge[$t.p.id], postdata) || {}; }
  9695. if ($.isFunction(rp_ge[$t.p.id].beforeSubmit)) { ret = rp_ge[$t.p.id].beforeSubmit.call($t, postdata); }
  9696. if (ret[0] && !rp_ge[$t.p.id].processing) {
  9697. rp_ge[$t.p.id].processing = true;
  9698. opers = $t.p.prmNames;
  9699. postd = $.extend({}, rp_ge[$t.p.id].delData, onCS);
  9700. oper = opers.oper;
  9701. postd[oper] = opers.deloper;
  9702. idname = opers.id;
  9703. postdata = String(postdata).split(",");
  9704. if (!postdata.length) { return false; }
  9705. for (pk in postdata) {
  9706. if (postdata.hasOwnProperty(pk)) {
  9707. postdata[pk] = $.jgrid.stripPref($t.p.idPrefix, postdata[pk]);
  9708. }
  9709. }
  9710. postd[idname] = postdata.join();
  9711. $(this).addClass(commonstyle.active);
  9712. var ajaxOptions = $.extend({
  9713. url: rp_ge[$t.p.id].url || $($t).jqGrid('getGridParam', 'editurl'),
  9714. type: rp_ge[$t.p.id].mtype,
  9715. data: $.isFunction(rp_ge[$t.p.id].serializeDelData) ? rp_ge[$t.p.id].serializeDelData.call($t, postd) : postd,
  9716. complete: function (data, status) {
  9717. var i;
  9718. $("#dData", "#" + dtbl + "_2").removeClass(commonstyle.active);
  9719. if (data.status >= 300 && data.status !== 304) {
  9720. ret[0] = false;
  9721. if ($.isFunction(rp_ge[$t.p.id].errorTextFormat)) {
  9722. ret[1] = rp_ge[$t.p.id].errorTextFormat.call($t, data);
  9723. } else {
  9724. ret[1] = status + " Status: '" + data.statusText + "'. Error code: " + data.status;
  9725. }
  9726. } else {
  9727. // data is posted successful
  9728. // execute aftersubmit with the returned data from server
  9729. if ($.isFunction(rp_ge[$t.p.id].afterSubmit)) {
  9730. ret = rp_ge[$t.p.id].afterSubmit.call($t, data, postd);
  9731. }
  9732. }
  9733. if (ret[0] === false) {
  9734. $("#DelError>td", "#" + dtbl).html(ret[1]);
  9735. $("#DelError", "#" + dtbl).show();
  9736. } else {
  9737. if (rp_ge[$t.p.id].reloadAfterSubmit && $t.p.datatype !== "local") {
  9738. $($t).trigger("reloadGrid");
  9739. } else {
  9740. if ($t.p.treeGrid === true) {
  9741. try { $($t).jqGrid("delTreeNode", $t.p.idPrefix + postdata[0]); } catch (e) { }
  9742. } else {
  9743. for (i = 0; i < postdata.length; i++) {
  9744. $($t).jqGrid("delRowData", $t.p.idPrefix + postdata[i]);
  9745. }
  9746. }
  9747. $t.p.selrow = null;
  9748. $t.p.selarrrow = [];
  9749. }
  9750. if ($.isFunction(rp_ge[$t.p.id].afterComplete)) {
  9751. setTimeout(function () { rp_ge[$t.p.id].afterComplete.call($t, data, postdata); }, 500);
  9752. }
  9753. }
  9754. rp_ge[$t.p.id].processing = false;
  9755. if (ret[0]) { $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose }); }
  9756. }
  9757. }, $.jgrid.ajaxOptions, rp_ge[$t.p.id].ajaxDelOptions);
  9758. if (!ajaxOptions.url && !rp_ge[$t.p.id].useDataProxy) {
  9759. if ($.isFunction($t.p.dataProxy)) {
  9760. rp_ge[$t.p.id].useDataProxy = true;
  9761. } else {
  9762. ret[0] = false; ret[1] += " " + $.jgrid.getRegional($t, 'errors.nourl');
  9763. }
  9764. }
  9765. if (ret[0]) {
  9766. if (rp_ge[$t.p.id].useDataProxy) {
  9767. var dpret = $t.p.dataProxy.call($t, ajaxOptions, "del_" + $t.p.id);
  9768. if (dpret === undefined) {
  9769. dpret = [true, ""];
  9770. }
  9771. if (dpret[0] === false) {
  9772. ret[0] = false;
  9773. ret[1] = dpret[1] || "Error deleting the selected row!";
  9774. } else {
  9775. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: p.jqModal, onClose: rp_ge[$t.p.id].onClose });
  9776. }
  9777. }
  9778. else {
  9779. if (ajaxOptions.url === "clientArray") {
  9780. postd = ajaxOptions.data;
  9781. ajaxOptions.complete({ status: 200, statusText: '' }, '');
  9782. } else {
  9783. $.ajax(ajaxOptions);
  9784. }
  9785. }
  9786. }
  9787. }
  9788. if (ret[0] === false) {
  9789. $("#DelError>td", "#" + dtbl).html(ret[1]);
  9790. $("#DelError", "#" + dtbl).show();
  9791. }
  9792. return false;
  9793. });
  9794. $("#eData", "#" + dtbl + "_2").click(function () {
  9795. $.jgrid.hideModal("#" + $.jgrid.jqID(IDs.themodal), { gb: "#gbox_" + $.jgrid.jqID(gID), jqm: rp_ge[$t.p.id].jqModal, onClose: rp_ge[$t.p.id].onClose });
  9796. return false;
  9797. });
  9798. if (onBeforeShow) { rp_ge[$t.p.id].beforeShowForm.call($t, $("#" + dtbl)); }
  9799. $.jgrid.viewModal("#" + $.jgrid.jqID(IDs.themodal), { gbox: "#gbox_" + $.jgrid.jqID(gID), jqm: rp_ge[$t.p.id].jqModal, overlay: rp_ge[$t.p.id].overlay, modal: rp_ge[$t.p.id].modal });
  9800. if (onAfterShow) { rp_ge[$t.p.id].afterShowForm.call($t, $("#" + dtbl)); }
  9801. }
  9802. if (rp_ge[$t.p.id].closeOnEscape === true) {
  9803. setTimeout(function () { $(".ui-jqdialog-titlebar-close", "#" + $.jgrid.jqID(IDs.modalhead)).attr("tabindex", "-1").focus(); }, 0);
  9804. }
  9805. });
  9806. },
  9807. navGrid: function (elem, p, pEdit, pAdd, pDel, pSearch, pView) {
  9808. var regional = $.jgrid.getRegional(this[0], 'nav'),
  9809. currstyle = this[0].p.styleUI,
  9810. styles = $.jgrid.styleUI[currstyle].navigator,
  9811. commonstyle = $.jgrid.styleUI[currstyle].common;
  9812. p = $.extend({
  9813. edit: true,
  9814. editicon: styles.icon_edit_nav,
  9815. add: true,
  9816. addicon: styles.icon_add_nav,
  9817. del: true,
  9818. delicon: styles.icon_del_nav,
  9819. search: true,
  9820. searchicon: styles.icon_search_nav,
  9821. refresh: true,
  9822. refreshicon: styles.icon_refresh_nav,
  9823. refreshstate: 'firstpage',
  9824. view: false,
  9825. viewicon: styles.icon_view_nav,
  9826. position: "left",
  9827. closeOnEscape: true,
  9828. beforeRefresh: null,
  9829. afterRefresh: null,
  9830. cloneToTop: false,
  9831. alertwidth: 200,
  9832. alertheight: 'auto',
  9833. alerttop: null,
  9834. alertleft: null,
  9835. alertzIndex: null,
  9836. dropmenu: false,
  9837. navButtonText: ''
  9838. }, regional, p || {});
  9839. return this.each(function () {
  9840. if (this.p.navGrid) { return; }
  9841. var alertIDs = { themodal: 'alertmod_' + this.p.id, modalhead: 'alerthd_' + this.p.id, modalcontent: 'alertcnt_' + this.p.id },
  9842. $t = this, twd, tdw, o;
  9843. if (!$t.grid || typeof elem !== 'string') { return; }
  9844. if (!$($t).data('navGrid')) {
  9845. $($t).data('navGrid', p);
  9846. }
  9847. // speedoverhead, but usefull for future
  9848. o = $($t).data('navGrid');
  9849. if ($t.p.force_regional) {
  9850. o = $.extend(o, regional);
  9851. }
  9852. if ($("#" + alertIDs.themodal)[0] === undefined) {
  9853. if (!o.alerttop && !o.alertleft) {
  9854. if (window.innerWidth !== undefined) {
  9855. o.alertleft = window.innerWidth;
  9856. o.alerttop = window.innerHeight;
  9857. } else if (document.documentElement !== undefined && document.documentElement.clientWidth !== undefined && document.documentElement.clientWidth !== 0) {
  9858. o.alertleft = document.documentElement.clientWidth;
  9859. o.alerttop = document.documentElement.clientHeight;
  9860. } else {
  9861. o.alertleft = 1024;
  9862. o.alerttop = 768;
  9863. }
  9864. o.alertleft = o.alertleft / 2 - parseInt(o.alertwidth, 10) / 2;
  9865. o.alerttop = o.alerttop / 2 - 25;
  9866. }
  9867. $.jgrid.createModal(alertIDs,
  9868. "<div>" + o.alerttext + "</div><span tabindex='0'><span tabindex='-1' id='jqg_alrt'></span></span>",
  9869. {
  9870. gbox: "#gbox_" + $.jgrid.jqID($t.p.id),
  9871. jqModal: true,
  9872. drag: true,
  9873. resize: true,
  9874. caption: o.alertcap,
  9875. top: o.alerttop,
  9876. left: o.alertleft,
  9877. width: o.alertwidth,
  9878. height: o.alertheight,
  9879. closeOnEscape: o.closeOnEscape,
  9880. zIndex: o.alertzIndex,
  9881. styleUI: $t.p.styleUI
  9882. },
  9883. "#gview_" + $.jgrid.jqID($t.p.id),
  9884. $("#gbox_" + $.jgrid.jqID($t.p.id))[0],
  9885. true
  9886. );
  9887. }
  9888. var clone = 1, i,
  9889. onHoverIn = function () {
  9890. if (!$(this).hasClass(commonstyle.disabled)) {
  9891. $(this).addClass(commonstyle.hover);
  9892. }
  9893. },
  9894. onHoverOut = function () {
  9895. $(this).removeClass(commonstyle.hover);
  9896. };
  9897. if (o.cloneToTop && $t.p.toppager) { clone = 2; }
  9898. for (i = 0; i < clone; i++) {
  9899. var tbd,
  9900. navtbl = $("<table class='ui-pg-table navtable ui-common-table'><tbody><tr></tr></tbody></table>"),
  9901. sep = "<td class='ui-pg-button " + commonstyle.disabled + "' style='width:4px;'><span class='ui-separator'></span></td>",
  9902. pgid, elemids;
  9903. if (i === 0) {
  9904. pgid = elem;
  9905. elemids = $t.p.id;
  9906. if (pgid === $t.p.toppager) {
  9907. elemids += "_top";
  9908. clone = 1;
  9909. }
  9910. } else {
  9911. pgid = $t.p.toppager;
  9912. elemids = $t.p.id + "_top";
  9913. }
  9914. if ($t.p.direction === "rtl") {
  9915. $(navtbl).attr("dir", "rtl").css("float", "right");
  9916. }
  9917. pAdd = pAdd || {};
  9918. if (o.add) {
  9919. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  9920. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.addicon + "'></span>" + o.addtext + "</div>");
  9921. $("tr", navtbl).append(tbd);
  9922. $(tbd, navtbl)
  9923. .attr({ "title": o.addtitle || "", id: pAdd.id || "add_" + elemids })
  9924. .click(function () {
  9925. if (!$(this).hasClass(commonstyle.disabled)) {
  9926. if ($.isFunction(o.addfunc)) {
  9927. o.addfunc.call($t);
  9928. } else {
  9929. $($t).jqGrid("editGridRow", "new", pAdd);
  9930. }
  9931. }
  9932. return false;
  9933. }).hover(onHoverIn, onHoverOut);
  9934. tbd = null;
  9935. }
  9936. pEdit = pEdit || {};
  9937. if (o.edit) {
  9938. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  9939. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.editicon + "'></span>" + o.edittext + "</div>");
  9940. $("tr", navtbl).append(tbd);
  9941. $(tbd, navtbl)
  9942. .attr({ "title": o.edittitle || "", id: pEdit.id || "edit_" + elemids })
  9943. .click(function () {
  9944. if (!$(this).hasClass(commonstyle.disabled)) {
  9945. var sr = $t.p.selrow;
  9946. if (sr) {
  9947. if ($.isFunction(o.editfunc)) {
  9948. o.editfunc.call($t, sr);
  9949. } else {
  9950. $($t).jqGrid("editGridRow", sr, pEdit);
  9951. }
  9952. } else {
  9953. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true });
  9954. $("#jqg_alrt").focus();
  9955. }
  9956. }
  9957. return false;
  9958. }).hover(onHoverIn, onHoverOut);
  9959. tbd = null;
  9960. }
  9961. pView = pView || {};
  9962. if (o.view) {
  9963. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  9964. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.viewicon + "'></span>" + o.viewtext + "</div>");
  9965. $("tr", navtbl).append(tbd);
  9966. $(tbd, navtbl)
  9967. .attr({ "title": o.viewtitle || "", id: pView.id || "view_" + elemids })
  9968. .click(function () {
  9969. if (!$(this).hasClass(commonstyle.disabled)) {
  9970. var sr = $t.p.selrow;
  9971. if (sr) {
  9972. if ($.isFunction(o.viewfunc)) {
  9973. o.viewfunc.call($t, sr);
  9974. } else {
  9975. $($t).jqGrid("viewGridRow", sr, pView);
  9976. }
  9977. } else {
  9978. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true });
  9979. $("#jqg_alrt").focus();
  9980. }
  9981. }
  9982. return false;
  9983. }).hover(onHoverIn, onHoverOut);
  9984. tbd = null;
  9985. }
  9986. pDel = pDel || {};
  9987. if (o.del) {
  9988. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  9989. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.delicon + "'></span>" + o.deltext + "</div>");
  9990. $("tr", navtbl).append(tbd);
  9991. $(tbd, navtbl)
  9992. .attr({ "title": o.deltitle || "", id: pDel.id || "del_" + elemids })
  9993. .click(function () {
  9994. if (!$(this).hasClass(commonstyle.disabled)) {
  9995. var dr;
  9996. if ($t.p.multiselect) {
  9997. dr = $t.p.selarrrow;
  9998. if (dr.length === 0) { dr = null; }
  9999. } else {
  10000. dr = $t.p.selrow;
  10001. }
  10002. if (dr) {
  10003. if ($.isFunction(o.delfunc)) {
  10004. o.delfunc.call($t, dr);
  10005. } else {
  10006. $($t).jqGrid("delGridRow", dr, pDel);
  10007. }
  10008. } else {
  10009. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true }); $("#jqg_alrt").focus();
  10010. }
  10011. }
  10012. return false;
  10013. }).hover(onHoverIn, onHoverOut);
  10014. tbd = null;
  10015. }
  10016. if (o.add || o.edit || o.del || o.view) { $("tr", navtbl).append(sep); }
  10017. pSearch = pSearch || {};
  10018. if (o.search) {
  10019. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  10020. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.searchicon + "'></span>" + o.searchtext + "</div>");
  10021. $("tr", navtbl).append(tbd);
  10022. $(tbd, navtbl)
  10023. .attr({ "title": o.searchtitle || "", id: pSearch.id || "search_" + elemids })
  10024. .click(function () {
  10025. if (!$(this).hasClass(commonstyle.disabled)) {
  10026. if ($.isFunction(o.searchfunc)) {
  10027. o.searchfunc.call($t, pSearch);
  10028. } else {
  10029. $($t).jqGrid("searchGrid", pSearch);
  10030. }
  10031. }
  10032. return false;
  10033. }).hover(onHoverIn, onHoverOut);
  10034. if (pSearch.showOnLoad && pSearch.showOnLoad === true) {
  10035. $(tbd, navtbl).click();
  10036. }
  10037. tbd = null;
  10038. }
  10039. if (o.refresh) {
  10040. tbd = $("<td class='ui-pg-button " + commonstyle.cornerall + "'></td>");
  10041. $(tbd).append("<div class='ui-pg-div'><span class='" + commonstyle.icon_base + " " + o.refreshicon + "'></span>" + o.refreshtext + "</div>");
  10042. $("tr", navtbl).append(tbd);
  10043. $(tbd, navtbl)
  10044. .attr({ "title": o.refreshtitle || "", id: "refresh_" + elemids })
  10045. .click(function () {
  10046. if (!$(this).hasClass(commonstyle.disabled)) {
  10047. if ($.isFunction(o.beforeRefresh)) { o.beforeRefresh.call($t); }
  10048. $t.p.search = false;
  10049. $t.p.resetsearch = true;
  10050. try {
  10051. if (o.refreshstate !== 'currentfilter') {
  10052. var gID = $t.p.id;
  10053. $t.p.postData.filters = "";
  10054. try {
  10055. $("#fbox_" + $.jgrid.jqID(gID)).jqFilter('resetFilter');
  10056. } catch (ef) { }
  10057. if ($.isFunction($t.clearToolbar)) { $t.clearToolbar.call($t, false); }
  10058. }
  10059. } catch (e) { }
  10060. switch (o.refreshstate) {
  10061. case 'firstpage':
  10062. $($t).trigger("reloadGrid", [{ page: 1 }]);
  10063. break;
  10064. case 'current':
  10065. case 'currentfilter':
  10066. $($t).trigger("reloadGrid", [{ current: true }]);
  10067. break;
  10068. }
  10069. if ($.isFunction(o.afterRefresh)) { o.afterRefresh.call($t); }
  10070. }
  10071. return false;
  10072. }).hover(onHoverIn, onHoverOut);
  10073. tbd = null;
  10074. }
  10075. tdw = $(".ui-jqgrid").css("font-size") || "11px";
  10076. $('body').append("<div id='testpg2' class='ui-jqgrid " + $.jgrid.styleUI[currstyle].base.entrieBox + "' style='font-size:" + tdw + ";visibility:hidden;' ></div>");
  10077. twd = $(navtbl).clone().appendTo("#testpg2").width();
  10078. $("#testpg2").remove();
  10079. if ($t.p._nvtd) {
  10080. if (o.dropmenu) {
  10081. navtbl = null;
  10082. $($t).jqGrid('_buildNavMenu', pgid, elemids, p, pEdit, pAdd, pDel, pSearch, pView);
  10083. } else if (twd > $t.p._nvtd[0]) {
  10084. if ($t.p.responsive) {
  10085. navtbl = null;
  10086. $($t).jqGrid('_buildNavMenu', pgid, elemids, p, pEdit, pAdd, pDel, pSearch, pView);
  10087. } else {
  10088. $(pgid + "_" + o.position, pgid).append(navtbl).width(twd);
  10089. }
  10090. $t.p._nvtd[0] = twd;
  10091. } else {
  10092. $(pgid + "_" + o.position, pgid).append(navtbl);
  10093. }
  10094. $t.p._nvtd[1] = twd;
  10095. }
  10096. $t.p.navGrid = true;
  10097. }
  10098. if ($t.p.storeNavOptions) {
  10099. $t.p.navOptions = o;
  10100. $t.p.editOptions = pEdit;
  10101. $t.p.addOptions = pAdd;
  10102. $t.p.delOptions = pDel;
  10103. $t.p.searchOptions = pSearch;
  10104. $t.p.viewOptions = pView;
  10105. $t.p.navButtons = [];
  10106. }
  10107. });
  10108. },
  10109. navButtonAdd: function (elem, p) {
  10110. var currstyle = this[0].p.styleUI,
  10111. styles = $.jgrid.styleUI[currstyle].navigator;
  10112. p = $.extend({
  10113. caption: "newButton",
  10114. title: '',
  10115. buttonicon: styles.icon_newbutton_nav,
  10116. onClickButton: null,
  10117. position: "last",
  10118. cursor: 'pointer',
  10119. internal: false
  10120. }, p || {});
  10121. return this.each(function () {
  10122. if (!this.grid) { return; }
  10123. if (typeof elem === "string" && elem.indexOf("#") !== 0) { elem = "#" + $.jgrid.jqID(elem); }
  10124. var findnav = $(".navtable", elem)[0], $t = this,
  10125. //getstyle = $.jgrid.getMethod("getStyleUI"),
  10126. disabled = $.jgrid.styleUI[currstyle].common.disabled,
  10127. hover = $.jgrid.styleUI[currstyle].common.hover,
  10128. cornerall = $.jgrid.styleUI[currstyle].common.cornerall,
  10129. iconbase = $.jgrid.styleUI[currstyle].common.icon_base;
  10130. if ($t.p.storeNavOptions && !p.internal) {
  10131. $t.p.navButtons.push([elem, p]);
  10132. }
  10133. if (findnav) {
  10134. if (p.id && $("#" + $.jgrid.jqID(p.id), findnav)[0] !== undefined) { return; }
  10135. var tbd = $("<td></td>");
  10136. if (p.buttonicon.toString().toUpperCase() === "NONE") {
  10137. $(tbd).addClass('ui-pg-button ' + cornerall).append("<div class='ui-pg-div'>" + p.caption + "</div>");
  10138. } else {
  10139. $(tbd).addClass('ui-pg-button ' + cornerall).append("<div class='ui-pg-div'><span class='" + iconbase + " " + p.buttonicon + "'></span>" + p.caption + "</div>");
  10140. }
  10141. if (p.id) { $(tbd).attr("id", p.id); }
  10142. if (p.position === 'first') {
  10143. if (findnav.rows[0].cells.length === 0) {
  10144. $("tr", findnav).append(tbd);
  10145. } else {
  10146. $("tr td:eq(0)", findnav).before(tbd);
  10147. }
  10148. } else {
  10149. $("tr", findnav).append(tbd);
  10150. }
  10151. $(tbd, findnav)
  10152. .attr("title", p.title || "")
  10153. .click(function (e) {
  10154. if (!$(this).hasClass(disabled)) {
  10155. if ($.isFunction(p.onClickButton)) { p.onClickButton.call($t, e); }
  10156. }
  10157. return false;
  10158. })
  10159. .hover(
  10160. function () {
  10161. if (!$(this).hasClass(disabled)) {
  10162. $(this).addClass(hover);
  10163. }
  10164. },
  10165. function () { $(this).removeClass(hover); }
  10166. );
  10167. } else {
  10168. findnav = $(".dropdownmenu", elem)[0];
  10169. if (findnav) {
  10170. var id = $(findnav).val(),
  10171. eid = p.id || $.jgrid.randId(),
  10172. item = $('<li class="ui-menu-item" role="presentation"><a class="' + cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.caption || p.title) + '</a></li>');
  10173. if (id) {
  10174. if (p.position === 'first') {
  10175. $("#" + id).prepend(item);
  10176. } else {
  10177. $("#" + id).append(item);
  10178. }
  10179. $(item).on("click", function (e) {
  10180. if (!$(this).hasClass(disabled)) {
  10181. $("#" + id).hide();
  10182. if ($.isFunction(p.onClickButton)) {
  10183. p.onClickButton.call($t, e);
  10184. }
  10185. }
  10186. return false;
  10187. }).find("a")
  10188. .hover(
  10189. function () {
  10190. if (!$(this).hasClass(disabled)) {
  10191. $(this).addClass(hover);
  10192. }
  10193. },
  10194. function () { $(this).removeClass(hover); }
  10195. );
  10196. }
  10197. }
  10198. }
  10199. });
  10200. },
  10201. navSeparatorAdd: function (elem, p) {
  10202. var currstyle = this[0].p.styleUI,
  10203. commonstyle = $.jgrid.styleUI[currstyle].common;
  10204. p = $.extend({
  10205. sepclass: "ui-separator",
  10206. sepcontent: '',
  10207. position: "last"
  10208. }, p || {});
  10209. return this.each(function () {
  10210. if (!this.grid) { return; }
  10211. if (typeof elem === "string" && elem.indexOf("#") !== 0) { elem = "#" + $.jgrid.jqID(elem); }
  10212. var findnav = $(".navtable", elem)[0], sep, id;
  10213. if (this.p.storeNavOptions) {
  10214. this.p.navButtons.push([elem, p]);
  10215. }
  10216. if (findnav) {
  10217. sep = "<td class='ui-pg-button " + commonstyle.disabled + "' style='width:4px;'><span class='" + p.sepclass + "'></span>" + p.sepcontent + "</td>";
  10218. if (p.position === 'first') {
  10219. if (findnav.rows[0].cells.length === 0) {
  10220. $("tr", findnav).append(sep);
  10221. } else {
  10222. $("tr td:eq(0)", findnav).before(sep);
  10223. }
  10224. } else {
  10225. $("tr", findnav).append(sep);
  10226. }
  10227. } else {
  10228. findnav = $(".dropdownmenu", elem)[0];
  10229. sep = "<li class='ui-menu-item " + commonstyle.disabled + "' style='width:100%' role='presentation'><hr class='ui-separator-li'></li>";
  10230. if (findnav) {
  10231. id = $(findnav).val();
  10232. if (id) {
  10233. if (p.position === "first") {
  10234. $("#" + id).prepend(sep);
  10235. } else {
  10236. $("#" + id).append(sep);
  10237. }
  10238. }
  10239. }
  10240. }
  10241. });
  10242. },
  10243. _buildNavMenu: function (elem, elemids, p, pEdit, pAdd, pDel, pSearch, pView) {
  10244. return this.each(function () {
  10245. var $t = this,
  10246. //actions = ['add','edit', 'del', 'view', 'search','refresh'],
  10247. regional = $.jgrid.getRegional($t, 'nav'),
  10248. currstyle = $t.p.styleUI,
  10249. styles = $.jgrid.styleUI[currstyle].navigator,
  10250. classes = $.jgrid.styleUI[currstyle].filter,
  10251. commonstyle = $.jgrid.styleUI[currstyle].common,
  10252. mid = "form_menu_" + $.jgrid.randId(),
  10253. bt = p.navButtonText ? p.navButtonText : regional.selectcaption || 'Actions',
  10254. act = "<button class='dropdownmenu " + commonstyle.button + "' value='" + mid + "'>" + bt + "</button>";
  10255. $(elem + "_" + p.position, elem).append(act);
  10256. var alertIDs = { themodal: 'alertmod_' + this.p.id, modalhead: 'alerthd_' + this.p.id, modalcontent: 'alertcnt_' + this.p.id },
  10257. _buildMenu = function () {
  10258. var fs = $('.ui-jqgrid-view').css('font-size') || '11px',
  10259. eid, itm,
  10260. str = $('<ul id="' + mid + '" class="ui-nav-menu modal-content" role="menu" tabindex="0" style="display:none;font-size:' + fs + '"></ul>');
  10261. if (p.add) {
  10262. pAdd = pAdd || {};
  10263. eid = pAdd.id || "add_" + elemids;
  10264. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.addtext || p.addtitle) + '</a></li>').click(function () {
  10265. if (!$(this).hasClass(commonstyle.disabled)) {
  10266. if ($.isFunction(p.addfunc)) {
  10267. p.addfunc.call($t);
  10268. } else {
  10269. $($t).jqGrid("editGridRow", "new", pAdd);
  10270. }
  10271. $(str).hide();
  10272. }
  10273. return false;
  10274. });
  10275. $(str).append(itm);
  10276. }
  10277. if (p.edit) {
  10278. pEdit = pEdit || {};
  10279. eid = pEdit.id || "edit_" + elemids;
  10280. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.edittext || p.edittitle) + '</a></li>').click(function () {
  10281. if (!$(this).hasClass(commonstyle.disabled)) {
  10282. var sr = $t.p.selrow;
  10283. if (sr) {
  10284. if ($.isFunction(p.editfunc)) {
  10285. p.editfunc.call($t, sr);
  10286. } else {
  10287. $($t).jqGrid("editGridRow", sr, pEdit);
  10288. }
  10289. } else {
  10290. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true });
  10291. $("#jqg_alrt").focus();
  10292. }
  10293. $(str).hide();
  10294. }
  10295. return false;
  10296. });
  10297. $(str).append(itm);
  10298. }
  10299. if (p.view) {
  10300. pView = pView || {};
  10301. eid = pView.id || "view_" + elemids;
  10302. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.viewtext || p.viewtitle) + '</a></li>').click(function () {
  10303. if (!$(this).hasClass(commonstyle.disabled)) {
  10304. var sr = $t.p.selrow;
  10305. if (sr) {
  10306. if ($.isFunction(p.editfunc)) {
  10307. p.viewfunc.call($t, sr);
  10308. } else {
  10309. $($t).jqGrid("viewGridRow", sr, pView);
  10310. }
  10311. } else {
  10312. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true });
  10313. $("#jqg_alrt").focus();
  10314. }
  10315. $(str).hide();
  10316. }
  10317. return false;
  10318. });
  10319. $(str).append(itm);
  10320. }
  10321. if (p.del) {
  10322. pDel = pDel || {};
  10323. eid = pDel.id || "del_" + elemids;
  10324. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.deltext || p.deltitle) + '</a></li>').click(function () {
  10325. if (!$(this).hasClass(commonstyle.disabled)) {
  10326. var dr;
  10327. if ($t.p.multiselect) {
  10328. dr = $t.p.selarrrow;
  10329. if (dr.length === 0) { dr = null; }
  10330. } else {
  10331. dr = $t.p.selrow;
  10332. }
  10333. if (dr) {
  10334. if ($.isFunction(p.delfunc)) {
  10335. p.delfunc.call($t, dr);
  10336. } else {
  10337. $($t).jqGrid("delGridRow", dr, pDel);
  10338. }
  10339. } else {
  10340. $.jgrid.viewModal("#" + alertIDs.themodal, { gbox: "#gbox_" + $.jgrid.jqID($t.p.id), jqm: true }); $("#jqg_alrt").focus();
  10341. }
  10342. $(str).hide();
  10343. }
  10344. return false;
  10345. });
  10346. $(str).append(itm);
  10347. }
  10348. if (p.add || p.edit || p.del || p.view) {
  10349. $(str).append("<li class='ui-menu-item " + commonstyle.disabled + "' style='width:100%' role='presentation'><hr class='ui-separator-li'></li>");
  10350. }
  10351. if (p.search) {
  10352. pSearch = pSearch || {};
  10353. eid = pSearch.id || "search_" + elemids;
  10354. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.searchtext || p.searchtitle) + '</a></li>').click(function () {
  10355. if (!$(this).hasClass(commonstyle.disabled)) {
  10356. if ($.isFunction(p.searchfunc)) {
  10357. p.searchfunc.call($t, pSearch);
  10358. } else {
  10359. $($t).jqGrid("searchGrid", pSearch);
  10360. }
  10361. $(str).hide();
  10362. }
  10363. return false;
  10364. });
  10365. $(str).append(itm);
  10366. if (pSearch.showOnLoad && pSearch.showOnLoad === true) {
  10367. $(itm).click();
  10368. }
  10369. }
  10370. if (p.refresh) {
  10371. eid = pSearch.id || "search_" + elemids;
  10372. itm = $('<li class="ui-menu-item" role="presentation"><a class="' + commonstyle.cornerall + ' g-menu-item" tabindex="0" role="menuitem" id="' + eid + '">' + (p.refreshtext || p.refreshtitle) + '</a></li>').click(function () {
  10373. if (!$(this).hasClass(commonstyle.disabled)) {
  10374. if ($.isFunction(p.beforeRefresh)) { p.beforeRefresh.call($t); }
  10375. $t.p.search = false;
  10376. $t.p.resetsearch = true;
  10377. try {
  10378. if (p.refreshstate !== 'currentfilter') {
  10379. var gID = $t.p.id;
  10380. $t.p.postData.filters = "";
  10381. try {
  10382. $("#fbox_" + $.jgrid.jqID(gID)).jqFilter('resetFilter');
  10383. } catch (ef) { }
  10384. if ($.isFunction($t.clearToolbar)) { $t.clearToolbar.call($t, false); }
  10385. }
  10386. } catch (e) { }
  10387. switch (p.refreshstate) {
  10388. case 'firstpage':
  10389. $($t).trigger("reloadGrid", [{ page: 1 }]);
  10390. break;
  10391. case 'current':
  10392. case 'currentfilter':
  10393. $($t).trigger("reloadGrid", [{ current: true }]);
  10394. break;
  10395. }
  10396. if ($.isFunction(p.afterRefresh)) { p.afterRefresh.call($t); }
  10397. $(str).hide();
  10398. }
  10399. return false;
  10400. });
  10401. $(str).append(itm);
  10402. }
  10403. $(str).hide();
  10404. $('body').append(str);
  10405. $("#" + mid).addClass("ui-menu " + classes.menu_widget);
  10406. $("#" + mid + " > li > a").hover(
  10407. function () { $(this).addClass(commonstyle.hover); },
  10408. function () { $(this).removeClass(commonstyle.hover); }
  10409. );
  10410. };
  10411. _buildMenu();
  10412. $(".dropdownmenu", elem + "_" + p.position).on("click", function (e) {
  10413. var offset = $(this).offset(),
  10414. left = (offset.left),
  10415. top = parseInt(offset.top),
  10416. bid = $(this).val();
  10417. //if( $("#"+mid)[0] === undefined) {
  10418. //_buildMenu();
  10419. //}
  10420. $("#" + bid).show().css({ "top": top - ($("#" + bid).height() + 10) + "px", "left": left + "px" });
  10421. e.stopPropagation();
  10422. });
  10423. $("body").on('click', function (e) {
  10424. if (!$(e.target).hasClass("dropdownmenu")) {
  10425. $("#" + mid).hide();
  10426. }
  10427. });
  10428. });
  10429. },
  10430. GridToForm: function (rowid, formid) {
  10431. return this.each(function () {
  10432. var $t = this, i;
  10433. if (!$t.grid) { return; }
  10434. var rowdata = $($t).jqGrid("getRowData", rowid);
  10435. if (rowdata) {
  10436. for (i in rowdata) {
  10437. if (rowdata.hasOwnProperty(i)) {
  10438. if ($("[name=" + $.jgrid.jqID(i) + "]", formid).is("input:radio") || $("[name=" + $.jgrid.jqID(i) + "]", formid).is("input:checkbox")) {
  10439. $("[name=" + $.jgrid.jqID(i) + "]", formid).each(function () {
  10440. if ($(this).val() == rowdata[i]) {
  10441. $(this)[$t.p.useProp ? 'prop' : 'attr']("checked", true);
  10442. } else {
  10443. $(this)[$t.p.useProp ? 'prop' : 'attr']("checked", false);
  10444. }
  10445. });
  10446. } else {
  10447. // this is very slow on big table and form.
  10448. $("[name=" + $.jgrid.jqID(i) + "]", formid).val(rowdata[i]);
  10449. }
  10450. }
  10451. }
  10452. }
  10453. });
  10454. },
  10455. FormToGrid: function (rowid, formid, mode, position) {
  10456. return this.each(function () {
  10457. var $t = this;
  10458. if (!$t.grid) { return; }
  10459. if (!mode) { mode = 'set'; }
  10460. if (!position) { position = 'first'; }
  10461. var fields = $(formid).serializeArray();
  10462. var griddata = {};
  10463. $.each(fields, function (i, field) {
  10464. griddata[field.name] = field.value;
  10465. });
  10466. if (mode === 'add') { $($t).jqGrid("addRowData", rowid, griddata, position); }
  10467. else if (mode === 'set') { $($t).jqGrid("setRowData", rowid, griddata); }
  10468. });
  10469. }
  10470. });
  10471. //module begin
  10472. $.jgrid.extend({
  10473. groupingSetup: function () {
  10474. return this.each(function () {
  10475. var $t = this, i, j, cml, cm = $t.p.colModel, grp = $t.p.groupingView,
  10476. classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].grouping;
  10477. if (grp !== null && ((typeof grp === 'object') || $.isFunction(grp))) {
  10478. if (!grp.plusicon) { grp.plusicon = classes.icon_plus; }
  10479. if (!grp.minusicon) { grp.minusicon = classes.icon_minus; }
  10480. if (!grp.groupField.length) {
  10481. $t.p.grouping = false;
  10482. } else {
  10483. if (grp.visibiltyOnNextGrouping === undefined) {
  10484. grp.visibiltyOnNextGrouping = [];
  10485. }
  10486. grp.lastvalues = [];
  10487. if (!grp._locgr) {
  10488. grp.groups = [];
  10489. }
  10490. grp.counters = [];
  10491. for (i = 0; i < grp.groupField.length; i++) {
  10492. if (!grp.groupOrder[i]) {
  10493. grp.groupOrder[i] = 'asc';
  10494. }
  10495. if (!grp.groupText[i]) {
  10496. grp.groupText[i] = '{0}';
  10497. }
  10498. if (typeof grp.groupColumnShow[i] !== 'boolean') {
  10499. grp.groupColumnShow[i] = true;
  10500. }
  10501. if (typeof grp.groupSummary[i] !== 'boolean') {
  10502. grp.groupSummary[i] = false;
  10503. }
  10504. if (!grp.groupSummaryPos[i]) {
  10505. grp.groupSummaryPos[i] = 'footer';
  10506. }
  10507. if (grp.groupColumnShow[i] === true) {
  10508. grp.visibiltyOnNextGrouping[i] = true;
  10509. $($t).jqGrid('showCol', grp.groupField[i]);
  10510. } else {
  10511. grp.visibiltyOnNextGrouping[i] = $("#" + $.jgrid.jqID($t.p.id + "_" + grp.groupField[i])).is(":visible");
  10512. $($t).jqGrid('hideCol', grp.groupField[i]);
  10513. }
  10514. }
  10515. grp.summary = [];
  10516. if (grp.hideFirstGroupCol) {
  10517. if ($.isArray(grp.formatDisplayField) && !$.isFunction(grp.formatDisplayField[0])) {
  10518. grp.formatDisplayField[0] = function (v) { return v; };
  10519. }
  10520. }
  10521. for (j = 0, cml = cm.length; j < cml; j++) {
  10522. if (grp.hideFirstGroupCol) {
  10523. if (!cm[j].hidden && grp.groupField[0] === cm[j].name) {
  10524. cm[j].formatter = function () { return ''; };
  10525. }
  10526. }
  10527. if (cm[j].summaryType) {
  10528. if (cm[j].summaryDivider) {
  10529. grp.summary.push({ nm: cm[j].name, st: cm[j].summaryType, v: '', sd: cm[j].summaryDivider, vd: '', sr: cm[j].summaryRound, srt: cm[j].summaryRoundType || 'round' });
  10530. } else {
  10531. grp.summary.push({ nm: cm[j].name, st: cm[j].summaryType, v: '', sr: cm[j].summaryRound, srt: cm[j].summaryRoundType || 'round' });
  10532. }
  10533. }
  10534. }
  10535. }
  10536. } else {
  10537. $t.p.grouping = false;
  10538. }
  10539. });
  10540. },
  10541. groupingPrepare: function (record, irow) {
  10542. this.each(function () {
  10543. var grp = this.p.groupingView, $t = this, i,
  10544. sumGroups = function () {
  10545. if ($.isFunction(this.st)) {
  10546. this.v = this.st.call($t, this.v, this.nm, record);
  10547. } else {
  10548. this.v = $($t).jqGrid('groupingCalculations.handler', this.st, this.v, this.nm, this.sr, this.srt, record);
  10549. if (this.st.toLowerCase() === 'avg' && this.sd) {
  10550. this.vd = $($t).jqGrid('groupingCalculations.handler', this.st, this.vd, this.sd, this.sr, this.srt, record);
  10551. }
  10552. }
  10553. },
  10554. grlen = grp.groupField.length,
  10555. fieldName,
  10556. v,
  10557. displayName,
  10558. displayValue,
  10559. changed = 0;
  10560. for (i = 0; i < grlen; i++) {
  10561. fieldName = grp.groupField[i];
  10562. displayName = grp.displayField[i];
  10563. v = record[fieldName];
  10564. displayValue = displayName == null ? null : record[displayName];
  10565. if (displayValue == null) {
  10566. displayValue = v;
  10567. }
  10568. if (v !== undefined) {
  10569. if (irow === 0) {
  10570. // First record always starts a new group
  10571. grp.groups.push({ idx: i, dataIndex: fieldName, value: v, displayValue: displayValue, startRow: irow, cnt: 1, summary: [] });
  10572. grp.lastvalues[i] = v;
  10573. grp.counters[i] = { cnt: 1, pos: grp.groups.length - 1, summary: $.extend(true, [], grp.summary) };
  10574. $.each(grp.counters[i].summary, sumGroups);
  10575. grp.groups[grp.counters[i].pos].summary = grp.counters[i].summary;
  10576. } else {
  10577. if (typeof v !== "object" && ($.isArray(grp.isInTheSameGroup) && $.isFunction(grp.isInTheSameGroup[i]) ? !grp.isInTheSameGroup[i].call($t, grp.lastvalues[i], v, i, grp) : grp.lastvalues[i] !== v)) {
  10578. // This record is not in same group as previous one
  10579. grp.groups.push({ idx: i, dataIndex: fieldName, value: v, displayValue: displayValue, startRow: irow, cnt: 1, summary: [] });
  10580. grp.lastvalues[i] = v;
  10581. changed = 1;
  10582. grp.counters[i] = { cnt: 1, pos: grp.groups.length - 1, summary: $.extend(true, [], grp.summary) };
  10583. $.each(grp.counters[i].summary, sumGroups);
  10584. grp.groups[grp.counters[i].pos].summary = grp.counters[i].summary;
  10585. } else {
  10586. if (changed === 1) {
  10587. // This group has changed because an earlier group changed.
  10588. grp.groups.push({ idx: i, dataIndex: fieldName, value: v, displayValue: displayValue, startRow: irow, cnt: 1, summary: [] });
  10589. grp.lastvalues[i] = v;
  10590. grp.counters[i] = { cnt: 1, pos: grp.groups.length - 1, summary: $.extend(true, [], grp.summary) };
  10591. $.each(grp.counters[i].summary, sumGroups);
  10592. grp.groups[grp.counters[i].pos].summary = grp.counters[i].summary;
  10593. } else {
  10594. grp.counters[i].cnt += 1;
  10595. grp.groups[grp.counters[i].pos].cnt = grp.counters[i].cnt;
  10596. $.each(grp.counters[i].summary, sumGroups);
  10597. grp.groups[grp.counters[i].pos].summary = grp.counters[i].summary;
  10598. }
  10599. }
  10600. }
  10601. }
  10602. }
  10603. //gdata.push( rData );
  10604. });
  10605. return this;
  10606. },
  10607. groupingToggle: function (hid) {
  10608. this.each(function () {
  10609. var $t = this,
  10610. grp = $t.p.groupingView,
  10611. strpos = hid.split('_'),
  10612. num = parseInt(strpos[strpos.length - 2], 10);
  10613. strpos.splice(strpos.length - 2, 2);
  10614. var uid = strpos.join("_"),
  10615. minus = grp.minusicon,
  10616. plus = grp.plusicon,
  10617. tar = $("#" + $.jgrid.jqID(hid)),
  10618. r = tar.length ? tar[0].nextSibling : null,
  10619. tarspan = $("#" + $.jgrid.jqID(hid) + " span." + "tree-wrap-" + $t.p.direction),
  10620. getGroupingLevelFromClass = function (className) {
  10621. var nums = $.map(className.split(" "), function (item) {
  10622. if (item.substring(0, uid.length + 1) === uid + "_") {
  10623. return parseInt(item.substring(uid.length + 1), 10);
  10624. }
  10625. });
  10626. return nums.length > 0 ? nums[0] : undefined;
  10627. },
  10628. itemGroupingLevel,
  10629. showData,
  10630. collapsed = false,
  10631. skip = false,
  10632. frz = $t.p.frozenColumns ? $t.p.id + "_frozen" : false,
  10633. tar2 = frz ? $("#" + $.jgrid.jqID(hid), "#" + $.jgrid.jqID(frz)) : false,
  10634. r2 = (tar2 && tar2.length) ? tar2[0].nextSibling : null;
  10635. if (tarspan.hasClass(minus)) {
  10636. if (r) {
  10637. while (r) {
  10638. itemGroupingLevel = getGroupingLevelFromClass(r.className);
  10639. if (itemGroupingLevel !== undefined && itemGroupingLevel <= num) {
  10640. break;
  10641. }
  10642. $(r).hide();
  10643. r = r.nextSibling;
  10644. if (frz) {
  10645. $(r2).hide();
  10646. r2 = r2.nextSibling;
  10647. }
  10648. }
  10649. }
  10650. tarspan.removeClass(minus).addClass(plus);
  10651. collapsed = true;
  10652. } else {
  10653. if (r) {
  10654. showData = undefined;
  10655. while (r) {
  10656. itemGroupingLevel = getGroupingLevelFromClass(r.className);
  10657. if (showData === undefined) {
  10658. showData = itemGroupingLevel === undefined; // if the first row after the opening group is data row then show the data rows
  10659. }
  10660. skip = $(r).hasClass("ui-subgrid") && $(r).hasClass("ui-sg-collapsed");
  10661. if (itemGroupingLevel !== undefined) {
  10662. if (itemGroupingLevel <= num) {
  10663. break;// next item of the same lever are found
  10664. }
  10665. if (itemGroupingLevel === num + 1) {
  10666. if (!skip) {
  10667. $(r).show().find(">td>span." + "tree-wrap-" + $t.p.direction).removeClass(minus).addClass(plus);
  10668. if (frz) {
  10669. $(r2).show().find(">td>span." + "tree-wrap-" + $t.p.direction).removeClass(minus).addClass(plus);
  10670. }
  10671. }
  10672. }
  10673. } else if (showData) {
  10674. if (!skip) {
  10675. $(r).show();
  10676. if (frz) {
  10677. $(r2).show();
  10678. }
  10679. }
  10680. }
  10681. r = r.nextSibling;
  10682. if (frz) {
  10683. r2 = r2.nextSibling;
  10684. }
  10685. }
  10686. }
  10687. tarspan.removeClass(plus).addClass(minus);
  10688. }
  10689. $($t).triggerHandler("jqGridGroupingClickGroup", [hid, collapsed]);
  10690. if ($.isFunction($t.p.onClickGroup)) { $t.p.onClickGroup.call($t, hid, collapsed); }
  10691. });
  10692. return false;
  10693. },
  10694. groupingRender: function (grdata, colspans, page, rn) {
  10695. return this.each(function () {
  10696. var $t = this,
  10697. grp = $t.p.groupingView,
  10698. str = "", icon = "", hid, clid, pmrtl = grp.groupCollapse ? grp.plusicon : grp.minusicon, gv, cp = [], len = grp.groupField.length,
  10699. //classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')]['grouping'],
  10700. common = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].common;
  10701. pmrtl = pmrtl + " tree-wrap-" + $t.p.direction;
  10702. $.each($t.p.colModel, function (i, n) {
  10703. var ii;
  10704. for (ii = 0; ii < len; ii++) {
  10705. if (grp.groupField[ii] === n.name) {
  10706. cp[ii] = i;
  10707. break;
  10708. }
  10709. }
  10710. });
  10711. var toEnd = 0;
  10712. function findGroupIdx(ind, offset, grp) {
  10713. var ret = false, i;
  10714. if (offset === 0) {
  10715. ret = grp[ind];
  10716. } else {
  10717. var id = grp[ind].idx;
  10718. if (id === 0) {
  10719. ret = grp[ind];
  10720. } else {
  10721. for (i = ind; i >= 0; i--) {
  10722. if (grp[i].idx === id - offset) {
  10723. ret = grp[i];
  10724. break;
  10725. }
  10726. }
  10727. }
  10728. }
  10729. return ret;
  10730. }
  10731. function buildSummaryTd(i, ik, grp, foffset) {
  10732. var fdata = findGroupIdx(i, ik, grp),
  10733. cm = $t.p.colModel,
  10734. vv, grlen = fdata.cnt, str = "", k;
  10735. for (k = foffset; k < colspans; k++) {
  10736. var tmpdata = "<td " + $t.formatCol(k, 1, '') + ">&#160;</td>",
  10737. tplfld = "{0}";
  10738. $.each(fdata.summary, function () {
  10739. if (this.nm === cm[k].name) {
  10740. if (cm[k].summaryTpl) {
  10741. tplfld = cm[k].summaryTpl;
  10742. }
  10743. if (typeof this.st === 'string' && this.st.toLowerCase() === 'avg') {
  10744. if (this.sd && this.vd) {
  10745. this.v = (this.v / this.vd);
  10746. } else if (this.v && grlen > 0) {
  10747. this.v = (this.v / grlen);
  10748. }
  10749. }
  10750. try {
  10751. this.groupCount = fdata.cnt;
  10752. this.groupIndex = fdata.dataIndex;
  10753. this.groupValue = fdata.value;
  10754. vv = $t.formatter('', this.v, k, this);
  10755. } catch (ef) {
  10756. vv = this.v;
  10757. }
  10758. tmpdata = "<td " + $t.formatCol(k, 1, '') + ">" + $.jgrid.template(tplfld, vv) + "</td>";
  10759. return false;
  10760. }
  10761. });
  10762. str += tmpdata;
  10763. }
  10764. return str;
  10765. }
  10766. var sumreverse = $.makeArray(grp.groupSummary), mul;
  10767. sumreverse.reverse();
  10768. mul = $t.p.multiselect ? " colspan=\"2\"" : "";
  10769. $.each(grp.groups, function (i, n) {
  10770. if (grp._locgr) {
  10771. if (!(n.startRow + n.cnt > (page - 1) * rn && n.startRow < page * rn)) {
  10772. return true;
  10773. }
  10774. }
  10775. toEnd++;
  10776. clid = $t.p.id + "ghead_" + n.idx;
  10777. hid = clid + "_" + i;
  10778. icon = "<span style='cursor:pointer;margin-right:8px;margin-left:5px;' class='" + common.icon_base + " " + pmrtl + "' onclick=\"jQuery('#" + $.jgrid.jqID($t.p.id) + "').jqGrid('groupingToggle','" + hid + "');return false;\"></span>";
  10779. try {
  10780. if ($.isArray(grp.formatDisplayField) && $.isFunction(grp.formatDisplayField[n.idx])) {
  10781. n.displayValue = grp.formatDisplayField[n.idx].call($t, n.displayValue, n.value, $t.p.colModel[cp[n.idx]], n.idx, grp);
  10782. gv = n.displayValue;
  10783. } else {
  10784. gv = $t.formatter(hid, n.displayValue, cp[n.idx], n.value);
  10785. }
  10786. } catch (egv) {
  10787. gv = n.displayValue;
  10788. }
  10789. var grpTextStr = '';
  10790. if ($.isFunction(grp.groupText[n.idx])) {
  10791. grpTextStr = grp.groupText[n.idx].call($t, gv, n.cnt, n.summary);
  10792. } else {
  10793. grpTextStr = $.jgrid.template(grp.groupText[n.idx], gv, n.cnt, n.summary);
  10794. }
  10795. if (!(typeof grpTextStr === 'string' || typeof grpTextStr === 'number')) {
  10796. grpTextStr = gv;
  10797. }
  10798. if (grp.groupSummaryPos[n.idx] === 'header') {
  10799. str += "<tr id=\"" + hid + "\"" + (grp.groupCollapse && n.idx > 0 ? " style=\"display:none;\" " : " ") + "role=\"row\" class= \"" + common.content + " jqgroup ui-row-" + $t.p.direction + " " + clid + "\"><td style=\"padding-left:" + (n.idx * 12) + "px;" + "\"" + mul + ">" + icon + grpTextStr + "</td>";
  10800. str += buildSummaryTd(i, 0, grp.groups, grp.groupColumnShow[n.idx] === false ? (mul === "" ? 2 : 3) : ((mul === "") ? 1 : 2));
  10801. str += "</tr>";
  10802. } else {
  10803. str += "<tr id=\"" + hid + "\"" + (grp.groupCollapse && n.idx > 0 ? " style=\"display:none;\" " : " ") + "role=\"row\" class= \"" + common.content + " jqgroup ui-row-" + $t.p.direction + " " + clid + "\"><td style=\"padding-left:" + (n.idx * 12) + "px;" + "\" colspan=\"" + (grp.groupColumnShow[n.idx] === false ? colspans - 1 : colspans) + "\">" + icon + grpTextStr + "</td></tr>";
  10804. }
  10805. var leaf = len - 1 === n.idx;
  10806. if (leaf) {
  10807. var gg = grp.groups[i + 1], kk, ik, offset = 0, sgr = n.startRow,
  10808. end = gg !== undefined ? gg.startRow : grp.groups[i].startRow + grp.groups[i].cnt;
  10809. if (grp._locgr) {
  10810. offset = (page - 1) * rn;
  10811. if (offset > n.startRow) {
  10812. sgr = offset;
  10813. }
  10814. }
  10815. for (kk = sgr; kk < end; kk++) {
  10816. if (!grdata[kk - offset]) { break; }
  10817. str += grdata[kk - offset].join('');
  10818. }
  10819. if (grp.groupSummaryPos[n.idx] !== 'header') {
  10820. var jj;
  10821. if (gg !== undefined) {
  10822. for (jj = 0; jj < grp.groupField.length; jj++) {
  10823. if (gg.dataIndex === grp.groupField[jj]) {
  10824. break;
  10825. }
  10826. }
  10827. toEnd = grp.groupField.length - jj;
  10828. }
  10829. for (ik = 0; ik < toEnd; ik++) {
  10830. if (!sumreverse[ik]) { continue; }
  10831. var hhdr = "";
  10832. if (grp.groupCollapse && !grp.showSummaryOnHide) {
  10833. hhdr = " style=\"display:none;\"";
  10834. }
  10835. str += "<tr" + hhdr + " jqfootlevel=\"" + (n.idx - ik) + "\" role=\"row\" class=\"" + common.content + " jqfoot ui-row-" + $t.p.direction + "\">";
  10836. str += buildSummaryTd(i, ik, grp.groups, 0);
  10837. str += "</tr>";
  10838. }
  10839. toEnd = jj;
  10840. }
  10841. }
  10842. });
  10843. $("#" + $.jgrid.jqID($t.p.id) + " tbody:first").append(str);
  10844. // free up memory
  10845. str = null;
  10846. });
  10847. },
  10848. groupingGroupBy: function (name, options) {
  10849. return this.each(function () {
  10850. var $t = this;
  10851. if (typeof name === "string") {
  10852. name = [name];
  10853. }
  10854. var grp = $t.p.groupingView;
  10855. $t.p.grouping = true;
  10856. grp._locgr = false;
  10857. //Set default, in case visibilityOnNextGrouping is undefined
  10858. if (grp.visibiltyOnNextGrouping === undefined) {
  10859. grp.visibiltyOnNextGrouping = [];
  10860. }
  10861. var i;
  10862. // show previous hidden groups if they are hidden and weren't removed yet
  10863. for (i = 0; i < grp.groupField.length; i++) {
  10864. if (!grp.groupColumnShow[i] && grp.visibiltyOnNextGrouping[i]) {
  10865. $($t).jqGrid('showCol', grp.groupField[i]);
  10866. }
  10867. }
  10868. // set visibility status of current group columns on next grouping
  10869. for (i = 0; i < name.length; i++) {
  10870. grp.visibiltyOnNextGrouping[i] = $("#" + $.jgrid.jqID($t.p.id) + "_" + $.jgrid.jqID(name[i])).is(":visible");
  10871. }
  10872. $t.p.groupingView = $.extend($t.p.groupingView, options || {});
  10873. grp.groupField = name;
  10874. $($t).trigger("reloadGrid");
  10875. });
  10876. },
  10877. groupingRemove: function (current) {
  10878. return this.each(function () {
  10879. var $t = this;
  10880. if (current === undefined) {
  10881. current = true;
  10882. }
  10883. $t.p.grouping = false;
  10884. if (current === true) {
  10885. var grp = $t.p.groupingView, i;
  10886. // show previous hidden groups if they are hidden and weren't removed yet
  10887. for (i = 0; i < grp.groupField.length; i++) {
  10888. if (!grp.groupColumnShow[i] && grp.visibiltyOnNextGrouping[i]) {
  10889. $($t).jqGrid('showCol', grp.groupField);
  10890. }
  10891. }
  10892. $("tr.jqgroup, tr.jqfoot", "#" + $.jgrid.jqID($t.p.id) + " tbody:first").remove();
  10893. $("tr.jqgrow:hidden", "#" + $.jgrid.jqID($t.p.id) + " tbody:first").show();
  10894. } else {
  10895. $($t).trigger("reloadGrid");
  10896. }
  10897. });
  10898. },
  10899. groupingCalculations: {
  10900. handler: function (fn, v, field, round, roundType, rc) {
  10901. var funcs = {
  10902. sum: function () {
  10903. return parseFloat(v || 0) + parseFloat((rc[field] || 0));
  10904. },
  10905. min: function () {
  10906. if (v === "") {
  10907. return parseFloat(rc[field] || 0);
  10908. }
  10909. return Math.min(parseFloat(v), parseFloat(rc[field] || 0));
  10910. },
  10911. max: function () {
  10912. if (v === "") {
  10913. return parseFloat(rc[field] || 0);
  10914. }
  10915. return Math.max(parseFloat(v), parseFloat(rc[field] || 0));
  10916. },
  10917. count: function () {
  10918. if (v === "") { v = 0; }
  10919. if (rc.hasOwnProperty(field)) {
  10920. return v + 1;
  10921. }
  10922. return 0;
  10923. },
  10924. avg: function () {
  10925. // the same as sum, but at end we divide it
  10926. // so use sum instead of duplicating the code (?)
  10927. return funcs.sum();
  10928. }
  10929. };
  10930. if (!funcs[fn]) {
  10931. throw ("jqGrid Grouping No such method: " + fn);
  10932. }
  10933. var res = funcs[fn]();
  10934. if (round != null) {
  10935. if (roundType === 'fixed') {
  10936. res = res.toFixed(round);
  10937. } else {
  10938. var mul = Math.pow(10, round);
  10939. res = Math.round(res * mul) / mul;
  10940. }
  10941. }
  10942. return res;
  10943. }
  10944. },
  10945. setGroupHeaders: function (o) {
  10946. o = $.extend({
  10947. useColSpanStyle: false,
  10948. groupHeaders: []
  10949. }, o || {});
  10950. return this.each(function () {
  10951. var ts = this,
  10952. i, cmi, skip = 0, $tr, $colHeader, th, $th, thStyle,
  10953. iCol,
  10954. cghi,
  10955. //startColumnName,
  10956. numberOfColumns,
  10957. titleText,
  10958. cVisibleColumns,
  10959. className,
  10960. colModel = ts.p.colModel,
  10961. cml = colModel.length,
  10962. ths = ts.grid.headers,
  10963. $htable = $("table.ui-jqgrid-htable", ts.grid.hDiv),
  10964. $trLabels = $htable.children("thead").children("tr.ui-jqgrid-labels:last").addClass("jqg-second-row-header"),
  10965. $thead = $htable.children("thead"),
  10966. $theadInTable,
  10967. $firstHeaderRow = $htable.find(".jqg-first-row-header"),
  10968. //classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')]['grouping'],
  10969. base = $.jgrid.styleUI[(ts.p.styleUI || 'jQueryUI')].base;
  10970. if (!ts.p.groupHeader) {
  10971. ts.p.groupHeader = [];
  10972. }
  10973. ts.p.groupHeader.push(o);
  10974. if ($firstHeaderRow[0] === undefined) {
  10975. $firstHeaderRow = $('<tr>', { role: "row", "aria-hidden": "true" }).addClass("jqg-first-row-header").css("height", "auto");
  10976. } else {
  10977. $firstHeaderRow.empty();
  10978. }
  10979. var $firstRow,
  10980. inColumnHeader = function (text, columnHeaders) {
  10981. var length = columnHeaders.length, i;
  10982. for (i = 0; i < length; i++) {
  10983. if (columnHeaders[i].startColumnName === text) {
  10984. return i;
  10985. }
  10986. }
  10987. return -1;
  10988. };
  10989. $(ts).prepend($thead);
  10990. $tr = $('<tr>', { role: "row" }).addClass("ui-jqgrid-labels jqg-third-row-header");
  10991. for (i = 0; i < cml; i++) {
  10992. th = ths[i].el;
  10993. $th = $(th);
  10994. cmi = colModel[i];
  10995. // build the next cell for the first header row
  10996. thStyle = { height: '0px', width: ths[i].width + 'px', display: (cmi.hidden ? 'none' : '') };
  10997. $("<th>", { role: 'gridcell' }).css(thStyle).addClass("ui-first-th-" + ts.p.direction).appendTo($firstHeaderRow);
  10998. th.style.width = ""; // remove unneeded style
  10999. iCol = inColumnHeader(cmi.name, o.groupHeaders);
  11000. if (iCol >= 0) {
  11001. cghi = o.groupHeaders[iCol];
  11002. numberOfColumns = cghi.numberOfColumns;
  11003. titleText = cghi.titleText;
  11004. className = cghi.className || "";
  11005. // caclulate the number of visible columns from the next numberOfColumns columns
  11006. for (cVisibleColumns = 0, iCol = 0; iCol < numberOfColumns && (i + iCol < cml) ; iCol++) {
  11007. if (!colModel[i + iCol].hidden) {
  11008. cVisibleColumns++;
  11009. }
  11010. }
  11011. // The next numberOfColumns headers will be moved in the next row
  11012. // in the current row will be placed the new column header with the titleText.
  11013. // The text will be over the cVisibleColumns columns
  11014. $colHeader = $('<th>').attr({ role: "columnheader" })
  11015. .addClass(base.headerBox + " ui-th-column-header ui-th-" + ts.p.direction + " " + className)
  11016. //.css({'height':'22px', 'border-top': '0 none'})
  11017. .html(titleText);
  11018. if (cVisibleColumns > 0) {
  11019. $colHeader.attr("colspan", String(cVisibleColumns));
  11020. }
  11021. if (ts.p.headertitles) {
  11022. $colHeader.attr("title", $colHeader.text());
  11023. }
  11024. // hide if not a visible cols
  11025. if (cVisibleColumns === 0) {
  11026. $colHeader.hide();
  11027. }
  11028. $th.before($colHeader); // insert new column header before the current
  11029. $tr.append(th); // move the current header in the next row
  11030. // set the coumter of headers which will be moved in the next row
  11031. skip = numberOfColumns - 1;
  11032. } else {
  11033. if (skip === 0) {
  11034. if (o.useColSpanStyle) {
  11035. // expand the header height to two rows
  11036. $th.attr("rowspan", "2");
  11037. } else {
  11038. $('<th>', { role: "columnheader" })
  11039. .addClass(base.headerBox + " ui-th-column-header ui-th-" + ts.p.direction)
  11040. .css({ "display": cmi.hidden ? 'none' : '' })
  11041. .insertBefore($th);
  11042. $tr.append(th);
  11043. }
  11044. } else {
  11045. // move the header to the next row
  11046. //$th.css({"padding-top": "2px", height: "19px"});
  11047. $tr.append(th);
  11048. skip--;
  11049. }
  11050. }
  11051. }
  11052. $theadInTable = $(ts).children("thead");
  11053. $theadInTable.prepend($firstHeaderRow);
  11054. $tr.insertAfter($trLabels);
  11055. $htable.append($theadInTable);
  11056. if (o.useColSpanStyle) {
  11057. // Increase the height of resizing span of visible headers
  11058. $htable.find("span.ui-jqgrid-resize").each(function () {
  11059. var $parent = $(this).parent();
  11060. if ($parent.is(":visible")) {
  11061. this.style.cssText = 'height: ' + $parent.height() + 'px !important; cursor: col-resize;';
  11062. }
  11063. });
  11064. // Set position of the sortable div (the main lable)
  11065. // with the column header text to the middle of the cell.
  11066. // One should not do this for hidden headers.
  11067. $htable.find("div.ui-jqgrid-sortable").each(function () {
  11068. var $ts = $(this), $parent = $ts.parent();
  11069. if ($parent.is(":visible") && $parent.is(":has(span.ui-jqgrid-resize)")) {
  11070. // minus 4px from the margins of the resize markers
  11071. $ts.css('top', ($parent.height() - $ts.outerHeight()) / 2 - 4 + 'px');
  11072. }
  11073. });
  11074. }
  11075. $firstRow = $theadInTable.find("tr.jqg-first-row-header");
  11076. $(ts).bind('jqGridResizeStop.setGroupHeaders', function (e, nw, idx) {
  11077. $firstRow.find('th').eq(idx)[0].style.width = nw + "px";
  11078. });
  11079. });
  11080. },
  11081. destroyGroupHeader: function (nullHeader) {
  11082. if (nullHeader === undefined) {
  11083. nullHeader = true;
  11084. }
  11085. return this.each(function () {
  11086. var $t = this, $tr, i, l, headers, $th, $resizing, grid = $t.grid,
  11087. thead = $("table.ui-jqgrid-htable thead", grid.hDiv), cm = $t.p.colModel, hc;
  11088. if (!grid) { return; }
  11089. $(this).unbind('.setGroupHeaders');
  11090. $tr = $("<tr>", { role: "row" }).addClass("ui-jqgrid-labels");
  11091. headers = grid.headers;
  11092. for (i = 0, l = headers.length; i < l; i++) {
  11093. hc = cm[i].hidden ? "none" : "";
  11094. $th = $(headers[i].el)
  11095. .width(headers[i].width)
  11096. .css('display', hc);
  11097. try {
  11098. $th.removeAttr("rowSpan");
  11099. } catch (rs) {
  11100. //IE 6/7
  11101. $th.attr("rowSpan", 1);
  11102. }
  11103. $tr.append($th);
  11104. $resizing = $th.children("span.ui-jqgrid-resize");
  11105. if ($resizing.length > 0) {// resizable column
  11106. $resizing[0].style.height = "";
  11107. }
  11108. $th.children("div")[0].style.top = "";
  11109. }
  11110. $(thead).children('tr.ui-jqgrid-labels').remove();
  11111. $(thead).prepend($tr);
  11112. if (nullHeader === true) {
  11113. $($t).jqGrid('setGridParam', { 'groupHeader': null });
  11114. }
  11115. });
  11116. }
  11117. });
  11118. //module begin
  11119. $.jgrid = $.jgrid || {};
  11120. $.extend($.jgrid, {
  11121. saveState: function (jqGridId, o) {
  11122. o = $.extend({
  11123. useStorage: true,
  11124. storageType: "localStorage", // localStorage or sessionStorage
  11125. beforeSetItem: null,
  11126. compression: false,
  11127. compressionModule: 'LZString', // object by example gzip, LZString
  11128. compressionMethod: 'compressToUTF16', // string by example zip, compressToUTF16
  11129. debug: false
  11130. }, o || {});
  11131. if (!jqGridId) { return; }
  11132. var gridstate = "", data = "", ret, $t = $("#" + jqGridId)[0], tmp;
  11133. // to use navigator set storeNavOptions to true in grid options
  11134. if (!$t.grid) { return; }
  11135. tmp = $($t).data('inlineNav');
  11136. if (tmp && $t.p.inlineNav) {
  11137. $($t).jqGrid('setGridParam', { _iN: tmp });
  11138. }
  11139. tmp = $($t).data('filterToolbar');
  11140. if (tmp && $t.p.filterToolbar) {
  11141. $($t).jqGrid('setGridParam', { _fT: tmp });
  11142. }
  11143. gridstate = $($t).jqGrid('jqGridExport', { exptype: "jsonstring", ident: "", root: "" });
  11144. data = $($t.grid.bDiv).find(".ui-jqgrid-btable tbody:first").html();
  11145. var firstrow = data.indexOf("</tr>");
  11146. data = data.slice(firstrow + 5);
  11147. if ($.isFunction(o.beforeSetItem)) {
  11148. ret = o.beforeSetItem.call($t, gridstate);
  11149. if (ret != null) {
  11150. gridstate = ret;
  11151. }
  11152. }
  11153. if (o.debug) {
  11154. $("#gbox_tree").prepend('<a id="link_save" target="_blank" download="jqGrid_dump.txt">Click to save Dump Data</a>');
  11155. var temp = [], file, properties = {}, url;
  11156. temp.push("Grid Options\n");
  11157. temp.push(gridstate);
  11158. temp.push("\n");
  11159. temp.push("GridData\n");
  11160. temp.push(data);
  11161. properties.type = 'plain/text;charset=utf-8'; // Specify the file's mime-type.
  11162. try {
  11163. file = new File(temp, "jqGrid_dump.txt", properties);
  11164. } catch (e) {
  11165. file = new Blob(temp, properties);
  11166. }
  11167. //saveAs(file, "jqGrid_dump.txt" );
  11168. url = URL.createObjectURL(file);
  11169. $("#link_save").attr("href", url).bind('click', function () {
  11170. $(this).remove();
  11171. });
  11172. }
  11173. if (o.compression) {
  11174. if (o.compressionModule) {
  11175. try {
  11176. ret = window[o.compressionModule][o.compressionMethod](gridstate);
  11177. if (ret != null) {
  11178. gridstate = ret;
  11179. data = window[o.compressionModule][o.compressionMethod](data);
  11180. }
  11181. } catch (e) {
  11182. // can not execute a compression.
  11183. }
  11184. }
  11185. }
  11186. if (o.useStorage && $.jgrid.isLocalStorage()) {
  11187. try {
  11188. window[o.storageType].setItem("jqGrid" + $t.p.id, gridstate);
  11189. window[o.storageType].setItem("jqGrid" + $t.p.id + "_data", data);
  11190. } catch (e) {
  11191. if (e.code === 22) { // chrome is 21
  11192. // just for now. we should make some additionla changes and eventually clear some local items
  11193. alert("Local storage limit is over!");
  11194. }
  11195. }
  11196. }
  11197. return gridstate;
  11198. },
  11199. loadState: function (jqGridId, gridstring, o) {
  11200. o = $.extend({
  11201. useStorage: true,
  11202. storageType: "localStorage",
  11203. clearAfterLoad: false, // clears the jqGrid localStorage items aftre load
  11204. beforeSetGrid: null,
  11205. afterSetGrid: null,
  11206. decompression: false,
  11207. decompressionModule: 'LZString', // object by example gzip, LZString
  11208. decompressionMethod: 'decompressFromUTF16' // string by example unzip, decompressFromUTF16
  11209. }, o || {});
  11210. if (!jqGridId) { return; }
  11211. var ret, tmp, $t = $("#" + jqGridId)[0], data, iN, fT;
  11212. if (o.useStorage) {
  11213. try {
  11214. gridstring = window[o.storageType].getItem("jqGrid" + $t.id);
  11215. data = window[o.storageType].getItem("jqGrid" + $t.id + "_data");
  11216. } catch (e) {
  11217. // can not get data
  11218. }
  11219. }
  11220. if (!gridstring) { return; }
  11221. if (o.decompression) {
  11222. if (o.decompressionModule) {
  11223. try {
  11224. ret = window[o.decompressionModule][o.decompressionMethod](gridstring);
  11225. if (ret != null) {
  11226. gridstring = ret;
  11227. data = window[o.decompressionModule][o.decompressionMethod](data);
  11228. }
  11229. } catch (e) {
  11230. // decompression can not be done
  11231. }
  11232. }
  11233. }
  11234. ret = jqGridUtils.parse(gridstring);
  11235. if (ret && $.type(ret) === 'object') {
  11236. if ($t.grid) {
  11237. $.jgrid.gridUnload(jqGridId);
  11238. }
  11239. if ($.isFunction(o.beforeSetGrid)) {
  11240. tmp = o.beforeSetGrid(ret);
  11241. if (tmp && $.type(tmp) === 'object') {
  11242. ret = tmp;
  11243. }
  11244. }
  11245. // some preparings
  11246. var retfunc = function (param) { var p; p = param; return p; },
  11247. prm = {
  11248. "reccount": ret.reccount,
  11249. "records": ret.records,
  11250. "lastpage": ret.lastpage,
  11251. "shrinkToFit": retfunc(ret.shrinkToFit),
  11252. "data": retfunc(ret.data),
  11253. "datatype": retfunc(ret.datatype),
  11254. "grouping": retfunc(ret.grouping)
  11255. };
  11256. ret.shrinkToFit = false;
  11257. ret.data = [];
  11258. ret.datatype = 'local';
  11259. ret.grouping = false;
  11260. //ret.navGrid = false;
  11261. if (ret.inlineNav) {
  11262. iN = retfunc(ret._iN);
  11263. ret._iN = null; delete ret._iN;
  11264. }
  11265. if (ret.filterToolbar) {
  11266. fT = retfunc(ret._fT);
  11267. ret._fT = null; delete ret._fT;
  11268. }
  11269. var grid = $("#" + jqGridId).jqGrid(ret);
  11270. grid.append(data);
  11271. grid.jqGrid('setGridParam', prm);
  11272. if (ret.storeNavOptions && ret.navGrid) {
  11273. // set to false so that nav grid can be run
  11274. grid[0].p.navGrid = false;
  11275. grid.jqGrid('navGrid', ret.pager, ret.navOptions, ret.editOptions, ret.addOptions, ret.delOptions, ret.searchOptions, ret.viewOptions);
  11276. if (ret.navButtons && ret.navButtons.length) {
  11277. for (var b = 0; b < ret.navButtons.length; b++) {
  11278. if ('sepclass' in ret.navButtons[b][1]) {
  11279. grid.jqGrid('navSeparatorAdd', ret.navButtons[b][0], ret.navButtons[b][1]);
  11280. } else {
  11281. grid.jqGrid('navButtonAdd', ret.navButtons[b][0], ret.navButtons[b][1]);
  11282. }
  11283. }
  11284. }
  11285. }
  11286. // refresh index
  11287. grid[0].refreshIndex();
  11288. // subgrid
  11289. if (ret.subGrid) {
  11290. var ms = ret.multiselect === 1 ? 1 : 0,
  11291. rn = ret.rownumbers === true ? 1 : 0;
  11292. grid.jqGrid('addSubGrid', ms + rn);
  11293. }
  11294. // treegrid
  11295. if (ret.treeGrid) {
  11296. var i = 1, len = grid[0].rows.length,
  11297. expCol = ret.expColInd,
  11298. isLeaf = ret.treeReader.leaf_field,
  11299. expanded = ret.treeReader.expanded_field;
  11300. // optimization of code needed here
  11301. while (i < len) {
  11302. $(grid[0].rows[i].cells[expCol])
  11303. .find("div.treeclick")
  11304. .bind("click", function (e) {
  11305. var target = e.target || e.srcElement,
  11306. ind2 = $.jgrid.stripPref(ret.idPrefix, $(target, grid[0].rows).closest("tr.jqgrow")[0].id),
  11307. pos = grid[0].p._index[ind2];
  11308. if (!grid[0].p.data[pos][isLeaf]) {
  11309. if (grid[0].p.data[pos][expanded]) {
  11310. grid.jqGrid("collapseRow", grid[0].p.data[pos]);
  11311. grid.jqGrid("collapseNode", grid[0].p.data[pos]);
  11312. } else {
  11313. grid.jqGrid("expandRow", grid[0].p.data[pos]);
  11314. grid.jqGrid("expandNode", grid[0].p.data[pos]);
  11315. }
  11316. }
  11317. return false;
  11318. });
  11319. if (ret.ExpandColClick === true) {
  11320. $(grid[0].rows[i].cells[expCol])
  11321. .find("span.cell-wrapper")
  11322. .css("cursor", "pointer")
  11323. .bind("click", function (e) {
  11324. var target = e.target || e.srcElement,
  11325. ind2 = $.jgrid.stripPref(ret.idPrefix, $(target, grid[0].rows).closest("tr.jqgrow")[0].id),
  11326. pos = grid[0].p._index[ind2];
  11327. if (!grid[0].p.data[pos][isLeaf]) {
  11328. if (grid[0].p.data[pos][expanded]) {
  11329. grid.jqGrid("collapseRow", grid[0].p.data[pos]);
  11330. grid.jqGrid("collapseNode", grid[0].p.data[pos]);
  11331. } else {
  11332. grid.jqGrid("expandRow", grid[0].p.data[pos]);
  11333. grid.jqGrid("expandNode", grid[0].p.data[pos]);
  11334. }
  11335. }
  11336. grid.jqGrid("setSelection", ind2);
  11337. return false;
  11338. });
  11339. }
  11340. i++;
  11341. }
  11342. }
  11343. // multiselect
  11344. if (ret.multiselect) {
  11345. $.each(ret.selarrrow, function () {
  11346. $("#jqg_" + jqGridId + "_" + this)[ret.useProp ? 'prop' : 'attr']("checked", "checked");
  11347. });
  11348. }
  11349. // grouping
  11350. // pivotgrid
  11351. if (ret.inlineNav && iN) {
  11352. grid.jqGrid('setGridParam', { inlineNav: false });
  11353. grid.jqGrid('inlineNav', ret.pager, iN);
  11354. }
  11355. if (ret.filterToolbar && fT) {
  11356. grid.jqGrid('setGridParam', { filterToolbar: false });
  11357. fT.restoreFromFilters = true;
  11358. grid.jqGrid('filterToolbar', fT);
  11359. }
  11360. // finally frozenColums
  11361. if (ret.frozenColumns) {
  11362. grid.jqGrid('setFrozenColumns');
  11363. }
  11364. grid[0].updatepager(true, true);
  11365. if ($.isFunction(o.afterSetGrid)) {
  11366. o.afterSetGrid(grid);
  11367. }
  11368. if (o.clearAfterLoad) {
  11369. window[o.storageType].removeItem("jqGrid" + $t.id);
  11370. window[o.storageType].removeItem("jqGrid" + $t.id + "_data");
  11371. }
  11372. } else {
  11373. alert("can not convert to object");
  11374. }
  11375. },
  11376. isGridInStorage: function (jqGridId, options) {
  11377. var o = {
  11378. storageType: "localStorage"
  11379. };
  11380. o = $.extend(o, options || {});
  11381. var ret, gridstring, data;
  11382. try {
  11383. gridstring = window[o.storageType].getItem("jqGrid" + jqGridId);
  11384. data = window[o.storageType].getItem("jqGrid" + jqGridId + "_data");
  11385. ret = gridstring != null && data != null && typeof gridstring === "string" && typeof data === "string";
  11386. } catch (e) {
  11387. ret = false;
  11388. }
  11389. return ret;
  11390. },
  11391. setRegional: function (jqGridId, options) {
  11392. var o = {
  11393. storageType: "sessionStorage"
  11394. };
  11395. o = $.extend(o, options || {});
  11396. if (!o.regional) {
  11397. return;
  11398. }
  11399. $.jgrid.saveState(jqGridId, o);
  11400. o.beforeSetGrid = function (params) {
  11401. params.regional = o.regional;
  11402. params.force_regional = true;
  11403. return params;
  11404. };
  11405. $.jgrid.loadState(jqGridId, null, o);
  11406. // check for formatter actions
  11407. var grid = $("#" + jqGridId)[0],
  11408. model = $(grid).jqGrid('getGridParam', 'colModel'), i = -1, nav = $.jgrid.getRegional(grid, 'nav');
  11409. $.each(model, function (k) {
  11410. if (this.formatter && this.formatter === 'actions') {
  11411. i = k;
  11412. return false;
  11413. }
  11414. });
  11415. if (i !== -1 && nav) {
  11416. $("#" + jqGridId + " tbody tr").each(function () {
  11417. var td = this.cells[i];
  11418. $(td).find(".ui-inline-edit").attr("title", nav.edittitle);
  11419. $(td).find(".ui-inline-del").attr("title", nav.deltitle);
  11420. $(td).find(".ui-inline-save").attr("title", nav.savetitle);
  11421. $(td).find(".ui-inline-cancel").attr("title", nav.canceltitle);
  11422. });
  11423. }
  11424. try {
  11425. window[o.storageType].removeItem("jqGrid" + grid.id);
  11426. window[o.storageType].removeItem("jqGrid" + grid.id + "_data");
  11427. } catch (e) { }
  11428. },
  11429. jqGridImport: function (jqGridId, o) {
  11430. o = $.extend({
  11431. imptype: "xml", // xml, json, xmlstring, jsonstring
  11432. impstring: "",
  11433. impurl: "",
  11434. mtype: "GET",
  11435. impData: {},
  11436. xmlGrid: {
  11437. config: "root>grid",
  11438. data: "root>rows"
  11439. },
  11440. jsonGrid: {
  11441. config: "grid",
  11442. data: "data"
  11443. },
  11444. ajaxOptions: {}
  11445. }, o || {});
  11446. var $t = (jqGridId.indexOf("#") === 0 ? "" : "#") + $.jgrid.jqID(jqGridId);
  11447. var xmlConvert = function (xml, o) {
  11448. var cnfg = $(o.xmlGrid.config, xml)[0];
  11449. var xmldata = $(o.xmlGrid.data, xml)[0], jstr, jstr1, key;
  11450. if (jqGridUtils.xmlToJSON) {
  11451. jstr = jqGridUtils.xmlToJSON(cnfg);
  11452. //jstr = $.jgrid.parse(jstr);
  11453. for (key in jstr) {
  11454. if (jstr.hasOwnProperty(key)) {
  11455. jstr1 = jstr[key];
  11456. }
  11457. }
  11458. if (xmldata) {
  11459. // save the datatype
  11460. var svdatatype = jstr.grid.datatype;
  11461. jstr.grid.datatype = 'xmlstring';
  11462. jstr.grid.datastr = xml;
  11463. $($t).jqGrid(jstr1).jqGrid("setGridParam", { datatype: svdatatype });
  11464. } else {
  11465. setTimeout(function () { $($t).jqGrid(jstr1); }, 0);
  11466. }
  11467. } else {
  11468. alert("xml2json or parse are not present");
  11469. }
  11470. };
  11471. var jsonConvert = function (jsonstr, o) {
  11472. if (jsonstr && typeof jsonstr === 'string') {
  11473. var json = jqGridUtils.parse(jsonstr);
  11474. var gprm = json[o.jsonGrid.config];
  11475. var jdata = json[o.jsonGrid.data];
  11476. if (jdata) {
  11477. var svdatatype = gprm.datatype;
  11478. gprm.datatype = 'jsonstring';
  11479. gprm.datastr = jdata;
  11480. $($t).jqGrid(gprm).jqGrid("setGridParam", { datatype: svdatatype });
  11481. } else {
  11482. $($t).jqGrid(gprm);
  11483. }
  11484. }
  11485. };
  11486. switch (o.imptype) {
  11487. case 'xml':
  11488. $.ajax($.extend({
  11489. url: o.impurl,
  11490. type: o.mtype,
  11491. data: o.impData,
  11492. dataType: "xml",
  11493. complete: function (xml, stat) {
  11494. if (stat === 'success') {
  11495. xmlConvert(xml.responseXML, o);
  11496. $($t).triggerHandler("jqGridImportComplete", [xml, o]);
  11497. if ($.isFunction(o.importComplete)) {
  11498. o.importComplete(xml);
  11499. }
  11500. }
  11501. xml = null;
  11502. }
  11503. }, o.ajaxOptions));
  11504. break;
  11505. case 'xmlstring':
  11506. // we need to make just the conversion and use the same code as xml
  11507. if (o.impstring && typeof o.impstring === 'string') {
  11508. var xmld = $.parseXML(o.impstring);
  11509. if (xmld) {
  11510. xmlConvert(xmld, o);
  11511. $($t).triggerHandler("jqGridImportComplete", [xmld, o]);
  11512. if ($.isFunction(o.importComplete)) {
  11513. o.importComplete(xmld);
  11514. }
  11515. }
  11516. }
  11517. break;
  11518. case 'json':
  11519. $.ajax($.extend({
  11520. url: o.impurl,
  11521. type: o.mtype,
  11522. data: o.impData,
  11523. dataType: "json",
  11524. complete: function (json) {
  11525. try {
  11526. jsonConvert(json.responseText, o);
  11527. $($t).triggerHandler("jqGridImportComplete", [json, o]);
  11528. if ($.isFunction(o.importComplete)) {
  11529. o.importComplete(json);
  11530. }
  11531. } catch (ee) { }
  11532. json = null;
  11533. }
  11534. }, o.ajaxOptions));
  11535. break;
  11536. case 'jsonstring':
  11537. if (o.impstring && typeof o.impstring === 'string') {
  11538. jsonConvert(o.impstring, o);
  11539. $($t).triggerHandler("jqGridImportComplete", [o.impstring, o]);
  11540. if ($.isFunction(o.importComplete)) {
  11541. o.importComplete(o.impstring);
  11542. }
  11543. }
  11544. break;
  11545. }
  11546. }
  11547. });
  11548. $.jgrid.extend({
  11549. jqGridExport: function (o) {
  11550. o = $.extend({
  11551. exptype: "xmlstring",
  11552. root: "grid",
  11553. ident: "\t",
  11554. addOptions: {}
  11555. }, o || {});
  11556. var ret = null;
  11557. this.each(function () {
  11558. if (!this.grid) { return; }
  11559. var key, gprm = $.extend(true, {}, $(this).jqGrid("getGridParam"), o.addOptions);
  11560. // we need to check for:
  11561. // 1.multiselect, 2.subgrid 3. treegrid and remove the unneded columns from colNames
  11562. if (gprm.rownumbers) {
  11563. gprm.colNames.splice(0, 1);
  11564. gprm.colModel.splice(0, 1);
  11565. }
  11566. if (gprm.multiselect) {
  11567. gprm.colNames.splice(0, 1);
  11568. gprm.colModel.splice(0, 1);
  11569. }
  11570. if (gprm.subGrid) {
  11571. gprm.colNames.splice(0, 1);
  11572. gprm.colModel.splice(0, 1);
  11573. }
  11574. gprm.knv = null;
  11575. switch (o.exptype) {
  11576. case 'xmlstring':
  11577. ret = "<" + o.root + ">" + jqGridUtils.jsonToXML(gprm, { xmlDecl: "" }) + "</" + o.root + ">";
  11578. break;
  11579. case 'jsonstring':
  11580. ret = jqGridUtils.stringify(gprm);
  11581. if (o.root) { ret = "{" + o.root + ":" + ret + "}"; }
  11582. break;
  11583. }
  11584. });
  11585. return ret;
  11586. },
  11587. excelExport: function (o) {
  11588. o = $.extend({
  11589. exptype: "remote",
  11590. url: null,
  11591. oper: "oper",
  11592. tag: "excel",
  11593. beforeExport: null,
  11594. exporthidden: false,
  11595. exportgrouping: false,
  11596. exportOptions: {}
  11597. }, o || {});
  11598. return this.each(function () {
  11599. if (!this.grid) { return; }
  11600. var url;
  11601. if (o.exptype === "remote") {
  11602. var pdata = $.extend({}, this.p.postData), expg;
  11603. pdata[o.oper] = o.tag;
  11604. if ($.isFunction(o.beforeExport)) {
  11605. var result = o.beforeExport.call(this, pdata);
  11606. if ($.isPlainObject(result)) {
  11607. pdata = result;
  11608. }
  11609. }
  11610. if (o.exporthidden) {
  11611. var cm = this.p.colModel, i, len = cm.length, newm = [];
  11612. for (i = 0; i < len; i++) {
  11613. if (cm[i].hidden === undefined) { cm[i].hidden = false; }
  11614. newm.push({ name: cm[i].name, hidden: cm[i].hidden });
  11615. }
  11616. var newm1 = JSON.stringify(newm);
  11617. if (typeof newm1 === 'string') {
  11618. pdata['colModel'] = newm1;
  11619. }
  11620. }
  11621. if (o.exportgrouping) {
  11622. expg = JSON.stringify(this.p.groupingView)
  11623. if (typeof expg === 'string') {
  11624. pdata['groupingView'] = expg;
  11625. }
  11626. }
  11627. var params = jQuery.param(pdata);
  11628. if (o.url.indexOf("?") !== -1) { url = o.url + "&" + params; }
  11629. else { url = o.url + "?" + params; }
  11630. window.location = url;
  11631. }
  11632. });
  11633. }
  11634. });
  11635. //module begin
  11636. $.jgrid.inlineEdit = $.jgrid.inlineEdit || {};
  11637. $.jgrid.extend({
  11638. //Editing
  11639. editRow: function (rowid, keys, oneditfunc, successfunc, url, extraparam, aftersavefunc, errorfunc, afterrestorefunc) {
  11640. // Compatible mode old versions
  11641. var o = {}, args = $.makeArray(arguments).slice(1);
  11642. if ($.type(args[0]) === "object") {
  11643. o = args[0];
  11644. } else {
  11645. if (keys !== undefined) { o.keys = keys; }
  11646. if ($.isFunction(oneditfunc)) { o.oneditfunc = oneditfunc; }
  11647. if ($.isFunction(successfunc)) { o.successfunc = successfunc; }
  11648. if (url !== undefined) { o.url = url; }
  11649. if (extraparam !== undefined) { o.extraparam = extraparam; }
  11650. if ($.isFunction(aftersavefunc)) { o.aftersavefunc = aftersavefunc; }
  11651. if ($.isFunction(errorfunc)) { o.errorfunc = errorfunc; }
  11652. if ($.isFunction(afterrestorefunc)) { o.afterrestorefunc = afterrestorefunc; }
  11653. // last two not as param, but as object (sorry)
  11654. //if (restoreAfterError !== undefined) { o.restoreAfterError = restoreAfterError; }
  11655. //if (mtype !== undefined) { o.mtype = mtype || "POST"; }
  11656. }
  11657. o = $.extend(true, {
  11658. keys: false,
  11659. keyevent: "keydown",
  11660. oneditfunc: null,
  11661. successfunc: null,
  11662. url: null,
  11663. extraparam: {},
  11664. aftersavefunc: null,
  11665. errorfunc: null,
  11666. afterrestorefunc: null,
  11667. restoreAfterError: true,
  11668. mtype: "POST",
  11669. focusField: true
  11670. }, $.jgrid.inlineEdit, o);
  11671. // End compatible
  11672. return this.each(function () {
  11673. var $t = this, nm, tmp, editable, cnt = 0, focus = null, svr = {}, ind, cm, bfer,
  11674. inpclass = $(this).jqGrid('getStyleUI', $t.p.styleUI + ".inlinedit", 'inputClass', true);
  11675. if (!$t.grid) { return; }
  11676. ind = $($t).jqGrid("getInd", rowid, true);
  11677. if (ind === false) { return; }
  11678. bfer = $.isFunction(o.beforeEditRow) ? o.beforeEditRow.call($t, o, rowid) : undefined;
  11679. if (bfer === undefined) {
  11680. bfer = true;
  11681. }
  11682. if (!bfer) { return; }
  11683. editable = $(ind).attr("editable") || "0";
  11684. if (editable === "0" && !$(ind).hasClass("not-editable-row")) {
  11685. cm = $t.p.colModel;
  11686. $('td[role="gridcell"]', ind).each(function (i) {
  11687. nm = cm[i].name;
  11688. var treeg = $t.p.treeGrid === true && nm === $t.p.ExpandColumn;
  11689. if (treeg) { tmp = $("span:first", this).html(); }
  11690. else {
  11691. try {
  11692. tmp = $.unformat.call($t, this, { rowId: rowid, colModel: cm[i] }, i);
  11693. } catch (_) {
  11694. tmp = (cm[i].edittype && cm[i].edittype === 'textarea') ? $(this).text() : $(this).html();
  11695. }
  11696. }
  11697. if (nm !== 'cb' && nm !== 'subgrid' && nm !== 'rn') {
  11698. if ($t.p.autoencode) { tmp = $.jgrid.htmlDecode(tmp); }
  11699. svr[nm] = tmp;
  11700. if (cm[i].editable === true) {
  11701. if (focus === null) { focus = i; }
  11702. if (treeg) { $("span:first", this).html(""); }
  11703. else { $(this).html(""); }
  11704. var opt = $.extend({}, cm[i].editoptions || {}, { id: rowid + "_" + nm, name: nm, rowId: rowid, oper: 'edit' });
  11705. if (!cm[i].edittype) { cm[i].edittype = "text"; }
  11706. if (tmp === "&nbsp;" || tmp === "&#160;" || (tmp.length === 1 && tmp.charCodeAt(0) === 160)) { tmp = ''; }
  11707. var elc = $.jgrid.createEl.call($t, cm[i].edittype, opt, tmp, true, $.extend({}, $.jgrid.ajaxOptions, $t.p.ajaxSelectOptions || {}));
  11708. $(elc).addClass("editable inline-edit-cell");
  11709. if ($.inArray(cm[i].edittype, ['text', 'textarea', 'password', 'select']) > -1) {
  11710. $(elc).addClass(inpclass);
  11711. }
  11712. if (treeg) { $("span:first", this).append(elc); }
  11713. else { $(this).append(elc); }
  11714. $.jgrid.bindEv.call($t, elc, opt);
  11715. //Again IE
  11716. if (cm[i].edittype === "select" && cm[i].editoptions !== undefined && cm[i].editoptions.multiple === true && cm[i].editoptions.dataUrl === undefined && $.jgrid.msie) {
  11717. $(elc).width($(elc).width());
  11718. }
  11719. cnt++;
  11720. }
  11721. }
  11722. });
  11723. if (cnt > 0) {
  11724. svr.id = rowid; $t.p.savedRow.push(svr);
  11725. $(ind).attr("editable", "1");
  11726. if (o.focusField) {
  11727. if (typeof o.focusField === 'number' && parseInt(o.focusField, 10) <= cm.length) {
  11728. focus = o.focusField;
  11729. }
  11730. setTimeout(function () {
  11731. var fe = $("td:eq(" + focus + ") :input:visible", ind).not(":disabled");
  11732. if (fe.length > 0) {
  11733. fe.focus();
  11734. }
  11735. }, 0);
  11736. }
  11737. if (o.keys === true) {
  11738. $(ind).bind(o.keyevent, function (e) {
  11739. if (e.keyCode === 27) {
  11740. $($t).jqGrid("restoreRow", rowid, o.afterrestorefunc);
  11741. if ($t.p.inlineNav) {
  11742. try {
  11743. $($t).jqGrid('showAddEditButtons');
  11744. } catch (eer1) { }
  11745. }
  11746. return false;
  11747. }
  11748. if (e.keyCode === 13) {
  11749. var ta = e.target;
  11750. if (ta.tagName === 'TEXTAREA') { return true; }
  11751. if ($($t).jqGrid("saveRow", rowid, o)) {
  11752. if ($t.p.inlineNav) {
  11753. try {
  11754. $($t).jqGrid('showAddEditButtons');
  11755. } catch (eer2) { }
  11756. }
  11757. }
  11758. return false;
  11759. }
  11760. });
  11761. }
  11762. $($t).triggerHandler("jqGridInlineEditRow", [rowid, o]);
  11763. if ($.isFunction(o.oneditfunc)) { o.oneditfunc.call($t, rowid); }
  11764. }
  11765. }
  11766. });
  11767. },
  11768. saveRow: function (rowid, successfunc, url, extraparam, aftersavefunc, errorfunc, afterrestorefunc) {
  11769. // Compatible mode old versions
  11770. var args = $.makeArray(arguments).slice(1), o = {}, $t = this[0];
  11771. if ($.type(args[0]) === "object") {
  11772. o = args[0];
  11773. } else {
  11774. if ($.isFunction(successfunc)) { o.successfunc = successfunc; }
  11775. if (url !== undefined) { o.url = url; }
  11776. if (extraparam !== undefined) { o.extraparam = extraparam; }
  11777. if ($.isFunction(aftersavefunc)) { o.aftersavefunc = aftersavefunc; }
  11778. if ($.isFunction(errorfunc)) { o.errorfunc = errorfunc; }
  11779. if ($.isFunction(afterrestorefunc)) { o.afterrestorefunc = afterrestorefunc; }
  11780. }
  11781. o = $.extend(true, {
  11782. successfunc: null,
  11783. url: null,
  11784. extraparam: {},
  11785. aftersavefunc: null,
  11786. errorfunc: null,
  11787. afterrestorefunc: null,
  11788. restoreAfterError: true,
  11789. mtype: "POST",
  11790. saveui: "enable",
  11791. savetext: $.jgrid.getRegional($t, 'defaults.savetext')
  11792. }, $.jgrid.inlineEdit, o);
  11793. // End compatible
  11794. var success = false, nm, tmp = {}, tmp2 = {}, tmp3 = {}, editable, fr, cv, ind, nullIfEmpty = false,
  11795. error = $.trim($($t).jqGrid('getStyleUI', $t.p.styleUI + '.common', 'error', true));
  11796. if (!$t.grid) { return success; }
  11797. ind = $($t).jqGrid("getInd", rowid, true);
  11798. if (ind === false) { return success; }
  11799. var errors = $.jgrid.getRegional($t, 'errors'),
  11800. edit = $.jgrid.getRegional($t, 'edit'),
  11801. bfsr = $.isFunction(o.beforeSaveRow) ? o.beforeSaveRow.call($t, o, rowid) : undefined;
  11802. if (bfsr === undefined) {
  11803. bfsr = true;
  11804. }
  11805. if (!bfsr) { return; }
  11806. editable = $(ind).attr("editable");
  11807. o.url = o.url || $t.p.editurl;
  11808. if (editable === "1") {
  11809. var cm;
  11810. $('td[role="gridcell"]', ind).each(function (i) {
  11811. cm = $t.p.colModel[i];
  11812. nm = cm.name;
  11813. if (nm !== 'cb' && nm !== 'subgrid' && cm.editable === true && nm !== 'rn' && !$(this).hasClass('not-editable-cell')) {
  11814. switch (cm.edittype) {
  11815. case "checkbox":
  11816. var cbv = ["Yes", "No"];
  11817. if (cm.editoptions) {
  11818. cbv = cm.editoptions.value.split(":");
  11819. }
  11820. tmp[nm] = $("input", this).is(":checked") ? cbv[0] : cbv[1];
  11821. break;
  11822. case 'text':
  11823. case 'password':
  11824. case 'textarea':
  11825. case "button":
  11826. tmp[nm] = $("input, textarea", this).val();
  11827. break;
  11828. case 'select':
  11829. if (!cm.editoptions.multiple) {
  11830. tmp[nm] = $("select option:selected", this).val();
  11831. tmp2[nm] = $("select option:selected", this).text();
  11832. } else {
  11833. var sel = $("select", this), selectedText = [];
  11834. tmp[nm] = $(sel).val();
  11835. if (tmp[nm]) { tmp[nm] = tmp[nm].join(","); } else { tmp[nm] = ""; }
  11836. $("select option:selected", this).each(
  11837. function (i, selected) {
  11838. selectedText[i] = $(selected).text();
  11839. }
  11840. );
  11841. tmp2[nm] = selectedText.join(",");
  11842. }
  11843. if (cm.formatter && cm.formatter === 'select') { tmp2 = {}; }
  11844. break;
  11845. case 'custom':
  11846. try {
  11847. if (cm.editoptions && $.isFunction(cm.editoptions.custom_value)) {
  11848. tmp[nm] = cm.editoptions.custom_value.call($t, $(".customelement", this), 'get');
  11849. if (tmp[nm] === undefined) { throw "e2"; }
  11850. } else { throw "e1"; }
  11851. } catch (e) {
  11852. if (e === "e1") { $.jgrid.info_dialog(errors.errcap, "function 'custom_value' " + edit.msg.nodefined, edit.bClose, { styleUI: $t.p.styleUI }); }
  11853. else { $.jgrid.info_dialog(errors.errcap, e.message, edit.bClose, { styleUI: $t.p.styleUI }); }
  11854. }
  11855. break;
  11856. }
  11857. cv = $.jgrid.checkValues.call($t, tmp[nm], i);
  11858. if (cv[0] === false) {
  11859. return false;
  11860. }
  11861. if ($t.p.autoencode) { tmp[nm] = $.jgrid.htmlEncode(tmp[nm]); }
  11862. if (o.url !== 'clientArray' && cm.editoptions && cm.editoptions.NullIfEmpty === true) {
  11863. if (tmp[nm] === "") {
  11864. tmp3[nm] = 'null';
  11865. nullIfEmpty = true;
  11866. }
  11867. }
  11868. }
  11869. });
  11870. if (cv[0] === false) {
  11871. try {
  11872. var tr = $($t).jqGrid('getGridRowById', rowid), positions = $.jgrid.findPos(tr);
  11873. $.jgrid.info_dialog(errors.errcap, cv[1], edit.bClose, { left: positions[0], top: positions[1] + $(tr).outerHeight(), styleUI: $t.p.styleUI });
  11874. } catch (e) {
  11875. alert(cv[1]);
  11876. }
  11877. return success;
  11878. }
  11879. var idname, opers = $t.p.prmNames, oldRowId = rowid;
  11880. if ($t.p.keyName === false) {
  11881. idname = opers.id;
  11882. } else {
  11883. idname = $t.p.keyName;
  11884. }
  11885. if (tmp) {
  11886. tmp[opers.oper] = opers.editoper;
  11887. if (tmp[idname] === undefined || tmp[idname] === "") {
  11888. tmp[idname] = rowid;
  11889. } else if (ind.id !== $t.p.idPrefix + tmp[idname]) {
  11890. // rename rowid
  11891. var oldid = $.jgrid.stripPref($t.p.idPrefix, rowid);
  11892. if ($t.p._index[oldid] !== undefined) {
  11893. $t.p._index[tmp[idname]] = $t.p._index[oldid];
  11894. delete $t.p._index[oldid];
  11895. }
  11896. rowid = $t.p.idPrefix + tmp[idname];
  11897. $(ind).attr("id", rowid);
  11898. if ($t.p.selrow === oldRowId) {
  11899. $t.p.selrow = rowid;
  11900. }
  11901. if ($.isArray($t.p.selarrrow)) {
  11902. var i = $.inArray(oldRowId, $t.p.selarrrow);
  11903. if (i >= 0) {
  11904. $t.p.selarrrow[i] = rowid;
  11905. }
  11906. }
  11907. if ($t.p.multiselect) {
  11908. var newCboxId = "jqg_" + $t.p.id + "_" + rowid;
  11909. $("input.cbox", ind)
  11910. .attr("id", newCboxId)
  11911. .attr("name", newCboxId);
  11912. }
  11913. // TODO: to test the case of frozen columns
  11914. }
  11915. if ($t.p.inlineData === undefined) { $t.p.inlineData = {}; }
  11916. tmp = $.extend({}, tmp, $t.p.inlineData, o.extraparam);
  11917. }
  11918. if (o.url === 'clientArray') {
  11919. tmp = $.extend({}, tmp, tmp2);
  11920. if ($t.p.autoencode) {
  11921. $.each(tmp, function (n, v) {
  11922. tmp[n] = $.jgrid.htmlDecode(v);
  11923. });
  11924. }
  11925. var k, resp = $($t).jqGrid("setRowData", rowid, tmp);
  11926. $(ind).attr("editable", "0");
  11927. for (k = 0; k < $t.p.savedRow.length; k++) {
  11928. if (String($t.p.savedRow[k].id) === String(oldRowId)) { fr = k; break; }
  11929. }
  11930. if (fr >= 0) { $t.p.savedRow.splice(fr, 1); }
  11931. $($t).triggerHandler("jqGridInlineAfterSaveRow", [rowid, resp, tmp, o]);
  11932. if ($.isFunction(o.aftersavefunc)) { o.aftersavefunc.call($t, rowid, resp, tmp, o); }
  11933. success = true;
  11934. $(ind).removeClass("jqgrid-new-row").unbind("keydown");
  11935. } else {
  11936. $($t).jqGrid("progressBar", { method: "show", loadtype: o.saveui, htmlcontent: o.savetext });
  11937. tmp3 = $.extend({}, tmp, tmp3);
  11938. tmp3[idname] = $.jgrid.stripPref($t.p.idPrefix, tmp3[idname]);
  11939. $.ajax($.extend({
  11940. url: o.url,
  11941. data: $.isFunction($t.p.serializeRowData) ? $t.p.serializeRowData.call($t, tmp3) : tmp3,
  11942. type: o.mtype,
  11943. async: false, //?!?
  11944. complete: function (res, stat) {
  11945. $($t).jqGrid("progressBar", { method: "hide", loadtype: o.saveui, htmlcontent: o.savetext });
  11946. if (stat === "success") {
  11947. var ret = true, sucret, k;
  11948. sucret = $($t).triggerHandler("jqGridInlineSuccessSaveRow", [res, rowid, o]);
  11949. if (!$.isArray(sucret)) { sucret = [true, tmp3]; }
  11950. if (sucret[0] && $.isFunction(o.successfunc)) { sucret = o.successfunc.call($t, res); }
  11951. if ($.isArray(sucret)) {
  11952. // expect array - status, data, rowid
  11953. ret = sucret[0];
  11954. tmp = sucret[1] || tmp;
  11955. } else {
  11956. ret = sucret;
  11957. }
  11958. if (ret === true) {
  11959. if ($t.p.autoencode) {
  11960. $.each(tmp, function (n, v) {
  11961. tmp[n] = $.jgrid.htmlDecode(v);
  11962. });
  11963. }
  11964. if (nullIfEmpty) {
  11965. $.each(tmp, function (n) {
  11966. if (tmp[n] === 'null') {
  11967. tmp[n] = '';
  11968. }
  11969. });
  11970. }
  11971. tmp = $.extend({}, tmp, tmp2);
  11972. $($t).jqGrid("setRowData", rowid, tmp);
  11973. $(ind).attr("editable", "0");
  11974. for (k = 0; k < $t.p.savedRow.length; k++) {
  11975. if (String($t.p.savedRow[k].id) === String(rowid)) { fr = k; break; }
  11976. }
  11977. if (fr >= 0) { $t.p.savedRow.splice(fr, 1); }
  11978. $($t).triggerHandler("jqGridInlineAfterSaveRow", [rowid, res, tmp, o]);
  11979. if ($.isFunction(o.aftersavefunc)) { o.aftersavefunc.call($t, rowid, res, tmp, o); }
  11980. success = true;
  11981. $(ind).removeClass("jqgrid-new-row").unbind("keydown");
  11982. } else {
  11983. $($t).triggerHandler("jqGridInlineErrorSaveRow", [rowid, res, stat, null, o]);
  11984. if ($.isFunction(o.errorfunc)) {
  11985. o.errorfunc.call($t, rowid, res, stat, null);
  11986. }
  11987. if (o.restoreAfterError === true) {
  11988. $($t).jqGrid("restoreRow", rowid, o.afterrestorefunc);
  11989. }
  11990. }
  11991. }
  11992. },
  11993. error: function (res, stat, err) {
  11994. $("#lui_" + $.jgrid.jqID($t.p.id)).hide();
  11995. $($t).triggerHandler("jqGridInlineErrorSaveRow", [rowid, res, stat, err, o]);
  11996. if ($.isFunction(o.errorfunc)) {
  11997. o.errorfunc.call($t, rowid, res, stat, err);
  11998. } else {
  11999. var rT = res.responseText || res.statusText;
  12000. try {
  12001. $.jgrid.info_dialog(errors.errcap, '<div class="' + error + '">' + rT + '</div>', edit.bClose, { buttonalign: 'right', styleUI: $t.p.styleUI });
  12002. } catch (e) {
  12003. alert(rT);
  12004. }
  12005. }
  12006. if (o.restoreAfterError === true) {
  12007. $($t).jqGrid("restoreRow", rowid, o.afterrestorefunc);
  12008. }
  12009. }
  12010. }, $.jgrid.ajaxOptions, $t.p.ajaxRowOptions || {}));
  12011. }
  12012. }
  12013. return success;
  12014. },
  12015. restoreRow: function (rowid, afterrestorefunc) {
  12016. // Compatible mode old versions
  12017. var args = $.makeArray(arguments).slice(1), o = {};
  12018. if ($.type(args[0]) === "object") {
  12019. o = args[0];
  12020. } else {
  12021. if ($.isFunction(afterrestorefunc)) { o.afterrestorefunc = afterrestorefunc; }
  12022. }
  12023. o = $.extend(true, {}, $.jgrid.inlineEdit, o);
  12024. // End compatible
  12025. return this.each(function () {
  12026. var $t = this, fr = -1, ind, ares = {}, k;
  12027. if (!$t.grid) { return; }
  12028. ind = $($t).jqGrid("getInd", rowid, true);
  12029. if (ind === false) { return; }
  12030. var bfcr = $.isFunction(o.beforeCancelRow) ? o.beforeCancelRow.call($t, o, rowid) : undefined;
  12031. if (bfcr === undefined) {
  12032. bfcr = true;
  12033. }
  12034. if (!bfcr) { return; }
  12035. for (k = 0; k < $t.p.savedRow.length; k++) {
  12036. if (String($t.p.savedRow[k].id) === String(rowid)) { fr = k; break; }
  12037. }
  12038. if (fr >= 0) {
  12039. if ($.isFunction($.fn.datepicker)) {
  12040. try {
  12041. $("input.hasDatepicker", "#" + $.jgrid.jqID(ind.id)).datepicker('hide');
  12042. } catch (e) { }
  12043. }
  12044. $.each($t.p.colModel, function () {
  12045. if (this.editable === true && $t.p.savedRow[fr].hasOwnProperty(this.name)) {
  12046. ares[this.name] = $t.p.savedRow[fr][this.name];
  12047. }
  12048. });
  12049. $($t).jqGrid("setRowData", rowid, ares);
  12050. $(ind).attr("editable", "0").unbind("keydown");
  12051. $t.p.savedRow.splice(fr, 1);
  12052. if ($("#" + $.jgrid.jqID(rowid), "#" + $.jgrid.jqID($t.p.id)).hasClass("jqgrid-new-row")) {
  12053. setTimeout(function () {
  12054. $($t).jqGrid("delRowData", rowid);
  12055. $($t).jqGrid('showAddEditButtons');
  12056. }, 0);
  12057. }
  12058. }
  12059. $($t).triggerHandler("jqGridInlineAfterRestoreRow", [rowid]);
  12060. if ($.isFunction(o.afterrestorefunc)) {
  12061. o.afterrestorefunc.call($t, rowid);
  12062. }
  12063. });
  12064. },
  12065. addRow: function (p) {
  12066. p = $.extend(true, {
  12067. rowID: null,
  12068. initdata: {},
  12069. position: "first",
  12070. useDefValues: true,
  12071. useFormatter: false,
  12072. addRowParams: { extraparam: {} }
  12073. }, p || {});
  12074. return this.each(function () {
  12075. if (!this.grid) { return; }
  12076. var $t = this;
  12077. var bfar = $.isFunction(p.beforeAddRow) ? p.beforeAddRow.call($t, p.addRowParams) : undefined;
  12078. if (bfar === undefined) {
  12079. bfar = true;
  12080. }
  12081. if (!bfar) { return; }
  12082. p.rowID = $.isFunction(p.rowID) ? p.rowID.call($t, p) : ((p.rowID != null) ? p.rowID : $.jgrid.randId());
  12083. if (p.useDefValues === true) {
  12084. $($t.p.colModel).each(function () {
  12085. if (this.editoptions && this.editoptions.defaultValue) {
  12086. var opt = this.editoptions.defaultValue,
  12087. tmp = $.isFunction(opt) ? opt.call($t) : opt;
  12088. p.initdata[this.name] = tmp;
  12089. }
  12090. });
  12091. }
  12092. $($t).jqGrid('addRowData', p.rowID, p.initdata, p.position);
  12093. p.rowID = $t.p.idPrefix + p.rowID;
  12094. $("#" + $.jgrid.jqID(p.rowID), "#" + $.jgrid.jqID($t.p.id)).addClass("jqgrid-new-row");
  12095. if (p.useFormatter) {
  12096. $("#" + $.jgrid.jqID(p.rowID) + " .ui-inline-edit", "#" + $.jgrid.jqID($t.p.id)).click();
  12097. } else {
  12098. var opers = $t.p.prmNames,
  12099. oper = opers.oper;
  12100. p.addRowParams.extraparam[oper] = opers.addoper;
  12101. $($t).jqGrid('editRow', p.rowID, p.addRowParams);
  12102. $($t).jqGrid('setSelection', p.rowID);
  12103. }
  12104. });
  12105. },
  12106. inlineNav: function (elem, o) {
  12107. var $t = this[0],
  12108. regional = $.jgrid.getRegional($t, 'nav'),
  12109. icons = $.jgrid.styleUI[$t.p.styleUI].inlinedit;
  12110. o = $.extend(true, {
  12111. edit: true,
  12112. editicon: icons.icon_edit_nav,
  12113. add: true,
  12114. addicon: icons.icon_add_nav,
  12115. save: true,
  12116. saveicon: icons.icon_save_nav,
  12117. cancel: true,
  12118. cancelicon: icons.icon_cancel_nav,
  12119. addParams: { addRowParams: { extraparam: {} } },
  12120. editParams: {},
  12121. restoreAfterSelect: true,
  12122. saveAfterSelect: false
  12123. }, regional, o || {});
  12124. return this.each(function () {
  12125. if (!this.grid || this.p.inlineNav) { return; }
  12126. var gID = $.jgrid.jqID($t.p.id),
  12127. disabled = $.trim($($t).jqGrid('getStyleUI', $t.p.styleUI + '.common', 'disabled', true));
  12128. // check to see if navgrid is started, if not call it with all false parameters.
  12129. if (!$t.p.navGrid) {
  12130. $($t).jqGrid('navGrid', elem, { refresh: false, edit: false, add: false, del: false, search: false, view: false });
  12131. }
  12132. if (!$($t).data('inlineNav')) {
  12133. $($t).data('inlineNav', o);
  12134. }
  12135. if ($t.p.force_regional) {
  12136. o = $.extend(o, regional);
  12137. }
  12138. $t.p.inlineNav = true;
  12139. // detect the formatactions column
  12140. if (o.addParams.useFormatter === true) {
  12141. var cm = $t.p.colModel, i;
  12142. for (i = 0; i < cm.length; i++) {
  12143. if (cm[i].formatter && cm[i].formatter === "actions") {
  12144. if (cm[i].formatoptions) {
  12145. var defaults = {
  12146. keys: false,
  12147. onEdit: null,
  12148. onSuccess: null,
  12149. afterSave: null,
  12150. onError: null,
  12151. afterRestore: null,
  12152. extraparam: {},
  12153. url: null
  12154. },
  12155. ap = $.extend(defaults, cm[i].formatoptions);
  12156. o.addParams.addRowParams = {
  12157. "keys": ap.keys,
  12158. "oneditfunc": ap.onEdit,
  12159. "successfunc": ap.onSuccess,
  12160. "url": ap.url,
  12161. "extraparam": ap.extraparam,
  12162. "aftersavefunc": ap.afterSave,
  12163. "errorfunc": ap.onError,
  12164. "afterrestorefunc": ap.afterRestore
  12165. };
  12166. }
  12167. break;
  12168. }
  12169. }
  12170. }
  12171. if (o.add) {
  12172. $($t).jqGrid('navButtonAdd', elem, {
  12173. caption: o.addtext,
  12174. title: o.addtitle,
  12175. buttonicon: o.addicon,
  12176. id: $t.p.id + "_iladd",
  12177. internal: true,
  12178. onClickButton: function () {
  12179. $($t).jqGrid('addRow', o.addParams);
  12180. if (!o.addParams.useFormatter) {
  12181. $("#" + gID + "_ilsave").removeClass(disabled);
  12182. $("#" + gID + "_ilcancel").removeClass(disabled);
  12183. $("#" + gID + "_iladd").addClass(disabled);
  12184. $("#" + gID + "_iledit").addClass(disabled);
  12185. }
  12186. }
  12187. });
  12188. }
  12189. if (o.edit) {
  12190. $($t).jqGrid('navButtonAdd', elem, {
  12191. caption: o.edittext,
  12192. title: o.edittitle,
  12193. buttonicon: o.editicon,
  12194. id: $t.p.id + "_iledit",
  12195. internal: true,
  12196. onClickButton: function () {
  12197. var sr = $($t).jqGrid('getGridParam', 'selrow');
  12198. if (sr) {
  12199. $($t).jqGrid('editRow', sr, o.editParams);
  12200. $("#" + gID + "_ilsave").removeClass(disabled);
  12201. $("#" + gID + "_ilcancel").removeClass(disabled);
  12202. $("#" + gID + "_iladd").addClass(disabled);
  12203. $("#" + gID + "_iledit").addClass(disabled);
  12204. } else {
  12205. $.jgrid.viewModal("#alertmod_" + gID, { gbox: "#gbox_" + gID, jqm: true }); $("#jqg_alrt").focus();
  12206. }
  12207. }
  12208. });
  12209. }
  12210. if (o.save) {
  12211. $($t).jqGrid('navButtonAdd', elem, {
  12212. caption: o.savetext || '',
  12213. title: o.savetitle || 'Save row',
  12214. buttonicon: o.saveicon,
  12215. id: $t.p.id + "_ilsave",
  12216. internal: true,
  12217. onClickButton: function () {
  12218. var sr = $t.p.savedRow[0].id;
  12219. if (sr) {
  12220. var opers = $t.p.prmNames,
  12221. oper = opers.oper, tmpParams = o.editParams;
  12222. if ($("#" + $.jgrid.jqID(sr), "#" + gID).hasClass("jqgrid-new-row")) {
  12223. o.addParams.addRowParams.extraparam[oper] = opers.addoper;
  12224. tmpParams = o.addParams.addRowParams;
  12225. } else {
  12226. if (!o.editParams.extraparam) {
  12227. o.editParams.extraparam = {};
  12228. }
  12229. o.editParams.extraparam[oper] = opers.editoper;
  12230. }
  12231. if ($($t).jqGrid('saveRow', sr, tmpParams)) {
  12232. $($t).jqGrid('showAddEditButtons');
  12233. }
  12234. } else {
  12235. $.jgrid.viewModal("#alertmod_" + gID, { gbox: "#gbox_" + gID, jqm: true }); $("#jqg_alrt").focus();
  12236. }
  12237. }
  12238. });
  12239. $("#" + gID + "_ilsave").addClass(disabled);
  12240. }
  12241. if (o.cancel) {
  12242. $($t).jqGrid('navButtonAdd', elem, {
  12243. caption: o.canceltext || '',
  12244. title: o.canceltitle || 'Cancel row editing',
  12245. buttonicon: o.cancelicon,
  12246. id: $t.p.id + "_ilcancel",
  12247. internal: true,
  12248. onClickButton: function () {
  12249. var sr = $t.p.savedRow[0].id, cancelPrm = o.editParams;
  12250. if (sr) {
  12251. if ($("#" + $.jgrid.jqID(sr), "#" + gID).hasClass("jqgrid-new-row")) {
  12252. cancelPrm = o.addParams.addRowParams;
  12253. }
  12254. $($t).jqGrid('restoreRow', sr, cancelPrm);
  12255. $($t).jqGrid('showAddEditButtons');
  12256. } else {
  12257. $.jgrid.viewModal("#alertmod", { gbox: "#gbox_" + gID, jqm: true }); $("#jqg_alrt").focus();
  12258. }
  12259. }
  12260. });
  12261. $("#" + gID + "_ilcancel").addClass(disabled);
  12262. }
  12263. if (o.restoreAfterSelect === true || o.saveAfterSelect === true) {
  12264. $($t).bind("jqGridBeforeSelectRow.inlineNav", function (event, id) {
  12265. if ($t.p.savedRow.length > 0 && $t.p.inlineNav === true && (id !== $t.p.selrow && $t.p.selrow !== null)) {
  12266. if ($t.p.selrow === o.addParams.rowID) {
  12267. $($t).jqGrid('delRowData', $t.p.selrow);
  12268. } else {
  12269. if (o.restoreAfterSelect === true) {
  12270. $($t).jqGrid('restoreRow', $t.p.selrow, o.editParams);
  12271. } else {
  12272. $($t).jqGrid('saveRow', $t.p.selrow, o.editParams);
  12273. }
  12274. }
  12275. $($t).jqGrid('showAddEditButtons');
  12276. }
  12277. });
  12278. }
  12279. });
  12280. },
  12281. showAddEditButtons: function () {
  12282. return this.each(function () {
  12283. if (!this.grid) { return; }
  12284. var gID = $.jgrid.jqID(this.p.id),
  12285. disabled = $.trim($(this).jqGrid('getStyleUI', this.p.styleUI + '.common', 'disabled', true));
  12286. $("#" + gID + "_ilsave").addClass(disabled);
  12287. $("#" + gID + "_ilcancel").addClass(disabled);
  12288. $("#" + gID + "_iladd").removeClass(disabled);
  12289. $("#" + gID + "_iledit").removeClass(disabled);
  12290. });
  12291. }
  12292. //end inline edit
  12293. });
  12294. //module begin
  12295. if ($.jgrid.msie && $.jgrid.msiever() === 8) {
  12296. $.expr[":"].hidden = function (elem) {
  12297. return elem.offsetWidth === 0 || elem.offsetHeight === 0 ||
  12298. elem.style.display === "none";
  12299. };
  12300. }
  12301. // requiere load multiselect before grid
  12302. $.jgrid._multiselect = false;
  12303. if ($.ui) {
  12304. if ($.ui.multiselect) {
  12305. if ($.ui.multiselect.prototype._setSelected) {
  12306. var setSelected = $.ui.multiselect.prototype._setSelected;
  12307. $.ui.multiselect.prototype._setSelected = function (item, selected) {
  12308. var ret = setSelected.call(this, item, selected);
  12309. if (selected && this.selectedList) {
  12310. var elt = this.element;
  12311. this.selectedList.find('li').each(function () {
  12312. if ($(this).data('optionLink')) {
  12313. $(this).data('optionLink').remove().appendTo(elt);
  12314. }
  12315. });
  12316. }
  12317. return ret;
  12318. };
  12319. }
  12320. if ($.ui.multiselect.prototype.destroy) {
  12321. $.ui.multiselect.prototype.destroy = function () {
  12322. this.element.show();
  12323. this.container.remove();
  12324. if ($.Widget === undefined) {
  12325. $.widget.prototype.destroy.apply(this, arguments);
  12326. } else {
  12327. $.Widget.prototype.destroy.apply(this, arguments);
  12328. }
  12329. };
  12330. }
  12331. $.jgrid._multiselect = true;
  12332. }
  12333. }
  12334. $.jgrid.extend({
  12335. sortableColumns: function (tblrow) {
  12336. return this.each(function () {
  12337. var ts = this, tid = $.jgrid.jqID(ts.p.id);
  12338. function start() { ts.p.disableClick = true; }
  12339. var sortable_opts = {
  12340. "tolerance": "pointer",
  12341. "axis": "x",
  12342. "scrollSensitivity": "1",
  12343. "items": '>th:not(:has(#jqgh_' + tid + '_cb' + ',#jqgh_' + tid + '_rn' + ',#jqgh_' + tid + '_subgrid),:hidden)',
  12344. "placeholder": {
  12345. element: function (item) {
  12346. var el = $(document.createElement(item[0].nodeName))
  12347. .addClass(item[0].className + " ui-sortable-placeholder ui-state-highlight")
  12348. .removeClass("ui-sortable-helper")[0];
  12349. return el;
  12350. },
  12351. update: function (self, p) {
  12352. p.height(self.currentItem.innerHeight() - parseInt(self.currentItem.css('paddingTop') || 0, 10) - parseInt(self.currentItem.css('paddingBottom') || 0, 10));
  12353. p.width(self.currentItem.innerWidth() - parseInt(self.currentItem.css('paddingLeft') || 0, 10) - parseInt(self.currentItem.css('paddingRight') || 0, 10));
  12354. }
  12355. },
  12356. "update": function (event, ui) {
  12357. var p = $(ui.item).parent(),
  12358. th = $(">th", p),
  12359. colModel = ts.p.colModel,
  12360. cmMap = {}, tid = ts.p.id + "_";
  12361. $.each(colModel, function (i) { cmMap[this.name] = i; });
  12362. var permutation = [];
  12363. th.each(function () {
  12364. var id = $(">div", this).get(0).id.replace(/^jqgh_/, "").replace(tid, "");
  12365. if (cmMap.hasOwnProperty(id)) {
  12366. permutation.push(cmMap[id]);
  12367. }
  12368. });
  12369. $(ts).jqGrid("remapColumns", permutation, true, true);
  12370. if ($.isFunction(ts.p.sortable.update)) {
  12371. ts.p.sortable.update(permutation);
  12372. }
  12373. setTimeout(function () { ts.p.disableClick = false; }, 50);
  12374. }
  12375. };
  12376. if (ts.p.sortable.options) {
  12377. $.extend(sortable_opts, ts.p.sortable.options);
  12378. } else if ($.isFunction(ts.p.sortable)) {
  12379. ts.p.sortable = { "update": ts.p.sortable };
  12380. }
  12381. if (sortable_opts.start) {
  12382. var s = sortable_opts.start;
  12383. sortable_opts.start = function (e, ui) {
  12384. start();
  12385. s.call(this, e, ui);
  12386. };
  12387. } else {
  12388. sortable_opts.start = start;
  12389. }
  12390. if (ts.p.sortable.exclude) {
  12391. sortable_opts.items += ":not(" + ts.p.sortable.exclude + ")";
  12392. }
  12393. var $e = tblrow.sortable(sortable_opts), dataObj = $e.data("sortable") || $e.data("uiSortable");
  12394. if (dataObj != null) {
  12395. dataObj.data("sortable").floating = true;
  12396. }
  12397. });
  12398. },
  12399. columnChooser: function (opts) {
  12400. var self = this, selector, select, colMap = {}, fixedCols = [], dopts, mopts, $dialogContent, multiselectData, listHeight,
  12401. colModel = self.jqGrid("getGridParam", "colModel"),
  12402. colNames = self.jqGrid("getGridParam", "colNames"),
  12403. getMultiselectWidgetData = function ($elem) {
  12404. return ($.ui.multiselect.prototype && $elem.data($.ui.multiselect.prototype.widgetFullName || $.ui.multiselect.prototype.widgetName)) ||
  12405. $elem.data("ui-multiselect") || $elem.data("multiselect");
  12406. },
  12407. regional = $.jgrid.getRegional(this[0], 'col');
  12408. if ($("#colchooser_" + $.jgrid.jqID(self[0].p.id)).length) { return; }
  12409. selector = $('<div id="colchooser_' + self[0].p.id + '" style="position:relative;overflow:hidden"><div><select multiple="multiple"></select></div></div>');
  12410. select = $('select', selector);
  12411. function insert(perm, i, v) {
  12412. var a, b;
  12413. if (i >= 0) {
  12414. a = perm.slice();
  12415. b = a.splice(i, Math.max(perm.length - i, i));
  12416. if (i > perm.length) { i = perm.length; }
  12417. a[i] = v;
  12418. return a.concat(b);
  12419. }
  12420. return perm;
  12421. }
  12422. function call(fn, obj) {
  12423. if (!fn) { return; }
  12424. if (typeof fn === 'string') {
  12425. if ($.fn[fn]) {
  12426. $.fn[fn].apply(obj, $.makeArray(arguments).slice(2));
  12427. }
  12428. } else if ($.isFunction(fn)) {
  12429. fn.apply(obj, $.makeArray(arguments).slice(2));
  12430. }
  12431. }
  12432. opts = $.extend({
  12433. width: 400,
  12434. height: 240,
  12435. classname: null,
  12436. done: function (perm) { if (perm) { self.jqGrid("remapColumns", perm, true); } },
  12437. /* msel is either the name of a ui widget class that
  12438. extends a multiselect, or a function that supports
  12439. creating a multiselect object (with no argument,
  12440. or when passed an object), and destroying it (when
  12441. passed the string "destroy"). */
  12442. msel: "multiselect",
  12443. /* "msel_opts" : {}, */
  12444. /* dlog is either the name of a ui widget class that
  12445. behaves in a dialog-like way, or a function, that
  12446. supports creating a dialog (when passed dlog_opts)
  12447. or destroying a dialog (when passed the string
  12448. "destroy")
  12449. */
  12450. dlog: "dialog",
  12451. dialog_opts: {
  12452. minWidth: 470,
  12453. dialogClass: "ui-jqdialog"
  12454. },
  12455. /* dlog_opts is either an option object to be passed
  12456. to "dlog", or (more likely) a function that creates
  12457. the options object.
  12458. The default produces a suitable options object for
  12459. ui.dialog */
  12460. dlog_opts: function (options) {
  12461. var buttons = {};
  12462. buttons[options.bSubmit] = function () {
  12463. options.apply_perm();
  12464. options.cleanup(false);
  12465. };
  12466. buttons[options.bCancel] = function () {
  12467. options.cleanup(true);
  12468. };
  12469. return $.extend(true, {
  12470. buttons: buttons,
  12471. close: function () {
  12472. options.cleanup(true);
  12473. },
  12474. modal: options.modal || false,
  12475. resizable: options.resizable || true,
  12476. width: options.width + 70,
  12477. resize: function () {
  12478. var widgetData = getMultiselectWidgetData(select),
  12479. $thisDialogContent = widgetData.container.closest(".ui-dialog-content");
  12480. if ($thisDialogContent.length > 0 && typeof $thisDialogContent[0].style === "object") {
  12481. $thisDialogContent[0].style.width = "";
  12482. } else {
  12483. $thisDialogContent.css("width", ""); // or just remove width style
  12484. }
  12485. widgetData.selectedList.height(Math.max(widgetData.selectedContainer.height() - widgetData.selectedActions.outerHeight() - 1, 1));
  12486. widgetData.availableList.height(Math.max(widgetData.availableContainer.height() - widgetData.availableActions.outerHeight() - 1, 1));
  12487. }
  12488. }, options.dialog_opts || {});
  12489. },
  12490. /* Function to get the permutation array, and pass it to the
  12491. "done" function */
  12492. apply_perm: function () {
  12493. var perm = [];
  12494. $('option', select).each(function () {
  12495. if ($(this).is(":selected")) {
  12496. self.jqGrid("showCol", colModel[this.value].name);
  12497. } else {
  12498. self.jqGrid("hideCol", colModel[this.value].name);
  12499. }
  12500. });
  12501. //fixedCols.slice(0);
  12502. $('option[selected]', select).each(function () { perm.push(parseInt(this.value, 10)); });
  12503. $.each(perm, function () { delete colMap[colModel[parseInt(this, 10)].name]; });
  12504. $.each(colMap, function () {
  12505. var ti = parseInt(this, 10);
  12506. perm = insert(perm, ti, ti);
  12507. });
  12508. if (opts.done) {
  12509. opts.done.call(self, perm);
  12510. }
  12511. self.jqGrid("setGridWidth", self[0].p.width, self[0].p.shrinkToFit);
  12512. },
  12513. /* Function to cleanup the dialog, and select. Also calls the
  12514. done function with no permutation (to indicate that the
  12515. columnChooser was aborted */
  12516. cleanup: function (calldone) {
  12517. call(opts.dlog, selector, 'destroy');
  12518. call(opts.msel, select, 'destroy');
  12519. selector.remove();
  12520. if (calldone && opts.done) {
  12521. opts.done.call(self);
  12522. }
  12523. },
  12524. msel_opts: {}
  12525. }, regional, opts || {});
  12526. if ($.ui) {
  12527. if ($.ui.multiselect && $.ui.multiselect.defaults) {
  12528. if (!$.jgrid._multiselect) {
  12529. // should be in language file
  12530. alert("Multiselect plugin loaded after jqGrid. Please load the plugin before the jqGrid!");
  12531. return;
  12532. }
  12533. // ??? the next line uses $.ui.multiselect.defaults which will be typically undefined
  12534. opts.msel_opts = $.extend($.ui.multiselect.defaults, opts.msel_opts);
  12535. }
  12536. }
  12537. if (opts.caption) {
  12538. selector.attr("title", opts.caption);
  12539. }
  12540. if (opts.classname) {
  12541. selector.addClass(opts.classname);
  12542. select.addClass(opts.classname);
  12543. }
  12544. if (opts.width) {
  12545. $(">div", selector).css({ width: opts.width, margin: "0 auto" });
  12546. select.css("width", opts.width);
  12547. }
  12548. if (opts.height) {
  12549. $(">div", selector).css("height", opts.height);
  12550. select.css("height", opts.height - 10);
  12551. }
  12552. select.empty();
  12553. $.each(colModel, function (i) {
  12554. colMap[this.name] = i;
  12555. if (this.hidedlg) {
  12556. if (!this.hidden) {
  12557. fixedCols.push(i);
  12558. }
  12559. return;
  12560. }
  12561. select.append("<option value='" + i + "' " +
  12562. (this.hidden ? "" : "selected='selected'") + ">" + $.jgrid.stripHtml(colNames[i]) + "</option>");
  12563. });
  12564. dopts = $.isFunction(opts.dlog_opts) ? opts.dlog_opts.call(self, opts) : opts.dlog_opts;
  12565. call(opts.dlog, selector, dopts);
  12566. mopts = $.isFunction(opts.msel_opts) ? opts.msel_opts.call(self, opts) : opts.msel_opts;
  12567. call(opts.msel, select, mopts);
  12568. // fix height of elements of the multiselect widget
  12569. $dialogContent = $("#colchooser_" + $.jgrid.jqID(self[0].p.id));
  12570. $dialogContent.css({ margin: "auto" });
  12571. $dialogContent.find(">div").css({ width: "100%", height: "100%", margin: "auto" });
  12572. multiselectData = getMultiselectWidgetData(select);
  12573. multiselectData.container.css({ width: "100%", height: "100%", margin: "auto" });
  12574. multiselectData.selectedContainer.css({ width: multiselectData.options.dividerLocation * 100 + "%", height: "100%", margin: "auto", boxSizing: "border-box" });
  12575. multiselectData.availableContainer.css({ width: (100 - multiselectData.options.dividerLocation * 100) + "%", height: "100%", margin: "auto", boxSizing: "border-box" });
  12576. // set height for both selectedList and availableList
  12577. multiselectData.selectedList.css("height", "auto");
  12578. multiselectData.availableList.css("height", "auto");
  12579. listHeight = Math.max(multiselectData.selectedList.height(), multiselectData.availableList.height());
  12580. listHeight = Math.min(listHeight, $(window).height());
  12581. multiselectData.selectedList.css("height", listHeight);
  12582. multiselectData.availableList.css("height", listHeight);
  12583. },
  12584. sortableRows: function (opts) {
  12585. // Can accept all sortable options and events
  12586. return this.each(function () {
  12587. var $t = this;
  12588. if (!$t.grid) { return; }
  12589. // Currently we disable a treeGrid sortable
  12590. if ($t.p.treeGrid) { return; }
  12591. if ($.fn.sortable) {
  12592. opts = $.extend({
  12593. "cursor": "move",
  12594. "axis": "y",
  12595. "items": " > .jqgrow"
  12596. },
  12597. opts || {});
  12598. if (opts.start && $.isFunction(opts.start)) {
  12599. opts._start_ = opts.start;
  12600. delete opts.start;
  12601. } else { opts._start_ = false; }
  12602. if (opts.update && $.isFunction(opts.update)) {
  12603. opts._update_ = opts.update;
  12604. delete opts.update;
  12605. } else { opts._update_ = false; }
  12606. opts.start = function (ev, ui) {
  12607. $(ui.item).css("border-width", "0");
  12608. $("td", ui.item).each(function (i) {
  12609. this.style.width = $t.grid.cols[i].style.width;
  12610. });
  12611. if ($t.p.subGrid) {
  12612. var subgid = $(ui.item).attr("id");
  12613. try {
  12614. $($t).jqGrid('collapseSubGridRow', subgid);
  12615. } catch (e) { }
  12616. }
  12617. if (opts._start_) {
  12618. opts._start_.apply(this, [ev, ui]);
  12619. }
  12620. };
  12621. opts.update = function (ev, ui) {
  12622. $(ui.item).css("border-width", "");
  12623. if ($t.p.rownumbers === true) {
  12624. $("td.jqgrid-rownum", $t.rows).each(function (i) {
  12625. $(this).html(i + 1 + (parseInt($t.p.page, 10) - 1) * parseInt($t.p.rowNum, 10));
  12626. });
  12627. }
  12628. if (opts._update_) {
  12629. opts._update_.apply(this, [ev, ui]);
  12630. }
  12631. };
  12632. $("tbody:first", $t).sortable(opts);
  12633. $("tbody:first > .jqgrow", $t).disableSelection();
  12634. }
  12635. });
  12636. },
  12637. gridDnD: function (opts) {
  12638. return this.each(function () {
  12639. var $t = this, i, cn;
  12640. if (!$t.grid) { return; }
  12641. // Currently we disable a treeGrid drag and drop
  12642. if ($t.p.treeGrid) { return; }
  12643. if (!$.fn.draggable || !$.fn.droppable) { return; }
  12644. function updateDnD() {
  12645. var datadnd = $.data($t, "dnd");
  12646. $("tr.jqgrow:not(.ui-draggable)", $t).draggable($.isFunction(datadnd.drag) ? datadnd.drag.call($($t), datadnd) : datadnd.drag);
  12647. }
  12648. var appender = "<table id='jqgrid_dnd' class='ui-jqgrid-dnd'></table>";
  12649. if ($("#jqgrid_dnd")[0] === undefined) {
  12650. $('body').append(appender);
  12651. }
  12652. if (typeof opts === 'string' && opts === 'updateDnD' && $t.p.jqgdnd === true) {
  12653. updateDnD();
  12654. return;
  12655. }
  12656. opts = $.extend({
  12657. "drag": function (opts) {
  12658. return $.extend({
  12659. start: function (ev, ui) {
  12660. var i, subgid;
  12661. // if we are in subgrid mode try to collapse the node
  12662. if ($t.p.subGrid) {
  12663. subgid = $(ui.helper).attr("id");
  12664. try {
  12665. $($t).jqGrid('collapseSubGridRow', subgid);
  12666. } catch (e) { }
  12667. }
  12668. // hack
  12669. // drag and drop does not insert tr in table, when the table has no rows
  12670. // we try to insert new empty row on the target(s)
  12671. for (i = 0; i < $.data($t, "dnd").connectWith.length; i++) {
  12672. if ($($.data($t, "dnd").connectWith[i]).jqGrid('getGridParam', 'reccount') === 0) {
  12673. $($.data($t, "dnd").connectWith[i]).jqGrid('addRowData', 'jqg_empty_row', {});
  12674. }
  12675. }
  12676. ui.helper.addClass("ui-state-highlight");
  12677. $("td", ui.helper).each(function (i) {
  12678. this.style.width = $t.grid.headers[i].width + "px";
  12679. });
  12680. if (opts.onstart && $.isFunction(opts.onstart)) { opts.onstart.call($($t), ev, ui); }
  12681. },
  12682. stop: function (ev, ui) {
  12683. var i, ids;
  12684. if (ui.helper.dropped && !opts.dragcopy) {
  12685. ids = $(ui.helper).attr("id");
  12686. if (ids === undefined) { ids = $(this).attr("id"); }
  12687. $($t).jqGrid('delRowData', ids);
  12688. }
  12689. // if we have a empty row inserted from start event try to delete it
  12690. for (i = 0; i < $.data($t, "dnd").connectWith.length; i++) {
  12691. $($.data($t, "dnd").connectWith[i]).jqGrid('delRowData', 'jqg_empty_row');
  12692. }
  12693. if (opts.onstop && $.isFunction(opts.onstop)) { opts.onstop.call($($t), ev, ui); }
  12694. }
  12695. }, opts.drag_opts || {});
  12696. },
  12697. "drop": function (opts) {
  12698. return $.extend({
  12699. accept: function (d) {
  12700. if (!$(d).hasClass('jqgrow')) { return d; }
  12701. var tid = $(d).closest("table.ui-jqgrid-btable");
  12702. if (tid.length > 0 && $.data(tid[0], "dnd") !== undefined) {
  12703. var cn = $.data(tid[0], "dnd").connectWith;
  12704. return $.inArray('#' + $.jgrid.jqID(this.id), cn) !== -1 ? true : false;
  12705. }
  12706. return false;
  12707. },
  12708. drop: function (ev, ui) {
  12709. if (!$(ui.draggable).hasClass('jqgrow')) { return; }
  12710. var accept = $(ui.draggable).attr("id");
  12711. var getdata = ui.draggable.parent().parent().jqGrid('getRowData', accept);
  12712. if (!opts.dropbyname) {
  12713. var j = 0, tmpdata = {}, nm, key;
  12714. var dropmodel = $("#" + $.jgrid.jqID(this.id)).jqGrid('getGridParam', 'colModel');
  12715. try {
  12716. for (key in getdata) {
  12717. if (getdata.hasOwnProperty(key)) {
  12718. nm = dropmodel[j].name;
  12719. if (!(nm === 'cb' || nm === 'rn' || nm === 'subgrid')) {
  12720. if (getdata.hasOwnProperty(key) && dropmodel[j]) {
  12721. tmpdata[nm] = getdata[key];
  12722. }
  12723. }
  12724. j++;
  12725. }
  12726. }
  12727. getdata = tmpdata;
  12728. } catch (e) { }
  12729. }
  12730. ui.helper.dropped = true;
  12731. if (opts.beforedrop && $.isFunction(opts.beforedrop)) {
  12732. //parameters to this callback - event, element, data to be inserted, sender, reciever
  12733. // should return object which will be inserted into the reciever
  12734. var datatoinsert = opts.beforedrop.call(this, ev, ui, getdata, $('#' + $.jgrid.jqID($t.p.id)), $(this));
  12735. if (datatoinsert !== undefined && datatoinsert !== null && typeof datatoinsert === "object") { getdata = datatoinsert; }
  12736. }
  12737. if (ui.helper.dropped) {
  12738. var grid;
  12739. if (opts.autoid) {
  12740. if ($.isFunction(opts.autoid)) {
  12741. grid = opts.autoid.call(this, getdata);
  12742. } else {
  12743. grid = Math.ceil(Math.random() * 1000);
  12744. grid = opts.autoidprefix + grid;
  12745. }
  12746. }
  12747. // NULL is interpreted as undefined while null as object
  12748. $("#" + $.jgrid.jqID(this.id)).jqGrid('addRowData', grid, getdata, opts.droppos);
  12749. }
  12750. if (opts.ondrop && $.isFunction(opts.ondrop)) { opts.ondrop.call(this, ev, ui, getdata); }
  12751. }
  12752. }, opts.drop_opts || {});
  12753. },
  12754. "onstart": null,
  12755. "onstop": null,
  12756. "beforedrop": null,
  12757. "ondrop": null,
  12758. "drop_opts": {
  12759. "activeClass": "ui-state-active",
  12760. "hoverClass": "ui-state-hover"
  12761. },
  12762. "drag_opts": {
  12763. "revert": "invalid",
  12764. "helper": "clone",
  12765. "cursor": "move",
  12766. "appendTo": "#jqgrid_dnd",
  12767. "zIndex": 5000
  12768. },
  12769. "dragcopy": false,
  12770. "dropbyname": false,
  12771. "droppos": "first",
  12772. "autoid": true,
  12773. "autoidprefix": "dnd_"
  12774. }, opts || {});
  12775. if (!opts.connectWith) { return; }
  12776. opts.connectWith = opts.connectWith.split(",");
  12777. opts.connectWith = $.map(opts.connectWith, function (n) { return $.trim(n); });
  12778. $.data($t, "dnd", opts);
  12779. if ($t.p.reccount !== 0 && !$t.p.jqgdnd) {
  12780. updateDnD();
  12781. }
  12782. $t.p.jqgdnd = true;
  12783. for (i = 0; i < opts.connectWith.length; i++) {
  12784. cn = opts.connectWith[i];
  12785. $(cn).droppable($.isFunction(opts.drop) ? opts.drop.call($($t), opts) : opts.drop);
  12786. }
  12787. });
  12788. },
  12789. gridResize: function (opts) {
  12790. return this.each(function () {
  12791. var $t = this, gID = $.jgrid.jqID($t.p.id), req;
  12792. if (!$t.grid || !$.fn.resizable) { return; }
  12793. opts = $.extend({}, opts || {});
  12794. if (opts.alsoResize) {
  12795. opts._alsoResize_ = opts.alsoResize;
  12796. delete opts.alsoResize;
  12797. } else {
  12798. opts._alsoResize_ = false;
  12799. }
  12800. if (opts.stop && $.isFunction(opts.stop)) {
  12801. opts._stop_ = opts.stop;
  12802. delete opts.stop;
  12803. } else {
  12804. opts._stop_ = false;
  12805. }
  12806. opts.stop = function (ev, ui) {
  12807. $($t).jqGrid('setGridParam', { height: $("#gview_" + gID + " .ui-jqgrid-bdiv").height() });
  12808. $($t).jqGrid('setGridWidth', ui.size.width, opts.shrinkToFit);
  12809. if (opts._stop_) { opts._stop_.call($t, ev, ui); }
  12810. if ($t.p.caption) {
  12811. $("#gbox_" + gID).css({ 'height': 'auto' });
  12812. }
  12813. if ($t.p.frozenColumns) {
  12814. if (req) clearTimeout(req);
  12815. req = setTimeout(function () {
  12816. if (req) clearTimeout(req);
  12817. $("#" + gID).jqGrid("destroyFrozenColumns");
  12818. $("#" + gID).jqGrid("setFrozenColumns");
  12819. });
  12820. }
  12821. };
  12822. if (opts._alsoResize_) {
  12823. var optstest = "{\'#gview_" + gID + " .ui-jqgrid-bdiv\':true,'" + opts._alsoResize_ + "':true}";
  12824. opts.alsoResize = eval('(' + optstest + ')'); // the only way that I found to do this
  12825. } else {
  12826. opts.alsoResize = $(".ui-jqgrid-bdiv", "#gview_" + gID);
  12827. }
  12828. delete opts._alsoResize_;
  12829. $("#gbox_" + gID).resizable(opts);
  12830. });
  12831. }
  12832. });
  12833. //module begin
  12834. function _pivotfilter(fn, context) {
  12835. /*jshint validthis: true */
  12836. var i,
  12837. value,
  12838. result = [],
  12839. length;
  12840. if (!this || typeof fn !== 'function' || (fn instanceof RegExp)) {
  12841. throw new TypeError();
  12842. }
  12843. length = this.length;
  12844. for (i = 0; i < length; i++) {
  12845. if (this.hasOwnProperty(i)) {
  12846. value = this[i];
  12847. if (fn.call(context, value, i, this)) {
  12848. result.push(value);
  12849. // We need break in order to cancel loop
  12850. // in case the row is found
  12851. break;
  12852. }
  12853. }
  12854. }
  12855. return result;
  12856. }
  12857. $.assocArraySize = function (obj) {
  12858. // http://stackoverflow.com/a/6700/11236
  12859. var size = 0, key;
  12860. for (key in obj) {
  12861. if (obj.hasOwnProperty(key)) {
  12862. size++;
  12863. }
  12864. }
  12865. return size;
  12866. };
  12867. $.jgrid.extend({
  12868. pivotSetup: function (data, options) {
  12869. // data should come in json format
  12870. // The function return the new colModel and the transformed data
  12871. // again with group setup options which then will be passed to the grid
  12872. var columns = [],
  12873. pivotrows = [],
  12874. summaries = [],
  12875. member = [],
  12876. labels = [],
  12877. groupOptions = {
  12878. grouping: true,
  12879. groupingView: {
  12880. groupField: [],
  12881. groupSummary: [],
  12882. groupSummaryPos: []
  12883. }
  12884. },
  12885. headers = [],
  12886. o = $.extend({
  12887. rowTotals: false,
  12888. rowTotalsText: 'Total',
  12889. // summary columns
  12890. colTotals: false,
  12891. groupSummary: true,
  12892. groupSummaryPos: 'header',
  12893. frozenStaticCols: false
  12894. }, options || {});
  12895. this.each(function () {
  12896. var
  12897. row,
  12898. rowindex,
  12899. i,
  12900. rowlen = data.length,
  12901. xlen, ylen, aggrlen,
  12902. tmp,
  12903. newObj,
  12904. r = 0;
  12905. // utility funcs
  12906. /*
  12907. * Filter the data to a given criteria. Return the firt occurance
  12908. */
  12909. function find(ar, fun, extra) {
  12910. var res;
  12911. res = _pivotfilter.call(ar, fun, extra);
  12912. return res.length > 0 ? res[0] : null;
  12913. }
  12914. /*
  12915. * Check if the grouped row column exist (See find)
  12916. * If the row is not find in pivot rows retun null,
  12917. * otherviese the column
  12918. */
  12919. function findGroup(item, index) {
  12920. /*jshint validthis: true */
  12921. var j = 0, ret = true, i;
  12922. for (i in item) {
  12923. if (item.hasOwnProperty(i)) {
  12924. if (item[i] != this[j]) {
  12925. ret = false;
  12926. break;
  12927. }
  12928. j++;
  12929. if (j >= this.length) {
  12930. break;
  12931. }
  12932. }
  12933. }
  12934. if (ret) {
  12935. rowindex = index;
  12936. }
  12937. return ret;
  12938. }
  12939. /*
  12940. * Perform calculations of the pivot values.
  12941. */
  12942. function calculation(oper, v, field, rc, _cnt) {
  12943. var ret;
  12944. switch (oper) {
  12945. case "sum":
  12946. ret = parseFloat(v || 0) + parseFloat((rc[field] || 0));
  12947. break;
  12948. case "count":
  12949. if (v === "" || v == null) {
  12950. v = 0;
  12951. }
  12952. if (rc.hasOwnProperty(field)) {
  12953. ret = v + 1;
  12954. } else {
  12955. ret = 0;
  12956. }
  12957. break;
  12958. case "min":
  12959. if (v === "" || v == null) {
  12960. ret = parseFloat(rc[field] || 0);
  12961. } else {
  12962. ret = Math.min(parseFloat(v), parseFloat(rc[field] || 0));
  12963. }
  12964. break;
  12965. case "max":
  12966. if (v === "" || v == null) {
  12967. ret = parseFloat(rc[field] || 0);
  12968. } else {
  12969. ret = Math.max(parseFloat(v), parseFloat(rc[field] || 0));
  12970. }
  12971. break;
  12972. case "avg": //avg grouping
  12973. ret = (parseFloat(v || 0) * (_cnt - 1) + parseFloat(rc[field] || 0)) / _cnt;
  12974. break;
  12975. }
  12976. return ret;
  12977. }
  12978. /*
  12979. * The function agragates the values of the pivot grid.
  12980. * Return the current row with pivot summary values
  12981. */
  12982. function agregateFunc(row, aggr, value, curr) {
  12983. // default is sum
  12984. var arrln = aggr.length, i, label, j, jv, mainval = "", swapvals = [];
  12985. if ($.isArray(value)) {
  12986. jv = value.length;
  12987. swapvals = value;
  12988. } else {
  12989. jv = 1;
  12990. swapvals[0] = value;
  12991. }
  12992. member = [];
  12993. labels = [];
  12994. member.root = 0;
  12995. if (! !!curr._count) {
  12996. curr._count = 1;
  12997. } else {
  12998. curr._count++;
  12999. }
  13000. for (j = 0; j < jv; j++) {
  13001. var tmpmember = [], vl;
  13002. for (i = 0; i < arrln; i++) {
  13003. if (value == null) {
  13004. label = $.trim(aggr[i].member) + "_" + aggr[i].aggregator;
  13005. vl = label;
  13006. swapvals[0] = aggr[i].label || (aggr[i].aggregator + " " + $.trim(aggr[i].member));
  13007. } else {
  13008. vl = value[j].replace(/\s+/g, '');
  13009. try {
  13010. label = (arrln === 1 ? mainval + vl : mainval + vl + "_" + aggr[i].aggregator + "_" + String(i));
  13011. } catch (e) { }
  13012. swapvals[j] = value[j];
  13013. }
  13014. //if(j<=1 && vl !== '_r_Totals' && mainval === "") { // this does not fix full the problem
  13015. //mainval = vl;
  13016. //}
  13017. label = !isNaN(parseInt(label, 10)) ? label + " " : label;
  13018. curr[label] = tmpmember[label] = calculation(aggr[i].aggregator, curr[label], aggr[i].member, row, curr._count);
  13019. }
  13020. mainval += value[j].replace(/\s+/g, '');
  13021. //vl = !isNaN(parseInt(vl,10)) ? vl + " " : vl;
  13022. member[label] = tmpmember;
  13023. labels[label] = swapvals[j];
  13024. }
  13025. return curr;
  13026. }
  13027. // Making the row totals without to add in yDimension
  13028. if (o.rowTotals && o.yDimension.length > 0) {
  13029. var dn = o.yDimension[0].dataName;
  13030. o.yDimension.splice(0, 0, { dataName: dn });
  13031. o.yDimension[0].converter = function () { return '_r_Totals'; };
  13032. }
  13033. // build initial columns (colModel) from xDimension
  13034. xlen = $.isArray(o.xDimension) ? o.xDimension.length : 0;
  13035. ylen = o.yDimension.length;
  13036. aggrlen = $.isArray(o.aggregates) ? o.aggregates.length : 0;
  13037. if (xlen === 0 || aggrlen === 0) {
  13038. throw ("xDimension or aggregates optiona are not set!");
  13039. }
  13040. var colc;
  13041. for (i = 0; i < xlen; i++) {
  13042. colc = { name: o.xDimension[i].dataName, frozen: o.frozenStaticCols };
  13043. if (o.xDimension[i].isGroupField == null) {
  13044. o.xDimension[i].isGroupField = true;
  13045. }
  13046. colc = $.extend(true, colc, o.xDimension[i]);
  13047. columns.push(colc);
  13048. }
  13049. var groupfields = xlen - 1, tree = {};
  13050. //tree = { text: 'root', leaf: false, children: [] };
  13051. //loop over alll the source data
  13052. while (r < rowlen) {
  13053. row = data[r];
  13054. var xValue = [];
  13055. var yValue = [];
  13056. tmp = {};
  13057. i = 0;
  13058. // build the data from xDimension
  13059. do {
  13060. xValue[i] = $.trim(row[o.xDimension[i].dataName]);
  13061. tmp[o.xDimension[i].dataName] = xValue[i];
  13062. i++;
  13063. } while (i < xlen);
  13064. var k = 0;
  13065. rowindex = -1;
  13066. // check to see if the row is in our new pivotrow set
  13067. newObj = find(pivotrows, findGroup, xValue);
  13068. if (!newObj) {
  13069. // if the row is not in our set
  13070. k = 0;
  13071. // if yDimension is set
  13072. if (ylen >= 1) {
  13073. // build the cols set in yDimension
  13074. for (k = 0; k < ylen; k++) {
  13075. yValue[k] = $.trim(row[o.yDimension[k].dataName]);
  13076. // Check to see if we have user defined conditions
  13077. if (o.yDimension[k].converter && $.isFunction(o.yDimension[k].converter)) {
  13078. yValue[k] = o.yDimension[k].converter.call(this, yValue[k], xValue, yValue);
  13079. }
  13080. }
  13081. // make the colums based on aggregates definition
  13082. // and return the members for late calculation
  13083. tmp = agregateFunc(row, o.aggregates, yValue, tmp);
  13084. } else if (ylen === 0) {
  13085. // if not set use direct the aggregates
  13086. tmp = agregateFunc(row, o.aggregates, null, tmp);
  13087. }
  13088. // add the result in pivot rows
  13089. pivotrows.push(tmp);
  13090. } else {
  13091. // the pivot exists
  13092. if (rowindex >= 0) {
  13093. k = 0;
  13094. // make the recalculations
  13095. if (ylen >= 1) {
  13096. for (k = 0; k < ylen; k++) {
  13097. yValue[k] = $.trim(row[o.yDimension[k].dataName]);
  13098. if (o.yDimension[k].converter && $.isFunction(o.yDimension[k].converter)) {
  13099. yValue[k] = o.yDimension[k].converter.call(this, yValue[k], xValue, yValue);
  13100. }
  13101. }
  13102. newObj = agregateFunc(row, o.aggregates, yValue, newObj);
  13103. } else if (ylen === 0) {
  13104. newObj = agregateFunc(row, o.aggregates, null, newObj);
  13105. }
  13106. // update the row
  13107. pivotrows[rowindex] = newObj;
  13108. }
  13109. }
  13110. var kj = 0, current = null, existing = null, kk;
  13111. // Build a JSON tree from the member (see aggregateFunc)
  13112. // to make later the columns
  13113. //
  13114. for (kk in member) {
  13115. if (member.hasOwnProperty(kk)) {
  13116. if (kj === 0) {
  13117. if (!tree.children || tree.children === undefined) {
  13118. tree = { text: kk, level: 0, children: [], label: kk };
  13119. }
  13120. current = tree.children;
  13121. } else {
  13122. existing = null;
  13123. for (i = 0; i < current.length; i++) {
  13124. if (current[i].text === kk) {
  13125. //current[i].fields=member[kk];
  13126. existing = current[i];
  13127. break;
  13128. }
  13129. }
  13130. if (existing) {
  13131. current = existing.children;
  13132. } else {
  13133. current.push({ children: [], text: kk, level: kj, fields: member[kk], label: labels[kk] });
  13134. current = current[current.length - 1].children;
  13135. }
  13136. }
  13137. kj++;
  13138. }
  13139. }
  13140. r++;
  13141. }
  13142. var lastval = [], initColLen = columns.length, swaplen = initColLen;
  13143. if (ylen > 0) {
  13144. headers[ylen - 1] = { useColSpanStyle: false, groupHeaders: [] };
  13145. }
  13146. /*
  13147. * Recursive function which uses the tree to build the
  13148. * columns from the pivot values and set the group Headers
  13149. */
  13150. function list(items) {
  13151. var l, j, key, k, col;
  13152. for (key in items) { // iterate
  13153. if (items.hasOwnProperty(key)) {
  13154. // write amount of spaces according to level
  13155. // and write name and newline
  13156. if (typeof items[key] !== "object") {
  13157. // If not a object build the header of the appropriate level
  13158. if (key === 'level') {
  13159. if (lastval[items.level] === undefined) {
  13160. lastval[items.level] = '';
  13161. if (items.level > 0 && items.text.indexOf('_r_Totals') === -1) {
  13162. headers[items.level - 1] = {
  13163. useColSpanStyle: false,
  13164. groupHeaders: []
  13165. };
  13166. }
  13167. }
  13168. if (lastval[items.level] !== items.text && items.children.length && items.text.indexOf('_r_Totals') === -1) {
  13169. if (items.level > 0) {
  13170. headers[items.level - 1].groupHeaders.push({
  13171. titleText: items.label,
  13172. numberOfColumns: 0
  13173. });
  13174. var collen = headers[items.level - 1].groupHeaders.length - 1,
  13175. colpos = collen === 0 ? swaplen : initColLen;//+aggrlen;
  13176. if (items.level - 1 === (o.rowTotals ? 1 : 0)) {
  13177. if (collen > 0) {
  13178. var l1 = 0;
  13179. for (var kk = 0; kk < collen; kk++) {
  13180. l1 += headers[items.level - 1].groupHeaders[kk].numberOfColumns;
  13181. }
  13182. if (l1) {
  13183. colpos = l1 + xlen;
  13184. }
  13185. }
  13186. }
  13187. if (columns[colpos]) {
  13188. headers[items.level - 1].groupHeaders[collen].startColumnName = columns[colpos].name;
  13189. headers[items.level - 1].groupHeaders[collen].numberOfColumns = columns.length - colpos;
  13190. }
  13191. initColLen = columns.length;
  13192. }
  13193. }
  13194. lastval[items.level] = items.text;
  13195. }
  13196. // This is in case when the member contain more than one summary item
  13197. if (items.level === ylen && key === 'level' && ylen > 0) {
  13198. if (aggrlen > 1) {
  13199. var ll = 1;
  13200. for (l in items.fields) {
  13201. if (items.fields.hasOwnProperty(l)) {
  13202. if (ll === 1) {
  13203. headers[ylen - 1].groupHeaders.push({ startColumnName: l, numberOfColumns: 1, titleText: items.label || items.text });
  13204. }
  13205. ll++;
  13206. }
  13207. }
  13208. headers[ylen - 1].groupHeaders[headers[ylen - 1].groupHeaders.length - 1].numberOfColumns = ll - 1;
  13209. } else {
  13210. headers.splice(ylen - 1, 1);
  13211. }
  13212. }
  13213. }
  13214. // if object, call recursively
  13215. if (items[key] != null && typeof items[key] === "object") {
  13216. list(items[key]);
  13217. }
  13218. // Finally build the columns
  13219. if (key === 'level') {
  13220. if (items.level > 0 && (items.level === (ylen === 0 ? items.level : ylen) || lastval[items.level].indexOf('_r_Totals') !== -1)) {
  13221. j = 0;
  13222. for (l in items.fields) {
  13223. if (items.fields.hasOwnProperty(l)) {
  13224. col = {};
  13225. for (k in o.aggregates[j]) {
  13226. if (o.aggregates[j].hasOwnProperty(k)) {
  13227. switch (k) {
  13228. case 'member':
  13229. case 'label':
  13230. case 'aggregator':
  13231. break;
  13232. default:
  13233. col[k] = o.aggregates[j][k];
  13234. }
  13235. }
  13236. }
  13237. if (aggrlen > 1) {
  13238. col.name = l;
  13239. col.label = o.aggregates[j].label || items.label;
  13240. } else {
  13241. col.name = items.text;
  13242. col.label = items.text === '_r_Totals' ? o.rowTotalsText : items.label;
  13243. }
  13244. columns.push(col);
  13245. j++;
  13246. }
  13247. }
  13248. }
  13249. }
  13250. }
  13251. }
  13252. }
  13253. list(tree);
  13254. var nm;
  13255. // loop again trougth the pivot rows in order to build grand total
  13256. if (o.colTotals) {
  13257. var plen = pivotrows.length;
  13258. while (plen--) {
  13259. for (i = xlen; i < columns.length; i++) {
  13260. nm = columns[i].name;
  13261. if (!summaries[nm]) {
  13262. summaries[nm] = parseFloat(pivotrows[plen][nm] || 0);
  13263. } else {
  13264. summaries[nm] += parseFloat(pivotrows[plen][nm] || 0);
  13265. }
  13266. }
  13267. }
  13268. }
  13269. // based on xDimension levels build grouping
  13270. if (groupfields > 0) {
  13271. for (i = 0; i < groupfields; i++) {
  13272. if (columns[i].isGroupField) {
  13273. groupOptions.groupingView.groupField.push(columns[i].name);
  13274. groupOptions.groupingView.groupSummary.push(o.groupSummary);
  13275. groupOptions.groupingView.groupSummaryPos.push(o.groupSummaryPos);
  13276. }
  13277. }
  13278. } else {
  13279. // no grouping is needed
  13280. groupOptions.grouping = false;
  13281. }
  13282. groupOptions.sortname = columns[groupfields].name;
  13283. groupOptions.groupingView.hideFirstGroupCol = true;
  13284. });
  13285. // return the final result.
  13286. return { "colModel": columns, "rows": pivotrows, "groupOptions": groupOptions, "groupHeaders": headers, summary: summaries };
  13287. },
  13288. jqPivot: function (data, pivotOpt, gridOpt, ajaxOpt) {
  13289. return this.each(function () {
  13290. var $t = this;
  13291. function pivot(data) {
  13292. var pivotGrid = jQuery($t).jqGrid('pivotSetup', data, pivotOpt),
  13293. footerrow = $.assocArraySize(pivotGrid.summary) > 0 ? true : false,
  13294. query = $.jgrid.from.call($t, pivotGrid.rows), i, so, st, len;
  13295. if (pivotOpt.ignoreCase) {
  13296. query = query.ignoreCase();
  13297. }
  13298. for (i = 0; i < pivotGrid.groupOptions.groupingView.groupField.length; i++) {
  13299. so = pivotOpt.xDimension[i].sortorder ? pivotOpt.xDimension[i].sortorder : 'asc';
  13300. st = pivotOpt.xDimension[i].sorttype ? pivotOpt.xDimension[i].sorttype : 'text';
  13301. query.orderBy(pivotGrid.groupOptions.groupingView.groupField[i], so, st, '', st);
  13302. }
  13303. len = pivotOpt.xDimension.length;
  13304. if (pivotGrid.groupOptions.sortname && len) {
  13305. so = pivotOpt.xDimension[len - 1].sortorder ? pivotOpt.xDimension[len - 1].sortorder : 'asc';
  13306. st = pivotOpt.xDimension[len - 1].sorttype ? pivotOpt.xDimension[len - 1].sorttype : 'text';
  13307. query.orderBy(pivotGrid.groupOptions.sortname, so, st, '', st);
  13308. }
  13309. jQuery($t).jqGrid($.extend(true, {
  13310. datastr: $.extend(query.select(), footerrow ? { userdata: pivotGrid.summary } : {}),
  13311. datatype: "jsonstring",
  13312. footerrow: footerrow,
  13313. userDataOnFooter: footerrow,
  13314. colModel: pivotGrid.colModel,
  13315. viewrecords: true,
  13316. sortname: pivotOpt.xDimension[0].dataName // ?????
  13317. }, pivotGrid.groupOptions, gridOpt || {}));
  13318. var gHead = pivotGrid.groupHeaders;
  13319. if (gHead.length) {
  13320. for (i = 0; i < gHead.length ; i++) {
  13321. if (gHead[i] && gHead[i].groupHeaders.length) {
  13322. jQuery($t).jqGrid('setGroupHeaders', gHead[i]);
  13323. }
  13324. }
  13325. }
  13326. if (pivotOpt.frozenStaticCols) {
  13327. jQuery($t).jqGrid("setFrozenColumns");
  13328. }
  13329. }
  13330. if (typeof data === "string") {
  13331. $.ajax($.extend({
  13332. url: data,
  13333. dataType: 'json',
  13334. success: function (response) {
  13335. pivot($.jgrid.getAccessor(response, ajaxOpt && ajaxOpt.reader ? ajaxOpt.reader : 'rows'));
  13336. }
  13337. }, ajaxOpt || {}));
  13338. } else {
  13339. pivot(data);
  13340. }
  13341. });
  13342. }
  13343. });
  13344. //module begin
  13345. $.jgrid.extend({
  13346. setSubGrid: function () {
  13347. return this.each(function () {
  13348. var $t = this, cm, i,
  13349. classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].subgrid,
  13350. suboptions = {
  13351. plusicon: classes.icon_plus,
  13352. minusicon: classes.icon_minus,
  13353. openicon: classes.icon_open,
  13354. expandOnLoad: false,
  13355. delayOnLoad: 50,
  13356. selectOnExpand: false,
  13357. selectOnCollapse: false,
  13358. reloadOnExpand: true
  13359. };
  13360. $t.p.subGridOptions = $.extend(suboptions, $t.p.subGridOptions || {});
  13361. $t.p.colNames.unshift("");
  13362. $t.p.colModel.unshift({ name: 'subgrid', width: $.jgrid.cell_width ? $t.p.subGridWidth + $t.p.cellLayout : $t.p.subGridWidth, sortable: false, resizable: false, hidedlg: true, search: false, fixed: true });
  13363. cm = $t.p.subGridModel;
  13364. if (cm[0]) {
  13365. cm[0].align = $.extend([], cm[0].align || []);
  13366. for (i = 0; i < cm[0].name.length; i++) { cm[0].align[i] = cm[0].align[i] || 'left'; }
  13367. }
  13368. });
  13369. },
  13370. addSubGridCell: function (pos, iRow) {
  13371. var prp = '', ic, sid, icb;
  13372. this.each(function () {
  13373. prp = this.formatCol(pos, iRow);
  13374. sid = this.p.id;
  13375. ic = this.p.subGridOptions.plusicon;
  13376. icb = $.jgrid.styleUI[(this.p.styleUI || 'jQueryUI')].common;
  13377. });
  13378. return "<td role=\"gridcell\" aria-describedby=\"" + sid + "_subgrid\" class=\"ui-sgcollapsed sgcollapsed\" " + prp + "><a style='cursor:pointer;' class='ui-sghref'><span class='" + icb.icon_base + " " + ic + "'></span></a></td>";
  13379. },
  13380. addSubGrid: function (pos, sind) {
  13381. return this.each(function () {
  13382. var ts = this;
  13383. if (!ts.grid) { return; }
  13384. var base = $.jgrid.styleUI[(ts.p.styleUI || 'jQueryUI')].base,
  13385. common = $.jgrid.styleUI[(ts.p.styleUI || 'jQueryUI')].common;
  13386. //-------------------------
  13387. var subGridCell = function (trdiv, cell, pos) {
  13388. var tddiv = $("<td align='" + ts.p.subGridModel[0].align[pos] + "'></td>").html(cell);
  13389. $(trdiv).append(tddiv);
  13390. };
  13391. var subGridXml = function (sjxml, sbid) {
  13392. var tddiv, i, sgmap,
  13393. dummy = $("<table class='" + base.rowTable + " ui-common-table'><tbody></tbody></table>"),
  13394. trdiv = $("<tr></tr>");
  13395. for (i = 0; i < ts.p.subGridModel[0].name.length; i++) {
  13396. tddiv = $("<th class='" + base.headerBox + " ui-th-subgrid ui-th-column ui-th-" + ts.p.direction + "'></th>");
  13397. $(tddiv).html(ts.p.subGridModel[0].name[i]);
  13398. $(tddiv).width(ts.p.subGridModel[0].width[i]);
  13399. $(trdiv).append(tddiv);
  13400. }
  13401. $(dummy).append(trdiv);
  13402. if (sjxml) {
  13403. sgmap = ts.p.xmlReader.subgrid;
  13404. $(sgmap.root + " " + sgmap.row, sjxml).each(function () {
  13405. trdiv = $("<tr class='" + common.content + " ui-subtblcell'></tr>");
  13406. if (sgmap.repeatitems === true) {
  13407. $(sgmap.cell, this).each(function (i) {
  13408. subGridCell(trdiv, $(this).text() || '&#160;', i);
  13409. });
  13410. } else {
  13411. var f = ts.p.subGridModel[0].mapping || ts.p.subGridModel[0].name;
  13412. if (f) {
  13413. for (i = 0; i < f.length; i++) {
  13414. subGridCell(trdiv, $(f[i], this).text() || '&#160;', i);
  13415. }
  13416. }
  13417. }
  13418. $(dummy).append(trdiv);
  13419. });
  13420. }
  13421. var pID = $("table:first", ts.grid.bDiv).attr("id") + "_";
  13422. $("#" + $.jgrid.jqID(pID + sbid)).append(dummy);
  13423. ts.grid.hDiv.loading = false;
  13424. $("#load_" + $.jgrid.jqID(ts.p.id)).hide();
  13425. return false;
  13426. };
  13427. var subGridJson = function (sjxml, sbid) {
  13428. var tddiv, result, i, cur, sgmap, j,
  13429. dummy = $("<table class='" + base.rowTable + " ui-common-table'><tbody></tbody></table>"),
  13430. trdiv = $("<tr></tr>");
  13431. for (i = 0; i < ts.p.subGridModel[0].name.length; i++) {
  13432. tddiv = $("<th class='" + base.headerBox + " ui-th-subgrid ui-th-column ui-th-" + ts.p.direction + "'></th>");
  13433. $(tddiv).html(ts.p.subGridModel[0].name[i]);
  13434. $(tddiv).width(ts.p.subGridModel[0].width[i]);
  13435. $(trdiv).append(tddiv);
  13436. }
  13437. $(dummy).append(trdiv);
  13438. if (sjxml) {
  13439. sgmap = ts.p.jsonReader.subgrid;
  13440. result = $.jgrid.getAccessor(sjxml, sgmap.root);
  13441. if (result !== undefined) {
  13442. for (i = 0; i < result.length; i++) {
  13443. cur = result[i];
  13444. trdiv = $("<tr class='" + common.content + " ui-subtblcell'></tr>");
  13445. if (sgmap.repeatitems === true) {
  13446. if (sgmap.cell) { cur = cur[sgmap.cell]; }
  13447. for (j = 0; j < cur.length; j++) {
  13448. subGridCell(trdiv, cur[j] || '&#160;', j);
  13449. }
  13450. } else {
  13451. var f = ts.p.subGridModel[0].mapping || ts.p.subGridModel[0].name;
  13452. if (f.length) {
  13453. for (j = 0; j < f.length; j++) {
  13454. subGridCell(trdiv, cur[f[j]] || '&#160;', j);
  13455. }
  13456. }
  13457. }
  13458. $(dummy).append(trdiv);
  13459. }
  13460. }
  13461. }
  13462. var pID = $("table:first", ts.grid.bDiv).attr("id") + "_";
  13463. $("#" + $.jgrid.jqID(pID + sbid)).append(dummy);
  13464. ts.grid.hDiv.loading = false;
  13465. $("#load_" + $.jgrid.jqID(ts.p.id)).hide();
  13466. return false;
  13467. };
  13468. var populatesubgrid = function (rd) {
  13469. var sid, dp, i, j;
  13470. sid = $(rd).attr("id");
  13471. dp = { nd_: (new Date().getTime()) };
  13472. dp[ts.p.prmNames.subgridid] = sid;
  13473. if (!ts.p.subGridModel[0]) { return false; }
  13474. if (ts.p.subGridModel[0].params) {
  13475. for (j = 0; j < ts.p.subGridModel[0].params.length; j++) {
  13476. for (i = 0; i < ts.p.colModel.length; i++) {
  13477. if (ts.p.colModel[i].name === ts.p.subGridModel[0].params[j]) {
  13478. dp[ts.p.colModel[i].name] = $("td:eq(" + i + ")", rd).text().replace(/\&#160\;/ig, '');
  13479. }
  13480. }
  13481. }
  13482. }
  13483. if (!ts.grid.hDiv.loading) {
  13484. ts.grid.hDiv.loading = true;
  13485. $("#load_" + $.jgrid.jqID(ts.p.id)).show();
  13486. if (!ts.p.subgridtype) { ts.p.subgridtype = ts.p.datatype; }
  13487. if ($.isFunction(ts.p.subgridtype)) {
  13488. ts.p.subgridtype.call(ts, dp);
  13489. } else {
  13490. ts.p.subgridtype = ts.p.subgridtype.toLowerCase();
  13491. }
  13492. switch (ts.p.subgridtype) {
  13493. case "xml":
  13494. case "json":
  13495. $.ajax($.extend({
  13496. type: ts.p.mtype,
  13497. url: $.isFunction(ts.p.subGridUrl) ? ts.p.subGridUrl.call(ts, dp) : ts.p.subGridUrl,
  13498. dataType: ts.p.subgridtype,
  13499. data: $.isFunction(ts.p.serializeSubGridData) ? ts.p.serializeSubGridData.call(ts, dp) : dp,
  13500. complete: function (sxml) {
  13501. if (ts.p.subgridtype === "xml") {
  13502. subGridXml(sxml.responseXML, sid);
  13503. } else {
  13504. subGridJson($.jgrid.parse(sxml.responseText), sid);
  13505. }
  13506. sxml = null;
  13507. }
  13508. }, $.jgrid.ajaxOptions, ts.p.ajaxSubgridOptions || {}));
  13509. break;
  13510. }
  13511. }
  13512. return false;
  13513. };
  13514. var _id, pID, atd, nhc = 0, bfsc, $r;
  13515. $.each(ts.p.colModel, function () {
  13516. if (this.hidden === true || this.name === 'rn' || this.name === 'cb') {
  13517. nhc++;
  13518. }
  13519. });
  13520. var len = ts.rows.length, i = 1, hsret, ishsg = $.isFunction(ts.p.isHasSubGrid);
  13521. if (sind !== undefined && sind > 0) {
  13522. i = sind;
  13523. len = sind + 1;
  13524. }
  13525. while (i < len) {
  13526. if ($(ts.rows[i]).hasClass('jqgrow')) {
  13527. if (ts.p.scroll) {
  13528. $(ts.rows[i].cells[pos]).unbind('click');
  13529. }
  13530. hsret = null;
  13531. if (ishsg) {
  13532. var hsret = ts.p.isHasSubGrid.call(ts, ts.rows[i].id);
  13533. }
  13534. if (hsret === false) {
  13535. ts.rows[i].cells[pos].innerHTML = "";
  13536. } else {
  13537. $(ts.rows[i].cells[pos]).bind('click', function () {
  13538. var tr = $(this).parent("tr")[0];
  13539. pID = ts.p.id;
  13540. _id = tr.id;
  13541. $r = $("#" + pID + "_" + _id + "_expandedContent");
  13542. if ($(this).hasClass("sgcollapsed")) {
  13543. bfsc = $(ts).triggerHandler("jqGridSubGridBeforeExpand", [pID + "_" + _id, _id]);
  13544. bfsc = (bfsc === false || bfsc === 'stop') ? false : true;
  13545. if (bfsc && $.isFunction(ts.p.subGridBeforeExpand)) {
  13546. bfsc = ts.p.subGridBeforeExpand.call(ts, pID + "_" + _id, _id);
  13547. }
  13548. if (bfsc === false) { return false; }
  13549. if (ts.p.subGridOptions.reloadOnExpand === true || (ts.p.subGridOptions.reloadOnExpand === false && !$r.hasClass('ui-subgrid'))) {
  13550. atd = pos >= 1 ? "<td colspan='" + pos + "'>&#160;</td>" : "";
  13551. $(tr).after("<tr role='row' id='" + pID + "_" + _id + "_expandedContent" + "' class='ui-subgrid ui-sg-expanded'>" + atd + "<td class='" + common.content + " subgrid-cell'><span class='" + common.icon_base + " " + ts.p.subGridOptions.openicon + "'></span></td><td colspan='" + parseInt(ts.p.colNames.length - 1 - nhc, 10) + "' class='" + common.content + " subgrid-data'><div id=" + pID + "_" + _id + " class='tablediv'></div></td></tr>");
  13552. $(ts).triggerHandler("jqGridSubGridRowExpanded", [pID + "_" + _id, _id]);
  13553. if ($.isFunction(ts.p.subGridRowExpanded)) {
  13554. ts.p.subGridRowExpanded.call(ts, pID + "_" + _id, _id);
  13555. } else {
  13556. populatesubgrid(tr);
  13557. }
  13558. } else {
  13559. $r.show().removeClass("ui-sg-collapsed").addClass("ui-sg-expanded");
  13560. }
  13561. $(this).html("<a style='cursor:pointer;' class='ui-sghref'><span class='" + common.icon_base + " " + ts.p.subGridOptions.minusicon + "'></span></a>").removeClass("sgcollapsed").addClass("sgexpanded");
  13562. if (ts.p.subGridOptions.selectOnExpand) {
  13563. $(ts).jqGrid('setSelection', _id);
  13564. }
  13565. } else if ($(this).hasClass("sgexpanded")) {
  13566. bfsc = $(ts).triggerHandler("jqGridSubGridRowColapsed", [pID + "_" + _id, _id]);
  13567. bfsc = (bfsc === false || bfsc === 'stop') ? false : true;
  13568. if (bfsc && $.isFunction(ts.p.subGridRowColapsed)) {
  13569. bfsc = ts.p.subGridRowColapsed.call(ts, pID + "_" + _id, _id);
  13570. }
  13571. if (bfsc === false) { return false; }
  13572. if (ts.p.subGridOptions.reloadOnExpand === true) {
  13573. $r.remove(".ui-subgrid");
  13574. } else if ($r.hasClass('ui-subgrid')) { // incase of dynamic deleting
  13575. $r.hide().addClass("ui-sg-collapsed").removeClass("ui-sg-expanded");
  13576. }
  13577. $(this).html("<a style='cursor:pointer;' class='ui-sghref'><span class='" + common.icon_base + " " + ts.p.subGridOptions.plusicon + "'></span></a>").removeClass("sgexpanded").addClass("sgcollapsed");
  13578. if (ts.p.subGridOptions.selectOnCollapse) {
  13579. $(ts).jqGrid('setSelection', _id);
  13580. }
  13581. }
  13582. return false;
  13583. });
  13584. }
  13585. }
  13586. i++;
  13587. }
  13588. if (ts.p.subGridOptions.expandOnLoad === true) {
  13589. $(ts.rows).filter('.jqgrow').each(function (index, row) {
  13590. $(row.cells[0]).click();
  13591. });
  13592. }
  13593. ts.subGridXml = function (xml, sid) { subGridXml(xml, sid); };
  13594. ts.subGridJson = function (json, sid) { subGridJson(json, sid); };
  13595. });
  13596. },
  13597. expandSubGridRow: function (rowid) {
  13598. return this.each(function () {
  13599. var $t = this;
  13600. if (!$t.grid && !rowid) { return; }
  13601. if ($t.p.subGrid === true) {
  13602. var rc = $(this).jqGrid("getInd", rowid, true);
  13603. if (rc) {
  13604. var sgc = $("td.sgcollapsed", rc)[0];
  13605. if (sgc) {
  13606. $(sgc).trigger("click");
  13607. }
  13608. }
  13609. }
  13610. });
  13611. },
  13612. collapseSubGridRow: function (rowid) {
  13613. return this.each(function () {
  13614. var $t = this;
  13615. if (!$t.grid && !rowid) { return; }
  13616. if ($t.p.subGrid === true) {
  13617. var rc = $(this).jqGrid("getInd", rowid, true);
  13618. if (rc) {
  13619. var sgc = $("td.sgexpanded", rc)[0];
  13620. if (sgc) {
  13621. $(sgc).trigger("click");
  13622. }
  13623. }
  13624. }
  13625. });
  13626. },
  13627. toggleSubGridRow: function (rowid) {
  13628. return this.each(function () {
  13629. var $t = this;
  13630. if (!$t.grid && !rowid) { return; }
  13631. if ($t.p.subGrid === true) {
  13632. var rc = $(this).jqGrid("getInd", rowid, true);
  13633. if (rc) {
  13634. var sgc = $("td.sgcollapsed", rc)[0];
  13635. if (sgc) {
  13636. $(sgc).trigger("click");
  13637. } else {
  13638. sgc = $("td.sgexpanded", rc)[0];
  13639. if (sgc) {
  13640. $(sgc).trigger("click");
  13641. }
  13642. }
  13643. }
  13644. }
  13645. });
  13646. }
  13647. });
  13648. //module begin
  13649. $.jgrid.extend({
  13650. setTreeNode: function (i, len) {
  13651. return this.each(function () {
  13652. var $t = this;
  13653. if (!$t.grid || !$t.p.treeGrid) { return; }
  13654. var expCol = $t.p.expColInd,
  13655. expanded = $t.p.treeReader.expanded_field,
  13656. isLeaf = $t.p.treeReader.leaf_field,
  13657. level = $t.p.treeReader.level_field,
  13658. icon = $t.p.treeReader.icon_field,
  13659. loaded = $t.p.treeReader.loaded, lft, rgt, curLevel, ident, lftpos, twrap,
  13660. ldat, lf,
  13661. common = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].common,
  13662. index = i;
  13663. $($t).triggerHandler("jqGridBeforeSetTreeNode", [index, len]);
  13664. if ($.isFunction($t.p.beforeSetTreeNode)) {
  13665. $t.p.beforeSetTreeNode.call($t, index, len);
  13666. }
  13667. while (i < len) {
  13668. var ind = $.jgrid.stripPref($t.p.idPrefix, $t.rows[i].id), dind = $t.p._index[ind], expan;
  13669. ldat = $t.p.data[dind];
  13670. //$t.rows[i].level = ldat[level];
  13671. if ($t.p.treeGridModel === 'nested') {
  13672. if (!ldat[isLeaf]) {
  13673. lft = parseInt(ldat[$t.p.treeReader.left_field], 10);
  13674. rgt = parseInt(ldat[$t.p.treeReader.right_field], 10);
  13675. // NS Model
  13676. ldat[isLeaf] = (rgt === lft + 1) ? 'true' : 'false';
  13677. $t.rows[i].cells[$t.p._treeleafpos].innerHTML = ldat[isLeaf];
  13678. }
  13679. }
  13680. //else {
  13681. //row.parent_id = rd[$t.p.treeReader.parent_id_field];
  13682. //}
  13683. curLevel = parseInt(ldat[level], 10);
  13684. if ($t.p.tree_root_level === 0) {
  13685. ident = curLevel + 1;
  13686. lftpos = curLevel;
  13687. } else {
  13688. ident = curLevel;
  13689. lftpos = curLevel - 1;
  13690. }
  13691. twrap = "<div class='tree-wrap tree-wrap-" + $t.p.direction + "' style='width:" + (ident * 18) + "px;'>";
  13692. twrap += "<div style='" + ($t.p.direction === "rtl" ? "right:" : "left:") + (lftpos * 18) + "px;' class='" + common.icon_base + " ";
  13693. if (ldat[loaded] !== undefined) {
  13694. if (ldat[loaded] === "true" || ldat[loaded] === true) {
  13695. ldat[loaded] = true;
  13696. } else {
  13697. ldat[loaded] = false;
  13698. }
  13699. }
  13700. if (ldat[isLeaf] === "true" || ldat[isLeaf] === true) {
  13701. //twrap += ((ldat[icon] !== undefined && ldat[icon] !== "") ? ldat[icon] : $t.p.treeIcons.leaf) + " tree-leaf treeclick";
  13702. ldat[isLeaf] = true;
  13703. lf = "leaf";
  13704. } else {
  13705. ldat[isLeaf] = false;
  13706. lf = "";
  13707. }
  13708. ldat[expanded] = ((ldat[expanded] === "true" || ldat[expanded] === true) ? true : false) && (ldat[loaded] || ldat[loaded] === undefined);
  13709. if (ldat[expanded] === false) {
  13710. twrap += ((ldat[isLeaf] === true) ? "'" : $t.p.treeIcons.plus + " tree-plus treeclick'");
  13711. } else {
  13712. twrap += ((ldat[isLeaf] === true) ? "'" : $t.p.treeIcons.minus + " tree-minus treeclick'");
  13713. }
  13714. twrap += "></div></div>";
  13715. $($t.rows[i].cells[expCol]).wrapInner("<span class='cell-wrapper" + lf + "'></span>").prepend(twrap);
  13716. if (curLevel !== parseInt($t.p.tree_root_level, 10)) {
  13717. //var pn = $($t).jqGrid('getNodeParent',ldat);
  13718. //expan = pn && pn.hasOwnProperty(expanded) ? pn[expanded] : true;
  13719. expan = $($t).jqGrid('isVisibleNode', ldat); // overhead
  13720. if (!expan) {
  13721. $($t.rows[i]).css("display", "none");
  13722. }
  13723. }
  13724. $($t.rows[i].cells[expCol])
  13725. .find("div.treeclick")
  13726. .bind("click", function (e) {
  13727. var target = e.target || e.srcElement,
  13728. ind2 = $.jgrid.stripPref($t.p.idPrefix, $(target, $t.rows).closest("tr.jqgrow")[0].id),
  13729. pos = $t.p._index[ind2];
  13730. if (!$t.p.data[pos][isLeaf]) {
  13731. if ($t.p.data[pos][expanded]) {
  13732. $($t).jqGrid("collapseRow", $t.p.data[pos]);
  13733. $($t).jqGrid("collapseNode", $t.p.data[pos]);
  13734. } else {
  13735. $($t).jqGrid("expandRow", $t.p.data[pos]);
  13736. $($t).jqGrid("expandNode", $t.p.data[pos]);
  13737. }
  13738. }
  13739. return false;
  13740. });
  13741. if ($t.p.ExpandColClick === true) {
  13742. $($t.rows[i].cells[expCol])
  13743. .find("span.cell-wrapper")
  13744. .css("cursor", "pointer")
  13745. .bind("click", function (e) {
  13746. var target = e.target || e.srcElement,
  13747. ind2 = $.jgrid.stripPref($t.p.idPrefix, $(target, $t.rows).closest("tr.jqgrow")[0].id),
  13748. pos = $t.p._index[ind2];
  13749. if (!$t.p.data[pos][isLeaf]) {
  13750. if ($t.p.data[pos][expanded]) {
  13751. $($t).jqGrid("collapseRow", $t.p.data[pos]);
  13752. $($t).jqGrid("collapseNode", $t.p.data[pos]);
  13753. } else {
  13754. $($t).jqGrid("expandRow", $t.p.data[pos]);
  13755. $($t).jqGrid("expandNode", $t.p.data[pos]);
  13756. }
  13757. }
  13758. $($t).jqGrid("setSelection", ind2);
  13759. return false;
  13760. });
  13761. }
  13762. i++;
  13763. }
  13764. $($t).triggerHandler("jqGridAfterSetTreeNode", [index, len]);
  13765. if ($.isFunction($t.p.afterSetTreeNode)) {
  13766. $t.p.afterSetTreeNode.call($t, index, len);
  13767. }
  13768. });
  13769. },
  13770. setTreeGrid: function () {
  13771. return this.each(function () {
  13772. var $t = this, i = 0, pico, ecol = false, nm, key, tkey, dupcols = [],
  13773. classes = $.jgrid.styleUI[($t.p.styleUI || 'jQueryUI')].treegrid;
  13774. if (!$t.p.treeGrid) { return; }
  13775. if (!$t.p.treedatatype) { $.extend($t.p, { treedatatype: $t.p.datatype }); }
  13776. if ($t.p.loadonce) { $t.p.treedatatype = 'local'; }
  13777. $t.p.subGrid = false; $t.p.altRows = false;
  13778. $t.p.pgbuttons = false; $t.p.pginput = false;
  13779. $t.p.gridview = true;
  13780. if ($t.p.rowTotal === null) { $t.p.rowNum = 10000; }
  13781. $t.p.multiselect = false; $t.p.rowList = [];
  13782. $t.p.expColInd = 0;
  13783. pico = classes.icon_plus;
  13784. if ($t.p.styleUI === 'jQueryUI') {
  13785. pico += ($t.p.direction === "rtl" ? 'w' : 'e');
  13786. }
  13787. $t.p.treeIcons = $.extend({ plus: pico, minus: classes.icon_minus, leaf: classes.icon_leaf }, $t.p.treeIcons || {});
  13788. if ($t.p.treeGridModel === 'nested') {
  13789. $t.p.treeReader = $.extend({
  13790. level_field: "level",
  13791. left_field: "lft",
  13792. right_field: "rgt",
  13793. leaf_field: "isLeaf",
  13794. expanded_field: "expanded",
  13795. loaded: "loaded",
  13796. icon_field: "icon"
  13797. }, $t.p.treeReader);
  13798. } else if ($t.p.treeGridModel === 'adjacency') {
  13799. $t.p.treeReader = $.extend({
  13800. level_field: "level",
  13801. parent_id_field: "parent",
  13802. leaf_field: "isLeaf",
  13803. expanded_field: "expanded",
  13804. loaded: "loaded",
  13805. icon_field: "icon"
  13806. }, $t.p.treeReader);
  13807. }
  13808. for (key in $t.p.colModel) {
  13809. if ($t.p.colModel.hasOwnProperty(key)) {
  13810. nm = $t.p.colModel[key].name;
  13811. if (nm === $t.p.ExpandColumn && !ecol) {
  13812. ecol = true;
  13813. $t.p.expColInd = i;
  13814. }
  13815. i++;
  13816. //
  13817. for (tkey in $t.p.treeReader) {
  13818. if ($t.p.treeReader.hasOwnProperty(tkey) && $t.p.treeReader[tkey] === nm) {
  13819. dupcols.push(nm);
  13820. }
  13821. }
  13822. }
  13823. }
  13824. $.each($t.p.treeReader, function (j, n) {
  13825. if (n && $.inArray(n, dupcols) === -1) {
  13826. if (j === 'leaf_field') { $t.p._treeleafpos = i; }
  13827. i++;
  13828. $t.p.colNames.push(n);
  13829. $t.p.colModel.push({ name: n, width: 1, hidden: true, sortable: false, resizable: false, hidedlg: true, editable: true, search: false });
  13830. }
  13831. });
  13832. });
  13833. },
  13834. expandRow: function (record) {
  13835. this.each(function () {
  13836. var $t = this;
  13837. if (!$t.grid || !$t.p.treeGrid) { return; }
  13838. var childern = $($t).jqGrid("getNodeChildren", record),
  13839. //if ($($t).jqGrid("isVisibleNode",record)) {
  13840. expanded = $t.p.treeReader.expanded_field,
  13841. rowid = record[$t.p.localReader.id];
  13842. var ret = $.isFunction($t.p.beforeExpandTreeGridRow) ? $t.p.beforeExpandTreeGridRow.call($t, rowid, record, childern) : true;
  13843. if (ret === false) { return; }
  13844. $(childern).each(function () {
  13845. var id = $t.p.idPrefix + $.jgrid.getAccessor(this, $t.p.localReader.id);
  13846. $($($t).jqGrid('getGridRowById', id)).css("display", "");
  13847. if (this[expanded]) {
  13848. $($t).jqGrid("expandRow", this);
  13849. }
  13850. });
  13851. if ($.isFunction($t.p.afterExpandTreeGridRow)) {
  13852. $t.p.afterExpandTreeGridRow.call($t, rowid, record, childern);
  13853. }
  13854. //}
  13855. });
  13856. },
  13857. collapseRow: function (record) {
  13858. this.each(function () {
  13859. var $t = this;
  13860. if (!$t.grid || !$t.p.treeGrid) { return; }
  13861. var childern = $($t).jqGrid("getNodeChildren", record),
  13862. expanded = $t.p.treeReader.expanded_field,
  13863. rowid = record[$t.p.localReader.id];
  13864. var ret = $.isFunction($t.p.beforeCollapseTreeGridRow) ? $t.p.beforeCollapseTreeGridRow.call($t, rowid, record, childern) : true;
  13865. if (ret === false) { return; }
  13866. $(childern).each(function () {
  13867. var id = $t.p.idPrefix + $.jgrid.getAccessor(this, $t.p.localReader.id);
  13868. $($($t).jqGrid('getGridRowById', id)).css("display", "none");
  13869. if (this[expanded]) {
  13870. $($t).jqGrid("collapseRow", this);
  13871. }
  13872. });
  13873. if ($.isFunction($t.p.afterCollapseTreeGridRow)) {
  13874. $t.p.afterCollapseTreeGridRow.call($t, rowid, record, childern);
  13875. }
  13876. });
  13877. },
  13878. // NS ,adjacency models
  13879. getRootNodes: function (currentview) {
  13880. var result = [];
  13881. this.each(function () {
  13882. var $t = this, level, parent_id, view;
  13883. if (!$t.grid || !$t.p.treeGrid) { return; }
  13884. if (typeof currentview !== 'boolean') {
  13885. currentview = false;
  13886. }
  13887. if (currentview) {
  13888. view = $($t).jqGrid('getRowData', null, true);
  13889. } else {
  13890. view = $t.p.data;
  13891. }
  13892. switch ($t.p.treeGridModel) {
  13893. case 'nested':
  13894. level = $t.p.treeReader.level_field;
  13895. $(view).each(function () {
  13896. if (parseInt(this[level], 10) === parseInt($t.p.tree_root_level, 10)) {
  13897. if (currentview) {
  13898. result.push($t.p.data[$t.p._index[this[$t.p.keyName]]]);
  13899. } else {
  13900. result.push(this);
  13901. }
  13902. }
  13903. });
  13904. break;
  13905. case 'adjacency':
  13906. parent_id = $t.p.treeReader.parent_id_field;
  13907. $(view).each(function () {
  13908. if (this[parent_id] === null || String(this[parent_id]).toLowerCase() === "null") {
  13909. if (currentview) {
  13910. result.push($t.p.data[$t.p._index[this[$t.p.keyName]]]);
  13911. } else {
  13912. result.push(this);
  13913. }
  13914. }
  13915. });
  13916. break;
  13917. }
  13918. });
  13919. return result;
  13920. },
  13921. getNodeDepth: function (rc) {
  13922. var ret = null;
  13923. this.each(function () {
  13924. if (!this.grid || !this.p.treeGrid) { return; }
  13925. var $t = this;
  13926. switch ($t.p.treeGridModel) {
  13927. case 'nested':
  13928. var level = $t.p.treeReader.level_field;
  13929. ret = parseInt(rc[level], 10) - parseInt($t.p.tree_root_level, 10);
  13930. break;
  13931. case 'adjacency':
  13932. ret = $($t).jqGrid("getNodeAncestors", rc).length;
  13933. break;
  13934. }
  13935. });
  13936. return ret;
  13937. },
  13938. getNodeParent: function (rc) {
  13939. var result = null;
  13940. this.each(function () {
  13941. var $t = this;
  13942. if (!$t.grid || !$t.p.treeGrid) { return; }
  13943. switch ($t.p.treeGridModel) {
  13944. case 'nested':
  13945. var lftc = $t.p.treeReader.left_field,
  13946. rgtc = $t.p.treeReader.right_field,
  13947. levelc = $t.p.treeReader.level_field,
  13948. lft = parseInt(rc[lftc], 10), rgt = parseInt(rc[rgtc], 10), level = parseInt(rc[levelc], 10);
  13949. $(this.p.data).each(function () {
  13950. if (parseInt(this[levelc], 10) === level - 1 && parseInt(this[lftc], 10) < lft && parseInt(this[rgtc], 10) > rgt) {
  13951. result = this;
  13952. return false;
  13953. }
  13954. });
  13955. break;
  13956. case 'adjacency':
  13957. var parent_id = $t.p.treeReader.parent_id_field,
  13958. dtid = $t.p.localReader.id,
  13959. ind = rc[dtid], pos = $t.p._index[ind];
  13960. while (pos--) {
  13961. if ($t.p.data[pos][dtid] === $.jgrid.stripPref($t.p.idPrefix, rc[parent_id])) {
  13962. result = $t.p.data[pos];
  13963. break;
  13964. }
  13965. }
  13966. break;
  13967. }
  13968. });
  13969. return result;
  13970. },
  13971. getNodeChildren: function (rc, currentview) {
  13972. var result = [];
  13973. this.each(function () {
  13974. var $t = this;
  13975. if (!$t.grid || !$t.p.treeGrid) { return; }
  13976. var i, len = currentview ? this.rows.length : this.p.data.length, row;
  13977. switch ($t.p.treeGridModel) {
  13978. case 'nested':
  13979. var lftc = $t.p.treeReader.left_field,
  13980. rgtc = $t.p.treeReader.right_field,
  13981. levelc = $t.p.treeReader.level_field,
  13982. lft = parseInt(rc[lftc], 10), rgt = parseInt(rc[rgtc], 10), level = parseInt(rc[levelc], 10);
  13983. for (i = 0; i < len; i++) {
  13984. row = currentview ? $t.p.data[$t.p._index[this.rows[i].id]] : $t.p.data[i];
  13985. if (row && parseInt(row[levelc], 10) === level + 1 && parseInt(row[lftc], 10) > lft && parseInt(row[rgtc], 10) < rgt) {
  13986. result.push(row);
  13987. }
  13988. }
  13989. break;
  13990. case 'adjacency':
  13991. var parent_id = $t.p.treeReader.parent_id_field,
  13992. dtid = $t.p.localReader.id;
  13993. for (i = 0; i < len; i++) {
  13994. row = currentview ? $t.p.data[$t.p._index[this.rows[i].id]] : $t.p.data[i];
  13995. if (row && String(row[parent_id]) === $.jgrid.stripPref($t.p.idPrefix, rc[dtid])) {
  13996. result.push(row);
  13997. }
  13998. }
  13999. break;
  14000. }
  14001. });
  14002. return result;
  14003. },
  14004. getFullTreeNode: function (rc, expand) {
  14005. var result = [];
  14006. this.each(function () {
  14007. var $t = this, len, expanded = $t.p.treeReader.expanded_field;
  14008. if (!$t.grid || !$t.p.treeGrid) { return; }
  14009. if (expand == null || typeof expand !== 'boolean') {
  14010. expand = false;
  14011. }
  14012. switch ($t.p.treeGridModel) {
  14013. case 'nested':
  14014. var lftc = $t.p.treeReader.left_field,
  14015. rgtc = $t.p.treeReader.right_field,
  14016. levelc = $t.p.treeReader.level_field,
  14017. lft = parseInt(rc[lftc], 10), rgt = parseInt(rc[rgtc], 10), level = parseInt(rc[levelc], 10);
  14018. $(this.p.data).each(function () {
  14019. if (parseInt(this[levelc], 10) >= level && parseInt(this[lftc], 10) >= lft && parseInt(this[lftc], 10) <= rgt) {
  14020. if (expand) { this[expanded] = true; }
  14021. result.push(this);
  14022. }
  14023. });
  14024. break;
  14025. case 'adjacency':
  14026. if (rc) {
  14027. result.push(rc);
  14028. var parent_id = $t.p.treeReader.parent_id_field,
  14029. dtid = $t.p.localReader.id;
  14030. $(this.p.data).each(function (i) {
  14031. len = result.length;
  14032. for (i = 0; i < len; i++) {
  14033. if ($.jgrid.stripPref($t.p.idPrefix, result[i][dtid]) === this[parent_id]) {
  14034. if (expand) { this[expanded] = true; }
  14035. result.push(this);
  14036. break;
  14037. }
  14038. }
  14039. });
  14040. }
  14041. break;
  14042. }
  14043. });
  14044. return result;
  14045. },
  14046. // End NS, adjacency Model
  14047. getNodeAncestors: function (rc, reverse, expanded) {
  14048. var ancestors = [];
  14049. if (reverse === undefined) {
  14050. reverse = false;
  14051. }
  14052. this.each(function () {
  14053. if (!this.grid || !this.p.treeGrid) { return; }
  14054. if (expanded === undefined) {
  14055. expanded = false;
  14056. } else {
  14057. expanded = this.p.treeReader.expanded_field;
  14058. }
  14059. var parent = $(this).jqGrid("getNodeParent", rc);
  14060. while (parent) {
  14061. if (expanded) {
  14062. try {
  14063. parent[expanded] = true;
  14064. } catch (etn) { }
  14065. }
  14066. if (reverse) {
  14067. ancestors.unshift(parent);
  14068. } else {
  14069. ancestors.push(parent);
  14070. }
  14071. parent = $(this).jqGrid("getNodeParent", parent);
  14072. }
  14073. });
  14074. return ancestors;
  14075. },
  14076. isVisibleNode: function (rc) {
  14077. var result = true;
  14078. this.each(function () {
  14079. var $t = this;
  14080. if (!$t.grid || !$t.p.treeGrid) { return; }
  14081. var ancestors = $($t).jqGrid("getNodeAncestors", rc),
  14082. expanded = $t.p.treeReader.expanded_field;
  14083. $(ancestors).each(function () {
  14084. result = result && this[expanded];
  14085. if (!result) { return false; }
  14086. });
  14087. });
  14088. return result;
  14089. },
  14090. isNodeLoaded: function (rc) {
  14091. var result;
  14092. this.each(function () {
  14093. var $t = this;
  14094. if (!$t.grid || !$t.p.treeGrid) { return; }
  14095. var isLeaf = $t.p.treeReader.leaf_field,
  14096. loaded = $t.p.treeReader.loaded;
  14097. if (rc !== undefined) {
  14098. if (rc[loaded] !== undefined) {
  14099. result = rc[loaded];
  14100. } else if (rc[isLeaf] || $($t).jqGrid("getNodeChildren", rc).length > 0) {
  14101. result = true;
  14102. } else {
  14103. result = false;
  14104. }
  14105. } else {
  14106. result = false;
  14107. }
  14108. });
  14109. return result;
  14110. },
  14111. setLeaf: function (rc, state, collapsed) {
  14112. return this.each(function () {
  14113. var id = $.jgrid.getAccessor(rc, this.p.localReader.id),
  14114. rc1 = $("#" + id, this.grid.bDiv)[0],
  14115. isLeaf = this.p.treeReader.leaf_field;
  14116. try {
  14117. var dr = this.p._index[id];
  14118. if (dr != null) {
  14119. this.p.data[dr][isLeaf] = state;
  14120. }
  14121. } catch (E) { }
  14122. if (state === true) {
  14123. // set it in data
  14124. $("div.treeclick", rc1).removeClass(this.p.treeIcons.minus + " tree-minus " + this.p.treeIcons.plus + " tree-plus").addClass(this.p.treeIcons.leaf + " tree-leaf");
  14125. } else if (state === false) {
  14126. var ico = this.p.treeIcons.minus + " tree-minus";
  14127. if (collapsed) {
  14128. ico = this.p.treeIcons.plus + " tree-plus";
  14129. }
  14130. $("div.treeclick", rc1).removeClass(this.p.treeIcons.leaf + " tree-leaf").addClass(ico);
  14131. }
  14132. });
  14133. },
  14134. reloadNode: function (rc, reloadcurrent) {
  14135. return this.each(function () {
  14136. if (!this.grid || !this.p.treeGrid) { return; }
  14137. var rid = this.p.localReader.id,
  14138. currselection = this.p.selrow;
  14139. $(this).jqGrid("delChildren", rc[rid]);
  14140. if (reloadcurrent === undefined) {
  14141. reloadcurrent = false;
  14142. }
  14143. if (!reloadcurrent) {
  14144. if (!jQuery._data(this, "events").jqGridAfterSetTreeNode) {
  14145. $(this).bind("jqGridAfterSetTreeNode.reloadNode", function () {
  14146. var isLeaf = this.p.treeReader.leaf_field;
  14147. if (this.p.reloadnode) {
  14148. var rc = this.p.reloadnode,
  14149. chld = $(this).jqGrid('getNodeChildren', rc);
  14150. if (rc[isLeaf] && chld.length) {
  14151. $(this).jqGrid('setLeaf', rc, false);
  14152. } else if (!rc[isLeaf] && chld.length === 0) {
  14153. $(this).jqGrid('setLeaf', rc, true);
  14154. }
  14155. }
  14156. this.p.reloadnode = false;
  14157. });
  14158. }
  14159. }
  14160. var expanded = this.p.treeReader.expanded_field,
  14161. parent = this.p.treeReader.parent_id_field,
  14162. loaded = this.p.treeReader.loaded,
  14163. level = this.p.treeReader.level_field,
  14164. isLeaf = this.p.treeReader.leaf_field,
  14165. lft = this.p.treeReader.left_field,
  14166. rgt = this.p.treeReader.right_field;
  14167. var id = $.jgrid.getAccessor(rc, this.p.localReader.id),
  14168. rc1 = $("#" + id, this.grid.bDiv)[0];
  14169. rc[expanded] = true;
  14170. if (!rc[isLeaf]) {
  14171. $("div.treeclick", rc1).removeClass(this.p.treeIcons.plus + " tree-plus").addClass(this.p.treeIcons.minus + " tree-minus");
  14172. }
  14173. this.p.treeANode = rc1.rowIndex;
  14174. this.p.datatype = this.p.treedatatype;
  14175. this.p.reloadnode = rc;
  14176. if (reloadcurrent) {
  14177. this.p.treeANode = rc1.rowIndex > 0 ? rc1.rowIndex - 1 : 1;
  14178. $(this).jqGrid('delRowData', id);
  14179. }
  14180. if (this.p.treeGridModel === 'nested') {
  14181. $(this).jqGrid("setGridParam", { postData: { nodeid: id, n_left: rc[lft], n_right: rc[rgt], n_level: rc[level] } });
  14182. } else {
  14183. $(this).jqGrid("setGridParam", { postData: { nodeid: id, parentid: rc[parent], n_level: rc[level] } });
  14184. }
  14185. $(this).trigger("reloadGrid");
  14186. rc[loaded] = true;
  14187. if (this.p.treeGridModel === 'nested') {
  14188. $(this).jqGrid("setGridParam", { selrow: currselection, postData: { nodeid: '', n_left: '', n_right: '', n_level: '' } });
  14189. } else {
  14190. $(this).jqGrid("setGridParam", { selrow: currselection, postData: { nodeid: '', parentid: '', n_level: '' } });
  14191. }
  14192. });
  14193. },
  14194. expandNode: function (rc) {
  14195. return this.each(function () {
  14196. if (!this.grid || !this.p.treeGrid) { return; }
  14197. var expanded = this.p.treeReader.expanded_field,
  14198. parent = this.p.treeReader.parent_id_field,
  14199. loaded = this.p.treeReader.loaded,
  14200. level = this.p.treeReader.level_field,
  14201. lft = this.p.treeReader.left_field,
  14202. rgt = this.p.treeReader.right_field;
  14203. if (!rc[expanded]) {
  14204. var id = $.jgrid.getAccessor(rc, this.p.localReader.id),
  14205. rc1 = $("#" + this.p.idPrefix + $.jgrid.jqID(id), this.grid.bDiv)[0],
  14206. position = this.p._index[id],
  14207. ret = $.isFunction(this.p.beforeExpandTreeGridNode) ? this.p.beforeExpandTreeGridNode.call(this, id, rc) : true;
  14208. if (ret === false) { return; }
  14209. if ($(this).jqGrid("isNodeLoaded", this.p.data[position])) {
  14210. rc[expanded] = true;
  14211. $("div.treeclick", rc1).removeClass(this.p.treeIcons.plus + " tree-plus").addClass(this.p.treeIcons.minus + " tree-minus");
  14212. } else if (!this.grid.hDiv.loading) {
  14213. rc[expanded] = true;
  14214. $("div.treeclick", rc1).removeClass(this.p.treeIcons.plus + " tree-plus").addClass(this.p.treeIcons.minus + " tree-minus");
  14215. this.p.treeANode = rc1.rowIndex;
  14216. this.p.datatype = this.p.treedatatype;
  14217. if (this.p.treeGridModel === 'nested') {
  14218. $(this).jqGrid("setGridParam", { postData: { nodeid: id, n_left: rc[lft], n_right: rc[rgt], n_level: rc[level] } });
  14219. } else {
  14220. $(this).jqGrid("setGridParam", { postData: { nodeid: id, parentid: rc[parent], n_level: rc[level] } });
  14221. }
  14222. $(this).trigger("reloadGrid");
  14223. rc[loaded] = true;
  14224. if (this.p.treeGridModel === 'nested') {
  14225. $(this).jqGrid("setGridParam", { postData: { nodeid: '', n_left: '', n_right: '', n_level: '' } });
  14226. } else {
  14227. $(this).jqGrid("setGridParam", { postData: { nodeid: '', parentid: '', n_level: '' } });
  14228. }
  14229. }
  14230. if ($.isFunction(this.p.afterExpandTreeGridNode)) {
  14231. this.p.afterExpandTreeGridNode.call(this, id, rc);
  14232. }
  14233. }
  14234. });
  14235. },
  14236. collapseNode: function (rc) {
  14237. return this.each(function () {
  14238. if (!this.grid || !this.p.treeGrid) { return; }
  14239. var expanded = this.p.treeReader.expanded_field;
  14240. if (rc[expanded]) {
  14241. var id = $.jgrid.getAccessor(rc, this.p.localReader.id),
  14242. ret = $.isFunction(this.p.beforeCollapseTreeGridNode) ? this.p.beforeCollapseTreeGridNode.call(this, id, rc) : true,
  14243. rc1 = $("#" + this.p.idPrefix + $.jgrid.jqID(id), this.grid.bDiv)[0];
  14244. rc[expanded] = false;
  14245. if (ret === false) { return; }
  14246. $("div.treeclick", rc1).removeClass(this.p.treeIcons.minus + " tree-minus").addClass(this.p.treeIcons.plus + " tree-plus");
  14247. if ($.isFunction(this.p.afterCollapseTreeGridNode)) {
  14248. this.p.afterCollapseTreeGridNode.call(this, id, rc);
  14249. }
  14250. }
  14251. });
  14252. },
  14253. SortTree: function (sortname, newDir, st, datefmt) {
  14254. return this.each(function () {
  14255. if (!this.grid || !this.p.treeGrid) { return; }
  14256. var i, len,
  14257. rec, records = [], $t = this, query, roots,
  14258. rt = $(this).jqGrid("getRootNodes", $t.p.search);
  14259. // Sorting roots
  14260. query = $.jgrid.from.call(this, rt);
  14261. query.orderBy(sortname, newDir, st, datefmt);
  14262. roots = query.select();
  14263. // Sorting children
  14264. for (i = 0, len = roots.length; i < len; i++) {
  14265. rec = roots[i];
  14266. records.push(rec);
  14267. $(this).jqGrid("collectChildrenSortTree", records, rec, sortname, newDir, st, datefmt);
  14268. }
  14269. $.each(records, function (index) {
  14270. var id = $.jgrid.getAccessor(this, $t.p.localReader.id);
  14271. $('#' + $.jgrid.jqID($t.p.id) + ' tbody tr:eq(' + index + ')').after($('tr#' + $.jgrid.jqID(id), $t.grid.bDiv));
  14272. });
  14273. query = null; roots = null; records = null;
  14274. });
  14275. },
  14276. searchTree: function (recs) {
  14277. var i = recs.length || 0, ancestors = [], lid, roots = [], result = [], tid, alen, rlen, j, k;
  14278. this.each(function () {
  14279. if (!this.grid || !this.p.treeGrid) {
  14280. return;
  14281. }
  14282. if (i) {
  14283. lid = this.p.localReader.id;
  14284. while (i--) { // reverse
  14285. ancestors = $(this).jqGrid('getNodeAncestors', recs[i], true, true);
  14286. //add the searched item
  14287. ancestors.push(recs[i]);
  14288. tid = ancestors[0][lid];
  14289. if ($.inArray(tid, roots) !== -1) { // ignore repeated, but add missing
  14290. for (j = 0, alen = ancestors.length; j < alen; j++) {
  14291. //$.inArray ?!?
  14292. var found = false;
  14293. for (k = 0, rlen = result.length; k < rlen; k++) {
  14294. if (ancestors[j][lid] === result[k][lid]) {
  14295. found = true;
  14296. break;
  14297. }
  14298. }
  14299. if (!found) {
  14300. result.push(ancestors[j]);
  14301. }
  14302. }
  14303. continue;
  14304. } else {
  14305. roots.push(tid);
  14306. }
  14307. result = result.concat(ancestors);
  14308. }
  14309. }
  14310. });
  14311. return result;
  14312. },
  14313. collectChildrenSortTree: function (records, rec, sortname, newDir, st, datefmt) {
  14314. return this.each(function () {
  14315. if (!this.grid || !this.p.treeGrid) { return; }
  14316. var i, len,
  14317. child, ch, query, children;
  14318. ch = $(this).jqGrid("getNodeChildren", rec, this.p.search);
  14319. query = $.jgrid.from.call(this, ch);
  14320. query.orderBy(sortname, newDir, st, datefmt);
  14321. children = query.select();
  14322. for (i = 0, len = children.length; i < len; i++) {
  14323. child = children[i];
  14324. records.push(child);
  14325. $(this).jqGrid("collectChildrenSortTree", records, child, sortname, newDir, st, datefmt);
  14326. }
  14327. });
  14328. },
  14329. // experimental
  14330. setTreeRow: function (rowid, data) {
  14331. var success = false;
  14332. this.each(function () {
  14333. var t = this;
  14334. if (!t.grid || !t.p.treeGrid) { return; }
  14335. success = $(t).jqGrid("setRowData", rowid, data);
  14336. });
  14337. return success;
  14338. },
  14339. delTreeNode: function (rowid) {
  14340. return this.each(function () {
  14341. var $t = this, rid = $t.p.localReader.id, i,
  14342. left = $t.p.treeReader.left_field,
  14343. right = $t.p.treeReader.right_field, myright, width, res, key;
  14344. if (!$t.grid || !$t.p.treeGrid) { return; }
  14345. var rc = $t.p._index[rowid];
  14346. if (rc !== undefined) {
  14347. // nested
  14348. myright = parseInt($t.p.data[rc][right], 10);
  14349. width = myright - parseInt($t.p.data[rc][left], 10) + 1;
  14350. var dr = $($t).jqGrid("getFullTreeNode", $t.p.data[rc]);
  14351. if (dr.length > 0) {
  14352. for (i = 0; i < dr.length; i++) {
  14353. $($t).jqGrid("delRowData", dr[i][rid]);
  14354. }
  14355. }
  14356. if ($t.p.treeGridModel === "nested") {
  14357. // ToDo - update grid data
  14358. res = $.jgrid.from.call($t, $t.p.data)
  14359. .greater(left, myright, { stype: 'integer' })
  14360. .select();
  14361. if (res.length) {
  14362. for (key in res) {
  14363. if (res.hasOwnProperty(key)) {
  14364. res[key][left] = parseInt(res[key][left], 10) - width;
  14365. }
  14366. }
  14367. }
  14368. res = $.jgrid.from.call($t, $t.p.data)
  14369. .greater(right, myright, { stype: 'integer' })
  14370. .select();
  14371. if (res.length) {
  14372. for (key in res) {
  14373. if (res.hasOwnProperty(key)) {
  14374. res[key][right] = parseInt(res[key][right], 10) - width;
  14375. }
  14376. }
  14377. }
  14378. }
  14379. }
  14380. });
  14381. },
  14382. delChildren: function (rowid) {
  14383. return this.each(function () {
  14384. var $t = this, rid = $t.p.localReader.id,
  14385. left = $t.p.treeReader.left_field,
  14386. right = $t.p.treeReader.right_field, myright, width, res, key;
  14387. if (!$t.grid || !$t.p.treeGrid) { return; }
  14388. var rc = $t.p._index[rowid];
  14389. if (rc !== undefined) {
  14390. // nested
  14391. myright = parseInt($t.p.data[rc][right], 10);
  14392. width = myright - parseInt($t.p.data[rc][left], 10) + 1;
  14393. var dr = $($t).jqGrid("getFullTreeNode", $t.p.data[rc]);
  14394. if (dr.length > 0) {
  14395. for (var i = 0; i < dr.length; i++) {
  14396. if (dr[i][rid] !== rowid)
  14397. $($t).jqGrid("delRowData", dr[i][rid]);
  14398. }
  14399. }
  14400. if ($t.p.treeGridModel === "nested") {
  14401. // ToDo - update grid data
  14402. res = $.jgrid.from($t.p.data)
  14403. .greater(left, myright, { stype: 'integer' })
  14404. .select();
  14405. if (res.length) {
  14406. for (key in res) {
  14407. if (res.hasOwnProperty(key)) {
  14408. res[key][left] = parseInt(res[key][left], 10) - width;
  14409. }
  14410. }
  14411. }
  14412. res = $.jgrid.from($t.p.data)
  14413. .greater(right, myright, { stype: 'integer' })
  14414. .select();
  14415. if (res.length) {
  14416. for (key in res) {
  14417. if (res.hasOwnProperty(key)) {
  14418. res[key][right] = parseInt(res[key][right], 10) - width;
  14419. }
  14420. }
  14421. }
  14422. }
  14423. }
  14424. });
  14425. },
  14426. addChildNode: function (nodeid, parentid, data, expandData) {
  14427. //return this.each(function(){
  14428. var $t = this[0];
  14429. if (data) {
  14430. // we suppose tha the id is autoincremet and
  14431. var expanded = $t.p.treeReader.expanded_field,
  14432. isLeaf = $t.p.treeReader.leaf_field,
  14433. level = $t.p.treeReader.level_field,
  14434. //icon = $t.p.treeReader.icon_field,
  14435. parent = $t.p.treeReader.parent_id_field,
  14436. left = $t.p.treeReader.left_field,
  14437. right = $t.p.treeReader.right_field,
  14438. loaded = $t.p.treeReader.loaded,
  14439. method, parentindex, parentdata, parentlevel, i, len, max = 0, rowind = parentid, leaf, maxright;
  14440. if (expandData === undefined) { expandData = false; }
  14441. if (nodeid == null) {
  14442. i = $t.p.data.length - 1;
  14443. if (i >= 0) {
  14444. while (i >= 0) { max = Math.max(max, parseInt($t.p.data[i][$t.p.localReader.id], 10)); i--; }
  14445. }
  14446. nodeid = max + 1;
  14447. }
  14448. var prow = $($t).jqGrid('getInd', parentid);
  14449. leaf = false;
  14450. // if not a parent we assume root
  14451. if (parentid === undefined || parentid === null || parentid === "") {
  14452. parentid = null;
  14453. rowind = null;
  14454. method = 'last';
  14455. parentlevel = $t.p.tree_root_level;
  14456. i = $t.p.data.length + 1;
  14457. } else {
  14458. method = 'after';
  14459. parentindex = $t.p._index[parentid];
  14460. parentdata = $t.p.data[parentindex];
  14461. parentid = parentdata[$t.p.localReader.id];
  14462. parentlevel = parseInt(parentdata[level], 10) + 1;
  14463. var childs = $($t).jqGrid('getFullTreeNode', parentdata);
  14464. // if there are child nodes get the last index of it
  14465. if (childs.length) {
  14466. i = childs[childs.length - 1][$t.p.localReader.id];
  14467. rowind = i;
  14468. i = $($t).jqGrid('getInd', rowind) + 1;
  14469. } else {
  14470. i = $($t).jqGrid('getInd', parentid) + 1;
  14471. }
  14472. // if the node is leaf
  14473. if (parentdata[isLeaf]) {
  14474. leaf = true;
  14475. parentdata[expanded] = true;
  14476. //var prow = $($t).jqGrid('getInd', parentid);
  14477. $($t.rows[prow])
  14478. .find("span.cell-wrapperleaf").removeClass("cell-wrapperleaf").addClass("cell-wrapper")
  14479. .end()
  14480. .find("div.tree-leaf").removeClass($t.p.treeIcons.leaf + " tree-leaf").addClass($t.p.treeIcons.minus + " tree-minus");
  14481. $t.p.data[parentindex][isLeaf] = false;
  14482. parentdata[loaded] = true;
  14483. }
  14484. }
  14485. len = i + 1;
  14486. if (data[expanded] === undefined) { data[expanded] = false; }
  14487. if (data[loaded] === undefined) { data[loaded] = false; }
  14488. data[level] = parentlevel;
  14489. if (data[isLeaf] === undefined) { data[isLeaf] = true; }
  14490. if ($t.p.treeGridModel === "adjacency") {
  14491. data[parent] = parentid;
  14492. }
  14493. if ($t.p.treeGridModel === "nested") {
  14494. // this method requiere more attention
  14495. var query, res, key;
  14496. //maxright = parseInt(maxright,10);
  14497. // ToDo - update grid data
  14498. if (parentid !== null) {
  14499. maxright = parseInt(parentdata[right], 10);
  14500. query = $.jgrid.from.call($t, $t.p.data);
  14501. query = query.greaterOrEquals(right, maxright, { stype: 'integer' });
  14502. res = query.select();
  14503. if (res.length) {
  14504. for (key in res) {
  14505. if (res.hasOwnProperty(key)) {
  14506. res[key][left] = res[key][left] > maxright ? parseInt(res[key][left], 10) + 2 : res[key][left];
  14507. res[key][right] = res[key][right] >= maxright ? parseInt(res[key][right], 10) + 2 : res[key][right];
  14508. }
  14509. }
  14510. }
  14511. data[left] = maxright;
  14512. data[right] = maxright + 1;
  14513. } else {
  14514. maxright = parseInt($($t).jqGrid('getCol', right, false, 'max'), 10);
  14515. res = $.jgrid.from.call($t, $t.p.data)
  14516. .greater(left, maxright, { stype: 'integer' })
  14517. .select();
  14518. if (res.length) {
  14519. for (key in res) {
  14520. if (res.hasOwnProperty(key)) {
  14521. res[key][left] = parseInt(res[key][left], 10) + 2;
  14522. }
  14523. }
  14524. }
  14525. res = $.jgrid.from.call($t, $t.p.data)
  14526. .greater(right, maxright, { stype: 'integer' })
  14527. .select();
  14528. if (res.length) {
  14529. for (key in res) {
  14530. if (res.hasOwnProperty(key)) {
  14531. res[key][right] = parseInt(res[key][right], 10) + 2;
  14532. }
  14533. }
  14534. }
  14535. data[left] = maxright + 1;
  14536. data[right] = maxright + 2;
  14537. }
  14538. }
  14539. if (parentid === null || $($t).jqGrid("isNodeLoaded", parentdata) || leaf) {
  14540. $($t).jqGrid('addRowData', nodeid, data, method, rowind);
  14541. $($t).jqGrid('setTreeNode', i, len);
  14542. }
  14543. if (parentdata && !parentdata[expanded] && expandData) {
  14544. $($t.rows[prow])
  14545. .find("div.treeclick")
  14546. .click();
  14547. }
  14548. }
  14549. //});
  14550. }
  14551. });
  14552. //module begin
  14553. $.fn.jqDrag = function (h) { return i(this, h, 'd'); };
  14554. $.fn.jqResize = function (h, ar) { return i(this, h, 'r', ar); };
  14555. $.jqDnR = {
  14556. dnr: {},
  14557. e: 0,
  14558. drag: function (v) {
  14559. if (M.k == 'd') { E.css({ left: M.X + v.pageX - M.pX, top: M.Y + v.pageY - M.pY }); }
  14560. else {
  14561. E.css({ width: Math.max(v.pageX - M.pX + M.W, 0), height: Math.max(v.pageY - M.pY + M.H, 0) });
  14562. if (M1) { E1.css({ width: Math.max(v.pageX - M1.pX + M1.W, 0), height: Math.max(v.pageY - M1.pY + M1.H, 0) }); }
  14563. }
  14564. return false;
  14565. },
  14566. stop: function () {
  14567. //E.css('opacity',M.o);
  14568. $(document).unbind('mousemove', J.drag).unbind('mouseup', J.stop);
  14569. }
  14570. };
  14571. var J = $.jqDnR, M = J.dnr, E = J.e, E1, M1,
  14572. i = function (e, h, k, aR) {
  14573. return e.each(function () {
  14574. h = (h) ? $(h, e) : e;
  14575. h.bind('mousedown', { e: e, k: k }, function (v) {
  14576. var d = v.data, p = {}; E = d.e; E1 = aR ? $(aR) : false;
  14577. // attempt utilization of dimensions plugin to fix IE issues
  14578. if (E.css('position') != 'relative') { try { E.position(p); } catch (e) { } }
  14579. M = {
  14580. X: p.left || f('left') || 0,
  14581. Y: p.top || f('top') || 0,
  14582. W: f('width') || E[0].scrollWidth || 0,
  14583. H: f('height') || E[0].scrollHeight || 0,
  14584. pX: v.pageX,
  14585. pY: v.pageY,
  14586. k: d.k
  14587. //o:E.css('opacity')
  14588. };
  14589. // also resize
  14590. if (E1 && d.k != 'd') {
  14591. M1 = {
  14592. X: p.left || f1('left') || 0,
  14593. Y: p.top || f1('top') || 0,
  14594. W: E1[0].offsetWidth || f1('width') || 0,
  14595. H: E1[0].offsetHeight || f1('height') || 0,
  14596. pX: v.pageX,
  14597. pY: v.pageY,
  14598. k: d.k
  14599. };
  14600. } else { M1 = false; }
  14601. //E.css({opacity:0.8});
  14602. if ($("input.hasDatepicker", E[0])[0]) {
  14603. try { $("input.hasDatepicker", E[0]).datepicker('hide'); } catch (dpe) { }
  14604. }
  14605. $(document).mousemove($.jqDnR.drag).mouseup($.jqDnR.stop);
  14606. return false;
  14607. });
  14608. });
  14609. },
  14610. f = function (k) { return parseInt(E.css(k), 10) || false; },
  14611. f1 = function (k) { return parseInt(E1.css(k), 10) || false; };
  14612. /*
  14613. jQuery tinyDraggable v1.0.2
  14614. Copyright (c) 2014 Simon Steinberger / Pixabay
  14615. GitHub: https://github.com/Pixabay/jQuery-tinyDraggable
  14616. More info: https://pixabay.com/blog/posts/p-52/
  14617. License: http://www.opensource.org/licenses/mit-license.php
  14618. */
  14619. $.fn.tinyDraggable = function (options) {
  14620. var settings = $.extend({ handle: 0, exclude: 0 }, options);
  14621. return this.each(function () {
  14622. var dx, dy, el = $(this), handle = settings.handle ? $(settings.handle, el) : el;
  14623. handle.on({
  14624. mousedown: function (e) {
  14625. if (settings.exclude && ~$.inArray(e.target, $(settings.exclude, el))) { return; }
  14626. e.preventDefault();
  14627. var os = el.offset(); dx = e.pageX - os.left, dy = e.pageY - os.top;
  14628. $(document).on('mousemove.drag', function (e) { el.offset({ top: e.pageY - dy, left: e.pageX - dx }); });
  14629. },
  14630. mouseup: function (e) { $(document).off('mousemove.drag'); }
  14631. });
  14632. });
  14633. };
  14634. //module begin
  14635. $.fn.jqm = function (o) {
  14636. var p = {
  14637. overlay: 50,
  14638. closeoverlay: true,
  14639. overlayClass: 'jqmOverlay',
  14640. closeClass: 'jqmClose',
  14641. trigger: '.jqModal',
  14642. ajax: F,
  14643. ajaxText: '',
  14644. target: F,
  14645. modal: F,
  14646. toTop: F,
  14647. onShow: F,
  14648. onHide: F,
  14649. onLoad: F
  14650. };
  14651. return this.each(function () {
  14652. if (this._jqm) { return H[this._jqm].c = $.extend({}, H[this._jqm].c, o); } s++; this._jqm = s;
  14653. H[s] = { c: $.extend(p, $.jqm.params, o), a: F, w: $(this).addClass('jqmID' + s), s: s };
  14654. if (p.trigger) { $(this).jqmAddTrigger(p.trigger); }
  14655. });
  14656. };
  14657. $.fn.jqmAddClose = function (e) { return hs(this, e, 'jqmHide'); };
  14658. $.fn.jqmAddTrigger = function (e) { return hs(this, e, 'jqmShow'); };
  14659. $.fn.jqmShow = function (t) { return this.each(function () { $.jqm.open(this._jqm, t); }); };
  14660. $.fn.jqmHide = function (t) { return this.each(function () { $.jqm.close(this._jqm, t); }); };
  14661. $.jqm = {
  14662. hash: {},
  14663. open: function (s, t) {
  14664. var h = H[s], c = h.c, cc = '.' + c.closeClass, z = (parseInt(h.w.css('z-index'))); z = (z > 0) ? z : 3000; var o = $('<div></div>').css({ height: '100%', width: '100%', position: 'fixed', left: 0, top: 0, 'z-index': z - 1, opacity: c.overlay / 100 }); if (h.a) { return F; } h.t = t; h.a = true; h.w.css('z-index', z);
  14665. if (c.modal) { if (!A[0]) { setTimeout(function () { new L('bind'); }, 1); } A.push(s); }
  14666. else if (c.overlay > 0) { if (c.closeoverlay) { h.w.jqmAddClose(o); } }
  14667. else { o = F; }
  14668. h.o = (o) ? o.addClass(c.overlayClass).prependTo('body') : F;
  14669. if (c.ajax) {
  14670. var r = c.target || h.w, u = c.ajax; r = (typeof r === 'string') ? $(r, h.w) : $(r); u = (u.substr(0, 1) === '@') ? $(t).attr(u.substring(1)) : u;
  14671. r.html(c.ajaxText).load(u, function () { if (c.onLoad) { c.onLoad.call(this, h); } if (cc) { h.w.jqmAddClose($(cc, h.w)); } e(h); });
  14672. }
  14673. else if (cc) { h.w.jqmAddClose($(cc, h.w)); }
  14674. if (c.toTop && h.o) { h.w.before('<span id="jqmP' + h.w[0]._jqm + '"></span>').insertAfter(h.o); }
  14675. (c.onShow) ? c.onShow(h) : h.w.show(); e(h); return F;
  14676. },
  14677. close: function (s) {
  14678. var h = H[s]; if (!h.a) { return F; } h.a = F;
  14679. if (A[0]) { A.pop(); if (!A[0]) { new L('unbind'); } }
  14680. if (h.c.toTop && h.o) { $('#jqmP' + h.w[0]._jqm).after(h.w).remove(); }
  14681. if (h.c.onHide) { h.c.onHide(h); } else { h.w.hide(); if (h.o) { h.o.remove(); } } return F;
  14682. },
  14683. params: {}
  14684. };
  14685. var s = 0, H = $.jqm.hash, A = [], F = false,
  14686. e = function (h) { if (h.c.focusField === undefined) { h.c.focusField = 0; } if (h.c.focusField >= 0) { f(h); } },
  14687. f = function (h) { try { $(':input:visible', h.w)[parseInt(h.c.focusField, 10)].focus(); } catch (_) { } },
  14688. L = function (t) { $(document)[t]("keypress", m)[t]("keydown", m)[t]("mousedown", m); },
  14689. m = function (e) { var h = H[A[A.length - 1]], r = (!$(e.target).parents('.jqmID' + h.s)[0]); if (r) { $('.jqmID' + h.s).each(function () { var $self = $(this), offset = $self.offset(); if (offset.top <= e.pageY && e.pageY <= offset.top + $self.height() && offset.left <= e.pageX && e.pageX <= offset.left + $self.width()) { r = false; return false; } }); f(h); } return !r; },
  14690. hs = function (w, t, c) {
  14691. return w.each(function () {
  14692. var s = this._jqm; $(t).each(function () {
  14693. if (!this[c]) { this[c] = []; $(this).click(function () { for (var i in { jqmShow: 1, jqmHide: 1 }) { for (var s in this[i]) { if (H[this[i][s]]) { H[this[i][s]].w[i](this); } } } return F; }); }
  14694. this[c].push(s);
  14695. });
  14696. });
  14697. };
  14698. //module begin
  14699. $.fmatter = {};
  14700. //opts can be id:row id for the row, rowdata:the data for the row, colmodel:the column model for this column
  14701. //example {id:1234,}
  14702. $.extend($.fmatter, {
  14703. isBoolean: function (o) {
  14704. return typeof o === 'boolean';
  14705. },
  14706. isObject: function (o) {
  14707. return (o && (typeof o === 'object' || $.isFunction(o))) || false;
  14708. },
  14709. isString: function (o) {
  14710. return typeof o === 'string';
  14711. },
  14712. isNumber: function (o) {
  14713. return typeof o === 'number' && isFinite(o);
  14714. },
  14715. isValue: function (o) {
  14716. return (this.isObject(o) || this.isString(o) || this.isNumber(o) || this.isBoolean(o));
  14717. },
  14718. isEmpty: function (o) {
  14719. if (!this.isString(o) && this.isValue(o)) {
  14720. return false;
  14721. }
  14722. if (!this.isValue(o)) {
  14723. return true;
  14724. }
  14725. o = $.trim(o).replace(/\&nbsp\;/ig, '').replace(/\&#160\;/ig, '');
  14726. return o === "";
  14727. }
  14728. });
  14729. $.fn.fmatter = function (formatType, cellval, opts, rwd, act) {
  14730. // build main options before element iteration
  14731. var v = cellval;
  14732. opts = $.extend({}, $.jgrid.getRegional(this, 'formatter'), opts);
  14733. try {
  14734. v = $.fn.fmatter[formatType].call(this, cellval, opts, rwd, act);
  14735. } catch (fe) { }
  14736. return v;
  14737. };
  14738. $.fmatter.util = {
  14739. // Taken from YAHOO utils
  14740. NumberFormat: function (nData, opts) {
  14741. if (!$.fmatter.isNumber(nData)) {
  14742. nData *= 1;
  14743. }
  14744. if ($.fmatter.isNumber(nData)) {
  14745. var bNegative = (nData < 0);
  14746. var sOutput = String(nData);
  14747. var sDecimalSeparator = opts.decimalSeparator || ".";
  14748. var nDotIndex;
  14749. if ($.fmatter.isNumber(opts.decimalPlaces)) {
  14750. // Round to the correct decimal place
  14751. var nDecimalPlaces = opts.decimalPlaces;
  14752. var nDecimal = Math.pow(10, nDecimalPlaces);
  14753. sOutput = String(Math.round(nData * nDecimal) / nDecimal);
  14754. nDotIndex = sOutput.lastIndexOf(".");
  14755. if (nDecimalPlaces > 0) {
  14756. // Add the decimal separator
  14757. if (nDotIndex < 0) {
  14758. sOutput += sDecimalSeparator;
  14759. nDotIndex = sOutput.length - 1;
  14760. }
  14761. // Replace the "."
  14762. else if (sDecimalSeparator !== ".") {
  14763. sOutput = sOutput.replace(".", sDecimalSeparator);
  14764. }
  14765. // Add missing zeros
  14766. while ((sOutput.length - 1 - nDotIndex) < nDecimalPlaces) {
  14767. sOutput += "0";
  14768. }
  14769. }
  14770. }
  14771. if (opts.thousandsSeparator) {
  14772. var sThousandsSeparator = opts.thousandsSeparator;
  14773. nDotIndex = sOutput.lastIndexOf(sDecimalSeparator);
  14774. nDotIndex = (nDotIndex > -1) ? nDotIndex : sOutput.length;
  14775. var sNewOutput = sOutput.substring(nDotIndex);
  14776. var nCount = -1, i;
  14777. for (i = nDotIndex; i > 0; i--) {
  14778. nCount++;
  14779. if ((nCount % 3 === 0) && (i !== nDotIndex) && (!bNegative || (i > 1))) {
  14780. sNewOutput = sThousandsSeparator + sNewOutput;
  14781. }
  14782. sNewOutput = sOutput.charAt(i - 1) + sNewOutput;
  14783. }
  14784. sOutput = sNewOutput;
  14785. }
  14786. // Prepend prefix
  14787. sOutput = (opts.prefix) ? opts.prefix + sOutput : sOutput;
  14788. // Append suffix
  14789. sOutput = (opts.suffix) ? sOutput + opts.suffix : sOutput;
  14790. return sOutput;
  14791. }
  14792. return nData;
  14793. }
  14794. };
  14795. $.fn.fmatter.defaultFormat = function (cellval, opts) {
  14796. return ($.fmatter.isValue(cellval) && cellval !== "") ? cellval : opts.defaultValue || "&#160;";
  14797. };
  14798. $.fn.fmatter.email = function (cellval, opts) {
  14799. if (!$.fmatter.isEmpty(cellval)) {
  14800. return "<a href=\"mailto:" + cellval + "\">" + cellval + "</a>";
  14801. }
  14802. return $.fn.fmatter.defaultFormat(cellval, opts);
  14803. };
  14804. $.fn.fmatter.checkbox = function (cval, opts) {
  14805. var op = $.extend({}, opts.checkbox), ds;
  14806. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14807. op = $.extend({}, op, opts.colModel.formatoptions);
  14808. }
  14809. if (op.disabled === true) { ds = "disabled=\"disabled\""; } else { ds = ""; }
  14810. if ($.fmatter.isEmpty(cval) || cval === undefined) { cval = $.fn.fmatter.defaultFormat(cval, op); }
  14811. cval = String(cval);
  14812. cval = (cval + "").toLowerCase();
  14813. var bchk = cval.search(/(false|f|0|no|n|off|undefined)/i) < 0 ? " checked='checked' " : "";
  14814. return "<input type=\"checkbox\" " + bchk + " value=\"" + cval + "\" offval=\"no\" " + ds + "/>";
  14815. };
  14816. $.fn.fmatter.link = function (cellval, opts) {
  14817. var op = { target: opts.target };
  14818. var target = "";
  14819. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14820. op = $.extend({}, op, opts.colModel.formatoptions);
  14821. }
  14822. if (op.target) { target = 'target=' + op.target; }
  14823. if (!$.fmatter.isEmpty(cellval)) {
  14824. return "<a " + target + " href=\"" + cellval + "\">" + cellval + "</a>";
  14825. }
  14826. return $.fn.fmatter.defaultFormat(cellval, opts);
  14827. };
  14828. $.fn.fmatter.showlink = function (cellval, opts) {
  14829. var op = { baseLinkUrl: opts.baseLinkUrl, showAction: opts.showAction, addParam: opts.addParam || "", target: opts.target, idName: opts.idName },
  14830. target = "", idUrl;
  14831. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14832. op = $.extend({}, op, opts.colModel.formatoptions);
  14833. }
  14834. if (op.target) { target = 'target=' + op.target; }
  14835. idUrl = op.baseLinkUrl + op.showAction + '?' + op.idName + '=' + opts.rowId + op.addParam;
  14836. if ($.fmatter.isString(cellval) || $.fmatter.isNumber(cellval)) { //add this one even if its blank string
  14837. return "<a " + target + " href=\"" + idUrl + "\">" + cellval + "</a>";
  14838. }
  14839. return $.fn.fmatter.defaultFormat(cellval, opts);
  14840. };
  14841. $.fn.fmatter.integer = function (cellval, opts) {
  14842. var op = $.extend({}, opts.integer);
  14843. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14844. op = $.extend({}, op, opts.colModel.formatoptions);
  14845. }
  14846. if ($.fmatter.isEmpty(cellval)) {
  14847. return op.defaultValue;
  14848. }
  14849. return $.fmatter.util.NumberFormat(cellval, op);
  14850. };
  14851. $.fn.fmatter.number = function (cellval, opts) {
  14852. var op = $.extend({}, opts.number);
  14853. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14854. op = $.extend({}, op, opts.colModel.formatoptions);
  14855. }
  14856. if ($.fmatter.isEmpty(cellval)) {
  14857. return op.defaultValue;
  14858. }
  14859. return $.fmatter.util.NumberFormat(cellval, op);
  14860. };
  14861. $.fn.fmatter.currency = function (cellval, opts) {
  14862. var op = $.extend({}, opts.currency);
  14863. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14864. op = $.extend({}, op, opts.colModel.formatoptions);
  14865. }
  14866. if ($.fmatter.isEmpty(cellval)) {
  14867. return op.defaultValue;
  14868. }
  14869. return $.fmatter.util.NumberFormat(cellval, op);
  14870. };
  14871. $.fn.fmatter.date = function (cellval, opts, rwd, act) {
  14872. var op = $.extend({}, opts.date);
  14873. if (opts.colModel !== undefined && opts.colModel.formatoptions !== undefined) {
  14874. op = $.extend({}, op, opts.colModel.formatoptions);
  14875. }
  14876. if (!op.reformatAfterEdit && act === 'edit') {
  14877. return $.fn.fmatter.defaultFormat(cellval, opts);
  14878. }
  14879. if (!$.fmatter.isEmpty(cellval)) {
  14880. return $.jgrid.parseDate.call(this, op.srcformat, cellval, op.newformat, op);
  14881. }
  14882. return $.fn.fmatter.defaultFormat(cellval, opts);
  14883. };
  14884. $.fn.fmatter.select = function (cellval, opts) {
  14885. // jqGrid specific
  14886. cellval = String(cellval);
  14887. var oSelect = false, ret = [], sep, delim;
  14888. if (opts.colModel.formatoptions !== undefined) {
  14889. oSelect = opts.colModel.formatoptions.value;
  14890. sep = opts.colModel.formatoptions.separator === undefined ? ":" : opts.colModel.formatoptions.separator;
  14891. delim = opts.colModel.formatoptions.delimiter === undefined ? ";" : opts.colModel.formatoptions.delimiter;
  14892. } else if (opts.colModel.editoptions !== undefined) {
  14893. oSelect = opts.colModel.editoptions.value;
  14894. sep = opts.colModel.editoptions.separator === undefined ? ":" : opts.colModel.editoptions.separator;
  14895. delim = opts.colModel.editoptions.delimiter === undefined ? ";" : opts.colModel.editoptions.delimiter;
  14896. }
  14897. if (oSelect) {
  14898. var msl = (opts.colModel.editoptions != null && opts.colModel.editoptions.multiple === true) === true ? true : false,
  14899. scell = [], sv;
  14900. if (msl) { scell = cellval.split(","); scell = $.map(scell, function (n) { return $.trim(n); }); }
  14901. if ($.fmatter.isString(oSelect)) {
  14902. // mybe here we can use some caching with care ????
  14903. var so = oSelect.split(delim), j = 0, i;
  14904. for (i = 0; i < so.length; i++) {
  14905. sv = so[i].split(sep);
  14906. if (sv.length > 2) {
  14907. sv[1] = $.map(sv, function (n, i) { if (i > 0) { return n; } }).join(sep);
  14908. }
  14909. if (msl) {
  14910. if ($.inArray(sv[0], scell) > -1) {
  14911. ret[j] = sv[1];
  14912. j++;
  14913. }
  14914. } else if ($.trim(sv[0]) === $.trim(cellval)) {
  14915. ret[0] = sv[1];
  14916. break;
  14917. }
  14918. }
  14919. } else if ($.fmatter.isObject(oSelect)) {
  14920. // this is quicker
  14921. if (msl) {
  14922. ret = $.map(scell, function (n) {
  14923. return oSelect[n];
  14924. });
  14925. } else {
  14926. ret[0] = oSelect[cellval] || "";
  14927. }
  14928. }
  14929. }
  14930. cellval = ret.join(", ");
  14931. return cellval === "" ? $.fn.fmatter.defaultFormat(cellval, opts) : cellval;
  14932. };
  14933. $.fn.fmatter.rowactions = function (act) {
  14934. var $tr = $(this).closest("tr.jqgrow"),
  14935. rid = $tr.attr("id"),
  14936. $id = $(this).closest("table.ui-jqgrid-btable").attr('id').replace(/_frozen([^_]*)$/, '$1'),
  14937. $grid = $("#" + $id),
  14938. $t = $grid[0],
  14939. p = $t.p,
  14940. cm = p.colModel[$.jgrid.getCellIndex(this)],
  14941. $actionsDiv = cm.frozen ? $("tr#" + rid + " td:eq(" + $.jgrid.getCellIndex(this) + ") > div", $grid) : $(this).parent(),
  14942. op = {
  14943. extraparam: {}
  14944. },
  14945. saverow = function (rowid, res) {
  14946. if ($.isFunction(op.afterSave)) { op.afterSave.call($t, rowid, res); }
  14947. $actionsDiv.find("div.ui-inline-edit,div.ui-inline-del").show();
  14948. $actionsDiv.find("div.ui-inline-save,div.ui-inline-cancel").hide();
  14949. },
  14950. restorerow = function (rowid) {
  14951. if ($.isFunction(op.afterRestore)) { op.afterRestore.call($t, rowid); }
  14952. $actionsDiv.find("div.ui-inline-edit,div.ui-inline-del").show();
  14953. $actionsDiv.find("div.ui-inline-save,div.ui-inline-cancel").hide();
  14954. };
  14955. if (cm.formatoptions !== undefined) {
  14956. op = $.extend(op, cm.formatoptions);
  14957. }
  14958. if (p.editOptions !== undefined) {
  14959. op.editOptions = p.editOptions;
  14960. }
  14961. if (p.delOptions !== undefined) {
  14962. op.delOptions = p.delOptions;
  14963. }
  14964. if ($tr.hasClass("jqgrid-new-row")) {
  14965. op.extraparam[p.prmNames.oper] = p.prmNames.addoper;
  14966. }
  14967. var actop = {
  14968. keys: op.keys,
  14969. oneditfunc: op.onEdit,
  14970. successfunc: op.onSuccess,
  14971. url: op.url,
  14972. extraparam: op.extraparam,
  14973. aftersavefunc: saverow,
  14974. errorfunc: op.onError,
  14975. afterrestorefunc: restorerow,
  14976. restoreAfterError: op.restoreAfterError,
  14977. mtype: op.mtype
  14978. };
  14979. switch (act) {
  14980. case 'edit':
  14981. $grid.jqGrid('editRow', rid, actop);
  14982. $actionsDiv.find("div.ui-inline-edit,div.ui-inline-del").hide();
  14983. $actionsDiv.find("div.ui-inline-save,div.ui-inline-cancel").show();
  14984. $grid.triggerHandler("jqGridAfterGridComplete");
  14985. break;
  14986. case 'save':
  14987. if ($grid.jqGrid('saveRow', rid, actop)) {
  14988. $actionsDiv.find("div.ui-inline-edit,div.ui-inline-del").show();
  14989. $actionsDiv.find("div.ui-inline-save,div.ui-inline-cancel").hide();
  14990. $grid.triggerHandler("jqGridAfterGridComplete");
  14991. }
  14992. break;
  14993. case 'cancel':
  14994. $grid.jqGrid('restoreRow', rid, restorerow);
  14995. $actionsDiv.find("div.ui-inline-edit,div.ui-inline-del").show();
  14996. $actionsDiv.find("div.ui-inline-save,div.ui-inline-cancel").hide();
  14997. $grid.triggerHandler("jqGridAfterGridComplete");
  14998. break;
  14999. case 'del':
  15000. $grid.jqGrid('delGridRow', rid, op.delOptions);
  15001. break;
  15002. case 'formedit':
  15003. $grid.jqGrid('setSelection', rid);
  15004. $grid.jqGrid('editGridRow', rid, op.editOptions);
  15005. break;
  15006. }
  15007. };
  15008. $.fn.fmatter.actions = function (cellval, opts) {
  15009. var op = { keys: false, editbutton: true, delbutton: true, editformbutton: false },
  15010. rowid = opts.rowId, str = "", ocl,
  15011. nav = $.jgrid.getRegional(this, 'nav'),
  15012. classes = $.jgrid.styleUI[(opts.styleUI || 'jQueryUI')].fmatter,
  15013. common = $.jgrid.styleUI[(opts.styleUI || 'jQueryUI')].common;
  15014. if (opts.colModel.formatoptions !== undefined) {
  15015. op = $.extend(op, opts.colModel.formatoptions);
  15016. }
  15017. if (rowid === undefined || $.fmatter.isEmpty(rowid)) { return ""; }
  15018. var hover = "onmouseover=jQuery(this).addClass('" + common.hover + "'); onmouseout=jQuery(this).removeClass('" + common.hover + "'); ";
  15019. if (op.editformbutton) {
  15020. ocl = "id='jEditButton_" + rowid + "' onclick=jQuery.fn.fmatter.rowactions.call(this,'formedit'); " + hover;
  15021. str += "<div title='" + nav.edittitle + "' style='float:left;cursor:pointer;' class='ui-pg-div ui-inline-edit' " + ocl + "><span class='" + common.icon_base + " " + classes.icon_edit + "'></span></div>";
  15022. } else if (op.editbutton) {
  15023. ocl = "id='jEditButton_" + rowid + "' onclick=jQuery.fn.fmatter.rowactions.call(this,'edit'); " + hover;
  15024. str += "<div title='" + nav.edittitle + "' style='float:left;cursor:pointer;' class='ui-pg-div ui-inline-edit' " + ocl + "><span class='" + common.icon_base + " " + classes.icon_edit + "'></span></div>";
  15025. }
  15026. if (op.delbutton) {
  15027. ocl = "id='jDeleteButton_" + rowid + "' onclick=jQuery.fn.fmatter.rowactions.call(this,'del'); " + hover;
  15028. str += "<div title='" + nav.deltitle + "' style='float:left;' class='ui-pg-div ui-inline-del' " + ocl + "><span class='" + common.icon_base + " " + classes.icon_del + "'></span></div>";
  15029. }
  15030. ocl = "id='jSaveButton_" + rowid + "' onclick=jQuery.fn.fmatter.rowactions.call(this,'save'); " + hover;
  15031. str += "<div title='" + nav.savetitle + "' style='float:left;display:none' class='ui-pg-div ui-inline-save' " + ocl + "><span class='" + common.icon_base + " " + classes.icon_save + "'></span></div>";
  15032. ocl = "id='jCancelButton_" + rowid + "' onclick=jQuery.fn.fmatter.rowactions.call(this,'cancel'); " + hover;
  15033. str += "<div title='" + nav.canceltitle + "' style='float:left;display:none;' class='ui-pg-div ui-inline-cancel' " + ocl + "><span class='" + common.icon_base + " " + classes.icon_cancel + "'></span></div>";
  15034. return "<div style='margin-left:8px;'>" + str + "</div>";
  15035. };
  15036. $.unformat = function (cellval, options, pos, cnt) {
  15037. // specific for jqGrid only
  15038. var ret, formatType = options.colModel.formatter,
  15039. op = options.colModel.formatoptions || {}, sep,
  15040. re = /([\.\*\_\'\(\)\{\}\+\?\\])/g,
  15041. unformatFunc = options.colModel.unformat || ($.fn.fmatter[formatType] && $.fn.fmatter[formatType].unformat);
  15042. if (unformatFunc !== undefined && $.isFunction(unformatFunc)) {
  15043. ret = unformatFunc.call(this, $(cellval).text(), options, cellval);
  15044. } else if (formatType !== undefined && $.fmatter.isString(formatType)) {
  15045. var opts = $.jgrid.getRegional(this, 'formatter') || {}, stripTag;
  15046. switch (formatType) {
  15047. case 'integer':
  15048. op = $.extend({}, opts.integer, op);
  15049. sep = op.thousandsSeparator.replace(re, "\\$1");
  15050. stripTag = new RegExp(sep, "g");
  15051. ret = $(cellval).text().replace(stripTag, '');
  15052. break;
  15053. case 'number':
  15054. op = $.extend({}, opts.number, op);
  15055. sep = op.thousandsSeparator.replace(re, "\\$1");
  15056. stripTag = new RegExp(sep, "g");
  15057. ret = $(cellval).text().replace(stripTag, "").replace(op.decimalSeparator, '.');
  15058. break;
  15059. case 'currency':
  15060. op = $.extend({}, opts.currency, op);
  15061. sep = op.thousandsSeparator.replace(re, "\\$1");
  15062. stripTag = new RegExp(sep, "g");
  15063. ret = $(cellval).text();
  15064. if (op.prefix && op.prefix.length) {
  15065. ret = ret.substr(op.prefix.length);
  15066. }
  15067. if (op.suffix && op.suffix.length) {
  15068. ret = ret.substr(0, ret.length - op.suffix.length);
  15069. }
  15070. ret = ret.replace(stripTag, '').replace(op.decimalSeparator, '.');
  15071. break;
  15072. case 'checkbox':
  15073. var cbv = (options.colModel.editoptions) ? options.colModel.editoptions.value.split(":") : ["Yes", "No"];
  15074. ret = $('input', cellval).is(":checked") ? cbv[0] : cbv[1];
  15075. break;
  15076. case 'select':
  15077. ret = $.unformat.select(cellval, options, pos, cnt);
  15078. break;
  15079. case 'actions':
  15080. return "";
  15081. default:
  15082. ret = $(cellval).text();
  15083. }
  15084. }
  15085. return ret !== undefined ? ret : cnt === true ? $(cellval).text() : $.jgrid.htmlDecode($(cellval).html());
  15086. };
  15087. $.unformat.select = function (cellval, options, pos, cnt) {
  15088. // Spacial case when we have local data and perform a sort
  15089. // cnt is set to true only in sortDataArray
  15090. var ret = [];
  15091. var cell = $(cellval).text();
  15092. if (cnt === true) { return cell; }
  15093. var op = $.extend({}, options.colModel.formatoptions !== undefined ? options.colModel.formatoptions : options.colModel.editoptions),
  15094. sep = op.separator === undefined ? ":" : op.separator,
  15095. delim = op.delimiter === undefined ? ";" : op.delimiter;
  15096. if (op.value) {
  15097. var oSelect = op.value,
  15098. msl = op.multiple === true ? true : false,
  15099. scell = [], sv;
  15100. if (msl) { scell = cell.split(","); scell = $.map(scell, function (n) { return $.trim(n); }); }
  15101. if ($.fmatter.isString(oSelect)) {
  15102. var so = oSelect.split(delim), j = 0, i;
  15103. for (i = 0; i < so.length; i++) {
  15104. sv = so[i].split(sep);
  15105. if (sv.length > 2) {
  15106. sv[1] = $.map(sv, function (n, i) { if (i > 0) { return n; } }).join(sep);
  15107. }
  15108. if (msl) {
  15109. if ($.inArray($.trim(sv[1]), scell) > -1) {
  15110. ret[j] = sv[0];
  15111. j++;
  15112. }
  15113. } else if ($.trim(sv[1]) === $.trim(cell)) {
  15114. ret[0] = sv[0];
  15115. break;
  15116. }
  15117. }
  15118. } else if ($.fmatter.isObject(oSelect) || $.isArray(oSelect)) {
  15119. if (!msl) { scell[0] = cell; }
  15120. ret = $.map(scell, function (n) {
  15121. var rv;
  15122. $.each(oSelect, function (i, val) {
  15123. if (val === n) {
  15124. rv = i;
  15125. return false;
  15126. }
  15127. });
  15128. if (rv !== undefined) { return rv; }
  15129. });
  15130. }
  15131. return ret.join(", ");
  15132. }
  15133. return cell || "";
  15134. };
  15135. $.unformat.date = function (cellval, opts) {
  15136. var op = $.jgrid.getRegional(this, 'formatter.date') || {};
  15137. if (opts.formatoptions !== undefined) {
  15138. op = $.extend({}, op, opts.formatoptions);
  15139. }
  15140. if (!$.fmatter.isEmpty(cellval)) {
  15141. return $.jgrid.parseDate.call(this, op.newformat, cellval, op.srcformat, op);
  15142. }
  15143. return $.fn.fmatter.defaultFormat(cellval, opts);
  15144. };
  15145. //module begin
  15146. var dragging, placeholders = $();
  15147. $.fn.html5sortable = function (options) {
  15148. var method = String(options);
  15149. options = $.extend({
  15150. connectWith: false
  15151. }, options);
  15152. return this.each(function () {
  15153. if (/^enable|disable|destroy$/.test(method)) {
  15154. var items = $(this).children($(this).data('items')).attr('draggable', method === 'enable');
  15155. if (method === 'destroy') {
  15156. items.add(this).removeData('connectWith items')
  15157. .off('dragstart.h5s dragend.h5s selectstart.h5s dragover.h5s dragenter.h5s drop.h5s');
  15158. }
  15159. return;
  15160. }
  15161. var isHandle, index, items = $(this).children(options.items);
  15162. var placeholder = $('<' + (/^ul|ol$/i.test(this.tagName) ? 'li' : /^tbody$/i.test(this.tagName) ? 'tr' : 'div')
  15163. + ' class="sortable-placeholder ' + options.placeholderClass + '">').html('&nbsp;');
  15164. items.find(options.handle).mousedown(function () {
  15165. isHandle = true;
  15166. }).mouseup(function () {
  15167. isHandle = false;
  15168. });
  15169. $(this).data('items', options.items);
  15170. placeholders = placeholders.add(placeholder);
  15171. if (options.connectWith) {
  15172. $(options.connectWith).add(this).data('connectWith', options.connectWith);
  15173. }
  15174. items.attr('draggable', 'true').on('dragstart.h5s', function (e) {
  15175. if (options.handle && !isHandle) {
  15176. return false;
  15177. }
  15178. isHandle = false;
  15179. var dt = e.originalEvent.dataTransfer;
  15180. dt.effectAllowed = 'move';
  15181. dt.setData('Text', 'dummy');
  15182. index = (dragging = $(this)).addClass('sortable-dragging').index();
  15183. }).on('dragend.h5s', function () {
  15184. if (!dragging) {
  15185. return;
  15186. }
  15187. dragging.removeClass('sortable-dragging').show();
  15188. placeholders.detach();
  15189. if (index !== dragging.index()) {
  15190. dragging.parent().trigger('sortupdate', { item: dragging, startindex: index, endindex: dragging.index() });
  15191. }
  15192. dragging = null;
  15193. }).not('a[href], img').on('selectstart.h5s', function () {
  15194. this.dragDrop && this.dragDrop();
  15195. return false;
  15196. }).end().add([this, placeholder]).on('dragover.h5s dragenter.h5s drop.h5s', function (e) {
  15197. if (!items.is(dragging) && options.connectWith !== $(dragging).parent().data('connectWith')) {
  15198. return true;
  15199. }
  15200. if (e.type === 'drop') {
  15201. e.stopPropagation();
  15202. placeholders.filter(':visible').after(dragging);
  15203. dragging.trigger('dragend.h5s');
  15204. return false;
  15205. }
  15206. e.preventDefault();
  15207. e.originalEvent.dataTransfer.dropEffect = 'move';
  15208. if (items.is(this)) {
  15209. if (options.forcePlaceholderSize) {
  15210. placeholder.height(dragging.outerHeight());
  15211. }
  15212. dragging.hide();
  15213. $(this)[placeholder.index() < $(this).index() ? 'after' : 'before'](placeholder);
  15214. placeholders.not(placeholder).detach();
  15215. } else if (!placeholders.is(this) && !$(this).children(options.items).length) {
  15216. placeholders.detach();
  15217. $(this).append(placeholder);
  15218. }
  15219. return false;
  15220. });
  15221. });
  15222. };
  15223. //module begin
  15224. window.jqGridUtils = {
  15225. stringify: function (obj) {
  15226. return JSON.stringify(obj, function (key, value) {
  15227. return (typeof value === 'function') ? value.toString() : value;
  15228. });
  15229. },
  15230. parse: function (str) {
  15231. return JSON.parse(str, function (key, value) {
  15232. if (typeof value === "string" && value.indexOf("function") !== -1) {
  15233. var sv = value.split(" ");
  15234. if (sv[0].trim() === 'function' && value.trim().slice(-1) === "}") {
  15235. return eval('(' + value + ')');
  15236. } else {
  15237. return value;
  15238. }
  15239. }
  15240. return value;
  15241. });
  15242. },
  15243. encode: function (text) { // repeated, but should not depend on grid
  15244. return String(text).replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/"/g, '&quot;');
  15245. },
  15246. jsonToXML: function (tree, options) {
  15247. var o = $.extend({
  15248. xmlDecl: '<?xml version="1.0" encoding="UTF-8" ?>\n',
  15249. attr_prefix: '-',
  15250. encode: true
  15251. }, options || {}),
  15252. that = this,
  15253. scalarToxml = function (name, text) {
  15254. if (name === "#text") {
  15255. return (o.encode ? that.encode(text) : text);
  15256. } else if (typeof (text) === 'function') {
  15257. return "<" + name + "><![CDATA[" + text + "]]></" + name + ">\n";
  15258. } if (text === "") {
  15259. return "<" + name + ">__EMPTY_STRING_</" + name + ">\n";
  15260. } else {
  15261. return "<" + name + ">" + (o.encode ? that.encode(text) : text) + "</" + name + ">\n";
  15262. }
  15263. },
  15264. arrayToxml = function (name, array) {
  15265. var out = [];
  15266. for (var i = 0; i < array.length; i++) {
  15267. var val = array[i];
  15268. if (typeof (val) === "undefined" || val == null) {
  15269. out[out.length] = "<" + name + " />";
  15270. } else if (typeof (val) === "object" && val.constructor == Array) {
  15271. out[out.length] = arrayToxml(name, val);
  15272. } else if (typeof (val) === "object") {
  15273. out[out.length] = hashToxml(name, val);
  15274. } else {
  15275. out[out.length] = scalarToxml(name, val);
  15276. }
  15277. }
  15278. if (!out.length) {
  15279. out[0] = "<" + name + ">__EMPTY_ARRAY_</" + name + ">\n";
  15280. }
  15281. return out.join("");
  15282. },
  15283. hashToxml = function (name, tree) {
  15284. var elem = [];
  15285. var attr = [];
  15286. for (var key in tree) {
  15287. if (!tree.hasOwnProperty(key)) continue;
  15288. var val = tree[key];
  15289. if (key.charAt(0) !== o.attr_prefix) {
  15290. if (val == null) { // null or undefined
  15291. elem[elem.length] = "<" + key + " />";
  15292. } else if (typeof (val) === "object" && val.constructor === Array) {
  15293. elem[elem.length] = arrayToxml(key, val);
  15294. } else if (typeof (val) === "object") {
  15295. elem[elem.length] = hashToxml(key, val);
  15296. } else {
  15297. elem[elem.length] = scalarToxml(key, val);
  15298. }
  15299. } else {
  15300. attr[attr.length] = " " + (key.substring(1)) + '="' + (o.encode ? that.encode(val) : val) + '"';
  15301. }
  15302. }
  15303. var jattr = attr.join("");
  15304. var jelem = elem.join("");
  15305. if (name == null) { // null or undefined
  15306. // no tag
  15307. } else if (elem.length > 0) {
  15308. if (jelem.match(/\n/)) {
  15309. jelem = "<" + name + jattr + ">\n" + jelem + "</" + name + ">\n";
  15310. } else {
  15311. jelem = "<" + name + jattr + ">" + jelem + "</" + name + ">\n";
  15312. }
  15313. } else {
  15314. jelem = "<" + name + jattr + " />\n";
  15315. }
  15316. return jelem;
  15317. };
  15318. var xml = hashToxml(null, tree);
  15319. return o.xmlDecl + xml;
  15320. },
  15321. xmlToJSON: function (root, options) {
  15322. var o = $.extend({
  15323. force_array: [], //[ "rdf:li", "item", "-xmlns" ];
  15324. attr_prefix: '-'
  15325. }, options || {});
  15326. if (!root) { return; }
  15327. var __force_array = {};
  15328. if (o.force_array) {
  15329. for (var i = 0; i < o.force_array.length; i++) {
  15330. __force_array[o.force_array[i]] = 1;
  15331. }
  15332. }
  15333. if (typeof root === 'string') {
  15334. root = $.parseXML(root);
  15335. }
  15336. if (root.documentElement) {
  15337. root = root.documentElement;
  15338. }
  15339. var addNode = function (hash, key, cnts, val) {
  15340. if (typeof val === 'string') {
  15341. if (val.indexOf('function') !== -1) {
  15342. val = eval('(' + val + ')'); // we need this in our implement
  15343. } else {
  15344. switch (val) {
  15345. case '__EMPTY_ARRAY_':
  15346. val = [];
  15347. break;
  15348. case '__EMPTY_STRING_':
  15349. val = "";
  15350. break;
  15351. case "false":
  15352. val = false;
  15353. break;
  15354. case "true":
  15355. val = true;
  15356. break;
  15357. }
  15358. }
  15359. }
  15360. if (__force_array[key]) {
  15361. if (cnts === 1) {
  15362. hash[key] = [];
  15363. }
  15364. hash[key][hash[key].length] = val; // push
  15365. } else if (cnts === 1) { // 1st sibling
  15366. hash[key] = val;
  15367. } else if (cnts === 2) { // 2nd sibling
  15368. hash[key] = [hash[key], val];
  15369. } else { // 3rd sibling and more
  15370. hash[key][hash[key].length] = val;
  15371. }
  15372. },
  15373. parseElement = function (elem) {
  15374. // COMMENT_NODE
  15375. if (elem.nodeType === 7) {
  15376. return;
  15377. }
  15378. // TEXT_NODE CDATA_SECTION_NODE
  15379. if (elem.nodeType === 3 || elem.nodeType === 4) {
  15380. var bool = elem.nodeValue.match(/[^\x00-\x20]/);
  15381. if (bool == null) return; // ignore white spaces
  15382. return elem.nodeValue;
  15383. }
  15384. var retval, cnt = {}, i, key, val;
  15385. // parse attributes
  15386. if (elem.attributes && elem.attributes.length) {
  15387. retval = {};
  15388. for (i = 0; i < elem.attributes.length; i++) {
  15389. key = elem.attributes[i].nodeName;
  15390. if (typeof (key) !== "string") {
  15391. continue;
  15392. }
  15393. val = elem.attributes[i].nodeValue;
  15394. if (!val) {
  15395. continue;
  15396. }
  15397. key = o.attr_prefix + key;
  15398. if (typeof (cnt[key]) === "undefined") {
  15399. cnt[key] = 0;
  15400. }
  15401. cnt[key]++;
  15402. addNode(retval, key, cnt[key], val);
  15403. }
  15404. }
  15405. // parse child nodes (recursive)
  15406. if (elem.childNodes && elem.childNodes.length) {
  15407. var textonly = true;
  15408. if (retval) {
  15409. textonly = false;
  15410. } // some attributes exists
  15411. for (i = 0; i < elem.childNodes.length && textonly; i++) {
  15412. var ntype = elem.childNodes[i].nodeType;
  15413. if (ntype === 3 || ntype === 4) {
  15414. continue;
  15415. }
  15416. textonly = false;
  15417. }
  15418. if (textonly) {
  15419. if (!retval) {
  15420. retval = "";
  15421. }
  15422. for (i = 0; i < elem.childNodes.length; i++) {
  15423. retval += elem.childNodes[i].nodeValue;
  15424. }
  15425. } else {
  15426. if (!retval) {
  15427. retval = {};
  15428. }
  15429. for (i = 0; i < elem.childNodes.length; i++) {
  15430. key = elem.childNodes[i].nodeName;
  15431. if (typeof (key) !== "string") {
  15432. continue;
  15433. }
  15434. val = parseElement(elem.childNodes[i]);
  15435. if (!val) {
  15436. continue;
  15437. }
  15438. if (typeof (cnt[key]) === "undefined") {
  15439. cnt[key] = 0;
  15440. }
  15441. cnt[key]++;
  15442. addNode(retval, key, cnt[key], val);
  15443. }
  15444. }
  15445. }
  15446. return retval;
  15447. };
  15448. var json = parseElement(root); // parse root node
  15449. if (__force_array[root.nodeName]) {
  15450. json = [json];
  15451. }
  15452. if (root.nodeType !== 11) { // DOCUMENT_FRAGMENT_NODE
  15453. var tmp = {};
  15454. tmp[root.nodeName] = json; // root nodeName
  15455. json = tmp;
  15456. }
  15457. return json;
  15458. }
  15459. };
  15460. }));
  15461. (function ($) {
  15462. $.fn.swapClass = function (c1, c2) {
  15463. return this.removeClass(c1).addClass(c2);
  15464. };
  15465. $.fn.switchClass = function (c1, c2) {
  15466. if (this.hasClass(c1)) {
  15467. return this.swapClass(c1, c2);
  15468. }
  15469. else {
  15470. return this.swapClass(c2, c1);
  15471. }
  15472. };
  15473. $.fn.treeview = function (settings) {
  15474. var dfop =
  15475. {
  15476. method: "GET",
  15477. datatype: "json",
  15478. url: false,
  15479. param: null,
  15480. cbiconpath: "/Content/js/wdtree/images/icons/",
  15481. icons: ["checkbox_0.png", "checkbox_1.png", "checkbox_2.png"],
  15482. showcheck: false,
  15483. oncheckboxclick: false,
  15484. onnodeclick: false,
  15485. cascadecheck: true,
  15486. data: null,
  15487. clicktoggle: true,
  15488. theme: "bbit-tree-arrows",
  15489. isTool: false,
  15490. nodeTools: []
  15491. };
  15492. $.extend(dfop, settings);
  15493. var treenodes = dfop.data;
  15494. var me = $(this);
  15495. var id = me.attr("id");
  15496. if (id == null || id == "") {
  15497. id = "bbtree" + new Date().getTime();
  15498. me.attr("id", id);
  15499. }
  15500. me.height(dfop.height);
  15501. if (dfop.slimscroll == true) {
  15502. me.css({ "overflow": "auto", "overflow-y": "hidden" });
  15503. } else {
  15504. me.css({ "overflow": "auto" });
  15505. }
  15506. var html = [];
  15507. buildtree(dfop.data, html);
  15508. me.html('');
  15509. me.addClass("bbit-tree").append(html.join(""));
  15510. InitEvent(me);
  15511. html = null;
  15512. if (dfop.showcheck) {
  15513. for (var i = 0; i < 3; i++) {
  15514. var im = new Image();
  15515. im.src = dfop.cbiconpath + dfop.icons[i];
  15516. }
  15517. }
  15518. function buildtree(data, ht) {
  15519. ht.push("<div class='bbit-tree-bwrap'>");
  15520. ht.push("<div class='bbit-tree-body " + id + "'>");
  15521. ht.push("<ul class='bbit-tree-root ", dfop.theme, "'>");
  15522. if (data && data.length > 0) {
  15523. var l = data.length;
  15524. for (var i = 0; i < l; i++) {
  15525. buildnode(data[i], ht, 0, i, i == l - 1);
  15526. }
  15527. }
  15528. else {
  15529. asnyloadc(null, false, function (data) {
  15530. if (data && data.length > 0) {
  15531. treenodes = data;
  15532. dfop.data = data;
  15533. if (dfop.description) {
  15534. data.unshift({
  15535. "id": "",
  15536. "text": dfop.description,
  15537. "value": "",
  15538. "img": "-1",
  15539. "parentnodes": "0",
  15540. "showcheck": false,
  15541. "isexpand": true,
  15542. "complete": true,
  15543. "hasChildren": false,
  15544. "ChildNodes": []
  15545. });
  15546. }
  15547. var l = data.length;
  15548. for (var i = 0; i < l; i++) {
  15549. buildnode(data[i], ht, 0, i, i == l - 1);
  15550. }
  15551. }
  15552. });
  15553. }
  15554. ht.push("</ul>");
  15555. ht.push("</div>");
  15556. ht.push("</div>");
  15557. }
  15558. function buildnode(nd, ht, deep, path, isend) {
  15559. var nid = nd.id.replace(/[^\w]/gi, "_");
  15560. ht.push("<li class='bbit-tree-node'>");
  15561. var title = nd.title;
  15562. if (title) {
  15563. title = nd.title;
  15564. } else {
  15565. title = nd.text;
  15566. }
  15567. ht.push("<div id='", id, "_", nid, "' tpath='", path, "' unselectable='on' title='", title, "'");
  15568. var cs = [];
  15569. cs.push("bbit-tree-node-el");
  15570. if (nd.hasChildren) {
  15571. nd.isexpand = false;
  15572. cs.push(nd.isexpand ? "bbit-tree-node-expanded" : "bbit-tree-node-collapsed");
  15573. }
  15574. else {
  15575. cs.push("bbit-tree-node-leaf");
  15576. }
  15577. if (nd.classes) { cs.push(nd.classes); }
  15578. ht.push(" class='", cs.join(" "), "'>");
  15579. ht.push("<span class='bbit-tree-node-indent'>");
  15580. if (deep == 1) {
  15581. ht.push("<img class='bbit-tree-icon' src='" + dfop.cbiconpath + "s.gif'/>");
  15582. }
  15583. else if (deep > 1) {
  15584. ht.push("<img class='bbit-tree-icon' src='" + dfop.cbiconpath + "s.gif'/>");
  15585. for (var j = 1; j < deep; j++) {
  15586. ht.push("<img class='bbit-tree-elbow-line' src='" + dfop.cbiconpath + "s.gif'/>");
  15587. }
  15588. }
  15589. ht.push("</span>");
  15590. cs.length = 0;
  15591. if (nd.hasChildren) {
  15592. if (nd.isexpand) {
  15593. cs.push(isend ? "bbit-tree-elbow-end-minus" : "bbit-tree-elbow-minus");
  15594. }
  15595. else {
  15596. cs.push(isend ? "bbit-tree-elbow-end-plus" : "bbit-tree-elbow-plus");
  15597. }
  15598. }
  15599. else {
  15600. cs.push(isend ? "bbit-tree-elbow-end" : "bbit-tree-elbow");
  15601. }
  15602. ht.push("<img class='bbit-tree-ec-icon ", cs.join(" "), "' src='" + dfop.cbiconpath + "s.gif'/>");
  15603. if (dfop.showcheck && nd.showcheck) {
  15604. if (nd.checkstate == null || nd.checkstate == undefined) {
  15605. nd.checkstate = 0;
  15606. }
  15607. ht.push("<img id='", id, "_", nid, "_cb' class='bbit-tree-node-cb' src='", dfop.cbiconpath, dfop.icons[nd.checkstate], "'/>");
  15608. }
  15609. if (nd.hasChildren) {
  15610. if (nd.img == -1) {
  15611. ht.push("");
  15612. } else
  15613. if (!!nd.img) {
  15614. ht.push("<i class=\"" + nd.img + "\"></i>");
  15615. } else {
  15616. ht.push("<i class=\"fa fa-folder-open\" style='width:15px'></i>");
  15617. }
  15618. } else {
  15619. if (nd.img == -1) {
  15620. ht.push("");
  15621. } else
  15622. if (!!nd.img) {
  15623. ht.push("<i class=\"" + nd.img + "\"></i>");
  15624. } else {
  15625. ht.push("<i class=\"fa fa-file-text-o\"></i>");
  15626. }
  15627. }
  15628. ht.push("<a hideFocus class='bbit-tree-node-anchor' tabIndex=1 href='javascript:void(0);'>");
  15629. ht.push("<span data-value='" + nd.id + "' class='bbit-tree-node-text' unselectable='on'>", nd.text, "</span>");
  15630. ht.push("</a>");
  15631. if (dfop.isTool) {
  15632. ht.push("<div class='bbit-tree-node-tool'>");
  15633. for (var ii in dfop.nodeTools) {
  15634. var toolItem = dfop.nodeTools[ii];
  15635. ht.push("<span class='" + toolItem.img + "' title='" + toolItem.text + "'></span>");
  15636. }
  15637. ht.push("</div>");
  15638. }
  15639. ht.push("</div>");
  15640. if (nd.hasChildren) {
  15641. if (nd.isexpand) {
  15642. //设置子节点默认不打开
  15643. ht.push("<ul class='bbit-tree-node-ct' style='z-index: 0; position: static; visibility: visible; top: auto; left: auto; display:none '>");
  15644. if (nd.ChildNodes) {
  15645. var l = nd.ChildNodes.length;
  15646. for (var k = 0; k < l; k++) {
  15647. nd.ChildNodes[k].parent = nd;
  15648. buildnode(nd.ChildNodes[k], ht, deep + 1, path + "." + k, k == l - 1);
  15649. }
  15650. }
  15651. ht.push("</ul>");
  15652. }
  15653. else {
  15654. ht.push("<ul style='display:none;'>");
  15655. if (nd.ChildNodes) {
  15656. var l = nd.ChildNodes.length;
  15657. for (var k = 0; k < l; k++) {
  15658. nd.ChildNodes[k].parent = nd;
  15659. buildnode(nd.ChildNodes[k], ht, deep + 1, path + "." + k, k == l - 1);
  15660. }
  15661. }
  15662. ht.push("</ul>");
  15663. }
  15664. }
  15665. ht.push("</li>");
  15666. nd.render = true;
  15667. }
  15668. function getItem(path) {
  15669. var ap = path.split(".");
  15670. var t = treenodes;
  15671. for (var i = 0; i < ap.length; i++) {
  15672. if (i == 0) {
  15673. t = t[ap[i]];
  15674. }
  15675. else {
  15676. t = t.ChildNodes[ap[i]];
  15677. }
  15678. }
  15679. return t;
  15680. }
  15681. function check(item, state, type) {
  15682. var pstate = item.checkstate;
  15683. if (type == 1) {
  15684. item.checkstate = state;
  15685. }
  15686. else {
  15687. var cs = item.ChildNodes;
  15688. var l = cs.length;
  15689. var ch = true;
  15690. for (var i = 0; i < l; i++) {
  15691. if ((state == 1 && cs[i].checkstate != 1) || state == 0 && cs[i].checkstate != 0) {
  15692. ch = false;
  15693. break;
  15694. }
  15695. }
  15696. if (ch) {
  15697. item.checkstate = state;
  15698. }
  15699. else {
  15700. item.checkstate = 2;
  15701. }
  15702. }
  15703. if (item.render && pstate != item.checkstate) {
  15704. var nid = item.id.replace(/[^\w]/gi, "_");
  15705. var et = $("#" + id + "_" + nid + "_cb");
  15706. if (et.length == 1) {
  15707. et.attr("src", dfop.cbiconpath + dfop.icons[item.checkstate]);
  15708. }
  15709. }
  15710. }
  15711. function cascade(fn, item, args) {
  15712. if (fn(item, args, 1) != false) {
  15713. if (item.ChildNodes != null && item.ChildNodes.length > 0) {
  15714. var cs = item.ChildNodes;
  15715. for (var i = 0, len = cs.length; i < len; i++) {
  15716. cascade(fn, cs[i], args);
  15717. }
  15718. }
  15719. }
  15720. }
  15721. function bubble(fn, item, args) {
  15722. var p = item.parent;
  15723. while (p) {
  15724. if (fn(p, args, 0) === false) {
  15725. break;
  15726. }
  15727. p = p.parent;
  15728. }
  15729. }
  15730. function nodeclick(e) {
  15731. var path = $(this).attr("tpath");
  15732. var et = e.target || e.srcElement;
  15733. var item = getItem(path);
  15734. if (et.tagName == "IMG") {
  15735. if ($(et).hasClass("bbit-tree-elbow-plus") || $(et).hasClass("bbit-tree-elbow-end-plus")) {
  15736. if ($(this).find('i').hasClass('fa-folder')) {
  15737. $(this).find('i').swapClass('fa-folder', 'fa-folder-open');
  15738. }
  15739. var ul = $(this).next();
  15740. if (ul.hasClass("bbit-tree-node-ct")) {
  15741. ul.slideDown(200);
  15742. }
  15743. else {
  15744. var deep = path.split(".").length;
  15745. if (item.complete) {
  15746. item.ChildNodes != null && asnybuild(item.ChildNodes, deep, path, ul, item);
  15747. }
  15748. else {
  15749. $(this).addClass("bbit-tree-node-loading");
  15750. asnyloadc(item, true, function (data) {
  15751. item.complete = true;
  15752. item.ChildNodes = data;
  15753. asnybuild(data, deep, path, ul, item);
  15754. });
  15755. }
  15756. }
  15757. if ($(et).hasClass("bbit-tree-elbow-plus")) {
  15758. $(et).swapClass("bbit-tree-elbow-plus", "bbit-tree-elbow-minus");
  15759. }
  15760. else {
  15761. $(et).swapClass("bbit-tree-elbow-end-plus", "bbit-tree-elbow-end-minus");
  15762. }
  15763. $(this).swapClass("bbit-tree-node-collapsed", "bbit-tree-node-expanded");
  15764. }
  15765. else if ($(et).hasClass("bbit-tree-elbow-minus") || $(et).hasClass("bbit-tree-elbow-end-minus")) {
  15766. if ($(this).find('i').hasClass('fa-folder-open')) {
  15767. $(this).find('i').swapClass('fa-folder-open', 'fa-folder');
  15768. }
  15769. $(this).next().slideUp(200);
  15770. if ($(et).hasClass("bbit-tree-elbow-minus")) {
  15771. $(et).swapClass("bbit-tree-elbow-minus", "bbit-tree-elbow-plus");
  15772. }
  15773. else {
  15774. $(et).swapClass("bbit-tree-elbow-end-minus", "bbit-tree-elbow-end-plus");
  15775. }
  15776. $(this).swapClass("bbit-tree-node-expanded", "bbit-tree-node-collapsed");
  15777. }
  15778. else if ($(et).hasClass("bbit-tree-node-cb")) {
  15779. var s = item.checkstate != 1 ? 1 : 0;
  15780. var r = true;
  15781. if (dfop.oncheckboxclick) {
  15782. r = dfop.oncheckboxclick.call(et, item, s);
  15783. }
  15784. if (r != false) {
  15785. if (dfop.cascadecheck) {
  15786. cascade(check, item, s);
  15787. bubble(check, item, s);
  15788. }
  15789. else {
  15790. check(item, s, 1);
  15791. }
  15792. }
  15793. }
  15794. }
  15795. else {
  15796. if (dfop.citem) {
  15797. var nid = dfop.citem.id.replace(/[^\w]/gi, "_");
  15798. $("." + id).removeClass("bbit-tree-selected");
  15799. }
  15800. dfop.citem = item;
  15801. $("." + id).find('div').removeClass("bbit-tree-selected");
  15802. $(this).addClass("bbit-tree-selected");
  15803. if (dfop.onnodeclick) {
  15804. if (!item.expand) {
  15805. item.expand = function () { expandnode.call(item); };
  15806. }
  15807. dfop.onnodeclick.call(this, item);
  15808. }
  15809. }
  15810. }
  15811. function expandnode() {
  15812. var item = this;
  15813. var nid = item.id.replace(/[^\w]/gi, "_");
  15814. var img = $("#" + id + "_" + nid + " img.bbit-tree-ec-icon");
  15815. if (img.length > 0) {
  15816. img.click();
  15817. }
  15818. }
  15819. function asnybuild(nodes, deep, path, ul, pnode) {
  15820. var l = nodes.length;
  15821. if (l > 0) {
  15822. var ht = [];
  15823. for (var i = 0; i < l; i++) {
  15824. nodes[i].parent = pnode;
  15825. buildnode(nodes[i], ht, deep, path + "." + i, i == l - 1);
  15826. }
  15827. ul.html(ht.join(""));
  15828. ht = null;
  15829. InitEvent(ul);
  15830. }
  15831. ul.addClass("bbit-tree-node-ct").css({ "z-index": 0, position: "static", visibility: "visible", top: "auto", left: "auto", display: "" });
  15832. ul.prev().removeClass("bbit-tree-node-loading");
  15833. }
  15834. function asnyloadc(pnode, isAsync, callback) {
  15835. if (dfop.url) {
  15836. if (pnode && pnode != null)
  15837. var param = builparam(pnode);
  15838. if (dfop.param != null) {
  15839. var param = dfop.param
  15840. }
  15841. $.ajax({
  15842. type: dfop.method,
  15843. url: dfop.url,
  15844. data: param,
  15845. async: isAsync,
  15846. dataType: dfop.datatype,
  15847. success: callback,
  15848. error: function (e) { dialogMsg("服务端未响应。", -1); }
  15849. });
  15850. }
  15851. }
  15852. function builparam(node) {
  15853. var p = [{ name: "id", value: encodeURIComponent(node.id) }
  15854. , { name: "text", value: encodeURIComponent(node.text) }
  15855. , { name: "value", value: encodeURIComponent(node.value) }
  15856. , { name: "checkstate", value: node.checkstate }];
  15857. return p;
  15858. }
  15859. function bindevent() {
  15860. $(this).hover(function () {
  15861. $(this).addClass("bbit-tree-node-over");
  15862. }, function () {
  15863. $(this).removeClass("bbit-tree-node-over");
  15864. }).click(nodeclick)
  15865. .find("img.bbit-tree-ec-icon").each(function (e) {
  15866. if (!$(this).hasClass("bbit-tree-elbow")) {
  15867. $(this).hover(function () {
  15868. $(this).parent().addClass("bbit-tree-ec-over");
  15869. }, function () {
  15870. $(this).parent().removeClass("bbit-tree-ec-over");
  15871. });
  15872. }
  15873. });
  15874. }
  15875. function InitEvent(parent) {
  15876. var nodes = $("li.bbit-tree-node>div", parent);
  15877. nodes.each(bindevent);
  15878. }
  15879. function reflash(itemId) {
  15880. var nid = itemId.replace(/[^\w-]/gi, "_");
  15881. var node = $("#" + id + "_" + nid);
  15882. if (node.length > 0) {
  15883. node.addClass("bbit-tree-node-loading");
  15884. var isend = node.hasClass("bbit-tree-elbow-end") || node.hasClass("bbit-tree-elbow-end-plus") || node.hasClass("bbit-tree-elbow-end-minus");
  15885. var path = node.attr("tpath");
  15886. var deep = path.split(".").length;
  15887. var item = getItem(path);
  15888. if (item) {
  15889. asnyloadc(item, true, function (data) {
  15890. item.complete = true;
  15891. item.ChildNodes = data;
  15892. item.isexpand = true;
  15893. if (data && data.length > 0) {
  15894. item.hasChildren = true;
  15895. }
  15896. else {
  15897. item.hasChildren = false;
  15898. }
  15899. var ht = [];
  15900. buildnode(item, ht, deep - 1, path, isend);
  15901. ht.shift();
  15902. ht.pop();
  15903. var li = node.parent();
  15904. li.html(ht.join(""));
  15905. ht = null;
  15906. InitEvent(li);
  15907. bindevent.call(li.find(">div"));
  15908. });
  15909. }
  15910. }
  15911. }
  15912. function getck(items, c, fn) {
  15913. for (var i = 0, l = items.length; i < l; i++) {
  15914. (items[i].showcheck == true && items[i].checkstate == 1) && c.push(fn(items[i]));
  15915. if (items[i].ChildNodes != null && items[i].ChildNodes.length > 0) {
  15916. getck(items[i].ChildNodes, c, fn);
  15917. }
  15918. }
  15919. }
  15920. function getCkAndHalfCk(items, c, fn) {
  15921. for (var i = 0, l = items.length; i < l; i++) {
  15922. (items[i].showcheck == true && (items[i].checkstate == 1 || items[i].checkstate == 2)) && c.push(fn(items[i]));
  15923. if (items[i].ChildNodes != null && items[i].ChildNodes.length > 0) {
  15924. getCkAndHalfCk(items[i].ChildNodes, c, fn);
  15925. }
  15926. }
  15927. }
  15928. me[0].t = {
  15929. getSelectedNodes: function (gethalfchecknode) {
  15930. var s = [];
  15931. if (gethalfchecknode) {
  15932. getCkAndHalfCk(treenodes, s, function (item) { return item; });
  15933. }
  15934. else {
  15935. getck(treenodes, s, function (item) { return item; });
  15936. }
  15937. return s;
  15938. },
  15939. getSelectedValues: function () {
  15940. var s = [];
  15941. getck(treenodes, s, function (item) { return item.value; });
  15942. return s;
  15943. },
  15944. getCurrentItem: function () {
  15945. return dfop.citem;
  15946. },
  15947. reflash: function (itemOrItemId) {
  15948. var id;
  15949. if (typeof (itemOrItemId) == "string") {
  15950. id = itemOrItemId;
  15951. }
  15952. else {
  15953. id = itemOrItemId.id;
  15954. }
  15955. reflash(id);
  15956. }
  15957. };
  15958. return me;
  15959. };
  15960. $.fn.getCheckedNodes = function () {
  15961. var $id = $(this);
  15962. var _length = $id.attr('id').trim().length + 1;
  15963. var value = []
  15964. $id.find('.bbit-tree-node-cb').each(function () {
  15965. var _src = $(this).attr('src');
  15966. _src = _src.substr(_src.lastIndexOf("/") + 1);
  15967. if (_src == 'checkbox_1.png' || _src == 'checkbox_2.png') {
  15968. var _value = $(this).attr('id').substring(parseInt(_length)).replace(/_/g, "-");
  15969. _value = _value.substring(0, _value.length - 3);
  15970. value.push(_value)
  15971. }
  15972. });
  15973. return value;
  15974. };
  15975. $.fn.setCheckedNodes = function (data) {
  15976. var $id = $(this);
  15977. var id = $id.attr('id').trim();
  15978. $.each(data, function (i, item) {
  15979. var object = $id.find(('#' + id + '_' + item.replace(/-/g, "_") + '_cb'));
  15980. if (object.length != 0) {
  15981. object.trigger("click");
  15982. }
  15983. });
  15984. }
  15985. $.fn.setCheckedNodeOne = function (data) {
  15986. var $id = $(this);
  15987. var id = $id.attr('id').trim();
  15988. var object = $id.find(('#' + id + '_' + data.replace(/-/g, "_") + '_cb'));
  15989. if (object.length != 0) {
  15990. object.trigger("click");
  15991. }
  15992. }
  15993. $.fn.setNoCheckedNodes = function (item) {
  15994. var $id = $(this);
  15995. var id = $id.attr('id').trim();
  15996. var object = $id.find(('#' + id + '_' + item.replace(/-/g, "_") + '_cb'));
  15997. var _src = object.attr('src');
  15998. object.attr('src', _src.replace('checkbox_1.png', 'checkbox_0.png'));
  15999. }
  16000. $.fn.getTSNs = function (gethalfchecknode) {
  16001. if (this[0].t) {
  16002. return this[0].t.getSelectedNodes(gethalfchecknode);
  16003. }
  16004. return null;
  16005. };
  16006. $.fn.getCurrentNode = function () {
  16007. if (this[0].t) {
  16008. return this[0].t.getCurrentItem();
  16009. }
  16010. return null;
  16011. };
  16012. $.fn.reflash = function (ItemOrItemId) {
  16013. if (this[0].t) {
  16014. return this[0].t.reflash(ItemOrItemId);
  16015. }
  16016. };
  16017. $.fn.setTreeHeight = function (height) {
  16018. var me = $(this);
  16019. me.height(height);
  16020. }
  16021. $.fn.setNodeChecked = function (value) {
  16022. var $id = $(this);
  16023. var id = $id.attr('id').trim();
  16024. $id.find('.bbit-tree-selected').removeClass('bbit-tree-selected');
  16025. var object = $id.find(('#' + id + '_' + value.replace(/-/g, "_")));
  16026. object.addClass('bbit-tree-selected');
  16027. }
  16028. })(jQuery);