improvement of formatter: "showlink" - free-jqgrid/jqGrid GitHub Wiki
jqGrid contains predefined formatter: "showlink"
which allows to construct anchor HTML element <a>
based on the input value of the cell and some additional options specified in formatoptions
. The following options can be included in formatoptions
: baseLinkUrl
, showAction
, addParam
, target
, idName
. The old versions of jqGrid (till 4.7) allows to construct the <a>
element in the following form (see here):
"<a " + (op.target ? "target=" + op.target : "") +
' href="' + (op.baseLinkUrl + op.showAction + '?' +
op.idName + '=' + opts.rowId + op.addParam) + '">' +
cellval + "</a>"
One can see some problems in the construct. I include just some examples of the existing problem:
- The value of
href
is static. One can't place rowid, for example, inside of URL to access RESTfull services. - Symbols
?
and=
will be always added. - There are no way to encode the inserted values by calling of
encodeURIComponent
function for example. So one can have problems if rowids contains special characters. - The value
cellval
will be displayed to the user as it be. One have no way to construct dynamic URL for example and to place some another text inside of<a>...</a>
. - One can't use the values from another columns to construct the URL or the text displayed in the anchor.
Because of the restrictions one have to use frequently custom formatters to generate the link instead of usage formatter: "showlink"
.
New version of formatter: "showlink"
supports of course all old options formatoptions
properties, but the properties can be functions. All the callback functions get the object parameter, which contains the information, which can be helpful to construct the results. The parameter have the following properties:
-
cellValue
- the cell value -
rowid
- the rowid -
rowData
- object which contains information all columns of the row. It's the same object which one have as parameter of custom formatter. -
options
- object which containsformatoptions
. One can for example include some custom properties informatoptions
(which can be different for different columns, for example). One can use the options inside of your implementations.
Additionally one can specify null
as the value of idName
option. If idName
is null
and addParam
are empty string, null
or false
then ?
and any symbols after ?
(like =
) will be added. It allows to construct pure URL without any URL parameters.
One more small feature: the idName
and rowid will be inserted in the URL encoded using encodeURIComponent
.
Additional options of formatoptions
:
-
hrefDefaultValue
with default value "#". It will be inserted as the value ofhref
if bothbaseLinkUrl
andshowAction
are empty. -
rowId
function which can be used to buildid
value other as the rowid. The rowid must be unique, so one build in some situations rowid based on some native ids of different tables of the database, by usage"_"
for example between the ids. The functionrowId
can get the required part of from the rowid which one want to use as id parameter in the URL.
All callbacks should return strings with exception addParam
which can return object which properties build parameters of the URL.
EXAMPLES:
Let us the input data for the column are strings "client1"
, "client2"
, ... Ids of the rows are values like 10, 20, 30, ...
{ id: 10, name: "client1", amount: 0, closed: false, ship_via: "TN" },
{ id: 20, name: "client2", amount: 351.75, closed: true, ship_via: "FE" },
{ id: 20, name: "client2", amount: 350, closed: false, ship_via: "DH" },
...
Below are some settings of formatoptions
and the resulting anchors which generates formatter: "showlink":
- One uses
formatoptions: {baseLinkUrl: "/myApp/Clients"}
without any additional options. It places anchors like
<a href="/myApp/Clients?id=10">Client1</a>
<a href="/myApp/Clients?id=20">Client2</a>
- One uses
formatoptions: {
baseLinkUrl: function: (options) {
return "/myApp/Clients/" + encodeURIComponent(options.rowid);
},
idName: null
}
It generates anchors like
<a href="/myApp/Clients/10">Client1</a>
<a href="/myApp/Clients/20">Client2</a>
- One uses
formatoptions: {
baseLinkUrl: function: (options) {
return "/myApp/Clients/" + encodeURIComponent(options.rowid);
},
idName: null,
addParam: function (options) {
var rowData = options.rowData;
return $.param({
amount: rowData.amount,
shipped: rowData.ship_via
});
},
cellValue: function (options) {
return '<span title="click to edit">Editing '+ options.cellValue + '</span>';
}
}
It generates anchors like
<a href="/myApp/Clients/10?amount=0&shipped=TN"><span title="click to edit">Editing Client1</span></a>
<a href="/myApp/Clients/20?amount=351.75&shipped=FE"><span title="click to edit">Editing Client2</span></a>
- One can remove
$.param
call from the implementation odaddParam
callback from the previous example
addParam: function (options) {
var rowData = options.rowData;
return {
amount: rowData.amount,
shipped: rowData.ship_via
};
}
jqGrid will generate identical code as before. The advantage of the form is in the case when one use non-empty idName
. The code
formatoptions: {
baseLinkUrl: function: (options) {
return "/myApp/Clients";
},
addParam: function (options) {
var rowData = options.rowData;
return $.param({
amount: rowData.amount,
shipped: rowData.ship_via
});
}
}
will generates the following anchors
<a href="/myApp/Clients?id=10amount=0&shipped=TN">Client1</a>
<a href="/myApp/Clients?id=20amount=351.75&shipped=FE">Client2</a>
where there is no &
symbol between id value and the name of the next parameters amount
. To fix the problem one have to use either returns object instead of string
addParam: function (options) {
var rowData = options.rowData;
return {
amount: rowData.amount,
shipped: rowData.ship_via
};
}
and jqGrid calls $.param(...)
with the object itself and pretend results with ampersand (if idName
is not null
) or to use
addParam: function (options) {
var rowData = options.rowData;
return "&" + $.param({
amount: rowData.amount,
shipped: rowData.ship_via
});
}
OnClick callback should also described here