2420 lines
123 KiB
JavaScript
2420 lines
123 KiB
JavaScript
|
/**
|
||
|
* bootstrap-table - An extended Bootstrap table with radio, checkbox, sort, pagination, and other added features. (supports twitter bootstrap v2 and v3).
|
||
|
*
|
||
|
* @version v1.14.2
|
||
|
* @homepage https://bootstrap-table.com
|
||
|
* @author wenzhixin <wenzhixin2010@gmail.com> (http://wenzhixin.net.cn/)
|
||
|
* @license MIT
|
||
|
*/
|
||
|
|
||
|
(function(e, t) {
|
||
|
if ('function' == typeof define && define.amd) define([], t);
|
||
|
else if ('undefined' != typeof exports) t();
|
||
|
else {
|
||
|
t(),
|
||
|
e.bootstrapTable = {
|
||
|
exports: {}
|
||
|
}.exports
|
||
|
}
|
||
|
})(this,
|
||
|
function() {
|
||
|
'use strict';
|
||
|
function e(e, t) {
|
||
|
if (! (e instanceof t)) throw new TypeError('Cannot call a class as a function')
|
||
|
}
|
||
|
function t(e) {
|
||
|
if (Array.isArray(e)) {
|
||
|
for (var t = 0,
|
||
|
o = Array(e.length); t < e.length; t++) o[t] = e[t];
|
||
|
return o
|
||
|
}
|
||
|
return Array.from(e)
|
||
|
}
|
||
|
var o = function() {
|
||
|
function e(e, t) {
|
||
|
for (var o, a = 0; a < t.length; a++) o = t[a],
|
||
|
o.enumerable = o.enumerable || !1,
|
||
|
o.configurable = !0,
|
||
|
'value' in o && (o.writable = !0),
|
||
|
Object.defineProperty(e, o.key, o)
|
||
|
}
|
||
|
return function(t, o, a) {
|
||
|
return o && e(t.prototype, o),
|
||
|
a && e(t, a),
|
||
|
t
|
||
|
}
|
||
|
} (),
|
||
|
a = function() {
|
||
|
function e(e, t) {
|
||
|
var o = [],
|
||
|
a = !0,
|
||
|
i = !1,
|
||
|
n = void 0;
|
||
|
try {
|
||
|
for (var s, l = e[Symbol.iterator](); ! (a = (s = l.next()).done) && (o.push(s.value), !(t && o.length === t)); a = !0);
|
||
|
} catch(e) {
|
||
|
i = !0,
|
||
|
n = e
|
||
|
} finally {
|
||
|
try { ! a && l['return'] && l['return']()
|
||
|
} finally {
|
||
|
if (i) throw n
|
||
|
}
|
||
|
}
|
||
|
return o
|
||
|
}
|
||
|
return function(t, o) {
|
||
|
if (Array.isArray(t)) return t;
|
||
|
if (Symbol.iterator in Object(t)) return e(t, o);
|
||
|
throw new TypeError('Invalid attempt to destructure non-iterable instance')
|
||
|
}
|
||
|
} (),
|
||
|
n = 'function' == typeof Symbol && 'symbol' == typeof Symbol.iterator ?
|
||
|
function(e) {
|
||
|
return typeof e
|
||
|
}: function(e) {
|
||
|
return e && 'function' == typeof Symbol && e.constructor === Symbol && e !== Symbol.prototype ? 'symbol': typeof e
|
||
|
}; (function(s) {
|
||
|
var i = 4;
|
||
|
try {
|
||
|
var g = s.fn.dropdown.Constructor.VERSION;
|
||
|
g !== void 0 && (i = parseInt(g, 10))
|
||
|
} catch(t) {}
|
||
|
var l = {
|
||
|
3 : {
|
||
|
theme: 'bootstrap3',
|
||
|
iconsPrefix: 'mdi',
|
||
|
icons: {
|
||
|
paginationSwitchDown: 'mdi-arrow-down-drop-circle-outline',
|
||
|
paginationSwitchUp: 'mdi-arrow-up-drop-circle-outline',
|
||
|
refresh: 'mdi-refresh',
|
||
|
toggleOff: 'mdi-playlist-check',
|
||
|
toggleOn: 'mdi-playlist-remove',
|
||
|
columns: 'mdi-table-column-remove',
|
||
|
detailOpen: 'mdi-plus',
|
||
|
detailClose: 'mdi-minus',
|
||
|
fullscreen: 'mdi-fullscreen'
|
||
|
},
|
||
|
classes: {
|
||
|
buttonsPrefix: 'btn',
|
||
|
buttons: 'default',
|
||
|
buttonsGroup: 'btn-group',
|
||
|
buttonsDropdown: 'btn-group',
|
||
|
pull: 'pull',
|
||
|
inputGroup: '',
|
||
|
input: 'form-control',
|
||
|
paginationDropdown: 'btn-group dropdown',
|
||
|
dropup: 'dropup',
|
||
|
dropdownActive: 'active',
|
||
|
paginationActive: 'active'
|
||
|
},
|
||
|
html: {
|
||
|
toobarDropdow: ['<ul class="dropdown-menu" role="menu">', '</ul>'],
|
||
|
toobarDropdowItem: '<li role="menuitem">%s</li>',
|
||
|
pageDropdown: ['<ul class="dropdown-menu" role="menu">', '</ul>'],
|
||
|
pageDropdownItem: '<li role="menuitem" class="%s"><a href="#">%s</a></li>',
|
||
|
dropdownCaret: '<span class="caret"></span>',
|
||
|
pagination: ['<ul class="pagination%s">', '</ul>'],
|
||
|
paginationItem: '<li class="page-item%s"><a class="page-link" href="#">%s</a></li>',
|
||
|
icon: '<i class="%s %s"></i>'
|
||
|
}
|
||
|
},
|
||
|
4 : {
|
||
|
theme: 'bootstrap4',
|
||
|
iconsPrefix: 'mdi',
|
||
|
icons: {
|
||
|
paginationSwitchDown: 'mdi-arrow-down-drop-circle-outline',
|
||
|
paginationSwitchUp: 'mdi-arrow-up-drop-circle-outline',
|
||
|
refresh: 'mdi-refresh',
|
||
|
toggleOff: 'mdi-playlist-check',
|
||
|
toggleOn: 'mdi-playlist-remove',
|
||
|
columns: 'mdi-table-column-remove',
|
||
|
fullscreen: 'mdi-fullscreen',
|
||
|
detailOpen: 'mdi-plus',
|
||
|
detailClose: 'mdi-minus'
|
||
|
},
|
||
|
classes: {
|
||
|
buttonsPrefix: 'btn',
|
||
|
buttons: 'secondary',
|
||
|
buttonsGroup: 'btn-group',
|
||
|
buttonsDropdown: 'btn-group',
|
||
|
pull: 'float',
|
||
|
inputGroup: '',
|
||
|
input: 'form-control',
|
||
|
paginationDropdown: 'btn-group dropdown',
|
||
|
dropup: 'dropup',
|
||
|
dropdownActive: 'active',
|
||
|
paginationActive: 'active'
|
||
|
},
|
||
|
html: {
|
||
|
toobarDropdow: ['<div class="dropdown-menu dropdown-menu-right">', '</div>'],
|
||
|
toobarDropdowItem: '<label class="dropdown-item">%s</label>',
|
||
|
pageDropdown: ['<div class="dropdown-menu">', '</div>'],
|
||
|
pageDropdownItem: '<a class="dropdown-item %s" href="#">%s</a>',
|
||
|
dropdownCaret: '<span class="caret"></span>',
|
||
|
pagination: ['<ul class="pagination%s">', '</ul>'],
|
||
|
paginationItem: '<li class="page-item%s"><a class="page-link" href="#">%s</a></li>',
|
||
|
icon: '<i class="%s %s"></i>'
|
||
|
}
|
||
|
}
|
||
|
} [i],
|
||
|
r = {
|
||
|
bootstrapVersion: i,
|
||
|
sprintf: function(e) {
|
||
|
for (var t = arguments.length,
|
||
|
o = Array(1 < t ? t - 1 : 0), a = 1; a < t; a++) o[a - 1] = arguments[a];
|
||
|
var n = !0,
|
||
|
s = 0,
|
||
|
i = e.replace(/%s/g,
|
||
|
function() {
|
||
|
var e = o[s++];
|
||
|
return 'undefined' == typeof e ? (n = !1, '') : e
|
||
|
});
|
||
|
return n ? i: ''
|
||
|
},
|
||
|
isEmptyObject: function() {
|
||
|
var e = 0 < arguments.length && arguments[0] !== void 0 ? arguments[0] : {};
|
||
|
return 0 ===
|
||
|
function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (e).length && e.constructor === Object
|
||
|
},
|
||
|
isNumeric: function(e) {
|
||
|
return ! isNaN(parseFloat(e)) && isFinite(e)
|
||
|
},
|
||
|
getFieldTitle: function(e, t) {
|
||
|
for (var o = e,
|
||
|
a = Array.isArray(o), i = 0, _iterator = a ? o: o[Symbol.iterator]();;) {
|
||
|
var n;
|
||
|
if (a) {
|
||
|
if (i >= o.length) break;
|
||
|
n = o[i++]
|
||
|
} else {
|
||
|
if (i = o.next(), i.done) break;
|
||
|
n = i.value
|
||
|
}
|
||
|
var s = n;
|
||
|
if (s.field === t) return s.title
|
||
|
}
|
||
|
return ''
|
||
|
},
|
||
|
setFieldIndex: function(e) {
|
||
|
for (var t = 0,
|
||
|
o = [], a = e[0], n = Array.isArray(a), s = 0, _iterator2 = n ? a: a[Symbol.iterator]();;) {
|
||
|
var l;
|
||
|
if (n) {
|
||
|
if (s >= a.length) break;
|
||
|
l = a[s++]
|
||
|
} else {
|
||
|
if (s = a.next(), s.done) break;
|
||
|
l = s.value
|
||
|
}
|
||
|
var d = l;
|
||
|
t += d.colspan || 1
|
||
|
}
|
||
|
for (var m = 0; m < e.length; m++) {
|
||
|
o[m] = [];
|
||
|
for (var i = 0; i < t; i++) o[m][i] = !1
|
||
|
}
|
||
|
for (var y = 0; y < e.length; y++) for (var c = e[y], p = Array.isArray(c), h = 0, _iterator3 = p ? c: c[Symbol.iterator]();;) {
|
||
|
var g;
|
||
|
if (p) {
|
||
|
if (h >= c.length) break;
|
||
|
g = c[h++]
|
||
|
} else {
|
||
|
if (h = c.next(), h.done) break;
|
||
|
g = h.value
|
||
|
}
|
||
|
var u = g,
|
||
|
r = u.rowspan || 1,
|
||
|
f = u.colspan || 1,
|
||
|
b = o[y].indexOf(!1);
|
||
|
1 === f && (u.fieldIndex = b, 'undefined' == typeof u.field && (u.field = b));
|
||
|
for (var w = 0; w < r; w++) o[y + w][b] = !0;
|
||
|
for (var k = 0; k < f; k++) o[y][b + k] = !0
|
||
|
}
|
||
|
},
|
||
|
getScrollBarWidth: function() {
|
||
|
if (this.cachedWidth === void 0) {
|
||
|
var e = s('<div/>').addClass('fixed-table-scroll-inner'),
|
||
|
t = s('<div/>').addClass('fixed-table-scroll-outer');
|
||
|
t.append(e),
|
||
|
s('body').append(t);
|
||
|
var o = e[0].offsetWidth;
|
||
|
t.css('overflow', 'scroll');
|
||
|
var a = e[0].offsetWidth;
|
||
|
o === a && (a = t[0].clientWidth),
|
||
|
t.remove(),
|
||
|
this.cachedWidth = o - a
|
||
|
}
|
||
|
return this.cachedWidth
|
||
|
},
|
||
|
calculateObjectValue: function(e, o, a, i) {
|
||
|
var s = o;
|
||
|
if ('string' == typeof o) {
|
||
|
var h = o.split('.');
|
||
|
if (1 < h.length) {
|
||
|
s = window;
|
||
|
for (var l = h,
|
||
|
r = Array.isArray(l), d = 0, _iterator4 = r ? l: l[Symbol.iterator]();;) {
|
||
|
var c;
|
||
|
if (r) {
|
||
|
if (d >= l.length) break;
|
||
|
c = l[d++]
|
||
|
} else {
|
||
|
if (d = l.next(), d.done) break;
|
||
|
c = d.value
|
||
|
}
|
||
|
var p = c;
|
||
|
s = s[p]
|
||
|
}
|
||
|
} else s = window[o]
|
||
|
}
|
||
|
return null !== s && 'object' === ('undefined' == typeof s ? 'undefined': n(s)) ? s: 'function' == typeof s ? s.apply(e, a || []) : !s && 'string' == typeof o && this.sprintf.apply(this, [o].concat(t(a))) ? this.sprintf.apply(this, [o].concat(t(a))) : i
|
||
|
},
|
||
|
compareObjects: function(e, t, o) {
|
||
|
var a = Object.keys(e),
|
||
|
i = Object.keys(t);
|
||
|
if (o && a.length !== i.length) return ! 1;
|
||
|
for (var n = a,
|
||
|
s = Array.isArray(n), l = 0, _iterator5 = s ? n: n[Symbol.iterator]();;) {
|
||
|
var r;
|
||
|
if (s) {
|
||
|
if (l >= n.length) break;
|
||
|
r = n[l++]
|
||
|
} else {
|
||
|
if (l = n.next(), l.done) break;
|
||
|
r = l.value
|
||
|
}
|
||
|
var d = r;
|
||
|
if ( - 1 !== i.indexOf(d) && e[d] !== t[d]) return ! 1
|
||
|
}
|
||
|
return ! 0
|
||
|
},
|
||
|
escapeHTML: function(e) {
|
||
|
return 'string' == typeof e ? e.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"').replace(/'/g, ''').replace(/`/g, '`') : e
|
||
|
},
|
||
|
getRealDataAttr: function(e) {
|
||
|
for (var t = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (e), o = Array.isArray(t), i = 0, _iterator6 = o ? t: t[Symbol.iterator]();;) {
|
||
|
var n;
|
||
|
if (o) {
|
||
|
if (i >= t.length) break;
|
||
|
n = t[i++]
|
||
|
} else {
|
||
|
if (i = t.next(), i.done) break;
|
||
|
n = i.value
|
||
|
}
|
||
|
var s = n,
|
||
|
l = a(s, 2),
|
||
|
r = l[0],
|
||
|
d = l[1],
|
||
|
c = r.split(/(?=[A-Z])/).join('-').toLowerCase();
|
||
|
c !== r && (e[c] = d, delete e[r])
|
||
|
}
|
||
|
return e
|
||
|
},
|
||
|
getItemField: function(e, t, o) {
|
||
|
var a = e;
|
||
|
if ('string' != typeof t || e.hasOwnProperty(t)) return o ? this.escapeHTML(e[t]) : e[t];
|
||
|
for (var i = t.split('.'), n = i, s = Array.isArray(n), l = 0, _iterator7 = s ? n: n[Symbol.iterator]();;) {
|
||
|
var r;
|
||
|
if (s) {
|
||
|
if (l >= n.length) break;
|
||
|
r = n[l++]
|
||
|
} else {
|
||
|
if (l = n.next(), l.done) break;
|
||
|
r = l.value
|
||
|
}
|
||
|
var d = r;
|
||
|
a = a && a[d]
|
||
|
}
|
||
|
return o ? this.escapeHTML(a) : a
|
||
|
},
|
||
|
isIEBrowser: function() {
|
||
|
return - 1 !== navigator.userAgent.indexOf('MSIE ') || /Trident.*rv:11\./.test(navigator.userAgent)
|
||
|
},
|
||
|
findIndex: function(e, t) {
|
||
|
for (var o = e,
|
||
|
a = Array.isArray(o), i = 0, _iterator8 = a ? o: o[Symbol.iterator]();;) {
|
||
|
var n;
|
||
|
if (a) {
|
||
|
if (i >= o.length) break;
|
||
|
n = o[i++]
|
||
|
} else {
|
||
|
if (i = o.next(), i.done) break;
|
||
|
n = i.value
|
||
|
}
|
||
|
var s = n;
|
||
|
if (JSON.stringify(s) === JSON.stringify(t)) return e.indexOf(s)
|
||
|
}
|
||
|
return - 1
|
||
|
}
|
||
|
},
|
||
|
d = {
|
||
|
height: void 0,
|
||
|
classes: 'table table-bordered table-hover',
|
||
|
theadClasses: '',
|
||
|
rowStyle: function() {
|
||
|
return {}
|
||
|
},
|
||
|
rowAttributes: function() {
|
||
|
return {}
|
||
|
},
|
||
|
undefinedText: '-',
|
||
|
locale: void 0,
|
||
|
sortable: !0,
|
||
|
sortClass: void 0,
|
||
|
silentSort: !0,
|
||
|
sortName: void 0,
|
||
|
sortOrder: 'asc',
|
||
|
sortStable: !1,
|
||
|
rememberOrder: !1,
|
||
|
customSort: void 0,
|
||
|
columns: [[]],
|
||
|
data: [],
|
||
|
url: void 0,
|
||
|
method: 'get',
|
||
|
cache: !0,
|
||
|
contentType: 'application/json',
|
||
|
dataType: 'json',
|
||
|
ajax: void 0,
|
||
|
ajaxOptions: {},
|
||
|
queryParams: function(e) {
|
||
|
return e
|
||
|
},
|
||
|
queryParamsType: 'limit',
|
||
|
responseHandler: function(e) {
|
||
|
return e
|
||
|
},
|
||
|
totalField: 'total',
|
||
|
dataField: 'rows',
|
||
|
pagination: !1,
|
||
|
onlyInfoPagination: !1,
|
||
|
paginationLoop: !0,
|
||
|
sidePagination: 'client',
|
||
|
totalRows: 0,
|
||
|
pageNumber: 1,
|
||
|
pageSize: 10,
|
||
|
pageList: [10, 25, 50, 100],
|
||
|
paginationHAlign: 'right',
|
||
|
paginationVAlign: 'bottom',
|
||
|
paginationDetailHAlign: 'left',
|
||
|
paginationPreText: '‹',
|
||
|
paginationNextText: '›',
|
||
|
paginationSuccessivelySize: 5,
|
||
|
paginationPagesBySide: 1,
|
||
|
paginationUseIntermediate: !1,
|
||
|
search: !1,
|
||
|
searchOnEnterKey: !1,
|
||
|
strictSearch: !1,
|
||
|
trimOnSearch: !0,
|
||
|
searchAlign: 'right',
|
||
|
searchTimeOut: 500,
|
||
|
searchText: '',
|
||
|
customSearch: void 0,
|
||
|
showHeader: !0,
|
||
|
showFooter: !1,
|
||
|
footerStyle: function() {
|
||
|
return {}
|
||
|
},
|
||
|
showColumns: !1,
|
||
|
minimumCountColumns: 1,
|
||
|
showPaginationSwitch: !1,
|
||
|
showRefresh: !1,
|
||
|
showToggle: !1,
|
||
|
showFullscreen: !1,
|
||
|
smartDisplay: !0,
|
||
|
escape: !1,
|
||
|
idField: void 0,
|
||
|
selectItemName: 'btSelectItem',
|
||
|
clickToSelect: !1,
|
||
|
ignoreClickToSelectOn: function(e) {
|
||
|
var t = e.tagName;
|
||
|
return - 1 !== ['A', 'BUTTON'].indexOf(t)
|
||
|
},
|
||
|
singleSelect: !1,
|
||
|
checkboxHeader: !0,
|
||
|
maintainSelected: !1,
|
||
|
uniqueId: void 0,
|
||
|
cardView: !1,
|
||
|
detailView: !1,
|
||
|
detailFormatter: function() {
|
||
|
return ''
|
||
|
},
|
||
|
detailFilter: function() {
|
||
|
return ! 0
|
||
|
},
|
||
|
toolbar: void 0,
|
||
|
toolbarAlign: 'left',
|
||
|
buttonsToolbar: void 0,
|
||
|
buttonsAlign: 'right',
|
||
|
buttonsPrefix: l.classes.buttonsPrefix,
|
||
|
buttonsClass: l.classes.buttons,
|
||
|
icons: l.icons,
|
||
|
iconSize: void 0,
|
||
|
iconsPrefix: l.iconsPrefix,
|
||
|
onAll: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onClickCell: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onDblClickCell: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onClickRow: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onDblClickRow: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onSort: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onCheck: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onUncheck: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onCheckAll: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onUncheckAll: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onCheckSome: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onUncheckSome: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onLoadSuccess: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onLoadError: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onColumnSwitch: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onPageChange: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onSearch: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onToggle: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onPreBody: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onPostBody: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onPostHeader: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onExpandRow: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onCollapseRow: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onRefreshOptions: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onRefresh: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onResetView: function() {
|
||
|
return ! 1
|
||
|
},
|
||
|
onScrollBody: function() {
|
||
|
return ! 1
|
||
|
}
|
||
|
},
|
||
|
c = {};
|
||
|
c['en-US'] = c.en = {
|
||
|
formatLoadingMessage: function() {
|
||
|
return 'Loading, please wait'
|
||
|
},
|
||
|
formatRecordsPerPage: function(e) {
|
||
|
return e + ' rows per page'
|
||
|
},
|
||
|
formatShowingRows: function(e, t, o) {
|
||
|
return 'Showing ' + e + ' to ' + t + ' of ' + o + ' rows'
|
||
|
},
|
||
|
formatDetailPagination: function(e) {
|
||
|
return 'Showing ' + e + ' rows'
|
||
|
},
|
||
|
formatSearch: function() {
|
||
|
return 'Search'
|
||
|
},
|
||
|
formatNoMatches: function() {
|
||
|
return 'No matching records found'
|
||
|
},
|
||
|
formatPaginationSwitch: function() {
|
||
|
return 'Hide/Show pagination'
|
||
|
},
|
||
|
formatRefresh: function() {
|
||
|
return 'Refresh'
|
||
|
},
|
||
|
formatToggle: function() {
|
||
|
return 'Toggle'
|
||
|
},
|
||
|
formatColumns: function() {
|
||
|
return 'Columns'
|
||
|
},
|
||
|
formatFullscreen: function() {
|
||
|
return 'Fullscreen'
|
||
|
},
|
||
|
formatAllRows: function() {
|
||
|
return 'All'
|
||
|
}
|
||
|
},
|
||
|
s.extend(d, c['en-US']);
|
||
|
var p = function() {
|
||
|
function t(o, a) {
|
||
|
e(this, t),
|
||
|
this.options = a,
|
||
|
this.$el = s(o),
|
||
|
this.$el_ = this.$el.clone(),
|
||
|
this.timeoutId_ = 0,
|
||
|
this.timeoutFooter_ = 0,
|
||
|
this.init()
|
||
|
}
|
||
|
return o(t, [{
|
||
|
key: 'init',
|
||
|
value: function() {
|
||
|
this.initConstants(),
|
||
|
this.initLocale(),
|
||
|
this.initContainer(),
|
||
|
this.initTable(),
|
||
|
this.initHeader(),
|
||
|
this.initData(),
|
||
|
this.initHiddenRows(),
|
||
|
this.initFooter(),
|
||
|
this.initToolbar(),
|
||
|
this.initPagination(),
|
||
|
this.initBody(),
|
||
|
this.initSearchText(),
|
||
|
this.initServer()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initConstants',
|
||
|
value: function() {
|
||
|
var e = this.options;
|
||
|
this.constants = l;
|
||
|
var t = e.buttonsPrefix ? e.buttonsPrefix + '-': '';
|
||
|
this.constants.buttonsClass = [e.buttonsPrefix, t + e.buttonsClass, r.sprintf(t + '%s', e.iconSize)].join(' ').trim()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initLocale',
|
||
|
value: function() {
|
||
|
if (this.options.locale) {
|
||
|
var e = s.fn.bootstrapTable.locales,
|
||
|
t = this.options.locale.split(/-|_/);
|
||
|
t[0] = t[0].toLowerCase(),
|
||
|
t[1] && (t[1] = t[1].toUpperCase()),
|
||
|
e[this.options.locale] ? s.extend(this.options, e[this.options.locale]) : e[t.join('-')] ? s.extend(this.options, e[t.join('-')]) : e[t[0]] && s.extend(this.options, e[t[0]])
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initContainer',
|
||
|
value: function() {
|
||
|
var e = -1 === ['top', 'both'].indexOf(this.options.paginationVAlign) ? '': '<div class="fixed-table-pagination clearfix"></div>',
|
||
|
t = -1 === ['bottom', 'both'].indexOf(this.options.paginationVAlign) ? '': '<div class="fixed-table-pagination"></div>';
|
||
|
this.$container = s('\n <div class="bootstrap-table">\n <div class="fixed-table-toolbar"></div>\n ' + e + '\n <div class="fixed-table-container">\n <div class="fixed-table-header"><table></table></div>\n <div class="fixed-table-body">\n <div class="fixed-table-loading">\n <span class="loading-wrap">\n <span class="loading-text">' + this.options.formatLoadingMessage() + '</span>\n <span class="animation-wrap"><span class="animation-dot"></span></span>\n </span>\n </div>\n </div>\n <div class="fixed-table-footer"><table><thead><tr></tr></thead></table></div>\n </div>\n ' + t + '\n </div>\n '),
|
||
|
this.$container.insertAfter(this.$el),
|
||
|
this.$tableContainer = this.$container.find('.fixed-table-container'),
|
||
|
this.$tableHeader = this.$container.find('.fixed-table-header'),
|
||
|
this.$tableBody = this.$container.find('.fixed-table-body'),
|
||
|
this.$tableLoading = this.$container.find('.fixed-table-loading'),
|
||
|
this.$tableFooter = this.$container.find('.fixed-table-footer'),
|
||
|
this.$toolbar = this.options.buttonsToolbar ? s('body').find(this.options.buttonsToolbar) : this.$container.find('.fixed-table-toolbar'),
|
||
|
this.$pagination = this.$container.find('.fixed-table-pagination'),
|
||
|
this.$tableBody.append(this.$el),
|
||
|
this.$container.after('<div class="clearfix"></div>'),
|
||
|
this.$el.addClass(this.options.classes),
|
||
|
this.$tableLoading.addClass(this.options.classes),
|
||
|
this.options.height && (this.$tableContainer.addClass('fixed-height'), this.options.showFooter && this.$tableContainer.addClass('has-footer'), -1 !== this.options.classes.split(' ').indexOf('table-bordered') && (this.$tableBody.append('<div class="fixed-table-border"></div>'), this.$tableBorder = this.$tableBody.find('.fixed-table-border'), this.$tableLoading.addClass('fixed-table-border')))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initTable',
|
||
|
value: function() {
|
||
|
var e = this,
|
||
|
o = [],
|
||
|
a = [];
|
||
|
if (this.$header = this.$el.find('>thead'), this.$header.length ? this.options.theadClasses && this.$header.addClass(this.options.theadClasses) : this.$header = s('<thead class="' + this.options.theadClasses + '"></thead>').appendTo(this.$el), this.$header.find('tr').each(function(e, t) {
|
||
|
var a = [];
|
||
|
s(t).find('th').each(function(e, t) {
|
||
|
'undefined' != typeof s(t).data('field') && s(t).data('field', '' + s(t).data('field')),
|
||
|
a.push(s.extend({},
|
||
|
{
|
||
|
title: s(t).html(),
|
||
|
class: s(t).attr('class'),
|
||
|
titleTooltip: s(t).attr('title'),
|
||
|
rowspan: s(t).attr('rowspan') ? +s(t).attr('rowspan') : void 0,
|
||
|
colspan: s(t).attr('colspan') ? +s(t).attr('colspan') : void 0
|
||
|
},
|
||
|
s(t).data()))
|
||
|
}),
|
||
|
o.push(a)
|
||
|
}), Array.isArray(this.options.columns[0]) || (this.options.columns = [this.options.columns]), this.options.columns = s.extend(!0, [], o, this.options.columns), this.columns = [], this.fieldsColumnsIndex = [], r.setFieldIndex(this.options.columns), this.options.columns.forEach(function(o, a) {
|
||
|
o.forEach(function(o, i) {
|
||
|
var n = s.extend({},
|
||
|
t.COLUMN_DEFAULTS, o);
|
||
|
'undefined' != typeof n.fieldIndex && (e.columns[n.fieldIndex] = n, e.fieldsColumnsIndex[n.field] = n.fieldIndex),
|
||
|
e.options.columns[a][i] = n
|
||
|
})
|
||
|
}), !this.options.data.length) {
|
||
|
var i = [];
|
||
|
this.$el.find('>tbody>tr').each(function(t, o) {
|
||
|
var n = {};
|
||
|
n._id = s(o).attr('id'),
|
||
|
n._class = s(o).attr('class'),
|
||
|
n._data = r.getRealDataAttr(s(o).data()),
|
||
|
s(o).find('>td').each(function(o, a) {
|
||
|
for (var l = +s(a).attr('colspan') || 1, d = +s(a).attr('rowspan') || 1, c = o; i[t] && i[t][c]; c++);
|
||
|
for (var h = c; h < c + l; h++) for (var g = t; g < t + d; g++) i[g] || (i[g] = []),
|
||
|
i[g][h] = !0;
|
||
|
var p = e.columns[c].field;
|
||
|
n[p] = s(a).html().trim(),
|
||
|
n['_' + p + '_id'] = s(a).attr('id'),
|
||
|
n['_' + p + '_class'] = s(a).attr('class'),
|
||
|
n['_' + p + '_rowspan'] = s(a).attr('rowspan'),
|
||
|
n['_' + p + '_colspan'] = s(a).attr('colspan'),
|
||
|
n['_' + p + '_title'] = s(a).attr('title'),
|
||
|
n['_' + p + '_data'] = r.getRealDataAttr(s(a).data())
|
||
|
}),
|
||
|
a.push(n)
|
||
|
}),
|
||
|
this.options.data = a,
|
||
|
a.length && (this.fromHtml = !0)
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initHeader',
|
||
|
value: function() {
|
||
|
var t = this,
|
||
|
e = {},
|
||
|
o = [];
|
||
|
this.header = {
|
||
|
fields: [],
|
||
|
styles: [],
|
||
|
classes: [],
|
||
|
formatters: [],
|
||
|
events: [],
|
||
|
sorters: [],
|
||
|
sortNames: [],
|
||
|
cellStyles: [],
|
||
|
searchables: []
|
||
|
},
|
||
|
this.options.columns.forEach(function(a, n) {
|
||
|
o.push('<tr>'),
|
||
|
0 === n && !t.options.cardView && t.options.detailView && o.push('<th class="detail" rowspan="' + t.options.columns.length + '">\n <div class="fht-cell"></div>\n </th>\n '),
|
||
|
a.forEach(function(a, i) {
|
||
|
var s = '',
|
||
|
l = '',
|
||
|
d = '',
|
||
|
c = '',
|
||
|
p = r.sprintf(' class="%s"', a['class']),
|
||
|
h = 'px',
|
||
|
g = a.width;
|
||
|
if (void 0 === a.width || t.options.cardView || 'string' != typeof a.width || -1 === a.width.indexOf('%') || (h = '%'), a.width && 'string' == typeof a.width && (g = a.width.replace('%', '').replace('px', '')), l = r.sprintf('text-align: %s; ', a.halign ? a.halign: a.align), d = r.sprintf('text-align: %s; ', a.align), c = r.sprintf('vertical-align: %s; ', a.valign), c += r.sprintf('width: %s; ', (a.checkbox || a.radio) && !g ? a.showSelectTitle ? void 0 : '36px': g ? g + h: void 0), 'undefined' != typeof a.fieldIndex) {
|
||
|
if (t.header.fields[a.fieldIndex] = a.field, t.header.styles[a.fieldIndex] = d + c, t.header.classes[a.fieldIndex] = p, t.header.formatters[a.fieldIndex] = a.formatter, t.header.events[a.fieldIndex] = a.events, t.header.sorters[a.fieldIndex] = a.sorter, t.header.sortNames[a.fieldIndex] = a.sortName, t.header.cellStyles[a.fieldIndex] = a.cellStyle, t.header.searchables[a.fieldIndex] = a.searchable, !a.visible) return;
|
||
|
if (t.options.cardView && !a.cardVisible) return;
|
||
|
e[a.field] = a
|
||
|
}
|
||
|
o.push('<th' + r.sprintf(' title="%s"', a.titleTooltip), a.checkbox || a.radio ? r.sprintf(' class="bs-checkbox %s"', a['class'] || '') : p, r.sprintf(' style="%s"', l + c), r.sprintf(' rowspan="%s"', a.rowspan), r.sprintf(' colspan="%s"', a.colspan), r.sprintf(' data-field="%s"', a.field), 0 === i && 0 < n ? ' data-not-first-th': '', '>'),
|
||
|
o.push(r.sprintf('<div class="th-inner %s">', t.options.sortable && a.sortable ? 'sortable both': '')),
|
||
|
s = t.options.escape ? r.escapeHTML(a.title) : a.title;
|
||
|
var u = s;
|
||
|
a.checkbox && (s = '', !t.options.singleSelect && t.options.checkboxHeader && (s = '<label class="lyear-checkbox checkbox-primary"><input type="checkbox" name="btSelectAll"><span></span></label>'), t.header.stateField = a.field),
|
||
|
a.radio && (s = '', t.header.stateField = a.field, t.options.singleSelect = !0),
|
||
|
!s && a.showSelectTitle && (s += u),
|
||
|
o.push(s),
|
||
|
o.push('</div>'),
|
||
|
o.push('<div class="fht-cell"></div>'),
|
||
|
o.push('</div>'),
|
||
|
o.push('</th>')
|
||
|
}),
|
||
|
o.push('</tr>')
|
||
|
}),
|
||
|
this.$header.html(o.join('')),
|
||
|
this.$header.find('th[data-field]').each(function(t, o) {
|
||
|
s(o).data(e[s(o).data('field')])
|
||
|
}),
|
||
|
this.$container.off('click', '.th-inner').on('click', '.th-inner',
|
||
|
function(o) {
|
||
|
var e = s(o.currentTarget);
|
||
|
return t.options.detailView && !e.parent().hasClass('bs-checkbox') && e.closest('.bootstrap-table')[0] !== t.$container[0] ? !1 : void(t.options.sortable && e.parent().data().sortable && t.onSort(o))
|
||
|
}),
|
||
|
this.$header.children().children().off('keypress').on('keypress',
|
||
|
function(o) {
|
||
|
if (t.options.sortable && s(o.currentTarget).data().sortable) {
|
||
|
var e = o.keyCode || o.which;
|
||
|
13 === e && t.onSort(o)
|
||
|
}
|
||
|
}),
|
||
|
s(window).off('resize.bootstrap-table'),
|
||
|
!this.options.showHeader || this.options.cardView ? (this.$header.hide(), this.$tableHeader.hide(), this.$tableLoading.css('top', 0)) : (this.$header.show(), this.$tableHeader.show(), this.$tableLoading.css('top', this.$header.outerHeight() + 1), this.getCaret(), s(window).on('resize.bootstrap-table',
|
||
|
function(o) {
|
||
|
return t.resetWidth(o)
|
||
|
})),
|
||
|
this.$selectAll = this.$header.find('[name="btSelectAll"]'),
|
||
|
this.$selectAll.off('click').on('click',
|
||
|
function(e) {
|
||
|
var o = e.currentTarget,
|
||
|
a = s(o).prop('checked');
|
||
|
t[a ? 'checkAll': 'uncheckAll'](),
|
||
|
t.updateSelected()
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initFooter',
|
||
|
value: function() { ! this.options.showFooter || this.options.cardView ? this.$tableFooter.hide() : this.$tableFooter.show()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initData',
|
||
|
value: function(e, t) {
|
||
|
this.options.data = 'append' === t ? this.options.data.concat(e) : 'prepend' === t ? [].concat(e).concat(this.options.data) : e || this.options.data,
|
||
|
this.data = this.options.data,
|
||
|
'server' === this.options.sidePagination || this.initSort()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initSort',
|
||
|
value: function() {
|
||
|
var e = this,
|
||
|
t = this.options.sortName,
|
||
|
o = 'desc' === this.options.sortOrder ? -1 : 1,
|
||
|
i = this.header.fields.indexOf(this.options.sortName),
|
||
|
a = 0; - 1 !== i && (this.options.sortStable && this.data.forEach(function(e, t) {
|
||
|
e.hasOwnProperty('_position') || (e._position = t)
|
||
|
}), this.options.customSort ? r.calculateObjectValue(this.options, this.options.customSort, [this.options.sortName, this.options.sortOrder, this.data]) : this.data.sort(function(n, a) {
|
||
|
e.header.sortNames[i] && (t = e.header.sortNames[i]);
|
||
|
var s = r.getItemField(n, t, e.options.escape),
|
||
|
l = r.getItemField(a, t, e.options.escape),
|
||
|
d = r.calculateObjectValue(e.header, e.header.sorters[i], [s, l, n, a]);
|
||
|
return void 0 === d ? ((void 0 === s || null === s) && (s = ''), (void 0 === l || null === l) && (l = ''), e.options.sortStable && s === l && (s = n._position, l = a._position), r.isNumeric(s) && r.isNumeric(l)) ? (s = parseFloat(s), l = parseFloat(l), s < l ? -1 * o: s > l ? o: 0) : s === l ? 0 : ('string' != typeof s && (s = s.toString()), -1 === s.localeCompare(l) ? -1 * o: o) : e.options.sortStable && 0 === d ? o * (n._position - a._position) : o * d
|
||
|
}), void 0 !== this.options.sortClass && (clearTimeout(a), a = setTimeout(function() {
|
||
|
e.$el.removeClass(e.options.sortClass);
|
||
|
var t = e.$header.find('[data-field="' + e.options.sortName + '"]').index();
|
||
|
e.$el.find('tr td:nth-child(' + (t + 1) + ')').addClass(e.options.sortClass)
|
||
|
},
|
||
|
250)))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onSort',
|
||
|
value: function(e) {
|
||
|
var t = e.type,
|
||
|
o = e.currentTarget,
|
||
|
a = 'keypress' === t ? s(o) : s(o).parent(),
|
||
|
i = this.$header.find('th').eq(a.index());
|
||
|
return this.$header.add(this.$header_).find('span.order').remove(),
|
||
|
this.options.sortName === a.data('field') ? this.options.sortOrder = 'asc' === this.options.sortOrder ? 'desc': 'asc': (this.options.sortName = a.data('field'), this.options.sortOrder = this.options.rememberOrder ? 'asc' === a.data('order') ? 'desc': 'asc': this.columns[this.fieldsColumnsIndex[a.data('field')]].order),
|
||
|
this.trigger('sort', this.options.sortName, this.options.sortOrder),
|
||
|
a.add(i).data('order', this.options.sortOrder),
|
||
|
this.getCaret(),
|
||
|
'server' === this.options.sidePagination ? void this.initServer(this.options.silentSort) : void(this.initSort(), this.initBody())
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initToolbar',
|
||
|
value: function() {
|
||
|
var e = this,
|
||
|
t = this.options,
|
||
|
o = [],
|
||
|
a = 0,
|
||
|
i = void 0,
|
||
|
l = void 0,
|
||
|
d = 0;
|
||
|
this.$toolbar.find('.bs-bars').children().length && s('body').append(s(t.toolbar)),
|
||
|
this.$toolbar.html(''),
|
||
|
('string' == typeof t.toolbar || 'object' === n(t.toolbar)) && s(r.sprintf('<div class="bs-bars %s-%s"></div>', this.constants.classes.pull, t.toolbarAlign)).appendTo(this.$toolbar).append(s(t.toolbar)),
|
||
|
o = ['<div class="' + ['columns', 'columns-' + t.buttonsAlign, this.constants.classes.buttonsGroup, this.constants.classes.pull + '-' + t.buttonsAlign].join(' ') + '">'],
|
||
|
'string' == typeof t.icons && (t.icons = r.calculateObjectValue(null, t.icons)),
|
||
|
t.showPaginationSwitch && o.push('<button class="' + this.constants.buttonsClass + '" type="button" name="paginationSwitch"\n aria-label="Pagination Switch" title="' + t.formatPaginationSwitch() + '">\n ' + r.sprintf(this.constants.html.icon, t.iconsPrefix, t.icons.paginationSwitchDown) + '\n </button>'),
|
||
|
t.showRefresh && o.push('<button class="' + this.constants.buttonsClass + '" type="button" name="refresh"\n aria-label="Refresh" title="' + t.formatRefresh() + '">\n ' + r.sprintf(this.constants.html.icon, t.iconsPrefix, t.icons.refresh) + '\n </button>'),
|
||
|
t.showToggle && o.push('<button class="' + this.constants.buttonsClass + '" type="button" name="toggle"\n aria-label="Toggle" title="' + t.formatToggle() + '">\n ' + r.sprintf(this.constants.html.icon, t.iconsPrefix, t.icons.toggleOff) + '\n </button>'),
|
||
|
t.showFullscreen && o.push('<button class="' + this.constants.buttonsClass + '" type="button" name="fullscreen"\n aria-label="Fullscreen" title="' + t.formatFullscreen() + '">\n ' + r.sprintf(this.constants.html.icon, t.iconsPrefix, t.icons.fullscreen) + '\n </button>'),
|
||
|
t.showColumns && (o.push('<div class="keep-open ' + this.constants.classes.buttonsDropdown + '" title="' + t.formatColumns() + '">\n <button class="' + this.constants.buttonsClass + ' dropdown-toggle" type="button" data-toggle="dropdown"\n aria-label="Columns" title="' + t.formatFullscreen() + '">\n ' + r.sprintf(this.constants.html.icon, t.iconsPrefix, t.icons.columns) + '\n ' + this.constants.html.dropdownCaret + '\n </button>\n ' + this.constants.html.toobarDropdow[0]), this.columns.forEach(function(a, n) {
|
||
|
if (! (a.radio || a.checkbox) && (!t.cardView || a.cardVisible)) {
|
||
|
var i = a.visible ? ' checked="checked"': '';
|
||
|
a.switchable && (o.push(r.sprintf(e.constants.html.toobarDropdowItem, r.sprintf('<label class="lyear-checkbox checkbox-primary"><input type="checkbox" data-field="%s" value="%s"%s> <span>%s</span></label>', a.field, n, i, a.title))), d++)
|
||
|
}
|
||
|
}), o.push(this.constants.html.toobarDropdow[1], '</div>')),
|
||
|
o.push('</div>'),
|
||
|
(this.showToolbar || 2 < o.length) && this.$toolbar.append(o.join('')),
|
||
|
t.showPaginationSwitch && this.$toolbar.find('button[name="paginationSwitch"]').off('click').on('click',
|
||
|
function() {
|
||
|
return e.togglePagination()
|
||
|
}),
|
||
|
t.showFullscreen && this.$toolbar.find('button[name="fullscreen"]').off('click').on('click',
|
||
|
function() {
|
||
|
return e.toggleFullscreen()
|
||
|
}),
|
||
|
t.showRefresh && this.$toolbar.find('button[name="refresh"]').off('click').on('click',
|
||
|
function() {
|
||
|
return e.refresh()
|
||
|
}),
|
||
|
t.showToggle && this.$toolbar.find('button[name="toggle"]').off('click').on('click',
|
||
|
function() {
|
||
|
e.toggleView()
|
||
|
}),
|
||
|
t.showColumns && (i = this.$toolbar.find('.keep-open'), d <= t.minimumCountColumns && i.find('input').prop('disabled', !0), i.find('li, label').off('click').on('click',
|
||
|
function(t) {
|
||
|
t.stopImmediatePropagation()
|
||
|
}), i.find('input').off('click').on('click',
|
||
|
function(t) {
|
||
|
var o = t.currentTarget,
|
||
|
a = s(o);
|
||
|
e.toggleColumn(a.val(), a.prop('checked'), !1),
|
||
|
e.trigger('column-switch', a.data('field'), a.prop('checked'))
|
||
|
})),
|
||
|
t.search && (o = [], o.push('<div class="' + this.constants.classes.pull + '-' + t.searchAlign + ' search ' + this.constants.classes.inputGroup + '">\n <input class="' + this.constants.classes.input + r.sprintf(' input-%s', t.iconSize) + '"\n type="text" placeholder="' + t.formatSearch() + '">\n </div>'), this.$toolbar.append(o.join('')), l = this.$toolbar.find('.search input'), l.off('keyup drop blur').on('keyup drop blur',
|
||
|
function(o) {
|
||
|
t.searchOnEnterKey && 13 !== o.keyCode || -1 !== [37, 38, 39, 40].indexOf(o.keyCode) || (clearTimeout(a), a = setTimeout(function() {
|
||
|
e.onSearch(o)
|
||
|
},
|
||
|
t.searchTimeOut))
|
||
|
}), r.isIEBrowser() && l.off('mouseup').on('mouseup',
|
||
|
function(o) {
|
||
|
clearTimeout(a),
|
||
|
a = setTimeout(function() {
|
||
|
e.onSearch(o)
|
||
|
},
|
||
|
t.searchTimeOut)
|
||
|
}))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onSearch',
|
||
|
value: function(e) {
|
||
|
var t = e.currentTarget,
|
||
|
o = e.firedByInitSearchText,
|
||
|
a = s(t).val().trim();
|
||
|
this.options.trimOnSearch && s(t).val() !== a && s(t).val(a),
|
||
|
a === this.searchText || (this.searchText = a, this.options.searchText = a, !o && (this.options.pageNumber = 1), this.initSearch(), o ? 'client' === this.options.sidePagination && this.updatePagination() : this.updatePagination(), this.trigger('search', a))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initSearch',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
if ('server' !== this.options.sidePagination) {
|
||
|
if (this.options.customSearch) return void(this.data = r.calculateObjectValue(this.options, this.options.customSearch, [this.options.data, this.searchText]));
|
||
|
var t = this.searchText && (this.options.escape ? r.escapeHTML(this.searchText) : this.searchText).toLowerCase(),
|
||
|
o = r.isEmptyObject(this.filterColumns) ? null: this.filterColumns;
|
||
|
this.data = o ? this.options.data.filter(function(e) {
|
||
|
for (var t in o) if (Array.isArray(o[t]) && -1 === o[t].indexOf(e[t]) || !Array.isArray(o[t]) && e[t] !== o[t]) return ! 1;
|
||
|
return ! 0
|
||
|
}) : this.options.data,
|
||
|
this.data = t ? this.data.filter(function(o, a) {
|
||
|
for (var c = 0; c < e.header.fields.length; c++) if (e.header.searchables[c]) {
|
||
|
var i = r.isNumeric(e.header.fields[c]) ? parseInt(e.header.fields[c], 10) : e.header.fields[c],
|
||
|
n = e.columns[e.fieldsColumnsIndex[i]],
|
||
|
s = void 0;
|
||
|
if ('string' == typeof i) {
|
||
|
s = o;
|
||
|
for (var l = i.split('.'), d = 0; d < l.length; d++) null !== s[l[d]] && (s = s[l[d]])
|
||
|
} else s = o[i];
|
||
|
if (n && n.searchFormatter && (s = r.calculateObjectValue(n, e.header.formatters[c], [s, o, a], s)), 'string' == typeof s || 'number' == typeof s) if (e.options.strictSearch) {
|
||
|
if (('' + s).toLowerCase() === t) return ! 0;
|
||
|
} else if ( - 1 !== ('' + s).toLowerCase().indexOf(t)) return ! 0
|
||
|
}
|
||
|
return ! 1
|
||
|
}) : this.data
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initPagination',
|
||
|
value: function() {
|
||
|
var e = Math.round,
|
||
|
t = this,
|
||
|
a = this.options;
|
||
|
if (!a.pagination) return void this.$pagination.hide();
|
||
|
this.$pagination.show();
|
||
|
var o = [],
|
||
|
n = !1,
|
||
|
s = void 0,
|
||
|
i = void 0,
|
||
|
l = void 0,
|
||
|
d = void 0,
|
||
|
c = void 0,
|
||
|
p = void 0,
|
||
|
h = void 0,
|
||
|
g = this.getData(),
|
||
|
u = a.pageList;
|
||
|
if ('server' !== a.sidePagination && (a.totalRows = g.length), this.totalPages = 0, a.totalRows) {
|
||
|
if (a.pageSize === a.formatAllRows()) a.pageSize = a.totalRows,
|
||
|
n = !0;
|
||
|
else if (a.pageSize === a.totalRows) {
|
||
|
var $ = 'string' == typeof a.pageList ? a.pageList.replace('[', '').replace(']', '').replace(/ /g, '').toLowerCase().split(',') : a.pageList; - 1 !== $.indexOf(a.formatAllRows().toLowerCase()) && (n = !0)
|
||
|
}
|
||
|
this.totalPages = ~~ ((a.totalRows - 1) / a.pageSize) + 1,
|
||
|
a.totalPages = this.totalPages
|
||
|
}
|
||
|
0 < this.totalPages && a.pageNumber > this.totalPages && (a.pageNumber = this.totalPages),
|
||
|
this.pageFrom = (a.pageNumber - 1) * a.pageSize + 1,
|
||
|
this.pageTo = a.pageNumber * a.pageSize,
|
||
|
this.pageTo > a.totalRows && (this.pageTo = a.totalRows);
|
||
|
var f = a.onlyInfoPagination ? a.formatDetailPagination(a.totalRows) : a.formatShowingRows(this.pageFrom, this.pageTo, a.totalRows);
|
||
|
if (o.push('<div class="' + this.constants.classes.pull + '-' + a.paginationDetailHAlign + ' pagination-detail">\n <span class="pagination-info">\n ' + f + '\n </span>'), !a.onlyInfoPagination) {
|
||
|
o.push('<span class="page-list">');
|
||
|
var P = ['<span class="' + this.constants.classes.paginationDropdown + '">\n <button class="' + this.constants.buttonsClass + ' dropdown-toggle" type="button" data-toggle="dropdown">\n <span class="page-size">\n ' + (n ? a.formatAllRows() : a.pageSize) + '\n </span>\n ' + this.constants.html.dropdownCaret + '\n </button>\n ' + this.constants.html.pageDropdown[0]];
|
||
|
if ('string' == typeof a.pageList) {
|
||
|
var C = a.pageList.replace('[', '').replace(']', '').replace(/ /g, '').split(',');
|
||
|
u = [];
|
||
|
for (var b = C,
|
||
|
m = Array.isArray(b), y = 0, _iterator9 = m ? b: b[Symbol.iterator]();;) {
|
||
|
var w;
|
||
|
if (m) {
|
||
|
if (y >= b.length) break;
|
||
|
w = b[y++]
|
||
|
} else {
|
||
|
if (y = b.next(), y.done) break;
|
||
|
w = y.value
|
||
|
}
|
||
|
var k = w;
|
||
|
u.push(k.toUpperCase() === a.formatAllRows().toUpperCase() || 'UNLIMITED' === k.toUpperCase() ? a.formatAllRows() : +k)
|
||
|
}
|
||
|
}
|
||
|
u.forEach(function(e, o) {
|
||
|
if (!a.smartDisplay || 0 === o || u[o - 1] < a.totalRows) {
|
||
|
var i;
|
||
|
i = n ? e === a.formatAllRows() ? t.constants.classes.dropdownActive: '': e === a.pageSize ? t.constants.classes.dropdownActive: '',
|
||
|
P.push(r.sprintf(t.constants.html.pageDropdownItem, i, e))
|
||
|
}
|
||
|
}),
|
||
|
P.push(this.constants.html.pageDropdown[1] + '</span>'),
|
||
|
o.push(a.formatRecordsPerPage(P.join(''))),
|
||
|
o.push('</span></div>'),
|
||
|
o.push('<div class="' + this.constants.classes.pull + '-' + a.paginationHAlign + ' pagination">', r.sprintf(this.constants.html.pagination[0], r.sprintf(' pagination-%s', a.iconSize)), r.sprintf(this.constants.html.paginationItem, ' page-pre', a.paginationPreText)),
|
||
|
this.totalPages < a.paginationSuccessivelySize ? (i = 1, l = this.totalPages) : (i = a.pageNumber - a.paginationPagesBySide, l = i + 2 * a.paginationPagesBySide),
|
||
|
a.pageNumber < a.paginationSuccessivelySize - 1 && (l = a.paginationSuccessivelySize),
|
||
|
l > this.totalPages && (l = this.totalPages),
|
||
|
a.paginationSuccessivelySize > this.totalPages - i && (i = i - (a.paginationSuccessivelySize - (this.totalPages - i)) + 1),
|
||
|
1 > i && (i = 1),
|
||
|
l > this.totalPages && (l = this.totalPages);
|
||
|
var v = e(a.paginationPagesBySide / 2),
|
||
|
x = function(e) {
|
||
|
var o = 1 < arguments.length && void 0 !== arguments[1] ? arguments[1] : '';
|
||
|
return r.sprintf(t.constants.html.paginationItem, o + (e === a.pageNumber ? ' ' + t.constants.classes.paginationActive: ''), e)
|
||
|
};
|
||
|
if (1 < i) {
|
||
|
var T = a.paginationPagesBySide;
|
||
|
for (T >= i && (T = i - 1), s = 1; s <= T; s++) o.push(x(s));
|
||
|
i - 1 === T + 1 ? (s = i - 1, o.push(x(s))) : i - 1 > T && (i - 2 * a.paginationPagesBySide > a.paginationPagesBySide && a.paginationUseIntermediate ? (s = e((i - v) / 2 + v), o.push(x(s, ' page-intermediate'))) : o.push(r.sprintf(this.constants.html.paginationItem, ' page-first-separator disabled', '...')))
|
||
|
}
|
||
|
for (s = i; s <= l; s++) o.push(x(s));
|
||
|
if (this.totalPages > l) {
|
||
|
var A = this.totalPages - (a.paginationPagesBySide - 1);
|
||
|
for (l >= A && (A = l + 1), l + 1 === A - 1 ? (s = l + 1, o.push(x(s))) : A > l + 1 && (this.totalPages - l > 2 * a.paginationPagesBySide && a.paginationUseIntermediate ? (s = e((this.totalPages - v - l) / 2 + l), o.push(x(s, ' page-intermediate'))) : o.push(r.sprintf(this.constants.html.paginationItem, ' page-last-separator disabled', '...'))), s = A; s <= this.totalPages; s++) o.push(x(s))
|
||
|
}
|
||
|
o.push(r.sprintf(this.constants.html.paginationItem, ' page-next', a.paginationNextText)),
|
||
|
o.push(this.constants.html.pagination[1], '</div>')
|
||
|
}
|
||
|
this.$pagination.html(o.join(''));
|
||
|
var S = -1 === ['bottom', 'both'].indexOf(a.paginationVAlign) ? '': ' ' + this.constants.classes.dropup;
|
||
|
this.$pagination.last().find('.page-list > span').addClass(S),
|
||
|
a.onlyInfoPagination || (d = this.$pagination.find('.page-list a'), c = this.$pagination.find('.page-pre'), p = this.$pagination.find('.page-next'), h = this.$pagination.find('.page-item').not('.page-next, .page-pre'), a.smartDisplay && (1 >= this.totalPages && this.$pagination.find('div.pagination').hide(), (2 > u.length || a.totalRows <= u[0]) && this.$pagination.find('span.page-list').hide(), this.$pagination[this.getData().length ? 'show': 'hide']()), !a.paginationLoop && (1 === a.pageNumber && c.addClass('disabled'), a.pageNumber === this.totalPages && p.addClass('disabled')), n && (a.pageSize = a.formatAllRows()), d.off('click').on('click',
|
||
|
function(o) {
|
||
|
return t.onPageListChange(o)
|
||
|
}), c.off('click').on('click',
|
||
|
function(o) {
|
||
|
return t.onPagePre(o)
|
||
|
}), p.off('click').on('click',
|
||
|
function(o) {
|
||
|
return t.onPageNext(o)
|
||
|
}), h.off('click').on('click',
|
||
|
function(o) {
|
||
|
return t.onPageNumber(o)
|
||
|
}))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updatePagination',
|
||
|
value: function(e) {
|
||
|
e && s(e.currentTarget).hasClass('disabled') || (!this.options.maintainSelected && this.resetRows(), this.initPagination(), 'server' === this.options.sidePagination ? this.initServer() : this.initBody(), this.trigger('page-change', this.options.pageNumber, this.options.pageSize))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onPageListChange',
|
||
|
value: function(e) {
|
||
|
e.preventDefault();
|
||
|
var t = s(e.currentTarget);
|
||
|
return t.parent().addClass(this.constants.classes.dropdownActive).siblings().removeClass(this.constants.classes.dropdownActive),
|
||
|
this.options.pageSize = t.text().toUpperCase() === this.options.formatAllRows().toUpperCase() ? this.options.formatAllRows() : +t.text(),
|
||
|
this.$toolbar.find('.page-size').text(this.options.pageSize),
|
||
|
this.updatePagination(e),
|
||
|
!1
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onPagePre',
|
||
|
value: function(e) {
|
||
|
return e.preventDefault(),
|
||
|
0 == this.options.pageNumber - 1 ? this.options.pageNumber = this.options.totalPages: this.options.pageNumber--,
|
||
|
this.updatePagination(e),
|
||
|
!1
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onPageNext',
|
||
|
value: function(e) {
|
||
|
return e.preventDefault(),
|
||
|
this.options.pageNumber + 1 > this.options.totalPages ? this.options.pageNumber = 1 : this.options.pageNumber++,
|
||
|
this.updatePagination(e),
|
||
|
!1
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'onPageNumber',
|
||
|
value: function(e) {
|
||
|
if (e.preventDefault(), this.options.pageNumber !== +s(e.currentTarget).text()) return this.options.pageNumber = +s(e.currentTarget).text(),
|
||
|
this.updatePagination(e),
|
||
|
!1
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initRow',
|
||
|
value: function(e, t) {
|
||
|
var o = this,
|
||
|
i = [],
|
||
|
n = {},
|
||
|
s = [],
|
||
|
l = '',
|
||
|
d = {},
|
||
|
c = [];
|
||
|
if (! ( - 1 < r.findIndex(this.hiddenRows, e))) {
|
||
|
if (n = r.calculateObjectValue(this.options, this.options.rowStyle, [e, t], n), n && n.css) for (var p = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (n.css), h = Array.isArray(p), g = 0, _iterator10 = h ? p: p[Symbol.iterator]();;) {
|
||
|
var u;
|
||
|
if (h) {
|
||
|
if (g >= p.length) break;
|
||
|
u = p[g++]
|
||
|
} else {
|
||
|
if (g = p.next(), g.done) break;
|
||
|
u = g.value
|
||
|
}
|
||
|
var f = u,
|
||
|
b = a(f, 2),
|
||
|
m = b[0],
|
||
|
y = b[1];
|
||
|
s.push(m + ': ' + y)
|
||
|
}
|
||
|
if (d = r.calculateObjectValue(this.options, this.options.rowAttributes, [e, t], d), d) for (var w = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (d), x = Array.isArray(w), S = 0, _iterator11 = x ? w: w[Symbol.iterator]();;) {
|
||
|
var $;
|
||
|
if (x) {
|
||
|
if (S >= w.length) break;
|
||
|
$ = w[S++]
|
||
|
} else {
|
||
|
if (S = w.next(), S.done) break;
|
||
|
$ = S.value
|
||
|
}
|
||
|
var P = $,
|
||
|
C = a(P, 2),
|
||
|
T = C[0],
|
||
|
A = C[1];
|
||
|
c.push(T + '="' + r.escapeHTML(A) + '"')
|
||
|
}
|
||
|
if (e._data && !r.isEmptyObject(e._data)) for (var O = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (e._data), I = Array.isArray(O), R = 0, _iterator12 = I ? O: O[Symbol.iterator]();;) {
|
||
|
var _;
|
||
|
if (I) {
|
||
|
if (R >= O.length) break;
|
||
|
_ = O[R++]
|
||
|
} else {
|
||
|
if (R = O.next(), R.done) break;
|
||
|
_ = R.value
|
||
|
}
|
||
|
var V = _,
|
||
|
F = a(V, 2),
|
||
|
B = F[0],
|
||
|
k = F[1];
|
||
|
if ('index' === B) return;
|
||
|
l += ' data-' + B + '="' + k + '"'
|
||
|
}
|
||
|
return i.push('<tr', r.sprintf(' %s', c.length ? c.join(' ') : void 0), r.sprintf(' id="%s"', Array.isArray(e) ? void 0 : e._id), r.sprintf(' class="%s"', n.classes || (Array.isArray(e) ? void 0 : e._class)), ' data-index="' + t + '"', r.sprintf(' data-uniqueid="%s"', e[this.options.uniqueId]), r.sprintf('%s', l), '>'),
|
||
|
this.options.cardView && i.push('<td colspan="' + this.header.fields.length + '"><div class="card-views">'),
|
||
|
!this.options.cardView && this.options.detailView && (i.push('<td>'), r.calculateObjectValue(null, this.options.detailFilter, [t, e]) && i.push('\n <a class="detail-icon" href="#">\n ' + r.sprintf(this.constants.html.icon, this.options.iconsPrefix, this.options.icons.detailOpen) + '\n </a>\n '), i.push('</td>')),
|
||
|
this.header.fields.forEach(function(n, l) {
|
||
|
var d = '',
|
||
|
p = r.getItemField(e, n, o.options.escape),
|
||
|
h = '',
|
||
|
g = '',
|
||
|
z = '',
|
||
|
u = {},
|
||
|
f = '',
|
||
|
b = o.header.classes[l],
|
||
|
m = '',
|
||
|
y = '',
|
||
|
w = '',
|
||
|
k = '',
|
||
|
v = '',
|
||
|
x = o.columns[l];
|
||
|
if ((!o.fromHtml || 'undefined' != typeof p || x.checkbox || x.radio) && x.visible && (!o.options.cardView || x.cardVisible)) {
|
||
|
if (x.escape && (p = r.escapeHTML(p)), s.concat([o.header.styles[l]]).length && (m = ' style="' + s.concat([o.header.styles[l]]).join('; ') + '"'), e['_' + n + '_id'] && (f = r.sprintf(' id="%s"', e['_' + n + '_id'])), e['_' + n + '_class'] && (b = r.sprintf(' class="%s"', e['_' + n + '_class'])), e['_' + n + '_rowspan'] && (w = r.sprintf(' rowspan="%s"', e['_' + n + '_rowspan'])), e['_' + n + '_colspan'] && (k = r.sprintf(' colspan="%s"', e['_' + n + '_colspan'])), e['_' + n + '_title'] && (v = r.sprintf(' title="%s"', e['_' + n + '_title'])), u = r.calculateObjectValue(o.header, o.header.cellStyles[l], [p, e, t, n], u), u.classes && (b = ' class="' + u.classes + '"'), u.css) {
|
||
|
for (var S = [], $ = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (u.css), P = Array.isArray($), C = 0, _iterator13 = P ? $: $[Symbol.iterator]();;) {
|
||
|
var T;
|
||
|
if (P) {
|
||
|
if (C >= $.length) break;
|
||
|
T = $[C++]
|
||
|
} else {
|
||
|
if (C = $.next(), C.done) break;
|
||
|
T = C.value
|
||
|
}
|
||
|
var A = T,
|
||
|
O = a(A, 2),
|
||
|
I = O[0],
|
||
|
R = O[1];
|
||
|
S.push(I + ': ' + R)
|
||
|
}
|
||
|
m = ' style="' + S.concat(o.header.styles[l]).join('; ') + '"'
|
||
|
}
|
||
|
if (h = r.calculateObjectValue(x, o.header.formatters[l], [p, e, t, n], p), e['_' + n + '_data'] && !r.isEmptyObject(e['_' + n + '_data'])) for (var _ = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (e['_' + n + '_data']), V = Array.isArray(_), F = 0, _iterator14 = V ? _: _[Symbol.iterator]();;) {
|
||
|
var B;
|
||
|
if (V) {
|
||
|
if (F >= _.length) break;
|
||
|
B = _[F++]
|
||
|
} else {
|
||
|
if (F = _.next(), F.done) break;
|
||
|
B = F.value
|
||
|
}
|
||
|
var N = B,
|
||
|
j = a(N, 2),
|
||
|
H = j[0],
|
||
|
L = j[1];
|
||
|
if ('index' === H) return;
|
||
|
y += ' data-' + H + '="' + L + '"'
|
||
|
}
|
||
|
if (x.checkbox || x.radio) {
|
||
|
g = x.checkbox ? 'checkbox': g,
|
||
|
g = x.radio ? 'radio': g;
|
||
|
z = x.checkbox ? 'lyear-checkbox checkbox-primary' : z,
|
||
|
z = x.radio ? 'lyear-radio radio-primary' : z;
|
||
|
var D = x['class'] || '',
|
||
|
c = !0 === h || p || h && h.checked,
|
||
|
E = !x.checkboxEnabled || h && h.disabled;
|
||
|
d = [o.options.cardView ? '<div class="card-view ' + D + '">': '<td class="bs-checkbox ' + D + '">', '<label class=" ' + z + ' ">\n <input\n data-index="' + t + '"\n name="' + o.options.selectItemName + '"\n type="' + g + '"\n ' + r.sprintf('value="%s"', e[o.options.idField]) + '\n ' + r.sprintf('checked="%s"', c ? 'checked': void 0) + '\n ' + r.sprintf('disabled="%s"', E ? 'disabled': void 0) + ' />\n <span></span>\n </label>', o.header.formatters[l] && 'string' == typeof h ? h: '', o.options.cardView ? '</div>': '</td>'].join(''),
|
||
|
e[o.header.stateField] = !0 === h || !!p || h && h.checked
|
||
|
} else if (h = 'undefined' == typeof h || null === h ? o.options.undefinedText: h, o.options.cardView) {
|
||
|
var U = o.options.showHeader ? '<span class="card-view-title"' + m + '>' + r.getFieldTitle(o.columns, n) + '</span>': '';
|
||
|
d = '<div class="card-view">' + U + '<span class="card-view-value">' + h + '</span></div>',
|
||
|
o.options.smartDisplay && '' === h && (d = '<div class="card-view"></div>')
|
||
|
} else d = '<td' + f + b + m + y + w + k + v + '>' + h + '</td>';
|
||
|
i.push(d)
|
||
|
}
|
||
|
}),
|
||
|
this.options.cardView && i.push('</div></td>'),
|
||
|
i.push('</tr>'),
|
||
|
i.join('')
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initBody',
|
||
|
value: function(e) {
|
||
|
var t = this,
|
||
|
o = this.getData();
|
||
|
this.trigger('pre-body', o),
|
||
|
this.$body = this.$el.find('>tbody'),
|
||
|
this.$body.length || (this.$body = s('<tbody></tbody>').appendTo(this.$el)),
|
||
|
this.options.pagination && 'server' !== this.options.sidePagination || (this.pageFrom = 1, this.pageTo = o.length);
|
||
|
for (var n = s(document.createDocumentFragment()), l = !1, d = this.pageFrom - 1; d < this.pageTo; d++) {
|
||
|
var i = o[d],
|
||
|
c = this.initRow(i, d, o, n);
|
||
|
l = l || !!c,
|
||
|
c && 'string' == typeof c && n.append(c)
|
||
|
}
|
||
|
l ? this.$body.html(n) : this.$body.html('<tr class="no-records-found">' + r.sprintf('<td colspan="%s">%s</td>', this.$header.find('th').length, this.options.formatNoMatches()) + '</tr>'),
|
||
|
e || this.scrollTo(0),
|
||
|
this.$body.find('> tr[data-index] > td').off('click dblclick').on('click dblclick',
|
||
|
function(e) {
|
||
|
var o = e.currentTarget,
|
||
|
a = e.type,
|
||
|
i = e.target,
|
||
|
n = s(o),
|
||
|
l = n.parent(),
|
||
|
d = s(i).parents('.card-views').children(),
|
||
|
c = s(i).parents('.card-view'),
|
||
|
p = t.data[l.data('index')],
|
||
|
h = t.options.cardView ? d.index(c) : n[0].cellIndex,
|
||
|
g = t.getVisibleFields(),
|
||
|
u = g[t.options.detailView && !t.options.cardView ? h - 1 : h],
|
||
|
f = t.columns[t.fieldsColumnsIndex[u]],
|
||
|
b = r.getItemField(p, u, t.options.escape);
|
||
|
if (!n.find('.detail-icon').length && (t.trigger('click' === a ? 'click-cell': 'dbl-click-cell', u, b, p, n), t.trigger('click' === a ? 'click-row': 'dbl-click-row', p, l, u), 'click' === a && t.options.clickToSelect && f.clickToSelect && !r.calculateObjectValue(t.options, t.options.ignoreClickToSelectOn, [i]))) {
|
||
|
var m = l.find(r.sprintf('[name="%s"]', t.options.selectItemName));
|
||
|
m.length && m[0].click()
|
||
|
}
|
||
|
}),
|
||
|
this.$body.find('> tr[data-index] > td > .detail-icon').off('click').on('click',
|
||
|
function(a) {
|
||
|
a.preventDefault();
|
||
|
var e = s(a.currentTarget),
|
||
|
i = e.parent().parent(),
|
||
|
n = i.data('index'),
|
||
|
l = o[n];
|
||
|
if (i.next().is('tr.detail-view')) e.html(r.sprintf(t.constants.html.icon, t.options.iconsPrefix, t.options.icons.detailOpen)),
|
||
|
t.trigger('collapse-row', n, l, i.next()),
|
||
|
i.next().remove();
|
||
|
else {
|
||
|
e.html(r.sprintf(t.constants.html.icon, t.options.iconsPrefix, t.options.icons.detailClose)),
|
||
|
i.after(r.sprintf('<tr class="detail-view"><td colspan="%s"></td></tr>', i.children('td').length));
|
||
|
var d = i.next().find('td'),
|
||
|
c = r.calculateObjectValue(t.options, t.options.detailFormatter, [n, l, d], '');
|
||
|
1 === d.length && d.append(c),
|
||
|
t.trigger('expand-row', n, l, d)
|
||
|
}
|
||
|
return t.resetView(),
|
||
|
!1
|
||
|
}),
|
||
|
this.$selectItem = this.$body.find(r.sprintf('[name="%s"]', this.options.selectItemName)),
|
||
|
this.$selectItem.off('click').on('click',
|
||
|
function(o) {
|
||
|
o.stopImmediatePropagation();
|
||
|
var e = s(o.currentTarget);
|
||
|
t.check_(e.prop('checked'), e.data('index'))
|
||
|
}),
|
||
|
this.header.events.forEach(function(e, o) {
|
||
|
var i = e;
|
||
|
if (i) {
|
||
|
'string' == typeof i && (i = r.calculateObjectValue(null, i));
|
||
|
var n = t.header.fields[o],
|
||
|
l = t.getVisibleFields().indexOf(n);
|
||
|
if ( - 1 !== l) {
|
||
|
t.options.detailView && !t.options.cardView && (l += 1);
|
||
|
for (var d = function() {
|
||
|
if (p) {
|
||
|
if (h >= c.length) return 'break';
|
||
|
g = c[h++]
|
||
|
} else {
|
||
|
if (h = c.next(), h.done) return 'break';
|
||
|
g = h.value
|
||
|
}
|
||
|
var e = g,
|
||
|
o = a(e, 2),
|
||
|
r = o[0],
|
||
|
i = o[1];
|
||
|
t.$body.find('>tr:not(.no-records-found)').each(function(e, o) {
|
||
|
var a = s(o),
|
||
|
d = a.find(t.options.cardView ? '.card-view': 'td').eq(l),
|
||
|
c = r.indexOf(' '),
|
||
|
p = r.substring(0, c),
|
||
|
h = r.substring(c + 1);
|
||
|
d.find(h).off(p).on(p,
|
||
|
function(o) {
|
||
|
var e = a.data('index'),
|
||
|
s = t.data[e],
|
||
|
l = s[n];
|
||
|
i.apply(t, [o, l, s, e])
|
||
|
})
|
||
|
})
|
||
|
},
|
||
|
c = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (i), p = Array.isArray(c), h = 0, _iterator15 = p ? c: c[Symbol.iterator]();;) {
|
||
|
var g, u = d();
|
||
|
if ('break' === u) break
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}),
|
||
|
this.updateSelected(),
|
||
|
this.resetView(),
|
||
|
this.trigger('post-body', o)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initServer',
|
||
|
value: function(e, t, o) {
|
||
|
var a = this,
|
||
|
i = {},
|
||
|
n = this.header.fields.indexOf(this.options.sortName),
|
||
|
l = {
|
||
|
searchText: this.searchText,
|
||
|
sortName: this.options.sortName,
|
||
|
sortOrder: this.options.sortOrder
|
||
|
};
|
||
|
if ((this.header.sortNames[n] && (l.sortName = this.header.sortNames[n]), this.options.pagination && 'server' === this.options.sidePagination && (l.pageSize = this.options.pageSize === this.options.formatAllRows() ? this.options.totalRows: this.options.pageSize, l.pageNumber = this.options.pageNumber), o || this.options.url || this.options.ajax) && ('limit' === this.options.queryParamsType && (l = {
|
||
|
search: l.searchText,
|
||
|
sort: l.sortName,
|
||
|
order: l.sortOrder
|
||
|
},
|
||
|
this.options.pagination && 'server' === this.options.sidePagination && (l.offset = this.options.pageSize === this.options.formatAllRows() ? 0 : this.options.pageSize * (this.options.pageNumber - 1), l.limit = this.options.pageSize === this.options.formatAllRows() ? this.options.totalRows: this.options.pageSize, 0 === l.limit && delete l.limit)), r.isEmptyObject(this.filterColumnsPartial) || (l.filter = JSON.stringify(this.filterColumnsPartial, null)), i = r.calculateObjectValue(this.options, this.options.queryParams, [l], i), s.extend(i, t || {}), !1 !== i)) {
|
||
|
e || this.showLoading();
|
||
|
var d = s.extend({},
|
||
|
r.calculateObjectValue(null, this.options.ajaxOptions), {
|
||
|
type: this.options.method,
|
||
|
url: o || this.options.url,
|
||
|
data: 'application/json' === this.options.contentType && 'post' === this.options.method ? JSON.stringify(i) : i,
|
||
|
cache: this.options.cache,
|
||
|
contentType: this.options.contentType,
|
||
|
dataType: this.options.dataType,
|
||
|
success: function(t) {
|
||
|
var o = r.calculateObjectValue(a.options, a.options.responseHandler, [t], t);
|
||
|
a.load(o),
|
||
|
a.trigger('load-success', o),
|
||
|
e || a.hideLoading()
|
||
|
},
|
||
|
error: function(t) {
|
||
|
var o = [];
|
||
|
'server' === a.options.sidePagination && (o = {},
|
||
|
o[a.options.totalField] = 0, o[a.options.dataField] = []),
|
||
|
a.load(o),
|
||
|
a.trigger('load-error', t.status, t),
|
||
|
e || a.$tableLoading.hide()
|
||
|
}
|
||
|
});
|
||
|
return this.options.ajax ? r.calculateObjectValue(this, this.options.ajax, [d], null) : (this._xhr && 4 !== this._xhr.readyState && this._xhr.abort(), this._xhr = s.ajax(d)),
|
||
|
i
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initSearchText',
|
||
|
value: function() {
|
||
|
if (this.options.search && (this.searchText = '', '' !== this.options.searchText)) {
|
||
|
var e = this.$toolbar.find('.search input');
|
||
|
e.val(this.options.searchText),
|
||
|
this.onSearch({
|
||
|
currentTarget: e,
|
||
|
firedByInitSearchText: !0
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getCaret',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
this.$header.find('th').each(function(t, o) {
|
||
|
s(o).find('.sortable').removeClass('desc asc').addClass(s(o).data('field') === e.options.sortName ? e.options.sortOrder: 'both')
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateSelected',
|
||
|
value: function() {
|
||
|
var e = this.$selectItem.filter(':enabled').length && this.$selectItem.filter(':enabled').length === this.$selectItem.filter(':enabled').filter(':checked').length;
|
||
|
this.$selectAll.add(this.$selectAll_).prop('checked', e),
|
||
|
this.$selectItem.each(function(e, t) {
|
||
|
s(t).closest('tr')[s(t).prop('checked') ? 'addClass': 'removeClass']('selected')
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateRows',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
this.$selectItem.each(function(t, o) {
|
||
|
e.data[s(o).data('index')][e.header.stateField] = s(o).prop('checked')
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetRows',
|
||
|
value: function() {
|
||
|
for (var e = this.data,
|
||
|
t = Array.isArray(e), o = 0, _iterator16 = t ? e: e[Symbol.iterator]();;) {
|
||
|
var a;
|
||
|
if (t) {
|
||
|
if (o >= e.length) break;
|
||
|
a = e[o++]
|
||
|
} else {
|
||
|
if (o = e.next(), o.done) break;
|
||
|
a = o.value
|
||
|
}
|
||
|
var i = a;
|
||
|
this.$selectAll.prop('checked', !1),
|
||
|
this.$selectItem.prop('checked', !1),
|
||
|
this.header.stateField && (i[this.header.stateField] = !1)
|
||
|
}
|
||
|
this.initHiddenRows()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'trigger',
|
||
|
value: function(e) {
|
||
|
for (var o, a = e + '.bs.table',
|
||
|
i = arguments.length,
|
||
|
n = Array(1 < i ? i - 1 : 0), l = 1; l < i; l++) n[l - 1] = arguments[l]; (o = this.options)[t.EVENTS[a]].apply(o, n),
|
||
|
this.$el.trigger(s.Event(a), n),
|
||
|
this.options.onAll(a, n),
|
||
|
this.$el.trigger(s.Event('all.bs.table'), [a, n])
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetHeader',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
clearTimeout(this.timeoutId_),
|
||
|
this.timeoutId_ = setTimeout(function() {
|
||
|
return e.fitHeader()
|
||
|
},
|
||
|
this.$el.is(':hidden') ? 100 : 0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'fitHeader',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
if (this.$el.is(':hidden')) return void(this.timeoutId_ = setTimeout(function() {
|
||
|
return e.fitHeader()
|
||
|
},
|
||
|
100));
|
||
|
var t = this.$tableBody.get(0),
|
||
|
o = t.scrollWidth > t.clientWidth && t.scrollHeight > t.clientHeight + this.$header.outerHeight() ? r.getScrollBarWidth() : 0;
|
||
|
this.$el.css('margin-top', -this.$header.outerHeight());
|
||
|
var a = s(':focus');
|
||
|
if (0 < a.length) {
|
||
|
var c = a.parents('th');
|
||
|
if (0 < c.length) {
|
||
|
var p = c.attr('data-field');
|
||
|
if (void 0 !== p) {
|
||
|
var h = this.$header.find('[data-field=\'' + p + '\']');
|
||
|
0 < h.length && h.find(':input').addClass('focus-temp')
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
this.$header_ = this.$header.clone(!0, !0),
|
||
|
this.$selectAll_ = this.$header_.find('[name="btSelectAll"]'),
|
||
|
this.$tableHeader.css('margin-right', o).find('table').css('width', this.$el.outerWidth()).html('').attr('class', this.$el.attr('class')).append(this.$header_),
|
||
|
this.$tableLoading.css('width', this.$el.outerWidth());
|
||
|
var i = s('.focus-temp:visible:eq(0)');
|
||
|
0 < i.length && (i.focus(), this.$header.find('.focus-temp').removeClass('focus-temp')),
|
||
|
this.$header.find('th[data-field]').each(function(t, o) {
|
||
|
e.$header_.find(r.sprintf('th[data-field="%s"]', s(o).data('field'))).data(s(o).data())
|
||
|
});
|
||
|
for (var n = this.getVisibleFields(), l = this.$header_.find('th'), d = this.$body.find('>tr:first-child:not(.no-records-found)'); d.length && d.find('>td[colspan]:not([colspan="1"])').length;) d = d.next();
|
||
|
d.find('> *').each(function(t, o) {
|
||
|
var a = s(o),
|
||
|
i = t;
|
||
|
if (e.options.detailView && !e.options.cardView) {
|
||
|
if (0 === t) {
|
||
|
var d = l.filter('.detail'),
|
||
|
c = d.width() - d.find('.fht-cell').width();
|
||
|
d.find('.fht-cell').width(a.innerWidth() - c)
|
||
|
}
|
||
|
i = t - 1
|
||
|
}
|
||
|
if ( - 1 !== i) {
|
||
|
var p = e.$header_.find(r.sprintf('th[data-field="%s"]', n[i]));
|
||
|
1 < p.length && (p = s(l[a[0].cellIndex]));
|
||
|
var h = p.width() - p.find('.fht-cell').width();
|
||
|
p.find('.fht-cell').width(a.innerWidth() - h)
|
||
|
}
|
||
|
}),
|
||
|
this.horizontalScroll(),
|
||
|
this.trigger('post-header')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetFooter',
|
||
|
value: function() {
|
||
|
var e = this.getData(),
|
||
|
t = [];
|
||
|
if (this.options.showFooter && !this.options.cardView) { ! this.options.cardView && this.options.detailView && t.push('<th class="detail"><div class="th-inner"></div><div class="fht-cell"></div></th>');
|
||
|
for (var o = this.columns,
|
||
|
i = Array.isArray(o), n = 0, _iterator17 = i ? o: o[Symbol.iterator]();;) {
|
||
|
var s;
|
||
|
if (i) {
|
||
|
if (n >= o.length) break;
|
||
|
s = o[n++]
|
||
|
} else {
|
||
|
if (n = o.next(), n.done) break;
|
||
|
s = n.value
|
||
|
}
|
||
|
var l = s,
|
||
|
d = '',
|
||
|
c = '',
|
||
|
p = [],
|
||
|
h = {},
|
||
|
g = r.sprintf(' class="%s"', l['class']);
|
||
|
if (l.visible) {
|
||
|
if (this.options.cardView && !l.cardVisible) return;
|
||
|
if (d = r.sprintf('text-align: %s; ', l.falign ? l.falign: l.align), c = r.sprintf('vertical-align: %s; ', l.valign), h = r.calculateObjectValue(null, this.options.footerStyle, [l]), h && h.css) for (var u = function(e) {
|
||
|
return Object.keys(e).map(function(t) {
|
||
|
return [t, e[t]]
|
||
|
})
|
||
|
} (h.css), f = Array.isArray(u), b = 0, _iterator18 = f ? u: u[Symbol.iterator]();;) {
|
||
|
var m;
|
||
|
if (f) {
|
||
|
if (b >= u.length) break;
|
||
|
m = u[b++]
|
||
|
} else {
|
||
|
if (b = u.next(), b.done) break;
|
||
|
m = b.value
|
||
|
}
|
||
|
var y = m,
|
||
|
w = a(y, 2),
|
||
|
k = w[0],
|
||
|
v = w[1];
|
||
|
p.push(k + ': ' + v)
|
||
|
}
|
||
|
h && h.classes && (g = r.sprintf(' class="%s"', l['class'] ? [l['class'], h.classes].join(' ') : h.classes)),
|
||
|
t.push('<th', g, r.sprintf(' style="%s"', d + c + p.concat().join('; ')), '>'),
|
||
|
t.push('<div class="th-inner">'),
|
||
|
t.push(r.calculateObjectValue(l, l.footerFormatter, [e], '')),
|
||
|
t.push('</div>'),
|
||
|
t.push('<div class="fht-cell"></div>'),
|
||
|
t.push('</div>'),
|
||
|
t.push('</th>')
|
||
|
}
|
||
|
}
|
||
|
this.$tableFooter.find('tr').html(t.join('')),
|
||
|
this.$tableFooter.show(),
|
||
|
this.fitFooter()
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'fitFooter',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
if (this.$el.is(':hidden')) return void setTimeout(function() {
|
||
|
return e.fitFooter()
|
||
|
},
|
||
|
100);
|
||
|
var t = this.$tableBody.get(0),
|
||
|
o = t.scrollWidth > t.clientWidth && t.scrollHeight > t.clientHeight + this.$header.outerHeight() ? r.getScrollBarWidth() : 0;
|
||
|
this.$tableFooter.css('margin-right', o).find('table').css('width', this.$el.outerWidth()).attr('class', this.$el.attr('class'));
|
||
|
for (var a = this.getVisibleFields(), n = this.$tableFooter.find('th'), i = this.$body.find('>tr:first-child:not(.no-records-found)'); i.length && i.find('>td[colspan]:not([colspan="1"])').length;) i = i.next();
|
||
|
i.find('> *').each(function(t, o) {
|
||
|
var a = s(o),
|
||
|
i = t;
|
||
|
if (e.options.detailView && !e.options.cardView) {
|
||
|
if (0 === t) {
|
||
|
var l = n.filter('.detail'),
|
||
|
r = l.width() - l.find('.fht-cell').width();
|
||
|
l.find('.fht-cell').width(a.innerWidth() - r)
|
||
|
}
|
||
|
i = t - 1
|
||
|
}
|
||
|
if ( - 1 !== i) {
|
||
|
var d = n.eq(t),
|
||
|
c = d.width() - d.find('.fht-cell').width();
|
||
|
d.find('.fht-cell').width(a.innerWidth() - c)
|
||
|
}
|
||
|
}),
|
||
|
this.horizontalScroll()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'horizontalScroll',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
this.trigger('scroll-body'),
|
||
|
this.$tableBody.off('scroll').on('scroll',
|
||
|
function(t) {
|
||
|
var o = t.currentTarget;
|
||
|
e.options.showHeader && e.options.height && e.$tableHeader.scrollLeft(s(o).scrollLeft()),
|
||
|
e.options.showFooter && !e.options.cardView && e.$tableFooter.scrollLeft(s(o).scrollLeft())
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'toggleColumn',
|
||
|
value: function(e, t, o) {
|
||
|
if ( - 1 !== e && (this.columns[e].visible = t, this.initHeader(), this.initSearch(), this.initPagination(), this.initBody(), this.options.showColumns)) {
|
||
|
var a = this.$toolbar.find('.keep-open input').prop('disabled', !1);
|
||
|
o && a.filter(r.sprintf('[value="%s"]', e)).prop('checked', t),
|
||
|
a.filter(':checked').length <= this.options.minimumCountColumns && a.filter(':checked').prop('disabled', !0)
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getVisibleFields',
|
||
|
value: function() {
|
||
|
for (var e = [], t = this.header.fields, o = Array.isArray(t), a = 0, _iterator19 = o ? t: t[Symbol.iterator]();;) {
|
||
|
var i;
|
||
|
if (o) {
|
||
|
if (a >= t.length) break;
|
||
|
i = t[a++]
|
||
|
} else {
|
||
|
if (a = t.next(), a.done) break;
|
||
|
i = a.value
|
||
|
}
|
||
|
var n = i,
|
||
|
s = this.columns[this.fieldsColumnsIndex[n]];
|
||
|
s.visible && e.push(n)
|
||
|
}
|
||
|
return e
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetView',
|
||
|
value: function(e) {
|
||
|
var t = 0;
|
||
|
if (e && e.height && (this.options.height = e.height), this.$selectAll.prop('checked', 0 < this.$selectItem.length && this.$selectItem.length === this.$selectItem.filter(':checked').length), this.options.cardView) return this.$el.css('margin-top', '0'),
|
||
|
this.$tableContainer.css('padding-bottom', '0'),
|
||
|
void this.$tableFooter.hide();
|
||
|
if (this.options.showHeader && this.options.height ? (this.$tableHeader.show(), this.resetHeader(), t += this.$header.outerHeight(!0)) : (this.$tableHeader.hide(), this.trigger('post-header')), this.options.showFooter && (this.resetFooter(), this.options.height && (t += this.$tableFooter.outerHeight(!0))), this.options.height) {
|
||
|
var o = this.$toolbar.outerHeight(!0),
|
||
|
a = this.$pagination.outerHeight(!0),
|
||
|
i = this.options.height - o - a,
|
||
|
n = this.$tableBody.find('table').outerHeight(!0);
|
||
|
this.$tableContainer.css('height', i + 'px'),
|
||
|
this.$tableBorder && this.$tableBorder.css('height', i - n - t - 1 + 'px')
|
||
|
}
|
||
|
this.getCaret(),
|
||
|
this.$tableContainer.css('padding-bottom', t + 'px'),
|
||
|
this.trigger('reset-view')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getData',
|
||
|
value: function(e) {
|
||
|
var t = this.options.data;
|
||
|
return (this.searchText || this.options.sortName || !r.isEmptyObject(this.filterColumns) || !r.isEmptyObject(this.filterColumnsPartial)) && (t = this.data),
|
||
|
e ? t.slice(this.pageFrom - 1, this.pageTo) : t
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'load',
|
||
|
value: function(e) {
|
||
|
var t = !1,
|
||
|
o = e;
|
||
|
this.options.pagination && 'server' === this.options.sidePagination && (this.options.totalRows = o[this.options.totalField]),
|
||
|
t = o.fixedScroll,
|
||
|
o = Array.isArray(o) ? o: o[this.options.dataField],
|
||
|
this.initData(o),
|
||
|
this.initSearch(),
|
||
|
this.initPagination(),
|
||
|
this.initBody(t)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'append',
|
||
|
value: function(e) {
|
||
|
this.initData(e, 'append'),
|
||
|
this.initSearch(),
|
||
|
this.initPagination(),
|
||
|
this.initSort(),
|
||
|
this.initBody(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'prepend',
|
||
|
value: function(e) {
|
||
|
this.initData(e, 'prepend'),
|
||
|
this.initSearch(),
|
||
|
this.initPagination(),
|
||
|
this.initSort(),
|
||
|
this.initBody(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'remove',
|
||
|
value: function(e) {
|
||
|
var t = this.options.data.length,
|
||
|
o = void 0,
|
||
|
a = void 0;
|
||
|
if (e.hasOwnProperty('field') && e.hasOwnProperty('values')) {
|
||
|
for (o = t - 1; 0 <= o; o--)(a = this.options.data[o], !!a.hasOwnProperty(e.field)) && -1 !== e.values.indexOf(a[e.field]) && (this.options.data.splice(o, 1), 'server' === this.options.sidePagination && (this.options.totalRows -= 1));
|
||
|
t === this.options.data.length || (this.initSearch(), this.initPagination(), this.initSort(), this.initBody(!0))
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'removeAll',
|
||
|
value: function() {
|
||
|
0 < this.options.data.length && (this.options.data.splice(0, this.options.data.length), this.initSearch(), this.initPagination(), this.initBody(!0))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getRowByUniqueId',
|
||
|
value: function(e) {
|
||
|
var t = this.options.uniqueId,
|
||
|
o = this.options.data.length,
|
||
|
a = e,
|
||
|
n = null,
|
||
|
s = void 0,
|
||
|
i = void 0,
|
||
|
l = void 0;
|
||
|
for (s = o - 1; 0 <= s; s--) {
|
||
|
if (i = this.options.data[s], i.hasOwnProperty(t)) l = i[t];
|
||
|
else if (i._data && i._data.hasOwnProperty(t)) l = i._data[t];
|
||
|
else continue;
|
||
|
if ('string' == typeof l ? a = a.toString() : 'number' == typeof l && ( + l === l && 0 == l % 1 ? a = parseInt(a) : l === +l && 0 !== l && (a = parseFloat(a))), l === a) {
|
||
|
n = i;
|
||
|
break
|
||
|
}
|
||
|
}
|
||
|
return n
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'removeByUniqueId',
|
||
|
value: function(e) {
|
||
|
var t = this.options.data.length,
|
||
|
o = this.getRowByUniqueId(e);
|
||
|
o && this.options.data.splice(this.options.data.indexOf(o), 1),
|
||
|
t === this.options.data.length || (this.initSearch(), this.initPagination(), this.initBody(!0))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateByUniqueId',
|
||
|
value: function(e) {
|
||
|
for (var t = Array.isArray(e) ? e: [e], o = t, a = Array.isArray(o), i = 0, _iterator20 = a ? o: o[Symbol.iterator]();;) {
|
||
|
var n;
|
||
|
if (a) {
|
||
|
if (i >= o.length) break;
|
||
|
n = o[i++]
|
||
|
} else {
|
||
|
if (i = o.next(), i.done) break;
|
||
|
n = i.value
|
||
|
}
|
||
|
var l = n;
|
||
|
if (l.hasOwnProperty('id') && l.hasOwnProperty('row')) {
|
||
|
var r = this.options.data.indexOf(this.getRowByUniqueId(l.id)); - 1 !== r && s.extend(this.options.data[r], l.row)
|
||
|
}
|
||
|
}
|
||
|
this.initSearch(),
|
||
|
this.initPagination(),
|
||
|
this.initSort(),
|
||
|
this.initBody(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'refreshColumnTitle',
|
||
|
value: function(e) {
|
||
|
if (e.hasOwnProperty('field') && e.hasOwnProperty('title') && (this.columns[this.fieldsColumnsIndex[e.field]].title = this.options.escape ? r.escapeHTML(e.title) : e.title, this.columns[this.fieldsColumnsIndex[e.field]].visible)) {
|
||
|
var t = void 0 === this.options.height ? this.$header: this.$tableHeader;
|
||
|
t.find('th[data-field]').each(function(t, o) {
|
||
|
if (s(o).data('field') === e.field) return s(s(o).find('.th-inner')[0]).text(e.title),
|
||
|
!1
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'insertRow',
|
||
|
value: function(e) {
|
||
|
e.hasOwnProperty('index') && e.hasOwnProperty('row') && (this.options.data.splice(e.index, 0, e.row), this.initSearch(), this.initPagination(), this.initSort(), this.initBody(!0))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateRow',
|
||
|
value: function(e) {
|
||
|
for (var t = Array.isArray(e) ? e: [e], o = t, a = Array.isArray(o), i = 0, _iterator21 = a ? o: o[Symbol.iterator]();;) {
|
||
|
var n;
|
||
|
if (a) {
|
||
|
if (i >= o.length) break;
|
||
|
n = o[i++]
|
||
|
} else {
|
||
|
if (i = o.next(), i.done) break;
|
||
|
n = i.value
|
||
|
}
|
||
|
var l = n;
|
||
|
l.hasOwnProperty('index') && l.hasOwnProperty('row') && s.extend(this.options.data[l.index], l.row)
|
||
|
}
|
||
|
this.initSearch(),
|
||
|
this.initPagination(),
|
||
|
this.initSort(),
|
||
|
this.initBody(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'initHiddenRows',
|
||
|
value: function() {
|
||
|
this.hiddenRows = []
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'showRow',
|
||
|
value: function(e) {
|
||
|
this.toggleRow(e, !0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'hideRow',
|
||
|
value: function(e) {
|
||
|
this.toggleRow(e, !1)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'toggleRow',
|
||
|
value: function(e, t) {
|
||
|
var o;
|
||
|
if (e.hasOwnProperty('index') ? o = this.getData()[e.index] : e.hasOwnProperty('uniqueId') && (o = this.getRowByUniqueId(e.uniqueId)), !!o) {
|
||
|
var a = r.findIndex(this.hiddenRows, o);
|
||
|
t || -1 !== a ? t && -1 < a && this.hiddenRows.splice(a, 1) : this.hiddenRows.push(o),
|
||
|
this.initBody(!0)
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getHiddenRows',
|
||
|
value: function(e) {
|
||
|
if (e) return this.initHiddenRows(),
|
||
|
void this.initBody(!0);
|
||
|
for (var t = this.getData(), o = [], a = t, i = Array.isArray(a), n = 0, _iterator22 = i ? a: a[Symbol.iterator]();;) {
|
||
|
var s;
|
||
|
if (i) {
|
||
|
if (n >= a.length) break;
|
||
|
s = a[n++]
|
||
|
} else {
|
||
|
if (n = a.next(), n.done) break;
|
||
|
s = n.value
|
||
|
}
|
||
|
var l = s; - 1 !== this.hiddenRows.indexOf(l) && o.push(l)
|
||
|
}
|
||
|
return this.hiddenRows = o,
|
||
|
o
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'mergeCells',
|
||
|
value: function(e) {
|
||
|
var t = e.index,
|
||
|
o = this.getVisibleFields().indexOf(e.field),
|
||
|
a = e.rowspan || 1,
|
||
|
n = e.colspan || 1,
|
||
|
s = void 0,
|
||
|
i = void 0,
|
||
|
l = this.$body.find('>tr');
|
||
|
this.options.detailView && !this.options.cardView && (o += 1);
|
||
|
var r = l.eq(t).find('>td').eq(o);
|
||
|
if (! (0 > t || 0 > o || t >= this.data.length)) {
|
||
|
for (s = t; s < t + a; s++) for (i = o; i < o + n; i++) l.eq(s).find('>td').eq(i).hide();
|
||
|
r.attr('rowspan', a).attr('colspan', n).show()
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateCell',
|
||
|
value: function(e) {
|
||
|
e.hasOwnProperty('index') && e.hasOwnProperty('field') && e.hasOwnProperty('value') && (this.data[e.index][e.field] = e.value, !1 === e.reinit || (this.initSort(), this.initBody(!0)))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateCellById',
|
||
|
value: function(e) {
|
||
|
var t = this;
|
||
|
if (e.hasOwnProperty('id') && e.hasOwnProperty('field') && e.hasOwnProperty('value')) {
|
||
|
var o = Array.isArray(e) ? e: [e];
|
||
|
o.forEach(function(e) {
|
||
|
var o = e.id,
|
||
|
a = e.field,
|
||
|
i = e.value,
|
||
|
n = t.options.data.indexOf(t.getRowByUniqueId(o)); - 1 === n || (t.data[n][a] = i)
|
||
|
}),
|
||
|
!1 === e.reinit || (this.initSort(), this.initBody(!0))
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getOptions',
|
||
|
value: function() {
|
||
|
var e = JSON.parse(JSON.stringify(this.options));
|
||
|
return delete e.data,
|
||
|
e
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getSelections',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
return this.options.data.filter(function(t) {
|
||
|
return ! 0 === t[e.header.stateField]
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getAllSelections',
|
||
|
value: function() {
|
||
|
var e = this;
|
||
|
return this.options.data.filter(function(t) {
|
||
|
return t[e.header.stateField]
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'checkAll',
|
||
|
value: function() {
|
||
|
this.checkAll_(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'uncheckAll',
|
||
|
value: function() {
|
||
|
this.checkAll_(!1)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'checkInvert',
|
||
|
value: function() {
|
||
|
var e = this.$selectItem.filter(':enabled'),
|
||
|
t = e.filter(':checked');
|
||
|
e.each(function(e, t) {
|
||
|
s(t).prop('checked', !s(t).prop('checked'))
|
||
|
}),
|
||
|
this.updateRows(),
|
||
|
this.updateSelected(),
|
||
|
this.trigger('uncheck-some', t),
|
||
|
t = this.getSelections(),
|
||
|
this.trigger('check-some', t)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'checkAll_',
|
||
|
value: function(e) {
|
||
|
var t;
|
||
|
e || (t = this.getSelections()),
|
||
|
this.$selectAll.add(this.$selectAll_).prop('checked', e),
|
||
|
this.$selectItem.filter(':enabled').prop('checked', e),
|
||
|
this.updateRows(),
|
||
|
e && (t = this.getSelections()),
|
||
|
this.trigger(e ? 'check-all': 'uncheck-all', t)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'check',
|
||
|
value: function(e) {
|
||
|
this.check_(!0, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'uncheck',
|
||
|
value: function(e) {
|
||
|
this.check_(!1, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'check_',
|
||
|
value: function(e, t) {
|
||
|
var o = this.$selectItem.filter('[data-index="' + t + '"]'),
|
||
|
a = this.data[t];
|
||
|
if (o.is(':radio') || this.options.singleSelect) {
|
||
|
for (var i = this.options.data,
|
||
|
n = Array.isArray(i), s = 0, _iterator23 = n ? i: i[Symbol.iterator]();;) {
|
||
|
var l;
|
||
|
if (n) {
|
||
|
if (s >= i.length) break;
|
||
|
l = i[s++]
|
||
|
} else {
|
||
|
if (s = i.next(), s.done) break;
|
||
|
l = s.value
|
||
|
}
|
||
|
var d = l;
|
||
|
d[this.header.stateField] = !1
|
||
|
}
|
||
|
this.$selectItem.filter(':checked').not(o).prop('checked', !1)
|
||
|
}
|
||
|
a[this.header.stateField] = e,
|
||
|
o.prop('checked', e),
|
||
|
this.updateSelected(),
|
||
|
this.trigger(e ? 'check': 'uncheck', this.data[t], o)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'checkBy',
|
||
|
value: function(e) {
|
||
|
this.checkBy_(!0, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'uncheckBy',
|
||
|
value: function(e) {
|
||
|
this.checkBy_(!1, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'checkBy_',
|
||
|
value: function(e, t) {
|
||
|
var o = this;
|
||
|
if (t.hasOwnProperty('field') && t.hasOwnProperty('values')) {
|
||
|
var a = [];
|
||
|
this.options.data.forEach(function(n, s) {
|
||
|
if (!n.hasOwnProperty(t.field)) return ! 1;
|
||
|
if ( - 1 !== t.values.indexOf(n[t.field])) {
|
||
|
var i = o.$selectItem.filter(':enabled').filter(r.sprintf('[data-index="%s"]', s)).prop('checked', e);
|
||
|
n[o.header.stateField] = e,
|
||
|
a.push(n),
|
||
|
o.trigger(e ? 'check': 'uncheck', n, i)
|
||
|
}
|
||
|
}),
|
||
|
this.updateSelected(),
|
||
|
this.trigger(e ? 'check-some': 'uncheck-some', a)
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'destroy',
|
||
|
value: function() {
|
||
|
this.$el.insertBefore(this.$container),
|
||
|
s(this.options.toolbar).insertBefore(this.$el),
|
||
|
this.$container.next().remove(),
|
||
|
this.$container.remove(),
|
||
|
this.$el.html(this.$el_.html()).css('margin-top', '0').attr('class', this.$el_.attr('class') || '')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'showLoading',
|
||
|
value: function() {
|
||
|
this.$tableLoading.css('display', 'flex')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'hideLoading',
|
||
|
value: function() {
|
||
|
this.$tableLoading.css('display', 'none')
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'togglePagination',
|
||
|
value: function() {
|
||
|
this.options.pagination = !this.options.pagination,
|
||
|
this.$toolbar.find('button[name="paginationSwitch"]').html(r.sprintf(this.constants.html.icon, this.options.iconsPrefix, this.options.pagination ? this.options.icons.paginationSwitchDown: this.options.icons.paginationSwitchUp)),
|
||
|
this.updatePagination()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'toggleFullscreen',
|
||
|
value: function() {
|
||
|
this.$el.closest('.bootstrap-table').toggleClass('fullscreen'),
|
||
|
this.resetView()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'refresh',
|
||
|
value: function(e) {
|
||
|
e && e.url && (this.options.url = e.url),
|
||
|
e && e.pageNumber && (this.options.pageNumber = e.pageNumber),
|
||
|
e && e.pageSize && (this.options.pageSize = e.pageSize),
|
||
|
this.trigger('refresh', this.initServer(e && e.silent, e && e.query, e && e.url))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetWidth',
|
||
|
value: function() {
|
||
|
this.options.showHeader && this.options.height && this.fitHeader(),
|
||
|
this.options.showFooter && !this.options.cardView && this.fitFooter()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'showColumn',
|
||
|
value: function(e) {
|
||
|
this.toggleColumn(this.fieldsColumnsIndex[e], !0, !0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'hideColumn',
|
||
|
value: function(e) {
|
||
|
this.toggleColumn(this.fieldsColumnsIndex[e], !1, !0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getHiddenColumns',
|
||
|
value: function() {
|
||
|
return this.columns.filter(function(e) {
|
||
|
var t = e.visible;
|
||
|
return ! t
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getVisibleColumns',
|
||
|
value: function() {
|
||
|
return this.columns.filter(function(e) {
|
||
|
var t = e.visible;
|
||
|
return t
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'toggleAllColumns',
|
||
|
value: function(e) {
|
||
|
for (var t = this.columns,
|
||
|
o = Array.isArray(t), a = 0, _iterator24 = o ? t: t[Symbol.iterator]();;) {
|
||
|
var i;
|
||
|
if (o) {
|
||
|
if (a >= t.length) break;
|
||
|
i = t[a++]
|
||
|
} else {
|
||
|
if (a = t.next(), a.done) break;
|
||
|
i = a.value
|
||
|
}
|
||
|
var n = i;
|
||
|
n.visible = e
|
||
|
}
|
||
|
if (this.initHeader(), this.initSearch(), this.initPagination(), this.initBody(), this.options.showColumns) {
|
||
|
var s = this.$toolbar.find('.keep-open input').prop('disabled', !1);
|
||
|
s.filter(':checked').length <= this.options.minimumCountColumns && s.filter(':checked').prop('disabled', !0)
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'showAllColumns',
|
||
|
value: function() {
|
||
|
this.toggleAllColumns(!0)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'hideAllColumns',
|
||
|
value: function() {
|
||
|
this.toggleAllColumns(!1)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'filterBy',
|
||
|
value: function(e) {
|
||
|
this.filterColumns = r.isEmptyObject(e) ? {}: e,
|
||
|
this.options.pageNumber = 1,
|
||
|
this.initSearch(),
|
||
|
this.updatePagination()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'scrollTo',
|
||
|
value: function(e) {
|
||
|
if ('undefined' == typeof e) return this.$tableBody.scrollTop();
|
||
|
var t = e;
|
||
|
'string' == typeof e && 'bottom' === e && (t = this.$tableBody[0].scrollHeight),
|
||
|
this.$tableBody.scrollTop(t)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'getScrollPosition',
|
||
|
value: function() {
|
||
|
return this.scrollTo()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'selectPage',
|
||
|
value: function(e) {
|
||
|
0 < e && e <= this.options.totalPages && (this.options.pageNumber = e, this.updatePagination())
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'prevPage',
|
||
|
value: function() {
|
||
|
1 < this.options.pageNumber && (this.options.pageNumber--, this.updatePagination())
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'nextPage',
|
||
|
value: function() {
|
||
|
this.options.pageNumber < this.options.totalPages && (this.options.pageNumber++, this.updatePagination())
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'toggleView',
|
||
|
value: function() {
|
||
|
this.options.cardView = !this.options.cardView,
|
||
|
this.initHeader(),
|
||
|
this.$toolbar.find('button[name="toggle"]').html(r.sprintf(this.constants.html.icon, this.options.iconsPrefix, this.options.cardView ? this.options.icons.toggleOn: this.options.icons.toggleOff)),
|
||
|
this.initBody(),
|
||
|
this.trigger('toggle', this.options.cardView)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'refreshOptions',
|
||
|
value: function(e) {
|
||
|
r.compareObjects(this.options, e, !0) || (this.options = s.extend(this.options, e), this.trigger('refresh-options', this.options), this.destroy(), this.init())
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'resetSearch',
|
||
|
value: function(e) {
|
||
|
var t = this.$toolbar.find('.search input');
|
||
|
t.val(e || ''),
|
||
|
this.onSearch({
|
||
|
currentTarget: t
|
||
|
})
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'expandRow_',
|
||
|
value: function(e, t) {
|
||
|
var o = this.$body.find(r.sprintf('> tr[data-index="%s"]', t));
|
||
|
o.next().is('tr.detail-view') === !e && o.find('> td > .detail-icon').click()
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'expandRow',
|
||
|
value: function(e) {
|
||
|
this.expandRow_(!0, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'collapseRow',
|
||
|
value: function(e) {
|
||
|
this.expandRow_(!1, e)
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'expandAllRows',
|
||
|
value: function(e) {
|
||
|
var t = this;
|
||
|
if (e) {
|
||
|
var o = this.$body.find(r.sprintf('> tr[data-index="%s"]', 0)),
|
||
|
a = null,
|
||
|
n = !1,
|
||
|
l = -1;
|
||
|
if (o.next().is('tr.detail-view') ? !o.next().next().is('tr.detail-view') && (o.next().find('.detail-icon').click(), n = !0) : (o.find('> td > .detail-icon').click(), n = !0), n) try {
|
||
|
l = setInterval(function() {
|
||
|
a = t.$body.find('tr.detail-view').last().find('.detail-icon'),
|
||
|
0 < a.length ? a.click() : clearInterval(l)
|
||
|
},
|
||
|
1)
|
||
|
} catch(e) {
|
||
|
clearInterval(l)
|
||
|
}
|
||
|
} else for (var d = this.$body.children(), c = 0; c < d.length; c++) this.expandRow_(!0, s(d[c]).data('index'))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'collapseAllRows',
|
||
|
value: function(e) {
|
||
|
if (e) this.expandRow_(!1, 0);
|
||
|
else for (var t = this.$body.children(), o = 0; o < t.length; o++) this.expandRow_(!1, s(t[o]).data('index'))
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
key: 'updateFormatText',
|
||
|
value: function(e, t) {
|
||
|
this.options[r.sprintf('format%s', e)] && ('string' == typeof t ? this.options[r.sprintf('format%s', e)] = function() {
|
||
|
return t
|
||
|
}: 'function' == typeof t && (this.options[r.sprintf('format%s', e)] = t)),
|
||
|
this.initToolbar(),
|
||
|
this.initPagination(),
|
||
|
this.initBody()
|
||
|
}
|
||
|
}]),
|
||
|
t
|
||
|
} ();
|
||
|
p.DEFAULTS = d,
|
||
|
p.LOCALES = c,
|
||
|
p.COLUMN_DEFAULTS = {
|
||
|
radio: !1,
|
||
|
checkbox: !1,
|
||
|
checkboxEnabled: !0,
|
||
|
field: void 0,
|
||
|
title: void 0,
|
||
|
titleTooltip: void 0,
|
||
|
class: void 0,
|
||
|
align: void 0,
|
||
|
halign: void 0,
|
||
|
falign: void 0,
|
||
|
valign: void 0,
|
||
|
width: void 0,
|
||
|
sortable: !1,
|
||
|
order: 'asc',
|
||
|
visible: !0,
|
||
|
switchable: !0,
|
||
|
clickToSelect: !0,
|
||
|
formatter: void 0,
|
||
|
footerFormatter: void 0,
|
||
|
events: void 0,
|
||
|
sorter: void 0,
|
||
|
sortName: void 0,
|
||
|
cellStyle: void 0,
|
||
|
searchable: !0,
|
||
|
searchFormatter: !0,
|
||
|
cardVisible: !0,
|
||
|
escape: !1,
|
||
|
showSelectTitle: !1
|
||
|
},
|
||
|
p.EVENTS = {
|
||
|
"all.bs.table": 'onAll',
|
||
|
"click-cell.bs.table": 'onClickCell',
|
||
|
"dbl-click-cell.bs.table": 'onDblClickCell',
|
||
|
"click-row.bs.table": 'onClickRow',
|
||
|
"dbl-click-row.bs.table": 'onDblClickRow',
|
||
|
"sort.bs.table": 'onSort',
|
||
|
"check.bs.table": 'onCheck',
|
||
|
"uncheck.bs.table": 'onUncheck',
|
||
|
"check-all.bs.table": 'onCheckAll',
|
||
|
"uncheck-all.bs.table": 'onUncheckAll',
|
||
|
"check-some.bs.table": 'onCheckSome',
|
||
|
"uncheck-some.bs.table": 'onUncheckSome',
|
||
|
"load-success.bs.table": 'onLoadSuccess',
|
||
|
"load-error.bs.table": 'onLoadError',
|
||
|
"column-switch.bs.table": 'onColumnSwitch',
|
||
|
"page-change.bs.table": 'onPageChange',
|
||
|
"search.bs.table": 'onSearch',
|
||
|
"toggle.bs.table": 'onToggle',
|
||
|
"pre-body.bs.table": 'onPreBody',
|
||
|
"post-body.bs.table": 'onPostBody',
|
||
|
"post-header.bs.table": 'onPostHeader',
|
||
|
"expand-row.bs.table": 'onExpandRow',
|
||
|
"collapse-row.bs.table": 'onCollapseRow',
|
||
|
"refresh-options.bs.table": 'onRefreshOptions',
|
||
|
"reset-view.bs.table": 'onResetView',
|
||
|
"refresh.bs.table": 'onRefresh',
|
||
|
"scroll-body.bs.table": 'onScrollBody'
|
||
|
};
|
||
|
var h = ['getOptions', 'getSelections', 'getAllSelections', 'getData', 'load', 'append', 'prepend', 'remove', 'removeAll', 'insertRow', 'updateRow', 'updateCell', 'updateByUniqueId', 'removeByUniqueId', 'getRowByUniqueId', 'showRow', 'hideRow', 'getHiddenRows', 'mergeCells', 'refreshColumnTitle', 'checkAll', 'uncheckAll', 'checkInvert', 'check', 'uncheck', 'checkBy', 'uncheckBy', 'refresh', 'resetView', 'resetWidth', 'destroy', 'showLoading', 'hideLoading', 'showColumn', 'hideColumn', 'getHiddenColumns', 'getVisibleColumns', 'showAllColumns', 'hideAllColumns', 'filterBy', 'scrollTo', 'getScrollPosition', 'selectPage', 'prevPage', 'nextPage', 'togglePagination', 'toggleView', 'refreshOptions', 'resetSearch', 'expandRow', 'collapseRow', 'expandAllRows', 'collapseAllRows', 'updateFormatText', 'updateCellById'];
|
||
|
s.BootstrapTable = p,
|
||
|
s.fn.bootstrapTable = function(e) {
|
||
|
for (var t = arguments.length,
|
||
|
o = Array(1 < t ? t - 1 : 0), a = 1; a < t; a++) o[a - 1] = arguments[a];
|
||
|
var i;
|
||
|
return this.each(function(t, a) {
|
||
|
var l = s(a).data('bootstrap.table'),
|
||
|
r = s.extend({},
|
||
|
p.DEFAULTS, s(a).data(), 'object' === ('undefined' == typeof e ? 'undefined': n(e)) && e);
|
||
|
if ('string' == typeof e) {
|
||
|
var d;
|
||
|
if ( - 1 === h.indexOf(e)) throw new Error('Unknown method: ' + e);
|
||
|
if (!l) return;
|
||
|
i = (d = l)[e].apply(d, o),
|
||
|
'destroy' === e && s(a).removeData('bootstrap.table')
|
||
|
}
|
||
|
l || s(a).data('bootstrap.table', l = new s.BootstrapTable(a, r))
|
||
|
}),
|
||
|
'undefined' == typeof i ? this: i
|
||
|
},
|
||
|
s.fn.bootstrapTable.Constructor = p,
|
||
|
s.fn.bootstrapTable.defaults = p.DEFAULTS,
|
||
|
s.fn.bootstrapTable.columnDefaults = p.COLUMN_DEFAULTS,
|
||
|
s.fn.bootstrapTable.locales = p.LOCALES,
|
||
|
s.fn.bootstrapTable.methods = h,
|
||
|
s.fn.bootstrapTable.utils = r,
|
||
|
s(function() {
|
||
|
s('[data-toggle="table"]').bootstrapTable()
|
||
|
})
|
||
|
})(jQuery)
|
||
|
});
|