react-table-6
Version:
A fast, lightweight, opinionated table and datagrid built on React
355 lines (332 loc) • 31.8 kB
JavaScript
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; };
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
import React from 'react';
import classnames from 'classnames';
//
import _ from './utils';
import Pagination from './pagination';
var emptyObj = function emptyObj() {
return {};
};
export default {
// General
data: [],
resolveData: function resolveData(data) {
return data;
},
loading: false,
showPagination: true,
showPaginationTop: false,
showPaginationBottom: true,
showPageSizeOptions: true,
pageSizeOptions: [5, 10, 20, 25, 50, 100],
defaultPage: 0,
defaultPageSize: 20,
showPageJump: true,
collapseOnSortingChange: true,
collapseOnPageChange: true,
collapseOnDataChange: true,
freezeWhenExpanded: false,
sortable: true,
multiSort: true,
resizable: true,
filterable: false,
defaultSortDesc: false,
defaultSorted: [],
defaultFiltered: [],
defaultResized: [],
defaultExpanded: {},
// eslint-disable-next-line no-unused-vars
defaultFilterMethod: function defaultFilterMethod(filter, row, column) {
var id = filter.pivotId || filter.id;
return row[id] !== undefined ? String(row[id]).startsWith(filter.value) : true;
},
// eslint-disable-next-line no-unused-vars
defaultSortMethod: function defaultSortMethod(a, b, desc) {
// force null and undefined to the bottom
a = a === null || a === undefined ? '' : a;
b = b === null || b === undefined ? '' : b;
// force any string values to lowercase
a = typeof a === 'string' ? a.toLowerCase() : a;
b = typeof b === 'string' ? b.toLowerCase() : b;
// Return either 1 or -1 to indicate a sort priority
if (a > b) {
return 1;
}
if (a < b) {
return -1;
}
// returning 0, undefined or any falsey value will use subsequent sorts or
// the index as a tiebreaker
return 0;
},
// Controlled State Props
// page: undefined,
// pageSize: undefined,
// sorted: [],
// filtered: [],
// resized: [],
// expanded: {},
// Controlled State Callbacks
onPageChange: undefined,
onPageSizeChange: undefined,
onSortedChange: undefined,
onFilteredChange: undefined,
onResizedChange: undefined,
onExpandedChange: undefined,
// Pivoting
pivotBy: undefined,
// Key Constants
pivotValKey: '_pivotVal',
pivotIDKey: '_pivotID',
subRowsKey: '_subRows',
aggregatedKey: '_aggregated',
nestingLevelKey: '_nestingLevel',
originalKey: '_original',
indexKey: '_index',
groupedByPivotKey: '_groupedByPivot',
// Server-side Callbacks
onFetchData: function onFetchData() {
return null;
},
// Classes
className: '',
style: {},
// Component decorators
getProps: emptyObj,
getTableProps: emptyObj,
getTheadGroupProps: emptyObj,
getTheadGroupTrProps: emptyObj,
getTheadGroupThProps: emptyObj,
getTheadProps: emptyObj,
getTheadTrProps: emptyObj,
getTheadThProps: emptyObj,
getTheadFilterProps: emptyObj,
getTheadFilterTrProps: emptyObj,
getTheadFilterThProps: emptyObj,
getTbodyProps: emptyObj,
getTrGroupProps: emptyObj,
getTrProps: emptyObj,
getTdProps: emptyObj,
getTfootProps: emptyObj,
getTfootTrProps: emptyObj,
getTfootTdProps: emptyObj,
getPaginationProps: emptyObj,
getLoadingProps: emptyObj,
getNoDataProps: emptyObj,
getResizerProps: emptyObj,
// Global Column Defaults
column: {
// Renderers
Cell: undefined,
Header: undefined,
Footer: undefined,
Aggregated: undefined,
Pivot: undefined,
PivotValue: undefined,
Expander: undefined,
Filter: undefined,
Placeholder: undefined,
// All Columns
sortable: undefined, // use table default
resizable: undefined, // use table default
filterable: undefined, // use table default
show: true,
minWidth: 100,
minResizeWidth: 11,
// Cells only
className: '',
style: {},
getProps: emptyObj,
// Pivot only
aggregate: undefined,
// Headers only
headerClassName: '',
headerStyle: {},
getHeaderProps: emptyObj,
// Footers only
footerClassName: '',
footerStyle: {},
getFooterProps: emptyObj,
filterMethod: undefined,
filterAll: false,
sortMethod: undefined
},
// Global Expander Column Defaults
expanderDefaults: {
sortable: false,
resizable: false,
filterable: false,
width: 35
},
pivotDefaults: {
// extend the defaults for pivoted columns here
},
// Text
previousText: 'Previous',
nextText: 'Next',
loadingText: 'Loading...',
noDataText: 'No rows found',
pageText: 'Page',
ofText: 'of',
rowsText: 'rows',
pageJumpText: 'jump to page',
rowsSelectorText: 'rows per page',
// Components
TableComponent: function TableComponent(_ref) {
var children = _ref.children,
className = _ref.className,
rest = _objectWithoutProperties(_ref, ['children', 'className']);
return React.createElement(
'div',
_extends({
className: classnames('rt-table', className),
role: 'grid'
// tabIndex='0'
}, rest),
children
);
},
TheadComponent: _.makeTemplateComponent('rt-thead', 'Thead'),
TbodyComponent: _.makeTemplateComponent('rt-tbody', 'Tbody'),
TrGroupComponent: function TrGroupComponent(_ref2) {
var children = _ref2.children,
className = _ref2.className,
rest = _objectWithoutProperties(_ref2, ['children', 'className']);
return React.createElement(
'div',
_extends({ className: classnames('rt-tr-group', className), role: 'rowgroup' }, rest),
children
);
},
TrComponent: function TrComponent(_ref3) {
var children = _ref3.children,
className = _ref3.className,
rest = _objectWithoutProperties(_ref3, ['children', 'className']);
return React.createElement(
'div',
_extends({ className: classnames('rt-tr', className), role: 'row' }, rest),
children
);
},
ThComponent: function ThComponent(_ref4) {
var toggleSort = _ref4.toggleSort,
className = _ref4.className,
children = _ref4.children,
rest = _objectWithoutProperties(_ref4, ['toggleSort', 'className', 'children']);
return (
// eslint-disable-next-line jsx-a11y/click-events-have-key-events
React.createElement(
'div',
_extends({
className: classnames('rt-th', className),
onClick: function onClick(e) {
return toggleSort && toggleSort(e);
},
role: 'columnheader',
tabIndex: '-1' // Resolves eslint issues without implementing keyboard navigation incorrectly
}, rest),
children
)
);
},
TdComponent: function TdComponent(_ref5) {
var toggleSort = _ref5.toggleSort,
className = _ref5.className,
children = _ref5.children,
rest = _objectWithoutProperties(_ref5, ['toggleSort', 'className', 'children']);
return React.createElement(
'div',
_extends({ className: classnames('rt-td', className), role: 'gridcell' }, rest),
children
);
},
TfootComponent: _.makeTemplateComponent('rt-tfoot', 'Tfoot'),
FilterComponent: function FilterComponent(_ref6) {
var filter = _ref6.filter,
_onChange = _ref6.onChange,
column = _ref6.column;
return React.createElement('input', {
type: 'text',
style: {
width: '100%'
},
placeholder: column.Placeholder,
value: filter ? filter.value : '',
onChange: function onChange(event) {
return _onChange(event.target.value);
}
});
},
ExpanderComponent: function ExpanderComponent(_ref7) {
var isExpanded = _ref7.isExpanded;
return React.createElement(
'div',
{ className: classnames('rt-expander', isExpanded && '-open') },
'\u2022'
);
},
PivotValueComponent: function PivotValueComponent(_ref8) {
var subRows = _ref8.subRows,
value = _ref8.value;
return React.createElement(
'span',
null,
value,
' ',
subRows && '(' + subRows.length + ')'
);
},
AggregatedComponent: function AggregatedComponent(_ref9) {
var subRows = _ref9.subRows,
column = _ref9.column;
var previewValues = subRows.filter(function (d) {
return typeof d[column.id] !== 'undefined';
}).map(function (row, i) {
return (
// eslint-disable-next-line react/no-array-index-key
React.createElement(
'span',
{ key: i },
row[column.id],
i < subRows.length - 1 ? ', ' : ''
)
);
});
return React.createElement(
'span',
null,
previewValues
);
},
PivotComponent: undefined, // this is a computed default generated using
// the ExpanderComponent and PivotValueComponent at run-time in methods.js
PaginationComponent: Pagination,
PreviousComponent: undefined,
NextComponent: undefined,
LoadingComponent: function LoadingComponent(_ref10) {
var className = _ref10.className,
loading = _ref10.loading,
loadingText = _ref10.loadingText,
rest = _objectWithoutProperties(_ref10, ['className', 'loading', 'loadingText']);
return React.createElement(
'div',
_extends({ className: classnames('-loading', { '-active': loading }, className) }, rest),
React.createElement(
'div',
{ className: '-loading-inner' },
loadingText
)
);
},
NoDataComponent: _.makeTemplateComponent('rt-noData', 'NoData'),
ResizerComponent: _.makeTemplateComponent('rt-resizer', 'Resizer'),
PadRowComponent: function PadRowComponent() {
return React.createElement(
'span',
null,
'\xA0'
);
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/defaultProps.js"],"names":["React","classnames","_","Pagination","emptyObj","data","resolveData","loading","showPagination","showPaginationTop","showPaginationBottom","showPageSizeOptions","pageSizeOptions","defaultPage","defaultPageSize","showPageJump","collapseOnSortingChange","collapseOnPageChange","collapseOnDataChange","freezeWhenExpanded","sortable","multiSort","resizable","filterable","defaultSortDesc","defaultSorted","defaultFiltered","defaultResized","defaultExpanded","defaultFilterMethod","filter","row","column","id","pivotId","undefined","String","startsWith","value","defaultSortMethod","a","b","desc","toLowerCase","onPageChange","onPageSizeChange","onSortedChange","onFilteredChange","onResizedChange","onExpandedChange","pivotBy","pivotValKey","pivotIDKey","subRowsKey","aggregatedKey","nestingLevelKey","originalKey","indexKey","groupedByPivotKey","onFetchData","className","style","getProps","getTableProps","getTheadGroupProps","getTheadGroupTrProps","getTheadGroupThProps","getTheadProps","getTheadTrProps","getTheadThProps","getTheadFilterProps","getTheadFilterTrProps","getTheadFilterThProps","getTbodyProps","getTrGroupProps","getTrProps","getTdProps","getTfootProps","getTfootTrProps","getTfootTdProps","getPaginationProps","getLoadingProps","getNoDataProps","getResizerProps","Cell","Header","Footer","Aggregated","Pivot","PivotValue","Expander","Filter","Placeholder","show","minWidth","minResizeWidth","aggregate","headerClassName","headerStyle","getHeaderProps","footerClassName","footerStyle","getFooterProps","filterMethod","filterAll","sortMethod","expanderDefaults","width","pivotDefaults","previousText","nextText","loadingText","noDataText","pageText","ofText","rowsText","pageJumpText","rowsSelectorText","TableComponent","children","rest","TheadComponent","makeTemplateComponent","TbodyComponent","TrGroupComponent","TrComponent","ThComponent","toggleSort","e","TdComponent","TfootComponent","FilterComponent","onChange","event","target","ExpanderComponent","isExpanded","PivotValueComponent","subRows","length","AggregatedComponent","previewValues","d","map","i","PivotComponent","PaginationComponent","PreviousComponent","NextComponent","LoadingComponent","NoDataComponent","ResizerComponent","PadRowComponent"],"mappings":"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","file":"defaultProps.js","sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\n//\nimport _ from './utils'\nimport Pagination from './pagination'\n\nconst emptyObj = () => ({})\n\nexport default {\n  // General\n  data: [],\n  resolveData: data => data,\n  loading: false,\n  showPagination: true,\n  showPaginationTop: false,\n  showPaginationBottom: true,\n  showPageSizeOptions: true,\n  pageSizeOptions: [5, 10, 20, 25, 50, 100],\n  defaultPage: 0,\n  defaultPageSize: 20,\n  showPageJump: true,\n  collapseOnSortingChange: true,\n  collapseOnPageChange: true,\n  collapseOnDataChange: true,\n  freezeWhenExpanded: false,\n  sortable: true,\n  multiSort: true,\n  resizable: true,\n  filterable: false,\n  defaultSortDesc: false,\n  defaultSorted: [],\n  defaultFiltered: [],\n  defaultResized: [],\n  defaultExpanded: {},\n  // eslint-disable-next-line no-unused-vars\n  defaultFilterMethod: (filter, row, column) => {\n    const id = filter.pivotId || filter.id\n    return row[id] !== undefined ? String(row[id]).startsWith(filter.value) : true\n  },\n  // eslint-disable-next-line no-unused-vars\n  defaultSortMethod: (a, b, desc) => {\n    // force null and undefined to the bottom\n    a = a === null || a === undefined ? '' : a\n    b = b === null || b === undefined ? '' : b\n    // force any string values to lowercase\n    a = typeof a === 'string' ? a.toLowerCase() : a\n    b = typeof b === 'string' ? b.toLowerCase() : b\n    // Return either 1 or -1 to indicate a sort priority\n    if (a > b) {\n      return 1\n    }\n    if (a < b) {\n      return -1\n    }\n    // returning 0, undefined or any falsey value will use subsequent sorts or\n    // the index as a tiebreaker\n    return 0\n  },\n\n  // Controlled State Props\n  // page: undefined,\n  // pageSize: undefined,\n  // sorted: [],\n  // filtered: [],\n  // resized: [],\n  // expanded: {},\n\n  // Controlled State Callbacks\n  onPageChange: undefined,\n  onPageSizeChange: undefined,\n  onSortedChange: undefined,\n  onFilteredChange: undefined,\n  onResizedChange: undefined,\n  onExpandedChange: undefined,\n\n  // Pivoting\n  pivotBy: undefined,\n\n  // Key Constants\n  pivotValKey: '_pivotVal',\n  pivotIDKey: '_pivotID',\n  subRowsKey: '_subRows',\n  aggregatedKey: '_aggregated',\n  nestingLevelKey: '_nestingLevel',\n  originalKey: '_original',\n  indexKey: '_index',\n  groupedByPivotKey: '_groupedByPivot',\n\n  // Server-side Callbacks\n  onFetchData: () => null,\n\n  // Classes\n  className: '',\n  style: {},\n\n  // Component decorators\n  getProps: emptyObj,\n  getTableProps: emptyObj,\n  getTheadGroupProps: emptyObj,\n  getTheadGroupTrProps: emptyObj,\n  getTheadGroupThProps: emptyObj,\n  getTheadProps: emptyObj,\n  getTheadTrProps: emptyObj,\n  getTheadThProps: emptyObj,\n  getTheadFilterProps: emptyObj,\n  getTheadFilterTrProps: emptyObj,\n  getTheadFilterThProps: emptyObj,\n  getTbodyProps: emptyObj,\n  getTrGroupProps: emptyObj,\n  getTrProps: emptyObj,\n  getTdProps: emptyObj,\n  getTfootProps: emptyObj,\n  getTfootTrProps: emptyObj,\n  getTfootTdProps: emptyObj,\n  getPaginationProps: emptyObj,\n  getLoadingProps: emptyObj,\n  getNoDataProps: emptyObj,\n  getResizerProps: emptyObj,\n\n  // Global Column Defaults\n  column: {\n    // Renderers\n    Cell: undefined,\n    Header: undefined,\n    Footer: undefined,\n    Aggregated: undefined,\n    Pivot: undefined,\n    PivotValue: undefined,\n    Expander: undefined,\n    Filter: undefined,\n    Placeholder: undefined,\n    // All Columns\n    sortable: undefined, // use table default\n    resizable: undefined, // use table default\n    filterable: undefined, // use table default\n    show: true,\n    minWidth: 100,\n    minResizeWidth: 11,\n    // Cells only\n    className: '',\n    style: {},\n    getProps: emptyObj,\n    // Pivot only\n    aggregate: undefined,\n    // Headers only\n    headerClassName: '',\n    headerStyle: {},\n    getHeaderProps: emptyObj,\n    // Footers only\n    footerClassName: '',\n    footerStyle: {},\n    getFooterProps: emptyObj,\n    filterMethod: undefined,\n    filterAll: false,\n    sortMethod: undefined,\n  },\n\n  // Global Expander Column Defaults\n  expanderDefaults: {\n    sortable: false,\n    resizable: false,\n    filterable: false,\n    width: 35,\n  },\n\n  pivotDefaults: {\n    // extend the defaults for pivoted columns here\n  },\n\n  // Text\n  previousText: 'Previous',\n  nextText: 'Next',\n  loadingText: 'Loading...',\n  noDataText: 'No rows found',\n  pageText: 'Page',\n  ofText: 'of',\n  rowsText: 'rows',\n  pageJumpText: 'jump to page',\n  rowsSelectorText: 'rows per page',\n\n  // Components\n  TableComponent: ({ children, className, ...rest }) => (\n    <div\n      className={classnames('rt-table', className)}\n      role=\"grid\"\n      // tabIndex='0'\n      {...rest}\n    >\n      {children}\n    </div>\n  ),\n  TheadComponent: _.makeTemplateComponent('rt-thead', 'Thead'),\n  TbodyComponent: _.makeTemplateComponent('rt-tbody', 'Tbody'),\n  TrGroupComponent: ({ children, className, ...rest }) => (\n    <div className={classnames('rt-tr-group', className)} role=\"rowgroup\" {...rest}>\n      {children}\n    </div>\n  ),\n  TrComponent: ({ children, className, ...rest }) => (\n    <div className={classnames('rt-tr', className)} role=\"row\" {...rest}>\n      {children}\n    </div>\n  ),\n  ThComponent: ({\n    toggleSort, className, children, ...rest\n  }) => (\n    // eslint-disable-next-line jsx-a11y/click-events-have-key-events\n    <div\n      className={classnames('rt-th', className)}\n      onClick={e => toggleSort && toggleSort(e)}\n      role=\"columnheader\"\n      tabIndex=\"-1\" // Resolves eslint issues without implementing keyboard navigation incorrectly\n      {...rest}\n    >\n      {children}\n    </div>\n  ),\n  TdComponent: ({\n    toggleSort, className, children, ...rest\n  }) => (\n    <div className={classnames('rt-td', className)} role=\"gridcell\" {...rest}>\n      {children}\n    </div>\n  ),\n  TfootComponent: _.makeTemplateComponent('rt-tfoot', 'Tfoot'),\n  FilterComponent: ({ filter, onChange, column }) => (\n    <input\n      type=\"text\"\n      style={{\n        width: '100%',\n      }}\n      placeholder={column.Placeholder}\n      value={filter ? filter.value : ''}\n      onChange={event => onChange(event.target.value)}\n    />\n  ),\n  ExpanderComponent: ({ isExpanded }) => (\n    <div className={classnames('rt-expander', isExpanded && '-open')}>&bull;</div>\n  ),\n  PivotValueComponent: ({ subRows, value }) => (\n    <span>\n      {value} {subRows && `(${subRows.length})`}\n    </span>\n  ),\n  AggregatedComponent: ({ subRows, column }) => {\n    const previewValues = subRows.filter(d => typeof d[column.id] !== 'undefined').map((row, i) => (\n      // eslint-disable-next-line react/no-array-index-key\n      <span key={i}>\n        {row[column.id]}\n        {i < subRows.length - 1 ? ', ' : ''}\n      </span>\n    ))\n    return <span>{previewValues}</span>\n  },\n  PivotComponent: undefined, // this is a computed default generated using\n  // the ExpanderComponent and PivotValueComponent at run-time in methods.js\n  PaginationComponent: Pagination,\n  PreviousComponent: undefined,\n  NextComponent: undefined,\n  LoadingComponent: ({\n    className, loading, loadingText, ...rest\n  }) => (\n    <div className={classnames('-loading', { '-active': loading }, className)} {...rest}>\n      <div className=\"-loading-inner\">{loadingText}</div>\n    </div>\n  ),\n  NoDataComponent: _.makeTemplateComponent('rt-noData', 'NoData'),\n  ResizerComponent: _.makeTemplateComponent('rt-resizer', 'Resizer'),\n  PadRowComponent: () => <span>&nbsp;</span>,\n}\n"]}