payload-auth 1.0.0
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/LICENSE.md +17 -0
- package/dist/authjs/index.d.ts +1 -0
- package/dist/authjs/index.js +3 -0
- package/dist/authjs/index.js.map +1 -0
- package/dist/better-auth/adapter/dev/bin/run.d.ts +1 -0
- package/dist/better-auth/adapter/dev/bin/run.js +64 -0
- package/dist/better-auth/adapter/dev/bin/run.js.map +1 -0
- package/dist/better-auth/adapter/dev/bin/schema.d.ts +22 -0
- package/dist/better-auth/adapter/dev/bin/schema.js +160 -0
- package/dist/better-auth/adapter/dev/bin/schema.js.map +1 -0
- package/dist/better-auth/adapter/dev/collections.d.ts +3 -0
- package/dist/better-auth/adapter/dev/collections.js +212 -0
- package/dist/better-auth/adapter/dev/collections.js.map +1 -0
- package/dist/better-auth/adapter/dev/index.d.ts +3 -0
- package/dist/better-auth/adapter/dev/index.js +168 -0
- package/dist/better-auth/adapter/dev/index.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.d.ts +23 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js +326 -0
- package/dist/better-auth/adapter/generate-schema/generate-schema-builder.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.d.ts +1 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.js +23 -0
- package/dist/better-auth/adapter/generate-schema/get-payload-schema.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/index.d.ts +4 -0
- package/dist/better-auth/adapter/generate-schema/index.js +19 -0
- package/dist/better-auth/adapter/generate-schema/index.js.map +1 -0
- package/dist/better-auth/adapter/generate-schema/utils.d.ts +2 -0
- package/dist/better-auth/adapter/generate-schema/utils.js +20 -0
- package/dist/better-auth/adapter/generate-schema/utils.js.map +1 -0
- package/dist/better-auth/adapter/index.d.ts +5 -0
- package/dist/better-auth/adapter/index.js +578 -0
- package/dist/better-auth/adapter/index.js.map +1 -0
- package/dist/better-auth/adapter/test/adapter.test.d.ts +1 -0
- package/dist/better-auth/adapter/test/adapter.test.js +181 -0
- package/dist/better-auth/adapter/test/adapter.test.js.map +1 -0
- package/dist/better-auth/adapter/test/better-auth-adapter-test.d.ts +7 -0
- package/dist/better-auth/adapter/test/better-auth-adapter-test.js +425 -0
- package/dist/better-auth/adapter/test/better-auth-adapter-test.js.map +1 -0
- package/dist/better-auth/adapter/test/schema.test.d.ts +1 -0
- package/dist/better-auth/adapter/test/schema.test.js +796 -0
- package/dist/better-auth/adapter/test/schema.test.js.map +1 -0
- package/dist/better-auth/adapter/test/test_payload1/schema.d.ts +23 -0
- package/dist/better-auth/adapter/test/test_payload1/schema.js +177 -0
- package/dist/better-auth/adapter/test/test_payload1/schema.js.map +1 -0
- package/dist/better-auth/adapter/test/test_payload2/schema.d.ts +23 -0
- package/dist/better-auth/adapter/test/test_payload2/schema.js +167 -0
- package/dist/better-auth/adapter/test/test_payload2/schema.js.map +1 -0
- package/dist/better-auth/adapter/test/test_payload3/schema.d.ts +23 -0
- package/dist/better-auth/adapter/test/test_payload3/schema.js +198 -0
- package/dist/better-auth/adapter/test/test_payload3/schema.js.map +1 -0
- package/dist/better-auth/adapter/transform/index.d.ts +16 -0
- package/dist/better-auth/adapter/transform/index.js +252 -0
- package/dist/better-auth/adapter/transform/index.js.map +1 -0
- package/dist/better-auth/adapter/types.d.ts +6 -0
- package/dist/better-auth/adapter/types.js +3 -0
- package/dist/better-auth/adapter/types.js.map +1 -0
- package/dist/better-auth/index.d.ts +6 -0
- package/dist/better-auth/index.js +8 -0
- package/dist/better-auth/index.js.map +1 -0
- package/dist/better-auth/plugin/collections/accounts/hooks/sync-password-to-user.d.ts +7 -0
- package/dist/better-auth/plugin/collections/accounts/hooks/sync-password-to-user.js +47 -0
- package/dist/better-auth/plugin/collections/accounts/hooks/sync-password-to-user.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/endpoints/refresh-token.d.ts +6 -0
- package/dist/better-auth/plugin/collections/users/endpoints/refresh-token.js +106 -0
- package/dist/better-auth/plugin/collections/users/endpoints/refresh-token.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-login.d.ts +11 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-login.js +71 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-login.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-logout.d.ts +6 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-logout.js +49 -0
- package/dist/better-auth/plugin/collections/users/hooks/after-logout.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/before-login.d.ts +5 -0
- package/dist/better-auth/plugin/collections/users/hooks/before-login.js +18 -0
- package/dist/better-auth/plugin/collections/users/hooks/before-login.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/clean-up-user-after-delete.d.ts +5 -0
- package/dist/better-auth/plugin/collections/users/hooks/clean-up-user-after-delete.js +33 -0
- package/dist/better-auth/plugin/collections/users/hooks/clean-up-user-after-delete.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/on-verified-change.d.ts +2 -0
- package/dist/better-auth/plugin/collections/users/hooks/on-verified-change.js +14 -0
- package/dist/better-auth/plugin/collections/users/hooks/on-verified-change.js.map +1 -0
- package/dist/better-auth/plugin/collections/users/hooks/sync-account.d.ts +7 -0
- package/dist/better-auth/plugin/collections/users/hooks/sync-account.js +82 -0
- package/dist/better-auth/plugin/collections/users/hooks/sync-account.js.map +1 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.d.ts +29 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.js +46 -0
- package/dist/better-auth/plugin/helpers/generate-verify-email-url.js.map +1 -0
- package/dist/better-auth/plugin/helpers/get-ip.d.ts +2 -0
- package/dist/better-auth/plugin/helpers/get-ip.js +31 -0
- package/dist/better-auth/plugin/helpers/get-ip.js.map +1 -0
- package/dist/better-auth/plugin/helpers/index.d.ts +1 -0
- package/dist/better-auth/plugin/helpers/index.js +3 -0
- package/dist/better-auth/plugin/helpers/index.js.map +1 -0
- package/dist/better-auth/plugin/helpers/serialize-cookie.d.ts +104 -0
- package/dist/better-auth/plugin/helpers/serialize-cookie.js +186 -0
- package/dist/better-auth/plugin/helpers/serialize-cookie.js.map +1 -0
- package/dist/better-auth/plugin/index.d.ts +7 -0
- package/dist/better-auth/plugin/index.js +64 -0
- package/dist/better-auth/plugin/index.js.map +1 -0
- package/dist/better-auth/plugin/lib/auth-strategy.d.ts +8 -0
- package/dist/better-auth/plugin/lib/auth-strategy.js +48 -0
- package/dist/better-auth/plugin/lib/auth-strategy.js.map +1 -0
- package/dist/better-auth/plugin/lib/build-collection-configs.d.ts +11 -0
- package/dist/better-auth/plugin/lib/build-collection-configs.js +1558 -0
- package/dist/better-auth/plugin/lib/build-collection-configs.js.map +1 -0
- package/dist/better-auth/plugin/lib/config.d.ts +41 -0
- package/dist/better-auth/plugin/lib/config.js +43 -0
- package/dist/better-auth/plugin/lib/config.js.map +1 -0
- package/dist/better-auth/plugin/lib/ensure-password-set-before-create.d.ts +7 -0
- package/dist/better-auth/plugin/lib/ensure-password-set-before-create.js +24 -0
- package/dist/better-auth/plugin/lib/ensure-password-set-before-create.js.map +1 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.d.ts +5 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.js +9 -0
- package/dist/better-auth/plugin/lib/get-payload-auth.js.map +1 -0
- package/dist/better-auth/plugin/lib/get-required-collection-slugs.d.ts +9 -0
- package/dist/better-auth/plugin/lib/get-required-collection-slugs.js +52 -0
- package/dist/better-auth/plugin/lib/get-required-collection-slugs.js.map +1 -0
- package/dist/better-auth/plugin/lib/init-better-auth.d.ts +6 -0
- package/dist/better-auth/plugin/lib/init-better-auth.js +13 -0
- package/dist/better-auth/plugin/lib/init-better-auth.js.map +1 -0
- package/dist/better-auth/plugin/lib/password.d.ts +25 -0
- package/dist/better-auth/plugin/lib/password.js +63 -0
- package/dist/better-auth/plugin/lib/password.js.map +1 -0
- package/dist/better-auth/plugin/lib/payload-access.d.ts +14 -0
- package/dist/better-auth/plugin/lib/payload-access.js +64 -0
- package/dist/better-auth/plugin/lib/payload-access.js.map +1 -0
- package/dist/better-auth/plugin/lib/prepare-session-data.d.ts +21 -0
- package/dist/better-auth/plugin/lib/prepare-session-data.js +42 -0
- package/dist/better-auth/plugin/lib/prepare-session-data.js.map +1 -0
- package/dist/better-auth/plugin/lib/respect-save-to-jwt-fields-middleware.d.ts +15 -0
- package/dist/better-auth/plugin/lib/respect-save-to-jwt-fields-middleware.js +30 -0
- package/dist/better-auth/plugin/lib/respect-save-to-jwt-fields-middleware.js.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-auth-options.d.ts +5 -0
- package/dist/better-auth/plugin/lib/sanitize-auth-options.js +298 -0
- package/dist/better-auth/plugin/lib/sanitize-auth-options.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons.d.ts +5 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons.js +222 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/login-redirect.d.ts +1 -0
- package/dist/better-auth/plugin/payload/components/login-redirect.js +6 -0
- package/dist/better-auth/plugin/payload/components/login-redirect.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/logo.d.ts +1 -0
- package/dist/better-auth/plugin/payload/components/logo.js +36 -0
- package/dist/better-auth/plugin/payload/components/logo.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/logout.d.ts +1 -0
- package/dist/better-auth/plugin/payload/components/logout.js +61 -0
- package/dist/better-auth/plugin/payload/components/logout.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/sign-in.d.ts +3 -0
- package/dist/better-auth/plugin/payload/components/sign-in.js +384 -0
- package/dist/better-auth/plugin/payload/components/sign-in.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/sign-up.d.ts +6 -0
- package/dist/better-auth/plugin/payload/components/sign-up.js +502 -0
- package/dist/better-auth/plugin/payload/components/sign-up.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/styles.css +73 -0
- package/dist/better-auth/plugin/payload/components/ui/button.d.ts +10 -0
- package/dist/better-auth/plugin/payload/components/ui/button.js +42 -0
- package/dist/better-auth/plugin/payload/components/ui/button.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/card.d.ts +9 -0
- package/dist/better-auth/plugin/payload/components/ui/card.js +55 -0
- package/dist/better-auth/plugin/payload/components/ui/card.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/checkbox.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/ui/checkbox.js +23 -0
- package/dist/better-auth/plugin/payload/components/ui/checkbox.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/cn.d.ts +2 -0
- package/dist/better-auth/plugin/payload/components/ui/cn.js +7 -0
- package/dist/better-auth/plugin/payload/components/ui/cn.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/input.d.ts +3 -0
- package/dist/better-auth/plugin/payload/components/ui/input.js +14 -0
- package/dist/better-auth/plugin/payload/components/ui/input.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/label.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/ui/label.js +15 -0
- package/dist/better-auth/plugin/payload/components/ui/label.js.map +1 -0
- package/dist/better-auth/plugin/payload/components/ui/password-input.d.ts +2 -0
- package/dist/better-auth/plugin/payload/components/ui/password-input.js +55 -0
- package/dist/better-auth/plugin/payload/components/ui/password-input.js.map +1 -0
- package/dist/better-auth/plugin/payload/exports/client.d.ts +3 -0
- package/dist/better-auth/plugin/payload/exports/client.js +5 -0
- package/dist/better-auth/plugin/payload/exports/client.js.map +1 -0
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts +5 -0
- package/dist/better-auth/plugin/payload/exports/rsc.js +7 -0
- package/dist/better-auth/plugin/payload/exports/rsc.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/create-first-admin/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/views/create-first-admin/index.js +112 -0
- package/dist/better-auth/plugin/payload/views/create-first-admin/index.js.map +1 -0
- package/dist/better-auth/plugin/payload/views/login/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/views/login/index.js +78 -0
- package/dist/better-auth/plugin/payload/views/login/index.js.map +1 -0
- package/dist/better-auth/plugin/types.d.ts +224 -0
- package/dist/better-auth/plugin/types.js +3 -0
- package/dist/better-auth/plugin/types.js.map +1 -0
- package/dist/better-auth/types.d.ts +2 -0
- package/dist/better-auth/types.js +4 -0
- package/dist/better-auth/types.js.map +1 -0
- package/dist/clerk/index.d.ts +1 -0
- package/dist/clerk/index.js +3 -0
- package/dist/clerk/index.js.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/kinde/index.d.ts +1 -0
- package/dist/kinde/index.js +3 -0
- package/dist/kinde/index.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { Slot } from '@radix-ui/react-slot';
|
|
4
|
+
import { cva } from 'class-variance-authority';
|
|
5
|
+
import { cn } from './cn';
|
|
6
|
+
const buttonVariants = cva("inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive", {
|
|
7
|
+
variants: {
|
|
8
|
+
variant: {
|
|
9
|
+
default: 'bg-primary text-primary-foreground shadow-xs hover:bg-primary/90',
|
|
10
|
+
destructive: 'bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60',
|
|
11
|
+
outline: 'border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50',
|
|
12
|
+
secondary: 'bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80',
|
|
13
|
+
ghost: 'hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50',
|
|
14
|
+
link: 'text-primary underline-offset-4 hover:underline'
|
|
15
|
+
},
|
|
16
|
+
size: {
|
|
17
|
+
default: 'h-9 px-4 py-2 has-[>svg]:px-3',
|
|
18
|
+
sm: 'h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5',
|
|
19
|
+
lg: 'h-10 rounded-md px-6 has-[>svg]:px-4',
|
|
20
|
+
icon: 'size-9'
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
defaultVariants: {
|
|
24
|
+
variant: 'default',
|
|
25
|
+
size: 'default'
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
function Button({ className, variant, size, asChild = false, ...props }) {
|
|
29
|
+
const Comp = asChild ? Slot : 'button';
|
|
30
|
+
return /*#__PURE__*/ _jsx(Comp, {
|
|
31
|
+
"data-slot": "button",
|
|
32
|
+
className: cn(buttonVariants({
|
|
33
|
+
variant,
|
|
34
|
+
size,
|
|
35
|
+
className
|
|
36
|
+
})),
|
|
37
|
+
...props
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
export { Button, buttonVariants };
|
|
41
|
+
|
|
42
|
+
//# sourceMappingURL=button.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/button.tsx"],"sourcesContent":["import * as React from 'react'\nimport { Slot } from '@radix-ui/react-slot'\nimport { cva, type VariantProps } from 'class-variance-authority'\n\nimport { cn } from './cn'\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n {\n variants: {\n variant: {\n default: 'bg-primary text-primary-foreground shadow-xs hover:bg-primary/90',\n destructive:\n 'bg-destructive text-white shadow-xs hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60',\n outline:\n 'border bg-background shadow-xs hover:bg-accent hover:text-accent-foreground dark:bg-input/30 dark:border-input dark:hover:bg-input/50',\n secondary: 'bg-secondary text-secondary-foreground shadow-xs hover:bg-secondary/80',\n ghost: 'hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50',\n link: 'text-primary underline-offset-4 hover:underline',\n },\n size: {\n default: 'h-9 px-4 py-2 has-[>svg]:px-3',\n sm: 'h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5',\n lg: 'h-10 rounded-md px-6 has-[>svg]:px-4',\n icon: 'size-9',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n)\n\nfunction Button({\n className,\n variant,\n size,\n asChild = false,\n ...props\n}: React.ComponentProps<'button'> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean\n }) {\n const Comp = asChild ? Slot : 'button'\n\n return (\n <Comp\n data-slot=\"button\"\n className={cn(buttonVariants({ variant, size, className }))}\n {...props}\n />\n )\n}\n\nexport { Button, buttonVariants }\n"],"names":["React","Slot","cva","cn","buttonVariants","variants","variant","default","destructive","outline","secondary","ghost","link","size","sm","lg","icon","defaultVariants","Button","className","asChild","props","Comp","data-slot"],"mappings":";AAAA,YAAYA,WAAW,QAAO;AAC9B,SAASC,IAAI,QAAQ,uBAAsB;AAC3C,SAASC,GAAG,QAA2B,2BAA0B;AAEjE,SAASC,EAAE,QAAQ,OAAM;AAEzB,MAAMC,iBAAiBF,IACrB,+bACA;IACEG,UAAU;QACRC,SAAS;YACPC,SAAS;YACTC,aACE;YACFC,SACE;YACFC,WAAW;YACXC,OAAO;YACPC,MAAM;QACR;QACAC,MAAM;YACJN,SAAS;YACTO,IAAI;YACJC,IAAI;YACJC,MAAM;QACR;IACF;IACAC,iBAAiB;QACfX,SAAS;QACTO,MAAM;IACR;AACF;AAGF,SAASK,OAAO,EACdC,SAAS,EACTb,OAAO,EACPO,IAAI,EACJO,UAAU,KAAK,EACf,GAAGC,OAIF;IACD,MAAMC,OAAOF,UAAUnB,OAAO;IAE9B,qBACE,KAACqB;QACCC,aAAU;QACVJ,WAAWhB,GAAGC,eAAe;YAAEE;YAASO;YAAMM;QAAU;QACvD,GAAGE,KAAK;;AAGf;AAEA,SAASH,MAAM,EAAEd,cAAc,GAAE"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
declare function Card({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
declare function CardHeader({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
declare function CardTitle({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
declare function CardDescription({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
declare function CardAction({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
declare function CardContent({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
declare function CardFooter({ className, ...props }: React.ComponentProps<'div'>): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export { Card, CardHeader, CardFooter, CardTitle, CardAction, CardDescription, CardContent };
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { cn } from './cn';
|
|
4
|
+
function Card({ className, ...props }) {
|
|
5
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
6
|
+
"data-slot": "card",
|
|
7
|
+
className: cn('bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm', className),
|
|
8
|
+
...props
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
function CardHeader({ className, ...props }) {
|
|
12
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
13
|
+
"data-slot": "card-header",
|
|
14
|
+
className: cn('@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-[data-slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6', className),
|
|
15
|
+
...props
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
function CardTitle({ className, ...props }) {
|
|
19
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
20
|
+
"data-slot": "card-title",
|
|
21
|
+
className: cn('leading-none font-semibold', className),
|
|
22
|
+
...props
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
function CardDescription({ className, ...props }) {
|
|
26
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
27
|
+
"data-slot": "card-description",
|
|
28
|
+
className: cn('text-muted-foreground text-sm', className),
|
|
29
|
+
...props
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
function CardAction({ className, ...props }) {
|
|
33
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
34
|
+
"data-slot": "card-action",
|
|
35
|
+
className: cn('col-start-2 row-span-2 row-start-1 self-start justify-self-end', className),
|
|
36
|
+
...props
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
function CardContent({ className, ...props }) {
|
|
40
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
41
|
+
"data-slot": "card-content",
|
|
42
|
+
className: cn('px-6', className),
|
|
43
|
+
...props
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
function CardFooter({ className, ...props }) {
|
|
47
|
+
return /*#__PURE__*/ _jsx("div", {
|
|
48
|
+
"data-slot": "card-footer",
|
|
49
|
+
className: cn('flex items-center px-6 [.border-t]:pt-6', className),
|
|
50
|
+
...props
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
export { Card, CardHeader, CardFooter, CardTitle, CardAction, CardDescription, CardContent };
|
|
54
|
+
|
|
55
|
+
//# sourceMappingURL=card.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/card.tsx"],"sourcesContent":["import * as React from 'react'\n\nimport { cn } from './cn'\n\nfunction Card({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card\"\n className={cn(\n 'bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction CardHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card-header\"\n className={cn(\n '@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-[data-slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction CardTitle({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card-title\"\n className={cn('leading-none font-semibold', className)}\n {...props}\n />\n )\n}\n\nfunction CardDescription({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card-description\"\n className={cn('text-muted-foreground text-sm', className)}\n {...props}\n />\n )\n}\n\nfunction CardAction({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card-action\"\n className={cn('col-start-2 row-span-2 row-start-1 self-start justify-self-end', className)}\n {...props}\n />\n )\n}\n\nfunction CardContent({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"card-content\" className={cn('px-6', className)} {...props} />\n}\n\nfunction CardFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"card-footer\"\n className={cn('flex items-center px-6 [.border-t]:pt-6', className)}\n {...props}\n />\n )\n}\n\nexport { Card, CardHeader, CardFooter, CardTitle, CardAction, CardDescription, CardContent }\n"],"names":["React","cn","Card","className","props","div","data-slot","CardHeader","CardTitle","CardDescription","CardAction","CardContent","CardFooter"],"mappings":";AAAA,YAAYA,WAAW,QAAO;AAE9B,SAASC,EAAE,QAAQ,OAAM;AAEzB,SAASC,KAAK,EAAEC,SAAS,EAAE,GAAGC,OAAoC;IAChE,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GACT,qFACAE;QAED,GAAGC,KAAK;;AAGf;AAEA,SAASG,WAAW,EAAEJ,SAAS,EAAE,GAAGC,OAAoC;IACtE,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GACT,8JACAE;QAED,GAAGC,KAAK;;AAGf;AAEA,SAASI,UAAU,EAAEL,SAAS,EAAE,GAAGC,OAAoC;IACrE,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GAAG,8BAA8BE;QAC3C,GAAGC,KAAK;;AAGf;AAEA,SAASK,gBAAgB,EAAEN,SAAS,EAAE,GAAGC,OAAoC;IAC3E,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GAAG,iCAAiCE;QAC9C,GAAGC,KAAK;;AAGf;AAEA,SAASM,WAAW,EAAEP,SAAS,EAAE,GAAGC,OAAoC;IACtE,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GAAG,kEAAkEE;QAC/E,GAAGC,KAAK;;AAGf;AAEA,SAASO,YAAY,EAAER,SAAS,EAAE,GAAGC,OAAoC;IACvE,qBAAO,KAACC;QAAIC,aAAU;QAAeH,WAAWF,GAAG,QAAQE;QAAa,GAAGC,KAAK;;AAClF;AAEA,SAASQ,WAAW,EAAET,SAAS,EAAE,GAAGC,OAAoC;IACtE,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWF,GAAG,2CAA2CE;QACxD,GAAGC,KAAK;;AAGf;AAEA,SAASF,IAAI,EAAEK,UAAU,EAAEK,UAAU,EAAEJ,SAAS,EAAEE,UAAU,EAAED,eAAe,EAAEE,WAAW,GAAE"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import * as CheckboxPrimitive from '@radix-ui/react-checkbox';
|
|
5
|
+
import { CheckIcon } from 'lucide-react';
|
|
6
|
+
import { cn } from './cn';
|
|
7
|
+
function Checkbox({ className, ...props }) {
|
|
8
|
+
return /*#__PURE__*/ _jsx(CheckboxPrimitive.Root, {
|
|
9
|
+
"data-slot": "checkbox",
|
|
10
|
+
className: cn('peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50', className),
|
|
11
|
+
...props,
|
|
12
|
+
children: /*#__PURE__*/ _jsx(CheckboxPrimitive.Indicator, {
|
|
13
|
+
"data-slot": "checkbox-indicator",
|
|
14
|
+
className: "flex items-center justify-center text-current transition-none",
|
|
15
|
+
children: /*#__PURE__*/ _jsx(CheckIcon, {
|
|
16
|
+
className: "size-3.5"
|
|
17
|
+
})
|
|
18
|
+
})
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
export { Checkbox };
|
|
22
|
+
|
|
23
|
+
//# sourceMappingURL=checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/checkbox.tsx"],"sourcesContent":["'use client'\n\nimport * as React from 'react'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { CheckIcon } from 'lucide-react'\n\nimport { cn } from './cn'\n\nfunction Checkbox({ className, ...props }: React.ComponentProps<typeof CheckboxPrimitive.Root>) {\n return (\n <CheckboxPrimitive.Root\n data-slot=\"checkbox\"\n className={cn(\n 'peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50',\n className,\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator\n data-slot=\"checkbox-indicator\"\n className=\"flex items-center justify-center text-current transition-none\"\n >\n <CheckIcon className=\"size-3.5\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n )\n}\n\nexport { Checkbox }\n"],"names":["React","CheckboxPrimitive","CheckIcon","cn","Checkbox","className","props","Root","data-slot","Indicator"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAO;AAC9B,YAAYC,uBAAuB,2BAA0B;AAC7D,SAASC,SAAS,QAAQ,eAAc;AAExC,SAASC,EAAE,QAAQ,OAAM;AAEzB,SAASC,SAAS,EAAEC,SAAS,EAAE,GAAGC,OAA4D;IAC5F,qBACE,KAACL,kBAAkBM,IAAI;QACrBC,aAAU;QACVH,WAAWF,GACT,+eACAE;QAED,GAAGC,KAAK;kBAET,cAAA,KAACL,kBAAkBQ,SAAS;YAC1BD,aAAU;YACVH,WAAU;sBAEV,cAAA,KAACH;gBAAUG,WAAU;;;;AAI7B;AAEA,SAASD,QAAQ,GAAE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/cn.ts"],"sourcesContent":["import { clsx, type ClassValue } from 'clsx'\nimport { twMerge } from 'tailwind-merge'\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n"],"names":["clsx","twMerge","cn","inputs"],"mappings":"AAAA,SAASA,IAAI,QAAyB,OAAM;AAC5C,SAASC,OAAO,QAAQ,iBAAgB;AAExC,OAAO,SAASC,GAAG,GAAGC,MAAoB;IACxC,OAAOF,QAAQD,KAAKG;AACtB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { cn } from './cn';
|
|
4
|
+
function Input({ className, type, ...props }) {
|
|
5
|
+
return /*#__PURE__*/ _jsx("input", {
|
|
6
|
+
type: type,
|
|
7
|
+
"data-slot": "input",
|
|
8
|
+
className: cn('file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm', 'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]', 'aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive', className),
|
|
9
|
+
...props
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
export { Input };
|
|
13
|
+
|
|
14
|
+
//# sourceMappingURL=input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/input.tsx"],"sourcesContent":["import * as React from 'react'\n\nimport { cn } from './cn'\n\nfunction Input({ className, type, ...props }: React.ComponentProps<'input'>) {\n return (\n <input\n type={type}\n data-slot=\"input\"\n className={cn(\n 'file:text-foreground placeholder:text-muted-foreground selection:bg-primary selection:text-primary-foreground dark:bg-input/30 border-input flex h-9 w-full min-w-0 rounded-md border bg-transparent px-3 py-1 text-base shadow-xs transition-[color,box-shadow] outline-none file:inline-flex file:h-7 file:border-0 file:bg-transparent file:text-sm file:font-medium disabled:pointer-events-none disabled:cursor-not-allowed disabled:opacity-50 md:text-sm',\n 'focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px]',\n 'aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport { Input }\n"],"names":["React","cn","Input","className","type","props","input","data-slot"],"mappings":";AAAA,YAAYA,WAAW,QAAO;AAE9B,SAASC,EAAE,QAAQ,OAAM;AAEzB,SAASC,MAAM,EAAEC,SAAS,EAAEC,IAAI,EAAE,GAAGC,OAAsC;IACzE,qBACE,KAACC;QACCF,MAAMA;QACNG,aAAU;QACVJ,WAAWF,GACT,mcACA,iFACA,0GACAE;QAED,GAAGE,KAAK;;AAGf;AAEA,SAASH,KAAK,GAAE"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import * as LabelPrimitive from '@radix-ui/react-label';
|
|
5
|
+
import { cn } from './cn';
|
|
6
|
+
function Label({ className, ...props }) {
|
|
7
|
+
return /*#__PURE__*/ _jsx(LabelPrimitive.Root, {
|
|
8
|
+
"data-slot": "label",
|
|
9
|
+
className: cn('flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50', className),
|
|
10
|
+
...props
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
export { Label };
|
|
14
|
+
|
|
15
|
+
//# sourceMappingURL=label.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/label.tsx"],"sourcesContent":["'use client'\n\nimport * as React from 'react'\nimport * as LabelPrimitive from '@radix-ui/react-label'\n\nimport { cn } from './cn'\n\nfunction Label({ className, ...props }: React.ComponentProps<typeof LabelPrimitive.Root>) {\n return (\n <LabelPrimitive.Root\n data-slot=\"label\"\n className={cn(\n 'flex items-center gap-2 text-sm leading-none font-medium select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50 peer-disabled:cursor-not-allowed peer-disabled:opacity-50',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport { Label }\n"],"names":["React","LabelPrimitive","cn","Label","className","props","Root","data-slot"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAO;AAC9B,YAAYC,oBAAoB,wBAAuB;AAEvD,SAASC,EAAE,QAAQ,OAAM;AAEzB,SAASC,MAAM,EAAEC,SAAS,EAAE,GAAGC,OAAyD;IACtF,qBACE,KAACJ,eAAeK,IAAI;QAClBC,aAAU;QACVH,WAAWF,GACT,uNACAE;QAED,GAAGC,KAAK;;AAGf;AAEA,SAASF,KAAK,GAAE"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { EyeIcon, EyeOffIcon } from 'lucide-react';
|
|
4
|
+
import * as React from 'react';
|
|
5
|
+
import { Button } from './button';
|
|
6
|
+
import { Input } from './input';
|
|
7
|
+
import { cn } from './cn';
|
|
8
|
+
export function PasswordInput({ className, ...props }) {
|
|
9
|
+
const [showPassword, setShowPassword] = React.useState(false);
|
|
10
|
+
const disabled = props.value === '' || props.value === undefined || props.disabled;
|
|
11
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
12
|
+
className: "relative",
|
|
13
|
+
children: [
|
|
14
|
+
/*#__PURE__*/ _jsx(Input, {
|
|
15
|
+
...props,
|
|
16
|
+
type: showPassword ? 'text' : 'password',
|
|
17
|
+
name: "password_fake",
|
|
18
|
+
className: cn('hide-password-toggle pr-10', className)
|
|
19
|
+
}),
|
|
20
|
+
/*#__PURE__*/ _jsxs(Button, {
|
|
21
|
+
type: "button",
|
|
22
|
+
variant: "ghost",
|
|
23
|
+
size: "sm",
|
|
24
|
+
className: "absolute right-0 top-0 h-full px-3 py-2 hover:bg-transparent",
|
|
25
|
+
onClick: ()=>setShowPassword((prev)=>!prev),
|
|
26
|
+
disabled: disabled,
|
|
27
|
+
children: [
|
|
28
|
+
showPassword && !disabled ? /*#__PURE__*/ _jsx(EyeIcon, {
|
|
29
|
+
className: "h-4 w-4",
|
|
30
|
+
"aria-hidden": "true"
|
|
31
|
+
}) : /*#__PURE__*/ _jsx(EyeOffIcon, {
|
|
32
|
+
className: "h-4 w-4",
|
|
33
|
+
"aria-hidden": "true"
|
|
34
|
+
}),
|
|
35
|
+
/*#__PURE__*/ _jsx("span", {
|
|
36
|
+
className: "sr-only",
|
|
37
|
+
children: showPassword ? 'Hide password' : 'Show password'
|
|
38
|
+
})
|
|
39
|
+
]
|
|
40
|
+
}),
|
|
41
|
+
/*#__PURE__*/ _jsx("style", {
|
|
42
|
+
children: `
|
|
43
|
+
.hide-password-toggle::-ms-reveal,
|
|
44
|
+
.hide-password-toggle::-ms-clear {
|
|
45
|
+
visibility: hidden;
|
|
46
|
+
pointer-events: none;
|
|
47
|
+
display: none;
|
|
48
|
+
}
|
|
49
|
+
`
|
|
50
|
+
})
|
|
51
|
+
]
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
//# sourceMappingURL=password-input.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/components/ui/password-input.tsx"],"sourcesContent":["'use client'\n\nimport { EyeIcon, EyeOffIcon } from 'lucide-react'\nimport * as React from 'react'\n\nimport { Button } from './button'\nimport { Input } from './input'\nimport { cn } from './cn'\n\nexport function PasswordInput({ className, ...props }: React.ComponentProps<'input'>) {\n const [showPassword, setShowPassword] = React.useState(false)\n const disabled = props.value === '' || props.value === undefined || props.disabled\n\n return (\n <div className=\"relative\">\n <Input\n {...props}\n type={showPassword ? 'text' : 'password'}\n name=\"password_fake\"\n className={cn('hide-password-toggle pr-10', className)}\n />\n <Button\n type=\"button\"\n variant=\"ghost\"\n size=\"sm\"\n className=\"absolute right-0 top-0 h-full px-3 py-2 hover:bg-transparent\"\n onClick={() => setShowPassword((prev) => !prev)}\n disabled={disabled}\n >\n {showPassword && !disabled ? (\n <EyeIcon className=\"h-4 w-4\" aria-hidden=\"true\" />\n ) : (\n <EyeOffIcon className=\"h-4 w-4\" aria-hidden=\"true\" />\n )}\n <span className=\"sr-only\">{showPassword ? 'Hide password' : 'Show password'}</span>\n </Button>\n\n <style>{`\n\t\t.hide-password-toggle::-ms-reveal,\n\t\t.hide-password-toggle::-ms-clear {\n\t\t\tvisibility: hidden;\n\t\t\tpointer-events: none;\n\t\t\tdisplay: none;\n\t\t}\n\t`}</style>\n </div>\n )\n}\n"],"names":["EyeIcon","EyeOffIcon","React","Button","Input","cn","PasswordInput","className","props","showPassword","setShowPassword","useState","disabled","value","undefined","div","type","name","variant","size","onClick","prev","aria-hidden","span","style"],"mappings":"AAAA;;AAEA,SAASA,OAAO,EAAEC,UAAU,QAAQ,eAAc;AAClD,YAAYC,WAAW,QAAO;AAE9B,SAASC,MAAM,QAAQ,WAAU;AACjC,SAASC,KAAK,QAAQ,UAAS;AAC/B,SAASC,EAAE,QAAQ,OAAM;AAEzB,OAAO,SAASC,cAAc,EAAEC,SAAS,EAAE,GAAGC,OAAsC;IAClF,MAAM,CAACC,cAAcC,gBAAgB,GAAGR,MAAMS,QAAQ,CAAC;IACvD,MAAMC,WAAWJ,MAAMK,KAAK,KAAK,MAAML,MAAMK,KAAK,KAAKC,aAAaN,MAAMI,QAAQ;IAElF,qBACE,MAACG;QAAIR,WAAU;;0BACb,KAACH;gBACE,GAAGI,KAAK;gBACTQ,MAAMP,eAAe,SAAS;gBAC9BQ,MAAK;gBACLV,WAAWF,GAAG,8BAA8BE;;0BAE9C,MAACJ;gBACCa,MAAK;gBACLE,SAAQ;gBACRC,MAAK;gBACLZ,WAAU;gBACVa,SAAS,IAAMV,gBAAgB,CAACW,OAAS,CAACA;gBAC1CT,UAAUA;;oBAETH,gBAAgB,CAACG,yBAChB,KAACZ;wBAAQO,WAAU;wBAAUe,eAAY;uCAEzC,KAACrB;wBAAWM,WAAU;wBAAUe,eAAY;;kCAE9C,KAACC;wBAAKhB,WAAU;kCAAWE,eAAe,kBAAkB;;;;0BAG9D,KAACe;0BAAO,CAAC;;;;;;;CAOd,CAAC;;;;AAGF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/plugin/payload/exports/client.ts"],"sourcesContent":["import AdminButtons from '../components/admin-buttons'\nimport LogoutButton from '../components/logout'\n\nexport { AdminButtons, LogoutButton }\n"],"names":["AdminButtons","LogoutButton"],"mappings":"AAAA,OAAOA,kBAAkB,8BAA6B;AACtD,OAAOC,kBAAkB,uBAAsB;AAE/C,SAASD,YAAY,EAAEC,YAAY,GAAE"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import LoginRedirect from '../components/login-redirect';
|
|
2
|
+
import Logo from '../components/logo';
|
|
3
|
+
import CreateFirstAdmin from '../views/create-first-admin/index';
|
|
4
|
+
import Login from '../views/login/index';
|
|
5
|
+
export { LoginRedirect, Logo, CreateFirstAdmin, Login };
|
|
6
|
+
|
|
7
|
+
//# sourceMappingURL=rsc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../src/plugin/payload/exports/rsc.ts"],"sourcesContent":["import LoginRedirect from '../components/login-redirect'\nimport Logo from '../components/logo'\nimport CreateFirstAdmin from '../views/create-first-admin/index'\nimport Login from '../views/login/index'\n\nexport { LoginRedirect, Logo, CreateFirstAdmin, Login }\n"],"names":["LoginRedirect","Logo","CreateFirstAdmin","Login"],"mappings":"AAAA,OAAOA,mBAAmB,+BAA8B;AACxD,OAAOC,UAAU,qBAAoB;AACrC,OAAOC,sBAAsB,oCAAmC;AAChE,OAAOC,WAAW,uBAAsB;AAExC,SAASH,aAAa,EAAEC,IAAI,EAAEC,gBAAgB,EAAEC,KAAK,GAAE"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
|
|
4
|
+
import { redirect } from 'next/navigation';
|
|
5
|
+
import { Gutter } from '@payloadcms/ui';
|
|
6
|
+
import { SignUp } from '../../components/sign-up';
|
|
7
|
+
import Logo from '../../components/logo';
|
|
8
|
+
export default async function CreateFirstAdmin({ initPageResult, params, searchParams, defaultAdminRole }) {
|
|
9
|
+
const { locale, permissions, req } = initPageResult;
|
|
10
|
+
const { i18n, payload: { config }, payload, user } = req;
|
|
11
|
+
const { admin: { components: { afterLogin, beforeLogin, graphics } = {}, user: userSlug }, routes: { admin, api } } = config;
|
|
12
|
+
const adminCount = await req.payload.count({
|
|
13
|
+
collection: userSlug,
|
|
14
|
+
where: {
|
|
15
|
+
role: {
|
|
16
|
+
equals: defaultAdminRole ?? 'admin'
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
if (adminCount.totalDocs > 0) {
|
|
21
|
+
redirect(admin);
|
|
22
|
+
}
|
|
23
|
+
// const addRoleAction = async (userId: string) => {
|
|
24
|
+
// 'use server'
|
|
25
|
+
// await payload.update({
|
|
26
|
+
// collection: userSlug,
|
|
27
|
+
// id: userId,
|
|
28
|
+
// data: {
|
|
29
|
+
// role: defaultAdminRole ?? 'admin',
|
|
30
|
+
// },
|
|
31
|
+
// })
|
|
32
|
+
// }
|
|
33
|
+
// Filter out the first component from afterLogin array or set to undefined if not more than 1
|
|
34
|
+
const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined;
|
|
35
|
+
return /*#__PURE__*/ _jsx(Gutter, {
|
|
36
|
+
className: "mt-40",
|
|
37
|
+
children: /*#__PURE__*/ _jsxs("div", {
|
|
38
|
+
style: {
|
|
39
|
+
display: 'flex',
|
|
40
|
+
flexDirection: 'column',
|
|
41
|
+
alignItems: 'center',
|
|
42
|
+
justifyContent: 'center'
|
|
43
|
+
},
|
|
44
|
+
children: [
|
|
45
|
+
/*#__PURE__*/ _jsx("div", {
|
|
46
|
+
style: {
|
|
47
|
+
display: 'flex',
|
|
48
|
+
justifyContent: 'center',
|
|
49
|
+
width: '100%',
|
|
50
|
+
marginBottom: '1.5rem'
|
|
51
|
+
},
|
|
52
|
+
children: RenderServerComponent({
|
|
53
|
+
Component: graphics?.Logo,
|
|
54
|
+
Fallback: ()=>/*#__PURE__*/ _jsx(Logo, {}),
|
|
55
|
+
importMap: payload.importMap,
|
|
56
|
+
serverProps: {
|
|
57
|
+
i18n,
|
|
58
|
+
locale,
|
|
59
|
+
params,
|
|
60
|
+
payload,
|
|
61
|
+
permissions,
|
|
62
|
+
searchParams,
|
|
63
|
+
user: user ?? undefined
|
|
64
|
+
}
|
|
65
|
+
})
|
|
66
|
+
}),
|
|
67
|
+
RenderServerComponent({
|
|
68
|
+
Component: beforeLogin,
|
|
69
|
+
importMap: payload.importMap,
|
|
70
|
+
serverProps: {
|
|
71
|
+
i18n,
|
|
72
|
+
locale,
|
|
73
|
+
params,
|
|
74
|
+
payload,
|
|
75
|
+
permissions,
|
|
76
|
+
searchParams,
|
|
77
|
+
user: user ?? undefined
|
|
78
|
+
}
|
|
79
|
+
}),
|
|
80
|
+
/*#__PURE__*/ _jsx("div", {
|
|
81
|
+
style: {
|
|
82
|
+
display: 'flex',
|
|
83
|
+
flexDirection: 'column',
|
|
84
|
+
alignItems: 'center',
|
|
85
|
+
justifyContent: 'center'
|
|
86
|
+
},
|
|
87
|
+
children: /*#__PURE__*/ _jsx(SignUp, {
|
|
88
|
+
admin: true,
|
|
89
|
+
apiRoute: api,
|
|
90
|
+
userSlug: userSlug,
|
|
91
|
+
defaultAdminRole: defaultAdminRole
|
|
92
|
+
})
|
|
93
|
+
}),
|
|
94
|
+
RenderServerComponent({
|
|
95
|
+
Component: filteredAfterLogin,
|
|
96
|
+
importMap: payload.importMap,
|
|
97
|
+
serverProps: {
|
|
98
|
+
i18n,
|
|
99
|
+
locale,
|
|
100
|
+
params,
|
|
101
|
+
payload,
|
|
102
|
+
permissions,
|
|
103
|
+
searchParams,
|
|
104
|
+
user: user ?? undefined
|
|
105
|
+
}
|
|
106
|
+
})
|
|
107
|
+
]
|
|
108
|
+
})
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/views/create-first-admin/index.tsx"],"sourcesContent":["import React from 'react'\nimport type { AdminViewServerProps, ServerProps } from 'payload'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { redirect } from 'next/navigation'\nimport { Gutter } from '@payloadcms/ui'\nimport { SignUp } from '../../components/sign-up'\nimport Logo from '../../components/logo'\n\nexport default async function CreateFirstAdmin({\n initPageResult,\n params,\n searchParams,\n defaultAdminRole,\n}: AdminViewServerProps & { defaultAdminRole: string }) {\n const { locale, permissions, req } = initPageResult\n const {\n i18n,\n payload: { config },\n payload,\n user,\n } = req\n\n const {\n admin: { components: { afterLogin, beforeLogin, graphics } = {}, user: userSlug },\n routes: { admin, api },\n } = config\n\n const adminCount = await req.payload.count({\n collection: userSlug,\n where: {\n role: {\n equals: defaultAdminRole ?? 'admin',\n },\n },\n })\n\n if (adminCount.totalDocs > 0) {\n redirect(admin)\n }\n\n // const addRoleAction = async (userId: string) => {\n // 'use server'\n // await payload.update({\n // collection: userSlug,\n // id: userId,\n // data: {\n // role: defaultAdminRole ?? 'admin',\n // },\n // })\n // }\n\n // Filter out the first component from afterLogin array or set to undefined if not more than 1\n const filteredAfterLogin =\n Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n\n return (\n <Gutter className=\"mt-40\">\n <div\n style={{\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n >\n <div\n style={{\n display: 'flex',\n justifyContent: 'center',\n width: '100%',\n marginBottom: '1.5rem',\n }}\n >\n {RenderServerComponent({\n Component: graphics?.Logo,\n Fallback: () => <Logo />,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n </div>\n {RenderServerComponent({\n Component: beforeLogin,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n <div\n style={{\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n }}\n >\n <SignUp\n admin={true}\n apiRoute={api}\n userSlug={userSlug}\n defaultAdminRole={defaultAdminRole}\n />\n </div>\n {RenderServerComponent({\n Component: filteredAfterLogin,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n </div>\n </Gutter>\n )\n}\n"],"names":["React","RenderServerComponent","redirect","Gutter","SignUp","Logo","CreateFirstAdmin","initPageResult","params","searchParams","defaultAdminRole","locale","permissions","req","i18n","payload","config","user","admin","components","afterLogin","beforeLogin","graphics","userSlug","routes","api","adminCount","count","collection","where","role","equals","totalDocs","filteredAfterLogin","Array","isArray","length","slice","undefined","className","div","style","display","flexDirection","alignItems","justifyContent","width","marginBottom","Component","Fallback","importMap","serverProps","apiRoute"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,SAASC,qBAAqB,QAAQ,gDAA+C;AACrF,SAASC,QAAQ,QAAQ,kBAAiB;AAC1C,SAASC,MAAM,QAAQ,iBAAgB;AACvC,SAASC,MAAM,QAAQ,2BAA0B;AACjD,OAAOC,UAAU,wBAAuB;AAExC,eAAe,eAAeC,iBAAiB,EAC7CC,cAAc,EACdC,MAAM,EACNC,YAAY,EACZC,gBAAgB,EACoC;IACpD,MAAM,EAAEC,MAAM,EAAEC,WAAW,EAAEC,GAAG,EAAE,GAAGN;IACrC,MAAM,EACJO,IAAI,EACJC,SAAS,EAAEC,MAAM,EAAE,EACnBD,OAAO,EACPE,IAAI,EACL,GAAGJ;IAEJ,MAAM,EACJK,OAAO,EAAEC,YAAY,EAAEC,UAAU,EAAEC,WAAW,EAAEC,QAAQ,EAAE,GAAG,CAAC,CAAC,EAAEL,MAAMM,QAAQ,EAAE,EACjFC,QAAQ,EAAEN,KAAK,EAAEO,GAAG,EAAE,EACvB,GAAGT;IAEJ,MAAMU,aAAa,MAAMb,IAAIE,OAAO,CAACY,KAAK,CAAC;QACzCC,YAAYL;QACZM,OAAO;YACLC,MAAM;gBACJC,QAAQrB,oBAAoB;YAC9B;QACF;IACF;IAEA,IAAIgB,WAAWM,SAAS,GAAG,GAAG;QAC5B9B,SAASgB;IACX;IAEA,oDAAoD;IACpD,iBAAiB;IACjB,2BAA2B;IAC3B,4BAA4B;IAC5B,kBAAkB;IAClB,cAAc;IACd,2CAA2C;IAC3C,SAAS;IACT,OAAO;IACP,IAAI;IAEJ,8FAA8F;IAC9F,MAAMe,qBACJC,MAAMC,OAAO,CAACf,eAAeA,WAAWgB,MAAM,GAAG,IAAIhB,WAAWiB,KAAK,CAAC,KAAKC;IAE7E,qBACE,KAACnC;QAAOoC,WAAU;kBAChB,cAAA,MAACC;YACCC,OAAO;gBACLC,SAAS;gBACTC,eAAe;gBACfC,YAAY;gBACZC,gBAAgB;YAClB;;8BAEA,KAACL;oBACCC,OAAO;wBACLC,SAAS;wBACTG,gBAAgB;wBAChBC,OAAO;wBACPC,cAAc;oBAChB;8BAEC9C,sBAAsB;wBACrB+C,WAAW1B,UAAUjB;wBACrB4C,UAAU,kBAAM,KAAC5C;wBACjB6C,WAAWnC,QAAQmC,SAAS;wBAC5BC,aAAa;4BACXrC;4BACAH;4BACAH;4BACAO;4BACAH;4BACAH;4BACAQ,MAAMA,QAAQqB;wBAChB;oBACF;;gBAEDrC,sBAAsB;oBACrB+C,WAAW3B;oBACX6B,WAAWnC,QAAQmC,SAAS;oBAC5BC,aAAa;wBACXrC;wBACAH;wBACAH;wBACAO;wBACAH;wBACAH;wBACAQ,MAAMA,QAAQqB;oBAChB;gBACF;8BACA,KAACE;oBACCC,OAAO;wBACLC,SAAS;wBACTC,eAAe;wBACfC,YAAY;wBACZC,gBAAgB;oBAClB;8BAEA,cAAA,KAACzC;wBACCc,OAAO;wBACPkC,UAAU3B;wBACVF,UAAUA;wBACVb,kBAAkBA;;;gBAGrBT,sBAAsB;oBACrB+C,WAAWf;oBACXiB,WAAWnC,QAAQmC,SAAS;oBAC5BC,aAAa;wBACXrC;wBACAH;wBACAH;wBACAO;wBACAH;wBACAH;wBACAQ,MAAMA,QAAQqB;oBAChB;gBACF;;;;AAIR"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
|
|
4
|
+
import { redirect } from 'next/navigation';
|
|
5
|
+
import { Gutter } from '@payloadcms/ui';
|
|
6
|
+
import SignIn from '../../components/sign-in';
|
|
7
|
+
import Logo from '../../components/logo';
|
|
8
|
+
export default async function LoginView({ initPageResult, params, searchParams, defaultAdminRole }) {
|
|
9
|
+
const { locale, permissions, req } = initPageResult;
|
|
10
|
+
const { i18n, payload: { config }, payload, user } = req;
|
|
11
|
+
const { admin: { components: { afterLogin, beforeLogin, graphics } = {}, user: userSlug }, routes: { admin } } = config;
|
|
12
|
+
const adminCount = await req.payload.count({
|
|
13
|
+
collection: userSlug,
|
|
14
|
+
where: {
|
|
15
|
+
role: {
|
|
16
|
+
equals: defaultAdminRole ?? 'admin'
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
// Filter out the first component from afterLogin array or set to undefined if not more than 1
|
|
21
|
+
const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined;
|
|
22
|
+
if (adminCount.totalDocs === 0) {
|
|
23
|
+
redirect(`${admin}/create-first-admin`);
|
|
24
|
+
}
|
|
25
|
+
return /*#__PURE__*/ _jsxs(Gutter, {
|
|
26
|
+
className: "mt-40",
|
|
27
|
+
children: [
|
|
28
|
+
RenderServerComponent({
|
|
29
|
+
Component: graphics?.Logo,
|
|
30
|
+
Fallback: ()=>/*#__PURE__*/ _jsx(Logo, {}),
|
|
31
|
+
importMap: payload.importMap,
|
|
32
|
+
serverProps: {
|
|
33
|
+
i18n,
|
|
34
|
+
locale,
|
|
35
|
+
params,
|
|
36
|
+
payload,
|
|
37
|
+
permissions,
|
|
38
|
+
searchParams,
|
|
39
|
+
user: user ?? undefined
|
|
40
|
+
}
|
|
41
|
+
}),
|
|
42
|
+
RenderServerComponent({
|
|
43
|
+
Component: beforeLogin,
|
|
44
|
+
importMap: payload.importMap,
|
|
45
|
+
serverProps: {
|
|
46
|
+
i18n,
|
|
47
|
+
locale,
|
|
48
|
+
params,
|
|
49
|
+
payload,
|
|
50
|
+
permissions,
|
|
51
|
+
searchParams,
|
|
52
|
+
user: user ?? undefined
|
|
53
|
+
}
|
|
54
|
+
}),
|
|
55
|
+
/*#__PURE__*/ _jsx("div", {
|
|
56
|
+
className: "flex flex-col items-center justify-center",
|
|
57
|
+
children: /*#__PURE__*/ _jsx(SignIn, {
|
|
58
|
+
admin: true
|
|
59
|
+
})
|
|
60
|
+
}),
|
|
61
|
+
RenderServerComponent({
|
|
62
|
+
Component: filteredAfterLogin,
|
|
63
|
+
importMap: payload.importMap,
|
|
64
|
+
serverProps: {
|
|
65
|
+
i18n,
|
|
66
|
+
locale,
|
|
67
|
+
params,
|
|
68
|
+
payload,
|
|
69
|
+
permissions,
|
|
70
|
+
searchParams,
|
|
71
|
+
user: user ?? undefined
|
|
72
|
+
}
|
|
73
|
+
})
|
|
74
|
+
]
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../../../src/plugin/payload/views/login/index.tsx"],"sourcesContent":["import React from 'react'\nimport type { AdminViewServerProps, ServerProps } from 'payload'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { redirect } from 'next/navigation'\nimport { Gutter } from '@payloadcms/ui'\nimport SignIn from '../../components/sign-in'\nimport Logo from '../../components/logo'\n\nexport default async function LoginView({\n initPageResult,\n params,\n searchParams,\n defaultAdminRole,\n}: AdminViewServerProps & { defaultAdminRole: string }) {\n const { locale, permissions, req } = initPageResult\n const {\n i18n,\n payload: { config },\n payload,\n user,\n } = req\n\n const {\n admin: { components: { afterLogin, beforeLogin, graphics } = {}, user: userSlug },\n routes: { admin },\n } = config\n\n const adminCount = await req.payload.count({\n collection: userSlug,\n where: {\n role: {\n equals: defaultAdminRole ?? 'admin',\n },\n },\n })\n\n // Filter out the first component from afterLogin array or set to undefined if not more than 1\n const filteredAfterLogin =\n Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n\n if (adminCount.totalDocs === 0) {\n redirect(`${admin}/create-first-admin`)\n }\n\n return (\n <Gutter className=\"mt-40\">\n {RenderServerComponent({\n Component: graphics?.Logo,\n Fallback: () => <Logo />,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n {RenderServerComponent({\n Component: beforeLogin,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n <div className=\"flex flex-col items-center justify-center\">\n <SignIn admin={true} />\n </div>\n {RenderServerComponent({\n Component: filteredAfterLogin,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user: user ?? undefined,\n } satisfies ServerProps,\n })}\n </Gutter>\n )\n}\n"],"names":["React","RenderServerComponent","redirect","Gutter","SignIn","Logo","LoginView","initPageResult","params","searchParams","defaultAdminRole","locale","permissions","req","i18n","payload","config","user","admin","components","afterLogin","beforeLogin","graphics","userSlug","routes","adminCount","count","collection","where","role","equals","filteredAfterLogin","Array","isArray","length","slice","undefined","totalDocs","className","Component","Fallback","importMap","serverProps","div"],"mappings":";AAAA,OAAOA,WAAW,QAAO;AAEzB,SAASC,qBAAqB,QAAQ,gDAA+C;AACrF,SAASC,QAAQ,QAAQ,kBAAiB;AAC1C,SAASC,MAAM,QAAQ,iBAAgB;AACvC,OAAOC,YAAY,2BAA0B;AAC7C,OAAOC,UAAU,wBAAuB;AAExC,eAAe,eAAeC,UAAU,EACtCC,cAAc,EACdC,MAAM,EACNC,YAAY,EACZC,gBAAgB,EACoC;IACpD,MAAM,EAAEC,MAAM,EAAEC,WAAW,EAAEC,GAAG,EAAE,GAAGN;IACrC,MAAM,EACJO,IAAI,EACJC,SAAS,EAAEC,MAAM,EAAE,EACnBD,OAAO,EACPE,IAAI,EACL,GAAGJ;IAEJ,MAAM,EACJK,OAAO,EAAEC,YAAY,EAAEC,UAAU,EAAEC,WAAW,EAAEC,QAAQ,EAAE,GAAG,CAAC,CAAC,EAAEL,MAAMM,QAAQ,EAAE,EACjFC,QAAQ,EAAEN,KAAK,EAAE,EAClB,GAAGF;IAEJ,MAAMS,aAAa,MAAMZ,IAAIE,OAAO,CAACW,KAAK,CAAC;QACzCC,YAAYJ;QACZK,OAAO;YACLC,MAAM;gBACJC,QAAQpB,oBAAoB;YAC9B;QACF;IACF;IAEA,8FAA8F;IAC9F,MAAMqB,qBACJC,MAAMC,OAAO,CAACb,eAAeA,WAAWc,MAAM,GAAG,IAAId,WAAWe,KAAK,CAAC,KAAKC;IAE7E,IAAIX,WAAWY,SAAS,KAAK,GAAG;QAC9BnC,SAAS,GAAGgB,MAAM,mBAAmB,CAAC;IACxC;IAEA,qBACE,MAACf;QAAOmC,WAAU;;YACfrC,sBAAsB;gBACrBsC,WAAWjB,UAAUjB;gBACrBmC,UAAU,kBAAM,KAACnC;gBACjBoC,WAAW1B,QAAQ0B,SAAS;gBAC5BC,aAAa;oBACX5B;oBACAH;oBACAH;oBACAO;oBACAH;oBACAH;oBACAQ,MAAMA,QAAQmB;gBAChB;YACF;YACCnC,sBAAsB;gBACrBsC,WAAWlB;gBACXoB,WAAW1B,QAAQ0B,SAAS;gBAC5BC,aAAa;oBACX5B;oBACAH;oBACAH;oBACAO;oBACAH;oBACAH;oBACAQ,MAAMA,QAAQmB;gBAChB;YACF;0BACA,KAACO;gBAAIL,WAAU;0BACb,cAAA,KAAClC;oBAAOc,OAAO;;;YAEhBjB,sBAAsB;gBACrBsC,WAAWR;gBACXU,WAAW1B,QAAQ0B,SAAS;gBAC5BC,aAAa;oBACX5B;oBACAH;oBACAH;oBACAO;oBACAH;oBACAH;oBACAQ,MAAMA,QAAQmB;gBAChB;YACF;;;AAGN"}
|