@schemavaults/ui 0.21.0 → 0.23.1
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/components/ui/datatable/datatable.js +5 -2
- package/dist/components/ui/datatable/datatable.js.map +1 -1
- package/dist/components/ui/index.d.ts +4 -0
- package/dist/components/ui/index.js +2 -0
- package/dist/components/ui/index.js.map +1 -1
- package/dist/components/ui/otp-input/index.d.ts +3 -0
- package/dist/components/ui/otp-input/index.js +3 -0
- package/dist/components/ui/otp-input/index.js.map +1 -0
- package/dist/components/ui/otp-input/otp-input.d.ts +51 -0
- package/dist/components/ui/otp-input/otp-input.js +186 -0
- package/dist/components/ui/otp-input/otp-input.js.map +1 -0
- package/dist/components/ui/pagination/index.d.ts +4 -0
- package/dist/components/ui/pagination/index.js +3 -0
- package/dist/components/ui/pagination/index.js.map +1 -0
- package/dist/components/ui/pagination/pagination-variants.d.ts +6 -0
- package/dist/components/ui/pagination/pagination-variants.js +16 -0
- package/dist/components/ui/pagination/pagination-variants.js.map +1 -0
- package/dist/components/ui/pagination/pagination.d.ts +105 -0
- package/dist/components/ui/pagination/pagination.js +171 -0
- package/dist/components/ui/pagination/pagination.js.map +1 -0
- package/package.json +1 -1
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
3
|
import { flexRender, getCoreRowModel, getFilteredRowModel, getPaginationRowModel, getSortedRowModel, useReactTable, } from "@tanstack/react-table";
|
|
4
|
-
import { ArrowDown, ArrowUp, ArrowUpDown, ChevronDown,
|
|
4
|
+
import { ArrowDown, ArrowUp, ArrowUpDown, ChevronDown, } from "lucide-react";
|
|
5
5
|
import { Button } from "../../ui/button";
|
|
6
6
|
import { DropdownMenu, DropdownMenuCheckboxItem, DropdownMenuContent, DropdownMenuTrigger, } from "../../ui/dropdown-menu";
|
|
7
7
|
import { Input } from "../../ui/input";
|
|
8
|
+
import { PaginationControls } from "../../ui/pagination";
|
|
8
9
|
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "../../ui/select";
|
|
9
10
|
import { Table, TableBody, TableCell, TableHead, TableHeader, TableRow, } from "../../ui/table";
|
|
10
11
|
import { useMemo, useState } from "react";
|
|
@@ -99,7 +100,9 @@ export function Datatable({ data, columns, initialVisibleColumns, datatypeLabel,
|
|
|
99
100
|
return (_jsx(TableHead, { children: header.isPlaceholder ? null : header.column.getCanSort() ? (_jsxs(Button, { variant: "ghost", className: "-ml-4", onClick: () => header.column.toggleSorting(header.column.getIsSorted() === "asc"), children: [flexRender(header.column.columnDef.header, header.getContext()), header.column.getIsSorted() === "asc" ? (_jsx(ArrowUp, { className: "ml-2 h-4 w-4" })) : header.column.getIsSorted() === "desc" ? (_jsx(ArrowDown, { className: "ml-2 h-4 w-4" })) : (_jsx(ArrowUpDown, { className: "ml-2 h-4 w-4" }))] })) : (flexRender(header.column.columnDef.header, header.getContext())) }, header.id));
|
|
100
101
|
}) }, headerGroup.id))) }), _jsx(TableBody, { children: table.getRowModel().rows?.length ? (table.getRowModel().rows.map((row) => (_jsx(TableRow, { "data-state": row.getIsSelected() && "selected", children: row.getVisibleCells().map((cell) => (_jsx(TableCell, { children: flexRender(cell.column.columnDef.cell, cell.getContext()) }, cell.id))) }, row.id)))) : (_jsx(TableRow, { children: _jsx(TableCell, { colSpan: columns.length, className: "h-24 text-center", children: "No results." }) })) })] }) }), _jsxs("div", { className: "flex flex-col sm:flex-row items-center justify-between gap-4 py-4 w-full", children: [_jsxs("div", { className: "text-sm text-muted-foreground", children: [table.getFilteredSelectedRowModel().rows.length, " of", " ", table.getFilteredRowModel().rows.length, " row(s) selected."] }), _jsxs("div", { className: "flex flex-col sm:flex-row items-center gap-4", children: [_jsxs("div", { className: "flex items-center gap-2", children: [_jsx("span", { className: "text-sm text-muted-foreground whitespace-nowrap", children: "Rows per page" }), _jsxs(Select, { value: String(table.getState().pagination.pageSize), onValueChange: (value) => {
|
|
101
102
|
table.setPageSize(Number(value));
|
|
102
|
-
}, children: [_jsx(SelectTrigger, { size: "sm", className: "w-[70px]", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: pageSizeOptions.map((size) => (_jsx(SelectItem, { value: String(size), children: size }, size))) })] })] }),
|
|
103
|
+
}, children: [_jsx(SelectTrigger, { size: "sm", className: "w-[70px]", children: _jsx(SelectValue, {}) }), _jsx(SelectContent, { children: pageSizeOptions.map((size) => (_jsx(SelectItem, { value: String(size), children: size }, size))) })] })] }), _jsx(PaginationControls, { className: "mx-0 w-auto justify-end", size: "sm", variant: "outline", page: table.getState().pagination.pageIndex + 1, totalPages: Math.max(1, table.getPageCount()), onPageChange: (nextPage) => {
|
|
104
|
+
table.setPageIndex(nextPage - 1);
|
|
105
|
+
}, showFirstLast: true, iconOnlyPrevNext: true, disabled: table.getPageCount() <= 1 })] })] })] }));
|
|
103
106
|
}
|
|
104
107
|
export default Datatable;
|
|
105
108
|
//# sourceMappingURL=datatable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"datatable.js","sourceRoot":"","sources":["../../../../src/components/ui/datatable/datatable.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAML,UAAU,EACV,eAAe,EACf,mBAAmB,EACnB,qBAAqB,EACrB,iBAAiB,EACjB,aAAa,GAEd,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,SAAS,EACT,OAAO,EACP,WAAW,EACX,WAAW,
|
|
1
|
+
{"version":3,"file":"datatable.js","sourceRoot":"","sources":["../../../../src/components/ui/datatable/datatable.tsx"],"names":[],"mappings":"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"}
|
|
@@ -16,6 +16,8 @@ export * from "./input";
|
|
|
16
16
|
export type * from "./input";
|
|
17
17
|
export * from "./password-input";
|
|
18
18
|
export type * from "./password-input";
|
|
19
|
+
export * from "./otp-input";
|
|
20
|
+
export type * from "./otp-input";
|
|
19
21
|
export * from "./secure-password-creation-input";
|
|
20
22
|
export type * from "./secure-password-creation-input";
|
|
21
23
|
export * from "./file-input";
|
|
@@ -98,6 +100,8 @@ export * from "./progress-bar";
|
|
|
98
100
|
export type * from "./progress-bar";
|
|
99
101
|
export * from "./breadcrumb";
|
|
100
102
|
export type * from "./breadcrumb";
|
|
103
|
+
export * from "./pagination";
|
|
104
|
+
export type * from "./pagination";
|
|
101
105
|
export * from "./kbd";
|
|
102
106
|
export type * from "./kbd";
|
|
103
107
|
export * from "./copy-button";
|
|
@@ -7,6 +7,7 @@ export * from "./themed-page-background";
|
|
|
7
7
|
export * from "./button";
|
|
8
8
|
export * from "./input";
|
|
9
9
|
export * from "./password-input";
|
|
10
|
+
export * from "./otp-input";
|
|
10
11
|
export * from "./secure-password-creation-input";
|
|
11
12
|
export * from "./file-input";
|
|
12
13
|
export * from "./label";
|
|
@@ -48,6 +49,7 @@ export * from "./slider";
|
|
|
48
49
|
export * from "./switch";
|
|
49
50
|
export * from "./progress-bar";
|
|
50
51
|
export * from "./breadcrumb";
|
|
52
|
+
export * from "./pagination";
|
|
51
53
|
export * from "./kbd";
|
|
52
54
|
export * from "./copy-button";
|
|
53
55
|
export * from "./spinner";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AAGzB,cAAc,aAAa,CAAC;AAG5B,cAAc,SAAS,CAAC;AAGxB,cAAc,SAAS,CAAC;AAGxB,cAAc,mBAAmB,CAAC;AAGlC,cAAc,0BAA0B,CAAC;AAGzC,cAAc,UAAU,CAAC;AAGzB,cAAc,SAAS,CAAC;AAGxB,cAAc,kBAAkB,CAAC;AAGjC,cAAc,kCAAkC,CAAC;AAGjD,cAAc,cAAc,CAAC;AAG7B,cAAc,SAAS,CAAC;AAGxB,cAAc,SAAS,CAAC;AAExB,cAAc,WAAW,CAAC;AAG1B,cAAc,YAAY,CAAC;AAG3B,cAAc,QAAQ,CAAC;AAGvB,cAAc,QAAQ,CAAC;AAGvB,cAAc,aAAa,CAAC;AAG5B,cAAc,iBAAiB,CAAC;AAGhC,cAAc,WAAW,CAAC;AAG1B,cAAc,mBAAmB,CAAC;AAGlC,cAAc,UAAU,CAAC;AAGzB,cAAc,WAAW,CAAC;AAG1B,cAAc,WAAW,CAAC;AAG1B,cAAc,SAAS,CAAC;AAGxB,cAAc,aAAa,CAAC;AAG5B,cAAc,YAAY,CAAC;AAG3B,cAAc,YAAY,CAAC;AAG3B,cAAc,cAAc,CAAC;AAG7B,cAAc,eAAe,CAAC;AAG9B,cAAc,YAAY,CAAC;AAG3B,cAAc,2BAA2B,CAAC;AAG1C,cAAc,kBAAkB,CAAC;AAGjC,cAAc,gBAAgB,CAAC;AAG/B,cAAc,eAAe,CAAC;AAG9B,cAAc,WAAW,CAAC;AAG1B,cAAc,gBAAgB,CAAC;AAG/B,cAAc,cAAc,CAAC;AAG7B,cAAc,SAAS,CAAC;AAGxB,cAAc,UAAU,CAAC;AAGzB,cAAc,eAAe,CAAC;AAG9B,cAAc,qBAAqB,CAAC;AAGpC,cAAc,oBAAoB,CAAC;AAGnC,cAAc,mBAAmB,CAAC;AAGlC,cAAc,QAAQ,CAAC;AAGvB,cAAc,QAAQ,CAAC;AAGvB,cAAc,UAAU,CAAC;AAGzB,cAAc,UAAU,CAAC;AAGzB,cAAc,gBAAgB,CAAC;AAG/B,cAAc,cAAc,CAAC;AAG7B,cAAc,OAAO,CAAC;AAGtB,cAAc,eAAe,CAAC;AAG9B,cAAc,WAAW,CAAC;AAG1B,cAAc,UAAU,CAAC;AAGzB,cAAc,eAAe,CAAC;AAG9B,cAAc,aAAa,CAAC;AAG5B,cAAc,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ui/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AAGzB,cAAc,aAAa,CAAC;AAG5B,cAAc,SAAS,CAAC;AAGxB,cAAc,SAAS,CAAC;AAGxB,cAAc,mBAAmB,CAAC;AAGlC,cAAc,0BAA0B,CAAC;AAGzC,cAAc,UAAU,CAAC;AAGzB,cAAc,SAAS,CAAC;AAGxB,cAAc,kBAAkB,CAAC;AAGjC,cAAc,aAAa,CAAC;AAG5B,cAAc,kCAAkC,CAAC;AAGjD,cAAc,cAAc,CAAC;AAG7B,cAAc,SAAS,CAAC;AAGxB,cAAc,SAAS,CAAC;AAExB,cAAc,WAAW,CAAC;AAG1B,cAAc,YAAY,CAAC;AAG3B,cAAc,QAAQ,CAAC;AAGvB,cAAc,QAAQ,CAAC;AAGvB,cAAc,aAAa,CAAC;AAG5B,cAAc,iBAAiB,CAAC;AAGhC,cAAc,WAAW,CAAC;AAG1B,cAAc,mBAAmB,CAAC;AAGlC,cAAc,UAAU,CAAC;AAGzB,cAAc,WAAW,CAAC;AAG1B,cAAc,WAAW,CAAC;AAG1B,cAAc,SAAS,CAAC;AAGxB,cAAc,aAAa,CAAC;AAG5B,cAAc,YAAY,CAAC;AAG3B,cAAc,YAAY,CAAC;AAG3B,cAAc,cAAc,CAAC;AAG7B,cAAc,eAAe,CAAC;AAG9B,cAAc,YAAY,CAAC;AAG3B,cAAc,2BAA2B,CAAC;AAG1C,cAAc,kBAAkB,CAAC;AAGjC,cAAc,gBAAgB,CAAC;AAG/B,cAAc,eAAe,CAAC;AAG9B,cAAc,WAAW,CAAC;AAG1B,cAAc,gBAAgB,CAAC;AAG/B,cAAc,cAAc,CAAC;AAG7B,cAAc,SAAS,CAAC;AAGxB,cAAc,UAAU,CAAC;AAGzB,cAAc,eAAe,CAAC;AAG9B,cAAc,qBAAqB,CAAC;AAGpC,cAAc,oBAAoB,CAAC;AAGnC,cAAc,mBAAmB,CAAC;AAGlC,cAAc,QAAQ,CAAC;AAGvB,cAAc,QAAQ,CAAC;AAGvB,cAAc,UAAU,CAAC;AAGzB,cAAc,UAAU,CAAC;AAGzB,cAAc,gBAAgB,CAAC;AAG/B,cAAc,cAAc,CAAC;AAG7B,cAAc,cAAc,CAAC;AAG7B,cAAc,OAAO,CAAC;AAGtB,cAAc,eAAe,CAAC;AAG9B,cAAc,WAAW,CAAC;AAG1B,cAAc,UAAU,CAAC;AAGzB,cAAc,eAAe,CAAC;AAG9B,cAAc,aAAa,CAAC;AAG5B,cAAc,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/ui/otp-input/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAE5B,OAAO,EAAE,QAAQ,IAAI,OAAO,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { type ReactElement, type Ref } from "react";
|
|
2
|
+
import { type VariantProps } from "class-variance-authority";
|
|
3
|
+
declare const otpSlotVariants: (props?: ({
|
|
4
|
+
variant?: "default" | "outline" | "underline" | "filled" | null | undefined;
|
|
5
|
+
size?: "sm" | "lg" | "md" | null | undefined;
|
|
6
|
+
invalid?: boolean | null | undefined;
|
|
7
|
+
} & import("class-variance-authority/types").ClassProp) | undefined) => string;
|
|
8
|
+
type OTPInputMode = "numeric" | "alphanumeric";
|
|
9
|
+
export interface OTPInputHandle {
|
|
10
|
+
focus: () => void;
|
|
11
|
+
clear: () => void;
|
|
12
|
+
}
|
|
13
|
+
export interface OTPInputProps extends VariantProps<typeof otpSlotVariants> {
|
|
14
|
+
/** Number of slots rendered. Defaults to 6. */
|
|
15
|
+
length?: number;
|
|
16
|
+
/** Controlled value. Extra characters beyond `length` are ignored. */
|
|
17
|
+
value?: string;
|
|
18
|
+
/** Uncontrolled default value. */
|
|
19
|
+
defaultValue?: string;
|
|
20
|
+
/** Called with the current concatenated string on every keystroke. */
|
|
21
|
+
onChange?: (value: string) => void;
|
|
22
|
+
/** Called once the user fills every slot. */
|
|
23
|
+
onComplete?: (value: string) => void;
|
|
24
|
+
/** Restrict input to digits ("numeric") or letters+digits ("alphanumeric"). */
|
|
25
|
+
mode?: OTPInputMode;
|
|
26
|
+
/** Mask characters as dots (useful for sensitive one-time passwords). */
|
|
27
|
+
mask?: boolean;
|
|
28
|
+
/** Render a visual separator between groups of this many slots. */
|
|
29
|
+
groupSize?: number;
|
|
30
|
+
/** Focus the first slot on mount. */
|
|
31
|
+
focusOnMount?: boolean;
|
|
32
|
+
disabled?: boolean;
|
|
33
|
+
invalid?: boolean;
|
|
34
|
+
/** Optional name used when emitting a hidden input for form submissions. */
|
|
35
|
+
name?: string;
|
|
36
|
+
/** Placeholder character shown in empty slots. */
|
|
37
|
+
placeholder?: string;
|
|
38
|
+
/** Accessible label for the group of inputs. */
|
|
39
|
+
"aria-label"?: string;
|
|
40
|
+
className?: string;
|
|
41
|
+
slotClassName?: string;
|
|
42
|
+
separatorClassName?: string;
|
|
43
|
+
/** Imperative handle exposing focus()/clear(). */
|
|
44
|
+
ref?: Ref<OTPInputHandle>;
|
|
45
|
+
}
|
|
46
|
+
declare const OTPInput: {
|
|
47
|
+
({ length, value: controlledValue, defaultValue, onChange, onComplete, mode, mask, groupSize, focusOnMount, disabled, invalid, name, placeholder, variant, size, className, slotClassName, separatorClassName, "aria-label": ariaLabel, ref, }: OTPInputProps): ReactElement;
|
|
48
|
+
displayName: string;
|
|
49
|
+
};
|
|
50
|
+
export { OTPInput, otpSlotVariants };
|
|
51
|
+
export default OTPInput;
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { useCallback, useEffect, useImperativeHandle, useRef, useState, } from "react";
|
|
4
|
+
import { cva } from "class-variance-authority";
|
|
5
|
+
import { cn } from "../../../lib/utils";
|
|
6
|
+
const otpSlotVariants = cva("relative flex items-center justify-center text-center font-medium tabular-nums bg-background text-foreground ring-offset-background transition-[color,box-shadow,border-color,background-color] outline-none focus-visible:z-10 focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50", {
|
|
7
|
+
variants: {
|
|
8
|
+
variant: {
|
|
9
|
+
default: "border border-input",
|
|
10
|
+
outline: "border-2 border-input",
|
|
11
|
+
underline: "border-0 border-b-2 border-input rounded-none bg-transparent",
|
|
12
|
+
filled: "border border-transparent bg-muted text-foreground focus-visible:bg-background focus-visible:border-input",
|
|
13
|
+
},
|
|
14
|
+
size: {
|
|
15
|
+
sm: "h-9 w-8 text-sm",
|
|
16
|
+
md: "h-11 w-10 text-base",
|
|
17
|
+
lg: "h-14 w-12 text-xl",
|
|
18
|
+
},
|
|
19
|
+
invalid: {
|
|
20
|
+
true: "border-destructive text-destructive focus-visible:ring-destructive",
|
|
21
|
+
false: "",
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
compoundVariants: [
|
|
25
|
+
{
|
|
26
|
+
variant: "default",
|
|
27
|
+
invalid: false,
|
|
28
|
+
class: "focus-visible:border-ring",
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
variant: "outline",
|
|
32
|
+
invalid: false,
|
|
33
|
+
class: "focus-visible:border-ring",
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
variant: "filled",
|
|
37
|
+
invalid: false,
|
|
38
|
+
class: "focus-visible:border-ring",
|
|
39
|
+
},
|
|
40
|
+
],
|
|
41
|
+
defaultVariants: {
|
|
42
|
+
variant: "default",
|
|
43
|
+
size: "md",
|
|
44
|
+
invalid: false,
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
const sanitize = (raw, mode) => {
|
|
48
|
+
const pattern = mode === "numeric" ? /[^0-9]/g : /[^a-zA-Z0-9]/g;
|
|
49
|
+
return raw.replace(pattern, "");
|
|
50
|
+
};
|
|
51
|
+
const OTPInput = ({ length = 6, value: controlledValue, defaultValue = "", onChange, onComplete, mode = "numeric", mask = false, groupSize, focusOnMount = false, disabled = false, invalid = false, name, placeholder = "", variant, size, className, slotClassName, separatorClassName, "aria-label": ariaLabel = "One-time passcode", ref, }) => {
|
|
52
|
+
const isControlled = controlledValue !== undefined;
|
|
53
|
+
const [internalValue, setInternalValue] = useState(() => sanitize(defaultValue, mode).slice(0, length));
|
|
54
|
+
const currentValue = sanitize(isControlled ? (controlledValue ?? "") : internalValue, mode).slice(0, length);
|
|
55
|
+
const slotRefs = useRef([]);
|
|
56
|
+
const hasFiredCompleteRef = useRef(false);
|
|
57
|
+
useImperativeHandle(ref, () => ({
|
|
58
|
+
focus: () => {
|
|
59
|
+
const target = slotRefs.current[currentValue.length] ?? slotRefs.current[0];
|
|
60
|
+
target?.focus();
|
|
61
|
+
},
|
|
62
|
+
clear: () => {
|
|
63
|
+
if (!isControlled)
|
|
64
|
+
setInternalValue("");
|
|
65
|
+
onChange?.("");
|
|
66
|
+
slotRefs.current[0]?.focus();
|
|
67
|
+
},
|
|
68
|
+
}), [currentValue.length, isControlled, onChange]);
|
|
69
|
+
useEffect(() => {
|
|
70
|
+
if (!focusOnMount)
|
|
71
|
+
return;
|
|
72
|
+
slotRefs.current[0]?.focus();
|
|
73
|
+
}, [focusOnMount]);
|
|
74
|
+
const commit = useCallback((next) => {
|
|
75
|
+
const clean = sanitize(next, mode).slice(0, length);
|
|
76
|
+
if (!isControlled)
|
|
77
|
+
setInternalValue(clean);
|
|
78
|
+
onChange?.(clean);
|
|
79
|
+
if (clean.length === length) {
|
|
80
|
+
if (!hasFiredCompleteRef.current) {
|
|
81
|
+
hasFiredCompleteRef.current = true;
|
|
82
|
+
onComplete?.(clean);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
hasFiredCompleteRef.current = false;
|
|
87
|
+
}
|
|
88
|
+
}, [isControlled, length, mode, onChange, onComplete]);
|
|
89
|
+
const focusSlot = (index) => {
|
|
90
|
+
const clamped = Math.max(0, Math.min(length - 1, index));
|
|
91
|
+
const target = slotRefs.current[clamped];
|
|
92
|
+
if (!target)
|
|
93
|
+
return;
|
|
94
|
+
target.focus();
|
|
95
|
+
target.select();
|
|
96
|
+
};
|
|
97
|
+
const handleChangeAt = (index, rawValue) => {
|
|
98
|
+
const cleaned = sanitize(rawValue, mode);
|
|
99
|
+
if (cleaned.length === 0)
|
|
100
|
+
return;
|
|
101
|
+
const chars = currentValue.split("");
|
|
102
|
+
if (cleaned.length === 1) {
|
|
103
|
+
chars[index] = cleaned;
|
|
104
|
+
const next = chars.join("").slice(0, length);
|
|
105
|
+
commit(next);
|
|
106
|
+
if (index < length - 1)
|
|
107
|
+
focusSlot(index + 1);
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
// Multi-character input (e.g. browser autofill of the full code).
|
|
111
|
+
const merged = currentValue.slice(0, index) + cleaned + currentValue.slice(index);
|
|
112
|
+
const next = merged.slice(0, length);
|
|
113
|
+
commit(next);
|
|
114
|
+
focusSlot(Math.min(length - 1, next.length));
|
|
115
|
+
};
|
|
116
|
+
const handleKeyDown = (index, event) => {
|
|
117
|
+
const chars = currentValue.split("");
|
|
118
|
+
if (event.key === "Backspace") {
|
|
119
|
+
event.preventDefault();
|
|
120
|
+
if (chars[index]) {
|
|
121
|
+
chars[index] = "";
|
|
122
|
+
commit(chars.join(""));
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
if (index > 0) {
|
|
126
|
+
chars[index - 1] = "";
|
|
127
|
+
commit(chars.join(""));
|
|
128
|
+
focusSlot(index - 1);
|
|
129
|
+
}
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
if (event.key === "Delete") {
|
|
133
|
+
event.preventDefault();
|
|
134
|
+
chars[index] = "";
|
|
135
|
+
commit(chars.join(""));
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
if (event.key === "ArrowLeft") {
|
|
139
|
+
event.preventDefault();
|
|
140
|
+
focusSlot(index - 1);
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
if (event.key === "ArrowRight") {
|
|
144
|
+
event.preventDefault();
|
|
145
|
+
focusSlot(index + 1);
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
if (event.key === "Home") {
|
|
149
|
+
event.preventDefault();
|
|
150
|
+
focusSlot(0);
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
if (event.key === "End") {
|
|
154
|
+
event.preventDefault();
|
|
155
|
+
focusSlot(length - 1);
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
const handlePaste = (index, event) => {
|
|
159
|
+
event.preventDefault();
|
|
160
|
+
const pasted = sanitize(event.clipboardData.getData("text"), mode);
|
|
161
|
+
if (!pasted)
|
|
162
|
+
return;
|
|
163
|
+
const merged = currentValue.slice(0, index) + pasted + currentValue.slice(index);
|
|
164
|
+
const next = merged.slice(0, length);
|
|
165
|
+
commit(next);
|
|
166
|
+
focusSlot(Math.min(length - 1, next.length));
|
|
167
|
+
};
|
|
168
|
+
const handleFocus = (event) => {
|
|
169
|
+
event.target.select();
|
|
170
|
+
};
|
|
171
|
+
return (_jsxs("div", { role: "group", "aria-label": ariaLabel, "data-slot": "otp-input", className: cn("inline-flex items-center", className), children: [Array.from({ length }, (_unused, index) => {
|
|
172
|
+
const char = currentValue[index] ?? "";
|
|
173
|
+
const displayChar = char ? (mask ? "•" : char) : "";
|
|
174
|
+
const showSeparator = groupSize && index > 0 && index % groupSize === 0;
|
|
175
|
+
return (_jsxs("span", { className: "inline-flex items-center", children: [showSeparator ? (_jsx("span", { "aria-hidden": "true", className: cn("select-none text-muted-foreground mx-1 text-lg", separatorClassName), children: "\u2013" })) : null, _jsx("input", { ref: (el) => {
|
|
176
|
+
slotRefs.current[index] = el;
|
|
177
|
+
}, type: "text", inputMode: mode === "numeric" ? "numeric" : "text", pattern: mode === "numeric" ? "[0-9]*" : "[a-zA-Z0-9]*", autoComplete: index === 0 ? "one-time-code" : "off", autoCorrect: "off", spellCheck: false, maxLength: 1, disabled: disabled, "aria-invalid": invalid || undefined, "aria-label": `${ariaLabel} digit ${index + 1}`, placeholder: placeholder, value: displayChar, onFocus: handleFocus, onChange: (e) => handleChangeAt(index, e.target.value), onKeyDown: (e) => handleKeyDown(index, e), onPaste: (e) => handlePaste(index, e), className: cn(otpSlotVariants({ variant, size, invalid }), variant !== "underline" &&
|
|
178
|
+
"first:rounded-l-md last:rounded-r-md", variant === "underline" && "rounded-none", variant !== "underline" &&
|
|
179
|
+
!groupSize &&
|
|
180
|
+
"[&+span>input]:-ml-px", slotClassName) })] }, index));
|
|
181
|
+
}), name ? (_jsx("input", { type: "hidden", name: name, value: currentValue, readOnly: true })) : null] }));
|
|
182
|
+
};
|
|
183
|
+
OTPInput.displayName = "OTPInput";
|
|
184
|
+
export { OTPInput, otpSlotVariants };
|
|
185
|
+
export default OTPInput;
|
|
186
|
+
//# sourceMappingURL=otp-input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"otp-input.js","sourceRoot":"","sources":["../../../../src/components/ui/otp-input/otp-input.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EACL,WAAW,EACX,SAAS,EACT,mBAAmB,EACnB,MAAM,EACN,QAAQ,GAMT,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAC;AAElE,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AAEjC,MAAM,eAAe,GAAG,GAAG,CACzB,0VAA0V,EAC1V;IACE,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,OAAO,EAAE,qBAAqB;YAC9B,OAAO,EAAE,uBAAuB;YAChC,SAAS,EACP,8DAA8D;YAChE,MAAM,EACJ,2GAA2G;SAC9G;QACD,IAAI,EAAE;YACJ,EAAE,EAAE,iBAAiB;YACrB,EAAE,EAAE,qBAAqB;YACzB,EAAE,EAAE,mBAAmB;SACxB;QACD,OAAO,EAAE;YACP,IAAI,EAAE,oEAAoE;YAC1E,KAAK,EAAE,EAAE;SACV;KACF;IACD,gBAAgB,EAAE;QAChB;YACE,OAAO,EAAE,SAAS;YAClB,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,2BAA2B;SACnC;QACD;YACE,OAAO,EAAE,SAAS;YAClB,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,2BAA2B;SACnC;QACD;YACE,OAAO,EAAE,QAAQ;YACjB,OAAO,EAAE,KAAK;YACd,KAAK,EAAE,2BAA2B;SACnC;KACF;IACD,eAAe,EAAE;QACf,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,KAAK;KACf;CACF,CACF,CAAC;AA2CF,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAE,IAAkB,EAAU,EAAE;IAC3D,MAAM,OAAO,GAAG,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,eAAe,CAAC;IACjE,OAAO,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,EAChB,MAAM,GAAG,CAAC,EACV,KAAK,EAAE,eAAe,EACtB,YAAY,GAAG,EAAE,EACjB,QAAQ,EACR,UAAU,EACV,IAAI,GAAG,SAAS,EAChB,IAAI,GAAG,KAAK,EACZ,SAAS,EACT,YAAY,GAAG,KAAK,EACpB,QAAQ,GAAG,KAAK,EAChB,OAAO,GAAG,KAAK,EACf,IAAI,EACJ,WAAW,GAAG,EAAE,EAChB,OAAO,EACP,IAAI,EACJ,SAAS,EACT,aAAa,EACb,kBAAkB,EAClB,YAAY,EAAE,SAAS,GAAG,mBAAmB,EAC7C,GAAG,GACW,EAAgB,EAAE;IAChC,MAAM,YAAY,GAAG,eAAe,KAAK,SAAS,CAAC;IACnD,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAS,GAAG,EAAE,CAC9D,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAC9C,CAAC;IACF,MAAM,YAAY,GAAG,QAAQ,CAC3B,YAAY,CAAC,CAAC,CAAC,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,EACtD,IAAI,CACL,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAEnB,MAAM,QAAQ,GAAG,MAAM,CAAiC,EAAE,CAAC,CAAC;IAC5D,MAAM,mBAAmB,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;IAEnD,mBAAmB,CACjB,GAAG,EACH,GAAmB,EAAE,CAAC,CAAC;QACrB,KAAK,EAAE,GAAS,EAAE;YAChB,MAAM,MAAM,GACV,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAC/D,MAAM,EAAE,KAAK,EAAE,CAAC;QAClB,CAAC;QACD,KAAK,EAAE,GAAS,EAAE;YAChB,IAAI,CAAC,YAAY;gBAAE,gBAAgB,CAAC,EAAE,CAAC,CAAC;YACxC,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC;YACf,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC;QAC/B,CAAC;KACF,CAAC,EACF,CAAC,YAAY,CAAC,MAAM,EAAE,YAAY,EAAE,QAAQ,CAAC,CAC9C,CAAC;IAEF,SAAS,CAAC,GAAS,EAAE;QACnB,IAAI,CAAC,YAAY;YAAE,OAAO;QAC1B,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC;IAC/B,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC;IAEnB,MAAM,MAAM,GAAG,WAAW,CACxB,CAAC,IAAY,EAAQ,EAAE;QACrB,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QACpD,IAAI,CAAC,YAAY;YAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC3C,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC;QAClB,IAAI,KAAK,CAAC,MAAM,KAAK,MAAM,EAAE,CAAC;YAC5B,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;gBACjC,mBAAmB,CAAC,OAAO,GAAG,IAAI,CAAC;gBACnC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,mBAAmB,CAAC,OAAO,GAAG,KAAK,CAAC;QACtC,CAAC;IACH,CAAC,EACD,CAAC,YAAY,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,CAAC,CACnD,CAAC;IAEF,MAAM,SAAS,GAAG,CAAC,KAAa,EAAQ,EAAE;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACzC,IAAI,CAAC,MAAM;YAAE,OAAO;QACpB,MAAM,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,CACrB,KAAa,EACb,QAAgB,EACV,EAAE;QACR,MAAM,OAAO,GAAG,QAAQ,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;QACzC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAEjC,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,KAAK,CAAC,KAAK,CAAC,GAAG,OAAO,CAAC;YACvB,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;YAC7C,MAAM,CAAC,IAAI,CAAC,CAAC;YACb,IAAI,KAAK,GAAG,MAAM,GAAG,CAAC;gBAAE,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YAC7C,OAAO;QACT,CAAC;QAED,kEAAkE;QAClE,MAAM,MAAM,GACV,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACrE,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,IAAI,CAAC,CAAC;QACb,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,CACpB,KAAa,EACb,KAA2C,EACrC,EAAE;QACR,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAErC,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC;gBACjB,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;gBAClB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;gBACd,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;gBACtB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;gBACvB,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YACvB,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,EAAE,CAAC;YAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;YAClB,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YACvB,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE,CAAC;YAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,YAAY,EAAE,CAAC;YAC/B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,MAAM,EAAE,CAAC;YACzB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS,CAAC,CAAC,CAAC,CAAC;YACb,OAAO;QACT,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACxB,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,CAClB,KAAa,EACb,KAA4C,EACtC,EAAE;QACR,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC;QACnE,IAAI,CAAC,MAAM;YAAE,OAAO;QACpB,MAAM,MAAM,GACV,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,MAAM,GAAG,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;QACrC,MAAM,CAAC,IAAI,CAAC,CAAC;QACb,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC;IAEF,MAAM,WAAW,GAAG,CAAC,KAAwC,EAAQ,EAAE;QACrE,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;IACxB,CAAC,CAAC;IAEF,OAAO,CACL,eACE,IAAI,EAAC,OAAO,gBACA,SAAS,eACX,WAAW,EACrB,SAAS,EAAE,EAAE,CAAC,0BAA0B,EAAE,SAAS,CAAC,aAEnD,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;gBACzC,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;gBACvC,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACpD,MAAM,aAAa,GACjB,SAAS,IAAI,KAAK,GAAG,CAAC,IAAI,KAAK,GAAG,SAAS,KAAK,CAAC,CAAC;gBAEpD,OAAO,CACL,gBAAkB,SAAS,EAAC,0BAA0B,aACnD,aAAa,CAAC,CAAC,CAAC,CACf,8BACc,MAAM,EAClB,SAAS,EAAE,EAAE,CACX,gDAAgD,EAChD,kBAAkB,CACnB,uBAGI,CACR,CAAC,CAAC,CAAC,IAAI,EACR,gBACE,GAAG,EAAE,CAAC,EAAE,EAAQ,EAAE;gCAChB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;4BAC/B,CAAC,EACD,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,EAClD,OAAO,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,cAAc,EACvD,YAAY,EAAE,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,EACnD,WAAW,EAAC,KAAK,EACjB,UAAU,EAAE,KAAK,EACjB,SAAS,EAAE,CAAC,EACZ,QAAQ,EAAE,QAAQ,kBACJ,OAAO,IAAI,SAAS,gBACtB,GAAG,SAAS,UAAU,KAAK,GAAG,CAAC,EAAE,EAC7C,WAAW,EAAE,WAAW,EACxB,KAAK,EAAE,WAAW,EAClB,OAAO,EAAE,WAAW,EACpB,QAAQ,EAAE,CAAC,CAAC,EAAQ,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAC5D,SAAS,EAAE,CAAC,CAAC,EAAQ,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC,EAC/C,OAAO,EAAE,CAAC,CAAC,EAAQ,EAAE,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,EAC3C,SAAS,EAAE,EAAE,CACX,eAAe,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,EAC3C,OAAO,KAAK,WAAW;gCACrB,sCAAsC,EACxC,OAAO,KAAK,WAAW,IAAI,cAAc,EACzC,OAAO,KAAK,WAAW;gCACrB,CAAC,SAAS;gCACV,uBAAuB,EACzB,aAAa,CACd,GACD,KA1CO,KAAK,CA2CT,CACR,CAAC;YACJ,CAAC,CAAC,EACD,IAAI,CAAC,CAAC,CAAC,CACN,gBAAO,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,SAAG,CAClE,CAAC,CAAC,CAAC,IAAI,IACJ,CACP,CAAC;AACJ,CAAC,CAAC;AACF,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC;AAElC,OAAO,EAAE,QAAQ,EAAE,eAAe,EAAE,CAAC;AAErC,eAAe,QAAQ,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { Pagination, Pagination as default, PaginationContent, PaginationItem, PaginationLink, PaginationPrevious, PaginationNext, PaginationFirst, PaginationLast, PaginationEllipsis, PaginationControls, paginationLinkVariants, } from "./pagination";
|
|
2
|
+
export type { PaginationProps, PaginationContentProps, PaginationItemProps, PaginationLinkProps, PaginationPreviousProps, PaginationNextProps, PaginationFirstProps, PaginationLastProps, PaginationEllipsisProps, PaginationControlsProps, } from "./pagination";
|
|
3
|
+
export { paginationSizeIds, paginationVariantIds, paginationShapeIds, } from "./pagination-variants";
|
|
4
|
+
export type { PaginationSize, PaginationVariant, PaginationShape, } from "./pagination-variants";
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { Pagination, Pagination as default, PaginationContent, PaginationItem, PaginationLink, PaginationPrevious, PaginationNext, PaginationFirst, PaginationLast, PaginationEllipsis, PaginationControls, paginationLinkVariants, } from "./pagination";
|
|
2
|
+
export { paginationSizeIds, paginationVariantIds, paginationShapeIds, } from "./pagination-variants";
|
|
3
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/ui/pagination/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,UAAU,IAAI,OAAO,EACrB,iBAAiB,EACjB,cAAc,EACd,cAAc,EACd,kBAAkB,EAClB,cAAc,EACd,eAAe,EACf,cAAc,EACd,kBAAkB,EAClB,kBAAkB,EAClB,sBAAsB,GACvB,MAAM,cAAc,CAAC;AAatB,OAAO,EACL,iBAAiB,EACjB,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const paginationSizeIds: readonly ["sm", "default", "lg"];
|
|
2
|
+
export type PaginationSize = (typeof paginationSizeIds)[number];
|
|
3
|
+
export declare const paginationVariantIds: readonly ["default", "outline", "ghost"];
|
|
4
|
+
export type PaginationVariant = (typeof paginationVariantIds)[number];
|
|
5
|
+
export declare const paginationShapeIds: readonly ["rounded", "square", "pill"];
|
|
6
|
+
export type PaginationShape = (typeof paginationShapeIds)[number];
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export const paginationSizeIds = [
|
|
2
|
+
"sm",
|
|
3
|
+
"default",
|
|
4
|
+
"lg",
|
|
5
|
+
];
|
|
6
|
+
export const paginationVariantIds = [
|
|
7
|
+
"default",
|
|
8
|
+
"outline",
|
|
9
|
+
"ghost",
|
|
10
|
+
];
|
|
11
|
+
export const paginationShapeIds = [
|
|
12
|
+
"rounded",
|
|
13
|
+
"square",
|
|
14
|
+
"pill",
|
|
15
|
+
];
|
|
16
|
+
//# sourceMappingURL=pagination-variants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination-variants.js","sourceRoot":"","sources":["../../../../src/components/ui/pagination/pagination-variants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,IAAI;IACJ,SAAS;IACT,IAAI;CACgC,CAAC;AAGvC,MAAM,CAAC,MAAM,oBAAoB,GAAG;IAClC,SAAS;IACT,SAAS;IACT,OAAO;CAC6B,CAAC;AAGvC,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,SAAS;IACT,QAAQ;IACR,MAAM;CAC8B,CAAC"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { type ComponentPropsWithoutRef, type ReactElement, type Ref } from "react";
|
|
2
|
+
import { type VariantProps } from "class-variance-authority";
|
|
3
|
+
import { type PaginationShape, type PaginationSize, type PaginationVariant } from "./pagination-variants";
|
|
4
|
+
export interface PaginationProps extends ComponentPropsWithoutRef<"nav"> {
|
|
5
|
+
size?: PaginationSize;
|
|
6
|
+
variant?: PaginationVariant;
|
|
7
|
+
shape?: PaginationShape;
|
|
8
|
+
ref?: Ref<HTMLElement>;
|
|
9
|
+
}
|
|
10
|
+
declare function Pagination({ className, size, variant, shape, ref, ...props }: PaginationProps): ReactElement;
|
|
11
|
+
declare namespace Pagination {
|
|
12
|
+
var displayName: string;
|
|
13
|
+
}
|
|
14
|
+
export interface PaginationContentProps extends ComponentPropsWithoutRef<"ul"> {
|
|
15
|
+
ref?: Ref<HTMLUListElement>;
|
|
16
|
+
}
|
|
17
|
+
declare function PaginationContent({ className, ref, ...props }: PaginationContentProps): ReactElement;
|
|
18
|
+
declare namespace PaginationContent {
|
|
19
|
+
var displayName: string;
|
|
20
|
+
}
|
|
21
|
+
export interface PaginationItemProps extends ComponentPropsWithoutRef<"li"> {
|
|
22
|
+
ref?: Ref<HTMLLIElement>;
|
|
23
|
+
}
|
|
24
|
+
declare function PaginationItem({ className, ref, ...props }: PaginationItemProps): ReactElement;
|
|
25
|
+
declare namespace PaginationItem {
|
|
26
|
+
var displayName: string;
|
|
27
|
+
}
|
|
28
|
+
declare const paginationLinkVariants: (props?: ({
|
|
29
|
+
size?: "sm" | "default" | "lg" | null | undefined;
|
|
30
|
+
variant?: "default" | "ghost" | "outline" | null | undefined;
|
|
31
|
+
shape?: "square" | "rounded" | "pill" | null | undefined;
|
|
32
|
+
} & import("class-variance-authority/types").ClassProp) | undefined) => string;
|
|
33
|
+
export interface PaginationLinkProps extends ComponentPropsWithoutRef<"a">, VariantProps<typeof paginationLinkVariants> {
|
|
34
|
+
isActive?: boolean;
|
|
35
|
+
asChild?: boolean;
|
|
36
|
+
ref?: Ref<HTMLAnchorElement>;
|
|
37
|
+
}
|
|
38
|
+
declare function PaginationLink({ className, isActive, asChild, size, variant, shape, ref, ...props }: PaginationLinkProps): ReactElement;
|
|
39
|
+
declare namespace PaginationLink {
|
|
40
|
+
var displayName: string;
|
|
41
|
+
}
|
|
42
|
+
export interface PaginationPreviousProps extends Omit<PaginationLinkProps, "children"> {
|
|
43
|
+
label?: string;
|
|
44
|
+
showLabel?: boolean;
|
|
45
|
+
}
|
|
46
|
+
declare function PaginationPrevious({ className, label, showLabel, ...props }: PaginationPreviousProps): ReactElement;
|
|
47
|
+
declare namespace PaginationPrevious {
|
|
48
|
+
var displayName: string;
|
|
49
|
+
}
|
|
50
|
+
export interface PaginationNextProps extends Omit<PaginationLinkProps, "children"> {
|
|
51
|
+
label?: string;
|
|
52
|
+
showLabel?: boolean;
|
|
53
|
+
}
|
|
54
|
+
declare function PaginationNext({ className, label, showLabel, ...props }: PaginationNextProps): ReactElement;
|
|
55
|
+
declare namespace PaginationNext {
|
|
56
|
+
var displayName: string;
|
|
57
|
+
}
|
|
58
|
+
export interface PaginationFirstProps extends Omit<PaginationLinkProps, "children"> {
|
|
59
|
+
}
|
|
60
|
+
declare function PaginationFirst({ className, ...props }: PaginationFirstProps): ReactElement;
|
|
61
|
+
declare namespace PaginationFirst {
|
|
62
|
+
var displayName: string;
|
|
63
|
+
}
|
|
64
|
+
export interface PaginationLastProps extends Omit<PaginationLinkProps, "children"> {
|
|
65
|
+
}
|
|
66
|
+
declare function PaginationLast({ className, ...props }: PaginationLastProps): ReactElement;
|
|
67
|
+
declare namespace PaginationLast {
|
|
68
|
+
var displayName: string;
|
|
69
|
+
}
|
|
70
|
+
export interface PaginationEllipsisProps extends ComponentPropsWithoutRef<"span"> {
|
|
71
|
+
ref?: Ref<HTMLSpanElement>;
|
|
72
|
+
}
|
|
73
|
+
declare function PaginationEllipsis({ className, ref, ...props }: PaginationEllipsisProps): ReactElement;
|
|
74
|
+
declare namespace PaginationEllipsis {
|
|
75
|
+
var displayName: string;
|
|
76
|
+
}
|
|
77
|
+
export interface PaginationControlsProps extends Omit<ComponentPropsWithoutRef<"nav">, "onChange"> {
|
|
78
|
+
/** Currently selected page (1-indexed). */
|
|
79
|
+
page: number;
|
|
80
|
+
/** Total number of pages available. */
|
|
81
|
+
totalPages: number;
|
|
82
|
+
/** Called with the new 1-indexed page when the user navigates. */
|
|
83
|
+
onPageChange: (nextPage: number) => void;
|
|
84
|
+
/** Number of pages to show on each side of the current page. Defaults to 1. */
|
|
85
|
+
siblingCount?: number;
|
|
86
|
+
/** Number of pages to always show at the start and end. Defaults to 1. */
|
|
87
|
+
boundaryCount?: number;
|
|
88
|
+
/** Show first/last page jump buttons. Defaults to false. */
|
|
89
|
+
showFirstLast?: boolean;
|
|
90
|
+
/** Show previous/next buttons. Defaults to true. */
|
|
91
|
+
showPrevNext?: boolean;
|
|
92
|
+
/** Hide the textual label on previous/next, leaving only the chevron. */
|
|
93
|
+
iconOnlyPrevNext?: boolean;
|
|
94
|
+
/** Disable the entire control. */
|
|
95
|
+
disabled?: boolean;
|
|
96
|
+
size?: PaginationSize;
|
|
97
|
+
variant?: PaginationVariant;
|
|
98
|
+
shape?: PaginationShape;
|
|
99
|
+
}
|
|
100
|
+
declare function PaginationControls({ page, totalPages, onPageChange, siblingCount, boundaryCount, showFirstLast, showPrevNext, iconOnlyPrevNext, disabled, size, variant, shape, className, ...props }: PaginationControlsProps): ReactElement;
|
|
101
|
+
declare namespace PaginationControls {
|
|
102
|
+
var displayName: string;
|
|
103
|
+
}
|
|
104
|
+
export { Pagination, PaginationContent, PaginationItem, PaginationLink, PaginationPrevious, PaginationNext, PaginationFirst, PaginationLast, PaginationEllipsis, PaginationControls, paginationLinkVariants, };
|
|
105
|
+
export default Pagination;
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { createContext, useContext, useMemo, } from "react";
|
|
4
|
+
import { Slot } from "@radix-ui/react-slot";
|
|
5
|
+
import { ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight, MoreHorizontal, } from "lucide-react";
|
|
6
|
+
import { cva } from "class-variance-authority";
|
|
7
|
+
import { cn } from "../../../lib/utils";
|
|
8
|
+
const PaginationContext = createContext({
|
|
9
|
+
size: "default",
|
|
10
|
+
variant: "default",
|
|
11
|
+
shape: "rounded",
|
|
12
|
+
});
|
|
13
|
+
function usePaginationContext() {
|
|
14
|
+
return useContext(PaginationContext);
|
|
15
|
+
}
|
|
16
|
+
function Pagination({ className, size = "default", variant = "default", shape = "rounded", ref, ...props }) {
|
|
17
|
+
const contextValue = useMemo(() => ({ size, variant, shape }), [size, variant, shape]);
|
|
18
|
+
return (_jsx(PaginationContext.Provider, { value: contextValue, children: _jsx("nav", { ref: ref, role: "navigation", "aria-label": "pagination", "data-slot": "pagination", className: cn("mx-auto flex w-full justify-center", className), ...props }) }));
|
|
19
|
+
}
|
|
20
|
+
Pagination.displayName = "Pagination";
|
|
21
|
+
function PaginationContent({ className, ref, ...props }) {
|
|
22
|
+
return (_jsx("ul", { ref: ref, "data-slot": "pagination-content", className: cn("flex flex-row items-center gap-1", className), ...props }));
|
|
23
|
+
}
|
|
24
|
+
PaginationContent.displayName = "PaginationContent";
|
|
25
|
+
function PaginationItem({ className, ref, ...props }) {
|
|
26
|
+
return (_jsx("li", { ref: ref, "data-slot": "pagination-item", className: cn(className), ...props }));
|
|
27
|
+
}
|
|
28
|
+
PaginationItem.displayName = "PaginationItem";
|
|
29
|
+
const paginationLinkVariants = cva("inline-flex items-center justify-center gap-1 whitespace-nowrap font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 select-none", {
|
|
30
|
+
variants: {
|
|
31
|
+
size: {
|
|
32
|
+
sm: "h-8 min-w-8 px-2 text-xs [&_svg]:size-3.5",
|
|
33
|
+
default: "h-10 min-w-10 px-3 text-sm [&_svg]:size-4",
|
|
34
|
+
lg: "h-11 min-w-11 px-4 text-base [&_svg]:size-5",
|
|
35
|
+
},
|
|
36
|
+
variant: {
|
|
37
|
+
default: "text-foreground hover:bg-accent hover:text-accent-foreground data-[active=true]:bg-primary data-[active=true]:text-primary-foreground data-[active=true]:hover:bg-primary/90",
|
|
38
|
+
outline: "border border-input bg-background text-foreground hover:bg-accent hover:text-accent-foreground data-[active=true]:border-primary data-[active=true]:bg-primary data-[active=true]:text-primary-foreground data-[active=true]:hover:bg-primary/90",
|
|
39
|
+
ghost: "text-muted-foreground hover:bg-accent hover:text-accent-foreground data-[active=true]:bg-accent data-[active=true]:text-accent-foreground data-[active=true]:font-semibold",
|
|
40
|
+
},
|
|
41
|
+
shape: {
|
|
42
|
+
rounded: "rounded-md",
|
|
43
|
+
square: "rounded-none",
|
|
44
|
+
pill: "rounded-full",
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
defaultVariants: {
|
|
48
|
+
size: "default",
|
|
49
|
+
variant: "default",
|
|
50
|
+
shape: "rounded",
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
function PaginationLink({ className, isActive = false, asChild = false, size, variant, shape, ref, ...props }) {
|
|
54
|
+
const ctx = usePaginationContext();
|
|
55
|
+
const Comp = asChild ? Slot : "a";
|
|
56
|
+
return (_jsx(Comp, { ref: ref, "aria-current": isActive ? "page" : undefined, "data-slot": "pagination-link", "data-active": isActive ? "true" : undefined, className: cn(paginationLinkVariants({
|
|
57
|
+
size: size ?? ctx.size,
|
|
58
|
+
variant: variant ?? ctx.variant,
|
|
59
|
+
shape: shape ?? ctx.shape,
|
|
60
|
+
}), className), ...props }));
|
|
61
|
+
}
|
|
62
|
+
PaginationLink.displayName = "PaginationLink";
|
|
63
|
+
function PaginationPrevious({ className, label = "Previous", showLabel = true, ...props }) {
|
|
64
|
+
return (_jsxs(PaginationLink, { "aria-label": "Go to previous page", className: cn(showLabel ? "px-2.5" : undefined, className), ...props, children: [_jsx(ChevronLeft, { "aria-hidden": "true" }), showLabel ? _jsx("span", { children: label }) : null] }));
|
|
65
|
+
}
|
|
66
|
+
PaginationPrevious.displayName = "PaginationPrevious";
|
|
67
|
+
function PaginationNext({ className, label = "Next", showLabel = true, ...props }) {
|
|
68
|
+
return (_jsxs(PaginationLink, { "aria-label": "Go to next page", className: cn(showLabel ? "px-2.5" : undefined, className), ...props, children: [showLabel ? _jsx("span", { children: label }) : null, _jsx(ChevronRight, { "aria-hidden": "true" })] }));
|
|
69
|
+
}
|
|
70
|
+
PaginationNext.displayName = "PaginationNext";
|
|
71
|
+
function PaginationFirst({ className, ...props }) {
|
|
72
|
+
return (_jsx(PaginationLink, { "aria-label": "Go to first page", className: className, ...props, children: _jsx(ChevronsLeft, { "aria-hidden": "true" }) }));
|
|
73
|
+
}
|
|
74
|
+
PaginationFirst.displayName = "PaginationFirst";
|
|
75
|
+
function PaginationLast({ className, ...props }) {
|
|
76
|
+
return (_jsx(PaginationLink, { "aria-label": "Go to last page", className: className, ...props, children: _jsx(ChevronsRight, { "aria-hidden": "true" }) }));
|
|
77
|
+
}
|
|
78
|
+
PaginationLast.displayName = "PaginationLast";
|
|
79
|
+
function PaginationEllipsis({ className, ref, ...props }) {
|
|
80
|
+
const ctx = usePaginationContext();
|
|
81
|
+
const sizeClass = ctx.size === "sm"
|
|
82
|
+
? "h-8 min-w-8 [&_svg]:size-3.5"
|
|
83
|
+
: ctx.size === "lg"
|
|
84
|
+
? "h-11 min-w-11 [&_svg]:size-5"
|
|
85
|
+
: "h-10 min-w-10 [&_svg]:size-4";
|
|
86
|
+
return (_jsxs("span", { ref: ref, role: "presentation", "aria-hidden": "true", "data-slot": "pagination-ellipsis", className: cn("flex items-center justify-center text-muted-foreground", sizeClass, className), ...props, children: [_jsx(MoreHorizontal, {}), _jsx("span", { className: "sr-only", children: "More pages" })] }));
|
|
87
|
+
}
|
|
88
|
+
PaginationEllipsis.displayName = "PaginationEllipsis";
|
|
89
|
+
function buildPageList(page, totalPages, siblingCount, boundaryCount) {
|
|
90
|
+
const totalNumbers = siblingCount * 2 + boundaryCount * 2 + 3;
|
|
91
|
+
if (totalPages <= totalNumbers) {
|
|
92
|
+
return Array.from({ length: totalPages }, (_, i) => ({
|
|
93
|
+
kind: "page",
|
|
94
|
+
page: i + 1,
|
|
95
|
+
}));
|
|
96
|
+
}
|
|
97
|
+
const startPages = Array.from({ length: boundaryCount }, (_, i) => i + 1);
|
|
98
|
+
const endPages = Array.from({ length: boundaryCount }, (_, i) => totalPages - boundaryCount + i + 1);
|
|
99
|
+
const siblingsStart = Math.max(Math.min(page - siblingCount, totalPages - boundaryCount - siblingCount * 2 - 1), boundaryCount + 2);
|
|
100
|
+
const siblingsEnd = Math.min(Math.max(page + siblingCount, boundaryCount + siblingCount * 2 + 2), endPages.length > 0 ? endPages[0] - 2 : totalPages - 1);
|
|
101
|
+
const items = [];
|
|
102
|
+
for (const p of startPages) {
|
|
103
|
+
items.push({ kind: "page", page: p });
|
|
104
|
+
}
|
|
105
|
+
if (siblingsStart > boundaryCount + 2) {
|
|
106
|
+
items.push({ kind: "ellipsis", key: "start-ellipsis" });
|
|
107
|
+
}
|
|
108
|
+
else if (boundaryCount + 1 < totalPages - boundaryCount) {
|
|
109
|
+
items.push({ kind: "page", page: boundaryCount + 1 });
|
|
110
|
+
}
|
|
111
|
+
for (let p = siblingsStart; p <= siblingsEnd; p++) {
|
|
112
|
+
items.push({ kind: "page", page: p });
|
|
113
|
+
}
|
|
114
|
+
if (siblingsEnd < totalPages - boundaryCount - 1) {
|
|
115
|
+
items.push({ kind: "ellipsis", key: "end-ellipsis" });
|
|
116
|
+
}
|
|
117
|
+
else if (totalPages - boundaryCount > boundaryCount) {
|
|
118
|
+
items.push({ kind: "page", page: totalPages - boundaryCount });
|
|
119
|
+
}
|
|
120
|
+
for (const p of endPages) {
|
|
121
|
+
items.push({ kind: "page", page: p });
|
|
122
|
+
}
|
|
123
|
+
const seen = new Set();
|
|
124
|
+
return items.filter((entry) => {
|
|
125
|
+
if (entry.kind === "ellipsis")
|
|
126
|
+
return true;
|
|
127
|
+
if (seen.has(entry.page))
|
|
128
|
+
return false;
|
|
129
|
+
seen.add(entry.page);
|
|
130
|
+
return true;
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
function PaginationControls({ page, totalPages, onPageChange, siblingCount = 1, boundaryCount = 1, showFirstLast = false, showPrevNext = true, iconOnlyPrevNext = false, disabled = false, size, variant, shape, className, ...props }) {
|
|
134
|
+
const safeTotal = Math.max(1, Math.floor(totalPages));
|
|
135
|
+
const safePage = Math.min(Math.max(1, Math.floor(page)), safeTotal);
|
|
136
|
+
const pages = useMemo(() => buildPageList(safePage, safeTotal, Math.max(0, siblingCount), Math.max(0, boundaryCount)), [safePage, safeTotal, siblingCount, boundaryCount]);
|
|
137
|
+
const isFirst = safePage <= 1;
|
|
138
|
+
const isLast = safePage >= safeTotal;
|
|
139
|
+
const goTo = (target) => {
|
|
140
|
+
if (disabled)
|
|
141
|
+
return;
|
|
142
|
+
const clamped = Math.min(Math.max(1, target), safeTotal);
|
|
143
|
+
if (clamped === safePage)
|
|
144
|
+
return;
|
|
145
|
+
onPageChange(clamped);
|
|
146
|
+
};
|
|
147
|
+
return (_jsx(Pagination, { size: size, variant: variant, shape: shape, className: className, ...props, children: _jsxs(PaginationContent, { children: [showFirstLast ? (_jsx(PaginationItem, { children: _jsx(PaginationFirst, { href: "#", "aria-disabled": disabled || isFirst, tabIndex: disabled || isFirst ? -1 : undefined, onClick: (e) => {
|
|
148
|
+
e.preventDefault();
|
|
149
|
+
if (!isFirst)
|
|
150
|
+
goTo(1);
|
|
151
|
+
} }) })) : null, showPrevNext ? (_jsx(PaginationItem, { children: _jsx(PaginationPrevious, { href: "#", "aria-disabled": disabled || isFirst, tabIndex: disabled || isFirst ? -1 : undefined, showLabel: !iconOnlyPrevNext, onClick: (e) => {
|
|
152
|
+
e.preventDefault();
|
|
153
|
+
if (!isFirst)
|
|
154
|
+
goTo(safePage - 1);
|
|
155
|
+
} }) })) : null, pages.map((entry) => entry.kind === "ellipsis" ? (_jsx(PaginationItem, { children: _jsx(PaginationEllipsis, {}) }, entry.key)) : (_jsx(PaginationItem, { children: _jsx(PaginationLink, { href: "#", isActive: entry.page === safePage, "aria-disabled": disabled || undefined, tabIndex: disabled ? -1 : undefined, onClick: (e) => {
|
|
156
|
+
e.preventDefault();
|
|
157
|
+
goTo(entry.page);
|
|
158
|
+
}, children: entry.page }) }, entry.page))), showPrevNext ? (_jsx(PaginationItem, { children: _jsx(PaginationNext, { href: "#", "aria-disabled": disabled || isLast, tabIndex: disabled || isLast ? -1 : undefined, showLabel: !iconOnlyPrevNext, onClick: (e) => {
|
|
159
|
+
e.preventDefault();
|
|
160
|
+
if (!isLast)
|
|
161
|
+
goTo(safePage + 1);
|
|
162
|
+
} }) })) : null, showFirstLast ? (_jsx(PaginationItem, { children: _jsx(PaginationLast, { href: "#", "aria-disabled": disabled || isLast, tabIndex: disabled || isLast ? -1 : undefined, onClick: (e) => {
|
|
163
|
+
e.preventDefault();
|
|
164
|
+
if (!isLast)
|
|
165
|
+
goTo(safeTotal);
|
|
166
|
+
} }) })) : null] }) }));
|
|
167
|
+
}
|
|
168
|
+
PaginationControls.displayName = "PaginationControls";
|
|
169
|
+
export { Pagination, PaginationContent, PaginationItem, PaginationLink, PaginationPrevious, PaginationNext, PaginationFirst, PaginationLast, PaginationEllipsis, PaginationControls, paginationLinkVariants, };
|
|
170
|
+
export default Pagination;
|
|
171
|
+
//# sourceMappingURL=pagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination.js","sourceRoot":"","sources":["../../../../src/components/ui/pagination/pagination.tsx"],"names":[],"mappings":"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"}
|