custom-app
Version:
ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������
224 lines (190 loc) • 23.9 kB
JavaScript
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"); } }; }();
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); } }
import { useMemo } from "react";
import { addActions, actions } from "../actions";
import { defaultState } from "./useTableState";
import { mergeProps, applyPropHooks, getFirstDefined, defaultOrderByFn, defaultSortByFn } from "../utils";
defaultState.sortBy = [];
addActions({
sortByChange: "__sortByChange__"
});
export var useSortBy = function useSortBy(api) {
var debug = api.debug,
rows = api.rows,
columns = api.columns,
_api$orderByFn = api.orderByFn,
orderByFn = _api$orderByFn === undefined ? defaultOrderByFn : _api$orderByFn,
_api$sortByFn = api.sortByFn,
sortByFn = _api$sortByFn === undefined ? 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 ? 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 = 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.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 mergeProps({
onClick: canSortBy ? function (e) {
e.persist();
column.toggleSortBy(undefined, !api.disableMultiSort && e.shiftKey);
} : undefined,
style: {
cursor: canSortBy ? "pointer" : undefined
},
title: "Toggle SortBy"
}, 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 = 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":["useMemo","addActions","actions","defaultState","mergeProps","applyPropHooks","getFirstDefined","defaultOrderByFn","defaultSortByFn","sortBy","sortByChange","useSortBy","debug","api","rows","columns","orderByFn","sortByFn","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","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"]}