custom-app
Version:
ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������
318 lines (241 loc) • 29 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
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 _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _left = require('./left.svg');
var _left2 = _interopRequireDefault(_left);
var _right = require('./right.svg');
var _right2 = _interopRequireDefault(_right);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
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; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } /* eslint-disable */
var defaultFoldIconComponent = function defaultFoldIconComponent(_ref) {
var collapsed = _ref.collapsed;
var style = { width: 25 };
if (collapsed) return _react2.default.createElement('img', { src: _right2.default, style: style, alt: 'right' });
return _react2.default.createElement('img', { src: _left2.default, style: style, alt: 'left' });
};
var defaultFoldButtonComponent = function defaultFoldButtonComponent(_ref2) {
var header = _ref2.header,
collapsed = _ref2.collapsed,
icon = _ref2.icon,
onClick = _ref2.onClick;
var style = {
marginLeft: '0px',
marginTop: '-5px',
marginBottom: '-8px',
float: 'left',
cursor: 'pointer'
};
return _react2.default.createElement(
'div',
null,
_react2.default.createElement(
'div',
{ style: style, onClick: onClick },
icon
),
!collapsed && _react2.default.createElement(
'div',
null,
header
)
);
};
exports.default = function (ReactTable) {
var wrapper = function (_React$Component) {
_inherits(RTFoldableTable, _React$Component);
function RTFoldableTable(props, context) {
_classCallCheck(this, RTFoldableTable);
var _this = _possibleConstructorReturn(this, (RTFoldableTable.__proto__ || Object.getPrototypeOf(RTFoldableTable)).call(this, props, context));
_this.onResizedChange = function (resized) {
var onResizedChange = _this.props.onResizedChange;
if (onResizedChange) onResizedChange(resized);else {
_this.setState(function (p) {
return { resized: resized };
});
}
};
_this.removeResized = function (column) {
var id = column.id;
if (!id) return;
var resized = _this.state.resized;
if (!resized) return;
var rs = resized.find(function (r) {
return r.id === id;
});
if (!rs) return;
var newResized = resized.filter(function (r) {
return r !== rs;
});
_this.onResizedChange(newResized);
};
_this.getWrappedInstance = function () {
if (!_this.wrappedInstance) console.warn('RTFoldableTable - No wrapped instance');
if (_this.wrappedInstance.getWrappedInstance) return _this.wrappedInstance.getWrappedInstance();
return _this.wrappedInstance;
};
_this.getCopiedKey = function (key) {
var foldableOriginalKey = _this.props.foldableOriginalKey;
return '' + foldableOriginalKey + key;
};
_this.copyOriginals = function (column) {
var FoldedColumn = _this.props.FoldedColumn;
// Stop copy if the column already copied
if (column.original_Header) return;
Object.keys(FoldedColumn).forEach(function (k) {
var copiedKey = _this.getCopiedKey(k);
if (k === 'Cell') column[copiedKey] = column[k] ? column[k] : function (c) {
return c.value;
};else column[copiedKey] = column[k];
});
// Copy sub Columns
if (column.columns && !column.original_Columns) column.original_Columns = column.columns;
// Copy Header
if (!column.original_Header) column.original_Header = column.Header;
};
_this.restoreToOriginal = function (column) {
var FoldedColumn = _this.props.FoldedColumn;
Object.keys(FoldedColumn).forEach(function (k) {
// ignore header as handling by foldableHeaderRender
if (k === 'Header') return;
var copiedKey = _this.getCopiedKey(k);
column[k] = column[copiedKey];
});
if (column.columns && column.original_Columns) column.columns = column.original_Columns;
};
_this.getState = function () {
return _this.props.onFoldChange ? _this.props.folded : _this.state.folded;
};
_this.isFolded = function (col) {
var folded = _this.getState();
return folded[col.id] === true;
};
_this.foldingHandler = function (col) {
if (!col || !col.id) return;
var onFoldChange = _this.props.onFoldChange;
var folded = _this.getState();
var id = col.id;
var newFold = Object.assign({}, folded);
newFold[id] = !newFold[id];
// Remove the Resized if have
_this.removeResized(col);
if (onFoldChange) onFoldChange(newFold);else {
_this.setState(function (previous) {
return { folded: newFold };
});
}
};
_this.foldableHeaderRender = function (cell) {
var _this$props = _this.props,
FoldButtonComponent = _this$props.FoldButtonComponent,
FoldIconComponent = _this$props.FoldIconComponent;
var column = cell.column;
var collapsed = _this.isFolded(column);
var icon = _react2.default.createElement(FoldIconComponent, { collapsed: collapsed });
var onClick = function onClick() {
return _this.foldingHandler(column);
};
return _react2.default.createElement(FoldButtonComponent, {
header: column.original_Header,
collapsed: collapsed,
icon: icon,
onClick: onClick
});
};
_this.applyFoldableForColumn = function (column) {
var collapsed = _this.isFolded(column);
var FoldedColumn = _this.props.FoldedColumn;
// Handle Column Header
if (column.columns) {
if (collapsed) {
column.columns = [FoldedColumn];
column.width = FoldedColumn.width;
column.style = FoldedColumn.style;
} else _this.restoreToOriginal(column);
}
// Handle Normal Column.
else if (collapsed) column = Object.assign(column, FoldedColumn);else {
_this.restoreToOriginal(column);
}
};
_this.applyFoldableForColumns = function (columns) {
return columns.map(function (col, index) {
if (!col.foldable) return col;
// If col don't have id then generate id based on index
if (!col.id) col.id = 'col_' + index;
_this.copyOriginals(col);
// Replace current header with internal header render.
col.Header = function (c) {
return _this.foldableHeaderRender(c);
};
// apply foldable
_this.applyFoldableForColumn(col);
// return the new column out
return col;
});
};
_this.state = {
folded: props.onFoldChange ? undefined : {},
resized: props.resized || []
};
return _this;
}
_createClass(RTFoldableTable, [{
key: 'componentWillReceiveProps',
value: function componentWillReceiveProps(newProps) {
if (this.state.resized !== newProps.resized) {
this.setState(function (p) {
return { resized: newProps.resized };
});
}
}
// this is so we can expose the underlying ReactTable.
}, {
key: 'render',
value: function render() {
var _this2 = this;
var _props = this.props,
originalCols = _props.columns,
FoldButtonComponent = _props.FoldButtonComponent,
FoldIconComponent = _props.FoldIconComponent,
FoldedColumn = _props.FoldedColumn,
rest = _objectWithoutProperties(_props, ['columns', 'FoldButtonComponent', 'FoldIconComponent', 'FoldedColumn']);
var columns = this.applyFoldableForColumns([].concat(_toConsumableArray(originalCols)));
var extra = {
columns: columns,
onResizedChange: this.onResizedChange,
resized: this.state.resized
};
return _react2.default.createElement(ReactTable, _extends({}, rest, extra, { ref: function ref(r) {
return _this2.wrappedInstance = r;
} }));
}
}]);
return RTFoldableTable;
}(_react2.default.Component);
wrapper.displayName = 'RTFoldableTable';
wrapper.defaultProps = {
FoldIconComponent: defaultFoldIconComponent,
FoldButtonComponent: defaultFoldButtonComponent,
foldableOriginalKey: 'original_',
FoldedColumn: {
Cell: function Cell(c) {
return '';
},
width: 30,
sortable: false,
resizable: false,
filterable: false
}
};
return wrapper;
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/hoc/foldableTable/index.js"],"names":["defaultFoldIconComponent","collapsed","style","width","right","left","defaultFoldButtonComponent","header","icon","onClick","marginLeft","marginTop","marginBottom","float","cursor","wrapper","props","context","onResizedChange","resized","setState","removeResized","id","column","state","rs","find","r","newResized","filter","getWrappedInstance","wrappedInstance","console","warn","getCopiedKey","foldableOriginalKey","key","copyOriginals","FoldedColumn","original_Header","Object","keys","forEach","copiedKey","k","c","value","columns","original_Columns","Header","restoreToOriginal","getState","onFoldChange","folded","isFolded","col","foldingHandler","newFold","assign","foldableHeaderRender","FoldButtonComponent","FoldIconComponent","cell","React","createElement","applyFoldableForColumn","applyFoldableForColumns","map","index","foldable","undefined","newProps","originalCols","rest","extra","Component","displayName","defaultProps","Cell","sortable","resizable","filterable"],"mappings":";;;;;;;;;;AAEA;;;;AACA;;;;AACA;;;;;;;;;;;;;;+eAJA;;AAMA,IAAMA,2BAA2B,SAA3BA,wBAA2B,OAAmB;AAAA,MAAhBC,SAAgB,QAAhBA,SAAgB;;AAClD,MAAMC,QAAQ,EAAEC,OAAO,EAAT,EAAd;;AAEA,MAAIF,SAAJ,EAAe,OAAO,uCAAK,KAAKG,eAAV,EAAiB,OAAOF,KAAxB,EAA+B,KAAI,OAAnC,GAAP;AACf,SAAO,uCAAK,KAAKG,cAAV,EAAgB,OAAOH,KAAvB,EAA8B,KAAI,MAAlC,GAAP;AACD,CALD;;AAOA,IAAMI,6BAA6B,SAA7BA,0BAA6B,QAA0C;AAAA,MAAvCC,MAAuC,SAAvCA,MAAuC;AAAA,MAA/BN,SAA+B,SAA/BA,SAA+B;AAAA,MAApBO,IAAoB,SAApBA,IAAoB;AAAA,MAAdC,OAAc,SAAdA,OAAc;;AAC3E,MAAMP,QAAQ;AACZQ,gBAAY,KADA;AAEZC,eAAW,MAFC;AAGZC,kBAAc,MAHF;AAIZC,WAAO,MAJK;AAKZC,YAAQ;AALI,GAAd;;AAQA,SACE;AAAA;AAAA;AACE;AAAA;AAAA,QAAK,OAAOZ,KAAZ,EAAmB,SAASO,OAA5B;AACGD;AADH,KADF;AAIG,KAACP,SAAD,IAAc;AAAA;AAAA;AAAMM;AAAN;AAJjB,GADF;AAQD,CAjBD;;kBAmBe,sBAAc;AAC3B,MAAMQ;AAAA;;AACJ,6BAAYC,KAAZ,EAAmBC,OAAnB,EAA4B;AAAA;;AAAA,oIACpBD,KADoB,EACbC,OADa;;AAAA,YAe5BC,eAf4B,GAeV,mBAAW;AAAA,YACnBA,eADmB,GACC,MAAKF,KADN,CACnBE,eADmB;;AAE3B,YAAIA,eAAJ,EAAqBA,gBAAgBC,OAAhB,EAArB,KACK;AACH,gBAAKC,QAAL,CAAc;AAAA,mBAAM,EAAED,gBAAF,EAAN;AAAA,WAAd;AACD;AACF,OArB2B;;AAAA,YAuB5BE,aAvB4B,GAuBZ,kBAAU;AAAA,YAChBC,EADgB,GACTC,MADS,CAChBD,EADgB;;AAExB,YAAI,CAACA,EAAL,EAAS;;AAFe,YAIhBH,OAJgB,GAIJ,MAAKK,KAJD,CAIhBL,OAJgB;;AAKxB,YAAI,CAACA,OAAL,EAAc;;AAEd,YAAMM,KAAKN,QAAQO,IAAR,CAAa;AAAA,iBAAKC,EAAEL,EAAF,KAASA,EAAd;AAAA,SAAb,CAAX;AACA,YAAI,CAACG,EAAL,EAAS;;AAET,YAAMG,aAAaT,QAAQU,MAAR,CAAe;AAAA,iBAAKF,MAAMF,EAAX;AAAA,SAAf,CAAnB;AACA,cAAKP,eAAL,CAAqBU,UAArB;AACD,OAnC2B;;AAAA,YAsC5BE,kBAtC4B,GAsCP,YAAM;AACzB,YAAI,CAAC,MAAKC,eAAV,EAA2BC,QAAQC,IAAR,CAAa,uCAAb;AAC3B,YAAI,MAAKF,eAAL,CAAqBD,kBAAzB,EAA6C,OAAO,MAAKC,eAAL,CAAqBD,kBAArB,EAAP;AAC7C,eAAO,MAAKC,eAAZ;AACD,OA1C2B;;AAAA,YA4C5BG,YA5C4B,GA4Cb,eAAO;AAAA,YACZC,mBADY,GACY,MAAKnB,KADjB,CACZmB,mBADY;;AAEpB,oBAAUA,mBAAV,GAAgCC,GAAhC;AACD,OA/C2B;;AAAA,YAiD5BC,aAjD4B,GAiDZ,kBAAU;AAAA,YAChBC,YADgB,GACC,MAAKtB,KADN,CAChBsB,YADgB;;AAGxB;;AACA,YAAIf,OAAOgB,eAAX,EAA4B;;AAE5BC,eAAOC,IAAP,CAAYH,YAAZ,EAA0BI,OAA1B,CAAkC,aAAK;AACrC,cAAMC,YAAY,MAAKT,YAAL,CAAkBU,CAAlB,CAAlB;;AAEA,cAAIA,MAAM,MAAV,EAAkBrB,OAAOoB,SAAP,IAAoBpB,OAAOqB,CAAP,IAAYrB,OAAOqB,CAAP,CAAZ,GAAwB;AAAA,mBAAKC,EAAEC,KAAP;AAAA,WAA5C,CAAlB,KACKvB,OAAOoB,SAAP,IAAoBpB,OAAOqB,CAAP,CAApB;AACN,SALD;;AAOA;AACA,YAAIrB,OAAOwB,OAAP,IAAkB,CAACxB,OAAOyB,gBAA9B,EAAgDzB,OAAOyB,gBAAP,GAA0BzB,OAAOwB,OAAjC;;AAEhD;AACA,YAAI,CAACxB,OAAOgB,eAAZ,EAA6BhB,OAAOgB,eAAP,GAAyBhB,OAAO0B,MAAhC;AAC9B,OAnE2B;;AAAA,YAqE5BC,iBArE4B,GAqER,kBAAU;AAAA,YACpBZ,YADoB,GACH,MAAKtB,KADF,CACpBsB,YADoB;;;AAG5BE,eAAOC,IAAP,CAAYH,YAAZ,EAA0BI,OAA1B,CAAkC,aAAK;AACrC;AACA,cAAIE,MAAM,QAAV,EAAoB;;AAEpB,cAAMD,YAAY,MAAKT,YAAL,CAAkBU,CAAlB,CAAlB;AACArB,iBAAOqB,CAAP,IAAYrB,OAAOoB,SAAP,CAAZ;AACD,SAND;;AAQA,YAAIpB,OAAOwB,OAAP,IAAkBxB,OAAOyB,gBAA7B,EAA+CzB,OAAOwB,OAAP,GAAiBxB,OAAOyB,gBAAxB;AAChD,OAjF2B;;AAAA,YAmF5BG,QAnF4B,GAmFjB;AAAA,eAAO,MAAKnC,KAAL,CAAWoC,YAAX,GAA0B,MAAKpC,KAAL,CAAWqC,MAArC,GAA8C,MAAK7B,KAAL,CAAW6B,MAAhE;AAAA,OAnFiB;;AAAA,YAqF5BC,QArF4B,GAqFjB,eAAO;AAChB,YAAMD,SAAS,MAAKF,QAAL,EAAf;AACA,eAAOE,OAAOE,IAAIjC,EAAX,MAAmB,IAA1B;AACD,OAxF2B;;AAAA,YA0F5BkC,cA1F4B,GA0FX,eAAO;AACtB,YAAI,CAACD,GAAD,IAAQ,CAACA,IAAIjC,EAAjB,EAAqB;;AADC,YAGd8B,YAHc,GAGG,MAAKpC,KAHR,CAGdoC,YAHc;;AAItB,YAAMC,SAAS,MAAKF,QAAL,EAAf;AAJsB,YAKd7B,EALc,GAKPiC,GALO,CAKdjC,EALc;;;AAOtB,YAAMmC,UAAUjB,OAAOkB,MAAP,CAAc,EAAd,EAAkBL,MAAlB,CAAhB;AACAI,gBAAQnC,EAAR,IAAc,CAACmC,QAAQnC,EAAR,CAAf;;AAEA;AACA,cAAKD,aAAL,CAAmBkC,GAAnB;;AAEA,YAAIH,YAAJ,EAAkBA,aAAaK,OAAb,EAAlB,KACK;AACH,gBAAKrC,QAAL,CAAc;AAAA,mBAAa,EAAEiC,QAAQI,OAAV,EAAb;AAAA,WAAd;AACD;AACF,OA3G2B;;AAAA,YA6G5BE,oBA7G4B,GA6GL,gBAAQ;AAAA,0BACsB,MAAK3C,KAD3B;AAAA,YACrB4C,mBADqB,eACrBA,mBADqB;AAAA,YACAC,iBADA,eACAA,iBADA;AAAA,YAErBtC,MAFqB,GAEVuC,IAFU,CAErBvC,MAFqB;;AAG7B,YAAMtB,YAAY,MAAKqD,QAAL,CAAc/B,MAAd,CAAlB;AACA,YAAMf,OAAOuD,gBAAMC,aAAN,CAAoBH,iBAApB,EAAuC,EAAE5D,oBAAF,EAAvC,CAAb;AACA,YAAMQ,UAAU,SAAVA,OAAU;AAAA,iBAAM,MAAK+C,cAAL,CAAoBjC,MAApB,CAAN;AAAA,SAAhB;;AAEA,eAAOwC,gBAAMC,aAAN,CAAoBJ,mBAApB,EAAyC;AAC9CrD,kBAAQgB,OAAOgB,eAD+B;AAE9CtC,8BAF8C;AAG9CO,oBAH8C;AAI9CC;AAJ8C,SAAzC,CAAP;AAMD,OA1H2B;;AAAA,YA4H5BwD,sBA5H4B,GA4HH,kBAAU;AACjC,YAAMhE,YAAY,MAAKqD,QAAL,CAAc/B,MAAd,CAAlB;AADiC,YAEzBe,YAFyB,GAER,MAAKtB,KAFG,CAEzBsB,YAFyB;;AAIjC;;AACA,YAAIf,OAAOwB,OAAX,EAAoB;AAClB,cAAI9C,SAAJ,EAAe;AACbsB,mBAAOwB,OAAP,GAAiB,CAACT,YAAD,CAAjB;AACAf,mBAAOpB,KAAP,GAAemC,aAAanC,KAA5B;AACAoB,mBAAOrB,KAAP,GAAeoC,aAAapC,KAA5B;AACD,WAJD,MAIO,MAAKgD,iBAAL,CAAuB3B,MAAvB;AACR;AACD;AAPA,aAQK,IAAItB,SAAJ,EAAesB,SAASiB,OAAOkB,MAAP,CAAcnC,MAAd,EAAsBe,YAAtB,CAAT,CAAf,KACA;AACH,kBAAKY,iBAAL,CAAuB3B,MAAvB;AACD;AACF,OA7I2B;;AAAA,YA+I5B2C,uBA/I4B,GA+IF;AAAA,eACxBnB,QAAQoB,GAAR,CAAY,UAACZ,GAAD,EAAMa,KAAN,EAAgB;AAC1B,cAAI,CAACb,IAAIc,QAAT,EAAmB,OAAOd,GAAP;;AAEnB;AACA,cAAI,CAACA,IAAIjC,EAAT,EAAaiC,IAAIjC,EAAJ,YAAgB8C,KAAhB;;AAEb,gBAAK/B,aAAL,CAAmBkB,GAAnB;AACA;AACAA,cAAIN,MAAJ,GAAa;AAAA,mBAAK,MAAKU,oBAAL,CAA0Bd,CAA1B,CAAL;AAAA,WAAb;AACA;AACA,gBAAKoB,sBAAL,CAA4BV,GAA5B;;AAEA;AACA,iBAAOA,GAAP;AACD,SAdD,CADwB;AAAA,OA/IE;;AAG1B,YAAK/B,KAAL,GAAa;AACX6B,gBAAQrC,MAAMoC,YAAN,GAAqBkB,SAArB,GAAiC,EAD9B;AAEXnD,iBAASH,MAAMG,OAAN,IAAiB;AAFf,OAAb;AAH0B;AAO3B;;AARG;AAAA;AAAA,gDAUsBoD,QAVtB,EAUgC;AAClC,YAAI,KAAK/C,KAAL,CAAWL,OAAX,KAAuBoD,SAASpD,OAApC,EAA6C;AAC3C,eAAKC,QAAL,CAAc;AAAA,mBAAM,EAAED,SAASoD,SAASpD,OAApB,EAAN;AAAA,WAAd;AACD;AACF;;AAwBD;;AAtCI;AAAA;AAAA,+BAiKK;AAAA;;AAAA,qBAOH,KAAKH,KAPF;AAAA,YAEIwD,YAFJ,UAELzB,OAFK;AAAA,YAGLa,mBAHK,UAGLA,mBAHK;AAAA,YAILC,iBAJK,UAILA,iBAJK;AAAA,YAKLvB,YALK,UAKLA,YALK;AAAA,YAMFmC,IANE;;AAQP,YAAM1B,UAAU,KAAKmB,uBAAL,8BAAiCM,YAAjC,GAAhB;;AAEA,YAAME,QAAQ;AACZ3B,0BADY;AAEZ7B,2BAAiB,KAAKA,eAFV;AAGZC,mBAAS,KAAKK,KAAL,CAAWL;AAHR,SAAd;;AAMA,eAAO,8BAAC,UAAD,eAAgBsD,IAAhB,EAA0BC,KAA1B,IAAiC,KAAK;AAAA,mBAAM,OAAK3C,eAAL,GAAuBJ,CAA7B;AAAA,WAAtC,IAAP;AACD;AAlLG;;AAAA;AAAA,IAAwCoC,gBAAMY,SAA9C,CAAN;;AAqLA5D,UAAQ6D,WAAR,GAAsB,iBAAtB;AACA7D,UAAQ8D,YAAR,GAAuB;AACrBhB,uBAAmB7D,wBADE;AAErB4D,yBAAqBtD,0BAFA;AAGrB6B,yBAAqB,WAHA;AAIrBG,kBAAc;AACZwC,YAAM;AAAA,eAAK,EAAL;AAAA,OADM;AAEZ3E,aAAO,EAFK;AAGZ4E,gBAAU,KAHE;AAIZC,iBAAW,KAJC;AAKZC,kBAAY;AALA;AAJO,GAAvB;;AAaA,SAAOlE,OAAP;AACD,C","file":"index.js","sourcesContent":["/* eslint-disable */\n\nimport React from 'react'\nimport left from './left.svg'\nimport right from './right.svg'\n\nconst defaultFoldIconComponent = ({ collapsed }) => {\n  const style = { width: 25 }\n\n  if (collapsed) return <img src={right} style={style} alt=\"right\" />\n  return <img src={left} style={style} alt=\"left\" />\n}\n\nconst defaultFoldButtonComponent = ({ header, collapsed, icon, onClick }) => {\n  const style = {\n    marginLeft: '0px',\n    marginTop: '-5px',\n    marginBottom: '-8px',\n    float: 'left',\n    cursor: 'pointer',\n  }\n\n  return (\n    <div>\n      <div style={style} onClick={onClick}>\n        {icon}\n      </div>\n      {!collapsed && <div>{header}</div>}\n    </div>\n  )\n}\n\nexport default ReactTable => {\n  const wrapper = class RTFoldableTable extends React.Component {\n    constructor(props, context) {\n      super(props, context)\n\n      this.state = {\n        folded: props.onFoldChange ? undefined : {},\n        resized: props.resized || [],\n      }\n    }\n\n    componentWillReceiveProps(newProps) {\n      if (this.state.resized !== newProps.resized) {\n        this.setState(p => ({ resized: newProps.resized }))\n      }\n    }\n\n    onResizedChange = resized => {\n      const { onResizedChange } = this.props\n      if (onResizedChange) onResizedChange(resized)\n      else {\n        this.setState(p => ({ resized }))\n      }\n    }\n\n    removeResized = column => {\n      const { id } = column\n      if (!id) return\n\n      const { resized } = this.state\n      if (!resized) return\n\n      const rs = resized.find(r => r.id === id)\n      if (!rs) return\n\n      const newResized = resized.filter(r => r !== rs)\n      this.onResizedChange(newResized)\n    }\n\n    // this is so we can expose the underlying ReactTable.\n    getWrappedInstance = () => {\n      if (!this.wrappedInstance) console.warn('RTFoldableTable - No wrapped instance')\n      if (this.wrappedInstance.getWrappedInstance) return this.wrappedInstance.getWrappedInstance()\n      return this.wrappedInstance\n    }\n\n    getCopiedKey = key => {\n      const { foldableOriginalKey } = this.props\n      return `${foldableOriginalKey}${key}`\n    }\n\n    copyOriginals = column => {\n      const { FoldedColumn } = this.props\n\n      // Stop copy if the column already copied\n      if (column.original_Header) return\n\n      Object.keys(FoldedColumn).forEach(k => {\n        const copiedKey = this.getCopiedKey(k)\n\n        if (k === 'Cell') column[copiedKey] = column[k] ? column[k] : c => c.value\n        else column[copiedKey] = column[k]\n      })\n\n      // Copy sub Columns\n      if (column.columns && !column.original_Columns) column.original_Columns = column.columns\n\n      // Copy Header\n      if (!column.original_Header) column.original_Header = column.Header\n    }\n\n    restoreToOriginal = column => {\n      const { FoldedColumn } = this.props\n\n      Object.keys(FoldedColumn).forEach(k => {\n        // ignore header as handling by foldableHeaderRender\n        if (k === 'Header') return\n\n        const copiedKey = this.getCopiedKey(k)\n        column[k] = column[copiedKey]\n      })\n\n      if (column.columns && column.original_Columns) column.columns = column.original_Columns\n    }\n\n    getState = () => (this.props.onFoldChange ? this.props.folded : this.state.folded)\n\n    isFolded = col => {\n      const folded = this.getState()\n      return folded[col.id] === true\n    }\n\n    foldingHandler = col => {\n      if (!col || !col.id) return\n\n      const { onFoldChange } = this.props\n      const folded = this.getState()\n      const { id } = col\n\n      const newFold = Object.assign({}, folded)\n      newFold[id] = !newFold[id]\n\n      // Remove the Resized if have\n      this.removeResized(col)\n\n      if (onFoldChange) onFoldChange(newFold)\n      else {\n        this.setState(previous => ({ folded: newFold }))\n      }\n    }\n\n    foldableHeaderRender = cell => {\n      const { FoldButtonComponent, FoldIconComponent } = this.props\n      const { column } = cell\n      const collapsed = this.isFolded(column)\n      const icon = React.createElement(FoldIconComponent, { collapsed })\n      const onClick = () => this.foldingHandler(column)\n\n      return React.createElement(FoldButtonComponent, {\n        header: column.original_Header,\n        collapsed,\n        icon,\n        onClick,\n      })\n    }\n\n    applyFoldableForColumn = column => {\n      const collapsed = this.isFolded(column)\n      const { FoldedColumn } = this.props\n\n      // Handle Column Header\n      if (column.columns) {\n        if (collapsed) {\n          column.columns = [FoldedColumn]\n          column.width = FoldedColumn.width\n          column.style = FoldedColumn.style\n        } else this.restoreToOriginal(column)\n      }\n      // Handle Normal Column.\n      else if (collapsed) column = Object.assign(column, FoldedColumn)\n      else {\n        this.restoreToOriginal(column)\n      }\n    }\n\n    applyFoldableForColumns = columns =>\n      columns.map((col, index) => {\n        if (!col.foldable) return col\n\n        // If col don't have id then generate id based on index\n        if (!col.id) col.id = `col_${index}`\n\n        this.copyOriginals(col)\n        // Replace current header with internal header render.\n        col.Header = c => this.foldableHeaderRender(c)\n        // apply foldable\n        this.applyFoldableForColumn(col)\n\n        // return the new column out\n        return col\n      })\n\n    render() {\n      const {\n        columns: originalCols,\n        FoldButtonComponent,\n        FoldIconComponent,\n        FoldedColumn,\n        ...rest\n      } = this.props\n      const columns = this.applyFoldableForColumns([...originalCols])\n\n      const extra = {\n        columns,\n        onResizedChange: this.onResizedChange,\n        resized: this.state.resized,\n      }\n\n      return <ReactTable {...rest} {...extra} ref={r => (this.wrappedInstance = r)} />\n    }\n  }\n\n  wrapper.displayName = 'RTFoldableTable'\n  wrapper.defaultProps = {\n    FoldIconComponent: defaultFoldIconComponent,\n    FoldButtonComponent: defaultFoldButtonComponent,\n    foldableOriginalKey: 'original_',\n    FoldedColumn: {\n      Cell: c => '',\n      width: 30,\n      sortable: false,\n      resizable: false,\n      filterable: false,\n    },\n  }\n\n  return wrapper\n}\n"]}