Skip to content

Commit

Permalink
add headerFormatter prop to be able to modify header labels
Browse files Browse the repository at this point in the history
  • Loading branch information
Bassel Ahmed committed Nov 1, 2018
1 parent 52fe9c5 commit c022837
Show file tree
Hide file tree
Showing 4 changed files with 1,256 additions and 1,218 deletions.
20 changes: 17 additions & 3 deletions lib/reactcohortgraph.js
Original file line number Diff line number Diff line change
Expand Up @@ -2768,6 +2768,7 @@ var ReactCohortGraph = function (_React$Component) {
showEmptyDataMessage = _props2$showEmptyData === undefined ? true : _props2$showEmptyData,
customEmptyDataMessage = _props2.customEmptyDataMessage,
labelFormatter = _props2.labelFormatter,
headerFormatter = _props2.headerFormatter,
_props2$bodyCellStyle = _props2.bodyCellStyles,
bodyCellStyles = _props2$bodyCellStyle === undefined ? {} : _props2$bodyCellStyle,
_props2$headerCellSty = _props2.headerCellStyles,
Expand Down Expand Up @@ -2797,6 +2798,7 @@ var ReactCohortGraph = function (_React$Component) {
var WrapperStyles = (0, _styles.wrapper)(wrapperStyles);
var ScrollableTablePartStyles = (0, _styles.scrollableTablePart)(scrollableTablePartStyles);
var ScrollableTableContentStyles = (0, _styles.scrollableTableContent)(scrollableTableContentStyles);
console.log(header);
if (header && header.length > 0) {
return _react2.default.createElement(
'div',
Expand All @@ -2821,7 +2823,7 @@ var ReactCohortGraph = function (_React$Component) {
'div',
{ style: TableHeadingStyles },
header.map(function (headerCell, i) {
return _this2.isFixed(i) && _react2.default.createElement(_components.HeaderCell, _extends({ tableCellStyles: tableCellStyles, headerLabelStyles: headerLabelStyles, style: headerCellStyles, key: "header" + i }, headerCell, { valueType: valueType }));
return _this2.isFixed(i) && _react2.default.createElement(_components.HeaderCell, _extends({ tableCellStyles: tableCellStyles, headerLabelStyles: headerLabelStyles, style: headerCellStyles, key: "header" + i }, headerCell, { headerFormatter: headerFormatter, valueType: valueType }));
})
),
_react2.default.createElement(
Expand Down Expand Up @@ -2852,7 +2854,7 @@ var ReactCohortGraph = function (_React$Component) {
'div',
{ style: TableHeadingStyles },
header.map(function (headerCell, i) {
return !_this2.isFixed(i) && _react2.default.createElement(_components.HeaderCell, _extends({ tableCellStyles: tableCellStyles, style: headerCellStyles, key: "header" + i }, headerCell, { valueType: valueType }));
return !_this2.isFixed(i) && _react2.default.createElement(_components.HeaderCell, _extends({ tableCellStyles: tableCellStyles, style: headerCellStyles, key: "header" + i }, headerCell, { headerFormatter: headerFormatter, valueType: valueType }));
})
),
_react2.default.createElement(
Expand Down Expand Up @@ -2929,6 +2931,7 @@ ReactCohortGraph.propTypes = {
bodyCellColor: _propTypes2.default.string,
keyCellColor: _propTypes2.default.string,
labelFormatter: _propTypes2.default.func, //function(label){ return formattedLabel;}
headerFormatter: _propTypes2.default.func,
/*maxDays : PropTypes.number,
maxWeeks : PropTypes.number, //TODO:
maxMonths : PropTypes.number,*/
Expand Down Expand Up @@ -3418,14 +3421,25 @@ var renderValue = function renderValue(props) {
return isTotal || isLabel ? props[VALUE] : props.valueType === PERCENT ? props[PERCENT] + ' %' : props[VALUE];
};

var renderHeader = function renderHeader(props) {
var isHeader = props.isHeader,
headerFormatter = props.headerFormatter,
label = props.label;

if (typeof headerFormatter === 'function' && isHeader) {
return headerFormatter(label);
}
return label;
};

var HeaderCell = exports.HeaderCell = function HeaderCell(props) {
return _react2.default.createElement(
'div',
{ style: _extends({}, (0, _styles.tableCell)(props.tableCellStyles), { backgroundColor: props.color }, props.style) },
_react2.default.createElement(
'p',
{ style: (0, _styles.headerLabel)(props.headerLabelStyles) },
props.label
renderHeader(props)
),
_react2.default.createElement(
'span',
Expand Down
Loading

0 comments on commit c022837

Please sign in to comment.