mirror of
https://github.com/gosticks/react-table.git
synced 2026-03-30 17:34:30 +00:00
643 lines
63 KiB
JavaScript
643 lines
63 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.ReactTableDefaults = undefined;
|
|
|
|
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
|
|
|
|
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
|
|
|
|
var _react = require('react');
|
|
|
|
var _react2 = _interopRequireDefault(_react);
|
|
|
|
var _classnames = require('classnames');
|
|
|
|
var _classnames2 = _interopRequireDefault(_classnames);
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
//
|
|
var _ = {
|
|
get: get,
|
|
takeRight: takeRight,
|
|
last: last,
|
|
orderBy: orderBy,
|
|
range: range,
|
|
clone: clone,
|
|
remove: remove
|
|
};
|
|
|
|
var defaultButton = function defaultButton(props) {
|
|
return _react2.default.createElement(
|
|
'button',
|
|
_extends({}, props, { className: '-btn' }),
|
|
props.children
|
|
);
|
|
};
|
|
|
|
var ReactTableDefaults = exports.ReactTableDefaults = {
|
|
// Classes
|
|
className: '-striped -highlight',
|
|
tableClassName: '',
|
|
theadClassName: '',
|
|
tbodyClassName: '',
|
|
trClassName: '',
|
|
paginationClassName: '',
|
|
//
|
|
pageSize: 20,
|
|
minRows: 0,
|
|
// Global Column Defaults
|
|
column: {
|
|
sortable: true,
|
|
show: true
|
|
},
|
|
// Text
|
|
previousText: 'Previous',
|
|
nextText: 'Next',
|
|
loadingText: 'Loading...',
|
|
// Components
|
|
tableComponent: function tableComponent(props) {
|
|
return _react2.default.createElement(
|
|
'table',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
theadComponent: function theadComponent(props) {
|
|
return _react2.default.createElement(
|
|
'thead',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
tbodyComponent: function tbodyComponent(props) {
|
|
return _react2.default.createElement(
|
|
'tbody',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
trComponent: function trComponent(props) {
|
|
return _react2.default.createElement(
|
|
'tr',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
thComponent: function thComponent(props) {
|
|
return _react2.default.createElement(
|
|
'th',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
tdComponent: function tdComponent(props) {
|
|
return _react2.default.createElement(
|
|
'td',
|
|
props,
|
|
props.children
|
|
);
|
|
},
|
|
previousComponent: null,
|
|
nextComponent: null,
|
|
// Unlisted
|
|
data: []
|
|
};
|
|
|
|
exports.default = _react2.default.createClass({
|
|
displayName: 'src',
|
|
getDefaultProps: function getDefaultProps() {
|
|
return ReactTableDefaults;
|
|
},
|
|
getInitialState: function getInitialState() {
|
|
return {
|
|
sorting: false
|
|
};
|
|
},
|
|
componentWillMount: function componentWillMount() {
|
|
this.update(this.props);
|
|
},
|
|
componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
|
|
this.update(nextProps);
|
|
},
|
|
update: function update(props) {
|
|
var resetState = {
|
|
loading: false,
|
|
page: 0,
|
|
pages: -1
|
|
// columns: {} for column hiding in the future
|
|
};
|
|
this.setState(resetState);
|
|
var newState = Object.assign({}, this.state, resetState);
|
|
this.isAsync = typeof props.data === 'function';
|
|
this.buildColumns(props, newState);
|
|
this.buildData(props, newState);
|
|
},
|
|
buildColumns: function buildColumns(props) {
|
|
var _this = this;
|
|
|
|
this.hasHeaderGroups = false;
|
|
props.columns.forEach(function (column) {
|
|
if (column.columns) {
|
|
_this.hasHeaderGroups = true;
|
|
}
|
|
});
|
|
|
|
this.headerGroups = [];
|
|
this.decoratedColumns = [];
|
|
var currentSpan = [];
|
|
|
|
var addHeader = function addHeader(columns) {
|
|
var column = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
|
|
_this.headerGroups.push(Object.assign({}, column, {
|
|
columns: columns
|
|
}));
|
|
currentSpan = [];
|
|
};
|
|
var makeDecoratedColumn = function makeDecoratedColumn(column) {
|
|
var dcol = Object.assign({}, _this.props.column, column);
|
|
|
|
if (typeof dcol.accessor === 'string') {
|
|
var _ret = function () {
|
|
dcol.id = dcol.id || dcol.accessor;
|
|
var accessorString = dcol.accessor;
|
|
dcol.accessor = function (row) {
|
|
return _.get(row, accessorString);
|
|
};
|
|
return {
|
|
v: dcol
|
|
};
|
|
}();
|
|
|
|
if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
|
|
}
|
|
|
|
if (dcol.accessor && !dcol.id) {
|
|
console.warn(dcol);
|
|
throw new Error('A column id is required if using a non-string accessor for column above.');
|
|
}
|
|
|
|
dcol.accessor = function (d) {
|
|
return undefined;
|
|
};
|
|
return dcol;
|
|
};
|
|
|
|
props.columns.forEach(function (column, i) {
|
|
if (column.columns) {
|
|
column.columns.forEach(function (nestedColumn) {
|
|
_this.decoratedColumns.push(makeDecoratedColumn(nestedColumn));
|
|
});
|
|
if (_this.hasHeaderGroups) {
|
|
if (currentSpan.length > 0) {
|
|
addHeader(currentSpan);
|
|
}
|
|
addHeader(_.takeRight(_this.decoratedColumns, column.columns.length), column);
|
|
}
|
|
} else {
|
|
_this.decoratedColumns.push(makeDecoratedColumn(column));
|
|
currentSpan.push(_.last(_this.decoratedColumns));
|
|
}
|
|
});
|
|
|
|
if (this.hasHeaderGroups && currentSpan.length > 0) {
|
|
addHeader(currentSpan);
|
|
}
|
|
},
|
|
getInitSorting: function getInitSorting() {
|
|
var initSorting = this.decoratedColumns.filter(function (d) {
|
|
return typeof d.sort !== 'undefined';
|
|
}).map(function (d) {
|
|
return {
|
|
id: d.id,
|
|
asc: d.sort === 'asc'
|
|
};
|
|
});
|
|
|
|
return initSorting.length ? initSorting : [{
|
|
id: this.decoratedColumns[0].id,
|
|
asc: true
|
|
}];
|
|
},
|
|
buildData: function buildData(props, state) {
|
|
var _this2 = this;
|
|
|
|
var sorting = state.sorting === false ? this.getInitSorting() : state.sorting;
|
|
|
|
var setData = function setData(data) {
|
|
_this2.setState({
|
|
sorting: sorting,
|
|
data: data,
|
|
page: state.page,
|
|
loading: false
|
|
});
|
|
};
|
|
|
|
if (this.isAsync) {
|
|
this.setState({
|
|
loading: true
|
|
});
|
|
|
|
var cb = function cb(res) {
|
|
if (!res) {
|
|
return Promise.reject('Uh Oh! Nothing was returned in ReactTable\'s data callback!');
|
|
}
|
|
if (res.pages) {
|
|
_this2.setState({
|
|
pages: res.pages
|
|
});
|
|
}
|
|
// Only access the data. Sorting is done server side.
|
|
var accessedData = _this2.accessData(res.rows);
|
|
setData(accessedData);
|
|
};
|
|
|
|
// Fetch data with current state
|
|
var dataRes = props.data({
|
|
sorting: sorting,
|
|
page: state.page || 0,
|
|
pageSize: props.pageSize,
|
|
pages: state.pages
|
|
}, cb);
|
|
|
|
if (dataRes && dataRes.then) {
|
|
dataRes.then(cb);
|
|
}
|
|
} else {
|
|
// Return locally accessed, sorted data
|
|
var accessedData = this.accessData(props.data);
|
|
var sortedData = this.sortData(accessedData, sorting);
|
|
setData(sortedData);
|
|
}
|
|
},
|
|
accessData: function accessData(data) {
|
|
var _this3 = this;
|
|
|
|
return data.map(function (d, i) {
|
|
var row = {
|
|
__original: d,
|
|
__index: i
|
|
};
|
|
_this3.decoratedColumns.forEach(function (column) {
|
|
row[column.id] = column.accessor(d);
|
|
});
|
|
return row;
|
|
});
|
|
},
|
|
sortData: function sortData(data, sorting) {
|
|
var resolvedSorting = sorting.length ? sorting : this.getInitSorting();
|
|
return _.orderBy(data, resolvedSorting.map(function (sort) {
|
|
return function (row) {
|
|
if (row[sort.id] === null || row[sort.id] === undefined) {
|
|
return -Infinity;
|
|
}
|
|
return typeof row[sort.id] === 'string' ? row[sort.id].toLowerCase() : row[sort.id];
|
|
};
|
|
}), resolvedSorting.map(function (d) {
|
|
return d.asc ? 'asc' : 'desc';
|
|
}));
|
|
},
|
|
setPage: function setPage(page) {
|
|
if (this.isAsync) {
|
|
return this.buildData(this.props, Object.assign({}, this.state, { page: page }));
|
|
}
|
|
this.setState({
|
|
page: page
|
|
});
|
|
},
|
|
render: function render() {
|
|
var _this4 = this;
|
|
|
|
var data = this.state.data ? this.state.data : [];
|
|
|
|
var pagesLength = this.isAsync ? this.state.pages : Math.ceil(data.length / this.props.pageSize);
|
|
var startRow = this.props.pageSize * this.state.page;
|
|
var endRow = startRow + this.props.pageSize;
|
|
var pageRows = this.isAsync ? data.slice(0, this.props.pageSize) : data.slice(startRow, endRow);
|
|
var padRows = pagesLength > 1 ? _.range(this.props.pageSize - pageRows.length) : this.props.minRows ? _.range(Math.max(this.props.minRows - pageRows.length, 0)) : [];
|
|
|
|
var canPrevious = this.state.page > 0;
|
|
var canNext = this.state.page + 1 < pagesLength;
|
|
|
|
var TableComponent = this.props.tableComponent;
|
|
var TheadComponent = this.props.theadComponent;
|
|
var TbodyComponent = this.props.tbodyComponent;
|
|
var TrComponent = this.props.trComponent;
|
|
var ThComponent = this.props.thComponent;
|
|
var TdComponent = this.props.tdComponent;
|
|
|
|
var PreviousComponent = this.props.previousComponent || defaultButton;
|
|
var NextComponent = this.props.nextComponent || defaultButton;
|
|
|
|
return _react2.default.createElement(
|
|
'div',
|
|
{ className: (0, _classnames2.default)(this.props.className, 'ReactTable') },
|
|
_react2.default.createElement(
|
|
TableComponent,
|
|
{ className: (0, _classnames2.default)(this.props.tableClassName) },
|
|
this.hasHeaderGroups && _react2.default.createElement(
|
|
TheadComponent,
|
|
{ className: (0, _classnames2.default)(this.props.theadClassName, '-headerGroups') },
|
|
_react2.default.createElement(
|
|
TrComponent,
|
|
{ className: this.props.trClassName },
|
|
this.headerGroups.map(function (column, i) {
|
|
return _react2.default.createElement(
|
|
ThComponent,
|
|
{
|
|
key: i,
|
|
className: (0, _classnames2.default)(column.className),
|
|
colSpan: column.columns.length },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{
|
|
className: (0, _classnames2.default)(column.innerClassName, '-th-inner') },
|
|
typeof column.header === 'function' ? _react2.default.createElement(column.header, {
|
|
data: _this4.props.data,
|
|
column: column
|
|
}) : column.header
|
|
)
|
|
);
|
|
})
|
|
)
|
|
),
|
|
_react2.default.createElement(
|
|
TheadComponent,
|
|
{ className: (0, _classnames2.default)(this.props.theadClassName) },
|
|
_react2.default.createElement(
|
|
TrComponent,
|
|
{ className: this.props.trClassName },
|
|
this.decoratedColumns.map(function (column, i) {
|
|
var sort = _this4.state.sorting.find(function (d) {
|
|
return d.id === column.id;
|
|
});
|
|
var show = typeof column.show === 'function' ? column.show() : column.show;
|
|
return _react2.default.createElement(
|
|
ThComponent,
|
|
{
|
|
key: i,
|
|
className: (0, _classnames2.default)(column.className, sort ? sort.asc ? '-sort-asc' : '-sort-desc' : '', {
|
|
'-cursor-pointer': column.sortable,
|
|
'-hidden': !show
|
|
}),
|
|
onClick: function onClick(e) {
|
|
column.sortable && _this4.sortColumn(column, e.shiftKey);
|
|
} },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{
|
|
className: (0, _classnames2.default)(column.innerClassName, '-th-inner'),
|
|
style: {
|
|
width: column.width + 'px',
|
|
minWidth: column.minWidth + 'px'
|
|
} },
|
|
typeof column.header === 'function' ? _react2.default.createElement(column.header, {
|
|
data: _this4.props.data,
|
|
column: column
|
|
}) : column.header
|
|
)
|
|
);
|
|
})
|
|
)
|
|
),
|
|
_react2.default.createElement(
|
|
TbodyComponent,
|
|
{ className: (0, _classnames2.default)(this.props.tbodyClassName) },
|
|
pageRows.map(function (row, i) {
|
|
return _react2.default.createElement(
|
|
TrComponent,
|
|
{
|
|
className: (0, _classnames2.default)(_this4.props.trClassName),
|
|
key: i },
|
|
_this4.decoratedColumns.map(function (column, i2) {
|
|
var Cell = column.render;
|
|
var show = typeof column.show === 'function' ? column.show() : column.show;
|
|
return _react2.default.createElement(
|
|
TdComponent,
|
|
{
|
|
className: (0, _classnames2.default)(column.className, { hidden: !show }),
|
|
key: i2 },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{
|
|
className: (0, _classnames2.default)(column.innerClassName, '-td-inner'),
|
|
style: {
|
|
width: column.width + 'px',
|
|
minWidth: column.minWidth + 'px'
|
|
} },
|
|
typeof Cell === 'function' ? _react2.default.createElement(Cell, {
|
|
value: row[column.id],
|
|
row: row.__original,
|
|
index: row.__index,
|
|
viewIndex: i
|
|
}) : typeof Cell !== 'undefined' ? Cell : row[column.id]
|
|
)
|
|
);
|
|
})
|
|
);
|
|
}),
|
|
padRows.map(function (row, i) {
|
|
return _react2.default.createElement(
|
|
TrComponent,
|
|
{
|
|
className: (0, _classnames2.default)(_this4.props.trClassName, '-padRow'),
|
|
key: i },
|
|
_this4.decoratedColumns.map(function (column, i2) {
|
|
var show = typeof column.show === 'function' ? column.show() : column.show;
|
|
return _react2.default.createElement(
|
|
TdComponent,
|
|
{
|
|
className: (0, _classnames2.default)(column.className, { hidden: !show }),
|
|
key: i2 },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{
|
|
className: (0, _classnames2.default)(column.innerClassName, '-td-inner'),
|
|
style: {
|
|
width: column.width + 'px',
|
|
minWidth: column.minWidth + 'px'
|
|
} },
|
|
'\xA0'
|
|
)
|
|
);
|
|
})
|
|
);
|
|
})
|
|
)
|
|
),
|
|
pagesLength > 1 && _react2.default.createElement(
|
|
'div',
|
|
{ className: (0, _classnames2.default)(this.props.paginationClassName, '-pagination') },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{ className: '-left' },
|
|
_react2.default.createElement(
|
|
PreviousComponent,
|
|
{
|
|
onClick: canPrevious && function (e) {
|
|
return _this4.previousPage(e);
|
|
},
|
|
disabled: !canPrevious },
|
|
this.props.previousText
|
|
)
|
|
),
|
|
_react2.default.createElement(
|
|
'div',
|
|
{ className: '-center' },
|
|
'Page ',
|
|
this.state.page + 1,
|
|
' of ',
|
|
pagesLength
|
|
),
|
|
_react2.default.createElement(
|
|
'div',
|
|
{ className: '-right' },
|
|
_react2.default.createElement(
|
|
NextComponent,
|
|
{
|
|
onClick: canNext && function (e) {
|
|
return _this4.nextPage(e);
|
|
},
|
|
disabled: !canNext },
|
|
this.props.nextText
|
|
)
|
|
)
|
|
),
|
|
_react2.default.createElement(
|
|
'div',
|
|
{ className: (0, _classnames2.default)('-loading', { '-active': this.state.loading }) },
|
|
_react2.default.createElement(
|
|
'div',
|
|
{ className: '-loading-inner' },
|
|
this.props.loadingText
|
|
)
|
|
)
|
|
);
|
|
},
|
|
sortColumn: function sortColumn(column, additive) {
|
|
var existingSorting = this.state.sorting || [];
|
|
var sorting = _.clone(this.state.sorting || []);
|
|
var existingIndex = sorting.findIndex(function (d) {
|
|
return d.id === column.id;
|
|
});
|
|
if (existingIndex > -1) {
|
|
var existing = sorting[existingIndex];
|
|
if (existing.asc) {
|
|
existing.asc = false;
|
|
if (!additive) {
|
|
sorting = [existing];
|
|
}
|
|
} else {
|
|
if (additive) {
|
|
sorting.splice(existingIndex, 1);
|
|
} else {
|
|
existing.asc = true;
|
|
sorting = [existing];
|
|
}
|
|
}
|
|
} else {
|
|
if (additive) {
|
|
sorting.push({
|
|
id: column.id,
|
|
asc: true
|
|
});
|
|
} else {
|
|
sorting = [{
|
|
id: column.id,
|
|
asc: true
|
|
}];
|
|
}
|
|
}
|
|
var page = existingIndex === 0 || !existingSorting.length && sorting.length || !additive ? 0 : this.state.page;
|
|
this.buildData(this.props, Object.assign({}, this.state, { page: page, sorting: sorting }));
|
|
},
|
|
nextPage: function nextPage(e) {
|
|
e.preventDefault();
|
|
this.setPage(this.state.page + 1);
|
|
},
|
|
previousPage: function previousPage(e) {
|
|
e.preventDefault();
|
|
this.setPage(this.state.page - 1);
|
|
}
|
|
});
|
|
|
|
// ########################################################################
|
|
// Utils
|
|
// ########################################################################
|
|
|
|
function remove(a, b) {
|
|
return a.filter(function (o, i) {
|
|
var r = b(o);
|
|
if (r) {
|
|
a.splice(i, 1);
|
|
return true;
|
|
}
|
|
return false;
|
|
});
|
|
}
|
|
|
|
function get(a, b) {
|
|
if (isArray(b)) {
|
|
b = b.join('.');
|
|
}
|
|
return b.replace('[', '.').replace(']', '').split('.').reduce(function (obj, property) {
|
|
return obj[property];
|
|
}, a);
|
|
}
|
|
|
|
function takeRight(arr, n) {
|
|
var start = n > arr.length ? 0 : arr.length - n;
|
|
return arr.slice(start);
|
|
}
|
|
|
|
function last(arr) {
|
|
return arr[arr.length - 1];
|
|
}
|
|
|
|
function range(n) {
|
|
var arr = [];
|
|
for (var i = 0; i < n; i++) {
|
|
arr.push(n);
|
|
}
|
|
return arr;
|
|
}
|
|
|
|
function orderBy(arr, funcs, dirs) {
|
|
return arr.sort(function (a, b) {
|
|
for (var i = 0; i < funcs.length; i++) {
|
|
var comp = funcs[i];
|
|
var ca = comp(a);
|
|
var cb = comp(b);
|
|
var desc = dirs[i] === false || dirs[i] === 'desc';
|
|
if (ca > cb) {
|
|
return desc ? -1 : 1;
|
|
}
|
|
if (ca < cb) {
|
|
return desc ? 1 : -1;
|
|
}
|
|
}
|
|
return 0;
|
|
});
|
|
}
|
|
|
|
function clone(a) {
|
|
return JSON.parse(JSON.stringify(a, function (key, value) {
|
|
if (typeof value === 'function') {
|
|
return value.toString();
|
|
}
|
|
return value;
|
|
}));
|
|
}
|
|
|
|
// ########################################################################
|
|
// Helpers
|
|
// ########################################################################
|
|
|
|
function isArray(a) {
|
|
return Array.isArray(a);
|
|
}
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/index.js"],"names":["_","get","takeRight","last","orderBy","range","clone","remove","defaultButton","props","children","ReactTableDefaults","className","tableClassName","theadClassName","tbodyClassName","trClassName","paginationClassName","pageSize","minRows","column","sortable","show","previousText","nextText","loadingText","tableComponent","theadComponent","tbodyComponent","trComponent","thComponent","tdComponent","previousComponent","nextComponent","data","createClass","getDefaultProps","getInitialState","sorting","componentWillMount","update","componentWillReceiveProps","nextProps","resetState","loading","page","pages","setState","newState","Object","assign","state","isAsync","buildColumns","buildData","hasHeaderGroups","columns","forEach","headerGroups","decoratedColumns","currentSpan","addHeader","push","makeDecoratedColumn","dcol","accessor","id","accessorString","row","console","warn","Error","undefined","i","nestedColumn","length","getInitSorting","initSorting","filter","d","sort","map","asc","setData","cb","res","Promise","reject","accessedData","accessData","rows","dataRes","then","sortedData","sortData","__original","__index","resolvedSorting","Infinity","toLowerCase","setPage","render","pagesLength","Math","ceil","startRow","endRow","pageRows","slice","padRows","max","canPrevious","canNext","TableComponent","TheadComponent","TbodyComponent","TrComponent","ThComponent","TdComponent","PreviousComponent","NextComponent","innerClassName","header","find","e","sortColumn","shiftKey","width","minWidth","i2","Cell","hidden","previousPage","nextPage","additive","existingSorting","existingIndex","findIndex","existing","splice","preventDefault","a","b","o","r","isArray","join","replace","split","reduce","obj","property","arr","n","start","funcs","dirs","comp","ca","desc","JSON","parse","stringify","key","value","toString","Array"],"mappings":"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","file":"index.js","sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\n//\nconst _ = {\n  get,\n  takeRight,\n  last,\n  orderBy,\n  range,\n  clone,\n  remove\n}\n\nconst defaultButton = (props) => (\n  <button {...props} className='-btn'>{props.children}</button>\n)\n\nexport const ReactTableDefaults = {\n  // Classes\n  className: '-striped -highlight',\n  tableClassName: '',\n  theadClassName: '',\n  tbodyClassName: '',\n  trClassName: '',\n  paginationClassName: '',\n  //\n  pageSize: 20,\n  minRows: 0,\n  // Global Column Defaults\n  column: {\n    sortable: true,\n    show: true\n  },\n  // Text\n  previousText: 'Previous',\n  nextText: 'Next',\n  loadingText: 'Loading...',\n  // Components\n  tableComponent: (props) => <table {...props}>{props.children}</table>,\n  theadComponent: (props) => <thead {...props}>{props.children}</thead>,\n  tbodyComponent: (props) => <tbody {...props}>{props.children}</tbody>,\n  trComponent: (props) => <tr {...props}>{props.children}</tr>,\n  thComponent: (props) => <th {...props}>{props.children}</th>,\n  tdComponent: (props) => <td {...props}>{props.children}</td>,\n  previousComponent: null,\n  nextComponent: null,\n  // Unlisted\n  data: []\n}\n\nexport default React.createClass({\n  getDefaultProps () {\n    return ReactTableDefaults\n  },\n  getInitialState () {\n    return {\n      sorting: false\n    }\n  },\n  componentWillMount () {\n    this.update(this.props)\n  },\n  componentWillReceiveProps (nextProps) {\n    this.update(nextProps)\n  },\n  update (props) {\n    const resetState = {\n      loading: false,\n      page: 0,\n      pages: -1\n      // columns: {}  for column hiding in the future\n    }\n    this.setState(resetState)\n    const newState = Object.assign({}, this.state, resetState)\n    this.isAsync = typeof props.data === 'function'\n    this.buildColumns(props, newState)\n    this.buildData(props, newState)\n  },\n  buildColumns (props) {\n    this.hasHeaderGroups = false\n    props.columns.forEach(column => {\n      if (column.columns) {\n        this.hasHeaderGroups = true\n      }\n    })\n\n    this.headerGroups = []\n    this.decoratedColumns = []\n    let currentSpan = []\n\n    const addHeader = (columns, column = {}) => {\n      this.headerGroups.push(Object.assign({}, column, {\n        columns: columns\n      }))\n      currentSpan = []\n    }\n    const makeDecoratedColumn = (column) => {\n      const dcol = Object.assign({}, this.props.column, column)\n\n      if (typeof dcol.accessor === 'string') {\n        dcol.id = dcol.id || dcol.accessor\n        const accessorString = dcol.accessor\n        dcol.accessor = row => _.get(row, accessorString)\n        return dcol\n      }\n\n      if (dcol.accessor && !dcol.id) {\n        console.warn(dcol)\n        throw new Error('A column id is required if using a non-string accessor for column above.')\n      }\n\n      dcol.accessor = d => undefined\n      return dcol\n    }\n\n    props.columns.forEach((column, i) => {\n      if (column.columns) {\n        column.columns.forEach(nestedColumn => {\n          this.decoratedColumns.push(makeDecoratedColumn(nestedColumn))\n        })\n        if (this.hasHeaderGroups) {\n          if (currentSpan.length > 0) {\n            addHeader(currentSpan)\n          }\n          addHeader(_.takeRight(this.decoratedColumns, column.columns.length), column)\n        }\n      } else {\n        this.decoratedColumns.push(makeDecoratedColumn(column))\n        currentSpan.push(_.last(this.decoratedColumns))\n      }\n    })\n\n    if (this.hasHeaderGroups && currentSpan.length > 0) {\n      addHeader(currentSpan)\n    }\n  },\n  getInitSorting () {\n    const initSorting = this.decoratedColumns.filter(d => {\n      return typeof d.sort !== 'undefined'\n    }).map(d => {\n      return {\n        id: d.id,\n        asc: d.sort === 'asc'\n      }\n    })\n\n    return initSorting.length ? initSorting : [{\n      id: this.decoratedColumns[0].id,\n      asc: true\n    }]\n  },\n  buildData (props, state) {\n    const sorting = state.sorting === false ? this.getInitSorting() : state.sorting\n\n    const setData = (data) => {\n      this.setState({\n        sorting,\n        data,\n        page: state.page,\n        loading: false\n      })\n    }\n\n    if (this.isAsync) {\n      this.setState({\n        loading: true\n      })\n\n      const cb = (res) => {\n        if (!res) {\n          return Promise.reject('Uh Oh! Nothing was returned in ReactTable\\'s data callback!')\n        }\n        if (res.pages) {\n          this.setState({\n            pages: res.pages\n          })\n        }\n        // Only access the data. Sorting is done server side.\n        const accessedData = this.accessData(res.rows)\n        setData(accessedData)\n      }\n\n      // Fetch data with current state\n      const dataRes = props.data({\n        sorting,\n        page: state.page || 0,\n        pageSize: props.pageSize,\n        pages: state.pages\n      }, cb)\n\n      if (dataRes && dataRes.then) {\n        dataRes.then(cb)\n      }\n    } else {\n      // Return locally accessed, sorted data\n      const accessedData = this.accessData(props.data)\n      const sortedData = this.sortData(accessedData, sorting)\n      setData(sortedData)\n    }\n  },\n  accessData (data) {\n    return data.map((d, i) => {\n      const row = {\n        __original: d,\n        __index: i\n      }\n      this.decoratedColumns.forEach(column => {\n        row[column.id] = column.accessor(d)\n      })\n      return row\n    })\n  },\n  sortData (data, sorting) {\n    const resolvedSorting = sorting.length ? sorting : this.getInitSorting()\n    return _.orderBy(data, resolvedSorting.map(sort => {\n      return row => {\n        if (row[sort.id] === null || row[sort.id] === undefined) {\n          return -Infinity\n        }\n        return typeof row[sort.id] === 'string' ? row[sort.id].toLowerCase() : row[sort.id]\n      }\n    }), resolvedSorting.map(d => d.asc ? 'asc' : 'desc'))\n  },\n  setPage (page) {\n    if (this.isAsync) {\n      return this.buildData(this.props, Object.assign({}, this.state, {page}))\n    }\n    this.setState({\n      page\n    })\n  },\n\n  render () {\n    const data = this.state.data ? this.state.data : []\n\n    const pagesLength = this.isAsync ? this.state.pages : Math.ceil(data.length / this.props.pageSize)\n    const startRow = this.props.pageSize * this.state.page\n    const endRow = startRow + this.props.pageSize\n    const pageRows = this.isAsync ? data.slice(0, this.props.pageSize) : data.slice(startRow, endRow)\n    const padRows = pagesLength > 1 ? _.range(this.props.pageSize - pageRows.length)\n      : this.props.minRows ? _.range(Math.max(this.props.minRows - pageRows.length, 0))\n      : []\n\n    const canPrevious = this.state.page > 0\n    const canNext = this.state.page + 1 < pagesLength\n\n    const TableComponent = this.props.tableComponent\n    const TheadComponent = this.props.theadComponent\n    const TbodyComponent = this.props.tbodyComponent\n    const TrComponent = this.props.trComponent\n    const ThComponent = this.props.thComponent\n    const TdComponent = this.props.tdComponent\n\n    const PreviousComponent = this.props.previousComponent || defaultButton\n    const NextComponent = this.props.nextComponent || defaultButton\n\n    return (\n      <div className={classnames(this.props.className, 'ReactTable')}>\n        <TableComponent className={classnames(this.props.tableClassName)}>\n          {this.hasHeaderGroups && (\n            <TheadComponent className={classnames(this.props.theadClassName, '-headerGroups')}>\n              <TrComponent className={this.props.trClassName}>\n                {this.headerGroups.map((column, i) => {\n                  return (\n                    <ThComponent\n                      key={i}\n                      className={classnames(column.className)}\n                      colSpan={column.columns.length}>\n                      <div\n                        className={classnames(column.innerClassName, '-th-inner')}>\n                        {typeof column.header === 'function' ? (\n                          <column.header\n                            data={this.props.data}\n                            column={column}\n                          />\n                        ) : column.header}\n                      </div>\n                    </ThComponent>\n                  )\n                })}\n              </TrComponent>\n            </TheadComponent>\n          )}\n          <TheadComponent className={classnames(this.props.theadClassName)}>\n            <TrComponent className={this.props.trClassName}>\n              {this.decoratedColumns.map((column, i) => {\n                const sort = this.state.sorting.find(d => d.id === column.id)\n                const show = typeof column.show === 'function' ? column.show() : column.show\n                return (\n                  <ThComponent\n                    key={i}\n                    className={classnames(\n                      column.className,\n                      sort ? (sort.asc ? '-sort-asc' : '-sort-desc') : '',\n                      {\n                        '-cursor-pointer': column.sortable,\n                        '-hidden': !show\n                      }\n                    )}\n                    onClick={(e) => {\n                      column.sortable && this.sortColumn(column, e.shiftKey)\n                    }}>\n                    <div\n                      className={classnames(column.innerClassName, '-th-inner')}\n                      style={{\n                        width: column.width + 'px',\n                        minWidth: column.minWidth + 'px'\n                      }}>\n                      {typeof column.header === 'function' ? (\n                        <column.header\n                          data={this.props.data}\n                          column={column}\n                        />\n                      ) : column.header}\n                    </div>\n                  </ThComponent>\n                )\n              })}\n            </TrComponent>\n          </TheadComponent>\n          <TbodyComponent className={classnames(this.props.tbodyClassName)}>\n            {pageRows.map((row, i) => {\n              return (\n                <TrComponent\n                  className={classnames(this.props.trClassName)}\n                  key={i}>\n                  {this.decoratedColumns.map((column, i2) => {\n                    const Cell = column.render\n                    const show = typeof column.show === 'function' ? column.show() : column.show\n                    return (\n                      <TdComponent\n                        className={classnames(column.className, {hidden: !show})}\n                        key={i2}>\n                        <div\n                          className={classnames(column.innerClassName, '-td-inner')}\n                          style={{\n                            width: column.width + 'px',\n                            minWidth: column.minWidth + 'px'\n                          }}>\n                          {typeof Cell === 'function' ? (\n                            <Cell\n                              value={row[column.id]}\n                              row={row.__original}\n                              index={row.__index}\n                              viewIndex={i}\n                            />\n                            ) : typeof Cell !== 'undefined' ? Cell\n                          : row[column.id]}\n                        </div>\n                      </TdComponent>\n                    )\n                  })}\n                </TrComponent>\n              )\n            })}\n            {padRows.map((row, i) => {\n              return (\n                <TrComponent\n                  className={classnames(this.props.trClassName, '-padRow')}\n                  key={i}>\n                  {this.decoratedColumns.map((column, i2) => {\n                    const show = typeof column.show === 'function' ? column.show() : column.show\n                    return (\n                      <TdComponent\n                        className={classnames(column.className, {hidden: !show})}\n                        key={i2}>\n                        <div\n                          className={classnames(column.innerClassName, '-td-inner')}\n                          style={{\n                            width: column.width + 'px',\n                            minWidth: column.minWidth + 'px'\n                          }}>&nbsp;</div>\n                      </TdComponent>\n                    )\n                  })}\n                </TrComponent>\n              )\n            })}\n          </TbodyComponent>\n        </TableComponent>\n        {pagesLength > 1 && (\n          <div className={classnames(this.props.paginationClassName, '-pagination')}>\n            <div className='-left'>\n              <PreviousComponent\n                onClick={canPrevious && ((e) => this.previousPage(e))}\n                disabled={!canPrevious}>\n                {this.props.previousText}\n              </PreviousComponent>\n            </div>\n            <div className='-center'>\n              Page {this.state.page + 1} of {pagesLength}\n            </div>\n            <div className='-right'>\n              <NextComponent\n                onClick={canNext && ((e) => this.nextPage(e))}\n                disabled={!canNext}>\n                {this.props.nextText}\n              </NextComponent>\n            </div>\n          </div>\n        )}\n        <div className={classnames('-loading', {'-active': this.state.loading})}>\n          <div className='-loading-inner'>\n            {this.props.loadingText}\n          </div>\n        </div>\n      </div>\n    )\n  },\n  sortColumn (column, additive) {\n    const existingSorting = this.state.sorting || []\n    let sorting = _.clone(this.state.sorting || [])\n    const existingIndex = sorting.findIndex(d => d.id === column.id)\n    if (existingIndex > -1) {\n      const existing = sorting[existingIndex]\n      if (existing.asc) {\n        existing.asc = false\n        if (!additive) {\n          sorting = [existing]\n        }\n      } else {\n        if (additive) {\n          sorting.splice(existingIndex, 1)\n        } else {\n          existing.asc = true\n          sorting = [existing]\n        }\n      }\n    } else {\n      if (additive) {\n        sorting.push({\n          id: column.id,\n          asc: true\n        })\n      } else {\n        sorting = [{\n          id: column.id,\n          asc: true\n        }]\n      }\n    }\n    const page = (existingIndex === 0 || (!existingSorting.length && sorting.length) || !additive) ? 0 : this.state.page\n    this.buildData(this.props, Object.assign({}, this.state, {page, sorting}))\n  },\n  nextPage (e) {\n    e.preventDefault()\n    this.setPage(this.state.page + 1)\n  },\n  previousPage (e) {\n    e.preventDefault()\n    this.setPage(this.state.page - 1)\n  }\n})\n\n// ########################################################################\n// Utils\n// ########################################################################\n\nfunction remove (a, b) {\n  return a.filter(function (o, i) {\n    var r = b(o)\n    if (r) {\n      a.splice(i, 1)\n      return true\n    }\n    return false\n  })\n}\n\nfunction get (a, b) {\n  if (isArray(b)) {\n    b = b.join('.')\n  }\n  return b\n    .replace('[', '.').replace(']', '')\n    .split('.')\n    .reduce(\n      function (obj, property) {\n        return obj[property]\n      }, a\n    )\n}\n\nfunction takeRight (arr, n) {\n  const start = n > arr.length ? 0 : arr.length - n\n  return arr.slice(start)\n}\n\nfunction last (arr) {\n  return arr[arr.length - 1]\n}\n\nfunction range (n) {\n  const arr = []\n  for (let i = 0; i < n; i++) {\n    arr.push(n)\n  }\n  return arr\n}\n\nfunction orderBy (arr, funcs, dirs) {\n  return arr.sort((a, b) => {\n    for (let i = 0; i < funcs.length; i++) {\n      const comp = funcs[i]\n      const ca = comp(a)\n      const cb = comp(b)\n      const desc = dirs[i] === false || dirs[i] === 'desc'\n      if (ca > cb) {\n        return desc ? -1 : 1\n      }\n      if (ca < cb) {\n        return desc ? 1 : -1\n      }\n    }\n    return 0\n  })\n}\n\nfunction clone (a) {\n  return JSON.parse(JSON.stringify(a, function (key, value) {\n    if (typeof value === 'function') {\n      return value.toString()\n    }\n    return value\n  }))\n}\n\n// ########################################################################\n// Helpers\n// ########################################################################\n\nfunction isArray (a) {\n  return Array.isArray(a)\n}\n"]}
|