mirror of
https://github.com/gosticks/react-table.git
synced 2026-03-31 01:44:31 +00:00
revert 3baa7139fbb5cf5f706ec228036b0e2eac806113 (#1249)
This commit is contained in:
committed by
Tanner Linsley
parent
73b4869329
commit
410417d067
34
src/index.js
34
src/index.js
@@ -124,7 +124,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
PadRowComponent,
|
||||
// Data model
|
||||
resolvedData,
|
||||
visibleColumns,
|
||||
allVisibleColumns,
|
||||
headerGroups,
|
||||
hasHeaderGroups,
|
||||
// Sorted Data
|
||||
@@ -139,8 +139,8 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
const minRows = this.getMinRows()
|
||||
const padRows = _.range(Math.max(minRows - pageRows.length, 0))
|
||||
|
||||
const hasColumnFooter = visibleColumns.some(d => d.Footer)
|
||||
const hasFilters = filterable || visibleColumns.some(d => d.filterable)
|
||||
const hasColumnFooter = allVisibleColumns.some(d => d.Footer)
|
||||
const hasFilters = filterable || allVisibleColumns.some(d => d.filterable)
|
||||
|
||||
const recurseRowsViewIndex = (rows, path = [], index = -1) => [
|
||||
rows.map((row, i) => {
|
||||
@@ -167,7 +167,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
const canNext = page + 1 < pages
|
||||
|
||||
const rowMinWidth = _.sum(
|
||||
visibleColumns.map(d => {
|
||||
allVisibleColumns.map(d => {
|
||||
const resizedColumn = resized.find(x => x.id === d.id) || {}
|
||||
return _.getFirstDefined(resizedColumn.value, d.width, d.minWidth)
|
||||
})
|
||||
@@ -201,13 +201,13 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
|
||||
const leafColumns = _.leaves(column, 'columns')
|
||||
const flex = _.sum(
|
||||
leafColumns.map(col => (col.width || resizedValue(col) ? 0 : col.minWidth))
|
||||
column.columns.map(col => (col.width || resizedValue(col) ? 0 : col.minWidth))
|
||||
)
|
||||
const width = _.sum(
|
||||
leafColumns.map(col => _.getFirstDefined(resizedValue(col), col.width, col.minWidth))
|
||||
column.columns.map(col => _.getFirstDefined(resizedValue(col), col.width, col.minWidth))
|
||||
)
|
||||
const maxWidth = _.sum(
|
||||
leafColumns.map(col => _.getFirstDefined(resizedValue(col), col.width, col.maxWidth))
|
||||
column.columns.map(col => _.getFirstDefined(resizedValue(col), col.width, col.maxWidth))
|
||||
)
|
||||
|
||||
const theadGroupThProps = _.splitProps(
|
||||
@@ -258,9 +258,9 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
)
|
||||
}
|
||||
|
||||
const makeHeaderGroups = (row, i) => {
|
||||
const theadGroupProps = _.splitProps(getTheadGroupProps(finalState, undefined, row, this))
|
||||
const theadGroupTrProps = _.splitProps(getTheadGroupTrProps(finalState, undefined, row, this))
|
||||
const makeHeaderGroups = () => {
|
||||
const theadGroupProps = _.splitProps(getTheadGroupProps(finalState, undefined, undefined, this))
|
||||
const theadGroupTrProps = _.splitProps(getTheadGroupTrProps(finalState, undefined, undefined, this))
|
||||
return (
|
||||
<TheadComponent
|
||||
key={`${i}-${row.id}`}
|
||||
@@ -276,7 +276,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={theadGroupTrProps.style}
|
||||
{...theadGroupTrProps.rest}
|
||||
>
|
||||
{row.map(makeHeaderGroup)}
|
||||
{headerGroups.map(makeHeaderGroup)}
|
||||
</TrComponent>
|
||||
</TheadComponent>
|
||||
)
|
||||
@@ -367,7 +367,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={theadTrProps.style}
|
||||
{...theadTrProps.rest}
|
||||
>
|
||||
{visibleColumns.map(makeHeader)}
|
||||
{allVisibleColumns.map(makeHeader)}
|
||||
</TrComponent>
|
||||
</TheadComponent>
|
||||
)
|
||||
@@ -455,7 +455,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={theadFilterTrProps.style}
|
||||
{...theadFilterTrProps.rest}
|
||||
>
|
||||
{visibleColumns.map(makeFilter)}
|
||||
{allVisibleColumns.map(makeFilter)}
|
||||
</TrComponent>
|
||||
</TheadComponent>
|
||||
)
|
||||
@@ -485,7 +485,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={trProps.style}
|
||||
{...trProps.rest}
|
||||
>
|
||||
{visibleColumns.map((column, i2) => {
|
||||
{allVisibleColumns.map((column, i2) => {
|
||||
const resizedCol = resized.find(x => x.id === column.id) || {}
|
||||
const show = typeof column.show === 'function' ? column.show() : column.show
|
||||
const width = _.getFirstDefined(resizedCol.value, column.width, column.minWidth)
|
||||
@@ -723,7 +723,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
)}
|
||||
style={trProps.style || {}}
|
||||
>
|
||||
{visibleColumns.map(makePadColumn)}
|
||||
{allVisibleColumns.map(makePadColumn)}
|
||||
</TrComponent>
|
||||
</TrGroupComponent>
|
||||
)
|
||||
@@ -793,7 +793,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={tFootTrProps.style}
|
||||
{...tFootTrProps.rest}
|
||||
>
|
||||
{visibleColumns.map(makeColumnFooter)}
|
||||
{allVisibleColumns.map(makeColumnFooter)}
|
||||
</TrComponent>
|
||||
</TfootComponent>
|
||||
)
|
||||
@@ -836,7 +836,7 @@ export default class ReactTable extends Methods(Lifecycle(Component)) {
|
||||
style={tableProps.style}
|
||||
{...tableProps.rest}
|
||||
>
|
||||
{hasHeaderGroups ? headerGroups.map(makeHeaderGroups) : null}
|
||||
{hasHeaderGroups ? makeHeaderGroups() : null}
|
||||
{makeHeaders()}
|
||||
{hasFilters ? makeFilters() : null}
|
||||
<TbodyComponent
|
||||
|
||||
146
src/methods.js
146
src/methods.js
@@ -31,17 +31,27 @@ export default Base =>
|
||||
} = newState
|
||||
|
||||
// Determine if there are Header Groups
|
||||
const hasHeaderGroups = columns.some(column => column.columns)
|
||||
let hasHeaderGroups = false
|
||||
columns.forEach(column => {
|
||||
if (column.columns) {
|
||||
hasHeaderGroups = true
|
||||
}
|
||||
})
|
||||
|
||||
// Find the expander column which could be deep in tree of columns
|
||||
const allColumns = _.iterTree(columns, 'columns')
|
||||
const expanderColumn = _.getFirstDefined(allColumns)
|
||||
let columnsWithExpander = [...columns]
|
||||
|
||||
let expanderColumn = columns.find(
|
||||
col => col.expander || (col.columns && col.columns.some(col2 => col2.expander))
|
||||
)
|
||||
|
||||
f (expanderColumn && !expanderColumn.expander) {
|
||||
expanderColumn = expanderColumn.columns.find(col => col.expander)
|
||||
}
|
||||
// If we have SubComponent's we need to make sure we have an expander column
|
||||
const hasSubComponentAndNoExpanderColumn = SubComponent && !expanderColumn
|
||||
const columnsWithExpander = hasSubComponentAndNoExpanderColumn
|
||||
? [{ expander: true }, ...columns]
|
||||
: [...columns]
|
||||
if (SubComponent && !expanderColumn) {
|
||||
expanderColumn = { expander: true }
|
||||
columnsWithExpander = [expanderColumn, ...columnsWithExpander]
|
||||
}
|
||||
|
||||
const makeDecoratedColumn = (column, parentColumn) => {
|
||||
let dcol
|
||||
@@ -95,31 +105,40 @@ export default Base =>
|
||||
const allDecoratedColumns = []
|
||||
|
||||
// Decorate the columns
|
||||
const decorateAndAddToAll = (columns, parentColumn) => columns.map(column => {
|
||||
const decorateAndAddToAll = (column, parentColumn) => {
|
||||
const decoratedColumn = makeDecoratedColumn(column, parentColumn)
|
||||
if (column.columns) {
|
||||
decoratedColumn.columns = decorateAndAddToAll(column.columns, column)
|
||||
}
|
||||
|
||||
allDecoratedColumns.push(decoratedColumn)
|
||||
return decoratedColumn
|
||||
}
|
||||
|
||||
const decoratedColumns = columnsWithExpander.map(column => {
|
||||
if (column.columns) {
|
||||
return {
|
||||
...column,
|
||||
columns: column.columns.map(d => decorateAndAddToAll(d, column)),
|
||||
}
|
||||
}
|
||||
return decorateAndAddToAll(column)
|
||||
})
|
||||
|
||||
const decoratedColumns = decorateAndAddToAll(columnsWithExpander)
|
||||
const mapVisibleColumns = columns => columns.map(column => {
|
||||
// Build the visible columns, headers and flat column list
|
||||
let visibleColumns = decoratedColumns.slice()
|
||||
let allVisibleColumns = []
|
||||
|
||||
visibleColumns = visibleColumns.map(column => {
|
||||
if (column.columns) {
|
||||
const visibleSubColumns = column.columns.filter(
|
||||
d => (pivotBy.indexOf(d.id) > -1 ? false : _.getFirstDefined(d.show, true))
|
||||
)
|
||||
return {
|
||||
...column,
|
||||
columns: mapVisibleColumns(visibleSubColumns),
|
||||
columns: visibleSubColumns,
|
||||
}
|
||||
}
|
||||
return column
|
||||
})
|
||||
|
||||
const filterVisibleColumns = columns => columns.filter(
|
||||
visibleColumns = visibleColumns.filter(
|
||||
column =>
|
||||
column.columns
|
||||
? column.columns.length
|
||||
@@ -128,12 +147,8 @@ export default Base =>
|
||||
: _.getFirstDefined(column.show, true)
|
||||
)
|
||||
|
||||
// Build the full array of visible columns - this is an array that contains all columns that
|
||||
// are not hidden via pivoting
|
||||
const allVisibleColumns = filterVisibleColumns(mapVisibleColumns(decoratedColumns.slice()))
|
||||
|
||||
// Find any custom pivot location
|
||||
const pivotIndex = allVisibleColumns.findIndex(col => col.pivot)
|
||||
const pivotIndex = visibleColumns.findIndex(col => col.pivot)
|
||||
|
||||
// Handle Pivot Columns
|
||||
if (pivotBy.length) {
|
||||
@@ -166,66 +181,46 @@ export default Base =>
|
||||
// Place the pivotColumns back into the visibleColumns
|
||||
if (pivotIndex >= 0) {
|
||||
pivotColumnGroup = {
|
||||
...allVisibleColumns[pivotIndex],
|
||||
...visibleColumns[pivotIndex],
|
||||
...pivotColumnGroup,
|
||||
}
|
||||
allVisibleColumns.splice(pivotIndex, 1, pivotColumnGroup)
|
||||
visibleColumns.splice(pivotIndex, 1, pivotColumnGroup)
|
||||
} else {
|
||||
allVisibleColumns.unshift(pivotColumnGroup)
|
||||
visibleColumns.unshift(pivotColumnGroup)
|
||||
}
|
||||
}
|
||||
|
||||
// Build Visible Columns and Header Groups
|
||||
const allColumnHeaders = []
|
||||
// Build Header Groups
|
||||
const headerGroups = []
|
||||
let currentSpan = []
|
||||
|
||||
const addHeader = column => {
|
||||
let level = 0
|
||||
// A convenience function to add a header and reset the currentSpan
|
||||
const addHeader = (columns, column) => {
|
||||
headerGroups.push({
|
||||
...this.props.column,
|
||||
...column,
|
||||
columns,
|
||||
})
|
||||
currentSpan = []
|
||||
}
|
||||
|
||||
// If this column has children, push them first and add this column to the next level
|
||||
// Build flat list of allVisibleColumns and HeaderGroups
|
||||
visibleColumns.forEach(column => {
|
||||
if (column.columns) {
|
||||
const childLevels = column.columns.map(addHeader)
|
||||
level = Math.max(...childLevels) + 1
|
||||
}
|
||||
|
||||
// Add spans above columns without parents (orphans) to fill the space above them
|
||||
if (allColumnHeaders.length <= level) allColumnHeaders.push([])
|
||||
if (level > 0) {
|
||||
// The spans need to contain the shifted headers as children. This finds all of the
|
||||
// columns in the lower level between the first child of this column and the last child
|
||||
// of the preceding column (if there is one)
|
||||
const lowerLevel = allColumnHeaders[level - 1]
|
||||
const precedingColumn = _.last(allColumnHeaders[level])
|
||||
|
||||
const indexOfFirstChildInLowerLevel = lowerLevel.indexOf(column.columns[0])
|
||||
const indexAfterLastChildInPrecedingColumn = precedingColumn
|
||||
? lowerLevel.indexOf(_.last(precedingColumn.columns)) + 1
|
||||
: 0
|
||||
|
||||
// If there are ophans, add a span above them
|
||||
const orphans = lowerLevel.slice(
|
||||
indexAfterLastChildInPrecedingColumn,
|
||||
indexOfFirstChildInLowerLevel
|
||||
)
|
||||
|
||||
if (orphans.length) {
|
||||
allColumnHeaders[level].push({
|
||||
...this.props.column,
|
||||
columns: orphans,
|
||||
})
|
||||
allVisibleColumns = allVisibleColumns.concat(column.columns)
|
||||
if (currentSpan.length > 0) {
|
||||
addHeader(currentSpan)
|
||||
}
|
||||
addHeader(column.columns, column)
|
||||
return
|
||||
}
|
||||
|
||||
allColumnHeaders[level].push(column)
|
||||
|
||||
return level
|
||||
allVisibleColumns.push(column)
|
||||
currentSpan.push(column)
|
||||
})
|
||||
if (hasHeaderGroups && currentSpan.length > 0) {
|
||||
addHeader(currentSpan)
|
||||
}
|
||||
|
||||
allVisibleColumns.forEach(addHeader)
|
||||
|
||||
// visibleColumns is an array containing column definitions for the bottom row of TH elements
|
||||
const visibleColumns = allColumnHeaders.shift()
|
||||
const headerGroups = allColumnHeaders.reverse()
|
||||
|
||||
// Access the data
|
||||
const accessRow = (d, i, level = 0) => {
|
||||
const row = {
|
||||
@@ -255,7 +250,7 @@ export default Base =>
|
||||
resolvedData = resolvedData.map((d, i) => accessRow(d, i))
|
||||
|
||||
// TODO: Make it possible to fabricate nested rows without pivoting
|
||||
const aggregatingColumns = visibleColumns.filter(d => !d.expander && d.aggregate)
|
||||
const aggregatingColumns = allVisibleColumns.filter(d => !d.expander && d.aggregate)
|
||||
|
||||
// If pivoting, recursively group the data
|
||||
const aggregate = rows => {
|
||||
@@ -299,7 +294,7 @@ export default Base =>
|
||||
return {
|
||||
...newState,
|
||||
resolvedData,
|
||||
visibleColumns,
|
||||
allVisibleColumns,
|
||||
headerGroups,
|
||||
allDecoratedColumns,
|
||||
hasHeaderGroups,
|
||||
@@ -313,6 +308,7 @@ export default Base =>
|
||||
filtered,
|
||||
defaultFilterMethod,
|
||||
resolvedData,
|
||||
allVisibleColumns,
|
||||
allDecoratedColumns,
|
||||
} = resolvedState
|
||||
|
||||
@@ -327,7 +323,7 @@ export default Base =>
|
||||
sortedData: manual
|
||||
? resolvedData
|
||||
: this.sortData(
|
||||
this.filterData(resolvedData, filtered, defaultFilterMethod, allDecoratedColumns),
|
||||
this.filterData(resolvedData, filtered, defaultFilterMethod, allVisibleColumns),
|
||||
sorted,
|
||||
sortMethodsByColumnID
|
||||
),
|
||||
@@ -354,12 +350,12 @@ export default Base =>
|
||||
return _.getFirstDefined(this.state[key], this.props[key])
|
||||
}
|
||||
|
||||
filterData (data, filtered, defaultFilterMethod, visibleColumns) {
|
||||
filterData (data, filtered, defaultFilterMethod, allVisibleColumns) {
|
||||
let filteredData = data
|
||||
|
||||
if (filtered.length) {
|
||||
filteredData = filtered.reduce((filteredSoFar, nextFilter) => {
|
||||
const column = visibleColumns.find(x => x.id === nextFilter.id)
|
||||
const column = allVisibleColumns.find(x => x.id === nextFilter.id)
|
||||
|
||||
// Don't filter hidden columns or columns that have had their filters disabled
|
||||
if (!column || column.filterable === false) {
|
||||
@@ -388,7 +384,7 @@ export default Base =>
|
||||
row[this.props.subRowsKey],
|
||||
filtered,
|
||||
defaultFilterMethod,
|
||||
visibleColumns
|
||||
allVisibleColumns
|
||||
),
|
||||
}
|
||||
})
|
||||
|
||||
20
src/utils.js
20
src/utils.js
@@ -10,8 +10,6 @@ export default {
|
||||
range,
|
||||
remove,
|
||||
clone,
|
||||
leaves,
|
||||
iterTree,
|
||||
getFirstDefined,
|
||||
sum,
|
||||
makeTemplateComponent,
|
||||
@@ -110,24 +108,6 @@ function clone (a) {
|
||||
}
|
||||
}
|
||||
|
||||
function leaves (root, childProperty) {
|
||||
if (Object.prototype.hasOwnProperty.call(root, childProperty)) {
|
||||
const children = root[childProperty].map(child => leaves(child, childProperty))
|
||||
return [].concat(...children)
|
||||
}
|
||||
|
||||
return [root]
|
||||
}
|
||||
|
||||
function iterTree (root, childProperty) {
|
||||
if (Object.prototype.hasOwnProperty.call(root, childProperty)) {
|
||||
const children = root[childProperty].map(child => leaves(child, childProperty))
|
||||
return [].concat(root, ...children)
|
||||
}
|
||||
|
||||
return [root]
|
||||
}
|
||||
|
||||
function getFirstDefined (...args) {
|
||||
for (let i = 0; i < args.length; i += 1) {
|
||||
if (typeof args[i] !== 'undefined') {
|
||||
|
||||
Reference in New Issue
Block a user