custom-app
Version:
ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������
233 lines (195 loc) • 23.8 kB
JavaScript
;
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"]}