@elliemae/ds-pagination 3.16.0-next.2 → 3.16.0-next.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/DSPaginationDefinitions.js +17 -1
- package/dist/cjs/DSPaginationDefinitions.js.map +2 -2
- package/dist/cjs/Pagination.js +11 -7
- package/dist/cjs/Pagination.js.map +2 -2
- package/dist/cjs/PaginationDataTestID.js +7 -1
- package/dist/cjs/PaginationDataTestID.js.map +2 -2
- package/dist/cjs/index.js +36 -2
- package/dist/cjs/index.js.map +3 -3
- package/dist/cjs/package.json +7 -0
- package/dist/cjs/parts/DSPageNextButton.js +74 -0
- package/dist/cjs/parts/DSPageNextButton.js.map +7 -0
- package/dist/cjs/parts/DSPagePrevButton.js +74 -0
- package/dist/cjs/parts/DSPagePrevButton.js.map +7 -0
- package/dist/cjs/parts/DSPaginationContainer.js +61 -0
- package/dist/cjs/parts/DSPaginationContainer.js.map +7 -0
- package/dist/cjs/parts/DSPaginator/createPaginatorHeader.js +50 -0
- package/dist/cjs/parts/DSPaginator/createPaginatorHeader.js.map +7 -0
- package/dist/cjs/parts/DSPaginator/getOptions.js +76 -0
- package/dist/cjs/parts/DSPaginator/getOptions.js.map +7 -0
- package/dist/cjs/parts/DSPaginator/index.js +148 -0
- package/dist/cjs/parts/DSPaginator/index.js.map +7 -0
- package/dist/cjs/{hooks → parts/DSPaginator}/usePaginationSearch.js +9 -2
- package/dist/cjs/parts/DSPaginator/usePaginationSearch.js.map +7 -0
- package/dist/cjs/parts/DSPaginator/usePaginator.js +91 -0
- package/dist/cjs/parts/DSPaginator/usePaginator.js.map +7 -0
- package/dist/cjs/parts/{PagePrevButton.js → DSPerPageSelector/getOptions.js} +25 -22
- package/dist/cjs/parts/DSPerPageSelector/getOptions.js.map +7 -0
- package/dist/cjs/parts/DSPerPageSelector/index.js +106 -0
- package/dist/cjs/parts/DSPerPageSelector/index.js.map +7 -0
- package/dist/cjs/parts/DSPerPageSelector/usePerPageSelector.js +72 -0
- package/dist/cjs/parts/DSPerPageSelector/usePerPageSelector.js.map +7 -0
- package/dist/cjs/parts/PaginationContent.js +41 -52
- package/dist/cjs/parts/PaginationContent.js.map +3 -3
- package/dist/cjs/parts/index.js +49 -0
- package/dist/cjs/parts/index.js.map +7 -0
- package/dist/cjs/props.js +85 -0
- package/dist/cjs/props.js.map +7 -0
- package/dist/cjs/react-desc-prop-types.js +111 -33
- package/dist/cjs/react-desc-prop-types.js.map +2 -2
- package/dist/cjs/styled.js +21 -27
- package/dist/cjs/styled.js.map +2 -2
- package/dist/esm/DSPaginationDefinitions.js +13 -1
- package/dist/esm/DSPaginationDefinitions.js.map +2 -2
- package/dist/esm/Pagination.js +4 -4
- package/dist/esm/Pagination.js.map +1 -1
- package/dist/esm/PaginationDataTestID.js +3 -1
- package/dist/esm/PaginationDataTestID.js.map +2 -2
- package/dist/esm/index.js +39 -1
- package/dist/esm/index.js.map +3 -3
- package/dist/esm/package.json +7 -0
- package/dist/esm/parts/DSPageNextButton.js +50 -0
- package/dist/esm/parts/DSPageNextButton.js.map +7 -0
- package/dist/esm/parts/DSPagePrevButton.js +50 -0
- package/dist/esm/parts/DSPagePrevButton.js.map +7 -0
- package/dist/esm/parts/DSPaginationContainer.js +31 -0
- package/dist/esm/parts/DSPaginationContainer.js.map +7 -0
- package/dist/esm/parts/DSPaginator/createPaginatorHeader.js +20 -0
- package/dist/esm/parts/DSPaginator/createPaginatorHeader.js.map +7 -0
- package/dist/esm/parts/DSPaginator/getOptions.js +46 -0
- package/dist/esm/parts/DSPaginator/getOptions.js.map +7 -0
- package/dist/esm/parts/DSPaginator/index.js +118 -0
- package/dist/esm/parts/DSPaginator/index.js.map +7 -0
- package/dist/esm/{hooks → parts/DSPaginator}/usePaginationSearch.js +5 -2
- package/dist/esm/parts/DSPaginator/usePaginationSearch.js.map +7 -0
- package/dist/esm/parts/DSPaginator/usePaginator.js +61 -0
- package/dist/esm/parts/DSPaginator/usePaginator.js.map +7 -0
- package/dist/esm/parts/DSPerPageSelector/getOptions.js +22 -0
- package/dist/esm/parts/DSPerPageSelector/getOptions.js.map +7 -0
- package/dist/esm/parts/DSPerPageSelector/index.js +76 -0
- package/dist/esm/parts/DSPerPageSelector/index.js.map +7 -0
- package/dist/esm/parts/DSPerPageSelector/usePerPageSelector.js +42 -0
- package/dist/esm/parts/DSPerPageSelector/usePerPageSelector.js.map +7 -0
- package/dist/esm/parts/PaginationContent.js +37 -52
- package/dist/esm/parts/PaginationContent.js.map +2 -2
- package/dist/esm/parts/index.js +19 -0
- package/dist/esm/parts/index.js.map +7 -0
- package/dist/esm/props.js +55 -0
- package/dist/esm/props.js.map +7 -0
- package/dist/esm/react-desc-prop-types.js +88 -14
- package/dist/esm/react-desc-prop-types.js.map +2 -2
- package/dist/esm/styled.js +15 -25
- package/dist/esm/styled.js.map +2 -2
- package/dist/types/DSPaginationDefinitions.d.ts +6 -0
- package/dist/types/Pagination.d.ts +2 -2
- package/dist/types/PaginationDataTestID.d.ts +2 -0
- package/dist/types/index.d.ts +17 -1
- package/dist/types/parts/DSPageNextButton.d.ts +4 -0
- package/dist/types/parts/DSPagePrevButton.d.ts +4 -0
- package/dist/types/parts/DSPaginationContainer.d.ts +4 -0
- package/dist/types/parts/DSPaginator/createPaginatorHeader.d.ts +6 -0
- package/dist/types/parts/DSPaginator/getOptions.d.ts +7 -0
- package/dist/types/parts/DSPaginator/index.d.ts +4 -0
- package/dist/types/parts/DSPaginator/usePaginationSearch.d.ts +2 -0
- package/dist/types/parts/DSPaginator/usePaginator.d.ts +17 -0
- package/dist/types/parts/DSPerPageSelector/getOptions.d.ts +3 -0
- package/dist/types/parts/DSPerPageSelector/index.d.ts +4 -0
- package/dist/types/parts/DSPerPageSelector/usePerPageSelector.d.ts +13 -0
- package/dist/types/parts/PaginationContent.d.ts +1 -1
- package/dist/types/parts/index.d.ts +5 -0
- package/dist/types/props.d.ts +20 -0
- package/dist/types/react-desc-prop-types.d.ts +528 -9
- package/dist/types/styled.d.ts +7 -9
- package/dist/types/tests/a11y/axe.test.d.ts +1 -0
- package/dist/types/tests/callbacks/paginator.test.d.ts +1 -0
- package/dist/types/tests/callbacks/per-page-selector.test.d.ts +1 -0
- package/dist/types/tests/callbacks/prev-next-buttons.test.d.ts +1 -0
- package/dist/types/tests/keyboard/navigation.test.d.ts +1 -0
- package/dist/types/tests/keyboard/paginator-search.test.d.ts +1 -0
- package/dist/types/tests/render/page-count-loading.test.d.ts +1 -0
- package/dist/types/tests/render/paginator.test.d.ts +1 -0
- package/dist/types/tests/render/per-page-selector.test.d.ts +1 -0
- package/dist/types/tests/render/segmented-paginator.test.d.ts +1 -0
- package/dist/types/tests/render/simple.render.test.d.ts +1 -0
- package/package.json +18 -12
- package/dist/cjs/hooks/usePaginationSearch.js.map +0 -7
- package/dist/cjs/parts/PageNextButton.js +0 -52
- package/dist/cjs/parts/PageNextButton.js.map +0 -7
- package/dist/cjs/parts/PagePrevButton.js.map +0 -7
- package/dist/cjs/parts/Paginator.js +0 -162
- package/dist/cjs/parts/Paginator.js.map +0 -7
- package/dist/cjs/parts/PerPageSelector.js +0 -114
- package/dist/cjs/parts/PerPageSelector.js.map +0 -7
- package/dist/esm/hooks/usePaginationSearch.js.map +0 -7
- package/dist/esm/parts/PageNextButton.js +0 -26
- package/dist/esm/parts/PageNextButton.js.map +0 -7
- package/dist/esm/parts/PagePrevButton.js +0 -23
- package/dist/esm/parts/PagePrevButton.js.map +0 -7
- package/dist/esm/parts/Paginator.js +0 -136
- package/dist/esm/parts/Paginator.js.map +0 -7
- package/dist/esm/parts/PerPageSelector.js +0 -88
- package/dist/esm/parts/PerPageSelector.js.map +0 -7
- package/dist/types/hooks/usePaginationSearch.d.ts +0 -1
- package/dist/types/parts/PageNextButton.d.ts +0 -3
- package/dist/types/parts/PagePrevButton.d.ts +0 -3
- package/dist/types/parts/Paginator.d.ts +0 -11
- package/dist/types/parts/PerPageSelector.d.ts +0 -4
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { useEffect, useLayoutEffect, useMemo, useRef, useState } from "react";
|
|
4
|
-
import { Checkmark, ChevronDown } from "@elliemae/ds-icons";
|
|
5
|
-
import { useOnElementResize } from "@elliemae/ds-utilities";
|
|
6
|
-
import { Grid } from "@elliemae/ds-grid";
|
|
7
|
-
import { DSDropdownMenuV2 } from "@elliemae/ds-dropdownmenu";
|
|
8
|
-
import { SimpleTruncatedTooltipText } from "@elliemae/ds-truncated-tooltip-text";
|
|
9
|
-
import { DSCircularIndeterminateIndicator } from "@elliemae/ds-circular-progress-indicator";
|
|
10
|
-
import { InvisibleDetail, PaginationBoldText, PaginationDropdownButton, PaginationSeparator } from "../styled";
|
|
11
|
-
import { usePaginationSearch } from "../hooks/usePaginationSearch";
|
|
12
|
-
const Paginator = (props) => {
|
|
13
|
-
const { pageIndex, pageCount, isLoadingPageCount, onPageChange, pageDetails, pageDetailsTitle } = props;
|
|
14
|
-
const [isOpened, setIsOpened] = useState(false);
|
|
15
|
-
const btnRef = useRef(null);
|
|
16
|
-
const pageInfoRef = useRef(null);
|
|
17
|
-
const { width: btnWidth } = useOnElementResize(btnRef);
|
|
18
|
-
const { width: txtWidth } = useOnElementResize(pageInfoRef);
|
|
19
|
-
const options = useMemo(
|
|
20
|
-
() => new Array(typeof pageCount === "string" ? pageIndex + 1 : pageCount).fill(0).map((_, index) => {
|
|
21
|
-
const option = {
|
|
22
|
-
dsId: (index + 1).toString(),
|
|
23
|
-
label: (index + 1).toString(),
|
|
24
|
-
value: index + 1,
|
|
25
|
-
type: "single"
|
|
26
|
-
};
|
|
27
|
-
if (pageDetails?.length) {
|
|
28
|
-
option.render = () => /* @__PURE__ */ jsxs(Grid, { cols: ["16px", `${txtWidth + 16}px`, "auto"], gutter: "xxs", alignItems: "center", children: [
|
|
29
|
-
pageIndex === index ? /* @__PURE__ */ jsx(Checkmark, { size: "s", color: ["brand-primary", "600"] }) : /* @__PURE__ */ jsx("div", {}),
|
|
30
|
-
/* @__PURE__ */ jsx("span", { children: index + 1 }),
|
|
31
|
-
/* @__PURE__ */ jsx(
|
|
32
|
-
"span",
|
|
33
|
-
{
|
|
34
|
-
style: {
|
|
35
|
-
whiteSpace: "nowrap",
|
|
36
|
-
textOverflow: "ellipsis",
|
|
37
|
-
overflow: "hidden"
|
|
38
|
-
},
|
|
39
|
-
children: pageDetails[index]
|
|
40
|
-
}
|
|
41
|
-
)
|
|
42
|
-
] });
|
|
43
|
-
}
|
|
44
|
-
return option;
|
|
45
|
-
}),
|
|
46
|
-
[pageCount, pageDetails, pageIndex, txtWidth]
|
|
47
|
-
);
|
|
48
|
-
const actionRef = useRef({});
|
|
49
|
-
useEffect(() => {
|
|
50
|
-
if (isOpened) {
|
|
51
|
-
actionRef.current.setActiveDescendant((pageIndex + 1).toString());
|
|
52
|
-
actionRef.current.scrollOptionIntoView((pageIndex + 1).toString());
|
|
53
|
-
}
|
|
54
|
-
}, [isOpened]);
|
|
55
|
-
const [detailWidth, setDetailWidth] = useState(0);
|
|
56
|
-
useLayoutEffect(() => {
|
|
57
|
-
const invisibleDetails = [
|
|
58
|
-
...document.body.querySelectorAll('[data-testid="ds-pagination-invisible-detail-for-width-calc"]')
|
|
59
|
-
];
|
|
60
|
-
const maxWidth = invisibleDetails.reduce((acc, cur) => Math.max(acc, cur.getBoundingClientRect().width), 0);
|
|
61
|
-
setDetailWidth(maxWidth);
|
|
62
|
-
}, [pageDetails]);
|
|
63
|
-
const onKeyDown = usePaginationSearch(pageCount, actionRef);
|
|
64
|
-
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
65
|
-
/* @__PURE__ */ jsx(PaginationSeparator, {}),
|
|
66
|
-
/* @__PURE__ */ jsx(
|
|
67
|
-
DSDropdownMenuV2,
|
|
68
|
-
{
|
|
69
|
-
isOpened,
|
|
70
|
-
options,
|
|
71
|
-
selectedOptions: { [(pageIndex + 1).toString()]: true },
|
|
72
|
-
onOptionClick: (_, clickedOption) => {
|
|
73
|
-
onPageChange(clickedOption.value);
|
|
74
|
-
setIsOpened(false);
|
|
75
|
-
btnRef.current?.focus();
|
|
76
|
-
},
|
|
77
|
-
onClickOutside: () => {
|
|
78
|
-
setIsOpened(false);
|
|
79
|
-
btnRef.current?.focus();
|
|
80
|
-
},
|
|
81
|
-
customOffset: [-23, 2],
|
|
82
|
-
startPlacementPreference: "top-start",
|
|
83
|
-
actionRef,
|
|
84
|
-
onKeyDown,
|
|
85
|
-
minWidth: pageDetails.length !== 0 ? btnWidth + 23 : pageCount.toString().length * 6 + 90,
|
|
86
|
-
maxHeight: 300,
|
|
87
|
-
HeaderComp: () => pageDetailsTitle !== "" ? /* @__PURE__ */ jsxs(Grid, { cols: [`${txtWidth + 50}px`, "8px", "auto"], children: [
|
|
88
|
-
/* @__PURE__ */ jsx("span", { style: { marginLeft: "8px" }, children: "Page" }),
|
|
89
|
-
/* @__PURE__ */ jsx(PaginationSeparator, { height: "100%" }),
|
|
90
|
-
/* @__PURE__ */ jsx("span", { children: pageDetailsTitle })
|
|
91
|
-
] }) : "Page",
|
|
92
|
-
children: /* @__PURE__ */ jsx(
|
|
93
|
-
PaginationDropdownButton,
|
|
94
|
-
{
|
|
95
|
-
buttonType: "raw",
|
|
96
|
-
disabled: isLoadingPageCount,
|
|
97
|
-
onClick: () => setIsOpened((prev) => !prev),
|
|
98
|
-
innerRef: btnRef,
|
|
99
|
-
"aria-label": `Page ${pageIndex + 1} out of ${pageCount}, ${pageDetails.length !== 0 ? pageDetails[pageIndex] : "\b\b"}. Press to change the current page`,
|
|
100
|
-
children: /* @__PURE__ */ jsxs(
|
|
101
|
-
Grid,
|
|
102
|
-
{
|
|
103
|
-
gutter: "xxs",
|
|
104
|
-
alignItems: "center",
|
|
105
|
-
cols: pageDetails.length !== 0 ? ["auto", "min-content", "minmax(0px, 70%)", "min-content"] : ["auto", "min-content"],
|
|
106
|
-
children: [
|
|
107
|
-
/* @__PURE__ */ jsxs(Grid, { alignItems: "center", gutter: "xxxs", ref: pageInfoRef, style: { gridAutoFlow: "column" }, children: [
|
|
108
|
-
/* @__PURE__ */ jsx(PaginationBoldText, { fontSize: "18px", children: pageIndex + 1 }),
|
|
109
|
-
" / ",
|
|
110
|
-
pageCount
|
|
111
|
-
] }),
|
|
112
|
-
isLoadingPageCount ? /* @__PURE__ */ jsx(DSCircularIndeterminateIndicator, { size: "xs" }) : /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
113
|
-
pageDetails.length !== 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
114
|
-
/* @__PURE__ */ jsx(PaginationSeparator, { height: "12px", ml: "8px" }),
|
|
115
|
-
/* @__PURE__ */ jsxs(PaginationBoldText, { fontSize: "13px", w: detailWidth, mr: "xxs", display: "grid", children: [
|
|
116
|
-
/* @__PURE__ */ jsx(SimpleTruncatedTooltipText, { value: pageDetails[pageIndex], children: pageDetails[pageIndex] }),
|
|
117
|
-
pageDetails.map((pageDetail) => /* @__PURE__ */ jsx(InvisibleDetail, { "data-testid": "ds-pagination-invisible-detail-for-width-calc", children: pageDetail }))
|
|
118
|
-
] })
|
|
119
|
-
] }),
|
|
120
|
-
/* @__PURE__ */ jsx(ChevronDown, { color: ["brand-primary", "700"] })
|
|
121
|
-
] })
|
|
122
|
-
]
|
|
123
|
-
}
|
|
124
|
-
)
|
|
125
|
-
}
|
|
126
|
-
)
|
|
127
|
-
}
|
|
128
|
-
),
|
|
129
|
-
/* @__PURE__ */ jsx(PaginationSeparator, {})
|
|
130
|
-
] });
|
|
131
|
-
};
|
|
132
|
-
var Paginator_default = Paginator;
|
|
133
|
-
export {
|
|
134
|
-
Paginator_default as default
|
|
135
|
-
};
|
|
136
|
-
//# sourceMappingURL=Paginator.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/parts/Paginator.tsx"],
|
|
4
|
-
"sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable react/prop-types */\nimport React, { useEffect, useLayoutEffect, useMemo, useRef, useState } from 'react';\nimport { Checkmark, ChevronDown } from '@elliemae/ds-icons';\nimport { useOnElementResize } from '@elliemae/ds-utilities';\nimport { Grid } from '@elliemae/ds-grid';\nimport { DSDropdownMenuV2 } from '@elliemae/ds-dropdownmenu';\nimport { SimpleTruncatedTooltipText } from '@elliemae/ds-truncated-tooltip-text';\nimport { DSCircularIndeterminateIndicator } from '@elliemae/ds-circular-progress-indicator';\nimport { InvisibleDetail, PaginationBoldText, PaginationDropdownButton, PaginationSeparator } from '../styled';\nimport { usePaginationSearch } from '../hooks/usePaginationSearch';\n\ninterface PaginatorPropsT {\n pageIndex: number;\n pageCount: number | string;\n isLoadingPageCount: boolean;\n onPageChange: (page: number) => void;\n pageDetails: string[];\n pageDetailsTitle: string;\n}\n\nconst Paginator: React.ComponentType<PaginatorPropsT> = (props) => {\n const { pageIndex, pageCount, isLoadingPageCount, onPageChange, pageDetails, pageDetailsTitle } = props;\n\n const [isOpened, setIsOpened] = useState(false);\n\n const btnRef = useRef<HTMLButtonElement>(null);\n const pageInfoRef = useRef<HTMLDivElement>(null);\n\n const { width: btnWidth } = useOnElementResize(btnRef);\n const { width: txtWidth } = useOnElementResize(pageInfoRef);\n\n const options = useMemo(\n () =>\n new Array(typeof pageCount === 'string' ? pageIndex + 1 : pageCount).fill(0).map((_, index) => {\n const option: Record<string, unknown> = {\n dsId: (index + 1).toString(),\n label: (index + 1).toString(),\n value: index + 1,\n type: 'single',\n };\n if (pageDetails?.length) {\n option.render = () => (\n <Grid cols={['16px', `${txtWidth + 16}px`, 'auto']} gutter=\"xxs\" alignItems=\"center\">\n {pageIndex === index ? <Checkmark size=\"s\" color={['brand-primary', '600']} /> : <div />}\n <span>{index + 1}</span>\n <span\n style={{\n whiteSpace: 'nowrap',\n textOverflow: 'ellipsis',\n overflow: 'hidden',\n }}\n >\n {pageDetails[index]}\n </span>\n </Grid>\n );\n }\n return option;\n }),\n [pageCount, pageDetails, pageIndex, txtWidth],\n );\n\n const actionRef = useRef<Record<string, (dsId: string) => void>>({});\n\n useEffect(() => {\n if (isOpened) {\n actionRef.current.setActiveDescendant((pageIndex + 1).toString());\n actionRef.current.scrollOptionIntoView((pageIndex + 1).toString());\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpened]);\n\n const [detailWidth, setDetailWidth] = useState(0);\n\n useLayoutEffect(() => {\n const invisibleDetails = [\n ...document.body.querySelectorAll('[data-testid=\"ds-pagination-invisible-detail-for-width-calc\"]'),\n ] as HTMLDivElement[];\n const maxWidth = invisibleDetails.reduce((acc, cur) => Math.max(acc, cur.getBoundingClientRect().width), 0);\n setDetailWidth(maxWidth);\n }, [pageDetails]);\n\n const onKeyDown = usePaginationSearch(pageCount, actionRef);\n\n return (\n <>\n <PaginationSeparator />\n <DSDropdownMenuV2\n isOpened={isOpened}\n options={options}\n selectedOptions={{ [(pageIndex + 1).toString()]: true }}\n onOptionClick={(_, clickedOption) => {\n onPageChange(clickedOption.value);\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n onClickOutside={() => {\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n customOffset={[-23, 2]}\n startPlacementPreference=\"top-start\"\n actionRef={actionRef}\n onKeyDown={onKeyDown}\n minWidth={pageDetails.length !== 0 ? btnWidth + 23 : pageCount.toString().length * 6 + 90}\n maxHeight={300}\n HeaderComp={() =>\n pageDetailsTitle !== '' ? (\n <Grid cols={[`${txtWidth + 50}px`, '8px', 'auto']}>\n <span style={{ marginLeft: '8px' }}>Page</span>\n <PaginationSeparator height=\"100%\" />\n <span>{pageDetailsTitle}</span>\n </Grid>\n ) : (\n 'Page'\n )\n }\n >\n <PaginationDropdownButton\n buttonType=\"raw\"\n disabled={isLoadingPageCount}\n onClick={() => setIsOpened((prev) => !prev)}\n innerRef={btnRef}\n aria-label={`Page ${pageIndex + 1} out of ${pageCount}, ${\n pageDetails.length !== 0 ? pageDetails[pageIndex] : '\\b\\b'\n }. Press to change the current page`}\n >\n <Grid\n gutter=\"xxs\"\n alignItems=\"center\"\n cols={\n pageDetails.length !== 0\n ? ['auto', 'min-content', 'minmax(0px, 70%)', 'min-content']\n : ['auto', 'min-content']\n }\n >\n <Grid alignItems=\"center\" gutter=\"xxxs\" ref={pageInfoRef} style={{ gridAutoFlow: 'column' }}>\n <PaginationBoldText fontSize=\"18px\">{pageIndex + 1}</PaginationBoldText> / {pageCount}\n </Grid>\n {isLoadingPageCount ? (\n <DSCircularIndeterminateIndicator size=\"xs\" />\n ) : (\n <>\n {pageDetails.length !== 0 && (\n <>\n <PaginationSeparator height=\"12px\" ml=\"8px\" />\n <PaginationBoldText fontSize=\"13px\" w={detailWidth} mr=\"xxs\" display=\"grid\">\n <SimpleTruncatedTooltipText value={pageDetails[pageIndex]}>\n {pageDetails[pageIndex]}\n </SimpleTruncatedTooltipText>\n {pageDetails.map((pageDetail) => (\n <InvisibleDetail data-testid=\"ds-pagination-invisible-detail-for-width-calc\">\n {pageDetail}\n </InvisibleDetail>\n ))}\n </PaginationBoldText>\n </>\n )}\n <ChevronDown color={['brand-primary', '700']} />\n </>\n )}\n </Grid>\n </PaginationDropdownButton>\n </DSDropdownMenuV2>\n <PaginationSeparator />\n </>\n );\n};\n\nexport default Paginator;\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import * as React from "react";
|
|
2
|
-
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { useEffect, useMemo, useRef, useState } from "react";
|
|
4
|
-
import memoize from "memoize-one";
|
|
5
|
-
import { range } from "@elliemae/ds-utilities";
|
|
6
|
-
import { DSDropdownMenuV2 } from "@elliemae/ds-dropdownmenu";
|
|
7
|
-
import { ChevronDown } from "@elliemae/ds-icons";
|
|
8
|
-
import { PaginationDropdownButton } from "../styled";
|
|
9
|
-
const generateOption = (value) => {
|
|
10
|
-
if (typeof value === "object") {
|
|
11
|
-
return value;
|
|
12
|
-
}
|
|
13
|
-
return {
|
|
14
|
-
dsId: value.toString(),
|
|
15
|
-
value,
|
|
16
|
-
label: value.toString(),
|
|
17
|
-
type: "single"
|
|
18
|
-
};
|
|
19
|
-
};
|
|
20
|
-
const getOptions = memoize((step, min, max) => {
|
|
21
|
-
const options = range(min, max + step, step).map(generateOption);
|
|
22
|
-
return min === 0 ? options.slice(1, options.length) : options;
|
|
23
|
-
});
|
|
24
|
-
const Header = () => /* @__PURE__ */ jsx(Fragment, { children: "Per Page" });
|
|
25
|
-
const PerPageSelector = (props) => {
|
|
26
|
-
const [isOpened, setIsOpened] = useState(false);
|
|
27
|
-
const { pageSize, onPageSizeChange, perPageOptions, maxPerPage, perPageStep, minPerPage } = props;
|
|
28
|
-
const options = useMemo(() => {
|
|
29
|
-
if (perPageOptions)
|
|
30
|
-
return perPageOptions.map(generateOption);
|
|
31
|
-
return getOptions(perPageStep, minPerPage, maxPerPage);
|
|
32
|
-
}, [maxPerPage, minPerPage, perPageOptions, perPageStep]);
|
|
33
|
-
const actionRef = useRef({});
|
|
34
|
-
const btnRef = useRef(null);
|
|
35
|
-
useEffect(() => {
|
|
36
|
-
if (isOpened) {
|
|
37
|
-
actionRef.current.setActiveDescendant(pageSize.toString());
|
|
38
|
-
actionRef.current.scrollOptionIntoView(pageSize.toString());
|
|
39
|
-
}
|
|
40
|
-
}, [isOpened]);
|
|
41
|
-
const width = useMemo(() => {
|
|
42
|
-
const maxLength = options.reduce((acc, cur) => Math.max(acc, cur?.label?.length ?? 0), 0);
|
|
43
|
-
return maxLength * 6 + 90;
|
|
44
|
-
}, [options]);
|
|
45
|
-
return /* @__PURE__ */ jsx(
|
|
46
|
-
DSDropdownMenuV2,
|
|
47
|
-
{
|
|
48
|
-
isOpened,
|
|
49
|
-
options,
|
|
50
|
-
selectedOptions: { [pageSize.toString()]: true },
|
|
51
|
-
onOptionClick: (_, clickedOption) => {
|
|
52
|
-
onPageSizeChange(clickedOption.value);
|
|
53
|
-
setIsOpened(false);
|
|
54
|
-
btnRef.current?.focus();
|
|
55
|
-
},
|
|
56
|
-
onClickOutside: () => {
|
|
57
|
-
setIsOpened(false);
|
|
58
|
-
btnRef.current?.focus();
|
|
59
|
-
},
|
|
60
|
-
customOffset: [10, 2],
|
|
61
|
-
startPlacementPreference: "top-start",
|
|
62
|
-
actionRef,
|
|
63
|
-
minWidth: width,
|
|
64
|
-
maxHeight: 300,
|
|
65
|
-
HeaderComp: Header,
|
|
66
|
-
children: /* @__PURE__ */ jsx("div", { style: { marginLeft: "32px" }, children: /* @__PURE__ */ jsxs(
|
|
67
|
-
PaginationDropdownButton,
|
|
68
|
-
{
|
|
69
|
-
buttonType: "raw",
|
|
70
|
-
onClick: () => setIsOpened((prev) => !prev),
|
|
71
|
-
"aria-pressed": isOpened,
|
|
72
|
-
innerRef: btnRef,
|
|
73
|
-
"aria-label": `${pageSize} rows per page. Press to select rows per page`,
|
|
74
|
-
children: [
|
|
75
|
-
pageSize,
|
|
76
|
-
" / page",
|
|
77
|
-
/* @__PURE__ */ jsx(ChevronDown, { color: ["brand-primary", "700"] })
|
|
78
|
-
]
|
|
79
|
-
}
|
|
80
|
-
) })
|
|
81
|
-
}
|
|
82
|
-
);
|
|
83
|
-
};
|
|
84
|
-
var PerPageSelector_default = PerPageSelector;
|
|
85
|
-
export {
|
|
86
|
-
PerPageSelector_default as default
|
|
87
|
-
};
|
|
88
|
-
//# sourceMappingURL=PerPageSelector.js.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/parts/PerPageSelector.tsx"],
|
|
4
|
-
"sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable react/prop-types */\nimport React, { useEffect, useMemo, useRef, useState } from 'react';\nimport memoize from 'memoize-one';\nimport { range } from '@elliemae/ds-utilities';\nimport { DSDropdownMenuV2 } from '@elliemae/ds-dropdownmenu';\nimport { ChevronDown } from '@elliemae/ds-icons';\nimport type { DSPaginationT } from '../react-desc-prop-types';\nimport { PaginationDropdownButton } from '../styled';\n\nconst generateOption = (value: number | Record<string, unknown>) => {\n if (typeof value === 'object') {\n return value;\n }\n return {\n dsId: value.toString(),\n value,\n label: value.toString(),\n type: 'single',\n };\n};\n\nconst getOptions = memoize((step: number, min: number, max: number) => {\n const options = range(min, max + step, step).map(generateOption);\n return min === 0 ? options.slice(1, options.length) : options;\n});\n\nconst Header = () => <>{'Per Page'}</>;\n\nconst PerPageSelector: React.ComponentType<\n Pick<\n DSPaginationT.InternalProps,\n 'pageSize' | 'onPageSizeChange' | 'perPageOptions' | 'perPageStep' | 'minPerPage' | 'maxPerPage'\n >\n> = (props) => {\n const [isOpened, setIsOpened] = useState(false);\n const { pageSize, onPageSizeChange, perPageOptions, maxPerPage, perPageStep, minPerPage } = props;\n\n const options = useMemo(() => {\n if (perPageOptions) return perPageOptions.map(generateOption);\n return getOptions(perPageStep, minPerPage, maxPerPage);\n }, [maxPerPage, minPerPage, perPageOptions, perPageStep]);\n\n const actionRef = useRef<Record<string, (dsId: string) => void>>({});\n const btnRef = useRef<HTMLButtonElement>(null);\n\n useEffect(() => {\n if (isOpened) {\n actionRef.current.setActiveDescendant(pageSize.toString());\n actionRef.current.scrollOptionIntoView(pageSize.toString());\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpened]);\n\n const width = useMemo(() => {\n const maxLength = options.reduce((acc, cur) => Math.max(acc, (cur?.label as string)?.length ?? 0), 0);\n return maxLength * 6 + 90;\n }, [options]);\n\n return (\n <DSDropdownMenuV2\n isOpened={isOpened}\n options={options}\n selectedOptions={{ [pageSize.toString()]: true }}\n onOptionClick={(_, clickedOption) => {\n onPageSizeChange(clickedOption.value);\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n onClickOutside={() => {\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n customOffset={[10, 2]}\n startPlacementPreference=\"top-start\"\n actionRef={actionRef}\n minWidth={width}\n maxHeight={300}\n HeaderComp={Header}\n >\n <div style={{ marginLeft: '32px' }}>\n <PaginationDropdownButton\n buttonType=\"raw\"\n onClick={() => setIsOpened((prev) => !prev)}\n aria-pressed={isOpened}\n innerRef={btnRef}\n aria-label={`${pageSize} rows per page. Press to select rows per page`}\n >\n {pageSize} / page\n <ChevronDown color={['brand-primary', '700']} />\n </PaginationDropdownButton>\n </div>\n </DSDropdownMenuV2>\n );\n};\n\nexport default PerPageSelector;\n"],
|
|
5
|
-
"mappings": "AAAA,YAAY,WAAW;AC0BF,wBAsDb,YAtDa;AAzBrB,SAAgB,WAAW,SAAS,QAAQ,gBAAgB;AAC5D,OAAO,aAAa;AACpB,SAAS,aAAa;AACtB,SAAS,wBAAwB;AACjC,SAAS,mBAAmB;AAE5B,SAAS,gCAAgC;AAEzC,MAAM,iBAAiB,CAAC,UAA4C;AAClE,MAAI,OAAO,UAAU,UAAU;AAC7B,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,MAAM,MAAM,SAAS;AAAA,IACrB;AAAA,IACA,OAAO,MAAM,SAAS;AAAA,IACtB,MAAM;AAAA,EACR;AACF;AAEA,MAAM,aAAa,QAAQ,CAAC,MAAc,KAAa,QAAgB;AACrE,QAAM,UAAU,MAAM,KAAK,MAAM,MAAM,IAAI,EAAE,IAAI,cAAc;AAC/D,SAAO,QAAQ,IAAI,QAAQ,MAAM,GAAG,QAAQ,MAAM,IAAI;AACxD,CAAC;AAED,MAAM,SAAS,MAAM,gCAAG,sBAAW;AAEnC,MAAM,kBAKF,CAAC,UAAU;AACb,QAAM,CAAC,UAAU,WAAW,IAAI,SAAS,KAAK;AAC9C,QAAM,EAAE,UAAU,kBAAkB,gBAAgB,YAAY,aAAa,WAAW,IAAI;AAE5F,QAAM,UAAU,QAAQ,MAAM;AAC5B,QAAI;AAAgB,aAAO,eAAe,IAAI,cAAc;AAC5D,WAAO,WAAW,aAAa,YAAY,UAAU;AAAA,EACvD,GAAG,CAAC,YAAY,YAAY,gBAAgB,WAAW,CAAC;AAExD,QAAM,YAAY,OAA+C,CAAC,CAAC;AACnE,QAAM,SAAS,OAA0B,IAAI;AAE7C,YAAU,MAAM;AACd,QAAI,UAAU;AACZ,gBAAU,QAAQ,oBAAoB,SAAS,SAAS,CAAC;AACzD,gBAAU,QAAQ,qBAAqB,SAAS,SAAS,CAAC;AAAA,IAC5D;AAAA,EAEF,GAAG,CAAC,QAAQ,CAAC;AAEb,QAAM,QAAQ,QAAQ,MAAM;AAC1B,UAAM,YAAY,QAAQ,OAAO,CAAC,KAAK,QAAQ,KAAK,IAAI,KAAM,KAAK,OAAkB,UAAU,CAAC,GAAG,CAAC;AACpG,WAAO,YAAY,IAAI;AAAA,EACzB,GAAG,CAAC,OAAO,CAAC;AAEZ,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,iBAAiB,EAAE,CAAC,SAAS,SAAS,IAAI,KAAK;AAAA,MAC/C,eAAe,CAAC,GAAG,kBAAkB;AACnC,yBAAiB,cAAc,KAAK;AACpC,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,gBAAgB,MAAM;AACpB,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,cAAc,CAAC,IAAI,CAAC;AAAA,MACpB,0BAAyB;AAAA,MACzB;AAAA,MACA,UAAU;AAAA,MACV,WAAW;AAAA,MACX,YAAY;AAAA,MAEZ,8BAAC,SAAI,OAAO,EAAE,YAAY,OAAO,GAC/B;AAAA,QAAC;AAAA;AAAA,UACC,YAAW;AAAA,UACX,SAAS,MAAM,YAAY,CAAC,SAAS,CAAC,IAAI;AAAA,UAC1C,gBAAc;AAAA,UACd,UAAU;AAAA,UACV,cAAY,GAAG;AAAA,UAEd;AAAA;AAAA,YAAS;AAAA,YACV,oBAAC,eAAY,OAAO,CAAC,iBAAiB,KAAK,GAAG;AAAA;AAAA;AAAA,MAChD,GACF;AAAA;AAAA,EACF;AAEJ;AAEA,IAAO,0BAAQ;",
|
|
6
|
-
"names": []
|
|
7
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare const usePaginationSearch: (pageCount: number, actionRef: React.MutableRefObject<any>) => React.KeyboardEventHandler;
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
interface PaginatorPropsT {
|
|
3
|
-
pageIndex: number;
|
|
4
|
-
pageCount: number | string;
|
|
5
|
-
isLoadingPageCount: boolean;
|
|
6
|
-
onPageChange: (page: number) => void;
|
|
7
|
-
pageDetails: string[];
|
|
8
|
-
pageDetailsTitle: string;
|
|
9
|
-
}
|
|
10
|
-
declare const Paginator: React.ComponentType<PaginatorPropsT>;
|
|
11
|
-
export default Paginator;
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import type { DSPaginationT } from '../react-desc-prop-types';
|
|
3
|
-
declare const PerPageSelector: React.ComponentType<Pick<DSPaginationT.InternalProps, 'pageSize' | 'onPageSizeChange' | 'perPageOptions' | 'perPageStep' | 'minPerPage' | 'maxPerPage'>>;
|
|
4
|
-
export default PerPageSelector;
|