UNPKG

custom-app

Version:

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

152 lines (125 loc) 14.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.usePagination = 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 _propTypes = require("prop-types"); var _propTypes2 = _interopRequireDefault(_propTypes); var _actions = require("../actions"); var _useTableState = require("./useTableState"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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.pageSize = 10; _useTableState.defaultState.pageIndex = 0; (0, _actions.addActions)({ pageChange: "__pageChange__" }); var propTypes = { defaultPageSize: _propTypes2.default.number, defaultPageIndex: _propTypes2.default.number, pageSize: _propTypes2.default.number, pages: _propTypes2.default.number, pageIndex: _propTypes2.default.number, onStateChange: _propTypes2.default.func, stateReducer: _propTypes2.default.func, debug: _propTypes2.default.bool }; var usePagination = exports.usePagination = function usePagination(props) { // Validate props _propTypes2.default.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]; (0, _react.useLayoutEffect)(function () { setState(function (old) { return _extends({}, old, { pageIndex: 0 }); }, _actions.actions.pageChange); }, [filters, groupBy, sortBy]); var _useMemo = (0, _react.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.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.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":["defaultState","pageSize","pageIndex","pageChange","propTypes","defaultPageSize","PropTypes","number","defaultPageIndex","pages","onStateChange","func","stateReducer","debug","bool","usePagination","checkPropTypes","props","parentDebug","rows","manualPagination","state","userPageCount","pageCount","filters","groupBy","sortBy","setState","old","actions","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"]}