@teselagen/react-table 6.10.9 → 6.10.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -352,4 +352,4 @@ export default {
352
352
  );
353
353
  }
354
354
  };
355
- //# 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"]}
355
+ //# sourceMappingURL=data:application/json;charset=utf-8;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"]}
@@ -230,4 +230,4 @@ var advancedExpandTableHOC = function advancedExpandTableHOC(TableComponent) {
230
230
  }, _class.DisplayName = 'AdvancedExpandTable', _temp;
231
231
  };
232
232
  export { advancedExpandTableHOC };
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/hoc/advancedExpandTable/index.js"],"names":["React","Component","PropTypes","set","get","subComponentWithToggle","SubComponent","expandFuncs","props","columnsWithToggle","columns","map","column","getProps","advancedExpandTableHOC","state","expanded","toggleRowSubComponent","bind","showRowSubComponent","hideRowSubComponent","getTdProps","fireOnExpandedChange","setState","rowInfo","e","onExpandedChange","rowInfoOrNestingPath","expandType","nestingPath","isExpanded","prevState","newExpanded","resolveNewTableState","tableState","expander","onClick","wrappedInstance","console","warn","getWrappedInstance","rest","wrappedColumns","WrappedSubComponent","AdvancedExpandTable","TdComponent","propTypes","array","isRequired","oneOfType","func","element","defaultProps","DisplayName"],"mappings":"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","file":"index.js","sourcesContent":["import React, { Component } from 'react'\nimport PropTypes from 'prop-types'\nimport set from 'lodash.set'\nimport get from 'lodash.get'\n\n/*\n  AvancedExpandTableHOC for ReactTable\n\n  HOC which allows any Cell in the row to toggle the row's\n  SubComponent. Also allows the SubComponent to toggle itself.\n\n  Expand functions available to any SubComponent or Column Cell:\n    toggleRowSubComponent\n    showRowSubComponent\n    hideRowSubComponent\n\n  Each Column Renderer (E.g. Cell ) gets the expand functions in its props\n  And Each SubComponent gets the expand functions in its props\n\n  Expand functions takes the `rowInfo` given to each\n  Column Renderer and SubComponent already by ReactTable.\n*/\n\nexport const subComponentWithToggle = (SubComponent, expandFuncs) => props => (\n  <SubComponent {...props} {...expandFuncs} />\n)\n\n// each cell in the column gets passed the function to toggle a sub component\nexport const columnsWithToggle = (columns, expandFuncs) =>\n  columns.map(column => {\n    if (column.columns) {\n      return {\n        ...column,\n        columns: columnsWithToggle(column.columns, expandFuncs),\n      }\n    }\n    return {\n      ...column,\n      getProps () {\n        return {\n          ...expandFuncs,\n        }\n      },\n    }\n  })\n\nexport const advancedExpandTableHOC = TableComponent =>\n  class AdvancedExpandTable extends Component {\n    constructor (props) {\n      super(props)\n      this.state = {\n        expanded: {},\n      }\n      this.toggleRowSubComponent = this.toggleRowSubComponent.bind(this)\n      this.showRowSubComponent = this.showRowSubComponent.bind(this)\n      this.hideRowSubComponent = this.hideRowSubComponent.bind(this)\n      this.getTdProps = this.getTdProps.bind(this)\n      this.fireOnExpandedChange = this.fireOnExpandedChange.bind(this)\n      this.expandFuncs = {\n        toggleRowSubComponent: this.toggleRowSubComponent,\n        showRowSubComponent: this.showRowSubComponent,\n        hideRowSubComponent: this.hideRowSubComponent,\n      }\n    }\n\n    // after initial render if we get new\n    // data, columns, page changes, etc.\n    // we reset expanded state.\n    UNSAFE_componentWillReceiveProps () {\n      this.setState({\n        expanded: {},\n      })\n    }\n\n    static propTypes = {\n      columns: PropTypes.array.isRequired,\n      SubComponent: PropTypes.oneOfType([PropTypes.func, PropTypes.element])\n        .isRequired,\n      onExpandedChange: PropTypes.func,\n    };\n\n    static defaultProps = {\n      onExpandedChange: null,\n    };\n\n    static DisplayName = 'AdvancedExpandTable';\n\n    // since we pass the expand functions to each Cell,\n    // we need to filter it out from being passed as an\n    // actual DOM attribute. See getProps in columnsWithToggle above.\n    static TdComponent ({\n      toggleRowSubComponent,\n      showRowSubComponent,\n      hideRowSubComponent,\n      ...rest\n    }) {\n      return <TableComponent.defaultProps.TdComponent {...rest} />\n    }\n\n    fireOnExpandedChange (rowInfo, e) {\n      // fire callback once state has changed.\n      if (this.props.onExpandedChange) {\n        this.props.onExpandedChange(rowInfo, e)\n      }\n    }\n\n    resolveNewTableState (rowInfoOrNestingPath, e, expandType) {\n      // derive nestingPath if only rowInfo is passed\n      let nestingPath = rowInfoOrNestingPath\n\n      if (rowInfoOrNestingPath.nestingPath) {\n        nestingPath = rowInfoOrNestingPath.nestingPath\n      }\n\n      this.setState(\n        prevState => {\n          const isExpanded = get(prevState.expanded, nestingPath)\n          // since we do not support nested rows, a shallow clone is okay.\n          const newExpanded = { ...prevState.expanded }\n\n          switch (expandType) {\n            case 'show':\n              set(newExpanded, nestingPath, {})\n              break\n            case 'hide':\n              set(newExpanded, nestingPath, false)\n              break\n            default:\n              // toggle\n              set(newExpanded, nestingPath, isExpanded ? false : {})\n          }\n          return {\n            ...prevState,\n            expanded: newExpanded,\n          }\n        },\n        () => this.fireOnExpandedChange(rowInfoOrNestingPath, e)\n      )\n    }\n\n    toggleRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e)\n    }\n\n    showRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e, 'show')\n    }\n\n    hideRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e, 'hide')\n    }\n\n    getTdProps (tableState, rowInfo, column) {\n      const { expander } = column\n\n      if (!expander) {\n        // no overrides\n        return {}\n      }\n\n      return {\n        // only override onClick for column Td\n        onClick: e => {\n          this.toggleRowSubComponent(rowInfo, e)\n        },\n      }\n    }\n\n    getWrappedInstance () {\n      if (!this.wrappedInstance) { console.warn('AdvancedExpandTable - No wrapped instance') }\n      if (this.wrappedInstance.getWrappedInstance) {\n        return this.wrappedInstance.getWrappedInstance()\n      }\n      return this.wrappedInstance\n    }\n\n    render () {\n      const {\n        columns, SubComponent, onExpandedChange, ...rest\n      } = this.props\n\n      const wrappedColumns = columnsWithToggle(columns, this.expandFuncs)\n      const WrappedSubComponent = subComponentWithToggle(\n        SubComponent,\n        this.expandFuncs\n      )\n\n      return (\n        <TableComponent\n          {...rest}\n          columns={wrappedColumns}\n          expanded={this.state.expanded}\n          getTdProps={this.getTdProps}\n          SubComponent={WrappedSubComponent}\n          TdComponent={AdvancedExpandTable.TdComponent}\n        />\n      )\n    }\n  }\n"]}
233
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/hoc/advancedExpandTable/index.js"],"names":["React","Component","PropTypes","set","get","subComponentWithToggle","SubComponent","expandFuncs","props","columnsWithToggle","columns","map","column","getProps","advancedExpandTableHOC","state","expanded","toggleRowSubComponent","bind","showRowSubComponent","hideRowSubComponent","getTdProps","fireOnExpandedChange","setState","rowInfo","e","onExpandedChange","rowInfoOrNestingPath","expandType","nestingPath","isExpanded","prevState","newExpanded","resolveNewTableState","tableState","expander","onClick","wrappedInstance","console","warn","getWrappedInstance","rest","wrappedColumns","WrappedSubComponent","AdvancedExpandTable","TdComponent","propTypes","array","isRequired","oneOfType","func","element","defaultProps","DisplayName"],"mappings":"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","file":"index.js","sourcesContent":["import React, { Component } from 'react'\nimport PropTypes from 'prop-types'\nimport set from 'lodash.set'\nimport get from 'lodash.get'\n\n/*\n  AvancedExpandTableHOC for ReactTable\n\n  HOC which allows any Cell in the row to toggle the row's\n  SubComponent. Also allows the SubComponent to toggle itself.\n\n  Expand functions available to any SubComponent or Column Cell:\n    toggleRowSubComponent\n    showRowSubComponent\n    hideRowSubComponent\n\n  Each Column Renderer (E.g. Cell ) gets the expand functions in its props\n  And Each SubComponent gets the expand functions in its props\n\n  Expand functions takes the `rowInfo` given to each\n  Column Renderer and SubComponent already by ReactTable.\n*/\n\nexport const subComponentWithToggle = (SubComponent, expandFuncs) => props => (\n  <SubComponent {...props} {...expandFuncs} />\n)\n\n// each cell in the column gets passed the function to toggle a sub component\nexport const columnsWithToggle = (columns, expandFuncs) =>\n  columns.map(column => {\n    if (column.columns) {\n      return {\n        ...column,\n        columns: columnsWithToggle(column.columns, expandFuncs),\n      }\n    }\n    return {\n      ...column,\n      getProps () {\n        return {\n          ...expandFuncs,\n        }\n      },\n    }\n  })\n\nexport const advancedExpandTableHOC = TableComponent =>\n  class AdvancedExpandTable extends Component {\n    constructor (props) {\n      super(props)\n      this.state = {\n        expanded: {},\n      }\n      this.toggleRowSubComponent = this.toggleRowSubComponent.bind(this)\n      this.showRowSubComponent = this.showRowSubComponent.bind(this)\n      this.hideRowSubComponent = this.hideRowSubComponent.bind(this)\n      this.getTdProps = this.getTdProps.bind(this)\n      this.fireOnExpandedChange = this.fireOnExpandedChange.bind(this)\n      this.expandFuncs = {\n        toggleRowSubComponent: this.toggleRowSubComponent,\n        showRowSubComponent: this.showRowSubComponent,\n        hideRowSubComponent: this.hideRowSubComponent,\n      }\n    }\n\n    // after initial render if we get new\n    // data, columns, page changes, etc.\n    // we reset expanded state.\n    UNSAFE_componentWillReceiveProps () {\n      this.setState({\n        expanded: {},\n      })\n    }\n\n    static propTypes = {\n      columns: PropTypes.array.isRequired,\n      SubComponent: PropTypes.oneOfType([PropTypes.func, PropTypes.element])\n        .isRequired,\n      onExpandedChange: PropTypes.func,\n    };\n\n    static defaultProps = {\n      onExpandedChange: null,\n    };\n\n    static DisplayName = 'AdvancedExpandTable';\n\n    // since we pass the expand functions to each Cell,\n    // we need to filter it out from being passed as an\n    // actual DOM attribute. See getProps in columnsWithToggle above.\n    static TdComponent ({\n      toggleRowSubComponent,\n      showRowSubComponent,\n      hideRowSubComponent,\n      ...rest\n    }) {\n      return <TableComponent.defaultProps.TdComponent {...rest} />\n    }\n\n    fireOnExpandedChange (rowInfo, e) {\n      // fire callback once state has changed.\n      if (this.props.onExpandedChange) {\n        this.props.onExpandedChange(rowInfo, e)\n      }\n    }\n\n    resolveNewTableState (rowInfoOrNestingPath, e, expandType) {\n      // derive nestingPath if only rowInfo is passed\n      let nestingPath = rowInfoOrNestingPath\n\n      if (rowInfoOrNestingPath.nestingPath) {\n        nestingPath = rowInfoOrNestingPath.nestingPath\n      }\n\n      this.setState(\n        prevState => {\n          const isExpanded = get(prevState.expanded, nestingPath)\n          // since we do not support nested rows, a shallow clone is okay.\n          const newExpanded = { ...prevState.expanded }\n\n          switch (expandType) {\n            case 'show':\n              set(newExpanded, nestingPath, {})\n              break\n            case 'hide':\n              set(newExpanded, nestingPath, false)\n              break\n            default:\n              // toggle\n              set(newExpanded, nestingPath, isExpanded ? false : {})\n          }\n          return {\n            ...prevState,\n            expanded: newExpanded,\n          }\n        },\n        () => this.fireOnExpandedChange(rowInfoOrNestingPath, e)\n      )\n    }\n\n    toggleRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e)\n    }\n\n    showRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e, 'show')\n    }\n\n    hideRowSubComponent (rowInfo, e) {\n      this.resolveNewTableState(rowInfo, e, 'hide')\n    }\n\n    getTdProps (tableState, rowInfo, column) {\n      const { expander } = column\n\n      if (!expander) {\n        // no overrides\n        return {}\n      }\n\n      return {\n        // only override onClick for column Td\n        onClick: e => {\n          this.toggleRowSubComponent(rowInfo, e)\n        },\n      }\n    }\n\n    getWrappedInstance () {\n      if (!this.wrappedInstance) { console.warn('AdvancedExpandTable - No wrapped instance') }\n      if (this.wrappedInstance.getWrappedInstance) {\n        return this.wrappedInstance.getWrappedInstance()\n      }\n      return this.wrappedInstance\n    }\n\n    render () {\n      const {\n        columns, SubComponent, onExpandedChange, ...rest\n      } = this.props\n\n      const wrappedColumns = columnsWithToggle(columns, this.expandFuncs)\n      const WrappedSubComponent = subComponentWithToggle(\n        SubComponent,\n        this.expandFuncs\n      )\n\n      return (\n        <TableComponent\n          {...rest}\n          columns={wrappedColumns}\n          expanded={this.state.expanded}\n          getTdProps={this.getTdProps}\n          SubComponent={WrappedSubComponent}\n          TdComponent={AdvancedExpandTable.TdComponent}\n        />\n      )\n    }\n  }\n"]}
@@ -301,4 +301,4 @@ export default (function (ReactTable) {
301
301
 
302
302
  return wrapper;
303
303
  });
