mirror of
https://github.com/gosticks/react-bootstrap-table2.git
synced 2025-10-16 11:55:39 +00:00
enhance footer event
This commit is contained in:
parent
16128e77e6
commit
7d28d46185
@ -666,7 +666,7 @@ It's also available to custom via a callback function:
|
||||
{
|
||||
// omit...
|
||||
footerEvents: {
|
||||
onClick: e => { ... }
|
||||
onClick: (e, column, columnIndex) => { ... }
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
@ -12,7 +12,7 @@ const columns = [{
|
||||
dataField: 'id',
|
||||
text: 'Product ID',
|
||||
footerEvents: {
|
||||
onClick: () => alert('Click on Product ID footer column')
|
||||
onClick: (e, column, columnIndex) => alert(`Click on Product ID header column, columnIndex: ${columnIndex}`)
|
||||
},
|
||||
footer: 'Footer 1'
|
||||
}, {
|
||||
@ -32,7 +32,7 @@ const columns = [{
|
||||
dataField: 'id',
|
||||
text: 'Product ID',
|
||||
footerEvents: {
|
||||
onClick: () => alert('Click on Product ID footer column')
|
||||
onClick: (e, column, columnIndex) => alert('Click on Product ID footer column')
|
||||
},
|
||||
footer: 'Footer 1'
|
||||
}, {
|
||||
|
||||
@ -4,56 +4,61 @@ import cs from 'classnames';
|
||||
import PropTypes from 'prop-types';
|
||||
|
||||
import _ from './utils';
|
||||
import eventDelegater from './cell-event-delegater';
|
||||
|
||||
const FooterCell = (props) => {
|
||||
const { index, column, columnData } = props;
|
||||
class FooterCell extends eventDelegater(React.Component) {
|
||||
render() {
|
||||
const { index, column, columnData } = this.props;
|
||||
|
||||
const {
|
||||
footer,
|
||||
footerTitle,
|
||||
footerAlign,
|
||||
footerFormatter,
|
||||
footerEvents,
|
||||
footerClasses,
|
||||
footerStyle,
|
||||
footerAttrs
|
||||
} = column;
|
||||
const {
|
||||
footer,
|
||||
footerTitle,
|
||||
footerAlign,
|
||||
footerFormatter,
|
||||
footerEvents,
|
||||
footerClasses,
|
||||
footerStyle,
|
||||
footerAttrs
|
||||
} = column;
|
||||
|
||||
const cellAttrs = {
|
||||
...(_.isFunction(footerAttrs) ? footerAttrs(column, index) : footerAttrs),
|
||||
...footerEvents
|
||||
};
|
||||
const delegateEvents = this.delegate(footerEvents);
|
||||
const cellAttrs = {
|
||||
...(_.isFunction(footerAttrs) ? footerAttrs(column, index) : footerAttrs),
|
||||
...delegateEvents
|
||||
};
|
||||
|
||||
let text = '';
|
||||
if (_.isString(footer)) {
|
||||
text = footer;
|
||||
} else if (_.isFunction(footer)) {
|
||||
text = footer(columnData, column, index);
|
||||
|
||||
let text = '';
|
||||
if (_.isString(footer)) {
|
||||
text = footer;
|
||||
} else if (_.isFunction(footer)) {
|
||||
text = footer(columnData, column, index);
|
||||
}
|
||||
|
||||
let cellStyle = {};
|
||||
const cellClasses = _.isFunction(footerClasses) ? footerClasses(column, index) : footerClasses;
|
||||
|
||||
if (footerStyle) {
|
||||
cellStyle = _.isFunction(footerStyle) ? footerStyle(column, index) : footerStyle;
|
||||
cellStyle = cellStyle ? { ...cellStyle } : cellStyle;
|
||||
}
|
||||
|
||||
if (footerTitle) {
|
||||
cellAttrs.title = _.isFunction(footerTitle) ? footerTitle(column, index) : text;
|
||||
}
|
||||
|
||||
if (footerAlign) {
|
||||
cellStyle.textAlign = _.isFunction(footerAlign) ? footerAlign(column, index) : footerAlign;
|
||||
}
|
||||
|
||||
if (cellClasses) cellAttrs.className = cs(cellAttrs.className, cellClasses);
|
||||
if (!_.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;
|
||||
|
||||
const children = footerFormatter ? footerFormatter(column, index) : text;
|
||||
|
||||
return React.createElement('th', cellAttrs, children);
|
||||
}
|
||||
|
||||
let cellStyle = {};
|
||||
const cellClasses = _.isFunction(footerClasses) ? footerClasses(column, index) : footerClasses;
|
||||
|
||||
if (footerStyle) {
|
||||
cellStyle = _.isFunction(footerStyle) ? footerStyle(column, index) : footerStyle;
|
||||
cellStyle = cellStyle ? { ...cellStyle } : cellStyle;
|
||||
}
|
||||
|
||||
if (footerTitle) {
|
||||
cellAttrs.title = _.isFunction(footerTitle) ? footerTitle(column, index) : text;
|
||||
}
|
||||
|
||||
if (footerAlign) {
|
||||
cellStyle.textAlign = _.isFunction(footerAlign) ? footerAlign(column, index) : footerAlign;
|
||||
}
|
||||
|
||||
if (cellClasses) cellAttrs.className = cs(cellAttrs.className, cellClasses);
|
||||
if (!_.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;
|
||||
|
||||
const children = footerFormatter ? footerFormatter(column, index) : text;
|
||||
|
||||
return React.createElement('th', cellAttrs, children);
|
||||
};
|
||||
}
|
||||
|
||||
FooterCell.propTypes = {
|
||||
columnData: PropTypes.array,
|
||||
|
||||
Loading…
Reference in New Issue
Block a user