UNPKG

custom-app

Version:

ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������

233 lines (195 loc) 23.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.useSortBy = undefined; 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 _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); var _react = require("react"); var _actions = require("../actions"); var _useTableState = require("./useTableState"); var _utils = require("../utils"); 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); } } _useTableState.defaultState.sortBy = []; (0, _actions.addActions)({ sortByChange: "__sortByChange__" }); var useSortBy = exports.useSortBy = function useSortBy(api) { var debug = api.debug, rows = api.rows, columns = api.columns, _api$orderByFn = api.orderByFn, orderByFn = _api$orderByFn === undefined ? _utils.defaultOrderByFn : _api$orderByFn, _api$sortByFn = api.sortByFn, sortByFn = _api$sortByFn === undefined ? _utils.defaultSortByFn : _api$sortByFn, manualSorting = api.manualSorting, disableSorting = api.disableSorting, defaultSortDesc = api.defaultSortDesc, hooks = api.hooks, _api$state = _slicedToArray(api.state, 2), sortBy = _api$state[0].sortBy, setState = _api$state[1]; columns.forEach(function (column) { var accessor = column.accessor, canSortBy = column.canSortBy; column.canSortBy = accessor ? (0, _utils.getFirstDefined)(canSortBy, disableSorting === true ? false : undefined, true) : false; }); // Updates sorting based on a columnID, desc flag and multi flag var toggleSortByID = function toggleSortByID(columnID, desc, multi) { return setState(function (old) { var sortBy = old.sortBy; // Find the column for this columnID var column = columns.find(function (d) { return d.id === columnID; }); var resolvedDefaultSortDesc = (0, _utils.getFirstDefined)(column.defaultSortDesc, defaultSortDesc); // Find any existing sortBy for this column var existingSortBy = sortBy.find(function (d) { return d.id === columnID; }); var hasDescDefined = typeof desc !== "undefined" && desc !== null; var newSortBy = []; // What should we do with this filter? var action = void 0; if (!multi) { if (sortBy.length <= 1 && existingSortBy) { if (existingSortBy.desc) { action = "remove"; } else { action = "toggle"; } } else { action = "replace"; } } else { if (!existingSortBy) { action = "add"; } else { if (hasDescDefined) { action = "set"; } else { action = "toggle"; } } } if (action === "replace") { newSortBy = [{ id: columnID, desc: hasDescDefined ? desc : resolvedDefaultSortDesc }]; } else if (action === "add") { newSortBy = [].concat(_toConsumableArray(sortBy), [{ id: columnID, desc: hasDescDefined ? desc : resolvedDefaultSortDesc }]); } else if (action === "set") { newSortBy = sortBy.map(function (d) { if (d.id === columnID) { return _extends({}, d, { desc: desc }); } return d; }); } else if (action === "toggle") { newSortBy = sortBy.map(function (d) { if (d.id === columnID) { return _extends({}, d, { desc: !existingSortBy.desc }); } return d; }); } else if (action === "remove") { newSortBy = []; } return _extends({}, old, { sortBy: newSortBy }); }, _actions.actions.sortByChange); }; hooks.columns.push(function (columns) { columns.forEach(function (column) { if (column.canSortBy) { column.toggleSortBy = function (desc, multi) { return toggleSortByID(column.id, desc, multi); }; } }); return columns; }); hooks.getSortByToggleProps = []; var addSortByToggleProps = function addSortByToggleProps(columns, api) { columns.forEach(function (column) { var canSortBy = column.canSortBy; column.getSortByToggleProps = function (props) { return (0, _utils.mergeProps)({ onClick: canSortBy ? function (e) { e.persist(); column.toggleSortBy(undefined, !api.disableMultiSort && e.shiftKey); } : undefined, style: { cursor: canSortBy ? "pointer" : undefined }, title: "Toggle SortBy" }, (0, _utils.applyPropHooks)(api.hooks.getSortByToggleProps, column, api), props); }; }); return columns; }; hooks.columns.push(addSortByToggleProps); hooks.headers.push(addSortByToggleProps); // Mutate columns to reflect sorting state columns.forEach(function (column) { var id = column.id; column.sorted = sortBy.find(function (d) { return d.id === id; }); column.sortedIndex = sortBy.findIndex(function (d) { return d.id === id; }); column.sortedDesc = column.sorted ? column.sorted.desc : undefined; }); var sortedRows = (0, _react.useMemo)(function () { if (manualSorting || !sortBy.length) { return rows; } if (debug) console.info("getSortedRows"); var sortMethodsByColumnID = {}; columns.filter(function (col) { return col.sortMethod; }).forEach(function (col) { sortMethodsByColumnID[col.id] = col.sortMethod; }); var sortData = function sortData(rows) { // Use the orderByFn to compose multiple sortBy's together. // This will also perform a stable sorting using the row index // if needed. var sortedData = orderByFn(rows, sortBy.map(function (sort) { // Support custom sorting methods for each column var columnSortBy = sortMethodsByColumnID[sort.id]; // Return the correct sortFn return function (a, b) { return (columnSortBy ? columnSortBy : sortByFn)(a.values[sort.id], b.values[sort.id], sort.desc); }; }), // Map the directions sortBy.map(function (d) { return !d.desc; })); // TODO: this should be optimized. Not good to loop again sortedData.forEach(function (row) { if (!row.subRows) { return; } row.subRows = sortData(row.subRows); }); return sortedData; }; return sortData(rows); }, [rows, columns, sortBy, manualSorting]); return _extends({}, api, { rows: sortedRows }); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/hooks/useSortBy.js"],"names":["defaultState","sortBy","sortByChange","useSortBy","debug","api","rows","columns","orderByFn","defaultOrderByFn","sortByFn","defaultSortByFn","manualSorting","disableSorting","defaultSortDesc","hooks","state","setState","forEach","accessor","column","canSortBy","undefined","toggleSortByID","columnID","desc","multi","old","find","d","id","resolvedDefaultSortDesc","existingSortBy","hasDescDefined","newSortBy","action","length","map","actions","push","toggleSortBy","getSortByToggleProps","addSortByToggleProps","onClick","e","persist","disableMultiSort","shiftKey","style","cursor","title","props","headers","sorted","sortedIndex","findIndex","sortedDesc","sortedRows","console","info","sortMethodsByColumnID","filter","col","sortMethod","sortData","sortedData","columnSortBy","sort","a","b","values","row","subRows"],"mappings":"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","file":"useSortBy.js","sourcesContent":["import { useMemo } from \"react\";\n\nimport { addActions, actions } from \"../actions\";\nimport { defaultState } from \"./useTableState\";\nimport {\n  mergeProps,\n  applyPropHooks,\n  getFirstDefined,\n  defaultOrderByFn,\n  defaultSortByFn\n} from \"../utils\";\n\ndefaultState.sortBy = [];\n\naddActions({\n  sortByChange: \"__sortByChange__\"\n});\n\nexport const useSortBy = api => {\n  const {\n    debug,\n    rows,\n    columns,\n    orderByFn = defaultOrderByFn,\n    sortByFn = defaultSortByFn,\n    manualSorting,\n    disableSorting,\n    defaultSortDesc,\n    hooks,\n    state: [{ sortBy }, setState]\n  } = api;\n\n  columns.forEach(column => {\n    const { accessor, canSortBy } = column;\n    column.canSortBy = accessor\n      ? getFirstDefined(\n          canSortBy,\n          disableSorting === true ? false : undefined,\n          true\n        )\n      : false;\n  });\n\n  // Updates sorting based on a columnID, desc flag and multi flag\n  const toggleSortByID = (columnID, desc, multi) => {\n    return setState(old => {\n      const { sortBy } = old;\n\n      // Find the column for this columnID\n      const column = columns.find(d => d.id === columnID);\n      const resolvedDefaultSortDesc = getFirstDefined(\n        column.defaultSortDesc,\n        defaultSortDesc\n      );\n\n      // Find any existing sortBy for this column\n      const existingSortBy = sortBy.find(d => d.id === columnID);\n      const hasDescDefined = typeof desc !== \"undefined\" && desc !== null;\n\n      let newSortBy = [];\n\n      // What should we do with this filter?\n      let action;\n\n      if (!multi) {\n        if (sortBy.length <= 1 && existingSortBy) {\n          if (existingSortBy.desc) {\n            action = \"remove\";\n          } else {\n            action = \"toggle\";\n          }\n        } else {\n          action = \"replace\";\n        }\n      } else {\n        if (!existingSortBy) {\n          action = \"add\";\n        } else {\n          if (hasDescDefined) {\n            action = \"set\";\n          } else {\n            action = \"toggle\";\n          }\n        }\n      }\n\n      if (action === \"replace\") {\n        newSortBy = [\n          {\n            id: columnID,\n            desc: hasDescDefined ? desc : resolvedDefaultSortDesc\n          }\n        ];\n      } else if (action === \"add\") {\n        newSortBy = [\n          ...sortBy,\n          {\n            id: columnID,\n            desc: hasDescDefined ? desc : resolvedDefaultSortDesc\n          }\n        ];\n      } else if (action === \"set\") {\n        newSortBy = sortBy.map(d => {\n          if (d.id === columnID) {\n            return {\n              ...d,\n              desc\n            };\n          }\n          return d;\n        });\n      } else if (action === \"toggle\") {\n        newSortBy = sortBy.map(d => {\n          if (d.id === columnID) {\n            return {\n              ...d,\n              desc: !existingSortBy.desc\n            };\n          }\n          return d;\n        });\n      } else if (action === \"remove\") {\n        newSortBy = [];\n      }\n\n      return {\n        ...old,\n        sortBy: newSortBy\n      };\n    }, actions.sortByChange);\n  };\n\n  hooks.columns.push(columns => {\n    columns.forEach(column => {\n      if (column.canSortBy) {\n        column.toggleSortBy = (desc, multi) =>\n          toggleSortByID(column.id, desc, multi);\n      }\n    });\n    return columns;\n  });\n\n  hooks.getSortByToggleProps = [];\n\n  const addSortByToggleProps = (columns, api) => {\n    columns.forEach(column => {\n      const { canSortBy } = column;\n      column.getSortByToggleProps = props => {\n        return mergeProps(\n          {\n            onClick: canSortBy\n              ? e => {\n                  e.persist();\n                  column.toggleSortBy(\n                    undefined,\n                    !api.disableMultiSort && e.shiftKey\n                  );\n                }\n              : undefined,\n            style: {\n              cursor: canSortBy ? \"pointer\" : undefined\n            },\n            title: \"Toggle SortBy\"\n          },\n          applyPropHooks(api.hooks.getSortByToggleProps, column, api),\n          props\n        );\n      };\n    });\n    return columns;\n  };\n\n  hooks.columns.push(addSortByToggleProps);\n  hooks.headers.push(addSortByToggleProps);\n\n  // Mutate columns to reflect sorting state\n  columns.forEach(column => {\n    const { id } = column;\n    column.sorted = sortBy.find(d => d.id === id);\n    column.sortedIndex = sortBy.findIndex(d => d.id === id);\n    column.sortedDesc = column.sorted ? column.sorted.desc : undefined;\n  });\n\n  const sortedRows = useMemo(\n    () => {\n      if (manualSorting || !sortBy.length) {\n        return rows;\n      }\n      if (debug) console.info(\"getSortedRows\");\n\n      const sortMethodsByColumnID = {};\n\n      columns\n        .filter(col => col.sortMethod)\n        .forEach(col => {\n          sortMethodsByColumnID[col.id] = col.sortMethod;\n        });\n\n      const sortData = rows => {\n        // Use the orderByFn to compose multiple sortBy's together.\n        // This will also perform a stable sorting using the row index\n        // if needed.\n        const sortedData = orderByFn(\n          rows,\n          sortBy.map(sort => {\n            // Support custom sorting methods for each column\n            const columnSortBy = sortMethodsByColumnID[sort.id];\n\n            // Return the correct sortFn\n            return (a, b) =>\n              (columnSortBy ? columnSortBy : sortByFn)(\n                a.values[sort.id],\n                b.values[sort.id],\n                sort.desc\n              );\n          }),\n          // Map the directions\n          sortBy.map(d => !d.desc)\n        );\n\n        // TODO: this should be optimized. Not good to loop again\n        sortedData.forEach(row => {\n          if (!row.subRows) {\n            return;\n          }\n          row.subRows = sortData(row.subRows);\n        });\n\n        return sortedData;\n      };\n\n      return sortData(rows);\n    },\n    [rows, columns, sortBy, manualSorting]\n  );\n\n  return {\n    ...api,\n    rows: sortedRows\n  };\n};\n"]}