custom-app
Version:
ITIMS��Ʒ�鿪��ר��React���,�Dz��ý��ּ�dhcc-app���������
139 lines (118 loc) • 13.8 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, useState, useLayoutEffect } from "react";
import PropTypes from "prop-types";
import { addActions, actions } from "../actions";
import { defaultState } from "./useTableState";
defaultState.pageSize = 10;
defaultState.pageIndex = 0;
addActions({
pageChange: "__pageChange__"
});
var propTypes = {
defaultPageSize: PropTypes.number,
defaultPageIndex: PropTypes.number,
pageSize: PropTypes.number,
pages: PropTypes.number,
pageIndex: PropTypes.number,
onStateChange: PropTypes.func,
stateReducer: PropTypes.func,
debug: PropTypes.bool
};
export var usePagination = function usePagination(props) {
// Validate props
PropTypes.checkPropTypes(propTypes, props, "property", "usePagination");
var parentDebug = props.debug,
rows = props.rows,
manualPagination = props.manualPagination,
_props$debug = props.debug,
debug = _props$debug === undefined ? parentDebug : _props$debug,
_props$state = _slicedToArray(props.state, 2),
_props$state$ = _props$state[0],
pageSize = _props$state$.pageSize,
pageIndex = _props$state$.pageIndex,
userPageCount = _props$state$.pageCount,
filters = _props$state$.filters,
groupBy = _props$state$.groupBy,
sortBy = _props$state$.sortBy,
setState = _props$state[1];
useLayoutEffect(function () {
setState(function (old) {
return _extends({}, old, {
pageIndex: 0
});
}, actions.pageChange);
}, [filters, groupBy, sortBy]);
var _useMemo = useMemo(function () {
if (manualPagination) {
return {
pages: [rows],
pageCount: userPageCount
};
}
if (debug) console.info("getPages");
// Create a new pages with the first page ready to go.
var pages = rows.length ? [] : [[]];
// Start the pageIndex and currentPage cursors
var cursor = 0;
while (cursor < rows.length) {
var end = cursor + pageSize;
pages.push(rows.slice(cursor, end));
cursor = end;
}
var pageCount = pages.length;
return {
pages: pages,
pageCount: pageCount,
pageOptions: pageOptions
};
}, [rows, pageSize, userPageCount]),
pages = _useMemo.pages,
pageCount = _useMemo.pageCount;
var pageOptions = [].concat(_toConsumableArray(new Array(pageCount))).map(function (d, i) {
return i;
});
var page = manualPagination ? rows : pages[pageIndex] || [];
var canPreviousPage = pageIndex > 0;
var canNextPage = pageIndex < pageCount - 1;
var gotoPage = function gotoPage(pageIndex) {
if (debug) console.info("gotoPage");
return setState(function (old) {
if (pageIndex < 0 || pageIndex > pageCount - 1) {
return old;
}
return _extends({}, old, {
pageIndex: pageIndex
});
}, actions.pageChange);
};
var previousPage = function previousPage() {
return gotoPage(pageIndex - 1);
};
var nextPage = function nextPage() {
return gotoPage(pageIndex + 1);
};
var setPageSize = function setPageSize(pageSize) {
setState(function (old) {
var topRowIndex = old.pageSize * old.pageIndex;
var pageIndex = Math.floor(topRowIndex / pageSize);
return _extends({}, old, {
pageIndex: pageIndex,
pageSize: pageSize
});
}, actions.setPageSize);
};
return _extends({}, props, {
pages: pages,
pageOptions: pageOptions,
page: page,
canPreviousPage: canPreviousPage,
canNextPage: canNextPage,
gotoPage: gotoPage,
previousPage: previousPage,
nextPage: nextPage,
setPageSize: setPageSize
});
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/hooks/usePagination.js"],"names":["useMemo","useState","useLayoutEffect","PropTypes","addActions","actions","defaultState","pageSize","pageIndex","pageChange","propTypes","defaultPageSize","number","defaultPageIndex","pages","onStateChange","func","stateReducer","debug","bool","usePagination","checkPropTypes","props","parentDebug","rows","manualPagination","state","userPageCount","pageCount","filters","groupBy","sortBy","setState","old","console","info","length","cursor","end","push","slice","pageOptions","Array","map","d","i","page","canPreviousPage","canNextPage","gotoPage","previousPage","nextPage","setPageSize","topRowIndex","Math","floor"],"mappings":"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","file":"usePagination.js","sourcesContent":["import { useMemo, useState, useLayoutEffect } from \"react\";\nimport PropTypes from \"prop-types\";\n\nimport { addActions, actions } from \"../actions\";\nimport { defaultState } from \"./useTableState\";\n\ndefaultState.pageSize = 10;\ndefaultState.pageIndex = 0;\n\naddActions({\n  pageChange: \"__pageChange__\"\n});\n\nconst propTypes = {\n  defaultPageSize: PropTypes.number,\n  defaultPageIndex: PropTypes.number,\n  pageSize: PropTypes.number,\n  pages: PropTypes.number,\n  pageIndex: PropTypes.number,\n  onStateChange: PropTypes.func,\n  stateReducer: PropTypes.func,\n  debug: PropTypes.bool\n};\n\nexport const usePagination = props => {\n  // Validate props\n  PropTypes.checkPropTypes(propTypes, props, \"property\", \"usePagination\");\n\n  const {\n    debug: parentDebug,\n    rows,\n    manualPagination,\n    debug = parentDebug,\n    state: [\n      {\n        pageSize,\n        pageIndex,\n        pageCount: userPageCount,\n        filters,\n        groupBy,\n        sortBy\n      },\n      setState\n    ]\n  } = props;\n\n  useLayoutEffect(\n    () => {\n      setState(\n        old => ({\n          ...old,\n          pageIndex: 0\n        }),\n        actions.pageChange\n      );\n    },\n    [filters, groupBy, sortBy]\n  );\n\n  const { pages, pageCount } = useMemo(\n    () => {\n      if (manualPagination) {\n        return {\n          pages: [rows],\n          pageCount: userPageCount\n        };\n      }\n      if (debug) console.info(\"getPages\");\n\n      // Create a new pages with the first page ready to go.\n      const pages = rows.length ? [] : [[]];\n\n      // Start the pageIndex and currentPage cursors\n      let cursor = 0;\n      while (cursor < rows.length) {\n        const end = cursor + pageSize;\n        pages.push(rows.slice(cursor, end));\n        cursor = end;\n      }\n\n      const pageCount = pages.length;\n\n      return {\n        pages,\n        pageCount,\n        pageOptions\n      };\n    },\n    [rows, pageSize, userPageCount]\n  );\n\n  const pageOptions = [...new Array(pageCount)].map((d, i) => i);\n  const page = manualPagination ? rows : pages[pageIndex] || [];\n  const canPreviousPage = pageIndex > 0;\n  const canNextPage = pageIndex < pageCount - 1;\n\n  const gotoPage = pageIndex => {\n    if (debug) console.info(\"gotoPage\");\n    return setState(old => {\n      if (pageIndex < 0 || pageIndex > pageCount - 1) {\n        return old;\n      }\n      return {\n        ...old,\n        pageIndex\n      };\n    }, actions.pageChange);\n  };\n\n  const previousPage = () => {\n    return gotoPage(pageIndex - 1);\n  };\n\n  const nextPage = () => {\n    return gotoPage(pageIndex + 1);\n  };\n\n  const setPageSize = pageSize => {\n    setState(old => {\n      const topRowIndex = old.pageSize * old.pageIndex;\n      const pageIndex = Math.floor(topRowIndex / pageSize);\n      return {\n        ...old,\n        pageIndex,\n        pageSize\n      };\n    }, actions.setPageSize);\n  };\n\n  return {\n    ...props,\n    pages,\n    pageOptions,\n    page,\n    canPreviousPage,\n    canNextPage,\n    gotoPage,\n    previousPage,\n    nextPage,\n    setPageSize\n  };\n};\n"]}