UNPKG

linkmore-design

Version:

🌈 πŸš€lmη»„δ»ΆεΊ“γ€‚πŸš€

81 lines (78 loc) β€’ 2.52 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.DEFAULT_PAGE_SIZE = void 0; exports.default = usePagination; exports.getPaginationParam = getPaginationParam; var _react = require("react"); const DEFAULT_PAGE_SIZE = 10; exports.DEFAULT_PAGE_SIZE = DEFAULT_PAGE_SIZE; function getPaginationParam(pagination, mergedPagination) { const param = { current: mergedPagination.current, pageSize: mergedPagination.pageSize }; const paginationObj = pagination && typeof pagination === 'object' ? pagination : {}; Object.keys(paginationObj).forEach(pageProp => { const value = mergedPagination[pageProp]; if (typeof value !== 'function') { param[pageProp] = value; } }); return param; } function extendsObject(...list) { const result = {}; list.forEach(obj => { if (obj) { Object.keys(obj).forEach(key => { const val = obj[key]; if (val !== undefined) { result[key] = val; } }); } }); return result; } function usePagination(total, pagination, onChange) { const { total: paginationTotal = 0, ...paginationObj } = pagination && typeof pagination === 'object' ? pagination : {}; const [innerPagination, setInnerPagination] = (0, _react.useState)(() => ({ current: 'defaultCurrent' in paginationObj ? paginationObj.defaultCurrent : 1, pageSize: 'defaultPageSize' in paginationObj ? paginationObj.defaultPageSize : DEFAULT_PAGE_SIZE })); // ============ Basic Pagination Config ============ const mergedPagination = extendsObject(innerPagination, paginationObj, { total: paginationTotal > 0 ? paginationTotal : total }); // Reset `current` if data length or pageSize changed const maxPage = Math.ceil((paginationTotal || total) / mergedPagination.pageSize); if (mergedPagination.current > maxPage) { // Prevent a maximum page count of 0 mergedPagination.current = maxPage || 1; } const refreshPagination = (current, pageSize) => { setInnerPagination({ current: current ?? 1, pageSize: pageSize || mergedPagination.pageSize }); }; const onInternalChange = (current, pageSize) => { if (pagination) { pagination.onChange?.(current, pageSize); } refreshPagination(current, pageSize); onChange(current, pageSize || mergedPagination?.pageSize); }; if (pagination === false) { return [{}, () => {}]; } return [{ ...mergedPagination, onChange: onInternalChange }, refreshPagination]; }