@alepha/ui 0.17.1 → 0.18.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/dist/admin/{AdminApiKeys-CF_qOO3u.js → AdminApiKeys-C-6_Q-lH.js} +56 -192
- package/dist/admin/AdminApiKeys-C-6_Q-lH.js.map +1 -0
- package/dist/admin/{AdminAudits-BQno3hZG.js → AdminAudits-Bgbf04hO.js} +25 -61
- package/dist/admin/AdminAudits-Bgbf04hO.js.map +1 -0
- package/dist/admin/{AdminFiles-kvuUaASF.js → AdminFiles-B9a7G3cY.js} +6 -8
- package/dist/admin/AdminFiles-B9a7G3cY.js.map +1 -0
- package/dist/admin/{AdminJobDashboard-CrPxp0W1.js → AdminJobDashboard-DaTwf5OY.js} +55 -186
- package/dist/admin/AdminJobDashboard-DaTwf5OY.js.map +1 -0
- package/dist/admin/{AdminJobExecutions-D-b4Zt7W.js → AdminJobExecutions-B9cek5dl.js} +132 -168
- package/dist/admin/AdminJobExecutions-B9cek5dl.js.map +1 -0
- package/dist/admin/{AdminJobRegistry-CNX5cpDx.js → AdminJobRegistry-DFgV3oqx.js} +60 -83
- package/dist/admin/AdminJobRegistry-DFgV3oqx.js.map +1 -0
- package/dist/admin/AdminLayout-DHsvWxVB.js +70 -0
- package/dist/admin/AdminLayout-DHsvWxVB.js.map +1 -0
- package/dist/admin/{AdminParameters-iQE8o7a7.js → AdminParameters-DHw9ATgl.js} +53 -53
- package/dist/admin/AdminParameters-DHw9ATgl.js.map +1 -0
- package/dist/admin/{AdminSessions-oKJCbd7w.js → AdminSessions-BhGJPI3z.js} +11 -18
- package/dist/admin/AdminSessions-BhGJPI3z.js.map +1 -0
- package/dist/admin/{AdminUserLayout-HAlobhWf.js → AdminUserLayout-BdC4Te8m.js} +112 -151
- package/dist/admin/AdminUserLayout-BdC4Te8m.js.map +1 -0
- package/dist/admin/AdminUserProfile-DAt23fqY.js +69 -0
- package/dist/admin/AdminUserProfile-DAt23fqY.js.map +1 -0
- package/dist/admin/AdminUserSessions-1uzcx02z.js +109 -0
- package/dist/admin/AdminUserSessions-1uzcx02z.js.map +1 -0
- package/dist/admin/AdminUsers-C85c3eiQ.js +121 -0
- package/dist/admin/AdminUsers-C85c3eiQ.js.map +1 -0
- package/dist/{auth/AuthLayout-CdJcrPs4.js → admin/AuthLayout-DFJvCvzw.js} +3 -3
- package/dist/{auth/AuthLayout-CdJcrPs4.js.map → admin/AuthLayout-DFJvCvzw.js.map} +1 -1
- package/dist/{auth/IconGoogle-Bm18QD2q.js → admin/IconGoogle-CSQLPYwX.js} +1 -1
- package/dist/{auth/IconGoogle-Bm18QD2q.js.map → admin/IconGoogle-CSQLPYwX.js.map} +1 -1
- package/dist/{demo/DemoLogin-DjJ9314c.js → admin/Login-BGheURrg.js} +15 -129
- package/dist/{auth/Login-BS_FYTy0.js.map → admin/Login-BGheURrg.js.map} +1 -1
- package/dist/{auth/Profile-CjDsW378.js → admin/Profile-B-c9pCPf.js} +5 -5
- package/dist/{auth/Profile-CjDsW378.js.map → admin/Profile-B-c9pCPf.js.map} +1 -1
- package/dist/{demo/DemoRegister-DzkJ5M83.js → admin/Register-Cs10l8vX.js} +20 -146
- package/dist/{auth/Register-C5eqzAaD.js.map → admin/Register-Cs10l8vX.js.map} +1 -1
- package/dist/{demo/DemoResetPassword-DWh4_BpQ.js → admin/ResetPassword-BwDdfkGH.js} +20 -82
- package/dist/{auth/ResetPassword-XifinVao.js.map → admin/ResetPassword-BwDdfkGH.js.map} +1 -1
- package/dist/{demo/DemoVerifyEmail-DbU_tCj8.js → admin/VerifyEmail-DfXHAiQl.js} +15 -32
- package/dist/{auth/VerifyEmail-DTgbeJOO.js.map → admin/VerifyEmail-DfXHAiQl.js.map} +1 -1
- package/dist/admin/auth-Dr0Cf8I7.js +319 -0
- package/dist/admin/auth-Dr0Cf8I7.js.map +1 -0
- package/dist/admin/core-2xoLiT0o.js +4031 -0
- package/dist/admin/core-2xoLiT0o.js.map +1 -0
- package/dist/admin/index.d.ts +740 -17
- package/dist/admin/index.d.ts.map +1 -1
- package/dist/admin/index.js +80 -127
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/rolldown-runtime-CjeV3_4I.js +18 -0
- package/dist/auth/AuthLayout-CAE1pX9s.js +22 -0
- package/dist/auth/AuthLayout-CAE1pX9s.js.map +1 -0
- package/dist/auth/{Login-BS_FYTy0.js → Login-Denw_UGy.js} +8 -8
- package/dist/auth/Login-Denw_UGy.js.map +1 -0
- package/dist/auth/Profile-BMX_Ar_s.js +155 -0
- package/dist/auth/Profile-BMX_Ar_s.js.map +1 -0
- package/dist/auth/{Register-C5eqzAaD.js → Register-6hi_cpfF.js} +8 -8
- package/dist/auth/Register-6hi_cpfF.js.map +1 -0
- package/dist/auth/{ResetPassword-XifinVao.js → ResetPassword-CqfTk1FI.js} +6 -6
- package/dist/auth/ResetPassword-CqfTk1FI.js.map +1 -0
- package/dist/auth/{VerifyEmail-DTgbeJOO.js → VerifyEmail-nWiSTMjF.js} +5 -5
- package/dist/auth/VerifyEmail-nWiSTMjF.js.map +1 -0
- package/dist/auth/core-niW0sFLv.js +2264 -0
- package/dist/auth/core-niW0sFLv.js.map +1 -0
- package/dist/auth/index.d.ts +336 -8
- package/dist/auth/index.d.ts.map +1 -1
- package/dist/auth/index.js +18 -22
- package/dist/auth/index.js.map +1 -1
- package/dist/core/index.d.ts +1033 -843
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +1626 -1354
- package/dist/core/index.js.map +1 -1
- package/dist/demo/AuthLayout-jLa0aKsI.js +22 -0
- package/dist/demo/AuthLayout-jLa0aKsI.js.map +1 -0
- package/dist/demo/DemoButton-BmaWZVwf.js +178 -0
- package/dist/demo/DemoButton-BmaWZVwf.js.map +1 -0
- package/dist/demo/{DemoDataTable-lnBKWBf8.js → DemoDataTable-Z9xyV221.js} +18 -18
- package/dist/demo/DemoDataTable-Z9xyV221.js.map +1 -0
- package/dist/demo/DemoDialog-4ItHLf9t.js +101 -0
- package/dist/demo/DemoDialog-4ItHLf9t.js.map +1 -0
- package/dist/demo/DemoFlex-EtVq8QfX.js +105 -0
- package/dist/demo/DemoFlex-EtVq8QfX.js.map +1 -0
- package/dist/demo/DemoHeading-BS-vGfkI.js +18 -0
- package/dist/demo/DemoHeading-BS-vGfkI.js.map +1 -0
- package/dist/demo/{DemoHome-CUMZsYaH.js → DemoHome-Clbn8AmS.js} +9 -12
- package/dist/demo/DemoHome-Clbn8AmS.js.map +1 -0
- package/dist/demo/DemoJsonViewer-DkIX_ky2.js +109 -0
- package/dist/demo/DemoJsonViewer-DkIX_ky2.js.map +1 -0
- package/dist/demo/DemoLayout-C56xb5EE.js +73 -0
- package/dist/demo/DemoLayout-C56xb5EE.js.map +1 -0
- package/dist/demo/DemoLogin-BZwpicOS.js +128 -0
- package/dist/demo/DemoLogin-BZwpicOS.js.map +1 -0
- package/dist/demo/DemoRegister-C7_qc4MJ.js +140 -0
- package/dist/demo/DemoRegister-C7_qc4MJ.js.map +1 -0
- package/dist/demo/DemoResetPassword-BI1Ct4Dw.js +76 -0
- package/dist/demo/DemoResetPassword-BI1Ct4Dw.js.map +1 -0
- package/dist/demo/{DemoSidebar-C1csnGhX.js → DemoSidebar-CcBo4ltC.js} +6 -9
- package/dist/demo/DemoSidebar-CcBo4ltC.js.map +1 -0
- package/dist/demo/DemoText-CzXuUn3g.js +124 -0
- package/dist/demo/DemoText-CzXuUn3g.js.map +1 -0
- package/dist/demo/DemoToast-BgHDhWrX.js +95 -0
- package/dist/demo/DemoToast-BgHDhWrX.js.map +1 -0
- package/dist/demo/{DemoTypeForm-CWz6fJrJ.js → DemoTypeForm-DDzWoMSV.js} +4 -4
- package/dist/demo/{DemoTypeForm-CWz6fJrJ.js.map → DemoTypeForm-DDzWoMSV.js.map} +1 -1
- package/dist/demo/DemoVerifyEmail-C_Irdnov.js +30 -0
- package/dist/demo/DemoVerifyEmail-C_Irdnov.js.map +1 -0
- package/dist/demo/IconGoogle-CSQLPYwX.js +56 -0
- package/dist/demo/IconGoogle-CSQLPYwX.js.map +1 -0
- package/dist/demo/Login-hSOU3jZc.js +219 -0
- package/dist/demo/Login-hSOU3jZc.js.map +1 -0
- package/dist/demo/Profile-CWqti7FB.js +155 -0
- package/dist/demo/Profile-CWqti7FB.js.map +1 -0
- package/dist/demo/Register-a70LPgs2.js +375 -0
- package/dist/demo/Register-a70LPgs2.js.map +1 -0
- package/dist/demo/ResetPassword-DWN0lzr5.js +286 -0
- package/dist/demo/ResetPassword-DWN0lzr5.js.map +1 -0
- package/dist/demo/Showcase-Dq3MISpd.js +232 -0
- package/dist/demo/Showcase-Dq3MISpd.js.map +1 -0
- package/dist/demo/VerifyEmail-DZWL72K4.js +135 -0
- package/dist/demo/VerifyEmail-DZWL72K4.js.map +1 -0
- package/dist/demo/auth-d6n3xbug.js +257 -0
- package/dist/demo/auth-d6n3xbug.js.map +1 -0
- package/dist/demo/core-RCUw1Q-a.js +4217 -0
- package/dist/demo/core-RCUw1Q-a.js.map +1 -0
- package/dist/demo/index.d.ts +17 -6
- package/dist/demo/index.d.ts.map +1 -1
- package/dist/demo/index.js +92 -24
- package/dist/demo/index.js.map +1 -1
- package/dist/demo/rolldown-runtime-CjeV3_4I.js +18 -0
- package/package.json +16 -20
- package/src/admin/AdminRouter.ts +12 -61
- package/src/admin/components/AdminLayout.tsx +42 -10
- package/src/admin/components/audits/AdminAudits.tsx +10 -64
- package/src/admin/components/files/AdminFiles.tsx +2 -3
- package/src/admin/components/jobs/AdminJobDashboard.tsx +36 -142
- package/src/admin/components/jobs/AdminJobExecutions.tsx +117 -175
- package/src/admin/components/jobs/AdminJobRegistry.tsx +58 -73
- package/src/admin/components/keys/AdminApiKeys.tsx +21 -169
- package/src/admin/components/parameters/AdminParameters.tsx +4 -4
- package/src/admin/components/parameters/ParameterEmptyState.tsx +1 -2
- package/src/admin/components/parameters/ParameterHistory.tsx +3 -3
- package/src/admin/components/parameters/ParameterTree.tsx +2 -8
- package/src/admin/components/parameters/types.ts +3 -3
- package/src/admin/components/sessions/AdminSessions.tsx +8 -16
- package/src/admin/components/users/AdminUserLayout.tsx +113 -150
- package/src/admin/components/users/AdminUserProfile.tsx +50 -0
- package/src/admin/components/users/AdminUserSessions.tsx +106 -126
- package/src/admin/components/users/AdminUsers.tsx +46 -62
- package/src/admin/index.ts +1 -5
- package/src/auth/components/buttons/UserButton.tsx +1 -1
- package/src/auth/index.ts +0 -4
- package/src/core/UiRouter.ts +1 -1
- package/src/core/atoms/alephaSidebarAtom.ts +7 -31
- package/src/core/components/{layout/AlephaMantineProvider.tsx → AlephaMantineProvider.tsx} +3 -4
- package/src/core/components/Flex.tsx +63 -0
- package/src/core/components/Heading.tsx +19 -0
- package/src/core/components/Text.tsx +140 -0
- package/src/core/components/buttons/ActionButton.tsx +12 -1
- package/src/core/components/buttons/BurgerButton.tsx +3 -3
- package/src/core/components/buttons/LanguageButton.tsx +1 -1
- package/src/core/components/buttons/ToggleSidebarButton.tsx +1 -4
- package/src/core/components/data/DetailDrawer.tsx +144 -0
- package/src/core/components/data/DetailList.tsx +64 -0
- package/src/core/components/data/StatCards.tsx +50 -0
- package/src/core/components/layout/AppBar.tsx +11 -10
- package/src/core/components/layout/Breadcrumb.tsx +8 -8
- package/src/core/components/layout/Container.tsx +15 -0
- package/src/core/components/layout/DashboardShell.tsx +23 -238
- package/src/core/components/layout/Omnibar.tsx +1 -2
- package/src/core/components/layout/Sidebar.tsx +103 -71
- package/src/core/components/layout/index.ts +65 -0
- package/src/core/{components/form → form/components}/Control.tsx +32 -14
- package/src/core/{components/form → form/components}/ControlArray.tsx +2 -5
- package/src/core/{components/form → form/components}/ControlDate.tsx +1 -4
- package/src/core/{components/form → form/components}/ControlNumber.tsx +1 -4
- package/src/core/{components/form → form/components}/ControlObject.tsx +1 -4
- package/src/core/{components/form → form/components}/ControlQueryBuilder.tsx +7 -7
- package/src/core/{components/form → form/components}/ControlSelect.tsx +2 -4
- package/src/core/{components/form → form/components}/TypeForm.browser.spec.tsx +22 -64
- package/src/core/{components/form → form/components}/TypeForm.tsx +1 -3
- package/src/core/form/factories/dialogForm.tsx +31 -0
- package/src/core/form/index.ts +23 -0
- package/src/core/{utils → form/utils}/parseInput.ts +2 -4
- package/src/core/index.ts +43 -51
- package/src/core/interfaces/AlephaIntent.ts +6 -0
- package/src/core/interfaces/AlephaTheme.ts +0 -1
- package/src/core/json/factories/dialogJson.tsx +24 -0
- package/src/core/json/index.ts +2 -0
- package/src/core/primitives/$ui.ts +17 -0
- package/src/core/services/DialogService.tsx +1 -48
- package/src/core/styles.css +1 -8
- package/src/core/{components/table → table/components}/ColumnPicker.tsx +2 -3
- package/src/core/{components/table → table/components}/DataTable.tsx +8 -9
- package/src/core/{components/table → table/components}/DataTableFilters.tsx +6 -3
- package/src/core/{components/table → table/components}/DataTableToolbar.tsx +4 -5
- package/src/core/{components/table → table/components}/FilterPicker.tsx +2 -3
- package/src/core/table/index.ts +12 -0
- package/src/core/{components/table → table/interfaces}/types.ts +2 -2
- package/src/demo/DemoRouter.ts +87 -6
- package/src/demo/components/DemoHome.tsx +6 -10
- package/src/demo/components/DemoLayout.tsx +38 -8
- package/src/demo/components/auth/DemoLogin.tsx +1 -1
- package/src/demo/components/auth/DemoRegister.tsx +1 -1
- package/src/demo/components/auth/DemoResetPassword.tsx +1 -1
- package/src/demo/components/auth/DemoVerifyEmail.tsx +1 -1
- package/src/demo/components/core/DemoButton.tsx +160 -0
- package/src/demo/components/core/DemoFlex.tsx +101 -0
- package/src/demo/components/core/DemoHeading.tsx +13 -0
- package/src/demo/components/core/DemoText.tsx +110 -0
- package/src/demo/components/json/DemoJsonViewer.tsx +1 -1
- package/src/demo/components/layout/DemoDialog.tsx +103 -0
- package/src/demo/components/{core → layout}/DemoSidebar.tsx +0 -1
- package/src/demo/components/layout/DemoToast.tsx +96 -0
- package/src/demo/components/shared/MacWindow.tsx +149 -74
- package/src/demo/components/shared/Showcase.tsx +4 -8
- package/src/demo/index.ts +1 -4
- package/src/demo/primitives/$uiDemo.ts +10 -0
- package/dist/admin/AdminApiKeys-CF_qOO3u.js.map +0 -1
- package/dist/admin/AdminAudits-BQno3hZG.js.map +0 -1
- package/dist/admin/AdminFiles-kvuUaASF.js.map +0 -1
- package/dist/admin/AdminJobDashboard-CrPxp0W1.js.map +0 -1
- package/dist/admin/AdminJobExecutions-D-b4Zt7W.js.map +0 -1
- package/dist/admin/AdminJobRegistry-CNX5cpDx.js.map +0 -1
- package/dist/admin/AdminLayout-e-ZP5nWw.js +0 -37
- package/dist/admin/AdminLayout-e-ZP5nWw.js.map +0 -1
- package/dist/admin/AdminNotifications-DeHJFf6W.js +0 -153
- package/dist/admin/AdminNotifications-DeHJFf6W.js.map +0 -1
- package/dist/admin/AdminParameters-iQE8o7a7.js.map +0 -1
- package/dist/admin/AdminSessions-oKJCbd7w.js.map +0 -1
- package/dist/admin/AdminUserAudits-BNCEle_E.js +0 -177
- package/dist/admin/AdminUserAudits-BNCEle_E.js.map +0 -1
- package/dist/admin/AdminUserCreate-CgqeFwCt.js +0 -104
- package/dist/admin/AdminUserCreate-CgqeFwCt.js.map +0 -1
- package/dist/admin/AdminUserDetails-DDe1A1GP.js +0 -477
- package/dist/admin/AdminUserDetails-DDe1A1GP.js.map +0 -1
- package/dist/admin/AdminUserLayout-HAlobhWf.js.map +0 -1
- package/dist/admin/AdminUserSessions-Bq1LnVLf.js +0 -129
- package/dist/admin/AdminUserSessions-Bq1LnVLf.js.map +0 -1
- package/dist/admin/AdminUserSettings-BRsBZoxV.js +0 -167
- package/dist/admin/AdminUserSettings-BRsBZoxV.js.map +0 -1
- package/dist/admin/AdminUsers-D71kIOSn.js +0 -118
- package/dist/admin/AdminUsers-D71kIOSn.js.map +0 -1
- package/dist/demo/DemoDataTable-lnBKWBf8.js.map +0 -1
- package/dist/demo/DemoHome-CUMZsYaH.js.map +0 -1
- package/dist/demo/DemoJsonViewer-_uokbGaW.js +0 -429
- package/dist/demo/DemoJsonViewer-_uokbGaW.js.map +0 -1
- package/dist/demo/DemoLayout-DHVoacE6.js +0 -46
- package/dist/demo/DemoLayout-DHVoacE6.js.map +0 -1
- package/dist/demo/DemoLogin-DjJ9314c.js.map +0 -1
- package/dist/demo/DemoRegister-DzkJ5M83.js.map +0 -1
- package/dist/demo/DemoResetPassword-DWh4_BpQ.js.map +0 -1
- package/dist/demo/DemoSidebar-C1csnGhX.js.map +0 -1
- package/dist/demo/DemoVerifyEmail-DbU_tCj8.js.map +0 -1
- package/dist/demo/Showcase-BzoXNlCn.js +0 -185
- package/dist/demo/Showcase-BzoXNlCn.js.map +0 -1
- package/dist/json/index.d.ts +0 -57
- package/dist/json/index.d.ts.map +0 -1
- package/dist/json/index.js +0 -325
- package/dist/json/index.js.map +0 -1
- package/src/admin/components/notifications/AdminNotifications.tsx +0 -204
- package/src/admin/components/users/AdminUserAudits.tsx +0 -184
- package/src/admin/components/users/AdminUserCreate.tsx +0 -85
- package/src/admin/components/users/AdminUserDetails.tsx +0 -431
- package/src/admin/components/users/AdminUserSettings.tsx +0 -171
- package/src/core/components/data/ErrorViewer.tsx +0 -171
- package/src/json/extensions/DialogService.tsx +0 -31
- package/src/json/index.ts +0 -18
- package/src/json/styles.css +0 -1
- /package/dist/{demo → auth}/IconGoogle-Ch1m3Uzl.js +0 -0
- /package/dist/{demo → auth}/IconGoogle-Ch1m3Uzl.js.map +0 -0
- /package/src/{json → core/json}/components/JsonViewer.css +0 -0
- /package/src/{json → core/json}/components/JsonViewer.tsx +0 -0
- /package/src/core/{components/table → table/components}/DataTablePagination.tsx +0 -0
- /package/src/core/{components/table → table/components}/useTableSelection.ts +0 -0
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { c as Text, p as Flex } from "./core-RCUw1Q-a.js";
|
|
2
|
+
import { t as Showcase } from "./Showcase-Dq3MISpd.js";
|
|
3
|
+
import { t } from "alepha";
|
|
4
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
5
|
+
|
|
6
|
+
//#region ../../src/demo/components/core/DemoText.tsx
|
|
7
|
+
const showcaseSchema = t.object({
|
|
8
|
+
bold: t.boolean({
|
|
9
|
+
title: "bold",
|
|
10
|
+
default: false,
|
|
11
|
+
$control: { switch: true }
|
|
12
|
+
}),
|
|
13
|
+
italic: t.boolean({
|
|
14
|
+
title: "italic",
|
|
15
|
+
default: false,
|
|
16
|
+
$control: { switch: true }
|
|
17
|
+
}),
|
|
18
|
+
light: t.boolean({
|
|
19
|
+
title: "light",
|
|
20
|
+
default: false,
|
|
21
|
+
$control: { switch: true }
|
|
22
|
+
}),
|
|
23
|
+
muted: t.boolean({
|
|
24
|
+
title: "muted",
|
|
25
|
+
default: false,
|
|
26
|
+
$control: { switch: true }
|
|
27
|
+
}),
|
|
28
|
+
small: t.boolean({
|
|
29
|
+
title: "small",
|
|
30
|
+
default: false,
|
|
31
|
+
$control: { switch: true }
|
|
32
|
+
}),
|
|
33
|
+
monospace: t.boolean({
|
|
34
|
+
title: "monospace",
|
|
35
|
+
default: false,
|
|
36
|
+
$control: { switch: true }
|
|
37
|
+
}),
|
|
38
|
+
uppercase: t.boolean({
|
|
39
|
+
title: "uppercase",
|
|
40
|
+
default: false,
|
|
41
|
+
$control: { switch: true }
|
|
42
|
+
}),
|
|
43
|
+
capitalize: t.boolean({
|
|
44
|
+
title: "capitalize",
|
|
45
|
+
default: false,
|
|
46
|
+
$control: { switch: true }
|
|
47
|
+
}),
|
|
48
|
+
center: t.boolean({
|
|
49
|
+
title: "center",
|
|
50
|
+
default: false,
|
|
51
|
+
$control: { switch: true }
|
|
52
|
+
}),
|
|
53
|
+
intent: t.optional(t.enum([
|
|
54
|
+
"primary",
|
|
55
|
+
"info",
|
|
56
|
+
"success",
|
|
57
|
+
"warning",
|
|
58
|
+
"danger"
|
|
59
|
+
], { title: "intent" }))
|
|
60
|
+
});
|
|
61
|
+
const DemoText = () => {
|
|
62
|
+
return /* @__PURE__ */ jsx(Showcase, {
|
|
63
|
+
title: "Text",
|
|
64
|
+
schema: showcaseSchema,
|
|
65
|
+
initialValues: {
|
|
66
|
+
bold: false,
|
|
67
|
+
italic: false,
|
|
68
|
+
light: false,
|
|
69
|
+
muted: false,
|
|
70
|
+
small: false,
|
|
71
|
+
monospace: false,
|
|
72
|
+
uppercase: false,
|
|
73
|
+
capitalize: false,
|
|
74
|
+
center: false,
|
|
75
|
+
intent: void 0
|
|
76
|
+
},
|
|
77
|
+
columns: 2,
|
|
78
|
+
children: (props) => /* @__PURE__ */ jsxs(Flex, {
|
|
79
|
+
col: true,
|
|
80
|
+
gap: "lg",
|
|
81
|
+
p: "md",
|
|
82
|
+
style: { minWidth: 300 },
|
|
83
|
+
children: [
|
|
84
|
+
/* @__PURE__ */ jsx(Text, {
|
|
85
|
+
bold: props.bold,
|
|
86
|
+
italic: props.italic,
|
|
87
|
+
light: props.light,
|
|
88
|
+
muted: props.muted,
|
|
89
|
+
small: props.small,
|
|
90
|
+
monospace: props.monospace,
|
|
91
|
+
uppercase: props.uppercase,
|
|
92
|
+
capitalize: props.capitalize,
|
|
93
|
+
center: props.center,
|
|
94
|
+
intent: props.intent || void 0,
|
|
95
|
+
children: "The quick brown fox jumps over the lazy dog."
|
|
96
|
+
}),
|
|
97
|
+
/* @__PURE__ */ jsx(Text, {
|
|
98
|
+
muted: true,
|
|
99
|
+
small: true,
|
|
100
|
+
children: "Muted small text for secondary information."
|
|
101
|
+
}),
|
|
102
|
+
/* @__PURE__ */ jsx(Text, {
|
|
103
|
+
bold: true,
|
|
104
|
+
intent: "danger",
|
|
105
|
+
children: "Bold danger text for errors."
|
|
106
|
+
}),
|
|
107
|
+
/* @__PURE__ */ jsx(Text, {
|
|
108
|
+
monospace: true,
|
|
109
|
+
children: "console.log(\"monospace text\");"
|
|
110
|
+
}),
|
|
111
|
+
/* @__PURE__ */ jsx(Text, {
|
|
112
|
+
bold: true,
|
|
113
|
+
uppercase: true,
|
|
114
|
+
muted: true,
|
|
115
|
+
children: "Section header style"
|
|
116
|
+
})
|
|
117
|
+
]
|
|
118
|
+
})
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
//#endregion
|
|
123
|
+
export { DemoText as default };
|
|
124
|
+
//# sourceMappingURL=DemoText-CzXuUn3g.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DemoText-CzXuUn3g.js","names":[],"sources":["../../src/demo/components/core/DemoText.tsx"],"sourcesContent":["import type { AlephaIntent } from \"@alepha/ui\";\nimport { Flex, Text } from \"@alepha/ui\";\nimport { t } from \"alepha\";\nimport Showcase from \"../shared/Showcase.tsx\";\n\nconst showcaseSchema = t.object({\n bold: t.boolean({\n title: \"bold\",\n default: false,\n $control: { switch: true },\n }),\n italic: t.boolean({\n title: \"italic\",\n default: false,\n $control: { switch: true },\n }),\n light: t.boolean({\n title: \"light\",\n default: false,\n $control: { switch: true },\n }),\n muted: t.boolean({\n title: \"muted\",\n default: false,\n $control: { switch: true },\n }),\n small: t.boolean({\n title: \"small\",\n default: false,\n $control: { switch: true },\n }),\n monospace: t.boolean({\n title: \"monospace\",\n default: false,\n $control: { switch: true },\n }),\n uppercase: t.boolean({\n title: \"uppercase\",\n default: false,\n $control: { switch: true },\n }),\n capitalize: t.boolean({\n title: \"capitalize\",\n default: false,\n $control: { switch: true },\n }),\n center: t.boolean({\n title: \"center\",\n default: false,\n $control: { switch: true },\n }),\n intent: t.optional(\n t.enum([\"primary\", \"info\", \"success\", \"warning\", \"danger\"], {\n title: \"intent\",\n }),\n ),\n});\n\nconst DemoText = () => {\n return (\n <Showcase\n title=\"Text\"\n schema={showcaseSchema}\n initialValues={{\n bold: false,\n italic: false,\n light: false,\n muted: false,\n small: false,\n monospace: false,\n uppercase: false,\n capitalize: false,\n center: false,\n intent: undefined,\n }}\n columns={2}\n >\n {(props) => (\n <Flex col gap=\"lg\" p=\"md\" style={{ minWidth: 300 }}>\n <Text\n bold={props.bold}\n italic={props.italic}\n light={props.light}\n muted={props.muted}\n small={props.small}\n monospace={props.monospace}\n uppercase={props.uppercase}\n capitalize={props.capitalize}\n center={props.center}\n intent={(props.intent || undefined) as AlephaIntent | undefined}\n >\n The quick brown fox jumps over the lazy dog.\n </Text>\n <Text muted small>\n Muted small text for secondary information.\n </Text>\n <Text bold intent=\"danger\">\n Bold danger text for errors.\n </Text>\n <Text monospace>console.log(\"monospace text\");</Text>\n <Text bold uppercase muted>\n Section header style\n </Text>\n </Flex>\n )}\n </Showcase>\n );\n};\n\nexport default DemoText;\n"],"mappings":";;;;;;AAKA,MAAM,iBAAiB,EAAE,OAAO;CAC9B,MAAM,EAAE,QAAQ;EACd,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,QAAQ,EAAE,QAAQ;EAChB,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,OAAO,EAAE,QAAQ;EACf,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,OAAO,EAAE,QAAQ;EACf,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,OAAO,EAAE,QAAQ;EACf,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,WAAW,EAAE,QAAQ;EACnB,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,WAAW,EAAE,QAAQ;EACnB,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,YAAY,EAAE,QAAQ;EACpB,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,QAAQ,EAAE,QAAQ;EAChB,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,QAAQ,EAAE,SACR,EAAE,KAAK;EAAC;EAAW;EAAQ;EAAW;EAAW;EAAS,EAAE,EAC1D,OAAO,UACR,CAAC,CACH;CACF,CAAC;AAEF,MAAM,iBAAiB;AACrB,QACE,oBAAC;EACC,OAAM;EACN,QAAQ;EACR,eAAe;GACb,MAAM;GACN,QAAQ;GACR,OAAO;GACP,OAAO;GACP,OAAO;GACP,WAAW;GACX,WAAW;GACX,YAAY;GACZ,QAAQ;GACR,QAAQ;GACT;EACD,SAAS;aAEP,UACA,qBAAC;GAAK;GAAI,KAAI;GAAK,GAAE;GAAK,OAAO,EAAE,UAAU,KAAK;;IAChD,oBAAC;KACC,MAAM,MAAM;KACZ,QAAQ,MAAM;KACd,OAAO,MAAM;KACb,OAAO,MAAM;KACb,OAAO,MAAM;KACb,WAAW,MAAM;KACjB,WAAW,MAAM;KACjB,YAAY,MAAM;KAClB,QAAQ,MAAM;KACd,QAAS,MAAM,UAAU;eAC1B;MAEM;IACP,oBAAC;KAAK;KAAM;eAAM;MAEX;IACP,oBAAC;KAAK;KAAK,QAAO;eAAS;MAEpB;IACP,oBAAC;KAAK;eAAU;MAAqC;IACrD,oBAAC;KAAK;KAAK;KAAU;eAAM;MAEpB;;IACF;GAEA"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { c as Text, h as ActionButton, p as Flex, v as useToast } from "./core-RCUw1Q-a.js";
|
|
2
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
3
|
+
import { IconCheck, IconExclamationMark, IconInfoCircle, IconX } from "@tabler/icons-react";
|
|
4
|
+
|
|
5
|
+
//#region ../../src/demo/components/layout/DemoToast.tsx
|
|
6
|
+
const DemoToast = () => {
|
|
7
|
+
const toast = useToast();
|
|
8
|
+
return /* @__PURE__ */ jsxs(Flex, {
|
|
9
|
+
col: true,
|
|
10
|
+
gap: "xl",
|
|
11
|
+
p: "xl",
|
|
12
|
+
children: [
|
|
13
|
+
/* @__PURE__ */ jsx(Text, {
|
|
14
|
+
bold: true,
|
|
15
|
+
size: "lg",
|
|
16
|
+
children: "Toast Service"
|
|
17
|
+
}),
|
|
18
|
+
/* @__PURE__ */ jsx(Text, {
|
|
19
|
+
muted: true,
|
|
20
|
+
small: true,
|
|
21
|
+
children: "Notification toasts via the ToastService. Fire-and-forget notifications for user feedback."
|
|
22
|
+
}),
|
|
23
|
+
/* @__PURE__ */ jsxs(Flex, {
|
|
24
|
+
gap: "md",
|
|
25
|
+
wrap: "wrap",
|
|
26
|
+
children: [
|
|
27
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
28
|
+
icon: IconCheck,
|
|
29
|
+
variant: "light",
|
|
30
|
+
intent: "success",
|
|
31
|
+
onClick: () => toast.success("Operation completed successfully."),
|
|
32
|
+
children: "Success"
|
|
33
|
+
}),
|
|
34
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
35
|
+
icon: IconX,
|
|
36
|
+
variant: "light",
|
|
37
|
+
intent: "danger",
|
|
38
|
+
onClick: () => toast.danger("Something went wrong."),
|
|
39
|
+
children: "Error"
|
|
40
|
+
}),
|
|
41
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
42
|
+
icon: IconExclamationMark,
|
|
43
|
+
variant: "light",
|
|
44
|
+
intent: "warning",
|
|
45
|
+
onClick: () => toast.warning("Please check your input."),
|
|
46
|
+
children: "Warning"
|
|
47
|
+
}),
|
|
48
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
49
|
+
icon: IconInfoCircle,
|
|
50
|
+
variant: "light",
|
|
51
|
+
intent: "info",
|
|
52
|
+
onClick: () => toast.info("Here is some useful information."),
|
|
53
|
+
children: "Info"
|
|
54
|
+
})
|
|
55
|
+
]
|
|
56
|
+
}),
|
|
57
|
+
/* @__PURE__ */ jsxs(Flex, {
|
|
58
|
+
col: true,
|
|
59
|
+
gap: "md",
|
|
60
|
+
children: [/* @__PURE__ */ jsx(Text, {
|
|
61
|
+
bold: true,
|
|
62
|
+
small: true,
|
|
63
|
+
uppercase: true,
|
|
64
|
+
muted: true,
|
|
65
|
+
children: "With Title"
|
|
66
|
+
}), /* @__PURE__ */ jsxs(Flex, {
|
|
67
|
+
gap: "md",
|
|
68
|
+
wrap: "wrap",
|
|
69
|
+
children: [/* @__PURE__ */ jsx(ActionButton, {
|
|
70
|
+
variant: "light",
|
|
71
|
+
intent: "success",
|
|
72
|
+
onClick: () => toast.success({
|
|
73
|
+
message: "Your changes have been saved.",
|
|
74
|
+
title: "Saved"
|
|
75
|
+
}),
|
|
76
|
+
children: "With Title"
|
|
77
|
+
}), /* @__PURE__ */ jsx(ActionButton, {
|
|
78
|
+
variant: "light",
|
|
79
|
+
intent: "danger",
|
|
80
|
+
onClick: () => toast.danger({
|
|
81
|
+
message: "Failed to connect to the server.",
|
|
82
|
+
title: "Connection Error",
|
|
83
|
+
autoClose: false
|
|
84
|
+
}),
|
|
85
|
+
children: "Persistent"
|
|
86
|
+
})]
|
|
87
|
+
})]
|
|
88
|
+
})
|
|
89
|
+
]
|
|
90
|
+
});
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
//#endregion
|
|
94
|
+
export { DemoToast as default };
|
|
95
|
+
//# sourceMappingURL=DemoToast-BgHDhWrX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DemoToast-BgHDhWrX.js","names":[],"sources":["../../src/demo/components/layout/DemoToast.tsx"],"sourcesContent":["import { ActionButton, Flex, Text, useToast } from \"@alepha/ui\";\nimport {\n IconCheck,\n IconExclamationMark,\n IconInfoCircle,\n IconX,\n} from \"@tabler/icons-react\";\n\nconst DemoToast = () => {\n const toast = useToast();\n\n return (\n <Flex col gap=\"xl\" p=\"xl\">\n <Text bold size=\"lg\">\n Toast Service\n </Text>\n <Text muted small>\n Notification toasts via the ToastService. Fire-and-forget notifications\n for user feedback.\n </Text>\n\n <Flex gap=\"md\" wrap=\"wrap\">\n <ActionButton\n icon={IconCheck}\n variant=\"light\"\n intent=\"success\"\n onClick={() => toast.success(\"Operation completed successfully.\")}\n >\n Success\n </ActionButton>\n\n <ActionButton\n icon={IconX}\n variant=\"light\"\n intent=\"danger\"\n onClick={() => toast.danger(\"Something went wrong.\")}\n >\n Error\n </ActionButton>\n\n <ActionButton\n icon={IconExclamationMark}\n variant=\"light\"\n intent=\"warning\"\n onClick={() => toast.warning(\"Please check your input.\")}\n >\n Warning\n </ActionButton>\n\n <ActionButton\n icon={IconInfoCircle}\n variant=\"light\"\n intent=\"info\"\n onClick={() => toast.info(\"Here is some useful information.\")}\n >\n Info\n </ActionButton>\n </Flex>\n\n <Flex col gap=\"md\">\n <Text bold small uppercase muted>\n With Title\n </Text>\n <Flex gap=\"md\" wrap=\"wrap\">\n <ActionButton\n variant=\"light\"\n intent=\"success\"\n onClick={() =>\n toast.success({\n message: \"Your changes have been saved.\",\n title: \"Saved\",\n })\n }\n >\n With Title\n </ActionButton>\n <ActionButton\n variant=\"light\"\n intent=\"danger\"\n onClick={() =>\n toast.danger({\n message: \"Failed to connect to the server.\",\n title: \"Connection Error\",\n autoClose: false,\n })\n }\n >\n Persistent\n </ActionButton>\n </Flex>\n </Flex>\n </Flex>\n );\n};\n\nexport default DemoToast;\n"],"mappings":";;;;;AAQA,MAAM,kBAAkB;CACtB,MAAM,QAAQ,UAAU;AAExB,QACE,qBAAC;EAAK;EAAI,KAAI;EAAK,GAAE;;GACnB,oBAAC;IAAK;IAAK,MAAK;cAAK;KAEd;GACP,oBAAC;IAAK;IAAM;cAAM;KAGX;GAEP,qBAAC;IAAK,KAAI;IAAK,MAAK;;KAClB,oBAAC;MACC,MAAM;MACN,SAAQ;MACR,QAAO;MACP,eAAe,MAAM,QAAQ,oCAAoC;gBAClE;OAEc;KAEf,oBAAC;MACC,MAAM;MACN,SAAQ;MACR,QAAO;MACP,eAAe,MAAM,OAAO,wBAAwB;gBACrD;OAEc;KAEf,oBAAC;MACC,MAAM;MACN,SAAQ;MACR,QAAO;MACP,eAAe,MAAM,QAAQ,2BAA2B;gBACzD;OAEc;KAEf,oBAAC;MACC,MAAM;MACN,SAAQ;MACR,QAAO;MACP,eAAe,MAAM,KAAK,mCAAmC;gBAC9D;OAEc;;KACV;GAEP,qBAAC;IAAK;IAAI,KAAI;eACZ,oBAAC;KAAK;KAAK;KAAM;KAAU;eAAM;MAE1B,EACP,qBAAC;KAAK,KAAI;KAAK,MAAK;gBAClB,oBAAC;MACC,SAAQ;MACR,QAAO;MACP,eACE,MAAM,QAAQ;OACZ,SAAS;OACT,OAAO;OACR,CAAC;gBAEL;OAEc,EACf,oBAAC;MACC,SAAQ;MACR,QAAO;MACP,eACE,MAAM,OAAO;OACX,SAAS;OACT,OAAO;OACP,WAAW;OACZ,CAAC;gBAEL;OAEc;MACV;KACF;;GACF"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { o as TypeForm } from "./core-RCUw1Q-a.js";
|
|
2
|
+
import { t as Showcase } from "./Showcase-Dq3MISpd.js";
|
|
3
3
|
import { t } from "alepha";
|
|
4
|
-
import { jsx } from "react/jsx-runtime";
|
|
5
4
|
import { useForm } from "alepha/react/form";
|
|
5
|
+
import { jsx } from "react/jsx-runtime";
|
|
6
6
|
|
|
7
7
|
//#region ../../src/demo/components/core/DemoTypeForm.tsx
|
|
8
8
|
const formSchema = t.object({
|
|
@@ -79,4 +79,4 @@ const DemoTypeForm = () => {
|
|
|
79
79
|
|
|
80
80
|
//#endregion
|
|
81
81
|
export { DemoTypeForm as default };
|
|
82
|
-
//# sourceMappingURL=DemoTypeForm-
|
|
82
|
+
//# sourceMappingURL=DemoTypeForm-DDzWoMSV.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DemoTypeForm-
|
|
1
|
+
{"version":3,"file":"DemoTypeForm-DDzWoMSV.js","names":[],"sources":["../../src/demo/components/core/DemoTypeForm.tsx"],"sourcesContent":["import { TypeForm } from \"@alepha/ui\";\nimport { t } from \"alepha\";\nimport { useForm } from \"alepha/react/form\";\nimport Showcase from \"../shared/Showcase.tsx\";\n\nconst formSchema = t.object({\n username: t.text({ title: \"Username\", default: \"\" }),\n email: t.email({ title: \"Email\", default: \"\" }),\n age: t.integer({ title: \"Age\", minimum: 0, maximum: 120 }),\n role: t.enum([\"admin\", \"user\", \"guest\"], { title: \"Role\", default: \"user\" }),\n subscribe: t.boolean({ title: \"Subscribe\", default: false }),\n});\n\nconst showcaseSchema = t.object({\n columns: t.integer({\n title: \"Columns\",\n default: 1,\n minimum: 1,\n maximum: 4,\n $control: { slider: true },\n }),\n fill: t.boolean({\n title: \"Fill Width\",\n default: false,\n $control: { switch: true },\n }),\n skipSubmitButton: t.boolean({\n title: \"Hide Submit\",\n default: false,\n $control: { switch: true },\n }),\n});\n\nconst DemoTypeForm = () => {\n const form = useForm(\n {\n schema: formSchema,\n handler: (values) => {\n alert(JSON.stringify(values, null, 2));\n },\n },\n [],\n );\n\n return (\n <Showcase\n title=\"TypeForm\"\n schema={showcaseSchema}\n initialValues={{\n columns: 1,\n fill: false,\n skipSubmitButton: false,\n }}\n columns={1}\n >\n {(props) => (\n <TypeForm\n form={form}\n columns={props.columns}\n fill={props.fill}\n skipSubmitButton={props.skipSubmitButton}\n submitButtonProps={{ children: \"Submit\" }}\n />\n )}\n </Showcase>\n );\n};\n\nexport default DemoTypeForm;\n"],"mappings":";;;;;;;AAKA,MAAM,aAAa,EAAE,OAAO;CAC1B,UAAU,EAAE,KAAK;EAAE,OAAO;EAAY,SAAS;EAAI,CAAC;CACpD,OAAO,EAAE,MAAM;EAAE,OAAO;EAAS,SAAS;EAAI,CAAC;CAC/C,KAAK,EAAE,QAAQ;EAAE,OAAO;EAAO,SAAS;EAAG,SAAS;EAAK,CAAC;CAC1D,MAAM,EAAE,KAAK;EAAC;EAAS;EAAQ;EAAQ,EAAE;EAAE,OAAO;EAAQ,SAAS;EAAQ,CAAC;CAC5E,WAAW,EAAE,QAAQ;EAAE,OAAO;EAAa,SAAS;EAAO,CAAC;CAC7D,CAAC;AAEF,MAAM,iBAAiB,EAAE,OAAO;CAC9B,SAAS,EAAE,QAAQ;EACjB,OAAO;EACP,SAAS;EACT,SAAS;EACT,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,MAAM,EAAE,QAAQ;EACd,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACF,kBAAkB,EAAE,QAAQ;EAC1B,OAAO;EACP,SAAS;EACT,UAAU,EAAE,QAAQ,MAAM;EAC3B,CAAC;CACH,CAAC;AAEF,MAAM,qBAAqB;CACzB,MAAM,OAAO,QACX;EACE,QAAQ;EACR,UAAU,WAAW;AACnB,SAAM,KAAK,UAAU,QAAQ,MAAM,EAAE,CAAC;;EAEzC,EACD,EAAE,CACH;AAED,QACE,oBAAC;EACC,OAAM;EACN,QAAQ;EACR,eAAe;GACb,SAAS;GACT,MAAM;GACN,kBAAkB;GACnB;EACD,SAAS;aAEP,UACA,oBAAC;GACO;GACN,SAAS,MAAM;GACf,MAAM,MAAM;GACZ,kBAAkB,MAAM;GACxB,mBAAmB,EAAE,UAAU,UAAU;IACzC;GAEK"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import "./core-RCUw1Q-a.js";
|
|
2
|
+
import "./IconGoogle-CSQLPYwX.js";
|
|
3
|
+
import "./Login-hSOU3jZc.js";
|
|
4
|
+
import "./Register-a70LPgs2.js";
|
|
5
|
+
import "./ResetPassword-DWN0lzr5.js";
|
|
6
|
+
import { t as VerifyEmail } from "./VerifyEmail-DZWL72K4.js";
|
|
7
|
+
import "./auth-d6n3xbug.js";
|
|
8
|
+
import { t as Showcase } from "./Showcase-Dq3MISpd.js";
|
|
9
|
+
import { t } from "alepha";
|
|
10
|
+
import { jsx } from "react/jsx-runtime";
|
|
11
|
+
|
|
12
|
+
//#region ../../src/demo/components/auth/DemoVerifyEmail.tsx
|
|
13
|
+
const showcaseSchema = t.object({ placeholder: t.boolean({
|
|
14
|
+
title: "Demo Mode",
|
|
15
|
+
default: true,
|
|
16
|
+
$control: { switch: true }
|
|
17
|
+
}) });
|
|
18
|
+
const DemoVerifyEmail = () => {
|
|
19
|
+
return /* @__PURE__ */ jsx(Showcase, {
|
|
20
|
+
title: "VerifyEmail",
|
|
21
|
+
schema: showcaseSchema,
|
|
22
|
+
initialValues: { placeholder: true },
|
|
23
|
+
columns: 1,
|
|
24
|
+
children: () => /* @__PURE__ */ jsx(VerifyEmail, {})
|
|
25
|
+
});
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
//#endregion
|
|
29
|
+
export { DemoVerifyEmail as default };
|
|
30
|
+
//# sourceMappingURL=DemoVerifyEmail-C_Irdnov.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DemoVerifyEmail-C_Irdnov.js","names":[],"sources":["../../src/demo/components/auth/DemoVerifyEmail.tsx"],"sourcesContent":["import { VerifyEmail } from \"@alepha/ui/auth\";\nimport { t } from \"alepha\";\nimport Showcase from \"../shared/Showcase.tsx\";\n\nconst showcaseSchema = t.object({\n placeholder: t.boolean({\n title: \"Demo Mode\",\n default: true,\n $control: { switch: true },\n }),\n});\n\nconst DemoVerifyEmail = () => {\n return (\n <Showcase\n title=\"VerifyEmail\"\n schema={showcaseSchema}\n initialValues={{\n placeholder: true,\n }}\n columns={1}\n >\n {() => <VerifyEmail />}\n </Showcase>\n );\n};\n\nexport default DemoVerifyEmail;\n"],"mappings":";;;;;;;;;;;;AAIA,MAAM,iBAAiB,EAAE,OAAO,EAC9B,aAAa,EAAE,QAAQ;CACrB,OAAO;CACP,SAAS;CACT,UAAU,EAAE,QAAQ,MAAM;CAC3B,CAAC,EACH,CAAC;AAEF,MAAM,wBAAwB;AAC5B,QACE,oBAAC;EACC,OAAM;EACN,QAAQ;EACR,eAAe,EACb,aAAa,MACd;EACD,SAAS;kBAEF,oBAAC,gBAAc;GACb"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
|
|
3
|
+
//#region ../../src/auth/components/icons/IconGithub.tsx
|
|
4
|
+
const IconGithub = () => {
|
|
5
|
+
return /* @__PURE__ */ jsx("svg", {
|
|
6
|
+
width: "24",
|
|
7
|
+
height: "24",
|
|
8
|
+
viewBox: "0 0 1024 1024",
|
|
9
|
+
fill: "none",
|
|
10
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
11
|
+
children: /* @__PURE__ */ jsx("path", {
|
|
12
|
+
fillRule: "evenodd",
|
|
13
|
+
clipRule: "evenodd",
|
|
14
|
+
d: "M8 0C3.58 0 0 3.58 0 8C0 11.54 2.29 14.53 5.47 15.59C5.87 15.66 6.02 15.42 6.02 15.21C6.02 15.02 6.01 14.39 6.01 13.72C4 14.09 3.48 13.23 3.32 12.78C3.23 12.55 2.84 11.84 2.5 11.65C2.22 11.5 1.82 11.13 2.49 11.12C3.12 11.11 3.57 11.7 3.72 11.94C4.44 13.15 5.59 12.81 6.05 12.6C6.12 12.08 6.33 11.73 6.56 11.53C4.78 11.33 2.92 10.64 2.92 7.58C2.92 6.71 3.23 5.99 3.74 5.43C3.66 5.23 3.38 4.41 3.82 3.31C3.82 3.31 4.49 3.1 6.02 4.13C6.66 3.95 7.34 3.86 8.02 3.86C8.7 3.86 9.38 3.95 10.02 4.13C11.55 3.09 12.22 3.31 12.22 3.31C12.66 4.41 12.38 5.23 12.3 5.43C12.81 5.99 13.12 6.7 13.12 7.58C13.12 10.65 11.25 11.33 9.47 11.53C9.76 11.78 10.01 12.26 10.01 13.01C10.01 14.08 10 14.94 10 15.21C10 15.42 10.15 15.67 10.55 15.59C13.71 14.53 16 11.53 16 8C16 3.58 12.42 0 8 0Z",
|
|
15
|
+
transform: "scale(64)",
|
|
16
|
+
fill: "var(--alepha-text)"
|
|
17
|
+
})
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
//#endregion
|
|
22
|
+
//#region ../../src/auth/components/icons/IconGoogle.tsx
|
|
23
|
+
const IconGoogle = () => {
|
|
24
|
+
return /* @__PURE__ */ jsxs("svg", {
|
|
25
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
26
|
+
height: "24",
|
|
27
|
+
viewBox: "0 0 24 24",
|
|
28
|
+
width: "24",
|
|
29
|
+
children: [
|
|
30
|
+
/* @__PURE__ */ jsx("path", {
|
|
31
|
+
d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z",
|
|
32
|
+
fill: "#4285F4"
|
|
33
|
+
}),
|
|
34
|
+
/* @__PURE__ */ jsx("path", {
|
|
35
|
+
d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z",
|
|
36
|
+
fill: "#34A853"
|
|
37
|
+
}),
|
|
38
|
+
/* @__PURE__ */ jsx("path", {
|
|
39
|
+
d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z",
|
|
40
|
+
fill: "#FBBC05"
|
|
41
|
+
}),
|
|
42
|
+
/* @__PURE__ */ jsx("path", {
|
|
43
|
+
d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z",
|
|
44
|
+
fill: "#EA4335"
|
|
45
|
+
}),
|
|
46
|
+
/* @__PURE__ */ jsx("path", {
|
|
47
|
+
d: "M1 1h22v22H1z",
|
|
48
|
+
fill: "none"
|
|
49
|
+
})
|
|
50
|
+
]
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
//#endregion
|
|
55
|
+
export { IconGithub as n, IconGoogle as t };
|
|
56
|
+
//# sourceMappingURL=IconGoogle-CSQLPYwX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"IconGoogle-CSQLPYwX.js","names":[],"sources":["../../src/auth/components/icons/IconGithub.tsx","../../src/auth/components/icons/IconGoogle.tsx"],"sourcesContent":["const IconGithub = () => {\n return (\n <svg\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 1024 1024\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M8 0C3.58 0 0 3.58 0 8C0 11.54 2.29 14.53 5.47 15.59C5.87 15.66 6.02 15.42 6.02 15.21C6.02 15.02 6.01 14.39 6.01 13.72C4 14.09 3.48 13.23 3.32 12.78C3.23 12.55 2.84 11.84 2.5 11.65C2.22 11.5 1.82 11.13 2.49 11.12C3.12 11.11 3.57 11.7 3.72 11.94C4.44 13.15 5.59 12.81 6.05 12.6C6.12 12.08 6.33 11.73 6.56 11.53C4.78 11.33 2.92 10.64 2.92 7.58C2.92 6.71 3.23 5.99 3.74 5.43C3.66 5.23 3.38 4.41 3.82 3.31C3.82 3.31 4.49 3.1 6.02 4.13C6.66 3.95 7.34 3.86 8.02 3.86C8.7 3.86 9.38 3.95 10.02 4.13C11.55 3.09 12.22 3.31 12.22 3.31C12.66 4.41 12.38 5.23 12.3 5.43C12.81 5.99 13.12 6.7 13.12 7.58C13.12 10.65 11.25 11.33 9.47 11.53C9.76 11.78 10.01 12.26 10.01 13.01C10.01 14.08 10 14.94 10 15.21C10 15.42 10.15 15.67 10.55 15.59C13.71 14.53 16 11.53 16 8C16 3.58 12.42 0 8 0Z\"\n transform=\"scale(64)\"\n fill={\"var(--alepha-text)\"}\n />\n </svg>\n );\n};\n\nexport default IconGithub;\n","const IconGoogle = () => {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n width=\"24\"\n >\n <path\n d=\"M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z\"\n fill=\"#4285F4\"\n />\n <path\n d=\"M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z\"\n fill=\"#34A853\"\n />\n <path\n d=\"M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z\"\n fill=\"#FBBC05\"\n />\n <path\n d=\"M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z\"\n fill=\"#EA4335\"\n />\n <path d=\"M1 1h22v22H1z\" fill=\"none\" />\n </svg>\n );\n};\n\nexport default IconGoogle;\n"],"mappings":";;;AAAA,MAAM,mBAAmB;AACvB,QACE,oBAAC;EACC,OAAM;EACN,QAAO;EACP,SAAQ;EACR,MAAK;EACL,OAAM;YAEN,oBAAC;GACC,UAAS;GACT,UAAS;GACT,GAAE;GACF,WAAU;GACV,MAAM;IACN;GACE;;;;;AChBV,MAAM,mBAAmB;AACvB,QACE,qBAAC;EACC,OAAM;EACN,QAAO;EACP,SAAQ;EACR,OAAM;;GAEN,oBAAC;IACC,GAAE;IACF,MAAK;KACL;GACF,oBAAC;IACC,GAAE;IACF,MAAK;KACL;GACF,oBAAC;IACC,GAAE;IACF,MAAK;KACL;GACF,oBAAC;IACC,GAAE;IACF,MAAK;KACL;GACF,oBAAC;IAAK,GAAE;IAAgB,MAAK;KAAS;;GAClC"}
|
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import { t as __exportAll } from "./rolldown-runtime-CjeV3_4I.js";
|
|
2
|
+
import { h as ActionButton, n as capitalize, s as Control } from "./core-RCUw1Q-a.js";
|
|
3
|
+
import { n as IconGithub, t as IconGoogle } from "./IconGoogle-CSQLPYwX.js";
|
|
4
|
+
import { AlephaError, t } from "alepha";
|
|
5
|
+
import { FormValidationError, useForm } from "alepha/react/form";
|
|
6
|
+
import { useI18n } from "alepha/react/i18n";
|
|
7
|
+
import { Card, Flex, Image, Text, Title } from "@mantine/core";
|
|
8
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
9
|
+
import { useMemo } from "react";
|
|
10
|
+
import { IconLock, IconUser } from "@tabler/icons-react";
|
|
11
|
+
import { useRouter } from "alepha/react/router";
|
|
12
|
+
import { useAuth } from "alepha/react/auth";
|
|
13
|
+
import { HttpError } from "alepha/server";
|
|
14
|
+
|
|
15
|
+
//#region ../../src/auth/components/Login.tsx
|
|
16
|
+
var Login_exports = /* @__PURE__ */ __exportAll({ default: () => Login });
|
|
17
|
+
const Login = (props) => {
|
|
18
|
+
const auth = useAuth();
|
|
19
|
+
const router = useRouter();
|
|
20
|
+
const { tr } = useI18n();
|
|
21
|
+
const redirect = router.query.r || "/";
|
|
22
|
+
const credentialsProvider = props.realmConfig.authenticationMethods.find((it) => it.type === "CREDENTIALS");
|
|
23
|
+
const settings = props.realmConfig.settings;
|
|
24
|
+
const loginMethods = useMemo(() => {
|
|
25
|
+
const methods = [];
|
|
26
|
+
if (settings.usernameEnabled !== false) methods.push("username");
|
|
27
|
+
if (settings.emailEnabled !== false) methods.push("email");
|
|
28
|
+
if (settings.phoneEnabled === true) methods.push("phone");
|
|
29
|
+
return methods;
|
|
30
|
+
}, [settings]);
|
|
31
|
+
const identifierTitle = useMemo(() => {
|
|
32
|
+
if (loginMethods.length === 0) return tr("loginUsername");
|
|
33
|
+
if (loginMethods.length === 1) {
|
|
34
|
+
if (loginMethods[0] === "username") return tr("loginUsername");
|
|
35
|
+
if (loginMethods[0] === "email") return tr("loginEmail");
|
|
36
|
+
if (loginMethods[0] === "phone") return tr("loginPhone");
|
|
37
|
+
}
|
|
38
|
+
const labels = loginMethods.map((m) => {
|
|
39
|
+
if (m === "username") return tr("loginUsername").toLowerCase();
|
|
40
|
+
if (m === "email") return tr("loginEmail").toLowerCase();
|
|
41
|
+
if (m === "phone") return tr("loginPhone").toLowerCase();
|
|
42
|
+
return m;
|
|
43
|
+
});
|
|
44
|
+
return capitalize(`${labels.slice(0, -1).join(", ")} or ${labels[labels.length - 1]}`);
|
|
45
|
+
}, [loginMethods, tr]);
|
|
46
|
+
const form = useForm({
|
|
47
|
+
schema: t.object({
|
|
48
|
+
identifier: t.string({ minLength: 1 }),
|
|
49
|
+
password: t.string({ minLength: settings.passwordPolicy?.minLength || 6 })
|
|
50
|
+
}),
|
|
51
|
+
handler: async (data) => {
|
|
52
|
+
if (!credentialsProvider) throw new AlephaError("Credentials provider not configured");
|
|
53
|
+
try {
|
|
54
|
+
await auth.login(credentialsProvider.name, {
|
|
55
|
+
username: data.identifier,
|
|
56
|
+
password: data.password,
|
|
57
|
+
realm: props.realmConfig.realmName
|
|
58
|
+
});
|
|
59
|
+
await router.push(router.query.r || "/");
|
|
60
|
+
} catch (error) {
|
|
61
|
+
if (error instanceof HttpError && error.error === "InvalidCredentialsError") throw new FormValidationError({
|
|
62
|
+
message: "Invalid identifier or password",
|
|
63
|
+
path: "/password"
|
|
64
|
+
});
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
const getAutoCompleteType = () => {
|
|
70
|
+
if (loginMethods.includes("email")) return "email";
|
|
71
|
+
if (loginMethods.includes("username")) return "username";
|
|
72
|
+
if (loginMethods.includes("phone")) return "tel";
|
|
73
|
+
return "username";
|
|
74
|
+
};
|
|
75
|
+
const externalLoginMethods = props.realmConfig.authenticationMethods.filter((method) => method.type !== "CREDENTIALS");
|
|
76
|
+
const showOrDivider = credentialsProvider && externalLoginMethods.length > 0;
|
|
77
|
+
return /* @__PURE__ */ jsx(Flex, {
|
|
78
|
+
flex: 1,
|
|
79
|
+
justify: "center",
|
|
80
|
+
align: "center",
|
|
81
|
+
children: /* @__PURE__ */ jsxs(Flex, {
|
|
82
|
+
direction: "column",
|
|
83
|
+
gap: "sm",
|
|
84
|
+
w: 360,
|
|
85
|
+
children: [/* @__PURE__ */ jsx(Card, {
|
|
86
|
+
withBorder: true,
|
|
87
|
+
p: "lg",
|
|
88
|
+
bg: "var(--alepha-elevated)",
|
|
89
|
+
children: /* @__PURE__ */ jsxs(Flex, {
|
|
90
|
+
direction: "column",
|
|
91
|
+
gap: "md",
|
|
92
|
+
children: [
|
|
93
|
+
(settings.logoUrl || settings.displayName || settings.description) && /* @__PURE__ */ jsxs(Flex, {
|
|
94
|
+
direction: "column",
|
|
95
|
+
gap: "xs",
|
|
96
|
+
align: "center",
|
|
97
|
+
mb: "xs",
|
|
98
|
+
children: [
|
|
99
|
+
settings.logoUrl && /* @__PURE__ */ jsx(Image, {
|
|
100
|
+
src: settings.logoUrl,
|
|
101
|
+
alt: settings.displayName || props.realmConfig.realmName,
|
|
102
|
+
h: 48,
|
|
103
|
+
w: "auto",
|
|
104
|
+
fit: "contain"
|
|
105
|
+
}),
|
|
106
|
+
settings.displayName && /* @__PURE__ */ jsx(Title, {
|
|
107
|
+
order: 4,
|
|
108
|
+
ta: "center",
|
|
109
|
+
children: settings.displayName
|
|
110
|
+
}),
|
|
111
|
+
settings.description && /* @__PURE__ */ jsx(Text, {
|
|
112
|
+
size: "sm",
|
|
113
|
+
c: "dimmed",
|
|
114
|
+
ta: "center",
|
|
115
|
+
children: settings.description
|
|
116
|
+
})
|
|
117
|
+
]
|
|
118
|
+
}),
|
|
119
|
+
credentialsProvider && /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsx("form", {
|
|
120
|
+
...form.props,
|
|
121
|
+
children: /* @__PURE__ */ jsxs(Flex, {
|
|
122
|
+
direction: "column",
|
|
123
|
+
flex: 1,
|
|
124
|
+
gap: "md",
|
|
125
|
+
children: [
|
|
126
|
+
/* @__PURE__ */ jsx(Control, {
|
|
127
|
+
title: identifierTitle,
|
|
128
|
+
input: form.input.identifier,
|
|
129
|
+
icon: IconUser,
|
|
130
|
+
text: { autoComplete: getAutoCompleteType() }
|
|
131
|
+
}),
|
|
132
|
+
/* @__PURE__ */ jsx(Control, {
|
|
133
|
+
title: tr("loginPassword"),
|
|
134
|
+
input: form.input.password,
|
|
135
|
+
icon: IconLock,
|
|
136
|
+
password: { autoComplete: "current-password" }
|
|
137
|
+
}),
|
|
138
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
139
|
+
variant: "filled",
|
|
140
|
+
form,
|
|
141
|
+
children: tr("loginSignIn")
|
|
142
|
+
})
|
|
143
|
+
]
|
|
144
|
+
})
|
|
145
|
+
}), settings.resetPasswordAllowed && /* @__PURE__ */ jsx(Text, {
|
|
146
|
+
size: "sm",
|
|
147
|
+
ta: "center",
|
|
148
|
+
children: /* @__PURE__ */ jsx(ActionButton, {
|
|
149
|
+
href: router.path("resetPassword", { query: { realm: props.realmConfig.realmName } }),
|
|
150
|
+
anchorProps: { inherit: true },
|
|
151
|
+
children: tr("loginForgotPassword")
|
|
152
|
+
})
|
|
153
|
+
})] }),
|
|
154
|
+
showOrDivider && /* @__PURE__ */ jsxs(Flex, {
|
|
155
|
+
align: "center",
|
|
156
|
+
justify: "center",
|
|
157
|
+
gap: "md",
|
|
158
|
+
children: [
|
|
159
|
+
/* @__PURE__ */ jsx(Flex, {
|
|
160
|
+
flex: 1,
|
|
161
|
+
h: "1px",
|
|
162
|
+
bg: "var(--alepha-border)"
|
|
163
|
+
}),
|
|
164
|
+
/* @__PURE__ */ jsx(Text, {
|
|
165
|
+
size: "xs",
|
|
166
|
+
c: "dimmed",
|
|
167
|
+
children: tr("loginOr")
|
|
168
|
+
}),
|
|
169
|
+
/* @__PURE__ */ jsx(Flex, {
|
|
170
|
+
flex: 1,
|
|
171
|
+
h: "1px",
|
|
172
|
+
bg: "var(--alepha-border)"
|
|
173
|
+
})
|
|
174
|
+
]
|
|
175
|
+
}),
|
|
176
|
+
externalLoginMethods.length > 0 && /* @__PURE__ */ jsx(Flex, {
|
|
177
|
+
direction: "column",
|
|
178
|
+
gap: "sm",
|
|
179
|
+
children: externalLoginMethods.map((method) => /* @__PURE__ */ jsx(ActionButton, {
|
|
180
|
+
variant: "default",
|
|
181
|
+
leftSection: leftSection(method.name.toLowerCase()),
|
|
182
|
+
onClick: () => auth.login(method.name, {
|
|
183
|
+
redirect,
|
|
184
|
+
realm: props.realmConfig.realmName
|
|
185
|
+
}),
|
|
186
|
+
children: tr("loginContinueWith", { args: [capitalize(method.name)] })
|
|
187
|
+
}, method.type))
|
|
188
|
+
}),
|
|
189
|
+
settings.registrationAllowed && /* @__PURE__ */ jsxs(Text, {
|
|
190
|
+
size: "sm",
|
|
191
|
+
ta: "center",
|
|
192
|
+
children: [
|
|
193
|
+
tr("loginNoAccount"),
|
|
194
|
+
" ",
|
|
195
|
+
/* @__PURE__ */ jsx(ActionButton, {
|
|
196
|
+
href: router.path("register", { query: { realm: props.realmConfig.realmName } }),
|
|
197
|
+
anchorProps: { inherit: true },
|
|
198
|
+
children: tr("loginSignUp")
|
|
199
|
+
})
|
|
200
|
+
]
|
|
201
|
+
})
|
|
202
|
+
]
|
|
203
|
+
})
|
|
204
|
+
}), /* @__PURE__ */ jsx(ActionButton, {
|
|
205
|
+
variant: "subtle",
|
|
206
|
+
href: "/",
|
|
207
|
+
children: tr("loginCancel")
|
|
208
|
+
})]
|
|
209
|
+
})
|
|
210
|
+
});
|
|
211
|
+
};
|
|
212
|
+
const leftSection = (name) => {
|
|
213
|
+
if (name === "google") return /* @__PURE__ */ jsx(IconGoogle, {});
|
|
214
|
+
if (name === "github") return /* @__PURE__ */ jsx(IconGithub, {});
|
|
215
|
+
};
|
|
216
|
+
|
|
217
|
+
//#endregion
|
|
218
|
+
export { Login_exports as n, Login as t };
|
|
219
|
+
//# sourceMappingURL=Login-hSOU3jZc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Login-hSOU3jZc.js","names":[],"sources":["../../src/auth/components/Login.tsx"],"sourcesContent":["import { ActionButton, Control, capitalize } from \"@alepha/ui\";\nimport { Card, Flex, Image, Text, Title } from \"@mantine/core\";\nimport { IconLock, IconUser } from \"@tabler/icons-react\";\nimport { AlephaError, t } from \"alepha\";\nimport type { RealmConfig } from \"alepha/api/users\";\nimport { useAuth } from \"alepha/react/auth\";\nimport { FormValidationError, useForm } from \"alepha/react/form\";\nimport { useI18n } from \"alepha/react/i18n\";\nimport { useRouter } from \"alepha/react/router\";\nimport { HttpError } from \"alepha/server\";\nimport { useMemo } from \"react\";\nimport type { AuthI18n } from \"../AuthI18n.ts\";\nimport type { AuthRouter } from \"../AuthRouter.ts\";\nimport IconGithub from \"./icons/IconGithub.tsx\";\nimport IconGoogle from \"./icons/IconGoogle.tsx\";\n\nexport interface LoginProps {\n realmConfig: RealmConfig;\n}\n\nconst Login = (props: LoginProps) => {\n const auth = useAuth();\n const router = useRouter<AuthRouter>();\n const { tr } = useI18n<AuthI18n, \"en\">();\n const redirect = router.query.r || \"/\";\n\n const credentialsProvider = props.realmConfig.authenticationMethods.find(\n (it) => it.type === \"CREDENTIALS\",\n );\n\n const settings = props.realmConfig.settings;\n\n // Determine what login methods are available\n const loginMethods = useMemo(() => {\n const methods = [];\n if (settings.usernameEnabled !== false) methods.push(\"username\");\n if (settings.emailEnabled !== false) methods.push(\"email\");\n if (settings.phoneEnabled === true) methods.push(\"phone\");\n return methods;\n }, [settings]);\n\n // Create identifier title based on enabled methods\n const identifierTitle = useMemo(() => {\n if (loginMethods.length === 0) return tr(\"loginUsername\");\n if (loginMethods.length === 1) {\n if (loginMethods[0] === \"username\") return tr(\"loginUsername\");\n if (loginMethods[0] === \"email\") return tr(\"loginEmail\");\n if (loginMethods[0] === \"phone\") return tr(\"loginPhone\");\n }\n const labels = loginMethods.map((m) => {\n if (m === \"username\") return tr(\"loginUsername\").toLowerCase();\n if (m === \"email\") return tr(\"loginEmail\").toLowerCase();\n if (m === \"phone\") return tr(\"loginPhone\").toLowerCase();\n return m;\n });\n return capitalize(\n `${labels.slice(0, -1).join(\", \")} or ${labels[labels.length - 1]}`,\n );\n }, [loginMethods, tr]);\n\n const form = useForm({\n schema: t.object({\n identifier: t.string({\n minLength: 1,\n }),\n password: t.string({\n minLength: settings.passwordPolicy?.minLength || 6,\n }),\n }),\n handler: async (data) => {\n if (!credentialsProvider) {\n throw new AlephaError(\"Credentials provider not configured\");\n }\n\n try {\n await auth.login(credentialsProvider.name, {\n username: data.identifier,\n password: data.password,\n realm: props.realmConfig.realmName,\n });\n await router.push(router.query.r || \"/\");\n } catch (error) {\n if (\n error instanceof HttpError &&\n error.error === \"InvalidCredentialsError\"\n ) {\n throw new FormValidationError({\n message: \"Invalid identifier or password\",\n path: \"/password\",\n });\n }\n throw error;\n }\n },\n });\n\n const getAutoCompleteType = () => {\n if (loginMethods.includes(\"email\")) {\n return \"email\";\n }\n if (loginMethods.includes(\"username\")) {\n return \"username\";\n }\n if (loginMethods.includes(\"phone\")) {\n return \"tel\";\n }\n return \"username\";\n };\n\n const externalLoginMethods = props.realmConfig.authenticationMethods.filter(\n (method) => method.type !== \"CREDENTIALS\",\n );\n\n const showOrDivider = credentialsProvider && externalLoginMethods.length > 0;\n\n return (\n <Flex flex={1} justify={\"center\"} align={\"center\"}>\n <Flex direction=\"column\" gap={\"sm\"} w={360}>\n <Card withBorder p={\"lg\"} bg={\"var(--alepha-elevated)\"}>\n <Flex direction=\"column\" gap={\"md\"}>\n {/* Realm branding */}\n {(settings.logoUrl ||\n settings.displayName ||\n settings.description) && (\n <Flex direction=\"column\" gap={\"xs\"} align=\"center\" mb=\"xs\">\n {settings.logoUrl && (\n <Image\n src={settings.logoUrl}\n alt={settings.displayName || props.realmConfig.realmName}\n h={48}\n w=\"auto\"\n fit=\"contain\"\n />\n )}\n {settings.displayName && (\n <Title order={4} ta=\"center\">\n {settings.displayName}\n </Title>\n )}\n {settings.description && (\n <Text size=\"sm\" c=\"dimmed\" ta=\"center\">\n {settings.description}\n </Text>\n )}\n </Flex>\n )}\n\n {/* Credentials login form */}\n {credentialsProvider && (\n <>\n <form {...form.props}>\n <Flex direction=\"column\" flex={1} gap={\"md\"}>\n <Control\n title={identifierTitle}\n input={form.input.identifier}\n icon={IconUser}\n text={{\n autoComplete: getAutoCompleteType(),\n }}\n />\n <Control\n title={tr(\"loginPassword\")}\n input={form.input.password}\n icon={IconLock}\n password={{\n autoComplete: \"current-password\",\n }}\n />\n <ActionButton variant={\"filled\"} form={form}>\n {tr(\"loginSignIn\")}\n </ActionButton>\n </Flex>\n </form>\n {settings.resetPasswordAllowed && (\n <Text size=\"sm\" ta=\"center\">\n <ActionButton\n href={router.path(\"resetPassword\", {\n query: { realm: props.realmConfig.realmName },\n })}\n anchorProps={{ inherit: true }}\n >\n {tr(\"loginForgotPassword\")}\n </ActionButton>\n </Text>\n )}\n </>\n )}\n\n {/* OR divider - only when both credentials AND external methods exist */}\n {showOrDivider && (\n <Flex align=\"center\" justify=\"center\" gap={\"md\"}>\n <Flex flex={1} h={\"1px\"} bg={\"var(--alepha-border)\"} />\n <Text size=\"xs\" c={\"dimmed\"}>\n {tr(\"loginOr\")}\n </Text>\n <Flex flex={1} h={\"1px\"} bg={\"var(--alepha-border)\"} />\n </Flex>\n )}\n\n {/* External login methods */}\n {externalLoginMethods.length > 0 && (\n <Flex direction=\"column\" gap={\"sm\"}>\n {externalLoginMethods.map((method) => (\n <ActionButton\n variant={\"default\"}\n key={method.type}\n leftSection={leftSection(method.name.toLowerCase())}\n onClick={() =>\n auth.login(method.name, {\n redirect,\n realm: props.realmConfig.realmName,\n })\n }\n >\n {tr(\"loginContinueWith\", {\n args: [capitalize(method.name)],\n })}\n </ActionButton>\n ))}\n </Flex>\n )}\n\n {/* Registration link */}\n {settings.registrationAllowed && (\n <Text size=\"sm\" ta=\"center\">\n {tr(\"loginNoAccount\")}{\" \"}\n <ActionButton\n href={router.path(\"register\", {\n query: { realm: props.realmConfig.realmName },\n })}\n anchorProps={{ inherit: true }}\n >\n {tr(\"loginSignUp\")}\n </ActionButton>\n </Text>\n )}\n </Flex>\n </Card>\n <ActionButton variant={\"subtle\"} href={\"/\"}>\n {tr(\"loginCancel\")}\n </ActionButton>\n </Flex>\n </Flex>\n );\n};\n\nexport default Login;\n\nconst leftSection = (name: string) => {\n if (name === \"google\") {\n return <IconGoogle />;\n }\n\n if (name === \"github\") {\n return <IconGithub />;\n }\n};\n"],"mappings":"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"}
|