@s-hirano-ist/s-ui 1.19.9 → 1.19.10
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/dev/profiler-wrapper.d.ts +1 -1
- package/dist/dev/profiler-wrapper.d.ts.map +1 -1
- package/dist/dev/profiler-wrapper.js +4 -4
- package/dist/dev/profiler-wrapper.js.map +1 -1
- package/dist/display/loading.d.ts +1 -1
- package/dist/display/loading.d.ts.map +1 -1
- package/dist/display/status/status-code-view.d.ts +1 -1
- package/dist/display/status/status-code-view.d.ts.map +1 -1
- package/dist/display/status/status-code-view.js +1 -1
- package/dist/display/status/status-code-view.js.map +1 -1
- package/dist/forms/fields/form-dropdown-input.d.ts +1 -1
- package/dist/forms/fields/form-dropdown-input.d.ts.map +1 -1
- package/dist/forms/fields/form-dropdown-input.js +8 -2
- package/dist/forms/fields/form-dropdown-input.js.map +1 -1
- package/dist/forms/fields/form-file-input.d.ts +1 -1
- package/dist/forms/fields/form-file-input.d.ts.map +1 -1
- package/dist/forms/fields/form-input-with-button.d.ts +1 -1
- package/dist/forms/fields/form-input-with-button.d.ts.map +1 -1
- package/dist/forms/fields/form-input.d.ts +1 -1
- package/dist/forms/fields/form-input.d.ts.map +1 -1
- package/dist/forms/fields/form-textarea.d.ts +1 -1
- package/dist/forms/fields/form-textarea.d.ts.map +1 -1
- package/dist/forms/generic-form-wrapper.d.ts +1 -1
- package/dist/forms/generic-form-wrapper.d.ts.map +1 -1
- package/dist/forms/generic-form-wrapper.js +13 -7
- package/dist/forms/generic-form-wrapper.js.map +1 -1
- package/dist/layouts/body/viewer-body.d.ts +2 -2
- package/dist/layouts/body/viewer-body.d.ts.map +1 -1
- package/dist/layouts/body/viewer-body.js +8 -5
- package/dist/layouts/body/viewer-body.js.map +1 -1
- package/dist/providers/theme-provider.d.ts +2 -2
- package/dist/providers/theme-provider.d.ts.map +1 -1
- package/dist/providers/theme-provider.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/ui/badge.d.ts +4 -4
- package/dist/ui/badge.d.ts.map +1 -1
- package/dist/ui/badge.js +1 -1
- package/dist/ui/badge.js.map +1 -1
- package/dist/ui/button.d.ts +3 -3
- package/dist/ui/button.d.ts.map +1 -1
- package/dist/ui/button.js +6 -6
- package/dist/ui/button.js.map +1 -1
- package/dist/ui/card.d.ts +6 -6
- package/dist/ui/card.d.ts.map +1 -1
- package/dist/ui/card.js +2 -2
- package/dist/ui/card.js.map +1 -1
- package/dist/ui/command.d.ts +9 -9
- package/dist/ui/command.d.ts.map +1 -1
- package/dist/ui/command.js +5 -5
- package/dist/ui/command.js.map +1 -1
- package/dist/ui/dialog.d.ts +9 -9
- package/dist/ui/dialog.d.ts.map +1 -1
- package/dist/ui/dialog.js +4 -4
- package/dist/ui/dialog.js.map +1 -1
- package/dist/ui/drawer.d.ts +10 -10
- package/dist/ui/drawer.d.ts.map +1 -1
- package/dist/ui/drawer.js +1 -1
- package/dist/ui/drawer.js.map +1 -1
- package/dist/ui/dropdown-menu.d.ts +7 -7
- package/dist/ui/dropdown-menu.d.ts.map +1 -1
- package/dist/ui/dropdown-menu.js +3 -3
- package/dist/ui/dropdown-menu.js.map +1 -1
- package/dist/ui/input.d.ts +1 -1
- package/dist/ui/input.d.ts.map +1 -1
- package/dist/ui/input.js +1 -1
- package/dist/ui/input.js.map +1 -1
- package/dist/ui/label.d.ts +3 -3
- package/dist/ui/label.d.ts.map +1 -1
- package/dist/ui/label.js +1 -1
- package/dist/ui/label.js.map +1 -1
- package/dist/ui/pagination.d.ts +8 -8
- package/dist/ui/pagination.d.ts.map +1 -1
- package/dist/ui/pagination.js.map +1 -1
- package/dist/ui/popover.d.ts +2 -2
- package/dist/ui/popover.d.ts.map +1 -1
- package/dist/ui/popover.js +1 -1
- package/dist/ui/popover.js.map +1 -1
- package/dist/ui/rating.d.ts +1 -1
- package/dist/ui/rating.d.ts.map +1 -1
- package/dist/ui/rating.js +3 -1
- package/dist/ui/rating.js.map +1 -1
- package/dist/ui/slider.d.ts +1 -1
- package/dist/ui/slider.d.ts.map +1 -1
- package/dist/ui/slider.js.map +1 -1
- package/dist/ui/sonner.d.ts +1 -1
- package/dist/ui/sonner.d.ts.map +1 -1
- package/dist/ui/stat.d.ts +4 -4
- package/dist/ui/stat.d.ts.map +1 -1
- package/dist/ui/stat.js +3 -3
- package/dist/ui/stat.js.map +1 -1
- package/dist/ui/tabs.d.ts +4 -4
- package/dist/ui/tabs.d.ts.map +1 -1
- package/dist/ui/tabs.js +3 -3
- package/dist/ui/tabs.js.map +1 -1
- package/dist/ui/textarea.d.ts +1 -1
- package/dist/ui/textarea.d.ts.map +1 -1
- package/dist/ui/textarea.js +1 -1
- package/dist/ui/textarea.js.map +1 -1
- package/dist/utils/haptic.js +6 -6
- package/dist/utils/haptic.js.map +1 -1
- package/package.json +10 -10
|
@@ -20,6 +20,6 @@ type ProfilerWrapperProps = {
|
|
|
20
20
|
* Development-only React Profiler wrapper.
|
|
21
21
|
* When `enabled` is false (default in production), renders children directly with zero overhead.
|
|
22
22
|
*/
|
|
23
|
-
export declare function ProfilerWrapper({ children, enabled, ...rest }: ProfilerWrapperProps): string | number | bigint | boolean | import("react
|
|
23
|
+
export declare function ProfilerWrapper({ children, enabled, ...rest }: ProfilerWrapperProps): string | number | bigint | boolean | import("react").JSX.Element | Iterable<import("react").ReactNode> | Promise<string | number | bigint | boolean | import("react").ReactPortal | import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | Iterable<import("react").ReactNode> | null | undefined> | null | undefined;
|
|
24
24
|
export {};
|
|
25
25
|
//# sourceMappingURL=profiler-wrapper.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"profiler-wrapper.d.ts","sourceRoot":"","sources":["../../dev/profiler-wrapper.tsx"],"names":[],"mappings":"AAIA,MAAM,MAAM,cAAc,GAAG;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,OAAO,GAAG,QAAQ,GAAG,eAAe,CAAC;IAC5C,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,KAAK,oBAAoB,GAAG;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,kFAAkF;IAClF,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,oEAAoE;IACpE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6CAA6C;IAC7C,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,KAAK,IAAI,CAAC;IAC7C,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B,CAAC;AA+CF;;;GAGG;AACH,wBAAgB,eAAe,CAAC,EAC/B,QAAQ,EACR,OAAc,EACd,GAAG,IAAI,EACP,EAAE,oBAAoB
|
|
1
|
+
{"version":3,"file":"profiler-wrapper.d.ts","sourceRoot":"","sources":["../../dev/profiler-wrapper.tsx"],"names":[],"mappings":"AAIA,MAAM,MAAM,cAAc,GAAG;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,OAAO,GAAG,QAAQ,GAAG,eAAe,CAAC;IAC5C,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,KAAK,oBAAoB,GAAG;IAC3B,EAAE,EAAE,MAAM,CAAC;IACX,kFAAkF;IAClF,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,oEAAoE;IACpE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6CAA6C;IAC7C,SAAS,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,KAAK,IAAI,CAAC;IAC7C,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC1B,CAAC;AA+CF;;;GAGG;AACH,wBAAgB,eAAe,CAAC,EAC/B,QAAQ,EACR,OAAc,EACd,GAAG,IAAI,EACP,EAAE,oBAAoB,+VAMtB"}
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
3
|
import { Profiler } from "react";
|
|
4
4
|
function DevProfilerWrapper({ id, threshold = 16, onCollect, children, }) {
|
|
5
|
-
const onRender = (
|
|
5
|
+
const onRender = (renderedId, phase, actualDuration, baseDuration, startTime, commitTime) => {
|
|
6
6
|
const result = {
|
|
7
|
-
id,
|
|
7
|
+
id: renderedId,
|
|
8
8
|
phase,
|
|
9
9
|
actualDuration,
|
|
10
10
|
baseDuration,
|
|
@@ -15,10 +15,10 @@ function DevProfilerWrapper({ id, threshold = 16, onCollect, children, }) {
|
|
|
15
15
|
onCollect(result);
|
|
16
16
|
}
|
|
17
17
|
if (actualDuration > threshold) {
|
|
18
|
-
console.warn(`[Profiler] ${
|
|
18
|
+
console.warn(`[Profiler] ${renderedId} ${phase}: ${actualDuration.toFixed(1)}ms (threshold: ${threshold}ms)`);
|
|
19
19
|
}
|
|
20
20
|
else {
|
|
21
|
-
console.debug(`[Profiler] ${
|
|
21
|
+
console.debug(`[Profiler] ${renderedId} ${phase}: ${actualDuration.toFixed(1)}ms`);
|
|
22
22
|
}
|
|
23
23
|
};
|
|
24
24
|
return (_jsx(Profiler, { id: id, onRender: onRender, children: children }));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"profiler-wrapper.js","sourceRoot":"","sources":["../../dev/profiler-wrapper.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,QAAQ,EAAiC,MAAM,OAAO,CAAC;AAsBhE,SAAS,kBAAkB,CAAC,EAC3B,EAAE,EACF,SAAS,GAAG,EAAE,EACd,SAAS,EACT,QAAQ,GACc;IACtB,MAAM,QAAQ,GAA6B,CAC1C,
|
|
1
|
+
{"version":3,"file":"profiler-wrapper.js","sourceRoot":"","sources":["../../dev/profiler-wrapper.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,QAAQ,EAAiC,MAAM,OAAO,CAAC;AAsBhE,SAAS,kBAAkB,CAAC,EAC3B,EAAE,EACF,SAAS,GAAG,EAAE,EACd,SAAS,EACT,QAAQ,GACc;IACtB,MAAM,QAAQ,GAA6B,CAC1C,UAAU,EACV,KAAK,EACL,cAAc,EACd,YAAY,EACZ,SAAS,EACT,UAAU,EACT,EAAE;QACH,MAAM,MAAM,GAAmB;YAC9B,EAAE,EAAE,UAAU;YACd,KAAK;YACL,cAAc;YACd,YAAY;YACZ,SAAS;YACT,UAAU;SACV,CAAC;QAEF,IAAI,SAAS,EAAE,CAAC;YACf,SAAS,CAAC,MAAM,CAAC,CAAC;QACnB,CAAC;QAED,IAAI,cAAc,GAAG,SAAS,EAAE,CAAC;YAChC,OAAO,CAAC,IAAI,CACX,cAAc,UAAU,IAAI,KAAK,KAAK,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,kBAAkB,SAAS,KAAK,CAC/F,CAAC;QACH,CAAC;aAAM,CAAC;YACP,OAAO,CAAC,KAAK,CACZ,cAAc,UAAU,IAAI,KAAK,KAAK,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACnE,CAAC;QACH,CAAC;IACF,CAAC,CAAC;IAEF,OAAO,CACN,KAAC,QAAQ,IAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,QAAQ,YAClC,QAAQ,GACC,CACX,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,EAC/B,QAAQ,EACR,OAAO,GAAG,IAAI,EACd,GAAG,IAAI,EACe;IACtB,IAAI,CAAC,OAAO,EAAE,CAAC;QACd,OAAO,QAAQ,CAAC;IACjB,CAAC;IAED,OAAO,KAAC,kBAAkB,OAAK,IAAI,YAAG,QAAQ,GAAsB,CAAC;AACtE,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"loading.d.ts","sourceRoot":"","sources":["../../display/loading.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,iBAAS,OAAO,
|
|
1
|
+
{"version":3,"file":"loading.d.ts","sourceRoot":"","sources":["../../display/loading.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,iBAAS,OAAO,gCAQf;AAED,eAAe,OAAO,CAAC"}
|
|
@@ -29,5 +29,5 @@ export type StatusCode = "000" | "204" | "403" | "404" | "500";
|
|
|
29
29
|
export declare function StatusCodeView({ statusCode, statusCodeString, }: {
|
|
30
30
|
statusCode: StatusCode;
|
|
31
31
|
statusCodeString: string;
|
|
32
|
-
}): import("react
|
|
32
|
+
}): import("react").JSX.Element;
|
|
33
33
|
//# sourceMappingURL=status-code-view.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"status-code-view.d.ts","sourceRoot":"","sources":["../../../display/status/status-code-view.tsx"],"names":[],"mappings":"AAWA;;;;;;;;;GASG;AACH,MAAM,MAAM,UAAU,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;AAU/D;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,cAAc,CAAC,EAC9B,UAAU,EACV,gBAAgB,GAChB,EAAE;IACF,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;CACzB
|
|
1
|
+
{"version":3,"file":"status-code-view.d.ts","sourceRoot":"","sources":["../../../display/status/status-code-view.tsx"],"names":[],"mappings":"AAWA;;;;;;;;;GASG;AACH,MAAM,MAAM,UAAU,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;AAU/D;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,cAAc,CAAC,EAC9B,UAAU,EACV,gBAAgB,GAChB,EAAE;IACF,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;CACzB,+BAeA"}
|
|
@@ -26,6 +26,6 @@ const STATUS_ICON_MAP = {
|
|
|
26
26
|
* ```
|
|
27
27
|
*/
|
|
28
28
|
export function StatusCodeView({ statusCode, statusCodeString, }) {
|
|
29
|
-
return (_jsxs("div", { className: "flex animate-[card-enter_300ms_ease-out_both] flex-col items-center gap-3 py-12", "data-testid": "status-code-view", children: [_jsx("div", { className: "rounded-full bg-primary/10 p-4", children: STATUS_ICON_MAP[statusCode] }), _jsx("div", { className: "bg-linear-to-r from-primary to-primary-grad bg-clip-text font-black
|
|
29
|
+
return (_jsxs("div", { className: "flex animate-[card-enter_300ms_ease-out_both] flex-col items-center gap-3 py-12", "data-testid": "status-code-view", children: [_jsx("div", { className: "rounded-full bg-primary/10 p-4", children: STATUS_ICON_MAP[statusCode] }), _jsx("div", { className: "bg-linear-to-r from-primary to-primary-grad bg-clip-text text-8xl font-black tracking-tighter text-transparent", children: statusCode }), _jsx("div", { className: "text-base text-muted-foreground", children: statusCodeString })] }));
|
|
30
30
|
}
|
|
31
31
|
//# sourceMappingURL=status-code-view.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"status-code-view.js","sourceRoot":"","sources":["../../../display/status/status-code-view.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;
|
|
1
|
+
{"version":3,"file":"status-code-view.js","sourceRoot":"","sources":["../../../display/status/status-code-view.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EACN,iBAAiB,EACjB,SAAS,EACT,SAAS,EACT,WAAW,EACX,WAAW,GACX,MAAM,cAAc,CAAC;AActB,MAAM,eAAe,GAAkC;IACtD,KAAK,EAAE,KAAC,SAAS,IAAC,SAAS,EAAC,qBAAqB,GAAG;IACpD,KAAK,EAAE,KAAC,SAAS,IAAC,SAAS,EAAC,qBAAqB,GAAG;IACpD,KAAK,EAAE,KAAC,WAAW,IAAC,SAAS,EAAC,qBAAqB,GAAG;IACtD,KAAK,EAAE,KAAC,WAAW,IAAC,SAAS,EAAC,qBAAqB,GAAG;IACtD,KAAK,EAAE,KAAC,iBAAiB,IAAC,SAAS,EAAC,qBAAqB,GAAG;CAC5D,CAAC;AAEF;;;;;;;;;;;;;;;;GAgBG;AACH,MAAM,UAAU,cAAc,CAAC,EAC9B,UAAU,EACV,gBAAgB,GAIhB;IACA,OAAO,CACN,eACC,SAAS,EAAC,iFAAiF,iBAC/E,kBAAkB,aAE9B,cAAK,SAAS,EAAC,gCAAgC,YAC7C,eAAe,CAAC,UAAU,CAAC,GACvB,EACN,cAAK,SAAS,EAAC,gHAAgH,YAC7H,UAAU,GACN,EACN,cAAK,SAAS,EAAC,iCAAiC,YAAE,gBAAgB,GAAO,IACpE,CACN,CAAC;AACH,CAAC"}
|
|
@@ -75,5 +75,5 @@ export type Props = {
|
|
|
75
75
|
*
|
|
76
76
|
* @see {@link GenericFormWrapper} for form integration
|
|
77
77
|
*/
|
|
78
|
-
export declare function FormDropdownInput({ label, htmlFor, options, inputRef, placeholder, name, required, disabled, emptyMessage, searchPlaceholder, customValueLabel, }: Props): import("react
|
|
78
|
+
export declare function FormDropdownInput({ label, htmlFor, options, inputRef, placeholder, name, required, disabled, emptyMessage, searchPlaceholder, customValueLabel, }: Props): import("react").JSX.Element;
|
|
79
79
|
//# sourceMappingURL=form-dropdown-input.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-dropdown-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-dropdown-input.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,SAAS,
|
|
1
|
+
{"version":3,"file":"form-dropdown-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-dropdown-input.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,SAAS,EAAmB,MAAM,OAAO,CAAC;AAgBxD;;;;;;;;GAQG;AACH,MAAM,MAAM,KAAK,GAAG;IACnB,kDAAkD;IAClD,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,gDAAgD;IAChD,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IACxC,sDAAsD;IACtD,QAAQ,CAAC,EAAE,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;IAC9C,iDAAiD;IACjD,WAAW,EAAE,MAAM,CAAC;IACpB,gEAAgE;IAChE,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,oCAAoC;IACpC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,oCAAoC;IACpC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,qDAAqD;IACrD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,4CAA4C;IAC5C,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,uDAAuD;IACvD,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;CAC7C,CAAC;AAOF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,wBAAgB,iBAAiB,CAAC,EACjC,KAAK,EACL,OAAO,EACP,OAAO,EACP,QAAQ,EACR,WAAW,EACX,IAAI,EACJ,QAAQ,EACR,QAAQ,EACR,YAAoC,EACpC,iBAA8C,EAC9C,gBAA6C,GAC7C,EAAE,KAAK,+BAsHP"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
3
|
import { CheckIcon, ChevronsUpDownIcon } from "lucide-react";
|
|
4
|
-
import { useState } from "react";
|
|
4
|
+
import { useId, useState } from "react";
|
|
5
5
|
import { Button } from "../../ui/button";
|
|
6
6
|
import { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, } from "../../ui/command";
|
|
7
7
|
import { Label } from "../../ui/label";
|
|
@@ -56,17 +56,23 @@ const DEFAULT_CUSTOM_VALUE_LABEL = (v) => `Use "${v}"`;
|
|
|
56
56
|
export function FormDropdownInput({ label, htmlFor, options, inputRef, placeholder, name, required, disabled, emptyMessage = DEFAULT_EMPTY_MESSAGE, searchPlaceholder = DEFAULT_SEARCH_PLACEHOLDER, customValueLabel = DEFAULT_CUSTOM_VALUE_LABEL, }) {
|
|
57
57
|
const [open, setOpen] = useState(false);
|
|
58
58
|
const [searchValue, setSearchValue] = useState("");
|
|
59
|
+
const listboxId = useId();
|
|
59
60
|
const formValues = useFormValues();
|
|
60
61
|
const fieldName = name || htmlFor;
|
|
61
62
|
const preservedValue = formValues[fieldName];
|
|
62
63
|
// Local state is necessary because FormValuesContext is read-only.
|
|
63
64
|
// The context only provides values for restoration after form submission errors.
|
|
65
|
+
// `formValues` is a Record<string, string> whose keys are runtime-driven; an absent
|
|
66
|
+
// `fieldName` yields `undefined` at runtime despite the declared `string` type.
|
|
67
|
+
// oxlint-disable-next-line typescript/no-unnecessary-condition -- runtime key may be absent
|
|
64
68
|
const [value, setValue] = useState(() => preservedValue ?? "");
|
|
65
69
|
const [prevPreservedValue, setPrevPreservedValue] = useState(preservedValue);
|
|
66
70
|
// Sync context value to local state when context changes (e.g., after form error).
|
|
67
71
|
// This follows React's pattern for adjusting state when props change.
|
|
68
72
|
if (preservedValue !== prevPreservedValue) {
|
|
69
73
|
setPrevPreservedValue(preservedValue);
|
|
74
|
+
// `preservedValue` can be `undefined` at runtime when the form key is absent.
|
|
75
|
+
// oxlint-disable-next-line typescript/no-unnecessary-condition -- runtime value may be undefined
|
|
70
76
|
if (preservedValue !== undefined) {
|
|
71
77
|
setValue(preservedValue);
|
|
72
78
|
}
|
|
@@ -84,6 +90,6 @@ export function FormDropdownInput({ label, htmlFor, options, inputRef, placehold
|
|
|
84
90
|
setOpen(false);
|
|
85
91
|
}
|
|
86
92
|
};
|
|
87
|
-
return (_jsxs("div", { className: "space-y-1", children: [_jsx(Label, { htmlFor: htmlFor, children: label }), _jsxs(Popover, { onOpenChange: setOpen, open: open, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { "aria-expanded": open, "aria-label": label, className: "w-full justify-between", disabled: disabled, role: "combobox", variant: "outline", children: [value || placeholder, _jsx(ChevronsUpDownIcon, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-[var(--radix-popover-trigger-width)] p-0", children: _jsxs(Command, { shouldFilter: true, children: [_jsx(CommandInput, { onValueChange: setSearchValue, placeholder: searchPlaceholder, value: searchValue }), _jsxs(CommandList, { children: [_jsx(CommandEmpty, { children: searchValue ? (_jsx("button", { className: "w-full text-left hover:underline", onClick: handleCustomValue, type: "button", children: customValueLabel(searchValue) })) : (emptyMessage) }), _jsx(CommandGroup, { children: options.map((option) => (_jsxs(CommandItem, { onSelect: () => handleSelect(option.name), value: option.name, children: [_jsx(CheckIcon, { className: cn("mr-2 h-4 w-4", value === option.name ? "opacity-100" : "opacity-0") }), option.name] }, option.id))) })] })] }) })] }), _jsx("input", { id: htmlFor, name: fieldName, ref: inputRef, required: required, type: "hidden", value: value })] }));
|
|
93
|
+
return (_jsxs("div", { className: "space-y-1", children: [_jsx(Label, { htmlFor: htmlFor, children: label }), _jsxs(Popover, { onOpenChange: setOpen, open: open, children: [_jsx(PopoverTrigger, { asChild: true, children: _jsxs(Button, { "aria-controls": listboxId, "aria-expanded": open, "aria-label": label, className: "w-full justify-between", disabled: disabled, role: "combobox", variant: "outline", children: [value || placeholder, _jsx(ChevronsUpDownIcon, { className: "ml-2 h-4 w-4 shrink-0 opacity-50" })] }) }), _jsx(PopoverContent, { className: "w-[var(--radix-popover-trigger-width)] p-0", children: _jsxs(Command, { shouldFilter: true, children: [_jsx(CommandInput, { onValueChange: setSearchValue, placeholder: searchPlaceholder, value: searchValue }), _jsxs(CommandList, { id: listboxId, children: [_jsx(CommandEmpty, { children: searchValue ? (_jsx("button", { className: "w-full text-left hover:underline", onClick: handleCustomValue, type: "button", children: customValueLabel(searchValue) })) : (emptyMessage) }), _jsx(CommandGroup, { children: options.map((option) => (_jsxs(CommandItem, { onSelect: () => handleSelect(option.name), value: option.name, children: [_jsx(CheckIcon, { className: cn("mr-2 h-4 w-4", value === option.name ? "opacity-100" : "opacity-0") }), option.name] }, option.id))) })] })] }) })] }), _jsx("input", { id: htmlFor, name: fieldName, ref: inputRef, required: required, type: "hidden", value: value })] }));
|
|
88
94
|
}
|
|
89
95
|
//# sourceMappingURL=form-dropdown-input.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-dropdown-input.js","sourceRoot":"","sources":["../../../forms/fields/form-dropdown-input.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAC7D,OAAO,EAAkB,QAAQ,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"form-dropdown-input.js","sourceRoot":"","sources":["../../../forms/fields/form-dropdown-input.tsx"],"names":[],"mappings":"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"}
|
|
@@ -32,5 +32,5 @@ export type FormFileInputProps = {
|
|
|
32
32
|
* />
|
|
33
33
|
* ```
|
|
34
34
|
*/
|
|
35
|
-
export declare function FormFileInput({ label, htmlFor, ...inputProps }: FormFileInputProps): import("react
|
|
35
|
+
export declare function FormFileInput({ label, htmlFor, ...inputProps }: FormFileInputProps): import("react").JSX.Element;
|
|
36
36
|
//# sourceMappingURL=form-file-input.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-file-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-file-input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAGvC;;;;GAIG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAChC,oDAAoD;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjC;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,aAAa,CAAC,EAC7B,KAAK,EACL,OAAO,EACP,GAAG,UAAU,EACb,EAAE,kBAAkB
|
|
1
|
+
{"version":3,"file":"form-file-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-file-input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAGvC;;;;GAIG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAChC,oDAAoD;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjC;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,aAAa,CAAC,EAC7B,KAAK,EACL,OAAO,EACP,GAAG,UAAU,EACb,EAAE,kBAAkB,+BAOpB"}
|
|
@@ -50,5 +50,5 @@ export type FormInputWithButtonProps = {
|
|
|
50
50
|
*
|
|
51
51
|
* @see {@link GenericFormWrapper} for form integration
|
|
52
52
|
*/
|
|
53
|
-
export declare function FormInputWithButton({ label, htmlFor, buttonIcon, onButtonClick, inputRef, buttonTestId, buttonAriaLabel, defaultValue, ...inputProps }: FormInputWithButtonProps): import("react
|
|
53
|
+
export declare function FormInputWithButton({ label, htmlFor, buttonIcon, onButtonClick, inputRef, buttonTestId, buttonAriaLabel, defaultValue, ...inputProps }: FormInputWithButtonProps): import("react").JSX.Element;
|
|
54
54
|
//# sourceMappingURL=form-input-with-button.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-input-with-button.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-input-with-button.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAKvC;;;;GAIG;AACH,MAAM,MAAM,wBAAwB,GAAG;IACtC,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,4CAA4C;IAC5C,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B,0CAA0C;IAC1C,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,+CAA+C;IAC/C,QAAQ,CAAC,EAAE,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;IAC9C,qCAAqC;IACrC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,0DAA0D;IAC1D,eAAe,CAAC,EAAE,MAAM,CAAC;CACzB,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC;AAE9C;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,wBAAgB,mBAAmB,CAAC,EACnC,KAAK,EACL,OAAO,EACP,UAAU,EACV,aAAa,EACb,QAAQ,EACR,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,GAAG,UAAU,EACb,EAAE,wBAAwB
|
|
1
|
+
{"version":3,"file":"form-input-with-button.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-input-with-button.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAKvC;;;;GAIG;AACH,MAAM,MAAM,wBAAwB,GAAG;IACtC,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;IAChB,4CAA4C;IAC5C,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B,0CAA0C;IAC1C,aAAa,EAAE,MAAM,IAAI,CAAC;IAC1B,+CAA+C;IAC/C,QAAQ,CAAC,EAAE,SAAS,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAC;IAC9C,qCAAqC;IACrC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,0DAA0D;IAC1D,eAAe,CAAC,EAAE,MAAM,CAAC;CACzB,GAAG,IAAI,CAAC,cAAc,CAAC,OAAO,KAAK,CAAC,EAAE,KAAK,CAAC,CAAC;AAE9C;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,wBAAgB,mBAAmB,CAAC,EACnC,KAAK,EACL,OAAO,EACP,UAAU,EACV,aAAa,EACb,QAAQ,EACR,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,GAAG,UAAU,EACb,EAAE,wBAAwB,+BAiC1B"}
|
|
@@ -34,5 +34,5 @@ export type FormInputProps = {
|
|
|
34
34
|
*
|
|
35
35
|
* @see {@link GenericFormWrapper} for form integration
|
|
36
36
|
*/
|
|
37
|
-
export declare function FormInput({ label, htmlFor, defaultValue, ...inputProps }: FormInputProps): import("react
|
|
37
|
+
export declare function FormInput({ label, htmlFor, defaultValue, ...inputProps }: FormInputProps): import("react").JSX.Element;
|
|
38
38
|
//# sourceMappingURL=form-input.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAIvC;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAC5B,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjC;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,SAAS,CAAC,EACzB,KAAK,EACL,OAAO,EACP,YAAY,EACZ,GAAG,UAAU,EACb,EAAE,cAAc
|
|
1
|
+
{"version":3,"file":"form-input.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAIvC;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAC5B,+CAA+C;IAC/C,KAAK,EAAE,MAAM,CAAC;IACd,wCAAwC;IACxC,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,KAAK,CAAC,CAAC;AAEjC;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,SAAS,CAAC,EACzB,KAAK,EACL,OAAO,EACP,YAAY,EACZ,GAAG,UAAU,EACb,EAAE,cAAc,+BAchB"}
|
|
@@ -33,5 +33,5 @@ export type FormTextareaProps = {
|
|
|
33
33
|
*
|
|
34
34
|
* @see {@link GenericFormWrapper} for form integration
|
|
35
35
|
*/
|
|
36
|
-
export declare function FormTextarea({ label, htmlFor, defaultValue, ...textareaProps }: FormTextareaProps): import("react
|
|
36
|
+
export declare function FormTextarea({ label, htmlFor, defaultValue, ...textareaProps }: FormTextareaProps): import("react").JSX.Element;
|
|
37
37
|
//# sourceMappingURL=form-textarea.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form-textarea.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-textarea.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAE5C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG7C;;;;GAIG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC/B,kDAAkD;IAClD,KAAK,EAAE,MAAM,CAAC;IACd,2CAA2C;IAC3C,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,QAAQ,CAAC,CAAC;AAEpC;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,YAAY,CAAC,EAC5B,KAAK,EACL,OAAO,EACP,YAAY,EACZ,GAAG,aAAa,EAChB,EAAE,iBAAiB
|
|
1
|
+
{"version":3,"file":"form-textarea.d.ts","sourceRoot":"","sources":["../../../forms/fields/form-textarea.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAE5C,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAG7C;;;;GAIG;AACH,MAAM,MAAM,iBAAiB,GAAG;IAC/B,kDAAkD;IAClD,KAAK,EAAE,MAAM,CAAC;IACd,2CAA2C;IAC3C,OAAO,EAAE,MAAM,CAAC;CAChB,GAAG,cAAc,CAAC,OAAO,QAAQ,CAAC,CAAC;AAEpC;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,YAAY,CAAC,EAC5B,KAAK,EACL,OAAO,EACP,YAAY,EACZ,GAAG,aAAa,EAChB,EAAE,iBAAiB,+BAcnB"}
|
|
@@ -77,5 +77,5 @@ export type GenericFormWrapperProps<T> = {
|
|
|
77
77
|
export declare function GenericFormWrapper<T extends {
|
|
78
78
|
message: string;
|
|
79
79
|
success: boolean;
|
|
80
|
-
}>({ action, children, saveLabel, submitLabel, loadingLabel, onSubmit, preservedValues, afterSubmit, }: GenericFormWrapperProps<T>): import("react
|
|
80
|
+
}>({ action, children, saveLabel, submitLabel, loadingLabel, onSubmit, preservedValues, afterSubmit, }: GenericFormWrapperProps<T>): import("react").JSX.Element;
|
|
81
81
|
//# sourceMappingURL=generic-form-wrapper.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-form-wrapper.d.ts","sourceRoot":"","sources":["../../forms/generic-form-wrapper.tsx"],"names":[],"mappings":"AACA,OAAO,EAEN,KAAK,SAAS,
|
|
1
|
+
{"version":3,"file":"generic-form-wrapper.d.ts","sourceRoot":"","sources":["../../forms/generic-form-wrapper.tsx"],"names":[],"mappings":"AACA,OAAO,EAEN,KAAK,SAAS,EAKd,MAAM,OAAO,CAAC;AAWf;;;;;;;;;;;;;;;;;;;GAmBG;AACH,eAAO,MAAM,aAAa,8BAA+B,CAAC;AAE1D;;;;;;GAMG;AACH,MAAM,MAAM,uBAAuB,CAAC,CAAC,IAAI;IACxC,8CAA8C;IAC9C,MAAM,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3C,4BAA4B;IAC5B,QAAQ,EAAE,SAAS,CAAC;IACpB,2CAA2C;IAC3C,SAAS,EAAE,MAAM,CAAC;IAClB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,qCAAqC;IACrC,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACjD,6BAA6B;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzC,2DAA2D;IAC3D,WAAW,EAAE,CAAC,eAAe,EAAE,MAAM,KAAK,IAAI,CAAC;CAC/C,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,wBAAgB,kBAAkB,CACjC,CAAC,SAAS;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,EAC9C,EACD,MAAM,EACN,QAAQ,EACR,SAAS,EACT,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,eAAe,EACf,WAAW,GACX,EAAE,uBAAuB,CAAC,CAAC,CAAC,+BA8D5B"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
-
import { createContext, use, useActionState, useState, } from "react";
|
|
3
|
+
import { createContext, use, useActionState, useMemo, useState, } from "react";
|
|
4
4
|
import Loading from "../display/loading";
|
|
5
5
|
import { Button } from "../ui/button";
|
|
6
6
|
import { haptic } from "../utils/haptic";
|
|
@@ -63,7 +63,7 @@ export function GenericFormWrapper({ action, children, saveLabel, submitLabel, l
|
|
|
63
63
|
// Server response form data (only set on error, cleared on success)
|
|
64
64
|
const [serverFormData, setServerFormData] = useState(null);
|
|
65
65
|
// Derive form values: server response takes precedence, then preserved values
|
|
66
|
-
const formValues = serverFormData ?? preservedValues ?? {};
|
|
66
|
+
const formValues = useMemo(() => serverFormData ?? preservedValues ?? {}, [serverFormData, preservedValues]);
|
|
67
67
|
const submitForm = async (_previousState, formData) => {
|
|
68
68
|
if (onSubmit) {
|
|
69
69
|
await onSubmit(formData);
|
|
@@ -83,10 +83,16 @@ export function GenericFormWrapper({ action, children, saveLabel, submitLabel, l
|
|
|
83
83
|
return response;
|
|
84
84
|
};
|
|
85
85
|
const [_, submitAction, isPending] = useActionState(submitForm, null);
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
86
|
+
let buttonLabel;
|
|
87
|
+
if (isPending && loadingLabel) {
|
|
88
|
+
buttonLabel = loadingLabel;
|
|
89
|
+
}
|
|
90
|
+
else if (submitLabel) {
|
|
91
|
+
buttonLabel = submitLabel;
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
buttonLabel = saveLabel;
|
|
95
|
+
}
|
|
96
|
+
return (_jsx(FormValuesContext.Provider, { value: formValues, children: _jsxs("form", { action: submitAction, className: "space-y-4 px-2 py-4", children: [isPending ? _jsx(Loading, {}) : children, _jsx(Button, { className: "w-full", disabled: isPending, onClick: () => haptic(), type: "submit", children: buttonLabel })] }) }));
|
|
91
97
|
}
|
|
92
98
|
//# sourceMappingURL=generic-form-wrapper.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generic-form-wrapper.js","sourceRoot":"","sources":["../../forms/generic-form-wrapper.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,EACN,aAAa,EAEb,GAAG,EACH,cAAc,EACd,QAAQ,GACR,MAAM,OAAO,CAAC;AACf,OAAO,OAAO,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC;;;GAGG;AACH,MAAM,iBAAiB,GAAG,aAAa,CAAyB,EAAE,CAAC,CAAC;AAEpE;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;AA4B1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,UAAU,kBAAkB,CAEhC,EACD,MAAM,EACN,QAAQ,EACR,SAAS,EACT,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,eAAe,EACf,WAAW,GACiB;IAC5B,oEAAoE;IACpE,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAG1C,IAAI,CAAC,CAAC;IAEhB,8EAA8E;IAC9E,MAAM,UAAU,GAAG,cAAc,IAAI,eAAe,IAAI,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"generic-form-wrapper.js","sourceRoot":"","sources":["../../forms/generic-form-wrapper.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AACb,OAAO,EACN,aAAa,EAEb,GAAG,EACH,cAAc,EACd,OAAO,EACP,QAAQ,GACR,MAAM,OAAO,CAAC;AACf,OAAO,OAAO,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzC;;;GAGG;AACH,MAAM,iBAAiB,GAAG,aAAa,CAAyB,EAAE,CAAC,CAAC;AAEpE;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;AA4B1D;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,UAAU,kBAAkB,CAEhC,EACD,MAAM,EACN,QAAQ,EACR,SAAS,EACT,WAAW,EACX,YAAY,EACZ,QAAQ,EACR,eAAe,EACf,WAAW,GACiB;IAC5B,oEAAoE;IACpE,MAAM,CAAC,cAAc,EAAE,iBAAiB,CAAC,GAAG,QAAQ,CAG1C,IAAI,CAAC,CAAC;IAEhB,8EAA8E;IAC9E,MAAM,UAAU,GAAG,OAAO,CACzB,GAAG,EAAE,CAAC,cAAc,IAAI,eAAe,IAAI,EAAE,EAC7C,CAAC,cAAc,EAAE,eAAe,CAAC,CACjC,CAAC;IAEF,MAAM,UAAU,GAAG,KAAK,EACvB,cAAwB,EACxB,QAAkB,EACE,EAAE;QACtB,IAAI,QAAQ,EAAE,CAAC;YACd,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACzB,OAAO,IAAI,CAAC;QACb,CAAC;QACD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,CAAC;QACxC,WAAW,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAE9B,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;YACtB,oCAAoC;YACpC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YACxB,OAAO,QAAQ,CAAC;QACjB,CAAC;QACD,8BAA8B;QAC9B,IAAI,UAAU,IAAI,QAAQ,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;YACjD,iBAAiB,CAAC,QAAQ,CAAC,QAAkC,CAAC,CAAC;QAChE,CAAC;QACD,OAAO,QAAQ,CAAC;IACjB,CAAC,CAAC;IAEF,MAAM,CAAC,CAAC,EAAE,YAAY,EAAE,SAAS,CAAC,GAAG,cAAc,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;IAEtE,IAAI,WAAmB,CAAC;IACxB,IAAI,SAAS,IAAI,YAAY,EAAE,CAAC;QAC/B,WAAW,GAAG,YAAY,CAAC;IAC5B,CAAC;SAAM,IAAI,WAAW,EAAE,CAAC;QACxB,WAAW,GAAG,WAAW,CAAC;IAC3B,CAAC;SAAM,CAAC;QACP,WAAW,GAAG,SAAS,CAAC;IACzB,CAAC;IAED,OAAO,CACN,KAAC,iBAAiB,CAAC,QAAQ,IAAC,KAAK,EAAE,UAAU,YAC5C,gBAAM,MAAM,EAAE,YAAY,EAAE,SAAS,EAAC,qBAAqB,aACzD,SAAS,CAAC,CAAC,CAAC,KAAC,OAAO,KAAG,CAAC,CAAC,CAAC,QAAQ,EACnC,KAAC,MAAM,IACN,SAAS,EAAC,QAAQ,EAClB,QAAQ,EAAE,SAAS,EACnB,OAAO,EAAE,GAAG,EAAE,CAAC,MAAM,EAAE,EACvB,IAAI,EAAC,QAAQ,YAEZ,WAAW,GACJ,IACH,GACqB,CAC7B,CAAC;AACH,CAAC"}
|
|
@@ -28,7 +28,7 @@ export type ViewerBodyProps = {
|
|
|
28
28
|
* const content = await markdownToReact("# Hello\n\nWorld");
|
|
29
29
|
* ```
|
|
30
30
|
*/
|
|
31
|
-
export declare function markdownToReact(markdown: string): Promise<import("react
|
|
31
|
+
export declare function markdownToReact(markdown: string): Promise<import("react").JSX.Element>;
|
|
32
32
|
/**
|
|
33
33
|
* A markdown viewer component with prose styling.
|
|
34
34
|
*
|
|
@@ -51,5 +51,5 @@ export declare function markdownToReact(markdown: string): Promise<import("react
|
|
|
51
51
|
*
|
|
52
52
|
* @see {@link markdownToReact} for the markdown conversion function
|
|
53
53
|
*/
|
|
54
|
-
export declare function ViewerBodyClient({ children, markdown, }: ViewerBodyProps): Promise<import("react
|
|
54
|
+
export declare function ViewerBodyClient({ children, markdown, }: ViewerBodyProps): Promise<import("react").JSX.Element>;
|
|
55
55
|
//# sourceMappingURL=viewer-body.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"viewer-body.d.ts","sourceRoot":"","sources":["../../../layouts/body/viewer-body.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"viewer-body.d.ts","sourceRoot":"","sources":["../../../layouts/body/viewer-body.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAgBvC;;;;GAIG;AACH,MAAM,MAAM,eAAe,GAAG;IAC7B,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,iCAAiC;IACjC,QAAQ,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAsB,eAAe,CAAC,QAAQ,EAAE,MAAM,wCA2DrD;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAsB,gBAAgB,CAAC,EACtC,QAAQ,EACR,QAAQ,GACR,EAAE,eAAe,wCASjB"}
|
|
@@ -3,9 +3,11 @@ import ReactMarkdown from "react-markdown";
|
|
|
3
3
|
import { Prism as SyntaxHighlighter } from "react-syntax-highlighter";
|
|
4
4
|
import { vscDarkPlus } from "react-syntax-highlighter/dist/esm/styles/prism";
|
|
5
5
|
import remarkGfm from "remark-gfm";
|
|
6
|
-
const LANGUAGE_REGEX = /language-(\w+)
|
|
7
|
-
const SLUG_REGEX = /\W+/
|
|
6
|
+
const LANGUAGE_REGEX = /language-(\w+)/u;
|
|
7
|
+
const SLUG_REGEX = /\W+/gu;
|
|
8
8
|
function generateHeadingId(children) {
|
|
9
|
+
// react-markdown heading children are text at runtime; toString coercion must be preserved exactly
|
|
10
|
+
// oxlint-disable-next-line typescript/no-base-to-string -- ReactNode is a runtime-text boundary; preserving existing coercion
|
|
9
11
|
return children?.toString().toLowerCase().replace(SLUG_REGEX, "-") ?? "";
|
|
10
12
|
}
|
|
11
13
|
/**
|
|
@@ -31,13 +33,14 @@ export async function markdownToReact(markdown) {
|
|
|
31
33
|
code({ className, children }) {
|
|
32
34
|
const match = LANGUAGE_REGEX.exec(className || "");
|
|
33
35
|
const isInline = !match;
|
|
34
|
-
return isInline ? (_jsx("code", { className: className, children: children })) : (_jsx(SyntaxHighlighter, { PreTag: "div", language: match[1], style: vscDarkPlus, children: String(children).replace(/\n
|
|
36
|
+
return isInline ? (_jsx("code", { className: className, children: children })) : (_jsx(SyntaxHighlighter, { PreTag: "div", language: match[1], style: vscDarkPlus, children: String(children).replace(/\n$/u, "") }));
|
|
35
37
|
},
|
|
36
38
|
img({ src, alt, ...props }) {
|
|
37
39
|
if (!alt) {
|
|
38
40
|
return (_jsx("img", { alt: "", role: "presentation", src: src, ...props }));
|
|
39
41
|
}
|
|
40
|
-
//
|
|
42
|
+
// Markdown images have dynamic external URLs
|
|
43
|
+
// oxlint-disable-next-line nextjs/no-img-element
|
|
41
44
|
return _jsx("img", { alt: alt, src: src, ...props });
|
|
42
45
|
},
|
|
43
46
|
a({ href, children }) {
|
|
@@ -83,6 +86,6 @@ export async function markdownToReact(markdown) {
|
|
|
83
86
|
*/
|
|
84
87
|
export async function ViewerBodyClient({ children, markdown, }) {
|
|
85
88
|
const content = await markdownToReact(markdown);
|
|
86
|
-
return (_jsxs("div", { className: "prose prose-sm
|
|
89
|
+
return (_jsxs("div", { className: "mx-auto prose prose-sm max-w-5xl space-y-8 px-4 py-2 dark:prose-invert", children: [children, content] }));
|
|
87
90
|
}
|
|
88
91
|
//# sourceMappingURL=viewer-body.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"viewer-body.js","sourceRoot":"","sources":["../../../layouts/body/viewer-body.tsx"],"names":[],"mappings":";AAEA,OAAO,aAAa,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,KAAK,IAAI,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,WAAW,EAAE,MAAM,gDAAgD,CAAC;AAC7E,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,MAAM,cAAc,GAAG,
|
|
1
|
+
{"version":3,"file":"viewer-body.js","sourceRoot":"","sources":["../../../layouts/body/viewer-body.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { ThemeProvider as NextThemesProvider } from "next-themes";
|
|
2
1
|
import type * as React from "react";
|
|
2
|
+
import { ThemeProvider as NextThemesProvider } from "next-themes";
|
|
3
3
|
/**
|
|
4
4
|
* Theme provider component for dark/light mode support.
|
|
5
5
|
*
|
|
@@ -23,5 +23,5 @@ import type * as React from "react";
|
|
|
23
23
|
* </ThemeProvider>
|
|
24
24
|
* ```
|
|
25
25
|
*/
|
|
26
|
-
export declare function ThemeProvider({ children, ...props }: React.ComponentProps<typeof NextThemesProvider>):
|
|
26
|
+
export declare function ThemeProvider({ children, ...props }: React.ComponentProps<typeof NextThemesProvider>): React.JSX.Element;
|
|
27
27
|
//# sourceMappingURL=theme-provider.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme-provider.d.ts","sourceRoot":"","sources":["../../providers/theme-provider.tsx"],"names":[],"mappings":"AAEA,OAAO,
|
|
1
|
+
{"version":3,"file":"theme-provider.d.ts","sourceRoot":"","sources":["../../providers/theme-provider.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,aAAa,IAAI,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAElE;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,aAAa,CAAC,EAC7B,QAAQ,EACR,GAAG,KAAK,EACR,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,kBAAkB,CAAC,qBAEjD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"theme-provider.js","sourceRoot":"","sources":["../../providers/theme-provider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;
|
|
1
|
+
{"version":3,"file":"theme-provider.js","sourceRoot":"","sources":["../../providers/theme-provider.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EAAE,aAAa,IAAI,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAElE;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,aAAa,CAAC,EAC7B,QAAQ,EACR,GAAG,KAAK,EACyC;IACjD,OAAO,KAAC,kBAAkB,OAAK,KAAK,YAAG,QAAQ,GAAsB,CAAC;AACvE,CAAC"}
|