123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- /**
- * @author: YL
- * @version: v1.0.0
- */
- !function ($) {
- 'use strict';
- $.extend($.fn.bootstrapTable.defaults, {
- treeShowField: null,
- rootNo: 0,
- idField: 'id',
- parentIdField: 'pid',
- level: "depth",
- onGetNodes: function (row, data) {
- var that = this;
- var nodes = [];
- $.each(data, function (i, item) {
- if (row[that.options.idField] === item[that.options.parentIdField]) {
- nodes.push(item);
- }
- });
- return nodes;
- },
- responseHandler:responseHandler,
- queryParams: queryParams,
- onCheckRoot: function (row, data) {
- var that = this;
- return row[that.options.parentIdField] == that.options.rootNo || row[that.options.parentIdField]===null;
- }
- });
- var BootstrapTable = $.fn.bootstrapTable.Constructor,
- _init = BootstrapTable.prototype.init,
- _initRow = BootstrapTable.prototype.initRow,
- _initHeader = BootstrapTable.prototype.initHeader,
- _rowStyle = null;
- BootstrapTable.prototype.init = function () {
- _rowStyle = this.options.rowStyle;
- _init.apply(this, Array.prototype.slice.apply(arguments));
- };
- // td
- BootstrapTable.prototype.initHeader = function () {
- var that = this;
- _initHeader.apply(that, Array.prototype.slice.apply(arguments));
- var treeShowField = that.options.treeShowField;
- if (treeShowField) {
- $.each(this.header.fields, function (i, field) {
- if (treeShowField === field) {
- that.treeEnable = true;
- return false;
- }
- });
- }
- };
- function responseHandler(res) {
- if (res.success) {
- var data = JSON.parse('{"total":' +
- res.result.totalCount +
- ',"rows":' +
- JSON.stringify(res.result.items) +
- '}');
- console.log(data);
- return data;
- } else {
- console.log('Table load failed');
- if (res.error) {
- if (res.error.details) {
- return abp.message.error(res.error.details, res.error.message);
- } else {
- if (error.message && error.message.indexOf('登陆超时') >= 0) {
- return abp.message.error(error.message).done(function() {
- window.top.location.reload();
- });
- } else {
- return abp.message.error(error.message || abp.ajax.defaultError.message);
- }
- }
- }
- }
- return JSON.parse('{"total":0,"rows":[]}');
- };
- function queryParams(params) {
- return {
- MaxResultCount: params.limit,
- SkipCount: params.offset,
- sort: params.sort, //排序列名
- sortOrder: params.order //排位命令(desc,asc)
- };
- }
- var initTr = function (item, idx, data, parentDom) {
- var that = this;
- var nodes = that.options.onGetNodes.apply(that, [item, data]);
- item._nodes = nodes;
- parentDom.append(_initRow.apply(that, [item, idx, data, parentDom]));
- // init sub node
- var len = nodes.length - 1;
- for (var i = 0; i <= len; i++) {
- var node = nodes[i];
- node._level = item._level + 1;
- node._parent = item;
- if (i === len)
- node._last = 1;
- // jquery.treegrid.js
- that.options.rowStyle = function (item, idx) {
- var res = _rowStyle.apply(that, Array.prototype.slice.apply(arguments));
- var id = item[that.options.idField] ? item[that.options.idField] : 0;
- var pid = item[that.options.parentIdField] ? item[that.options.parentIdField] : 0;
- var level = item[that.options.level] ? item[that.options.level] : 0;
- res.classes = [
- res.classes || '',
- 'treegrid-' + id,
- 'treegrid-parent-' + pid,
- 'level-' + level
- ].join(' ');
- return res;
- };
- initTr.apply(that, [node, $.inArray(node, data), data, parentDom]);
- }
- };
- // tr
- BootstrapTable.prototype.initRow = function (item, idx, data, parentDom) {
- var that = this;
- if (that.treeEnable) {
- // init root node
- if (that.options.onCheckRoot.apply(that, [item, data])) {
- if (item._level === undefined) {
- item._level = 0;
- }
- // jquery.treegrid.js
- that.options.rowStyle = function (item, idx) {
- var res = _rowStyle.apply(that, Array.prototype.slice.apply(arguments));
- var x = item[that.options.idField] ? item[that.options.idField] : 0;
- res.classes = [
- res.classes || '',
- 'treegrid-' + x
- ].join(' ');
- return res;
- };
- initTr.apply(that, [item, idx, data, parentDom]);
- return true;
- }
- return false;
- }
- return _initRow.apply(that, Array.prototype.slice.apply(arguments));
- };
- }(jQuery);
|