@turinhub/atomix-common-ui 0.4.0 → 0.5.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.
Files changed (69) hide show
  1. package/README.md +20 -2
  2. package/dist/AuthPanel-C_2JBE7t.cjs +2 -0
  3. package/dist/AuthPanel-C_2JBE7t.cjs.map +1 -0
  4. package/dist/AuthPanel-D2HFX8eN.js +656 -0
  5. package/dist/AuthPanel-D2HFX8eN.js.map +1 -0
  6. package/dist/auth.cjs +2 -0
  7. package/dist/auth.cjs.map +1 -0
  8. package/dist/auth.d.ts +11 -0
  9. package/dist/auth.d.ts.map +1 -0
  10. package/dist/auth.js +9 -0
  11. package/dist/auth.js.map +1 -0
  12. package/dist/components/AuthLoginPanel.d.ts +55 -0
  13. package/dist/components/AuthLoginPanel.d.ts.map +1 -0
  14. package/dist/components/AuthPageShell.d.ts +11 -0
  15. package/dist/components/AuthPageShell.d.ts.map +1 -0
  16. package/dist/components/AuthPanel.d.ts +20 -0
  17. package/dist/components/AuthPanel.d.ts.map +1 -0
  18. package/dist/components/AuthRegisterPanel.d.ts +34 -0
  19. package/dist/components/AuthRegisterPanel.d.ts.map +1 -0
  20. package/dist/components/AuthVisualCarousel.d.ts +20 -0
  21. package/dist/components/AuthVisualCarousel.d.ts.map +1 -0
  22. package/dist/components/DataTable.d.ts +2 -2
  23. package/dist/components/DataTable.d.ts.map +1 -1
  24. package/dist/components/ImageReader.d.ts +44 -0
  25. package/dist/components/ImageReader.d.ts.map +1 -0
  26. package/dist/components/VideoReader.d.ts +39 -0
  27. package/dist/components/VideoReader.d.ts.map +1 -0
  28. package/dist/components/media-utils.d.ts +9 -0
  29. package/dist/components/media-utils.d.ts.map +1 -0
  30. package/dist/data-table.cjs +1 -1
  31. package/dist/data-table.cjs.map +1 -1
  32. package/dist/data-table.js +83 -73
  33. package/dist/data-table.js.map +1 -1
  34. package/dist/image-reader.cjs +2 -0
  35. package/dist/image-reader.cjs.map +1 -0
  36. package/dist/image-reader.d.ts +3 -0
  37. package/dist/image-reader.d.ts.map +1 -0
  38. package/dist/image-reader.js +214 -0
  39. package/dist/image-reader.js.map +1 -0
  40. package/dist/index.cjs +1 -1
  41. package/dist/index.d.ts +10 -0
  42. package/dist/index.d.ts.map +1 -1
  43. package/dist/index.js +8 -2
  44. package/dist/index.js.map +1 -1
  45. package/dist/media-utils-5UPuocc1.js +23 -0
  46. package/dist/media-utils-5UPuocc1.js.map +1 -0
  47. package/dist/media-utils-X1dDYP9W.cjs +2 -0
  48. package/dist/media-utils-X1dDYP9W.cjs.map +1 -0
  49. package/dist/pdf-reader.cjs +1 -1
  50. package/dist/pdf-reader.cjs.map +1 -1
  51. package/dist/pdf-reader.js +1 -1
  52. package/dist/pdf-reader.js.map +1 -1
  53. package/dist/simple-pdf-reader.cjs +1 -1
  54. package/dist/simple-pdf-reader.cjs.map +1 -1
  55. package/dist/simple-pdf-reader.js +1 -1
  56. package/dist/simple-pdf-reader.js.map +1 -1
  57. package/dist/types/component-types.d.ts +1 -0
  58. package/dist/types/component-types.d.ts.map +1 -1
  59. package/dist/video-reader.cjs +2 -0
  60. package/dist/video-reader.cjs.map +1 -0
  61. package/dist/video-reader.d.ts +3 -0
  62. package/dist/video-reader.d.ts.map +1 -0
  63. package/dist/video-reader.js +158 -0
  64. package/dist/video-reader.js.map +1 -0
  65. package/package.json +31 -1
  66. package/dist/index-BiA_tnaq.cjs +0 -13
  67. package/dist/index-BiA_tnaq.cjs.map +0 -1
  68. package/dist/index-BypbGNpR.js +0 -18821
  69. package/dist/index-BypbGNpR.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthPanel-D2HFX8eN.js","sources":["../src/components/AuthLoginPanel.tsx","../src/components/AuthRegisterPanel.tsx","../src/components/AuthPageShell.tsx","../src/components/AuthVisualCarousel.tsx","../src/components/AuthPanel.tsx"],"sourcesContent":["import {\n ArrowRight,\n Layers3,\n Loader2,\n LockKeyhole,\n MessageCircle,\n UserRound,\n} from 'lucide-react';\nimport { useEffect, useMemo, useState } from 'react';\nimport type { FormEvent, ReactNode } from 'react';\n\nimport { cn } from '../lib/utils';\nimport type {\n ButtonComponent,\n InputComponent,\n LabelComponent,\n TabsComponent,\n TabsContentComponent,\n TabsListComponent,\n TabsTriggerComponent,\n} from '../types/component-types';\n\nexport type AuthLoginMethod = 'password' | 'sms';\nexport type AuthValidationResult = string | undefined | null;\n\nexport interface AuthUIComponents {\n Button: ButtonComponent;\n Input: InputComponent;\n Label: LabelComponent;\n Tabs: TabsComponent;\n TabsList: TabsListComponent;\n TabsTrigger: TabsTriggerComponent;\n TabsContent: TabsContentComponent;\n}\n\nexport interface AuthSocialProvider {\n id: string;\n label: ReactNode;\n icon?: ReactNode;\n disabled?: boolean;\n onClick?: () => Promise<void> | void;\n}\n\nexport interface AuthSmsCodeResult {\n smsId?: string;\n smsType?: string;\n}\n\nexport interface AuthPasswordLoginPayload {\n username: string;\n password: string;\n}\n\nexport interface AuthSmsLoginPayload {\n phone: string;\n code: string;\n smsId?: string;\n smsType?: string;\n}\n\nexport interface AuthLoginPanelProps {\n components?: AuthUIComponents;\n title?: ReactNode;\n description?: ReactNode;\n brandIcon?: ReactNode;\n defaultMethod?: AuthLoginMethod;\n enabledMethods?: AuthLoginMethod[];\n error?: ReactNode;\n extraActions?: ReactNode;\n footer?: ReactNode;\n socialProviders?: AuthSocialProvider[];\n className?: string;\n smsCountdownSeconds?: number;\n validatePhone?: (phone: string) => AuthValidationResult;\n validatePassword?: (payload: AuthPasswordLoginPayload) => AuthValidationResult;\n onPasswordLogin?: (payload: AuthPasswordLoginPayload) => Promise<void> | void;\n onSendSmsCode?: (\n phone: string\n ) => Promise<AuthSmsCodeResult | void> | AuthSmsCodeResult | void;\n onSmsLogin?: (payload: AuthSmsLoginPayload) => Promise<void> | void;\n}\n\nconst defaultValidatePhone = (phone: string) =>\n /^1[3-9]\\d{9}$/.test(phone) ? undefined : '请输入正确的手机号';\n\nconst getErrorMessage = (error: unknown, fallback: string) => {\n if (error instanceof Error && error.message) return error.message;\n if (typeof error === 'string' && error) return error;\n return fallback;\n};\n\nconst normalizePhone = (value: string) => value.replace(/\\D/g, '').slice(0, 11);\n\nconst formatPhone = (phone: string) => {\n if (phone.length <= 3) return phone;\n if (phone.length <= 7) return `${phone.slice(0, 3)} ${phone.slice(3)}`;\n return `${phone.slice(0, 3)} ${phone.slice(3, 7)} ${phone.slice(7)}`;\n};\n\nexport function AuthLoginPanel({\n components,\n title = '欢迎登录',\n description = '使用账号密码或手机号验证码进入系统',\n brandIcon,\n defaultMethod = 'password',\n enabledMethods = ['password', 'sms'],\n error,\n extraActions,\n footer,\n socialProviders,\n className,\n smsCountdownSeconds = 60,\n validatePhone = defaultValidatePhone,\n validatePassword,\n onPasswordLogin,\n onSendSmsCode,\n onSmsLogin,\n}: AuthLoginPanelProps) {\n const [activeMethod, setActiveMethod] = useState<AuthLoginMethod>(\n enabledMethods.includes(defaultMethod) ? defaultMethod : enabledMethods[0]\n );\n const [phone, setPhone] = useState('');\n const [smsId, setSmsId] = useState<string | undefined>();\n const [smsType, setSmsType] = useState<string | undefined>();\n const [localError, setLocalError] = useState<ReactNode>();\n const [passwordPending, setPasswordPending] = useState(false);\n const [smsPending, setSmsPending] = useState(false);\n const [codePending, setCodePending] = useState(false);\n const [countdown, setCountdown] = useState(0);\n\n const methods = useMemo(\n () =>\n enabledMethods.filter(\n (method, index, array) => array.indexOf(method) === index\n ),\n [enabledMethods]\n );\n const shouldShowTabs = methods.length > 1;\n const displayedError = localError || error;\n\n useEffect(() => {\n if (countdown <= 0) return;\n const timer = setTimeout(() => setCountdown((value) => value - 1), 1000);\n return () => clearTimeout(timer);\n }, [countdown]);\n\n if (!components) {\n return (\n <div className=\"p-4 text-center text-destructive\">\n 错误:请通过 components prop 注入 UI 组件\n </div>\n );\n }\n\n const { Button, Input, Label, Tabs, TabsList, TabsTrigger, TabsContent } =\n components;\n\n const handlePasswordSubmit = async (event: FormEvent<HTMLFormElement>) => {\n event.preventDefault();\n const formData = new FormData(event.currentTarget);\n const payload = {\n username: String(formData.get('username') || '').trim(),\n password: String(formData.get('password') || ''),\n };\n\n const validationError =\n !payload.username || !payload.password\n ? '请输入账号和密码'\n : validatePassword?.(payload);\n if (validationError) {\n setLocalError(validationError);\n return;\n }\n\n try {\n setPasswordPending(true);\n setLocalError(undefined);\n await onPasswordLogin?.(payload);\n } catch (err) {\n setLocalError(getErrorMessage(err, '登录失败,请稍后重试'));\n } finally {\n setPasswordPending(false);\n }\n };\n\n const handleSendCode = async () => {\n const validationError = validatePhone(phone);\n if (validationError) {\n setLocalError(validationError);\n return;\n }\n\n try {\n setCodePending(true);\n setLocalError(undefined);\n const result = await onSendSmsCode?.(phone);\n setSmsId(result?.smsId);\n setSmsType(result?.smsType);\n setCountdown(smsCountdownSeconds);\n } catch (err) {\n setLocalError(getErrorMessage(err, '发送验证码失败,请稍后重试'));\n } finally {\n setCodePending(false);\n }\n };\n\n const handleSmsSubmit = async (event: FormEvent<HTMLFormElement>) => {\n event.preventDefault();\n const formData = new FormData(event.currentTarget);\n const code = String(formData.get('code') || '').trim();\n const validationError = validatePhone(phone);\n\n if (validationError) {\n setLocalError(validationError);\n return;\n }\n if (!code) {\n setLocalError('请输入验证码');\n return;\n }\n\n try {\n setSmsPending(true);\n setLocalError(undefined);\n await onSmsLogin?.({ phone, code, smsId, smsType });\n } catch (err) {\n setLocalError(getErrorMessage(err, '验证码错误或已过期'));\n } finally {\n setSmsPending(false);\n }\n };\n\n const renderHeader = () => (\n <div className=\"mb-7\">\n <div className=\"mb-4 flex h-11 w-11 items-center justify-center rounded-lg bg-primary text-primary-foreground shadow-sm\">\n {brandIcon || <Layers3 className=\"h-5 w-5\" />}\n </div>\n <h1 className=\"text-2xl font-semibold\">{title}</h1>\n {description && (\n <p className=\"mt-2 text-sm leading-6 text-muted-foreground\">\n {description}\n </p>\n )}\n </div>\n );\n\n const renderSocialProviders = () =>\n socialProviders?.length ? (\n <div className=\"mb-6 grid gap-2\">\n {socialProviders.map((provider) => (\n <Button\n key={provider.id}\n type=\"button\"\n variant=\"outline\"\n className=\"h-10 w-full\"\n disabled={provider.disabled}\n onClick={provider.onClick}\n >\n {provider.icon && (\n <span className=\"mr-2 inline-flex h-4 w-4 items-center justify-center\">\n {provider.icon}\n </span>\n )}\n {provider.label}\n </Button>\n ))}\n </div>\n ) : null;\n\n const renderPasswordForm = () => (\n <form className=\"flex flex-col\" onSubmit={handlePasswordSubmit}>\n <div className=\"flex flex-col gap-4\">\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-username\">用户名</Label>\n <div className=\"relative\">\n <UserRound className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-username\"\n name=\"username\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n placeholder=\"请输入用户名\"\n autoComplete=\"username\"\n required\n />\n </div>\n </div>\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-password\">密码</Label>\n <div className=\"relative\">\n <LockKeyhole className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-password\"\n name=\"password\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n type=\"password\"\n placeholder=\"请输入密码\"\n autoComplete=\"current-password\"\n required\n />\n </div>\n </div>\n <Button\n type=\"submit\"\n className=\"mt-4 h-11 w-full\"\n disabled={passwordPending}\n >\n {passwordPending ? (\n <>\n <Loader2 className=\"mr-2 h-4 w-4 animate-spin\" />\n 登录中...\n </>\n ) : (\n <>\n 登录\n <ArrowRight className=\"ml-2 h-4 w-4\" />\n </>\n )}\n </Button>\n </div>\n </form>\n );\n\n const renderSmsForm = () => (\n <form className=\"flex flex-col\" onSubmit={handleSmsSubmit}>\n <div className=\"flex flex-col gap-4\">\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-phone\">手机号</Label>\n <div className=\"flex gap-2\">\n <div className=\"relative w-full\">\n <MessageCircle className=\"pointer-events-none absolute left-3 top-1/2 z-10 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-phone\"\n name=\"phone\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n placeholder=\"请输入手机号\"\n value={formatPhone(phone)}\n onChange={(event) => setPhone(normalizePhone(event.target.value))}\n required\n maxLength={13}\n inputMode=\"numeric\"\n />\n </div>\n <Button\n type=\"button\"\n variant=\"outline\"\n className=\"h-10 w-28 shrink-0 bg-background/70 backdrop-blur hover:bg-background/90\"\n onClick={handleSendCode}\n disabled={!phone || codePending || countdown > 0}\n >\n {codePending ? (\n <Loader2 className=\"h-4 w-4 animate-spin\" />\n ) : countdown > 0 ? (\n `${countdown}秒`\n ) : (\n '发送验证码'\n )}\n </Button>\n </div>\n </div>\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-code\">验证码</Label>\n <Input\n id=\"auth-code\"\n name=\"code\"\n className=\"bg-background/80 backdrop-blur\"\n placeholder=\"请输入验证码\"\n inputMode=\"numeric\"\n autoComplete=\"one-time-code\"\n required\n />\n </div>\n <Button type=\"submit\" className=\"mt-4 h-11 w-full\" disabled={smsPending}>\n {smsPending ? (\n <>\n <Loader2 className=\"mr-2 h-4 w-4 animate-spin\" />\n 验证中...\n </>\n ) : (\n <>\n 验证并登录\n <ArrowRight className=\"ml-2 h-4 w-4\" />\n </>\n )}\n </Button>\n </div>\n </form>\n );\n\n const renderForms = () => {\n if (!shouldShowTabs) {\n return methods[0] === 'sms' ? renderSmsForm() : renderPasswordForm();\n }\n\n return (\n <Tabs\n value={activeMethod}\n onValueChange={(value) => setActiveMethod(value as AuthLoginMethod)}\n className=\"w-full\"\n >\n <TabsList className=\"mb-6 grid h-11 w-full grid-cols-2 bg-background/60 backdrop-blur\">\n {methods.includes('password') && (\n <TabsTrigger value=\"password\">账号密码登录</TabsTrigger>\n )}\n {methods.includes('sms') && (\n <TabsTrigger value=\"sms\">手机号登录</TabsTrigger>\n )}\n </TabsList>\n <TabsContent value=\"password\">{renderPasswordForm()}</TabsContent>\n <TabsContent value=\"sms\">{renderSmsForm()}</TabsContent>\n </Tabs>\n );\n };\n\n return (\n <div\n className={cn(\n 'w-full max-w-[calc(100vw-2rem)] rounded-lg border border-white/45 bg-background/60 p-5 shadow-2xl shadow-slate-950/25 backdrop-blur-md supports-[backdrop-filter]:bg-background/50 md:p-8',\n className\n )}\n >\n {renderHeader()}\n {renderSocialProviders()}\n {renderForms()}\n {extraActions && <div className=\"mt-5\">{extraActions}</div>}\n {displayedError && (\n <div className=\"mt-4 border-l-2 border-red-600 px-4 text-sm text-red-600 dark:border-red-400 dark:text-red-400\">\n {displayedError}\n </div>\n )}\n {footer && <div className=\"mt-6 text-sm text-muted-foreground\">{footer}</div>}\n </div>\n );\n}\n","import {\n ArrowRight,\n Layers3,\n Loader2,\n LockKeyhole,\n MessageCircle,\n UserRound,\n} from 'lucide-react';\nimport { useEffect, useState } from 'react';\nimport type { FormEvent, ReactNode } from 'react';\n\nimport { cn } from '../lib/utils';\n\nimport type {\n AuthSmsCodeResult,\n AuthSocialProvider,\n AuthUIComponents,\n AuthValidationResult,\n} from './AuthLoginPanel';\n\nexport interface AuthRegisterPayload {\n username: string;\n password: string;\n confirmPassword: string;\n phone: string;\n code: string;\n smsId?: string;\n smsType?: string;\n termsAccepted: boolean;\n}\n\nexport interface AuthRegisterPanelProps {\n components?: AuthUIComponents;\n title?: ReactNode;\n description?: ReactNode;\n brandIcon?: ReactNode;\n requirePhoneVerification?: boolean;\n requireTermsAccepted?: boolean;\n termsLabel?: ReactNode;\n error?: ReactNode;\n extraActions?: ReactNode;\n footer?: ReactNode;\n socialProviders?: AuthSocialProvider[];\n className?: string;\n smsCountdownSeconds?: number;\n validatePhone?: (phone: string) => AuthValidationResult;\n validatePassword?: (payload: AuthRegisterPayload) => AuthValidationResult;\n validateRegister?: (payload: AuthRegisterPayload) => AuthValidationResult;\n onSendSmsCode?: (\n phone: string\n ) => Promise<AuthSmsCodeResult | void> | AuthSmsCodeResult | void;\n onRegister?: (payload: AuthRegisterPayload) => Promise<void> | void;\n}\n\nconst defaultValidatePhone = (phone: string) =>\n /^1[3-9]\\d{9}$/.test(phone) ? undefined : '请输入正确的手机号';\n\nconst getErrorMessage = (error: unknown, fallback: string) => {\n if (error instanceof Error && error.message) return error.message;\n if (typeof error === 'string' && error) return error;\n return fallback;\n};\n\nconst normalizePhone = (value: string) => value.replace(/\\D/g, '').slice(0, 11);\n\nconst formatPhone = (phone: string) => {\n if (phone.length <= 3) return phone;\n if (phone.length <= 7) return `${phone.slice(0, 3)} ${phone.slice(3)}`;\n return `${phone.slice(0, 3)} ${phone.slice(3, 7)} ${phone.slice(7)}`;\n};\n\nexport function AuthRegisterPanel({\n components,\n title = '创建账号',\n description = '填写账号信息并完成手机号验证',\n brandIcon,\n requirePhoneVerification = true,\n requireTermsAccepted = false,\n termsLabel = '我已阅读并同意服务条款',\n error,\n extraActions,\n footer,\n socialProviders,\n className,\n smsCountdownSeconds = 60,\n validatePhone = defaultValidatePhone,\n validatePassword,\n validateRegister,\n onSendSmsCode,\n onRegister,\n}: AuthRegisterPanelProps) {\n const [phone, setPhone] = useState('');\n const [smsId, setSmsId] = useState<string | undefined>();\n const [smsType, setSmsType] = useState<string | undefined>();\n const [termsAccepted, setTermsAccepted] = useState(false);\n const [localError, setLocalError] = useState<ReactNode>();\n const [registerPending, setRegisterPending] = useState(false);\n const [codePending, setCodePending] = useState(false);\n const [countdown, setCountdown] = useState(0);\n const displayedError = localError || error;\n\n useEffect(() => {\n if (countdown <= 0) return;\n const timer = setTimeout(() => setCountdown((value) => value - 1), 1000);\n return () => clearTimeout(timer);\n }, [countdown]);\n\n if (!components) {\n return (\n <div className=\"p-4 text-center text-destructive\">\n 错误:请通过 components prop 注入 UI 组件\n </div>\n );\n }\n\n const { Button, Input, Label } = components;\n\n const handleSendCode = async () => {\n const validationError = validatePhone(phone);\n if (validationError) {\n setLocalError(validationError);\n return;\n }\n\n try {\n setCodePending(true);\n setLocalError(undefined);\n const result = await onSendSmsCode?.(phone);\n setSmsId(result?.smsId);\n setSmsType(result?.smsType);\n setCountdown(smsCountdownSeconds);\n } catch (err) {\n setLocalError(getErrorMessage(err, '发送验证码失败,请稍后重试'));\n } finally {\n setCodePending(false);\n }\n };\n\n const handleRegister = async (event: FormEvent<HTMLFormElement>) => {\n event.preventDefault();\n const formData = new FormData(event.currentTarget);\n const payload: AuthRegisterPayload = {\n username: String(formData.get('username') || '').trim(),\n password: String(formData.get('password') || ''),\n confirmPassword: String(formData.get('confirmPassword') || ''),\n phone,\n code: String(formData.get('code') || '').trim(),\n smsId,\n smsType,\n termsAccepted,\n };\n\n const validationError =\n (!payload.username && '请输入用户名') ||\n (!payload.password && '请输入密码') ||\n (payload.password !== payload.confirmPassword && '两次输入的密码不一致') ||\n (requirePhoneVerification && validatePhone(phone)) ||\n (requirePhoneVerification && !payload.code && '请输入验证码') ||\n (requireTermsAccepted && !termsAccepted && '请先同意服务条款') ||\n validatePassword?.(payload) ||\n validateRegister?.(payload);\n\n if (validationError) {\n setLocalError(validationError);\n return;\n }\n\n try {\n setRegisterPending(true);\n setLocalError(undefined);\n await onRegister?.(payload);\n } catch (err) {\n setLocalError(getErrorMessage(err, '注册失败,请稍后重试'));\n } finally {\n setRegisterPending(false);\n }\n };\n\n const renderSocialProviders = () =>\n socialProviders?.length ? (\n <div className=\"mb-6 grid gap-2\">\n {socialProviders.map((provider) => (\n <Button\n key={provider.id}\n type=\"button\"\n variant=\"outline\"\n className=\"h-10 w-full\"\n disabled={provider.disabled}\n onClick={provider.onClick}\n >\n {provider.icon && (\n <span className=\"mr-2 inline-flex h-4 w-4 items-center justify-center\">\n {provider.icon}\n </span>\n )}\n {provider.label}\n </Button>\n ))}\n </div>\n ) : null;\n\n return (\n <div\n className={cn(\n 'w-full max-w-[calc(100vw-2rem)] rounded-lg border border-white/45 bg-background/60 p-5 shadow-2xl shadow-slate-950/25 backdrop-blur-md supports-[backdrop-filter]:bg-background/50 md:p-8',\n className\n )}\n >\n <div className=\"mb-7\">\n <div className=\"mb-4 flex h-11 w-11 items-center justify-center rounded-lg bg-primary text-primary-foreground shadow-sm\">\n {brandIcon || <Layers3 className=\"h-5 w-5\" />}\n </div>\n <h1 className=\"text-2xl font-semibold\">{title}</h1>\n {description && (\n <p className=\"mt-2 text-sm leading-6 text-muted-foreground\">\n {description}\n </p>\n )}\n </div>\n\n {renderSocialProviders()}\n\n <form className=\"flex flex-col\" onSubmit={handleRegister}>\n <div className=\"flex flex-col gap-4\">\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-register-username\">用户名</Label>\n <div className=\"relative\">\n <UserRound className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-register-username\"\n name=\"username\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n placeholder=\"请输入用户名\"\n autoComplete=\"username\"\n required\n />\n </div>\n </div>\n\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-register-password\">密码</Label>\n <div className=\"relative\">\n <LockKeyhole className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-register-password\"\n name=\"password\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n type=\"password\"\n placeholder=\"请输入密码\"\n autoComplete=\"new-password\"\n required\n />\n </div>\n </div>\n\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-register-confirm-password\">确认密码</Label>\n <div className=\"relative\">\n <LockKeyhole className=\"pointer-events-none absolute left-3 top-1/2 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-register-confirm-password\"\n name=\"confirmPassword\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n type=\"password\"\n placeholder=\"请再次输入密码\"\n autoComplete=\"new-password\"\n required\n />\n </div>\n </div>\n\n {requirePhoneVerification && (\n <>\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-register-phone\">手机号</Label>\n <div className=\"flex gap-2\">\n <div className=\"relative w-full\">\n <MessageCircle className=\"pointer-events-none absolute left-3 top-1/2 z-10 h-4 w-4 -translate-y-1/2 text-muted-foreground\" />\n <Input\n id=\"auth-register-phone\"\n name=\"phone\"\n className=\"bg-background/80 pl-9 backdrop-blur\"\n placeholder=\"请输入手机号\"\n value={formatPhone(phone)}\n onChange={(event) =>\n setPhone(normalizePhone(event.target.value))\n }\n required\n maxLength={13}\n inputMode=\"numeric\"\n />\n </div>\n <Button\n type=\"button\"\n variant=\"outline\"\n className=\"h-10 w-28 shrink-0 bg-background/70 backdrop-blur hover:bg-background/90\"\n onClick={handleSendCode}\n disabled={!phone || codePending || countdown > 0}\n >\n {codePending ? (\n <Loader2 className=\"h-4 w-4 animate-spin\" />\n ) : countdown > 0 ? (\n `${countdown}秒`\n ) : (\n '发送验证码'\n )}\n </Button>\n </div>\n </div>\n <div className=\"space-y-2\">\n <Label htmlFor=\"auth-register-code\">验证码</Label>\n <Input\n id=\"auth-register-code\"\n name=\"code\"\n className=\"bg-background/80 backdrop-blur\"\n placeholder=\"请输入验证码\"\n inputMode=\"numeric\"\n autoComplete=\"one-time-code\"\n required\n />\n </div>\n </>\n )}\n\n {requireTermsAccepted && (\n <label className=\"flex items-start gap-2 text-sm text-muted-foreground\">\n <input\n type=\"checkbox\"\n className=\"mt-0.5 h-4 w-4 rounded border-input\"\n checked={termsAccepted}\n onChange={(event) => setTermsAccepted(event.target.checked)}\n />\n <span>{termsLabel}</span>\n </label>\n )}\n\n <Button\n type=\"submit\"\n className=\"mt-4 h-11 w-full\"\n disabled={registerPending}\n >\n {registerPending ? (\n <>\n <Loader2 className=\"mr-2 h-4 w-4 animate-spin\" />\n 注册中...\n </>\n ) : (\n <>\n 创建账号\n <ArrowRight className=\"ml-2 h-4 w-4\" />\n </>\n )}\n </Button>\n </div>\n </form>\n\n {extraActions && <div className=\"mt-5\">{extraActions}</div>}\n {displayedError && (\n <div className=\"mt-4 border-l-2 border-red-600 px-4 text-sm text-red-600 dark:border-red-400 dark:text-red-400\">\n {displayedError}\n </div>\n )}\n {footer && <div className=\"mt-6 text-sm text-muted-foreground\">{footer}</div>}\n </div>\n );\n}\n","import type { ReactNode } from 'react';\n\nimport { cn } from '../lib/utils';\n\nexport interface AuthPageShellProps {\n children: ReactNode;\n visual?: ReactNode;\n overlay?: ReactNode;\n className?: string;\n contentClassName?: string;\n panelClassName?: string;\n}\n\nexport function AuthPageShell({\n children,\n visual,\n overlay,\n className,\n contentClassName,\n panelClassName,\n}: AuthPageShellProps) {\n return (\n <div className={cn('min-h-screen', className)}>\n <main className=\"relative flex min-h-screen w-full overflow-hidden\">\n {visual && <div className=\"absolute inset-0\">{visual}</div>}\n {overlay ?? <div className=\"absolute inset-0 z-10 bg-black/35\" />}\n <div\n className={cn(\n 'relative z-20 flex min-h-screen w-full items-center justify-center px-4 py-6 sm:px-6 lg:p-12 xl:p-16',\n contentClassName\n )}\n >\n <div className={cn('w-full min-w-0 max-w-[420px]', panelClassName)}>\n {children}\n </div>\n </div>\n </main>\n </div>\n );\n}\n","import { useEffect, useState } from 'react';\nimport type { KeyboardEvent, ReactNode } from 'react';\n\nimport { cn } from '../lib/utils';\n\nexport interface AuthVisualCarouselItem {\n image: string;\n alt: string;\n title?: ReactNode;\n description?: ReactNode;\n eyebrow?: ReactNode;\n}\n\nexport interface AuthVisualCarouselProps {\n items: AuthVisualCarouselItem[];\n intervalMs?: number;\n showIndicators?: boolean;\n showText?: boolean;\n className?: string;\n imageClassName?: string;\n contentClassName?: string;\n ariaLabel?: string;\n}\n\nexport function AuthVisualCarousel({\n items,\n intervalMs = 5000,\n showIndicators = true,\n showText = true,\n className,\n imageClassName,\n contentClassName,\n ariaLabel = '认证页视觉轮播',\n}: AuthVisualCarouselProps) {\n const [currentSlide, setCurrentSlide] = useState(0);\n const [isPaused, setIsPaused] = useState(false);\n const hasItems = items.length > 0;\n const currentItem = hasItems ? items[currentSlide] : undefined;\n\n const goToSlide = (index: number) => {\n if (!hasItems) return;\n setCurrentSlide((index + items.length) % items.length);\n };\n\n const nextSlide = () => goToSlide(currentSlide + 1);\n const previousSlide = () => goToSlide(currentSlide - 1);\n\n useEffect(() => {\n if (!hasItems || isPaused || intervalMs <= 0 || items.length < 2) return;\n const timer = setTimeout(() => {\n setCurrentSlide((slide) => (slide + 1) % items.length);\n }, intervalMs);\n return () => clearTimeout(timer);\n }, [hasItems, intervalMs, isPaused, items.length, currentSlide]);\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'ArrowLeft') {\n event.preventDefault();\n previousSlide();\n }\n if (event.key === 'ArrowRight') {\n event.preventDefault();\n nextSlide();\n }\n };\n\n if (!hasItems) {\n return (\n <div\n className={cn(\n 'relative h-full min-h-[360px] w-full overflow-hidden bg-slate-950',\n className\n )}\n aria-label={ariaLabel}\n role=\"region\"\n />\n );\n }\n\n return (\n <div\n className={cn(\n 'relative h-full min-h-[360px] w-full overflow-hidden bg-slate-950 outline-none',\n className\n )}\n tabIndex={0}\n aria-label={ariaLabel}\n role=\"region\"\n onKeyDown={handleKeyDown}\n onMouseEnter={() => setIsPaused(true)}\n onMouseLeave={() => setIsPaused(false)}\n onFocus={() => setIsPaused(true)}\n onBlur={() => setIsPaused(false)}\n >\n {items.map((item, index) => (\n <img\n key={`${item.image}-${index}`}\n src={item.image}\n alt={item.alt}\n className={cn(\n 'absolute inset-0 h-full w-full object-cover transition-opacity duration-700 ease-out',\n index === currentSlide ? 'opacity-100' : 'opacity-0',\n imageClassName\n )}\n aria-hidden={index !== currentSlide}\n />\n ))}\n\n <div className=\"absolute inset-0 bg-gradient-to-r from-slate-950/80 via-slate-950/30 to-slate-950/10\" />\n <div className=\"absolute inset-x-0 bottom-0 bg-gradient-to-t from-slate-950/78 via-slate-950/30 to-transparent pb-16 pt-24\" />\n\n {(showText || showIndicators) && (\n <div\n className={cn(\n 'absolute inset-x-5 bottom-6 text-white sm:inset-x-8 sm:bottom-8 lg:inset-x-12 lg:bottom-10',\n contentClassName\n )}\n >\n {showText && currentItem && (\n <div className=\"max-w-[min(28rem,calc(100vw-2.5rem))]\">\n {currentItem.eyebrow && (\n <p className=\"mb-2 text-[0.68rem] font-medium uppercase tracking-normal text-cyan-100/80 sm:text-xs\">\n {currentItem.eyebrow}\n </p>\n )}\n {currentItem.title && (\n <h2 className=\"text-xl font-semibold leading-tight sm:text-2xl lg:text-3xl\">\n {currentItem.title}\n </h2>\n )}\n {currentItem.description && (\n <p className=\"mt-2 line-clamp-3 text-sm leading-6 text-slate-100/80 sm:text-base\">\n {currentItem.description}\n </p>\n )}\n </div>\n )}\n\n {showIndicators && items.length > 1 && (\n <div className=\"mt-5 flex items-center gap-2\">\n {items.map((item, index) => (\n <button\n key={`${item.image}-indicator-${index}`}\n type=\"button\"\n className={cn(\n 'h-1.5 rounded-full transition-all',\n index === currentSlide\n ? 'w-8 bg-white'\n : 'w-3 bg-white/40 hover:bg-white/70'\n )}\n aria-label={`切换到第 ${index + 1} 张轮播图`}\n aria-current={index === currentSlide}\n onClick={() => goToSlide(index)}\n />\n ))}\n </div>\n )}\n </div>\n )}\n </div>\n );\n}\n","import { useState } from 'react';\nimport type { ReactNode } from 'react';\n\nimport type { AuthLoginPanelProps, AuthUIComponents } from './AuthLoginPanel';\nimport { AuthLoginPanel } from './AuthLoginPanel';\nimport type { AuthRegisterPanelProps } from './AuthRegisterPanel';\nimport { AuthRegisterPanel } from './AuthRegisterPanel';\n\nexport type AuthPanelMode = 'login' | 'register';\n\nexport interface AuthPanelProps {\n components?: AuthUIComponents;\n mode?: AuthPanelMode;\n defaultMode?: AuthPanelMode;\n onModeChange?: (mode: AuthPanelMode) => void;\n loginProps?: Omit<AuthLoginPanelProps, 'components' | 'footer'> & {\n footer?: ReactNode;\n };\n registerProps?: Omit<AuthRegisterPanelProps, 'components' | 'footer'> & {\n footer?: ReactNode;\n };\n loginLabel?: ReactNode;\n registerLabel?: ReactNode;\n}\n\nexport function AuthPanel({\n components,\n mode,\n defaultMode = 'login',\n onModeChange,\n loginProps,\n registerProps,\n loginLabel = '已有账号?登录',\n registerLabel = '没有账号?注册',\n}: AuthPanelProps) {\n const [internalMode, setInternalMode] = useState<AuthPanelMode>(defaultMode);\n const currentMode = mode ?? internalMode;\n\n const setMode = (nextMode: AuthPanelMode) => {\n if (!mode) {\n setInternalMode(nextMode);\n }\n onModeChange?.(nextMode);\n };\n\n if (currentMode === 'register') {\n return (\n <AuthRegisterPanel\n {...registerProps}\n components={components}\n footer={\n registerProps?.footer ?? (\n <button\n type=\"button\"\n className=\"text-primary underline-offset-4 hover:underline\"\n onClick={() => setMode('login')}\n >\n {loginLabel}\n </button>\n )\n }\n />\n );\n }\n\n return (\n <AuthLoginPanel\n {...loginProps}\n components={components}\n footer={\n loginProps?.footer ?? (\n <button\n type=\"button\"\n className=\"text-primary underline-offset-4 hover:underline\"\n onClick={() => setMode('register')}\n >\n {registerLabel}\n </button>\n )\n }\n />\n );\n}\n"],"names":["defaultValidatePhone","phone","getErrorMessage","error","fallback","normalizePhone","value","formatPhone","AuthLoginPanel","components","title","description","brandIcon","defaultMethod","enabledMethods","extraActions","footer","socialProviders","className","smsCountdownSeconds","validatePhone","validatePassword","onPasswordLogin","onSendSmsCode","onSmsLogin","activeMethod","setActiveMethod","useState","setPhone","smsId","setSmsId","smsType","setSmsType","localError","setLocalError","passwordPending","setPasswordPending","smsPending","setSmsPending","codePending","setCodePending","countdown","setCountdown","methods","useMemo","method","index","array","shouldShowTabs","displayedError","useEffect","timer","jsx","Button","Input","Label","Tabs","TabsList","TabsTrigger","TabsContent","handlePasswordSubmit","event","formData","payload","validationError","err","handleSendCode","result","handleSmsSubmit","code","renderHeader","jsxs","Layers3","renderSocialProviders","provider","renderPasswordForm","UserRound","LockKeyhole","Fragment","Loader2","ArrowRight","renderSmsForm","MessageCircle","renderForms","cn","AuthRegisterPanel","requirePhoneVerification","requireTermsAccepted","termsLabel","validateRegister","onRegister","termsAccepted","setTermsAccepted","registerPending","setRegisterPending","handleRegister","AuthPageShell","children","visual","overlay","contentClassName","panelClassName","AuthVisualCarousel","items","intervalMs","showIndicators","showText","imageClassName","ariaLabel","currentSlide","setCurrentSlide","isPaused","setIsPaused","hasItems","currentItem","goToSlide","nextSlide","previousSlide","slide","handleKeyDown","item","AuthPanel","mode","defaultMode","onModeChange","loginProps","registerProps","loginLabel","registerLabel","internalMode","setInternalMode","currentMode","setMode","nextMode"],"mappings":";;;;AAkFA,MAAMA,KAAuB,CAACC,MAC5B,gBAAgB,KAAKA,CAAK,IAAI,SAAY,aAEtCC,KAAkB,CAACC,GAAgBC,MACnCD,aAAiB,SAASA,EAAM,UAAgBA,EAAM,UACtD,OAAOA,KAAU,YAAYA,IAAcA,IACxCC,GAGHC,KAAiB,CAACC,MAAkBA,EAAM,QAAQ,OAAO,EAAE,EAAE,MAAM,GAAG,EAAE,GAExEC,KAAc,CAACN,MACfA,EAAM,UAAU,IAAUA,IAC1BA,EAAM,UAAU,IAAU,GAAGA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,CAAC,CAAC,KAC7D,GAAGA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,CAAC,CAAC;AAG7D,SAASO,GAAe;AAAA,EAC7B,YAAAC;AAAA,EACA,OAAAC,IAAQ;AAAA,EACR,aAAAC,IAAc;AAAA,EACd,WAAAC;AAAA,EACA,eAAAC,IAAgB;AAAA,EAChB,gBAAAC,IAAiB,CAAC,YAAY,KAAK;AAAA,EACnC,OAAAX;AAAA,EACA,cAAAY;AAAA,EACA,QAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,WAAAC;AAAA,EACA,qBAAAC,IAAsB;AAAA,EACtB,eAAAC,IAAgBpB;AAAAA,EAChB,kBAAAqB;AAAA,EACA,iBAAAC;AAAA,EACA,eAAAC;AAAA,EACA,YAAAC;AACF,GAAwB;AACtB,QAAM,CAACC,GAAcC,CAAe,IAAIC;AAAA,IACtCb,EAAe,SAASD,CAAa,IAAIA,IAAgBC,EAAe,CAAC;AAAA,EAAA,GAErE,CAACb,GAAO2B,CAAQ,IAAID,EAAS,EAAE,GAC/B,CAACE,GAAOC,CAAQ,IAAIH,EAAA,GACpB,CAACI,GAASC,CAAU,IAAIL,EAAA,GACxB,CAACM,GAAYC,CAAa,IAAIP,EAAA,GAC9B,CAACQ,GAAiBC,CAAkB,IAAIT,EAAS,EAAK,GACtD,CAACU,GAAYC,CAAa,IAAIX,EAAS,EAAK,GAC5C,CAACY,GAAaC,CAAc,IAAIb,EAAS,EAAK,GAC9C,CAACc,GAAWC,CAAY,IAAIf,EAAS,CAAC,GAEtCgB,IAAUC;AAAA,IACd,MACE9B,EAAe;AAAA,MACb,CAAC+B,GAAQC,GAAOC,MAAUA,EAAM,QAAQF,CAAM,MAAMC;AAAA,IAAA;AAAA,IAExD,CAAChC,CAAc;AAAA,EAAA,GAEXkC,IAAiBL,EAAQ,SAAS,GAClCM,IAAiBhB,KAAc9B;AAQrC,MANA+C,GAAU,MAAM;AACd,QAAIT,KAAa,EAAG;AACpB,UAAMU,IAAQ,WAAW,MAAMT,EAAa,CAACpC,MAAUA,IAAQ,CAAC,GAAG,GAAI;AACvE,WAAO,MAAM,aAAa6C,CAAK;AAAA,EACjC,GAAG,CAACV,CAAS,CAAC,GAEV,CAAChC;AACH,WACE2C,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,oCAAmC,UAAA,mCAElD;AAIJ,QAAM,EAAE,QAAAC,GAAQ,OAAAC,GAAO,OAAAC,GAAO,MAAAC,GAAM,UAAAC,GAAU,aAAAC,GAAa,aAAAC,MACzDlD,GAEImD,IAAuB,OAAOC,MAAsC;AACxE,IAAAA,EAAM,eAAA;AACN,UAAMC,IAAW,IAAI,SAASD,EAAM,aAAa,GAC3CE,IAAU;AAAA,MACd,UAAU,OAAOD,EAAS,IAAI,UAAU,KAAK,EAAE,EAAE,KAAA;AAAA,MACjD,UAAU,OAAOA,EAAS,IAAI,UAAU,KAAK,EAAE;AAAA,IAAA,GAG3CE,IACJ,CAACD,EAAQ,YAAY,CAACA,EAAQ,WAC1B,aACA1C,KAAA,gBAAAA,EAAmB0C;AACzB,QAAIC,GAAiB;AACnB,MAAA9B,EAAc8B,CAAe;AAC7B;AAAA,IACF;AAEA,QAAI;AACF,MAAA5B,EAAmB,EAAI,GACvBF,EAAc,MAAS,GACvB,OAAMZ,KAAA,gBAAAA,EAAkByC;AAAA,IAC1B,SAASE,IAAK;AACZ,MAAA/B,EAAchC,GAAgB+D,IAAK,YAAY,CAAC;AAAA,IAClD,UAAA;AACE,MAAA7B,EAAmB,EAAK;AAAA,IAC1B;AAAA,EACF,GAEM8B,KAAiB,YAAY;AACjC,UAAMF,IAAkB5C,EAAcnB,CAAK;AAC3C,QAAI+D,GAAiB;AACnB,MAAA9B,EAAc8B,CAAe;AAC7B;AAAA,IACF;AAEA,QAAI;AACF,MAAAxB,EAAe,EAAI,GACnBN,EAAc,MAAS;AACvB,YAAMiC,IAAS,OAAM5C,KAAA,gBAAAA,EAAgBtB;AACrC,MAAA6B,EAASqC,KAAA,gBAAAA,EAAQ,KAAK,GACtBnC,EAAWmC,KAAA,gBAAAA,EAAQ,OAAO,GAC1BzB,EAAavB,CAAmB;AAAA,IAClC,SAAS8C,GAAK;AACZ,MAAA/B,EAAchC,GAAgB+D,GAAK,eAAe,CAAC;AAAA,IACrD,UAAA;AACE,MAAAzB,EAAe,EAAK;AAAA,IACtB;AAAA,EACF,GAEM4B,KAAkB,OAAOP,MAAsC;AACnE,IAAAA,EAAM,eAAA;AACN,UAAMC,IAAW,IAAI,SAASD,EAAM,aAAa,GAC3CQ,IAAO,OAAOP,EAAS,IAAI,MAAM,KAAK,EAAE,EAAE,KAAA,GAC1CE,IAAkB5C,EAAcnB,CAAK;AAE3C,QAAI+D,GAAiB;AACnB,MAAA9B,EAAc8B,CAAe;AAC7B;AAAA,IACF;AACA,QAAI,CAACK,GAAM;AACT,MAAAnC,EAAc,QAAQ;AACtB;AAAA,IACF;AAEA,QAAI;AACF,MAAAI,EAAc,EAAI,GAClBJ,EAAc,MAAS,GACvB,OAAMV,KAAA,gBAAAA,EAAa,EAAE,OAAAvB,GAAO,MAAAoE,GAAM,OAAAxC,GAAO,SAAAE;IAC3C,SAASkC,IAAK;AACZ,MAAA/B,EAAchC,GAAgB+D,IAAK,WAAW,CAAC;AAAA,IACjD,UAAA;AACE,MAAA3B,EAAc,EAAK;AAAA,IACrB;AAAA,EACF,GAEMgC,KAAe,MACnBC,gBAAAA,OAAC,OAAA,EAAI,WAAU,QACb,UAAA;AAAA,IAAAnB,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,2GACZ,UAAAxC,2BAAc4D,IAAA,EAAQ,WAAU,WAAU,EAAA,CAC7C;AAAA,IACApB,gBAAAA,EAAAA,IAAC,MAAA,EAAG,WAAU,0BAA0B,UAAA1C,GAAM;AAAA,IAC7CC,KACCyC,gBAAAA,EAAAA,IAAC,KAAA,EAAE,WAAU,gDACV,UAAAzC,EAAA,CACH;AAAA,EAAA,GAEJ,GAGI8D,KAAwB,MAC5BxD,KAAA,QAAAA,EAAiB,SACfmC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,mBACZ,UAAAnC,EAAgB,IAAI,CAACyD,MACpBH,gBAAAA,EAAAA;AAAAA,IAAClB;AAAA,IAAA;AAAA,MAEC,MAAK;AAAA,MACL,SAAQ;AAAA,MACR,WAAU;AAAA,MACV,UAAUqB,EAAS;AAAA,MACnB,SAASA,EAAS;AAAA,MAEjB,UAAA;AAAA,QAAAA,EAAS,QACRtB,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,wDACb,YAAS,MACZ;AAAA,QAEDsB,EAAS;AAAA,MAAA;AAAA,IAAA;AAAA,IAZLA,EAAS;AAAA,EAAA,CAcjB,GACH,IACE,MAEAC,KAAqB,MACzBvB,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,iBAAgB,UAAUQ,GACxC,UAAAW,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,uBACb,UAAA;AAAA,IAAAA,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,MAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,iBAAgB,UAAA,OAAG;AAAA,MAClCgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,YACb,UAAA;AAAA,QAAAnB,gBAAAA,EAAAA,IAACwB,IAAA,EAAU,WAAU,6FAAA,CAA6F;AAAA,QAClHxB,gBAAAA,EAAAA;AAAAA,UAACE;AAAA,UAAA;AAAA,YACC,IAAG;AAAA,YACH,MAAK;AAAA,YACL,WAAU;AAAA,YACV,aAAY;AAAA,YACZ,cAAa;AAAA,YACb,UAAQ;AAAA,UAAA;AAAA,QAAA;AAAA,MACV,EAAA,CACF;AAAA,IAAA,GACF;AAAA,IACAiB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,MAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,iBAAgB,UAAA,MAAE;AAAA,MACjCgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,YACb,UAAA;AAAA,QAAAnB,gBAAAA,EAAAA,IAACyB,IAAA,EAAY,WAAU,6FAAA,CAA6F;AAAA,QACpHzB,gBAAAA,EAAAA;AAAAA,UAACE;AAAA,UAAA;AAAA,YACC,IAAG;AAAA,YACH,MAAK;AAAA,YACL,WAAU;AAAA,YACV,MAAK;AAAA,YACL,aAAY;AAAA,YACZ,cAAa;AAAA,YACb,UAAQ;AAAA,UAAA;AAAA,QAAA;AAAA,MACV,EAAA,CACF;AAAA,IAAA,GACF;AAAA,IACAF,gBAAAA,EAAAA;AAAAA,MAACC;AAAA,MAAA;AAAA,QACC,MAAK;AAAA,QACL,WAAU;AAAA,QACV,UAAUlB;AAAA,QAET,cACCoC,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EACE,UAAA;AAAA,UAAA1B,gBAAAA,EAAAA,IAAC2B,GAAA,EAAQ,WAAU,4BAAA,CAA4B;AAAA,UAAE;AAAA,QAAA,EAAA,CAEnD,IAEAR,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EAAE,UAAA;AAAA,UAAA;AAAA,UAEA1B,gBAAAA,EAAAA,IAAC4B,IAAA,EAAW,WAAU,eAAA,CAAe;AAAA,QAAA,EAAA,CACvC;AAAA,MAAA;AAAA,IAAA;AAAA,EAEJ,EAAA,CACF,EAAA,CACF,GAGIC,KAAgB,MACpB7B,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,iBAAgB,UAAUgB,IACxC,UAAAG,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,uBACb,UAAA;AAAA,IAAAA,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,MAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,cAAa,UAAA,OAAG;AAAA,MAC/BgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,cACb,UAAA;AAAA,QAAAA,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,mBACb,UAAA;AAAA,UAAAnB,gBAAAA,EAAAA,IAAC8B,IAAA,EAAc,WAAU,kGAAA,CAAkG;AAAA,UAC3H9B,gBAAAA,EAAAA;AAAAA,YAACE;AAAA,YAAA;AAAA,cACC,IAAG;AAAA,cACH,MAAK;AAAA,cACL,WAAU;AAAA,cACV,aAAY;AAAA,cACZ,OAAO/C,GAAYN,CAAK;AAAA,cACxB,UAAU,CAAC4D,MAAUjC,EAASvB,GAAewD,EAAM,OAAO,KAAK,CAAC;AAAA,cAChE,UAAQ;AAAA,cACR,WAAW;AAAA,cACX,WAAU;AAAA,YAAA;AAAA,UAAA;AAAA,QACZ,GACF;AAAA,QACAT,gBAAAA,EAAAA;AAAAA,UAACC;AAAA,UAAA;AAAA,YACC,MAAK;AAAA,YACL,SAAQ;AAAA,YACR,WAAU;AAAA,YACV,SAASa;AAAA,YACT,UAAU,CAACjE,KAASsC,KAAeE,IAAY;AAAA,YAE9C,UAAAF,IACCa,gBAAAA,EAAAA,IAAC2B,GAAA,EAAQ,WAAU,wBAAuB,IACxCtC,IAAY,IACd,GAAGA,CAAS,MAEZ;AAAA,UAAA;AAAA,QAAA;AAAA,MAEJ,EAAA,CACF;AAAA,IAAA,GACF;AAAA,IACA8B,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,MAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,aAAY,UAAA,OAAG;AAAA,MAC9BH,gBAAAA,EAAAA;AAAAA,QAACE;AAAA,QAAA;AAAA,UACC,IAAG;AAAA,UACH,MAAK;AAAA,UACL,WAAU;AAAA,UACV,aAAY;AAAA,UACZ,WAAU;AAAA,UACV,cAAa;AAAA,UACb,UAAQ;AAAA,QAAA;AAAA,MAAA;AAAA,IACV,GACF;AAAA,IACAF,gBAAAA,EAAAA,IAACC,KAAO,MAAK,UAAS,WAAU,oBAAmB,UAAUhB,GAC1D,UAAAA,IACCkC,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EACE,UAAA;AAAA,MAAA1B,gBAAAA,EAAAA,IAAC2B,GAAA,EAAQ,WAAU,4BAAA,CAA4B;AAAA,MAAE;AAAA,IAAA,EAAA,CAEnD,IAEAR,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EAAE,UAAA;AAAA,MAAA;AAAA,MAEA1B,gBAAAA,EAAAA,IAAC4B,IAAA,EAAW,WAAU,eAAA,CAAe;AAAA,IAAA,EAAA,CACvC,EAAA,CAEJ;AAAA,EAAA,EAAA,CACF,EAAA,CACF,GAGIG,KAAc,MACbnC,IAKHuB,gBAAAA,EAAAA;AAAAA,IAACf;AAAA,IAAA;AAAA,MACC,OAAO/B;AAAA,MACP,eAAe,CAACnB,MAAUoB,EAAgBpB,CAAwB;AAAA,MAClE,WAAU;AAAA,MAEV,UAAA;AAAA,QAAAiE,gBAAAA,EAAAA,KAACd,GAAA,EAAS,WAAU,oEACjB,UAAA;AAAA,UAAAd,EAAQ,SAAS,UAAU,2BACzBe,GAAA,EAAY,OAAM,YAAW,UAAA,UAAM;AAAA,UAErCf,EAAQ,SAAS,KAAK,2BACpBe,GAAA,EAAY,OAAM,OAAM,UAAA,QAAA,CAAK;AAAA,QAAA,GAElC;AAAA,QACAN,gBAAAA,EAAAA,IAACO,GAAA,EAAY,OAAM,YAAY,gBAAqB;AAAA,QACpDP,gBAAAA,EAAAA,IAACO,GAAA,EAAY,OAAM,OAAO,eAAc,CAAE;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA,IAlBrChB,EAAQ,CAAC,MAAM,QAAQsC,GAAA,IAAkBN,GAAA;AAuBpD,SACEJ,gBAAAA,EAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWa;AAAA,QACT;AAAA,QACAlE;AAAA,MAAA;AAAA,MAGD,UAAA;AAAA,QAAAoD,GAAA;AAAA,QACAG,GAAA;AAAA,QACAU,GAAA;AAAA,QACApE,KAAgBqC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,QAAQ,UAAArC,GAAa;AAAA,QACpDkC,KACCG,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,kGACZ,UAAAH,GACH;AAAA,QAEDjC,KAAUoC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,sCAAsC,UAAApC,EAAA,CAAO;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAG7E;AC1XA,MAAMhB,KAAuB,CAACC,MAC5B,gBAAgB,KAAKA,CAAK,IAAI,SAAY,aAEtCC,KAAkB,CAACC,GAAgBC,MACnCD,aAAiB,SAASA,EAAM,UAAgBA,EAAM,UACtD,OAAOA,KAAU,YAAYA,IAAcA,IACxCC,GAGHC,KAAiB,CAACC,MAAkBA,EAAM,QAAQ,OAAO,EAAE,EAAE,MAAM,GAAG,EAAE,GAExEC,KAAc,CAACN,MACfA,EAAM,UAAU,IAAUA,IAC1BA,EAAM,UAAU,IAAU,GAAGA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,CAAC,CAAC,KAC7D,GAAGA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,GAAG,CAAC,CAAC,IAAIA,EAAM,MAAM,CAAC,CAAC;AAG7D,SAASoF,GAAkB;AAAA,EAChC,YAAA5E;AAAA,EACA,OAAAC,IAAQ;AAAA,EACR,aAAAC,IAAc;AAAA,EACd,WAAAC;AAAA,EACA,0BAAA0E,IAA2B;AAAA,EAC3B,sBAAAC,IAAuB;AAAA,EACvB,YAAAC,IAAa;AAAA,EACb,OAAArF;AAAA,EACA,cAAAY;AAAA,EACA,QAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,WAAAC;AAAA,EACA,qBAAAC,IAAsB;AAAA,EACtB,eAAAC,IAAgBpB;AAAA,EAChB,kBAAAqB;AAAA,EACA,kBAAAoE;AAAA,EACA,eAAAlE;AAAA,EACA,YAAAmE;AACF,GAA2B;AACzB,QAAM,CAACzF,GAAO2B,CAAQ,IAAID,EAAS,EAAE,GAC/B,CAACE,GAAOC,CAAQ,IAAIH,EAAA,GACpB,CAACI,GAASC,CAAU,IAAIL,EAAA,GACxB,CAACgE,GAAeC,CAAgB,IAAIjE,EAAS,EAAK,GAClD,CAACM,GAAYC,CAAa,IAAIP,EAAA,GAC9B,CAACkE,GAAiBC,CAAkB,IAAInE,EAAS,EAAK,GACtD,CAACY,GAAaC,CAAc,IAAIb,EAAS,EAAK,GAC9C,CAACc,GAAWC,CAAY,IAAIf,EAAS,CAAC,GACtCsB,IAAiBhB,KAAc9B;AAQrC,MANA+C,GAAU,MAAM;AACd,QAAIT,KAAa,EAAG;AACpB,UAAMU,IAAQ,WAAW,MAAMT,EAAa,CAACpC,MAAUA,IAAQ,CAAC,GAAG,GAAI;AACvE,WAAO,MAAM,aAAa6C,CAAK;AAAA,EACjC,GAAG,CAACV,CAAS,CAAC,GAEV,CAAChC;AACH,WACE2C,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,oCAAmC,UAAA,mCAElD;AAIJ,QAAM,EAAE,QAAAC,GAAQ,OAAAC,GAAO,OAAAC,EAAA,IAAU9C,GAE3ByD,IAAiB,YAAY;AACjC,UAAMF,IAAkB5C,EAAcnB,CAAK;AAC3C,QAAI+D,GAAiB;AACnB,MAAA9B,EAAc8B,CAAe;AAC7B;AAAA,IACF;AAEA,QAAI;AACF,MAAAxB,EAAe,EAAI,GACnBN,EAAc,MAAS;AACvB,YAAMiC,IAAS,OAAM5C,KAAA,gBAAAA,EAAgBtB;AACrC,MAAA6B,EAASqC,KAAA,gBAAAA,EAAQ,KAAK,GACtBnC,EAAWmC,KAAA,gBAAAA,EAAQ,OAAO,GAC1BzB,EAAavB,CAAmB;AAAA,IAClC,SAAS8C,GAAK;AACZ,MAAA/B,EAAchC,GAAgB+D,GAAK,eAAe,CAAC;AAAA,IACrD,UAAA;AACE,MAAAzB,EAAe,EAAK;AAAA,IACtB;AAAA,EACF,GAEMuD,IAAiB,OAAOlC,MAAsC;AAClE,IAAAA,EAAM,eAAA;AACN,UAAMC,IAAW,IAAI,SAASD,EAAM,aAAa,GAC3CE,IAA+B;AAAA,MACnC,UAAU,OAAOD,EAAS,IAAI,UAAU,KAAK,EAAE,EAAE,KAAA;AAAA,MACjD,UAAU,OAAOA,EAAS,IAAI,UAAU,KAAK,EAAE;AAAA,MAC/C,iBAAiB,OAAOA,EAAS,IAAI,iBAAiB,KAAK,EAAE;AAAA,MAC7D,OAAA7D;AAAA,MACA,MAAM,OAAO6D,EAAS,IAAI,MAAM,KAAK,EAAE,EAAE,KAAA;AAAA,MACzC,OAAAjC;AAAA,MACA,SAAAE;AAAA,MACA,eAAA4D;AAAA,IAAA,GAGI3B,IACH,CAACD,EAAQ,YAAY,YACrB,CAACA,EAAQ,YAAY,WACrBA,EAAQ,aAAaA,EAAQ,mBAAmB,gBAChDuB,KAA4BlE,EAAcnB,CAAK,KAC/CqF,KAA4B,CAACvB,EAAQ,QAAQ,YAC7CwB,KAAwB,CAACI,KAAiB,eAC3CtE,KAAA,gBAAAA,EAAmB0C,QACnB0B,KAAA,gBAAAA,EAAmB1B;AAErB,QAAIC,GAAiB;AACnB,MAAA9B,EAAc8B,CAAe;AAC7B;AAAA,IACF;AAEA,QAAI;AACF,MAAA8B,EAAmB,EAAI,GACvB5D,EAAc,MAAS,GACvB,OAAMwD,KAAA,gBAAAA,EAAa3B;AAAA,IACrB,SAASE,GAAK;AACZ,MAAA/B,EAAchC,GAAgB+D,GAAK,YAAY,CAAC;AAAA,IAClD,UAAA;AACE,MAAA6B,EAAmB,EAAK;AAAA,IAC1B;AAAA,EACF,GAEMrB,IAAwB,MAC5BxD,KAAA,QAAAA,EAAiB,SACfmC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,mBACZ,UAAAnC,EAAgB,IAAI,CAACyD,MACpBH,gBAAAA,EAAAA;AAAAA,IAAClB;AAAA,IAAA;AAAA,MAEC,MAAK;AAAA,MACL,SAAQ;AAAA,MACR,WAAU;AAAA,MACV,UAAUqB,EAAS;AAAA,MACnB,SAASA,EAAS;AAAA,MAEjB,UAAA;AAAA,QAAAA,EAAS,QACRtB,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,wDACb,YAAS,MACZ;AAAA,QAEDsB,EAAS;AAAA,MAAA;AAAA,IAAA;AAAA,IAZLA,EAAS;AAAA,EAAA,CAcjB,GACH,IACE;AAEN,SACEH,gBAAAA,EAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWa;AAAA,QACT;AAAA,QACAlE;AAAA,MAAA;AAAA,MAGF,UAAA;AAAA,QAAAqD,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,QACb,UAAA;AAAA,UAAAnB,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,2GACZ,UAAAxC,2BAAc4D,IAAA,EAAQ,WAAU,WAAU,EAAA,CAC7C;AAAA,UACApB,gBAAAA,EAAAA,IAAC,MAAA,EAAG,WAAU,0BAA0B,UAAA1C,GAAM;AAAA,UAC7CC,KACCyC,gBAAAA,EAAAA,IAAC,KAAA,EAAE,WAAU,gDACV,UAAAzC,EAAA,CACH;AAAA,QAAA,GAEJ;AAAA,QAEC8D,EAAA;AAAA,QAEDrB,gBAAAA,EAAAA,IAAC,UAAK,WAAU,iBAAgB,UAAU2C,GACxC,UAAAxB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,uBACb,UAAA;AAAA,UAAAA,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,YAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,0BAAyB,UAAA,OAAG;AAAA,YAC3CgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,YACb,UAAA;AAAA,cAAAnB,gBAAAA,EAAAA,IAACwB,IAAA,EAAU,WAAU,6FAAA,CAA6F;AAAA,cAClHxB,gBAAAA,EAAAA;AAAAA,gBAACE;AAAA,gBAAA;AAAA,kBACC,IAAG;AAAA,kBACH,MAAK;AAAA,kBACL,WAAU;AAAA,kBACV,aAAY;AAAA,kBACZ,cAAa;AAAA,kBACb,UAAQ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACV,EAAA,CACF;AAAA,UAAA,GACF;AAAA,UAEAiB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,YAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,0BAAyB,UAAA,MAAE;AAAA,YAC1CgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,YACb,UAAA;AAAA,cAAAnB,gBAAAA,EAAAA,IAACyB,IAAA,EAAY,WAAU,6FAAA,CAA6F;AAAA,cACpHzB,gBAAAA,EAAAA;AAAAA,gBAACE;AAAA,gBAAA;AAAA,kBACC,IAAG;AAAA,kBACH,MAAK;AAAA,kBACL,WAAU;AAAA,kBACV,MAAK;AAAA,kBACL,aAAY;AAAA,kBACZ,cAAa;AAAA,kBACb,UAAQ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACV,EAAA,CACF;AAAA,UAAA,GACF;AAAA,UAEAiB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,YAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,kCAAiC,UAAA,QAAI;AAAA,YACpDgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,YACb,UAAA;AAAA,cAAAnB,gBAAAA,EAAAA,IAACyB,IAAA,EAAY,WAAU,6FAAA,CAA6F;AAAA,cACpHzB,gBAAAA,EAAAA;AAAAA,gBAACE;AAAA,gBAAA;AAAA,kBACC,IAAG;AAAA,kBACH,MAAK;AAAA,kBACL,WAAU;AAAA,kBACV,MAAK;AAAA,kBACL,aAAY;AAAA,kBACZ,cAAa;AAAA,kBACb,UAAQ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACV,EAAA,CACF;AAAA,UAAA,GACF;AAAA,UAECgC,KACCf,gBAAAA,EAAAA,KAAAO,YAAA,EACE,UAAA;AAAA,YAAAP,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,cAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,uBAAsB,UAAA,OAAG;AAAA,cACxCgB,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,cACb,UAAA;AAAA,gBAAAA,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,mBACb,UAAA;AAAA,kBAAAnB,gBAAAA,EAAAA,IAAC8B,IAAA,EAAc,WAAU,kGAAA,CAAkG;AAAA,kBAC3H9B,gBAAAA,EAAAA;AAAAA,oBAACE;AAAA,oBAAA;AAAA,sBACC,IAAG;AAAA,sBACH,MAAK;AAAA,sBACL,WAAU;AAAA,sBACV,aAAY;AAAA,sBACZ,OAAO/C,GAAYN,CAAK;AAAA,sBACxB,UAAU,CAAC4D,MACTjC,EAASvB,GAAewD,EAAM,OAAO,KAAK,CAAC;AAAA,sBAE7C,UAAQ;AAAA,sBACR,WAAW;AAAA,sBACX,WAAU;AAAA,oBAAA;AAAA,kBAAA;AAAA,gBACZ,GACF;AAAA,gBACAT,gBAAAA,EAAAA;AAAAA,kBAACC;AAAA,kBAAA;AAAA,oBACC,MAAK;AAAA,oBACL,SAAQ;AAAA,oBACR,WAAU;AAAA,oBACV,SAASa;AAAA,oBACT,UAAU,CAACjE,KAASsC,KAAeE,IAAY;AAAA,oBAE9C,UAAAF,IACCa,gBAAAA,EAAAA,IAAC2B,GAAA,EAAQ,WAAU,wBAAuB,IACxCtC,IAAY,IACd,GAAGA,CAAS,MAEZ;AAAA,kBAAA;AAAA,gBAAA;AAAA,cAEJ,EAAA,CACF;AAAA,YAAA,GACF;AAAA,YACA8B,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,aACb,UAAA;AAAA,cAAAnB,gBAAAA,EAAAA,IAACG,GAAA,EAAM,SAAQ,sBAAqB,UAAA,OAAG;AAAA,cACvCH,gBAAAA,EAAAA;AAAAA,gBAACE;AAAA,gBAAA;AAAA,kBACC,IAAG;AAAA,kBACH,MAAK;AAAA,kBACL,WAAU;AAAA,kBACV,aAAY;AAAA,kBACZ,WAAU;AAAA,kBACV,cAAa;AAAA,kBACb,UAAQ;AAAA,gBAAA;AAAA,cAAA;AAAA,YACV,EAAA,CACF;AAAA,UAAA,GACF;AAAA,UAGDiC,KACChB,gBAAAA,EAAAA,KAAC,SAAA,EAAM,WAAU,wDACf,UAAA;AAAA,YAAAnB,gBAAAA,EAAAA;AAAAA,cAAC;AAAA,cAAA;AAAA,gBACC,MAAK;AAAA,gBACL,WAAU;AAAA,gBACV,SAASuC;AAAA,gBACT,UAAU,CAAC9B,MAAU+B,EAAiB/B,EAAM,OAAO,OAAO;AAAA,cAAA;AAAA,YAAA;AAAA,YAE5DT,gBAAAA,EAAAA,IAAC,UAAM,UAAAoC,EAAA,CAAW;AAAA,UAAA,GACpB;AAAA,UAGFpC,gBAAAA,EAAAA;AAAAA,YAACC;AAAA,YAAA;AAAA,cACC,MAAK;AAAA,cACL,WAAU;AAAA,cACV,UAAUwC;AAAA,cAET,cACCtB,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EACE,UAAA;AAAA,gBAAA1B,gBAAAA,EAAAA,IAAC2B,GAAA,EAAQ,WAAU,4BAAA,CAA4B;AAAA,gBAAE;AAAA,cAAA,EAAA,CAEnD,IAEAR,gBAAAA,EAAAA,KAAAO,EAAAA,UAAA,EAAE,UAAA;AAAA,gBAAA;AAAA,gBAEA1B,gBAAAA,EAAAA,IAAC4B,IAAA,EAAW,WAAU,eAAA,CAAe;AAAA,cAAA,EAAA,CACvC;AAAA,YAAA;AAAA,UAAA;AAAA,QAEJ,EAAA,CACF,EAAA,CACF;AAAA,QAECjE,KAAgBqC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,QAAQ,UAAArC,GAAa;AAAA,QACpDkC,KACCG,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,kGACZ,UAAAH,GACH;AAAA,QAEDjC,KAAUoC,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,sCAAsC,UAAApC,EAAA,CAAO;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAG7E;AChWO,SAASgF,GAAc;AAAA,EAC5B,UAAAC;AAAA,EACA,QAAAC;AAAA,EACA,SAAAC;AAAA,EACA,WAAAjF;AAAA,EACA,kBAAAkF;AAAA,EACA,gBAAAC;AACF,GAAuB;AACrB,SACEjD,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAWgC,EAAG,gBAAgBlE,CAAS,GAC1C,UAAAqD,gBAAAA,EAAAA,KAAC,QAAA,EAAK,WAAU,qDACb,UAAA;AAAA,IAAA2B,KAAU9C,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,oBAAoB,UAAA8C,GAAO;AAAA,IACpDC,KAAW/C,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,oCAAA,CAAoC;AAAA,IAC/DA,gBAAAA,EAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAWgC;AAAA,UACT;AAAA,UACAgB;AAAA,QAAA;AAAA,QAGF,gCAAC,OAAA,EAAI,WAAWhB,EAAG,gCAAgCiB,CAAc,GAC9D,UAAAJ,EAAA,CACH;AAAA,MAAA;AAAA,IAAA;AAAA,EACF,EAAA,CACF,EAAA,CACF;AAEJ;ACfO,SAASK,GAAmB;AAAA,EACjC,OAAAC;AAAA,EACA,YAAAC,IAAa;AAAA,EACb,gBAAAC,IAAiB;AAAA,EACjB,UAAAC,IAAW;AAAA,EACX,WAAAxF;AAAA,EACA,gBAAAyF;AAAA,EACA,kBAAAP;AAAA,EACA,WAAAQ,IAAY;AACd,GAA4B;AAC1B,QAAM,CAACC,GAAcC,CAAe,IAAInF,EAAS,CAAC,GAC5C,CAACoF,GAAUC,CAAW,IAAIrF,EAAS,EAAK,GACxCsF,IAAWV,EAAM,SAAS,GAC1BW,IAAcD,IAAWV,EAAMM,CAAY,IAAI,QAE/CM,IAAY,CAACrE,MAAkB;AACnC,IAAKmE,KACLH,GAAiBhE,IAAQyD,EAAM,UAAUA,EAAM,MAAM;AAAA,EACvD,GAEMa,IAAY,MAAMD,EAAUN,IAAe,CAAC,GAC5CQ,IAAgB,MAAMF,EAAUN,IAAe,CAAC;AAEtD,EAAA3D,GAAU,MAAM;AACd,QAAI,CAAC+D,KAAYF,KAAYP,KAAc,KAAKD,EAAM,SAAS,EAAG;AAClE,UAAMpD,IAAQ,WAAW,MAAM;AAC7B,MAAA2D,EAAgB,CAACQ,OAAWA,IAAQ,KAAKf,EAAM,MAAM;AAAA,IACvD,GAAGC,CAAU;AACb,WAAO,MAAM,aAAarD,CAAK;AAAA,EACjC,GAAG,CAAC8D,GAAUT,GAAYO,GAAUR,EAAM,QAAQM,CAAY,CAAC;AAE/D,QAAMU,IAAgB,CAAC1D,MAAyC;AAC9D,IAAIA,EAAM,QAAQ,gBAChBA,EAAM,eAAA,GACNwD,EAAA,IAEExD,EAAM,QAAQ,iBAChBA,EAAM,eAAA,GACNuD,EAAA;AAAA,EAEJ;AAEA,SAAKH,IAcH1C,gBAAAA,EAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWa;AAAA,QACT;AAAA,QACAlE;AAAA,MAAA;AAAA,MAEF,UAAU;AAAA,MACV,cAAY0F;AAAA,MACZ,MAAK;AAAA,MACL,WAAWW;AAAA,MACX,cAAc,MAAMP,EAAY,EAAI;AAAA,MACpC,cAAc,MAAMA,EAAY,EAAK;AAAA,MACrC,SAAS,MAAMA,EAAY,EAAI;AAAA,MAC/B,QAAQ,MAAMA,EAAY,EAAK;AAAA,MAE9B,UAAA;AAAA,QAAAT,EAAM,IAAI,CAACiB,GAAM1E,MAChBM,gBAAAA,EAAAA;AAAAA,UAAC;AAAA,UAAA;AAAA,YAEC,KAAKoE,EAAK;AAAA,YACV,KAAKA,EAAK;AAAA,YACV,WAAWpC;AAAA,cACT;AAAA,cACAtC,MAAU+D,IAAe,gBAAgB;AAAA,cACzCF;AAAA,YAAA;AAAA,YAEF,eAAa7D,MAAU+D;AAAA,UAAA;AAAA,UARlB,GAAGW,EAAK,KAAK,IAAI1E,CAAK;AAAA,QAAA,CAU9B;AAAA,QAEDM,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,uFAAA,CAAuF;AAAA,QACtGA,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,6GAAA,CAA6G;AAAA,SAE1HsD,KAAYD,MACZlC,gBAAAA,EAAAA;AAAAA,UAAC;AAAA,UAAA;AAAA,YACC,WAAWa;AAAA,cACT;AAAA,cACAgB;AAAA,YAAA;AAAA,YAGD,UAAA;AAAA,cAAAM,KAAYQ,KACX3C,gBAAAA,OAAC,OAAA,EAAI,WAAU,yCACZ,UAAA;AAAA,gBAAA2C,EAAY,WACX9D,gBAAAA,EAAAA,IAAC,KAAA,EAAE,WAAU,yFACV,YAAY,SACf;AAAA,gBAED8D,EAAY,SACX9D,gBAAAA,EAAAA,IAAC,QAAG,WAAU,+DACX,YAAY,OACf;AAAA,gBAED8D,EAAY,eACX9D,gBAAAA,EAAAA,IAAC,OAAE,WAAU,sEACV,YAAY,YAAA,CACf;AAAA,cAAA,GAEJ;AAAA,cAGDqD,KAAkBF,EAAM,SAAS,KAChCnD,gBAAAA,EAAAA,IAAC,OAAA,EAAI,WAAU,gCACZ,UAAAmD,EAAM,IAAI,CAACiB,GAAM1E,MAChBM,gBAAAA,EAAAA;AAAAA,gBAAC;AAAA,gBAAA;AAAA,kBAEC,MAAK;AAAA,kBACL,WAAWgC;AAAA,oBACT;AAAA,oBACAtC,MAAU+D,IACN,iBACA;AAAA,kBAAA;AAAA,kBAEN,cAAY,QAAQ/D,IAAQ,CAAC;AAAA,kBAC7B,gBAAcA,MAAU+D;AAAA,kBACxB,SAAS,MAAMM,EAAUrE,CAAK;AAAA,gBAAA;AAAA,gBAVzB,GAAG0E,EAAK,KAAK,cAAc1E,CAAK;AAAA,cAAA,CAYxC,EAAA,CACH;AAAA,YAAA;AAAA,UAAA;AAAA,QAAA;AAAA,MAEJ;AAAA,IAAA;AAAA,EAAA,IAzFFM,gBAAAA,EAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWgC;AAAA,QACT;AAAA,QACAlE;AAAA,MAAA;AAAA,MAEF,cAAY0F;AAAA,MACZ,MAAK;AAAA,IAAA;AAAA,EAAA;AAuFb;ACxIO,SAASa,GAAU;AAAA,EACxB,YAAAhH;AAAA,EACA,MAAAiH;AAAA,EACA,aAAAC,IAAc;AAAA,EACd,cAAAC;AAAA,EACA,YAAAC;AAAA,EACA,eAAAC;AAAA,EACA,YAAAC,IAAa;AAAA,EACb,eAAAC,IAAgB;AAClB,GAAmB;AACjB,QAAM,CAACC,GAAcC,CAAe,IAAIvG,EAAwBgG,CAAW,GACrEQ,IAAcT,KAAQO,GAEtBG,IAAU,CAACC,MAA4B;AAC3C,IAAKX,KACHQ,EAAgBG,CAAQ,GAE1BT,KAAA,QAAAA,EAAeS;AAAA,EACjB;AAEA,SAAIF,MAAgB,aAEhB/E,gBAAAA,EAAAA;AAAAA,IAACiC;AAAA,IAAA;AAAA,MACE,GAAGyC;AAAA,MACJ,YAAArH;AAAA,MACA,SACEqH,KAAA,gBAAAA,EAAe,WACb1E,gBAAAA,EAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,WAAU;AAAA,UACV,SAAS,MAAMgF,EAAQ,OAAO;AAAA,UAE7B,UAAAL;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA,IAQR3E,gBAAAA,EAAAA;AAAAA,IAAC5C;AAAA,IAAA;AAAA,MACE,GAAGqH;AAAA,MACJ,YAAApH;AAAA,MACA,SACEoH,KAAA,gBAAAA,EAAY,WACVzE,gBAAAA,EAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC,MAAK;AAAA,UACL,WAAU;AAAA,UACV,SAAS,MAAMgF,EAAQ,UAAU;AAAA,UAEhC,UAAAJ;AAAA,QAAA;AAAA,MAAA;AAAA,IACH;AAAA,EAAA;AAKV;"}
package/dist/auth.cjs ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./AuthPanel-C_2JBE7t.cjs");exports.AuthLoginPanel=e.AuthLoginPanel;exports.AuthPageShell=e.AuthPageShell;exports.AuthPanel=e.AuthPanel;exports.AuthRegisterPanel=e.AuthRegisterPanel;exports.AuthVisualCarousel=e.AuthVisualCarousel;
2
+ //# sourceMappingURL=auth.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
package/dist/auth.d.ts ADDED
@@ -0,0 +1,11 @@
1
+ export { AuthLoginPanel } from './components/AuthLoginPanel';
2
+ export type { AuthLoginMethod, AuthLoginPanelProps, AuthPasswordLoginPayload, AuthSmsCodeResult, AuthSmsLoginPayload, AuthSocialProvider, AuthUIComponents, AuthValidationResult, } from './components/AuthLoginPanel';
3
+ export { AuthRegisterPanel } from './components/AuthRegisterPanel';
4
+ export type { AuthRegisterPanelProps, AuthRegisterPayload, } from './components/AuthRegisterPanel';
5
+ export { AuthPageShell } from './components/AuthPageShell';
6
+ export type { AuthPageShellProps } from './components/AuthPageShell';
7
+ export { AuthVisualCarousel } from './components/AuthVisualCarousel';
8
+ export type { AuthVisualCarouselItem, AuthVisualCarouselProps, } from './components/AuthVisualCarousel';
9
+ export { AuthPanel } from './components/AuthPanel';
10
+ export type { AuthPanelMode, AuthPanelProps } from './components/AuthPanel';
11
+ //# sourceMappingURL=auth.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../src/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAC7D,YAAY,EACV,eAAe,EACf,mBAAmB,EACnB,wBAAwB,EACxB,iBAAiB,EACjB,mBAAmB,EACnB,kBAAkB,EAClB,gBAAgB,EAChB,oBAAoB,GACrB,MAAM,6BAA6B,CAAC;AAErC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,YAAY,EACV,sBAAsB,EACtB,mBAAmB,GACpB,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAC3D,YAAY,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAErE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AACrE,YAAY,EACV,sBAAsB,EACtB,uBAAuB,GACxB,MAAM,iCAAiC,CAAC;AAEzC,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC"}
package/dist/auth.js ADDED
@@ -0,0 +1,9 @@
1
+ import { A as s, a as l, b as t, c as u, d as h } from "./AuthPanel-D2HFX8eN.js";
2
+ export {
3
+ s as AuthLoginPanel,
4
+ l as AuthPageShell,
5
+ t as AuthPanel,
6
+ u as AuthRegisterPanel,
7
+ h as AuthVisualCarousel
8
+ };
9
+ //# sourceMappingURL=auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,55 @@
1
+ import { ReactNode } from 'react';
2
+ import { ButtonComponent, InputComponent, LabelComponent, TabsComponent, TabsContentComponent, TabsListComponent, TabsTriggerComponent } from '../types/component-types';
3
+ export type AuthLoginMethod = 'password' | 'sms';
4
+ export type AuthValidationResult = string | undefined | null;
5
+ export interface AuthUIComponents {
6
+ Button: ButtonComponent;
7
+ Input: InputComponent;
8
+ Label: LabelComponent;
9
+ Tabs: TabsComponent;
10
+ TabsList: TabsListComponent;
11
+ TabsTrigger: TabsTriggerComponent;
12
+ TabsContent: TabsContentComponent;
13
+ }
14
+ export interface AuthSocialProvider {
15
+ id: string;
16
+ label: ReactNode;
17
+ icon?: ReactNode;
18
+ disabled?: boolean;
19
+ onClick?: () => Promise<void> | void;
20
+ }
21
+ export interface AuthSmsCodeResult {
22
+ smsId?: string;
23
+ smsType?: string;
24
+ }
25
+ export interface AuthPasswordLoginPayload {
26
+ username: string;
27
+ password: string;
28
+ }
29
+ export interface AuthSmsLoginPayload {
30
+ phone: string;
31
+ code: string;
32
+ smsId?: string;
33
+ smsType?: string;
34
+ }
35
+ export interface AuthLoginPanelProps {
36
+ components?: AuthUIComponents;
37
+ title?: ReactNode;
38
+ description?: ReactNode;
39
+ brandIcon?: ReactNode;
40
+ defaultMethod?: AuthLoginMethod;
41
+ enabledMethods?: AuthLoginMethod[];
42
+ error?: ReactNode;
43
+ extraActions?: ReactNode;
44
+ footer?: ReactNode;
45
+ socialProviders?: AuthSocialProvider[];
46
+ className?: string;
47
+ smsCountdownSeconds?: number;
48
+ validatePhone?: (phone: string) => AuthValidationResult;
49
+ validatePassword?: (payload: AuthPasswordLoginPayload) => AuthValidationResult;
50
+ onPasswordLogin?: (payload: AuthPasswordLoginPayload) => Promise<void> | void;
51
+ onSendSmsCode?: (phone: string) => Promise<AuthSmsCodeResult | void> | AuthSmsCodeResult | void;
52
+ onSmsLogin?: (payload: AuthSmsLoginPayload) => Promise<void> | void;
53
+ }
54
+ export declare function AuthLoginPanel({ components, title, description, brandIcon, defaultMethod, enabledMethods, error, extraActions, footer, socialProviders, className, smsCountdownSeconds, validatePhone, validatePassword, onPasswordLogin, onSendSmsCode, onSmsLogin, }: AuthLoginPanelProps): import("react/jsx-runtime").JSX.Element;
55
+ //# sourceMappingURL=AuthLoginPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthLoginPanel.d.ts","sourceRoot":"","sources":["../../src/components/AuthLoginPanel.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import { ReactNode } from 'react';
2
+ export interface AuthPageShellProps {
3
+ children: ReactNode;
4
+ visual?: ReactNode;
5
+ overlay?: ReactNode;
6
+ className?: string;
7
+ contentClassName?: string;
8
+ panelClassName?: string;
9
+ }
10
+ export declare function AuthPageShell({ children, visual, overlay, className, contentClassName, panelClassName, }: AuthPageShellProps): import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=AuthPageShell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthPageShell.d.ts","sourceRoot":"","sources":["../../src/components/AuthPageShell.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAIvC,MAAM,WAAW,kBAAkB;IACjC,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,MAAM,EACN,OAAO,EACP,SAAS,EACT,gBAAgB,EAChB,cAAc,GACf,EAAE,kBAAkB,2CAmBpB"}
@@ -0,0 +1,20 @@
1
+ import { ReactNode } from 'react';
2
+ import { AuthLoginPanelProps, AuthUIComponents } from './AuthLoginPanel';
3
+ import { AuthRegisterPanelProps } from './AuthRegisterPanel';
4
+ export type AuthPanelMode = 'login' | 'register';
5
+ export interface AuthPanelProps {
6
+ components?: AuthUIComponents;
7
+ mode?: AuthPanelMode;
8
+ defaultMode?: AuthPanelMode;
9
+ onModeChange?: (mode: AuthPanelMode) => void;
10
+ loginProps?: Omit<AuthLoginPanelProps, 'components' | 'footer'> & {
11
+ footer?: ReactNode;
12
+ };
13
+ registerProps?: Omit<AuthRegisterPanelProps, 'components' | 'footer'> & {
14
+ footer?: ReactNode;
15
+ };
16
+ loginLabel?: ReactNode;
17
+ registerLabel?: ReactNode;
18
+ }
19
+ export declare function AuthPanel({ components, mode, defaultMode, onModeChange, loginProps, registerProps, loginLabel, registerLabel, }: AuthPanelProps): import("react/jsx-runtime").JSX.Element;
20
+ //# sourceMappingURL=AuthPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthPanel.d.ts","sourceRoot":"","sources":["../../src/components/AuthPanel.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAE9E,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAGlE,MAAM,MAAM,aAAa,GAAG,OAAO,GAAG,UAAU,CAAC;AAEjD,MAAM,WAAW,cAAc;IAC7B,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,WAAW,CAAC,EAAE,aAAa,CAAC;IAC5B,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,aAAa,KAAK,IAAI,CAAC;IAC7C,UAAU,CAAC,EAAE,IAAI,CAAC,mBAAmB,EAAE,YAAY,GAAG,QAAQ,CAAC,GAAG;QAChE,MAAM,CAAC,EAAE,SAAS,CAAC;KACpB,CAAC;IACF,aAAa,CAAC,EAAE,IAAI,CAAC,sBAAsB,EAAE,YAAY,GAAG,QAAQ,CAAC,GAAG;QACtE,MAAM,CAAC,EAAE,SAAS,CAAC;KACpB,CAAC;IACF,UAAU,CAAC,EAAE,SAAS,CAAC;IACvB,aAAa,CAAC,EAAE,SAAS,CAAC;CAC3B;AAED,wBAAgB,SAAS,CAAC,EACxB,UAAU,EACV,IAAI,EACJ,WAAqB,EACrB,YAAY,EACZ,UAAU,EACV,aAAa,EACb,UAAsB,EACtB,aAAyB,GAC1B,EAAE,cAAc,2CAgDhB"}
@@ -0,0 +1,34 @@
1
+ import { ReactNode } from 'react';
2
+ import { AuthSmsCodeResult, AuthSocialProvider, AuthUIComponents, AuthValidationResult } from './AuthLoginPanel';
3
+ export interface AuthRegisterPayload {
4
+ username: string;
5
+ password: string;
6
+ confirmPassword: string;
7
+ phone: string;
8
+ code: string;
9
+ smsId?: string;
10
+ smsType?: string;
11
+ termsAccepted: boolean;
12
+ }
13
+ export interface AuthRegisterPanelProps {
14
+ components?: AuthUIComponents;
15
+ title?: ReactNode;
16
+ description?: ReactNode;
17
+ brandIcon?: ReactNode;
18
+ requirePhoneVerification?: boolean;
19
+ requireTermsAccepted?: boolean;
20
+ termsLabel?: ReactNode;
21
+ error?: ReactNode;
22
+ extraActions?: ReactNode;
23
+ footer?: ReactNode;
24
+ socialProviders?: AuthSocialProvider[];
25
+ className?: string;
26
+ smsCountdownSeconds?: number;
27
+ validatePhone?: (phone: string) => AuthValidationResult;
28
+ validatePassword?: (payload: AuthRegisterPayload) => AuthValidationResult;
29
+ validateRegister?: (payload: AuthRegisterPayload) => AuthValidationResult;
30
+ onSendSmsCode?: (phone: string) => Promise<AuthSmsCodeResult | void> | AuthSmsCodeResult | void;
31
+ onRegister?: (payload: AuthRegisterPayload) => Promise<void> | void;
32
+ }
33
+ export declare function AuthRegisterPanel({ components, title, description, brandIcon, requirePhoneVerification, requireTermsAccepted, termsLabel, error, extraActions, footer, socialProviders, className, smsCountdownSeconds, validatePhone, validatePassword, validateRegister, onSendSmsCode, onRegister, }: AuthRegisterPanelProps): import("react/jsx-runtime").JSX.Element;
34
+ //# sourceMappingURL=AuthRegisterPanel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthRegisterPanel.d.ts","sourceRoot":"","sources":["../../src/components/AuthRegisterPanel.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAa,SAAS,EAAE,MAAM,OAAO,CAAC;AAIlD,OAAO,KAAK,EACV,iBAAiB,EACjB,kBAAkB,EAClB,gBAAgB,EAChB,oBAAoB,EACrB,MAAM,kBAAkB,CAAC;AAE1B,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,EAAE,MAAM,CAAC;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,sBAAsB;IACrC,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,wBAAwB,CAAC,EAAE,OAAO,CAAC;IACnC,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,UAAU,CAAC,EAAE,SAAS,CAAC;IACvB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,YAAY,CAAC,EAAE,SAAS,CAAC;IACzB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,eAAe,CAAC,EAAE,kBAAkB,EAAE,CAAC;IACvC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,oBAAoB,CAAC;IACxD,gBAAgB,CAAC,EAAE,CAAC,OAAO,EAAE,mBAAmB,KAAK,oBAAoB,CAAC;IAC1E,gBAAgB,CAAC,EAAE,CAAC,OAAO,EAAE,mBAAmB,KAAK,oBAAoB,CAAC;IAC1E,aAAa,CAAC,EAAE,CACd,KAAK,EAAE,MAAM,KACV,OAAO,CAAC,iBAAiB,GAAG,IAAI,CAAC,GAAG,iBAAiB,GAAG,IAAI,CAAC;IAClE,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,mBAAmB,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACrE;AAmBD,wBAAgB,iBAAiB,CAAC,EAChC,UAAU,EACV,KAAc,EACd,WAA8B,EAC9B,SAAS,EACT,wBAA+B,EAC/B,oBAA4B,EAC5B,UAA0B,EAC1B,KAAK,EACL,YAAY,EACZ,MAAM,EACN,eAAe,EACf,SAAS,EACT,mBAAwB,EACxB,aAAoC,EACpC,gBAAgB,EAChB,gBAAgB,EAChB,aAAa,EACb,UAAU,GACX,EAAE,sBAAsB,2CAmRxB"}
@@ -0,0 +1,20 @@
1
+ import { ReactNode } from 'react';
2
+ export interface AuthVisualCarouselItem {
3
+ image: string;
4
+ alt: string;
5
+ title?: ReactNode;
6
+ description?: ReactNode;
7
+ eyebrow?: ReactNode;
8
+ }
9
+ export interface AuthVisualCarouselProps {
10
+ items: AuthVisualCarouselItem[];
11
+ intervalMs?: number;
12
+ showIndicators?: boolean;
13
+ showText?: boolean;
14
+ className?: string;
15
+ imageClassName?: string;
16
+ contentClassName?: string;
17
+ ariaLabel?: string;
18
+ }
19
+ export declare function AuthVisualCarousel({ items, intervalMs, showIndicators, showText, className, imageClassName, contentClassName, ariaLabel, }: AuthVisualCarouselProps): import("react/jsx-runtime").JSX.Element;
20
+ //# sourceMappingURL=AuthVisualCarousel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AuthVisualCarousel.d.ts","sourceRoot":"","sources":["../../src/components/AuthVisualCarousel.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAiB,SAAS,EAAE,MAAM,OAAO,CAAC;AAItD,MAAM,WAAW,sBAAsB;IACrC,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB,OAAO,CAAC,EAAE,SAAS,CAAC;CACrB;AAED,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,sBAAsB,EAAE,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,kBAAkB,CAAC,EACjC,KAAK,EACL,UAAiB,EACjB,cAAqB,EACrB,QAAe,EACf,SAAS,EACT,cAAc,EACd,gBAAgB,EAChB,SAAqB,GACtB,EAAE,uBAAuB,2CAgIzB"}
@@ -1,4 +1,4 @@
1
- import { ReactNode, HTMLAttributes, ButtonHTMLAttributes } from 'react';
1
+ import { ReactNode, HTMLAttributes, ButtonHTMLAttributes, MouseEvent } from 'react';
2
2
  import { UIComponent, ButtonComponent, CardComponent, TableComponent, TableRowComponent, TableCellComponent } from '../types/component-types';
3
3
  import { TableHeaderProps } from './TableHeader';
4
4
  import { TablePaginationProps } from './TablePagination';
@@ -46,7 +46,7 @@ export interface UIComponents {
46
46
  align?: 'start' | 'end' | 'center';
47
47
  }>;
48
48
  DropdownMenuItem: UIComponent<ButtonHTMLAttributes<HTMLDivElement> & {
49
- onClick?: (e: React.MouseEvent) => void;
49
+ onClick?: (e: MouseEvent) => void;
50
50
  }>;
51
51
  DropdownMenuSeparator: UIComponent;
52
52
  Skeleton: UIComponent<HTMLAttributes<HTMLDivElement>>;
@@ -1 +1 @@
1
- {"version":3,"file":"DataTable.d.ts","sourceRoot":"","sources":["../../src/components/DataTable.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"DataTable.d.ts","sourceRoot":"","sources":["../../src/components/DataTable.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAClC,OAAO,KAAK,EACV,cAAc,EACd,oBAAoB,EACpB,UAAU,EACX,MAAM,OAAO,CAAC;AAEf,OAAO,KAAK,EACV,WAAW,EACX,eAAe,EACf,aAAa,EACb,cAAc,EACd,iBAAiB,EACjB,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAElC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAE9D,KAAK,SAAS,CAAC,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC;AAE7C,KAAK,cAAc,CAAC,CAAC,IAAI;IACvB,KAAK,EAAE,SAAS,CAAC;IACjB,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,OAAO,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,KAAK,CAAC;CACnB,CAAC;AAEF,KAAK,mBAAmB,GAAG;IACzB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,IAAI,CAAC,EAAE,KAAK,CAAC;IACb,OAAO,CAAC,EAAE,KAAK,CAAC;CACjB,CAAC;AAEF,KAAK,UAAU,CAAC,CAAC,IAAI,cAAc,CAAC,CAAC,CAAC,GAAG,mBAAmB,CAAC;AAE7D,MAAM,WAAW,MAAM,CAAC,CAAC,GAAG,OAAO;IACjC,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;IAClB,KAAK,EAAE,SAAS,CAAC;IACjB,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,SAAS,CAAC;IACzE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;CACrC;AAED;;;GAGG;AACH,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,aAAa,CAAC;IACpB,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC;IACzD,UAAU,EAAE,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC;IACxD,KAAK,EAAE,cAAc,CAAC;IACtB,SAAS,EAAE,WAAW,CAAC,cAAc,CAAC,uBAAuB,CAAC,CAAC,CAAC;IAChE,SAAS,EAAE,kBAAkB,CAAC;IAC9B,SAAS,EAAE,kBAAkB,CAAC;IAC9B,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,uBAAuB,CAAC,CAAC,CAAC;IAClE,QAAQ,EAAE,iBAAiB,CAAC;IAC5B,MAAM,EAAE,eAAe,CAAC;IACxB,YAAY,EAAE,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC;IAC1D,mBAAmB,EAAE,eAAe,CAAC;IACrC,mBAAmB,EAAE,WAAW,CAC9B,cAAc,CAAC,cAAc,CAAC,GAAG;QAAE,KAAK,CAAC,EAAE,OAAO,GAAG,KAAK,GAAG,QAAQ,CAAA;KAAE,CACxE,CAAC;IACF,gBAAgB,EAAE,WAAW,CAC3B,oBAAoB,CAAC,cAAc,CAAC,GAAG;QACrC,OAAO,CAAC,EAAE,CAAC,CAAC,EAAE,UAAU,KAAK,IAAI,CAAC;KACnC,CACF,CAAC;IACF,qBAAqB,EAAE,WAAW,CAAC;IACnC,QAAQ,EAAE,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC;IACtD,oBAAoB,EAAE,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;IAC5D,wBAAwB,EAAE,KAAK,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;CACrE;AAED,MAAM,WAAW,cAAc,CAAC,CAAC,GAAG,OAAO;IAEzC,IAAI,EAAE,CAAC,EAAE,CAAC;IACV,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;IACrB,MAAM,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,KAAK,MAAM,CAAC,CAAC;IAG1C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB,CAAC,EAAE,MAAM,CAAC;IAG/B,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAG1B,UAAU,CAAC,EAAE,oBAAoB,GAAG;QAClC,IAAI,CAAC,EAAE,OAAO,CAAC;KAChB,CAAC;IAGF,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACpD,KAAK,CAAC,EAAE,CACN,MAAM,EAAE,CAAC,EACT,KAAK,EAAE,MAAM,KACV;QACH,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;QACrB,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;KAC5B,CAAC;IAGF,OAAO,CAAC,EAAE;QACR,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,IAAI,CAAC,EAAE,UAAU,GAAG,WAAW,CAAC;QAChC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,SAAS,CAAC;QACjD,KAAK,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;KACzB,CAAC;IAGF,UAAU,CAAC,EAAE,YAAY,CAAC;IAG1B,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,KAAK,SAAS,CAAC;IAC/C,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,KAAK,SAAS,CAAC;IAChE,aAAa,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,SAAS,CAAC;CACzD;AAED;;;GAGG;AACH,wBAAgB,SAAS,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,EACvD,IAAI,EACJ,OAAe,EACf,OAAO,EACP,MAAM,EACN,SAAkB,EAClB,qBAAkC,EAClC,MAAM,EACN,UAAU,EACV,YAAY,EACZ,KAAK,EACL,OAAO,EACP,UAAU,EACV,UAAU,EACV,WAAW,EACX,aAAa,GACd,EAAE,cAAc,CAAC,CAAC,CAAC,2UA6RnB"}
@@ -0,0 +1,44 @@
1
+ import { HTMLAttributes, ImgHTMLAttributes } from 'react';
2
+ import { ButtonComponent, CardComponent, SkeletonComponent, UIComponent } from '../types/component-types';
3
+ export declare const SUPPORTED_IMAGE_EXTENSIONS: readonly ["jpg", "jpeg", "png", "gif", "webp", "svg", "bmp", "avif", "ico"];
4
+ export declare const SUPPORTED_IMAGE_MIME_TYPES: readonly ["image/jpeg", "image/png", "image/gif", "image/webp", "image/svg+xml", "image/bmp", "image/avif", "image/x-icon", "image/vnd.microsoft.icon"];
5
+ export interface ImageReaderUIComponents {
6
+ Card?: CardComponent;
7
+ CardContent?: UIComponent<HTMLAttributes<HTMLDivElement>>;
8
+ Button?: ButtonComponent;
9
+ Skeleton?: SkeletonComponent;
10
+ }
11
+ export interface ImageReaderProps extends Omit<ImgHTMLAttributes<HTMLImageElement>, 'alt' | 'children' | 'className' | 'loading' | 'onError' | 'onLoad' | 'src'> {
12
+ src: string;
13
+ alt?: string;
14
+ fileName?: string;
15
+ mimeType?: string;
16
+ components?: ImageReaderUIComponents;
17
+ loading?: boolean;
18
+ error?: Error | string | null;
19
+ className?: string;
20
+ containerClassName?: string;
21
+ imageClassName?: string;
22
+ toolbarClassName?: string;
23
+ loadingText?: string;
24
+ errorText?: string;
25
+ unsupportedText?: string;
26
+ showToolbar?: boolean;
27
+ showOpenInNewTab?: boolean;
28
+ objectFit?: 'contain' | 'cover' | 'fill' | 'none' | 'scale-down';
29
+ initialScale?: number;
30
+ minScale?: number;
31
+ maxScale?: number;
32
+ scaleStep?: number;
33
+ scale?: number;
34
+ onScaleChange?: (scale: number) => void;
35
+ rotation?: number;
36
+ onRotationChange?: (rotation: number) => void;
37
+ allowUnsupportedFormat?: boolean;
38
+ supportedExtensions?: readonly string[];
39
+ supportedMimeTypes?: readonly string[];
40
+ onLoad?: () => void;
41
+ onError?: (error: Error) => void;
42
+ }
43
+ export declare function ImageReader({ src, alt, fileName, mimeType, components, loading, error, className, containerClassName, imageClassName, toolbarClassName, loadingText, errorText, unsupportedText, showToolbar, showOpenInNewTab, objectFit, initialScale, minScale, maxScale, scaleStep, scale: controlledScale, onScaleChange, rotation: controlledRotation, onRotationChange, allowUnsupportedFormat, supportedExtensions, supportedMimeTypes, onLoad, onError, style, ...imageProps }: ImageReaderProps): import("react/jsx-runtime").JSX.Element;
44
+ //# sourceMappingURL=ImageReader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageReader.d.ts","sourceRoot":"","sources":["../../src/components/ImageReader.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ import { HTMLAttributes, TrackHTMLAttributes, VideoHTMLAttributes } from 'react';
2
+ import { ButtonComponent, CardComponent, SkeletonComponent, UIComponent } from '../types/component-types';
3
+ export declare const SUPPORTED_VIDEO_EXTENSIONS: readonly ["mp4", "webm", "ogg", "ogv", "mov", "m4v"];
4
+ export declare const SUPPORTED_VIDEO_MIME_TYPES: readonly ["video/mp4", "video/webm", "video/ogg", "video/quicktime", "video/x-m4v"];
5
+ export interface VideoReaderUIComponents {
6
+ Card?: CardComponent;
7
+ CardContent?: UIComponent<HTMLAttributes<HTMLDivElement>>;
8
+ Button?: ButtonComponent;
9
+ Skeleton?: SkeletonComponent;
10
+ }
11
+ export interface VideoReaderTrack extends Omit<TrackHTMLAttributes<HTMLTrackElement>, 'children'> {
12
+ src: string;
13
+ }
14
+ export interface VideoReaderProps extends Omit<VideoHTMLAttributes<HTMLVideoElement>, 'children' | 'className' | 'onError' | 'onLoadedData' | 'src'> {
15
+ src: string;
16
+ fileName?: string;
17
+ mimeType?: string;
18
+ title?: string;
19
+ components?: VideoReaderUIComponents;
20
+ tracks?: VideoReaderTrack[];
21
+ loading?: boolean;
22
+ error?: Error | string | null;
23
+ className?: string;
24
+ containerClassName?: string;
25
+ videoClassName?: string;
26
+ toolbarClassName?: string;
27
+ loadingText?: string;
28
+ errorText?: string;
29
+ unsupportedText?: string;
30
+ showToolbar?: boolean;
31
+ showOpenInNewTab?: boolean;
32
+ allowUnsupportedFormat?: boolean;
33
+ supportedExtensions?: readonly string[];
34
+ supportedMimeTypes?: readonly string[];
35
+ onLoadedData?: () => void;
36
+ onError?: (error: Error) => void;
37
+ }
38
+ export declare function VideoReader({ src, fileName, mimeType, title, components, tracks, loading, error, className, containerClassName, videoClassName, toolbarClassName, loadingText, errorText, unsupportedText, showToolbar, showOpenInNewTab, allowUnsupportedFormat, supportedExtensions, supportedMimeTypes, controls, preload, playsInline, onLoadedData, onError, ...videoProps }: VideoReaderProps): import("react/jsx-runtime").JSX.Element;
39
+ //# sourceMappingURL=VideoReader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VideoReader.d.ts","sourceRoot":"","sources":["../../src/components/VideoReader.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,cAAc,EAEd,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,OAAO,CAAC;AAGf,OAAO,KAAK,EACV,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,WAAW,EACZ,MAAM,0BAA0B,CAAC;AAIlC,eAAO,MAAM,0BAA0B,sDAO7B,CAAC;AAEX,eAAO,MAAM,0BAA0B,qFAM7B,CAAC;AAEX,MAAM,WAAW,uBAAuB;IACtC,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,WAAW,CAAC,EAAE,WAAW,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC,CAAC;IAC1D,MAAM,CAAC,EAAE,eAAe,CAAC;IACzB,QAAQ,CAAC,EAAE,iBAAiB,CAAC;CAC9B;AAED,MAAM,WAAW,gBACf,SAAQ,IAAI,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,EAAE,UAAU,CAAC;IAC/D,GAAG,EAAE,MAAM,CAAC;CACb;AAED,MAAM,WAAW,gBACf,SAAQ,IAAI,CACV,mBAAmB,CAAC,gBAAgB,CAAC,EACrC,UAAU,GAAG,WAAW,GAAG,SAAS,GAAG,cAAc,GAAG,KAAK,CAC9D;IACD,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,uBAAuB,CAAC;IACrC,MAAM,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC5B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,IAAI,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,sBAAsB,CAAC,EAAE,OAAO,CAAC;IACjC,mBAAmB,CAAC,EAAE,SAAS,MAAM,EAAE,CAAC;IACxC,kBAAkB,CAAC,EAAE,SAAS,MAAM,EAAE,CAAC;IACvC,YAAY,CAAC,EAAE,MAAM,IAAI,CAAC;IAC1B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CAClC;AAOD,wBAAgB,WAAW,CAAC,EAC1B,GAAG,EACH,QAAQ,EACR,QAAQ,EACR,KAAK,EACL,UAAU,EACV,MAAM,EACN,OAAe,EACf,KAAK,EACL,SAAS,EACT,kBAAkB,EAClB,cAAc,EACd,gBAAgB,EAChB,WAAyB,EACzB,SAAoB,EACpB,eAA6B,EAC7B,WAAkB,EAClB,gBAAuB,EACvB,sBAA8B,EAC9B,mBAAgD,EAChD,kBAA+C,EAC/C,QAAe,EACf,OAAoB,EACpB,WAAkB,EAClB,YAAY,EACZ,OAAO,EACP,GAAG,UAAU,EACd,EAAE,gBAAgB,2CAmKlB"}
@@ -0,0 +1,9 @@
1
+ export declare const getMediaExtension: (src?: string, fileName?: string) => string;
2
+ export declare const isSupportedMediaSource: ({ src, fileName, mimeType, supportedExtensions, supportedMimeTypes, }: {
3
+ src?: string;
4
+ fileName?: string;
5
+ mimeType?: string;
6
+ supportedExtensions: readonly string[];
7
+ supportedMimeTypes: readonly string[];
8
+ }) => boolean;
9
+ //# sourceMappingURL=media-utils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media-utils.d.ts","sourceRoot":"","sources":["../../src/components/media-utils.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,GAAI,MAAM,MAAM,EAAE,WAAW,MAAM,WAUhE,CAAC;AAEF,eAAO,MAAM,sBAAsB,GAAI,uEAMpC;IACD,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,mBAAmB,EAAE,SAAS,MAAM,EAAE,CAAC;IACvC,kBAAkB,EAAE,SAAS,MAAM,EAAE,CAAC;CACvC,YAeA,CAAC"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./jsx-runtime-BB_1_6y_.cjs"),ee=require("lucide-react");function te({data:f,loading:z=!1,columns:j,rowKey:c,emptyText:M="暂无数据",searchActiveEmptyText:D="未找到匹配的记录",header:l,pagination:n,rowClassName:g,onRow:R,actions:s,components:b,renderCard:S,renderTable:a,renderActions:N}){var C,v;if(!b)return e.jsxRuntimeExports.jsxs("div",{className:"p-4 text-center text-destructive",children:["错误:请通过 components prop 注入 UI 组件",e.jsxRuntimeExports.jsx("br",{}),e.jsxRuntimeExports.jsx("code",{className:"text-sm",children:'import { Card, Table, Button, ... } from "@/components/ui"'})]});const{Card:B,CardContent:$,CardFooter:A,Table:H,TableBody:E,TableCell:o,TableHead:T,TableHeader:V,TableRow:h,Button:O,DropdownMenu:q,DropdownMenuTrigger:I,DropdownMenuContent:J,DropdownMenuItem:F,DropdownMenuSeparator:U,Skeleton:w,TableHeaderComponent:_,TablePaginationComponent:G}=b,L=(t,x)=>{if(typeof c=="function")return c(t);const r=t[c];return r!=null?String(r):`row-${x}`},y=!!(l!=null&&l.searchValue&&l.searchValue.trim().length>0),u=!!(s!=null&&s.render||(C=s==null?void 0:s.items)!=null&&C.length),Q=(s==null?void 0:s.mode)??((v=s==null?void 0:s.items)!=null&&v.length?"collapsed":"expanded"),W=t=>t.separator===!0,X=(t,x)=>!s||!u?null:Q==="collapsed"&&s.items&&s.items.length>0?e.jsxRuntimeExports.jsxs(q,{children:[e.jsxRuntimeExports.jsx(I,{asChild:!0,children:e.jsxRuntimeExports.jsx(O,{variant:"ghost",className:"h-8 w-8 p-0","aria-label":"打开行操作菜单",children:e.jsxRuntimeExports.jsx(ee.MoreVertical,{className:"h-4 w-4"})})}),e.jsxRuntimeExports.jsx(J,{align:"end",children:s.items.map((r,d)=>W(r)?e.jsxRuntimeExports.jsx(U,{},`separator-${d}`):e.jsxRuntimeExports.jsxs(F,{onClick:()=>r.onClick(t,x),className:r.className,children:[r.icon&&e.jsxRuntimeExports.jsx("span",{className:"mr-2 h-4 w-4",children:r.icon}),r.label]},`action-${d}`))})]}):s.render?s.render(t,x):null,m=()=>e.jsxRuntimeExports.jsx(V,{children:e.jsxRuntimeExports.jsxs(h,{className:"bg-muted/50 hover:bg-muted/50",children:[j.map(t=>e.jsxRuntimeExports.jsx(T,{className:`font-semibold text-foreground ${t.align==="center"?"text-center":t.align==="right"?"text-right":"text-left"}`,style:{width:t.width},children:t.title},String(t.key))),u&&e.jsxRuntimeExports.jsx(T,{className:"text-right font-semibold text-foreground",children:(s==null?void 0:s.title)||"操作"})]})}),p=()=>z?e.jsxRuntimeExports.jsx(E,{children:Array.from({length:5}).map((t,x)=>e.jsxRuntimeExports.jsxs(h,{children:[j.map(r=>e.jsxRuntimeExports.jsx(o,{style:{width:r.width},className:r.align==="center"?"text-center":r.align==="right"?"text-right":"",children:e.jsxRuntimeExports.jsx(w,{className:"h-4 w-full"})},String(r.key))),u&&e.jsxRuntimeExports.jsx(o,{children:e.jsxRuntimeExports.jsx(w,{className:"ml-auto h-4 w-8"})})]},x))}):f.length===0?e.jsxRuntimeExports.jsx(E,{children:e.jsxRuntimeExports.jsx(h,{children:e.jsxRuntimeExports.jsx(o,{colSpan:j.length+(u?1:0),className:"py-8 text-center text-muted-foreground",children:y?D:M})})}):e.jsxRuntimeExports.jsx(E,{children:f.map((t,x)=>{const r=L(t,x),d=R==null?void 0:R(t,x),Z=g==null?void 0:g(t,x);return e.jsxRuntimeExports.jsxs(h,{className:`${Z||""} hover:bg-muted/50`,...d,children:[j.map(i=>{const k=t[i.key],K=i.render?i.render(k,t,x):k;return e.jsxRuntimeExports.jsx(o,{className:i.align==="center"?"text-center":i.align==="right"?"text-right":"",children:K},String(i.key))}),u&&e.jsxRuntimeExports.jsx(o,{className:"text-right",children:N?N(t,x):X(t,x)})]},r)})}),Y=t=>e.jsxRuntimeExports.jsxs(B,{children:[l&&e.jsxRuntimeExports.jsx("div",{className:"p-6 pb-0",children:e.jsxRuntimeExports.jsx(_,{...l})}),e.jsxRuntimeExports.jsx($,{className:"p-0",children:t}),(n==null?void 0:n.show)!==!1&&n&&e.jsxRuntimeExports.jsx(A,{className:"border-t py-4",children:e.jsxRuntimeExports.jsx(G,{currentPage:n.currentPage,pageSize:n.pageSize,total:n.total,onPageChange:n.onPageChange,onPageSizeChange:n.onPageSizeChange,pageSizeOptions:n.pageSizeOptions,showPageSizeSelector:n.showPageSizeSelector,showJumpToPage:n.showJumpToPage,showTotal:n.showTotal,searchActive:y})})]}),P=(t,x)=>e.jsxRuntimeExports.jsxs(H,{children:[t,x]});return S?S(a?a(m(),p()):P(m(),p())):Y(a?a(m(),p()):P(m(),p()))}exports.DataTable=te;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./jsx-runtime-BB_1_6y_.cjs"),ee=require("lucide-react");function te({data:b,loading:M=!1,columns:u,rowKey:c,emptyText:D="暂无数据",searchActiveEmptyText:B="未找到匹配的记录",header:o,pagination:n,rowClassName:g,onRow:R,actions:s,components:S,renderCard:N,renderTable:j,renderActions:T}){var k,v;if(!S)return e.jsxRuntimeExports.jsxs("div",{className:"p-4 text-center text-destructive",children:["错误:请通过 components prop 注入 UI 组件",e.jsxRuntimeExports.jsx("br",{}),e.jsxRuntimeExports.jsx("code",{className:"text-sm",children:'import { Card, Table, Button, ... } from "@/components/ui"'})]});const{Card:$,CardContent:A,CardFooter:H,Table:V,TableBody:E,TableCell:i,TableHead:P,TableHeader:O,TableRow:p,Button:q,DropdownMenu:I,DropdownMenuTrigger:J,DropdownMenuContent:F,DropdownMenuItem:U,DropdownMenuSeparator:_,Skeleton:w,TableHeaderComponent:G,TablePaginationComponent:L}=S,Q=(t,x)=>{if(typeof c=="function")return c(t);const r=t[c];return r!=null?String(r):`row-${x}`},y=!!(o!=null&&o.searchValue&&o.searchValue.trim().length>0),a=!!(s!=null&&s.render||(k=s==null?void 0:s.items)!=null&&k.length),W=(s==null?void 0:s.mode)??((v=s==null?void 0:s.items)!=null&&v.length?"collapsed":"expanded"),X=t=>t.separator===!0,Y=(t,x)=>!s||!a?null:W==="collapsed"&&s.items&&s.items.length>0?e.jsxRuntimeExports.jsxs(I,{children:[e.jsxRuntimeExports.jsx(J,{asChild:!0,children:e.jsxRuntimeExports.jsx(q,{variant:"ghost",className:"h-8 w-8 p-0","aria-label":"打开行操作菜单",onClick:r=>r.stopPropagation(),children:e.jsxRuntimeExports.jsx(ee.MoreVertical,{className:"h-4 w-4"})})}),e.jsxRuntimeExports.jsx(F,{align:"end",children:s.items.map((r,d)=>X(r)?e.jsxRuntimeExports.jsx(_,{},`separator-${d}`):e.jsxRuntimeExports.jsxs(U,{onClick:f=>{f.stopPropagation(),r.onClick(t,x)},className:r.className,children:[r.icon&&e.jsxRuntimeExports.jsx("span",{className:"mr-2 h-4 w-4",children:r.icon}),r.label]},`action-${d}`))})]}):s.render?s.render(t,x):null,h=()=>e.jsxRuntimeExports.jsx(O,{children:e.jsxRuntimeExports.jsxs(p,{className:"bg-muted/50 hover:bg-muted/50",children:[u.map(t=>e.jsxRuntimeExports.jsx(P,{className:`font-semibold text-foreground ${t.align==="center"?"text-center":t.align==="right"?"text-right":"text-left"}`,style:{width:t.width},children:t.title},String(t.key))),a&&e.jsxRuntimeExports.jsx(P,{className:"text-right font-semibold text-foreground",children:(s==null?void 0:s.title)||"操作"})]})}),m=()=>M?e.jsxRuntimeExports.jsx(E,{children:Array.from({length:5}).map((t,x)=>e.jsxRuntimeExports.jsxs(p,{children:[u.map(r=>e.jsxRuntimeExports.jsx(i,{style:{width:r.width},className:r.align==="center"?"text-center":r.align==="right"?"text-right":"",children:e.jsxRuntimeExports.jsx(w,{className:"h-4 w-full"})},String(r.key))),a&&e.jsxRuntimeExports.jsx(i,{children:e.jsxRuntimeExports.jsx(w,{className:"ml-auto h-4 w-8"})})]},x))}):b.length===0?e.jsxRuntimeExports.jsx(E,{children:e.jsxRuntimeExports.jsx(p,{children:e.jsxRuntimeExports.jsx(i,{colSpan:u.length+(a?1:0),className:"py-8 text-center text-muted-foreground",children:y?B:D})})}):e.jsxRuntimeExports.jsx(E,{children:b.map((t,x)=>{const r=Q(t,x),d=R==null?void 0:R(t,x),f=g==null?void 0:g(t,x);return e.jsxRuntimeExports.jsxs(p,{className:`${f||""} hover:bg-muted/50`,...d,children:[u.map(l=>{const z=t[l.key],K=l.render?l.render(z,t,x):z;return e.jsxRuntimeExports.jsx(i,{className:l.align==="center"?"text-center":l.align==="right"?"text-right":"",children:K},String(l.key))}),a&&e.jsxRuntimeExports.jsx(i,{className:"text-right",onClick:l=>l.stopPropagation(),children:T?T(t,x):Y(t,x)})]},r)})}),Z=t=>e.jsxRuntimeExports.jsxs($,{children:[o&&e.jsxRuntimeExports.jsx("div",{className:"p-6 pb-0",children:e.jsxRuntimeExports.jsx(G,{...o})}),e.jsxRuntimeExports.jsx(A,{className:"p-0",children:t}),(n==null?void 0:n.show)!==!1&&n&&e.jsxRuntimeExports.jsx(H,{className:"border-t py-4",children:e.jsxRuntimeExports.jsx(L,{currentPage:n.currentPage,pageSize:n.pageSize,total:n.total,onPageChange:n.onPageChange,onPageSizeChange:n.onPageSizeChange,pageSizeOptions:n.pageSizeOptions,showPageSizeSelector:n.showPageSizeSelector,showJumpToPage:n.showJumpToPage,showTotal:n.showTotal,searchActive:y})})]}),C=(t,x)=>e.jsxRuntimeExports.jsxs(V,{children:[t,x]});return N?N(j?j(h(),m()):C(h(),m())):Z(j?j(h(),m()):C(h(),m()))}exports.DataTable=te;
2
2
  //# sourceMappingURL=data-table.cjs.map