template.js.struts2.jquery.grid.struts2.js Maven / Gradle / Ivy
/**
* @preserve
* jquery.grid.struts2.js
*
* Integration of jqGrid with struts 2
*
* Requires use of jquery.struts2.js
*
* Copyright (c) 2010 - 2015 Johannes Geppert https://www.jgeppert.com
*
* Dual licensed under the MIT and GPL licenses:
* http://www.opensource.org/licenses/mit-license.php
* http://www.gnu.org/licenses/gpl.html
*
*/
/*global jQuery, window */
/*jslint evil: true */
"use strict";
(function($) {
/**
* Bind jqGrid to Struts2 Component
*/
$.struts2_jquery_grid = {
lastselectedrow : '',
navigatorButtons : function($elem, buttons, pager) {
var self = this;
$.each(buttons, function(name, options) {
if(options.title) {
if(options.title === "seperator"){
$elem.jqGrid('navSeparatorAdd', pager);
}
else if (options.topic || options.onclick){
var bopts = {};
if(options.id) {
bopts.id = options.id;
}
if(options.title) {
bopts.title = options.title;
}
if(options.position) {
bopts.position = options.position;
}
if(options.caption) {
bopts.caption = options.caption;
}
else {
bopts.caption = '';
}
if(options.icon) {
bopts.buttonicon = options.icon;
}
else{
bopts.buttonicon = "ui-icon-gear";
}
if(options.topic) {
bopts.onClickButton = function() {
var params = {};
params.grid = $elem;
self.publishTopic($elem, options.topic, params);
};
}
else if (options.onclick) {
bopts.onClickButton = options.onclick;
}
$elem.jqGrid('navButtonAdd', pager, bopts);
}
}
});
},
parseGridParams : function($elem, o, params) {
var self = this;
if (o.onselectrowtopics || (o.editurl && o.editinline === true)) {
params.onSelectRow = function(id, status) {
var data = {},
oneditbefor = null,
onsuccess = null,
onerror = null,
onaftersave = null;
data.id = id;
data.status = status;
data.grid = $elem;
self.publishTopic($elem, o.onalw, data);
$.struts2_jquery.publishTopic($elem, o.onselectrowtopics, data);
if (o.editurl && o.editinline === true && o.navinline === false) {
if (self.lastselectedrow !== '') {
$elem.jqGrid('restoreRow', self.lastselectedrow);
}
self.lastselectedrow = id;
if (o.oneibefore) {
oneditbefor = function() {
self.publishTopic($elem, o.oneibefore, data);
};
}
if (o.oneisuccess) {
onsuccess = function(response) {
var d = {};
d.response = response;
self.publishTopic($elem, o.oneisuccess, d);
if(response.status >= 400) {
return false;
}
else {
return true;
}
};
}
if (o.oneierror) {
onerror = function(rowid, response) {
var d = {};
d.rowid = rowid;
d.response = response;
self.publishTopic($elem, o.oneierror, d);
};
}
if (o.oneisave) {
onaftersave = function(rowid, response) {
var d = {};
d.rowid = rowid;
d.response = response;
self.publishTopic($elem, o.oneisave, d);
};
}
$elem.jqGrid('editRow', id, true, oneditbefor,
onsuccess, null, null, onaftersave, onerror,
null);
}
};
}
if (o.oncesuccess) {
params.afterSaveCell = function(rowid, cellname, value, iRow, iCol) {
var d = {};
d.rowid = rowid;
d.cellname = cellname;
d.value = value;
d.iRow = iRow;
d.iCol = iCol;
self.publishTopic($elem, o.oncesuccess, d);
};
}
if (o.onceerror) {
params.errorCell = function(response, status) {
var d = {};
d.response = response;
d.status = status;
self.publishTopic($elem, o.onceerror, d);
};
}
if (o.onselectalltopics) {
params.onSelectAll = function(ids, status) {
var data = {};
data.ids = ids;
data.status = status;
data.grid = $elem;
self.publishTopic($elem, o.onalw, data);
self.publishTopic($elem, o.onselectalltopics, data);
};
}
if (o.onbef) {
params.loadBeforeSend = function(xhr) {
var orginal = {};
orginal.xhr = xhr;
orginal.proceed = true;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onbef, orginal);
return orginal.proceed;
};
}
if (o.onpagingtopics) {
params.onPaging = function(pgButton) {
var orginal = {};
orginal.pgButton = pgButton;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onpagingtopics, orginal);
};
}
if (o.onsortcoltopics) {
params.onSortCol = function(index, iCol, sortorder) {
var orginal = {};
orginal.index = index;
orginal.iCol = iCol;
orginal.sortorder = sortorder;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onsortcoltopics, orginal);
};
}
if (o.oncellselecttopics) {
params.onCellSelect = function(rowid, iCol, cellcontent, e) {
var orginal = {};
orginal.rowid = rowid;
orginal.iCol = iCol;
orginal.cellcontent = cellcontent;
orginal.e = e;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.oncellselecttopics, orginal);
};
}
if (o.onclickgroup) {
params.onClickGroup = function(groupid, collapsed ) {
var orginal = {};
orginal.groupid = groupid;
orginal.collapsed = collapsed;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onclickgroup, orginal);
};
}
if (o.ondblclickrow) {
params.ondblClickRow = function(rowid, iRow, iCol, e) {
var orginal = {};
orginal.rowid = rowid;
orginal.iRow = iRow;
orginal.iCol = iCol;
orginal.e = e;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.ondblclickrow, orginal);
};
}
if (o.onrightclickrow) {
params.onRightClickRow = function(rowid, iRow, iCol, e) {
var orginal = {};
orginal.rowid = rowid;
orginal.iRow = iRow;
orginal.iCol = iCol;
orginal.e = e;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onrightclickrow, orginal);
};
}
params.gridComplete = function(data) {
var daos = o.draggableoptions,
dao = window[daos],
doos = o.droppableoptions,
doo = window[doos],
soos = o.sortableoptions,
soo = window[soos],
ros = o.resizableoptions,
ro = window[ros],
ddo = {},
navparams = {},
fpara = {};
if(!$elem.data('_s2jg_init')) {
$elem.data('_s2jg_init', true);
if (o.draggable && o.droppable) {
self.log('drag and drop for grid : ' + o.id);
if (!self.loadAtOnce) {
self.require( [
"js/base/data" + self.minSuffix + ".js",
"js/base/plugin" + self.minSuffix + ".js",
"js/base/safe-active-element" + self.minSuffix + ".js",
"js/base/safe-blur" + self.minSuffix + ".js",
"js/base/scroll-parent" + self.minSuffix + ".js",
"js/base/widget" + self.minSuffix + ".js",
"js/base/mouse" + self.minSuffix + ".js",
"js/base/draggable" + self.minSuffix + ".js",
"js/base/droppable" + self.minSuffix + ".js"
]);
}
if (!dao) {
dao = Function('return (' + daos + ')')();
} else {
dao = {};
}
dao.drap = self.pubTops($elem, o.onalw, o.draggableondragtopics);
if (!doo) {
doo = Function('return (' + doos + ')')();
} else {
doo = {};
}
doo.activate = self.pubTops($elem, o.onalw, o.droppableonactivatetopics);
doo.deactivate = self.pubTops($elem, o.onalw, o.droppableondeactivatetopics);
doo.start = self.pubTops($elem, o.onalw, o.droppableonstarttopics);
doo.stop = self.pubTops($elem, o.onalw, o.droppableonstoptopics);
ddo.drag_opts = dao;
ddo.drop_opts = doo;
ddo.connectWith = o.connectWith;
ddo.onstart = self.pubTops($elem, o.onalw, o.draggableonstarttopics);
ddo.onstop = self.pubTops($elem, o.onalw, o.draggableonstoptopics);
ddo.ondrop = self.pubTops($elem, o.onalw, o.droppableondroptopics);
$elem.jqGrid('gridDnD', ddo);
}
if (o.sortableRows) {
self.log('sortable rows for : ' + o.id);
if (!soo && soos) {
soo = Function('return (' + soos + ')')();
} else {
soo = {};
}
soo.beforeStop = self.pubTops($elem, o.onalw, o.sortableonbeforestoptopics);
soo.stop = self.pubTops($elem, o.onalw, o.sortableonstoptopics);
soo.start = self.pubTops($elem, o.onalw, o.sortableonstarttopics);
soo.sort = self.pubTops($elem, o.onalw, o.sortableonsorttopics);
soo.activate = self.pubTops($elem, o.onalw, o.sortableonactivatetopics);
soo.deactivate = self.pubTops($elem, o.onalw, o.sortableondeactivatetopics);
soo.over = self.pubTops($elem, o.onalw, o.sortableonovertopics);
soo.out = self.pubTops($elem, o.onalw, o.sortableonouttopics);
soo.remove = self.pubTops($elem, o.onalw, o.sortableonremovetopics);
soo.receive = self.pubTops($elem, o.onalw, o.sortableonreceivetopics);
soo.change = self.pubTops($elem, o.onalw, o.sortableonchangetopics);
soo.update = self.pubTops($elem, o.onalw, o.sortableonupdatetopics);
$elem.jqGrid('sortableRows', soo);
}
if (o.navigator) {
navparams.add = o.navigatoradd;
navparams.del = o.navigatordel;
navparams.edit = o.navigatoredit;
navparams.refresh = o.navigatorrefresh;
navparams.search = o.navigatorsearch;
navparams.view = o.navigatorview;
navparams.cloneToTop = o.cloneToTop;
$elem.jqGrid('navGrid', self.escId(o.pager), navparams,
o.navigatoreditoptions, o.navigatoraddoptions,
o.navigatordeleteoptions, o.navigatorsearchoptions,
o.navigatorviewoptions);
if(o.editinline === true && o.navinline === true) {
$elem.jqGrid('inlineNav',self.escId(o.pager));
}
if(o.navigatorextrabuttons) {
self.navigatorButtons($elem, o.navigatorextrabuttons, self.escId(o.pager));
}
if(o.cloneToTop) {
self.navigatorButtons($elem, o.navigatorextrabuttons, self.escId(o.toppagerElem));
}
}
if (o.filter) {
if (o.filteroptions) {
fpara = o.filteroptions;
}
$elem.jqGrid('filterToolbar', fpara);
}
if (o.frozen) {
$elem.jqGrid('setFrozenColumns');
}
if (o.resizable) {
if (!self.loadAtOnce) {
self.require( [
"js/base/widget" + self.minSuffix + ".js",
"js/base/mouse" + self.minSuffix + ".js",
"js/base/disable-selection" + self.minSuffix + ".js",
"js/base/plugin" + self.minSuffix + ".js",
"js/base/version" + self.minSuffix + ".js",
"js/base/resizable" + self.minSuffix + ".js"
]);
}
if (!ro) {
ro = Function('return (' + ros + ')')();
} else {
ro = {};
}
ro.start = self.pubTops($elem, o.onalw, o.resizableonstarttopics);
ro.stop = self.pubTops($elem, o.onalw, o.resizableonstoptopics);
ro.resize = self.pubTops($elem, o.onalw, o.resizableonresizetopics);
$elem.jqGrid('gridResize', ro);
}
}
if (o.ongridcompletetopics) {
self.publishTopic($elem, o.onalwaystopics, {});
self.publishTopic($elem, o.ongridcompletetopics, {});
}
};
if (o.onfocustopics) {
params.beforeSelectRow = function(rowid, e) {
var orginal = {};
orginal.rowid = rowid;
orginal.e = e;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onfocustopics, orginal);
};
}
if (o.reloadtopics) {
$.each(o.reloadtopics.split(','), function(i, rts) {
$elem.subscribe(rts, '_s2j_reloadgrid', o);
});
}
if (!params.loadtext && self.defaults.loadingText !== null) {
params.loadtext = self.defaults.loadingText;
}
params.loadComplete = self.pubCom($elem, o.onalw, o.oncom, null, null, o);
params.loadError = self.pubErr($elem, o.onalw, o.onerr, o.errortext);
if (o.grouping) {
self.require("js/plugins/grid.grouping" + self.minSuffix + ".js");
}
if (o.editurl) {
self.require(["js/plugins/grid.filter" + self.minSuffix + ".js", "js/plugins/grid.formedit" + self.minSuffix + ".js"]);
if (o.editinline) {
self.require("js/plugins/grid.inlinedit" + self.minSuffix + ".js");
}
}
if (o.cellurl) {
self.require("js/plugins/grid.celledit" + self.minSuffix + ".js");
}
if (o.navigator) {
self.require("js/plugins/grid.formedit" + self.minSuffix + ".js");
}
if (o.navigatorsearch) {
self.require("js/plugins/grid.filter" + self.minSuffix + ".js");
}
if (o.subgrid) {
self.require("js/plugins/grid.subgrid" + self.minSuffix + ".js");
params.subGrid = true;
// gridview can't be true when using the subgrid feature
params.gridview = false;
params.subGridRowExpanded = function(subgrid_id, row_id) {
var orginal = {},
so = o.subgridoptions,
subgridtableid = subgrid_id.replace(/(:|\.)/g, '\\$1') + "_table",
subgrid = $(self.escId(subgrid_id)),
subgridhtml = "
",
to = so.url.indexOf('?');
orginal.proceed = true;
if(o.onsgrowexpanded){
orginal.row_id = row_id;
orginal.subgrid_id = subgrid_id;
self.publishTopic($elem, o.onalw, orginal);
self.publishTopic($elem, o.onsgrowexpanded, orginal);
}
row_id = escape(row_id);
if(orginal.proceed) {
if ((so.pager && so.pager !== "") || so.navigator) {
subgridhtml = subgridhtml + "";
so.pager = subgrid_id.replace(/(:|\.)/g, '\\$1') + "_pager";
so.navigatoraddoptions = $.extend(true,so.navigatoraddoptions||{}, {editData:{rowid:row_id}});
so.navigatoreditoptions = $.extend(true,so.navigatoreditoptions||{}, {editData:{rowid:row_id}});
so.navigatordeleteoptions = $.extend(true,so.navigatordeleteoptions||{}, {delData:{rowid:row_id}});
}
$.each(so.colModel, function(i, col) {
if(col.editoptions && col.editoptions.dataUrl){
if(col.editoptions.dataUrl.indexOf("rowid") > 0) {
col.editoptions.dataUrl = self.changeParam(col.editoptions.dataUrl, "rowid", row_id);
}
else {
col.editoptions.dataUrl = self.addParam(col.editoptions.dataUrl, "rowid="+row_id);
}
}
if(col.searchoptions && col.searchoptions.dataUrl){
if(col.searchoptions.dataUrl.indexOf("rowid") > 0) {
col.searchoptions.dataUrl = self.changeParam(col.searchoptions.dataUrl, "rowid", row_id);
}
else {
col.searchoptions.dataUrl = self.addParam(col.searchoptions.dataUrl, "rowid="+row_id);
}
}
});
subgrid.html(subgridhtml);
if (so.url) {
if (to > 0) {
so.url = so.url.substring(0, to);
}
so.url = so.url + "?id=" + row_id;
}
subgrid = $(self.escId(subgridtableid));
so = self.parseGridParams(subgrid, so, so);
subgrid.jqGrid(so);
}
};
} else {
params.gridview = true;
}
if (o.url) {
var data = '';
if (o.formids) {
if (!self.loadAtOnce) {
self.require("js/plugins/jquery.form" + self.minSuffix + ".js");
}
$.each(o.formids.split(','), function(i, fid) {
var query = $(self.escId(fid)).formSerialize();
if (data !== '') {
data = data + '&' + query;
} else {
data = query;
}
});
}
params.url = self.addParam(o.url, data);
}
return params;
},
grid : function($elem, o) {
var self = this,
params = {};
self.log('grid for : ' + o.id);
self.require("i18n/grid.locale-" + self.gridLocal + ".js",
function() {
$.jgrid.no_legacy_api = true;
$.jgrid.useJSON = true;
});
if (!self.loadAtOnce) {
self.require([
"js/base/widget" + self.minSuffix + ".js",
"js/base/mouse" + self.minSuffix + ".js",
"js/base/position" + self.minSuffix + ".js",
"js/base/data" + self.minSuffix + ".js",
"js/base/disable-selection" + self.minSuffix + ".js",
"js/base/plugin" + self.minSuffix + ".js",
"js/base/resizable" + self.minSuffix + ".js",
"js/base/focusable" + self.minSuffix + ".js",
"js/base/keycode" + self.minSuffix + ".js",
"js/base/scroll-parent" + self.minSuffix + ".js",
"js/base/safe-active-element" + self.minSuffix + ".js",
"js/base/safe-blur" + self.minSuffix + ".js",
"js/base/tabbable" + self.minSuffix + ".js",
"js/base/unique-id" + self.minSuffix + ".js",
"js/base/version" + self.minSuffix + ".js",
"js/base/draggable" + self.minSuffix + ".js",
"js/base/button" + self.minSuffix + ".js",
"js/base/dialog" + self.minSuffix + ".js"
]);
}
self.requireCss("themes/ui.jqgrid.css");
self.require("js/base/jquery.jqGrid" + self.minSuffix + ".js");
if(o.sortable || o.sortableRows) {
if (!self.loadAtOnce) {
self.require( [
"js/base/widget" + self.minSuffix + ".js",
"js/base/mouse" + self.minSuffix + ".js",
"js/base/data" + self.minSuffix + ".js",
"js/base/ie" + self.minSuffix + ".js",
"js/base/scroll-parent" + self.minSuffix + ".js",
"js/base/version" + self.minSuffix + ".js",
"js/base/sortable" + self.minSuffix + ".js",
"js/plugins/ui.multiselect" + self.minSuffix + ".js"
]);
self.requireCss("themes/ui.multiselect.css");
}
}
$.extend(params, o);
$elem.data('_s2jg_init', false);
params = self.parseGridParams($elem, o, params);
$elem.jqGrid(params);
}
};
// Extend it from orginal plugin
$.extend(true, $.struts2_jquery_grid, $.struts2_jquery);
$.struts2_jquery_grid.debugPrefix = "[struts2_jquery_grid] ";
// Register handler for reloading grid
$.subscribeHandler('_s2j_reloadgrid', function(event, data) {
var s2jg = $.struts2_jquery_grid,
o = {},
formdata = '',
grid;
$.extend(o, event.data);
if (o.id) {
if (o.url && o.formids) {
if (o.formids) {
if (!s2jg.loadAtOnce) {
s2jg.require("js/plugins/jquery.form" + s2jg.minSuffix + ".js");
}
$.each(o.formids.split(','), function(i, fid) {
var query = $(s2jg.escId(fid)).formSerialize();
if (formdata !== '') {
formdata = formdata + '&' + query;
} else {
formdata = query;
}
});
}
o.url = s2jg.addParam(o.url, formdata);
}
grid = $(s2jg.escId(o.id));
grid.jqGrid('setGridParam', {
url : o.url
});
s2jg.log('reload grid ' + o.id);
grid.trigger("reloadGrid");
}
});
})(jQuery);
© 2015 - 2025 Weber Informatics LLC | Privacy Policy