304
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/hoc/foldableTable/index.js"],"names":["React","left","right","defaultFoldIconComponent","collapsed","style","width","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","createElement","applyFoldableForColumn","applyFoldableForColumns","map","index","foldable","undefined","newProps","originalCols","rest","extra","Component","displayName","defaultProps","Cell","sortable","resizable","filterable"],"mappings":"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","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    UNSAFE_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"]}
304
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/hoc/foldableTable/index.js"],"names":["React","left","right","defaultFoldIconComponent","collapsed","style","width","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","createElement","applyFoldableForColumn","applyFoldableForColumns","map","index","foldable","undefined","newProps","originalCols","rest","extra","Component","displayName","defaultProps","Cell","sortable","resizable","filterable"],"mappings":"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","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    UNSAFE_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"]}
@@ -158,4 +158,4 @@ export default (function (Component, options) {
158
158
 
159
159
  return wrapper;
160
160
  });
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/hoc/selectTable/index.js"],"names":["React","defaultSelectInputComponent","props","selectType","checked","id","shiftKey","e","stopPropagation","onClick","row","Component","options","wrapper","hasOwnProperty","keyField","toggleSelection","isSelected","inputProps","createElement","SelectInputComponent","toggleAll","selectAll","SelectAllInputComponent","wrappedInstance","console","warn","getWrappedInstance","originalCols","columns","selectWidth","rest","select","accessor","Header","headSelector","bind","Cell","rowSelector","ci","original","width","filterable","sortable","resizable","style","textAlign","undefined","floatingLeft","extra","r","displayName","defaultProps","log","key","shift"],"mappings":"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","file":"index.js","sourcesContent":["/* eslint-disable */\n\nimport React from 'react'\n\nconst defaultSelectInputComponent = props => {\n  return (\n    <input\n      type={props.selectType || 'checkbox'}\n      aria-label={`${props.checked ? 'Un-select':'Select'} row with id:${props.id}` }\n      checked={props.checked}\n      id={props.id}\n      onClick={e => {\n        const { shiftKey } = e\n        e.stopPropagation()\n        props.onClick(props.id, shiftKey, props.row)\n      }}\n      onChange={() => {}}\n    />\n  )\n}\n\nexport default (Component, options) => {\n  const wrapper = class RTSelectTable extends React.Component {\n    constructor(props) {\n      super(props)\n    }\n\n    rowSelector(row) {\n      if (!row || !row.hasOwnProperty(this.props.keyField)) return null\n      const { toggleSelection, selectType, keyField } = this.props\n      const checked = this.props.isSelected(row[this.props.keyField])\n      const inputProps = {\n        checked,\n        onClick: toggleSelection,\n        selectType,\n        row,\n        id: `select-${row[keyField]}`\n      }\n      return React.createElement(this.props.SelectInputComponent, inputProps)\n    }\n\n    headSelector(row) {\n      const { selectType } = this.props\n      if (selectType === 'radio') return null\n\n      const { toggleAll, selectAll: checked, SelectAllInputComponent } = this.props\n      const inputProps = {\n        checked,\n        onClick: toggleAll,\n        selectType,\n        id: 'select-all'\n      }\n\n      return React.createElement(SelectAllInputComponent, inputProps)\n    }\n\n    // this is so we can expose the underlying ReactTable to get at the sortedData for selectAll\n    getWrappedInstance() {\n      if (!this.wrappedInstance) console.warn('RTSelectTable - No wrapped instance')\n      if (this.wrappedInstance.getWrappedInstance) return this.wrappedInstance.getWrappedInstance()\n      else return this.wrappedInstance\n    }\n\n    render() {\n      const {\n        columns: originalCols,\n        isSelected,\n        toggleSelection,\n        toggleAll,\n        keyField,\n        selectAll,\n        selectType,\n        selectWidth,\n        SelectAllInputComponent,\n        SelectInputComponent,\n        ...rest\n      } = this.props\n      const select = {\n        id: '_selector',\n        accessor: () => 'x', // this value is not important\n        Header: this.headSelector.bind(this),\n        Cell: ci => {\n          return this.rowSelector.bind(this)(ci.original)\n        },\n        width: selectWidth || 30,\n        filterable: false,\n        sortable: false,\n        resizable: false,\n        style: { textAlign: 'center' },\n      }\n\n      const columns = (options !== undefined && options.floatingLeft === true) ? [...originalCols, select] : [select, ...originalCols]\n      const extra = {\n        columns,\n      }\n      return <Component {...rest} {...extra} ref={r => (this.wrappedInstance = r)} />\n    }\n  }\n\n  wrapper.displayName = 'RTSelectTable'\n  wrapper.defaultProps = {\n    keyField: '_id',\n    isSelected: key => {\n      console.log('No isSelected handler provided:', { key })\n    },\n    selectAll: false,\n    toggleSelection: (key, shift, row) => {\n      console.log('No toggleSelection handler provided:', { key, shift, row })\n    },\n    toggleAll: () => {\n      console.log('No toggleAll handler provided.')\n    },\n    selectType: 'checkbox',\n    SelectInputComponent: defaultSelectInputComponent,\n    SelectAllInputComponent: defaultSelectInputComponent,\n  }\n\n  return wrapper\n}\n"]}
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/hoc/selectTable/index.js"],"names":["React","defaultSelectInputComponent","props","selectType","checked","id","shiftKey","e","stopPropagation","onClick","row","Component","options","wrapper","hasOwnProperty","keyField","toggleSelection","isSelected","inputProps","createElement","SelectInputComponent","toggleAll","selectAll","SelectAllInputComponent","wrappedInstance","console","warn","getWrappedInstance","originalCols","columns","selectWidth","rest","select","accessor","Header","headSelector","bind","Cell","rowSelector","ci","original","width","filterable","sortable","resizable","style","textAlign","undefined","floatingLeft","extra","r","displayName","defaultProps","log","key","shift"],"mappings":"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","file":"index.js","sourcesContent":["/* eslint-disable */\n\nimport React from 'react'\n\nconst defaultSelectInputComponent = props => {\n  return (\n    <input\n      type={props.selectType || 'checkbox'}\n      aria-label={`${props.checked ? 'Un-select':'Select'} row with id:${props.id}` }\n      checked={props.checked}\n      id={props.id}\n      onClick={e => {\n        const { shiftKey } = e\n        e.stopPropagation()\n        props.onClick(props.id, shiftKey, props.row)\n      }}\n      onChange={() => {}}\n    />\n  )\n}\n\nexport default (Component, options) => {\n  const wrapper = class RTSelectTable extends React.Component {\n    constructor(props) {\n      super(props)\n    }\n\n    rowSelector(row) {\n      if (!row || !row.hasOwnProperty(this.props.keyField)) return null\n      const { toggleSelection, selectType, keyField } = this.props\n      const checked = this.props.isSelected(row[this.props.keyField])\n      const inputProps = {\n        checked,\n        onClick: toggleSelection,\n        selectType,\n        row,\n        id: `select-${row[keyField]}`\n      }\n      return React.createElement(this.props.SelectInputComponent, inputProps)\n    }\n\n    headSelector(row) {\n      const { selectType } = this.props\n      if (selectType === 'radio') return null\n\n      const { toggleAll, selectAll: checked, SelectAllInputComponent } = this.props\n      const inputProps = {\n        checked,\n        onClick: toggleAll,\n        selectType,\n        id: 'select-all'\n      }\n\n      return React.createElement(SelectAllInputComponent, inputProps)\n    }\n\n    // this is so we can expose the underlying ReactTable to get at the sortedData for selectAll\n    getWrappedInstance() {\n      if (!this.wrappedInstance) console.warn('RTSelectTable - No wrapped instance')\n      if (this.wrappedInstance.getWrappedInstance) return this.wrappedInstance.getWrappedInstance()\n      else return this.wrappedInstance\n    }\n\n    render() {\n      const {\n        columns: originalCols,\n        isSelected,\n        toggleSelection,\n        toggleAll,\n        keyField,\n        selectAll,\n        selectType,\n        selectWidth,\n        SelectAllInputComponent,\n        SelectInputComponent,\n        ...rest\n      } = this.props\n      const select = {\n        id: '_selector',\n        accessor: () => 'x', // this value is not important\n        Header: this.headSelector.bind(this),\n        Cell: ci => {\n          return this.rowSelector.bind(this)(ci.original)\n        },\n        width: selectWidth || 30,\n        filterable: false,\n        sortable: false,\n        resizable: false,\n        style: { textAlign: 'center' },\n      }\n\n      const columns = (options !== undefined && options.floatingLeft === true) ? [...originalCols, select] : [select, ...originalCols]\n      const extra = {\n        columns,\n      }\n      return <Component {...rest} {...extra} ref={r => (this.wrappedInstance = r)} />\n    }\n  }\n\n  wrapper.displayName = 'RTSelectTable'\n  wrapper.defaultProps = {\n    keyField: '_id',\n    isSelected: key => {\n      console.log('No isSelected handler provided:', { key })\n    },\n    selectAll: false,\n    toggleSelection: (key, shift, row) => {\n      console.log('No toggleSelection handler provided:', { key, shift, row })\n    },\n    toggleAll: () => {\n      console.log('No toggleAll handler provided.')\n    },\n    selectType: 'checkbox',\n    SelectInputComponent: defaultSelectInputComponent,\n    SelectAllInputComponent: defaultSelectInputComponent,\n  }\n\n  return wrapper\n}\n"]}
@@ -119,4 +119,4 @@ export default (function (Component) {
119
119
 
120
120
  return wrapper;
121
121
  });
122
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ob2MvdHJlZVRhYmxlL2luZGV4LmpzIl0sIm5hbWVzIjpbIlJlYWN0Iiwid3JhcHBlciIsInByb3BzIiwiZ2V0V3JhcHBlZEluc3RhbmNlIiwiYmluZCIsIlRyQ29tcG9uZW50IiwiZ2V0VHJQcm9wcyIsImNvbHVtbnMiLCJ0cmVlVGFibGVJbmRlbnQiLCJyZXN0IiwiZXh0cmEiLCJtYXAiLCJjb2x1bW4iLCJjb2wiLCJwaXZvdEJ5IiwiaW5jbHVkZXMiLCJhY2Nlc3NvciIsImlkIiwid2lkdGgiLCJzaG93IiwiSGVhZGVyIiwiRXhwYW5kZXIiLCJQaXZvdFZhbHVlIiwiUGl2b3QiLCJ3cmFwcGVkSW5zdGFuY2UiLCJyIiwiQ29tcG9uZW50IiwiY29uc29sZSIsIndhcm4iLCJyaSIsImdyb3VwZWRCeVBpdm90IiwiY2VsbCIsImNoaWxkcmVuIiwibGV2ZWwiLCJzdHlsZSIsImZsZXgiLCJtYXhXaWR0aCIsInBhZGRpbmdMZWZ0IiwiYm9yZGVyQm90dG9tIiwiY2xhc3NOYW1lIiwic3RhdGUiLCJjaSIsImluc3RhbmNlIiwiZGlzcGxheU5hbWUiLCJkZWZhdWx0UHJvcHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBOztBQUVBLE9BQU9BLEtBQVAsTUFBa0IsT0FBbEI7O0FBRUEsZ0JBQWUscUJBQWE7QUFBQTs7QUFDMUIsTUFBTUM7QUFBQTs7QUFDSix5QkFBWUMsS0FBWixFQUFtQjtBQUFBOztBQUFBLDRIQUNYQSxLQURXOztBQUFBOztBQUVqQixZQUFLQyxrQkFBTCxDQUF3QkMsSUFBeEI7QUFDQSxZQUFLQyxXQUFMLENBQWlCRCxJQUFqQjtBQUNBLFlBQUtFLFVBQUwsQ0FBZ0JGLElBQWhCO0FBSmlCO0FBS2xCOztBQUVEOzs7QUFSSTtBQUFBO0FBQUEsK0JBd0NLO0FBQUE7O0FBQUEscUJBQ3VDLEtBQUtGLEtBRDVDO0FBQUEsWUFDQ0ssT0FERCxVQUNDQSxPQUREO0FBQUEsWUFDVUMsZUFEVixVQUNVQSxlQURWO0FB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QVEyQyxZQUFSLEdBQXVCO0FBQ3JCcEMscUJBQWlCO0FBREksR0FBdkI7O0FBSUEsU0FBT1AsT0FBUDtBQUNELENBMUVEIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgZGVmYXVsdCBDb21wb25lbnQgPT4ge1xuICBjb25zdCB3cmFwcGVyID0gY2xhc3MgUlRUcmVlVGFibGUgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICAgIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgICBzdXBlcihwcm9wcylcbiAgICAgIHRoaXMuZ2V0V3JhcHBlZEluc3RhbmNlLmJpbmQodGhpcylcbiAgICAgIHRoaXMuVHJDb21wb25lbnQuYmluZCh0aGlzKVxuICAgICAgdGhpcy5nZXRUclByb3BzLmJpbmQodGhpcylcbiAgICB9XG5cbiAgICAvLyB0aGlzIGlzIHNvIHdlIGNhbiBleHBvc2UgdGhlIHVuZGVybHlpbmcgUmVhY3RUYWJsZSB0byBnZXQgYXQgdGhlIHNvcnRlZERhdGEgZm9yIHNlbGVjdEFsbFxuICAgIGdldFdyYXBwZWRJbnN0YW5jZSA9ICgpID0+IHtcbiAgICAgIGlmICghdGhpcy53cmFwcGVkSW5zdGFuY2UpIGNvbnNvbGUud2FybignUlRUcmVlVGFibGUgLSBObyB3cmFwcGVkIGluc3RhbmNlJylcbiAgICAgIGlmICh0aGlzLndyYXBwZWRJbnN0YW5jZS5nZXRXcmFwcGVkSW5zdGFuY2UpIHJldHVybiB0aGlzLndyYXBwZWRJbnN0YW5jZS5nZXRXcmFwcGVkSW5zdGFuY2UoKVxuICAgICAgZWxzZSByZXR1cm4gdGhpcy53cmFwcGVkSW5zdGFuY2VcbiAgICB9XG5cbiAgICBUckNvbXBvbmVudCA9IHByb3BzID0+IHtcbiAgICAgIGNvbnN0IHsgcmksIC4uLnJlc3QgfSA9IHByb3BzXG4gICAgICBpZiAocmkgJiYgcmkuZ3JvdXBlZEJ5UGl2b3QpIHtcbiAgICAgICAgY29uc3QgY2VsbCA9IHsgLi4ucHJvcHMuY2hpbGRyZW5bcmkubGV2ZWxdIH1cblxuICAgICAgICBjZWxsLnByb3BzLnN0eWxlLmZsZXggPSAndW5zZXQnXG4gICAgICAgIGNlbGwucHJvcHMuc3R5bGUud2lkdGggPSAnMTAwJSdcbiAgICAgICAgY2VsbC5wcm9wcy5zdHlsZS5tYXhXaWR0aCA9ICd1bnNldCdcbiAgICAgICAgY2VsbC5wcm9wcy5zdHlsZS5wYWRkaW5nTGVmdCA9IGAke3RoaXMucHJvcHMudHJlZVRhYmxlSW5kZW50ICogcmkubGV2ZWx9cHhgXG4gICAgICAgIC8vIGNlbGwucHJvcHMuc3R5bGUuYmFja2dyb3VuZENvbG9yID0gJyNEREQnO1xuICAgICAgICBjZWxsLnByb3BzLnN0eWxlLmJvcmRlckJvdHRvbSA9ICcxcHggc29saWQgcmdiYSgxMjgsMTI4LDEyOCwwLjIpJ1xuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2BydC10ciAke3Jlc3QuY2xhc3NOYW1lfWB9IHJvbGU9XCJyb3dcIiBzdHlsZT17cmVzdC5zdHlsZX0+XG4gICAgICAgICAgICB7Y2VsbH1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgKVxuICAgICAgfVxuICAgICAgcmV0dXJuIDxDb21wb25lbnQuZGVmYXVsdFByb3BzLlRyQ29tcG9uZW50IHsuLi5yZXN0fSAvPlxuICAgIH1cblxuICAgIGdldFRyUHJvcHMgPSAoc3RhdGUsIHJpLCBjaSwgaW5zdGFuY2UpID0+IHtcbiAgICAgIHJldHVybiB7IHJpIH1cbiAgICB9XG5cbiAgICByZW5kZXIoKSB7XG4gICAgICBjb25zdCB7IGNvbHVtbnMsIHRyZWVUYWJsZUluZGVudCwgLi4ucmVzdCB9ID0gdGhpcy5wcm9wc1xuICAgICAgY29uc3QgeyBUckNvbXBvbmVudCwgZ2V0VHJQcm9wcyB9ID0gdGhpc1xuICAgICAgY29uc3QgZXh0cmEgPSB7XG4gICAgICAgIGNvbHVtbnM6IGNvbHVtbnMubWFwKGNvbCA9PiB7XG4gICAgICAgICAgbGV0IGNvbHVtbiA9IGNvbFxuICAgICAgICAgIGlmIChyZXN0LnBpdm90QnkgJiYgKHJlc3QucGl2b3RCeS5pbmNsdWRlcyhjb2wuYWNjZXNzb3IpIHx8IHJlc3QucGl2b3RCeS5pbmNsdWRlcyhjb2wuaWQpKSkge1xuICAgICAgICAgICAgY29sdW1uID0ge1xuICAgICAgICAgICAgICBpZDogY29sLmlkLFxuICAgICAgICAgICAgICBhY2Nlc3NvcjogY29sLmFjY2Vzc29yLFxuICAgICAgICAgICAgICB3aWR0aDogYCR7dHJlZVRhYmxlSW5kZW50fXB4YCxcbiAgICAgICAgICAgICAgc2hvdzogZmFsc2UsXG4gICAgICAgICAgICAgIEhlYWRlcjogJycsXG4gICAgICAgICAgICAgIEV4cGFuZGVyOiBjb2wuRXhwYW5kZXIsXG4gICAgICAgICAgICAgIFBpdm90VmFsdWU6IGNvbC5QaXZvdFZhbHVlLFxuICAgICAgICAgICAgICBQaXZvdDogY29sLlBpdm90LFxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gY29sdW1uXG4gICAgICAgIH0pLFxuICAgICAgICBUckNvbXBvbmVudCxcbiAgICAgICAgZ2V0VHJQcm9wcyxcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIDxDb21wb25lbnQgey4uLnJlc3R9IHsuLi5leHRyYX0gcmVmPXtyID0+ICh0aGlzLndyYXBwZWRJbnN0YW5jZSA9IHIpfSAvPlxuICAgIH1cbiAgfVxuICB3cmFwcGVyLmRpc3BsYXlOYW1lID0gJ1JUVHJlZVRhYmxlJ1xuICB3cmFwcGVyLmRlZmF1bHRQcm9wcyA9IHtcbiAgICB0cmVlVGFibGVJbmRlbnQ6IDEwLFxuICB9XG5cbiAgcmV0dXJuIHdyYXBwZXJcbn1cbiJdfQ==
122
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9ob2MvdHJlZVRhYmxlL2luZGV4LmpzIl0sIm5hbWVzIjpbIlJlYWN0Iiwid3JhcHBlciIsInByb3BzIiwiZ2V0V3JhcHBlZEluc3RhbmNlIiwiYmluZCIsIlRyQ29tcG9uZW50IiwiZ2V0VHJQcm9wcyIsImNvbHVtbnMiLCJ0cmVlVGFibGVJbmRlbnQiLCJyZXN0IiwiZXh0cmEiLCJtYXAiLCJjb2x1bW4iLCJjb2wiLCJwaXZvdEJ5IiwiaW5jbHVkZXMiLCJhY2Nlc3NvciIsImlkIiwid2lkdGgiLCJzaG93IiwiSGVhZGVyIiwiRXhwYW5kZXIiLCJQaXZvdFZhbHVlIiwiUGl2b3QiLCJ3cmFwcGVkSW5zdGFuY2UiLCJyIiwiQ29tcG9uZW50IiwiY29uc29sZSIsIndhcm4iLCJyaSIsImdyb3VwZWRCeVBpdm90IiwiY2VsbCIsImNoaWxkcmVuIiwibGV2ZWwiLCJzdHlsZSIsImZsZXgiLCJtYXhXaWR0aCIsInBhZGRpbmdMZWZ0IiwiYm9yZGVyQm90dG9tIiwiY2xhc3NOYW1lIiwic3RhdGUiLCJjaSIsImluc3RhbmNlIiwiZGlzcGxheU5hbWUiLCJkZWZhdWx0UHJvcHMiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBOztBQUVBLE9BQU9BLEtBQVAsTUFBa0IsT0FBbEI7O0FBRUEsZ0JBQWUscUJBQWE7QUFBQTs7QUFDMUIsTUFBTUM7QUFBQTs7QUFDSix5QkFBWUMsS0FBWixFQUFtQjtBQUFBOztBQUFBLDRIQUNYQSxLQURXOztBQUFBOztBQUVqQixZQUFLQyxrQkFBTCxDQUF3QkMsSUFBeEI7QUFDQSxZQUFLQyxXQUFMLENBQWlCRCxJQUFqQjtBQUNBLFlBQUtFLFVBQUwsQ0FBZ0JGLElBQWhCO0FBSmlCO0FBS2xCOztBQUVEOzs7QUFSSTtBQUFBO0FBQUEsK0JBd0NLO0FBQUE7O0FBQUEscUJBQ3VDLEtBQUtGLEtBRDVDO0FBQUEsWUFDQ0ssT0FERCxVQUNDQSxPQUREO0FBQUEsWUFDVUMsZUFEVixVQUNVQSxlQURWO0FBQUEsWUFDOEJDLElBRDlCOztBQUFBLFlBRUNKLFdBRkQsR0FFNkIsSUFGN0IsQ0FFQ0EsV0FGRDtBQUFBLFlBRWNDLFVBRmQsR0FFNkIsSUFGN0IsQ0FFY0EsVUFGZDs7QUFHUCxZQUFNSSxRQUFRO0FBQ1pILG1CQUFTQSxRQUFRSSxHQUFSLENBQVksZUFBTztBQUMxQixnQkFBSUMsU0FBU0MsR0FBYjtBQUNBLGdCQUFJSixLQUFLSyxPQUFMLEtBQWlCTCxLQUFLSyxPQUFMLENBQWFDLFFBQWIsQ0FBc0JGLElBQUlHLFFBQTFCLEtBQXVDUCxLQUFLSyxPQUFMLENBQWFDLFFBQWIsQ0FBc0JGLElBQUlJLEVBQTFCLENBQXhELENBQUosRUFBNEY7QUFDMUZMLHVCQUFTO0FBQ1BLLG9CQUFJSixJQUFJSSxFQUREO0FBRVBELDBCQUFVSCxJQUFJRyxRQUZQO0FBR1BFLHVCQUFVVixlQUFWLE9BSE87QUFJUFcsc0JBQU0sS0FKQztBQUtQQyx3QkFBUSxFQUxEO0FBTVBDLDBCQUFVUixJQUFJUSxRQU5QO0FBT1BDLDRCQUFZVCxJQUFJUyxVQVBUO0FBUVBDLHVCQUFPVixJQUFJVTtBQVJKLGVBQVQ7QUFVRDtBQUNELG1CQUFPWCxNQUFQO0FBQ0QsV0FmUSxDQURHO0FBaUJaUCxrQ0FqQlk7QUFrQlpDO0FBbEJZLFNBQWQ7O0FBcUJBLGVBQU8sb0JBQUMsU0FBRCxlQUFlRyxJQUFmLEVBQXlCQyxLQUF6QixJQUFnQyxLQUFLO0FBQUEsbUJBQU0sT0FBS2MsZUFBTCxHQUF1QkMsQ0FBN0I7QUFBQSxXQUFyQyxJQUFQO0FBQ0Q7QUFqRUc7O0FBQUE7QUFBQSxJQUFvQ3pCLE1BQU0wQixTQUExQztBQUFBOztBQUFBLFNBU0p2QixrQkFUSSxHQVNpQixZQUFNO0FBQ3pCLFVBQUksQ0FBQyxPQUFLcUIsZUFBVixFQUEyQkcsUUFBUUMsSUFBUixDQUFhLG1DQUFiO0FBQzNCLFVBQUksT0FBS0osZUFBTCxDQUFxQnJCLGtCQUF6QixFQUE2QyxPQUFPLE9BQUtxQixlQUFMLENBQXFCckIsa0JBQXJCLEVBQVAsQ0FBN0MsS0FDSyxPQUFPLE9BQUtxQixlQUFaO0FBQ04sS0FiRzs7QUFBQSxTQWVKbkIsV0FmSSxHQWVVLGlCQUFTO0FBQUEsVUFDYndCLEVBRGEsR0FDRzNCLEtBREgsQ0FDYjJCLEVBRGE7QUFBQSxVQUNOcEIsSUFETSw0QkFDR1AsS0FESDs7QUFFckIsVUFBSTJCLE1BQU1BLEdBQUdDLGNBQWIsRUFBNkI7QUFDM0IsWUFBTUMsb0JBQVk3QixNQUFNOEIsUUFBTixDQUFlSCxHQUFHSSxLQUFsQixDQUFaLENBQU47O0FBRUFGLGFBQUs3QixLQUFMLENBQVdnQyxLQUFYLENBQWlCQyxJQUFqQixHQUF3QixPQUF4QjtBQUNBSixhQUFLN0IsS0FBTCxDQUFXZ0MsS0FBWCxDQUFpQmhCLEtBQWpCLEdBQXlCLE1BQXpCO0FBQ0FhLGFBQUs3QixLQUFMLENBQVdnQyxLQUFYLENBQWlCRSxRQUFqQixHQUE0QixPQUE1QjtBQUNBTCxhQUFLN0IsS0FBTCxDQUFXZ0MsS0FBWCxDQUFpQkcsV0FBakIsR0FBa0MsT0FBS25DLEtBQUwsQ0FBV00sZUFBWCxHQUE2QnFCLEdBQUdJLEtBQWxFO0FBQ0E7QUFDQUYsYUFBSzdCLEtBQUwsQ0FBV2dDLEtBQVgsQ0FBaUJJLFlBQWpCLEdBQWdDLGlDQUFoQzs7QUFFQSxlQUNFO0FBQUE7QUFBQSxZQUFLLHNCQUFvQjdCLEtBQUs4QixTQUE5QixFQUEyQyxNQUFLLEtBQWhELEVBQXNELE9BQU85QixLQUFLeUIsS0FBbEU7QUFDR0g7QUFESCxTQURGO0FBS0Q7QUFDRCxhQUFPLG9CQUFDLFNBQUQsQ0FBVyxZQUFYLENBQXdCLFdBQXhCLEVBQXdDdEIsSUFBeEMsQ0FBUDtBQUNELEtBbENHOztBQUFBLFNBb0NKSCxVQXBDSSxHQW9DUyxVQUFDa0MsS0FBRCxFQUFRWCxFQUFSLEVBQVlZLEVBQVosRUFBZ0JDLFFBQWhCLEVBQTZCO0FBQ3hDLGFBQU8sRUFBRWIsTUFBRixFQUFQO0FBQ0QsS0F0Q0c7QUFBQSxXQUFOO0FBbUVBNUIsVUFBUTBDLFdBQVIsR0FBc0IsYUFBdEI7QUFDQTFDLFVBQVEyQyxZQUFSLEdBQXVCO0FBQ3JCcEMscUJBQWlCO0FBREksR0FBdkI7O0FBSUEsU0FBT1AsT0FBUDtBQUNELENBMUVEIiwiZmlsZSI6ImluZGV4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgZGVmYXVsdCBDb21wb25lbnQgPT4ge1xuICBjb25zdCB3cmFwcGVyID0gY2xhc3MgUlRUcmVlVGFibGUgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICAgIGNvbnN0cnVjdG9yKHByb3BzKSB7XG4gICAgICBzdXBlcihwcm9wcylcbiAgICAgIHRoaXMuZ2V0V3JhcHBlZEluc3RhbmNlLmJpbmQodGhpcylcbiAgICAgIHRoaXMuVHJDb21wb25lbnQuYmluZCh0aGlzKVxuICAgICAgdGhpcy5nZXRUclByb3BzLmJpbmQodGhpcylcbiAgICB9XG5cbiAgICAvLyB0aGlzIGlzIHNvIHdlIGNhbiBleHBvc2UgdGhlIHVuZGVybHlpbmcgUmVhY3RUYWJsZSB0byBnZXQgYXQgdGhlIHNvcnRlZERhdGEgZm9yIHNlbGVjdEFsbFxuICAgIGdldFdyYXBwZWRJbnN0YW5jZSA9ICgpID0+IHtcbiAgICAgIGlmICghdGhpcy53cmFwcGVkSW5zdGFuY2UpIGNvbnNvbGUud2FybignUlRUcmVlVGFibGUgLSBObyB3cmFwcGVkIGluc3RhbmNlJylcbiAgICAgIGlmICh0aGlzLndyYXBwZWRJbnN0YW5jZS5nZXRXcmFwcGVkSW5zdGFuY2UpIHJldHVybiB0aGlzLndyYXBwZWRJbnN0YW5jZS5nZXRXcmFwcGVkSW5zdGFuY2UoKVxuICAgICAgZWxzZSByZXR1cm4gdGhpcy53cmFwcGVkSW5zdGFuY2VcbiAgICB9XG5cbiAgICBUckNvbXBvbmVudCA9IHByb3BzID0+IHtcbiAgICAgIGNvbnN0IHsgcmksIC4uLnJlc3QgfSA9IHByb3BzXG4gICAgICBpZiAocmkgJiYgcmkuZ3JvdXBlZEJ5UGl2b3QpIHtcbiAgICAgICAgY29uc3QgY2VsbCA9IHsgLi4ucHJvcHMuY2hpbGRyZW5bcmkubGV2ZWxdIH1cblxuICAgICAgICBjZWxsLnByb3BzLnN0eWxlLmZsZXggPSAndW5zZXQnXG4gICAgICAgIGNlbGwucHJvcHMuc3R5bGUud2lkdGggPSAnMTAwJSdcbiAgICAgICAgY2VsbC5wcm9wcy5zdHlsZS5tYXhXaWR0aCA9ICd1bnNldCdcbiAgICAgICAgY2VsbC5wcm9wcy5zdHlsZS5wYWRkaW5nTGVmdCA9IGAke3RoaXMucHJvcHMudHJlZVRhYmxlSW5kZW50ICogcmkubGV2ZWx9cHhgXG4gICAgICAgIC8vIGNlbGwucHJvcHMuc3R5bGUuYmFja2dyb3VuZENvbG9yID0gJyNEREQnO1xuICAgICAgICBjZWxsLnByb3BzLnN0eWxlLmJvcmRlckJvdHRvbSA9ICcxcHggc29saWQgcmdiYSgxMjgsMTI4LDEyOCwwLjIpJ1xuXG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgPGRpdiBjbGFzc05hbWU9e2BydC10ciAke3Jlc3QuY2xhc3NOYW1lfWB9IHJvbGU9XCJyb3dcIiBzdHlsZT17cmVzdC5zdHlsZX0+XG4gICAgICAgICAgICB7Y2VsbH1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgKVxuICAgICAgfVxuICAgICAgcmV0dXJuIDxDb21wb25lbnQuZGVmYXVsdFByb3BzLlRyQ29tcG9uZW50IHsuLi5yZXN0fSAvPlxuICAgIH1cblxuICAgIGdldFRyUHJvcHMgPSAoc3RhdGUsIHJpLCBjaSwgaW5zdGFuY2UpID0+IHtcbiAgICAgIHJldHVybiB7IHJpIH1cbiAgICB9XG5cbiAgICByZW5kZXIoKSB7XG4gICAgICBjb25zdCB7IGNvbHVtbnMsIHRyZWVUYWJsZUluZGVudCwgLi4ucmVzdCB9ID0gdGhpcy5wcm9wc1xuICAgICAgY29uc3QgeyBUckNvbXBvbmVudCwgZ2V0VHJQcm9wcyB9ID0gdGhpc1xuICAgICAgY29uc3QgZXh0cmEgPSB7XG4gICAgICAgIGNvbHVtbnM6IGNvbHVtbnMubWFwKGNvbCA9PiB7XG4gICAgICAgICAgbGV0IGNvbHVtbiA9IGNvbFxuICAgICAgICAgIGlmIChyZXN0LnBpdm90QnkgJiYgKHJlc3QucGl2b3RCeS5pbmNsdWRlcyhjb2wuYWNjZXNzb3IpIHx8IHJlc3QucGl2b3RCeS5pbmNsdWRlcyhjb2wuaWQpKSkge1xuICAgICAgICAgICAgY29sdW1uID0ge1xuICAgICAgICAgICAgICBpZDogY29sLmlkLFxuICAgICAgICAgICAgICBhY2Nlc3NvcjogY29sLmFjY2Vzc29yLFxuICAgICAgICAgICAgICB3aWR0aDogYCR7dHJlZVRhYmxlSW5kZW50fXB4YCxcbiAgICAgICAgICAgICAgc2hvdzogZmFsc2UsXG4gICAgICAgICAgICAgIEhlYWRlcjogJycsXG4gICAgICAgICAgICAgIEV4cGFuZGVyOiBjb2wuRXhwYW5kZXIsXG4gICAgICAgICAgICAgIFBpdm90VmFsdWU6IGNvbC5QaXZvdFZhbHVlLFxuICAgICAgICAgICAgICBQaXZvdDogY29sLlBpdm90LFxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gY29sdW1uXG4gICAgICAgIH0pLFxuICAgICAgICBUckNvbXBvbmVudCxcbiAgICAgICAgZ2V0VHJQcm9wcyxcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIDxDb21wb25lbnQgey4uLnJlc3R9IHsuLi5leHRyYX0gcmVmPXtyID0+ICh0aGlzLndyYXBwZWRJbnN0YW5jZSA9IHIpfSAvPlxuICAgIH1cbiAgfVxuICB3cmFwcGVyLmRpc3BsYXlOYW1lID0gJ1JUVHJlZVRhYmxlJ1xuICB3cmFwcGVyLmRlZmF1bHRQcm9wcyA9IHtcbiAgICB0cmVlVGFibGVJbmRlbnQ6IDEwLFxuICB9XG5cbiAgcmV0dXJuIHdyYXBwZXJcbn1cbiJdfQ==