@alepha/ui 0.19.0 → 0.19.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/admin/{AdminApiKeys-Bt1PjO6o.js → AdminApiKeys-C2ze85eD.js} +2 -2
- package/dist/admin/{AdminApiKeys-Bt1PjO6o.js.map → AdminApiKeys-C2ze85eD.js.map} +1 -1
- package/dist/admin/{AdminAudits-C7c1CN4c.js → AdminAudits-BIj81e4k.js} +2 -2
- package/dist/admin/{AdminAudits-C7c1CN4c.js.map → AdminAudits-BIj81e4k.js.map} +1 -1
- package/dist/admin/{AdminDashboard-C3RXpTp6.js → AdminDashboard-PMVzrwSu.js} +2 -2
- package/dist/admin/{AdminDashboard-C3RXpTp6.js.map → AdminDashboard-PMVzrwSu.js.map} +1 -1
- package/dist/admin/AdminFiles-Bq03BLt-.js +189 -0
- package/dist/admin/AdminFiles-Bq03BLt-.js.map +1 -0
- package/dist/admin/{AdminJobExecutions-D-G8RIlr.js → AdminJobs-D1_QGCDy.js} +400 -356
- package/dist/admin/AdminJobs-D1_QGCDy.js.map +1 -0
- package/dist/admin/{AdminLayout-BmZ9mtXh.js → AdminLayout-BNiwiw2D.js} +2 -2
- package/dist/admin/{AdminLayout-BmZ9mtXh.js.map → AdminLayout-BNiwiw2D.js.map} +1 -1
- package/dist/admin/{AdminNotifications-DHdzksww.js → AdminNotifications-DSKQtUfn.js} +84 -122
- package/dist/admin/AdminNotifications-DSKQtUfn.js.map +1 -0
- package/dist/admin/{AdminParameters-CyZQSXnN.js → AdminParameters-CoB7EhyM.js} +2 -2
- package/dist/admin/{AdminParameters-CyZQSXnN.js.map → AdminParameters-CoB7EhyM.js.map} +1 -1
- package/dist/admin/{AdminSessions--xwELDSO.js → AdminSessions-DFbFcrJQ.js} +2 -2
- package/dist/admin/{AdminSessions--xwELDSO.js.map → AdminSessions-DFbFcrJQ.js.map} +1 -1
- package/dist/admin/{AdminUserLayout-DvBTG5gd.js → AdminUserLayout-fSfi3KMm.js} +3 -3
- package/dist/admin/{AdminUserLayout-DvBTG5gd.js.map → AdminUserLayout-fSfi3KMm.js.map} +1 -1
- package/dist/admin/{AdminUserProfile-CzsPBl6Z.js → AdminUserProfile-_C-h8vUK.js} +3 -3
- package/dist/admin/{AdminUserProfile-CzsPBl6Z.js.map → AdminUserProfile-_C-h8vUK.js.map} +1 -1
- package/dist/admin/{AdminUserSessions-C-aUnhVN.js → AdminUserSessions-KpJHIeQo.js} +2 -2
- package/dist/admin/{AdminUserSessions-C-aUnhVN.js.map → AdminUserSessions-KpJHIeQo.js.map} +1 -1
- package/dist/admin/{AdminUsers-BYwei5sj.js → AdminUsers-DcVrzdQP.js} +2 -2
- package/dist/admin/{AdminUsers-BYwei5sj.js.map → AdminUsers-DcVrzdQP.js.map} +1 -1
- package/dist/admin/{AuthLayout-CkPGLJku.js → AuthLayout-CazfLzcf.js} +2 -2
- package/dist/admin/{AuthLayout-CkPGLJku.js.map → AuthLayout-CazfLzcf.js.map} +1 -1
- package/dist/admin/{Login-DSBqNsZc.js → Login-CaMjUrDP.js} +2 -2
- package/dist/admin/{Login-DSBqNsZc.js.map → Login-CaMjUrDP.js.map} +1 -1
- package/dist/admin/{Profile-CDRjJo0P.js → Profile-Ca4fZX15.js} +2 -2
- package/dist/{auth/Profile-Cy93pNTw.js.map → admin/Profile-Ca4fZX15.js.map} +1 -1
- package/dist/admin/{Register-4QGFOnfh.js → Register-C5DyKWPO.js} +2 -2
- package/dist/{demo/Register-KKZwr_lL.js.map → admin/Register-C5DyKWPO.js.map} +1 -1
- package/dist/admin/{ResetPassword-Gxc9L_mY.js → ResetPassword-BA5sAgXo.js} +2 -2
- package/dist/{auth/ResetPassword-B61QPlQi.js.map → admin/ResetPassword-BA5sAgXo.js.map} +1 -1
- package/dist/admin/{VerifyEmail-D7G5NnaN.js → VerifyEmail-DKNXROj_.js} +2 -2
- package/dist/{auth/VerifyEmail-CqBJ11id.js.map → admin/VerifyEmail-DKNXROj_.js.map} +1 -1
- package/dist/admin/{adminUserAtom-DCi4wf-v.js → adminUserAtom-BLNc7XbT.js} +1 -1
- package/dist/admin/{adminUserAtom-DCi4wf-v.js.map → adminUserAtom-BLNc7XbT.js.map} +1 -1
- package/dist/admin/{core-D1AbU50V.js → core-CJCEx18C.js} +111 -4
- package/dist/admin/core-CJCEx18C.js.map +1 -0
- package/dist/admin/index.d.ts +21 -3
- package/dist/admin/index.d.ts.map +1 -1
- package/dist/admin/index.js +29 -58
- package/dist/admin/index.js.map +1 -1
- package/dist/auth/{AuthLayout-CfRKcTqP.js → AuthLayout-vXPcCVzp.js} +2 -2
- package/dist/auth/{AuthLayout-CfRKcTqP.js.map → AuthLayout-vXPcCVzp.js.map} +1 -1
- package/dist/auth/{Login-DJyweoPS.js → Login-Dg08QR20.js} +2 -2
- package/dist/{demo/Login-CqG1iJbn.js.map → auth/Login-Dg08QR20.js.map} +1 -1
- package/dist/{demo/Profile-C0ojJCaG.js → auth/Profile-Bb5O1yeh.js} +2 -2
- package/dist/{admin/Profile-CDRjJo0P.js.map → auth/Profile-Bb5O1yeh.js.map} +1 -1
- package/dist/auth/{Register-CSqzzitW.js → Register-B2AN71NC.js} +2 -2
- package/dist/auth/{Register-CSqzzitW.js.map → Register-B2AN71NC.js.map} +1 -1
- package/dist/{demo/ResetPassword-DMrLFEtr.js → auth/ResetPassword-BLxwzbDj.js} +2 -2
- package/dist/{admin/ResetPassword-Gxc9L_mY.js.map → auth/ResetPassword-BLxwzbDj.js.map} +1 -1
- package/dist/auth/{VerifyEmail-CqBJ11id.js → VerifyEmail-CSDOk3Zm.js} +2 -2
- package/dist/{demo/VerifyEmail-BFCAFz6T.js.map → auth/VerifyEmail-CSDOk3Zm.js.map} +1 -1
- package/dist/auth/{core-C6D3pazL.js → core-DuGkjPiU.js} +2 -1
- package/dist/auth/core-DuGkjPiU.js.map +1 -0
- package/dist/auth/index.d.ts +20 -0
- package/dist/auth/index.d.ts.map +1 -1
- package/dist/auth/index.js +11 -11
- package/dist/core/index.d.ts +69 -17
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +110 -8
- package/dist/core/index.js.map +1 -1
- package/dist/demo/{AuthLayout-Dq5tSLSc.js → AuthLayout-DPsOOG4u.js} +2 -2
- package/dist/demo/{AuthLayout-Dq5tSLSc.js.map → AuthLayout-DPsOOG4u.js.map} +1 -1
- package/dist/demo/{DemoButton-_Ws2w-J0.js → DemoButton-wzcqGk4u.js} +3 -3
- package/dist/demo/{DemoButton-_Ws2w-J0.js.map → DemoButton-wzcqGk4u.js.map} +1 -1
- package/dist/demo/{DemoControlSelect-ChP4ZOpQ.js → DemoControlSelect-CMWvQ6Gm.js} +3 -3
- package/dist/demo/{DemoControlSelect-ChP4ZOpQ.js.map → DemoControlSelect-CMWvQ6Gm.js.map} +1 -1
- package/dist/demo/{DemoDataTable-Hwf_UUni.js → DemoDataTable-CHsAP3e2.js} +3 -3
- package/dist/demo/{DemoDataTable-Hwf_UUni.js.map → DemoDataTable-CHsAP3e2.js.map} +1 -1
- package/dist/demo/{DemoDialog-B01OMVRd.js → DemoDialog-Co2IePxX.js} +2 -2
- package/dist/demo/{DemoDialog-B01OMVRd.js.map → DemoDialog-Co2IePxX.js.map} +1 -1
- package/dist/demo/{DemoFlex-870PEl0V.js → DemoFlex-OEwQt5do.js} +3 -3
- package/dist/demo/{DemoFlex-870PEl0V.js.map → DemoFlex-OEwQt5do.js.map} +1 -1
- package/dist/demo/DemoHeading-Db-XkQIK.js +69 -0
- package/dist/demo/DemoHeading-Db-XkQIK.js.map +1 -0
- package/dist/demo/{DemoHome-DRbL2eGf.js → DemoHome-Cyp29ygy.js} +2 -2
- package/dist/demo/{DemoHome-DRbL2eGf.js.map → DemoHome-Cyp29ygy.js.map} +1 -1
- package/dist/demo/{DemoJsonViewer-DoABiqBW.js → DemoJsonViewer-DXtCeMzH.js} +3 -3
- package/dist/demo/{DemoJsonViewer-DoABiqBW.js.map → DemoJsonViewer-DXtCeMzH.js.map} +1 -1
- package/dist/demo/{DemoLayout-CN_PDCX2.js → DemoLayout-hh9VmZQP.js} +2 -2
- package/dist/demo/{DemoLayout-CN_PDCX2.js.map → DemoLayout-hh9VmZQP.js.map} +1 -1
- package/dist/demo/{DemoLogin-B5x-ug3Q.js → DemoLogin-DX7mnmkh.js} +13 -8
- package/dist/demo/{DemoLogin-B5x-ug3Q.js.map → DemoLogin-DX7mnmkh.js.map} +1 -1
- package/dist/demo/{DemoRegister-Q6sg2xuV.js → DemoRegister-DVcZl04m.js} +13 -8
- package/dist/demo/{DemoRegister-Q6sg2xuV.js.map → DemoRegister-DVcZl04m.js.map} +1 -1
- package/dist/demo/{DemoResetPassword-DrqZfmEw.js → DemoResetPassword-CPENlZH5.js} +13 -8
- package/dist/demo/{DemoResetPassword-DrqZfmEw.js.map → DemoResetPassword-CPENlZH5.js.map} +1 -1
- package/dist/demo/{DemoSidebar-CfKS6w1o.js → DemoSidebar-CGu7DZeM.js} +3 -3
- package/dist/demo/{DemoSidebar-CfKS6w1o.js.map → DemoSidebar-CGu7DZeM.js.map} +1 -1
- package/dist/demo/{DemoText-pT6Gi5b5.js → DemoText-DYUJ7bY_.js} +3 -3
- package/dist/demo/{DemoText-pT6Gi5b5.js.map → DemoText-DYUJ7bY_.js.map} +1 -1
- package/dist/demo/{DemoToast-I13NBzQQ.js → DemoToast-CgdnZNvx.js} +2 -2
- package/dist/demo/{DemoToast-I13NBzQQ.js.map → DemoToast-CgdnZNvx.js.map} +1 -1
- package/dist/demo/{DemoTypeForm-BqzcrtvN.js → DemoTypeForm-Pims-cGa.js} +3 -3
- package/dist/demo/{DemoTypeForm-BqzcrtvN.js.map → DemoTypeForm-Pims-cGa.js.map} +1 -1
- package/dist/demo/{DemoVerifyEmail-HwD8xfQw.js → DemoVerifyEmail-C7B3xxch.js} +8 -8
- package/dist/demo/{DemoVerifyEmail-HwD8xfQw.js.map → DemoVerifyEmail-C7B3xxch.js.map} +1 -1
- package/dist/demo/{Login-CqG1iJbn.js → Login-pwMF4TUj.js} +2 -2
- package/dist/{auth/Login-DJyweoPS.js.map → demo/Login-pwMF4TUj.js.map} +1 -1
- package/dist/{auth/Profile-Cy93pNTw.js → demo/Profile-BliZapZS.js} +2 -2
- package/dist/demo/{Profile-C0ojJCaG.js.map → Profile-BliZapZS.js.map} +1 -1
- package/dist/demo/{Register-KKZwr_lL.js → Register-CiwAT7Hy.js} +2 -2
- package/dist/{admin/Register-4QGFOnfh.js.map → demo/Register-CiwAT7Hy.js.map} +1 -1
- package/dist/{auth/ResetPassword-B61QPlQi.js → demo/ResetPassword-l9Vg4JE-.js} +2 -2
- package/dist/demo/{ResetPassword-DMrLFEtr.js.map → ResetPassword-l9Vg4JE-.js.map} +1 -1
- package/dist/demo/{Showcase-D49Wud2v.js → Showcase-CX6bDgwe.js} +2 -2
- package/dist/demo/{Showcase-D49Wud2v.js.map → Showcase-CX6bDgwe.js.map} +1 -1
- package/dist/demo/{VerifyEmail-BFCAFz6T.js → VerifyEmail-CAB-OS7i.js} +2 -2
- package/dist/{admin/VerifyEmail-D7G5NnaN.js.map → demo/VerifyEmail-CAB-OS7i.js.map} +1 -1
- package/dist/demo/{auth-D9qTZzCa.js → auth-uegJAdKu.js} +8 -8
- package/dist/demo/{auth-D9qTZzCa.js.map → auth-uegJAdKu.js.map} +1 -1
- package/dist/demo/{core-DRtQklr3.js → core-B4LVHzPn.js} +111 -9
- package/dist/demo/core-B4LVHzPn.js.map +1 -0
- package/dist/demo/index.js +19 -19
- package/dist/demo/index.js.map +1 -1
- package/package.json +6 -9
- package/src/admin/AdminRouter.tsx +5 -37
- package/src/admin/components/files/AdminFiles.tsx +123 -1
- package/src/admin/components/jobs/{AdminJobExecutions.tsx → AdminJobs.tsx} +450 -317
- package/src/admin/components/notifications/AdminNotifications.tsx +11 -25
- package/src/core/components/Section.tsx +109 -0
- package/src/core/components/SectionHeader.tsx +106 -0
- package/src/core/index.ts +4 -1
- package/src/core/table/components/DataTable.tsx +5 -1
- package/src/demo/DemoRouter.ts +1 -1
- package/src/demo/components/auth/DemoLogin.tsx +5 -0
- package/src/demo/components/auth/DemoRegister.tsx +5 -0
- package/src/demo/components/auth/DemoResetPassword.tsx +5 -0
- package/src/demo/components/core/DemoHeading.tsx +56 -3
- package/dist/admin/AdminFiles-31ivR6Wq.js +0 -110
- package/dist/admin/AdminFiles-31ivR6Wq.js.map +0 -1
- package/dist/admin/AdminJobDashboard-BABLe7hL.js +0 -402
- package/dist/admin/AdminJobDashboard-BABLe7hL.js.map +0 -1
- package/dist/admin/AdminJobExecutions-D-G8RIlr.js.map +0 -1
- package/dist/admin/AdminJobRegistry-oIS3K9NX.js +0 -269
- package/dist/admin/AdminJobRegistry-oIS3K9NX.js.map +0 -1
- package/dist/admin/AdminNotifications-DHdzksww.js.map +0 -1
- package/dist/admin/core-D1AbU50V.js.map +0 -1
- package/dist/auth/core-C6D3pazL.js.map +0 -1
- package/dist/demo/DemoHeading-C1YR27fz.js +0 -17
- package/dist/demo/DemoHeading-C1YR27fz.js.map +0 -1
- package/dist/demo/core-DRtQklr3.js.map +0 -1
- package/src/admin/components/jobs/AdminJobDashboard.tsx +0 -380
- package/src/admin/components/jobs/AdminJobRegistry.tsx +0 -301
- package/src/core/components/Heading.tsx +0 -19
package/dist/demo/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as AlephaUI } from "./core-
|
|
1
|
+
import { t as AlephaUI } from "./core-B4LVHzPn.js";
|
|
2
2
|
import { $context, $module } from "alepha";
|
|
3
3
|
import { IconBell, IconBinaryTree, IconBraces, IconClick, IconForms, IconHeading, IconHome, IconKey, IconLayout, IconLayoutSidebar, IconLetterT, IconLockQuestion, IconLogin, IconMailCheck, IconMessage, IconPackages, IconRowInsertBottom, IconTable, IconUserPlus, IconWall } from "@tabler/icons-react";
|
|
4
4
|
import { $page } from "alepha/react/router";
|
|
@@ -8,7 +8,7 @@ var DemoRouter = class {
|
|
|
8
8
|
icon: IconPackages,
|
|
9
9
|
path: "/demo",
|
|
10
10
|
label: "Demo",
|
|
11
|
-
lazy: () => import("./DemoLayout-
|
|
11
|
+
lazy: () => import("./DemoLayout-hh9VmZQP.js"),
|
|
12
12
|
children: () => [
|
|
13
13
|
this.demoHome,
|
|
14
14
|
this.demoCore,
|
|
@@ -23,7 +23,7 @@ var DemoRouter = class {
|
|
|
23
23
|
icon: IconHome,
|
|
24
24
|
path: "/",
|
|
25
25
|
label: "Home",
|
|
26
|
-
lazy: () => import("./DemoHome-
|
|
26
|
+
lazy: () => import("./DemoHome-Cyp29ygy.js")
|
|
27
27
|
});
|
|
28
28
|
demoCore = $page({
|
|
29
29
|
icon: IconWall,
|
|
@@ -40,25 +40,25 @@ var DemoRouter = class {
|
|
|
40
40
|
icon: IconRowInsertBottom,
|
|
41
41
|
path: "/flex",
|
|
42
42
|
label: "Flex",
|
|
43
|
-
lazy: () => import("./DemoFlex-
|
|
43
|
+
lazy: () => import("./DemoFlex-OEwQt5do.js")
|
|
44
44
|
});
|
|
45
45
|
demoText = $page({
|
|
46
46
|
icon: IconLetterT,
|
|
47
47
|
path: "/text",
|
|
48
48
|
label: "Text",
|
|
49
|
-
lazy: () => import("./DemoText-
|
|
49
|
+
lazy: () => import("./DemoText-DYUJ7bY_.js")
|
|
50
50
|
});
|
|
51
51
|
demoHeading = $page({
|
|
52
52
|
icon: IconHeading,
|
|
53
53
|
path: "/heading",
|
|
54
|
-
label: "
|
|
55
|
-
lazy: () => import("./DemoHeading-
|
|
54
|
+
label: "Section",
|
|
55
|
+
lazy: () => import("./DemoHeading-Db-XkQIK.js")
|
|
56
56
|
});
|
|
57
57
|
demoButton = $page({
|
|
58
58
|
icon: IconClick,
|
|
59
59
|
path: "/button",
|
|
60
60
|
label: "Button",
|
|
61
|
-
lazy: () => import("./DemoButton-
|
|
61
|
+
lazy: () => import("./DemoButton-wzcqGk4u.js")
|
|
62
62
|
});
|
|
63
63
|
demoLayoutSection = $page({
|
|
64
64
|
icon: IconLayout,
|
|
@@ -74,19 +74,19 @@ var DemoRouter = class {
|
|
|
74
74
|
icon: IconLayoutSidebar,
|
|
75
75
|
path: "/sidebar",
|
|
76
76
|
label: "Sidebar",
|
|
77
|
-
lazy: () => import("./DemoSidebar-
|
|
77
|
+
lazy: () => import("./DemoSidebar-CGu7DZeM.js")
|
|
78
78
|
});
|
|
79
79
|
demoDialog = $page({
|
|
80
80
|
icon: IconMessage,
|
|
81
81
|
path: "/dialog",
|
|
82
82
|
label: "Dialog",
|
|
83
|
-
lazy: () => import("./DemoDialog-
|
|
83
|
+
lazy: () => import("./DemoDialog-Co2IePxX.js")
|
|
84
84
|
});
|
|
85
85
|
demoToast = $page({
|
|
86
86
|
icon: IconBell,
|
|
87
87
|
path: "/toast",
|
|
88
88
|
label: "Toast",
|
|
89
|
-
lazy: () => import("./DemoToast-
|
|
89
|
+
lazy: () => import("./DemoToast-CgdnZNvx.js")
|
|
90
90
|
});
|
|
91
91
|
demoForm = $page({
|
|
92
92
|
icon: IconForms,
|
|
@@ -98,13 +98,13 @@ var DemoRouter = class {
|
|
|
98
98
|
icon: IconForms,
|
|
99
99
|
path: "/type-form",
|
|
100
100
|
label: "TypeForm",
|
|
101
|
-
lazy: () => import("./DemoTypeForm-
|
|
101
|
+
lazy: () => import("./DemoTypeForm-Pims-cGa.js")
|
|
102
102
|
});
|
|
103
103
|
demoControlSelect = $page({
|
|
104
104
|
icon: IconForms,
|
|
105
105
|
path: "/control-select",
|
|
106
106
|
label: "ControlSelect",
|
|
107
|
-
lazy: () => import("./DemoControlSelect-
|
|
107
|
+
lazy: () => import("./DemoControlSelect-CMWvQ6Gm.js")
|
|
108
108
|
});
|
|
109
109
|
demoTable = $page({
|
|
110
110
|
icon: IconTable,
|
|
@@ -116,7 +116,7 @@ var DemoRouter = class {
|
|
|
116
116
|
icon: IconTable,
|
|
117
117
|
path: "/data-table",
|
|
118
118
|
label: "DataTable",
|
|
119
|
-
lazy: () => import("./DemoDataTable-
|
|
119
|
+
lazy: () => import("./DemoDataTable-CHsAP3e2.js")
|
|
120
120
|
});
|
|
121
121
|
demoJson = $page({
|
|
122
122
|
icon: IconBraces,
|
|
@@ -128,7 +128,7 @@ var DemoRouter = class {
|
|
|
128
128
|
icon: IconBinaryTree,
|
|
129
129
|
path: "/viewer",
|
|
130
130
|
label: "JsonViewer",
|
|
131
|
-
lazy: () => import("./DemoJsonViewer-
|
|
131
|
+
lazy: () => import("./DemoJsonViewer-DXtCeMzH.js")
|
|
132
132
|
});
|
|
133
133
|
demoAuth = $page({
|
|
134
134
|
icon: IconKey,
|
|
@@ -145,25 +145,25 @@ var DemoRouter = class {
|
|
|
145
145
|
icon: IconLogin,
|
|
146
146
|
path: "/login",
|
|
147
147
|
label: "Login",
|
|
148
|
-
lazy: () => import("./DemoLogin-
|
|
148
|
+
lazy: () => import("./DemoLogin-DX7mnmkh.js")
|
|
149
149
|
});
|
|
150
150
|
demoRegister = $page({
|
|
151
151
|
icon: IconUserPlus,
|
|
152
152
|
path: "/register",
|
|
153
153
|
label: "Register",
|
|
154
|
-
lazy: () => import("./DemoRegister-
|
|
154
|
+
lazy: () => import("./DemoRegister-DVcZl04m.js")
|
|
155
155
|
});
|
|
156
156
|
demoResetPassword = $page({
|
|
157
157
|
icon: IconLockQuestion,
|
|
158
158
|
path: "/reset-password",
|
|
159
159
|
label: "ResetPassword",
|
|
160
|
-
lazy: () => import("./DemoResetPassword-
|
|
160
|
+
lazy: () => import("./DemoResetPassword-CPENlZH5.js")
|
|
161
161
|
});
|
|
162
162
|
demoVerifyEmail = $page({
|
|
163
163
|
icon: IconMailCheck,
|
|
164
164
|
path: "/verify-email",
|
|
165
165
|
label: "VerifyEmail",
|
|
166
|
-
lazy: () => import("./DemoVerifyEmail-
|
|
166
|
+
lazy: () => import("./DemoVerifyEmail-C7B3xxch.js")
|
|
167
167
|
});
|
|
168
168
|
};
|
|
169
169
|
//#endregion
|
package/dist/demo/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":[],"sources":["../../src/demo/DemoRouter.ts","../../src/demo/primitives/$uiDemo.ts","../../src/demo/index.ts"],"sourcesContent":["import {\n IconBell,\n IconBinaryTree,\n IconBraces,\n IconClick,\n IconForms,\n IconHeading,\n IconHome,\n IconKey,\n IconLayout,\n IconLayoutSidebar,\n IconLetterT,\n IconLockQuestion,\n IconLogin,\n IconMailCheck,\n IconMessage,\n IconPackages,\n IconRowInsertBottom,\n IconTable,\n IconUserPlus,\n IconWall,\n} from \"@tabler/icons-react\";\nimport { $page } from \"alepha/react/router\";\n\nexport class DemoRouter {\n demoLayout = $page({\n icon: IconPackages,\n path: \"/demo\",\n label: \"Demo\",\n lazy: () => import(\"./components/DemoLayout.tsx\"),\n children: () => [\n this.demoHome,\n this.demoCore,\n this.demoLayoutSection,\n this.demoForm,\n this.demoTable,\n this.demoJson,\n this.demoAuth,\n ],\n });\n\n demoHome = $page({\n icon: IconHome,\n path: \"/\",\n label: \"Home\",\n lazy: () => import(\"./components/DemoHome.tsx\"),\n });\n\n // Core Components\n demoCore = $page({\n icon: IconWall,\n path: \"/core\",\n label: \"Core\",\n children: () => [\n this.demoFlex,\n this.demoText,\n this.demoButton,\n this.demoHeading,\n ],\n });\n\n demoFlex = $page({\n icon: IconRowInsertBottom,\n path: \"/flex\",\n label: \"Flex\",\n lazy: () => import(\"./components/core/DemoFlex.tsx\"),\n });\n\n demoText = $page({\n icon: IconLetterT,\n path: \"/text\",\n label: \"Text\",\n lazy: () => import(\"./components/core/DemoText.tsx\"),\n });\n\n demoHeading = $page({\n icon: IconHeading,\n path: \"/heading\",\n label: \"
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../src/demo/DemoRouter.ts","../../src/demo/primitives/$uiDemo.ts","../../src/demo/index.ts"],"sourcesContent":["import {\n IconBell,\n IconBinaryTree,\n IconBraces,\n IconClick,\n IconForms,\n IconHeading,\n IconHome,\n IconKey,\n IconLayout,\n IconLayoutSidebar,\n IconLetterT,\n IconLockQuestion,\n IconLogin,\n IconMailCheck,\n IconMessage,\n IconPackages,\n IconRowInsertBottom,\n IconTable,\n IconUserPlus,\n IconWall,\n} from \"@tabler/icons-react\";\nimport { $page } from \"alepha/react/router\";\n\nexport class DemoRouter {\n demoLayout = $page({\n icon: IconPackages,\n path: \"/demo\",\n label: \"Demo\",\n lazy: () => import(\"./components/DemoLayout.tsx\"),\n children: () => [\n this.demoHome,\n this.demoCore,\n this.demoLayoutSection,\n this.demoForm,\n this.demoTable,\n this.demoJson,\n this.demoAuth,\n ],\n });\n\n demoHome = $page({\n icon: IconHome,\n path: \"/\",\n label: \"Home\",\n lazy: () => import(\"./components/DemoHome.tsx\"),\n });\n\n // Core Components\n demoCore = $page({\n icon: IconWall,\n path: \"/core\",\n label: \"Core\",\n children: () => [\n this.demoFlex,\n this.demoText,\n this.demoButton,\n this.demoHeading,\n ],\n });\n\n demoFlex = $page({\n icon: IconRowInsertBottom,\n path: \"/flex\",\n label: \"Flex\",\n lazy: () => import(\"./components/core/DemoFlex.tsx\"),\n });\n\n demoText = $page({\n icon: IconLetterT,\n path: \"/text\",\n label: \"Text\",\n lazy: () => import(\"./components/core/DemoText.tsx\"),\n });\n\n demoHeading = $page({\n icon: IconHeading,\n path: \"/heading\",\n label: \"Section\",\n lazy: () => import(\"./components/core/DemoHeading.tsx\"),\n });\n\n demoButton = $page({\n icon: IconClick,\n path: \"/button\",\n label: \"Button\",\n lazy: () => import(\"./components/core/DemoButton.tsx\"),\n });\n\n // Layout Components\n demoLayoutSection = $page({\n icon: IconLayout,\n path: \"/layout\",\n label: \"Layout\",\n children: () => [this.demoSidebar, this.demoDialog, this.demoToast],\n });\n\n demoSidebar = $page({\n icon: IconLayoutSidebar,\n path: \"/sidebar\",\n label: \"Sidebar\",\n lazy: () => import(\"./components/layout/DemoSidebar.tsx\"),\n });\n\n demoDialog = $page({\n icon: IconMessage,\n path: \"/dialog\",\n label: \"Dialog\",\n lazy: () => import(\"./components/layout/DemoDialog.tsx\"),\n });\n\n demoToast = $page({\n icon: IconBell,\n path: \"/toast\",\n label: \"Toast\",\n lazy: () => import(\"./components/layout/DemoToast.tsx\"),\n });\n\n // Form Components\n demoForm = $page({\n icon: IconForms,\n path: \"/form\",\n label: \"Form\",\n children: () => [this.demoTypeForm, this.demoControlSelect],\n });\n\n demoTypeForm = $page({\n icon: IconForms,\n path: \"/type-form\",\n label: \"TypeForm\",\n lazy: () => import(\"./components/core/DemoTypeForm.tsx\"),\n });\n\n demoControlSelect = $page({\n icon: IconForms,\n path: \"/control-select\",\n label: \"ControlSelect\",\n lazy: () => import(\"./components/core/DemoControlSelect.tsx\"),\n });\n\n // Table Components\n demoTable = $page({\n icon: IconTable,\n path: \"/table\",\n label: \"Table\",\n children: () => [this.demoDataTable],\n });\n\n demoDataTable = $page({\n icon: IconTable,\n path: \"/data-table\",\n label: \"DataTable\",\n lazy: () => import(\"./components/core/DemoDataTable.tsx\"),\n });\n\n // JSON Components\n demoJson = $page({\n icon: IconBraces,\n path: \"/json\",\n label: \"Json\",\n children: () => [this.demoJsonViewer],\n });\n\n demoJsonViewer = $page({\n icon: IconBinaryTree,\n path: \"/viewer\",\n label: \"JsonViewer\",\n lazy: () => import(\"./components/json/DemoJsonViewer.tsx\"),\n });\n\n // Auth Components\n demoAuth = $page({\n icon: IconKey,\n path: \"/auth\",\n label: \"Auth\",\n children: () => [\n this.demoLogin,\n this.demoRegister,\n this.demoResetPassword,\n this.demoVerifyEmail,\n ],\n });\n\n demoLogin = $page({\n icon: IconLogin,\n path: \"/login\",\n label: \"Login\",\n lazy: () => import(\"./components/auth/DemoLogin.tsx\"),\n });\n\n demoRegister = $page({\n icon: IconUserPlus,\n path: \"/register\",\n label: \"Register\",\n lazy: () => import(\"./components/auth/DemoRegister.tsx\"),\n });\n\n demoResetPassword = $page({\n icon: IconLockQuestion,\n path: \"/reset-password\",\n label: \"ResetPassword\",\n lazy: () => import(\"./components/auth/DemoResetPassword.tsx\"),\n });\n\n demoVerifyEmail = $page({\n icon: IconMailCheck,\n path: \"/verify-email\",\n label: \"VerifyEmail\",\n lazy: () => import(\"./components/auth/DemoVerifyEmail.tsx\"),\n });\n}\n","import { $context } from \"alepha\";\nimport { DemoRouter } from \"../DemoRouter.ts\";\n\n/**\n * Register Demo UI components and get the DemoRouter instance.\n */\nexport const $uiDemo = () => {\n const { alepha } = $context();\n return alepha.inject(DemoRouter);\n};\n","import { AlephaUI } from \"@alepha/ui\";\nimport { $module } from \"alepha\";\nimport { DemoRouter } from \"./DemoRouter.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\nexport { DemoRouter } from \"./DemoRouter.ts\";\nexport * from \"./primitives/$uiDemo.ts\";\n\n// ---------------------------------------------------------------------------------------------------------------------\n\n/**\n * Component showcase and documentation.\n *\n * **Features:**\n * - DemoLayout for demo pages\n * - DemoHome landing page\n * - MacWindow component for showcases\n * - Showcase component for component demos\n *\n * @module alepha.ui.demo\n */\nexport const AlephaUIDemo = $module({\n name: \"alepha.ui.demo\",\n services: [AlephaUI, DemoRouter],\n});\n"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -7,7 +7,7 @@
|
|
|
7
7
|
"mantine"
|
|
8
8
|
],
|
|
9
9
|
"author": "Nicolas Foures",
|
|
10
|
-
"version": "0.19.
|
|
10
|
+
"version": "0.19.1",
|
|
11
11
|
"type": "module",
|
|
12
12
|
"engines": {
|
|
13
13
|
"node": ">=22.0.0"
|
|
@@ -22,7 +22,6 @@
|
|
|
22
22
|
"styles.css"
|
|
23
23
|
],
|
|
24
24
|
"dependencies": {
|
|
25
|
-
"@mantine/charts": "^8.3.18",
|
|
26
25
|
"@mantine/core": "^8.3.18",
|
|
27
26
|
"@mantine/dates": "^8.3.18",
|
|
28
27
|
"@mantine/hooks": "^8.3.18",
|
|
@@ -31,16 +30,14 @@
|
|
|
31
30
|
"@mantine/nprogress": "^8.3.18",
|
|
32
31
|
"@mantine/spotlight": "^8.3.18",
|
|
33
32
|
"@tabler/icons-react": "^3.40.0",
|
|
34
|
-
"dayjs": "^1.11.20"
|
|
35
|
-
"react-is": "^19.2.4",
|
|
36
|
-
"recharts": "^3.8.0"
|
|
33
|
+
"dayjs": "^1.11.20"
|
|
37
34
|
},
|
|
38
35
|
"devDependencies": {
|
|
39
36
|
"@biomejs/biome": "^2.4.8",
|
|
40
37
|
"@testing-library/dom": "^10.4.1",
|
|
41
38
|
"@testing-library/react": "^16.3.2",
|
|
42
39
|
"@types/react-is": "^19.2.0",
|
|
43
|
-
"alepha": "0.19.
|
|
40
|
+
"alepha": "0.19.1",
|
|
44
41
|
"react": "^19.2.4",
|
|
45
42
|
"react-dom": "^19.2.4",
|
|
46
43
|
"typescript": "^5.9.3",
|
|
@@ -48,7 +45,7 @@
|
|
|
48
45
|
"vitest": "^4.1.0"
|
|
49
46
|
},
|
|
50
47
|
"peerDependencies": {
|
|
51
|
-
"alepha": "0.19.
|
|
48
|
+
"alepha": "0.19.1",
|
|
52
49
|
"react": "*",
|
|
53
50
|
"react-dom": "*"
|
|
54
51
|
},
|
|
@@ -57,8 +54,8 @@
|
|
|
57
54
|
"lint": "alepha lint && yarn build:check",
|
|
58
55
|
"typecheck": "alepha typecheck",
|
|
59
56
|
"test": "alepha test",
|
|
60
|
-
"build": "node
|
|
61
|
-
"build:check": "node
|
|
57
|
+
"build": "node ../../alepha/scripts/build.ts",
|
|
58
|
+
"build:check": "node ../../alepha/scripts/build.ts --check"
|
|
62
59
|
},
|
|
63
60
|
"repository": {
|
|
64
61
|
"type": "git",
|
|
@@ -10,14 +10,11 @@ import {
|
|
|
10
10
|
import { AuthRouter, UserButton } from "@alepha/ui/auth";
|
|
11
11
|
import {
|
|
12
12
|
IconBell,
|
|
13
|
-
IconClock,
|
|
14
|
-
IconDashboard,
|
|
15
13
|
IconDevices,
|
|
16
14
|
IconFile,
|
|
17
15
|
IconHistory,
|
|
18
16
|
IconKey,
|
|
19
17
|
IconLayoutDashboard,
|
|
20
|
-
IconListDetails,
|
|
21
18
|
IconLockPassword,
|
|
22
19
|
IconSettings,
|
|
23
20
|
IconTerminal2,
|
|
@@ -151,16 +148,7 @@ export class AdminRouter {
|
|
|
151
148
|
can: () => this.fileCtrl.findFiles.can(),
|
|
152
149
|
},
|
|
153
150
|
{
|
|
154
|
-
|
|
155
|
-
icon: IconTerminal2,
|
|
156
|
-
children: [
|
|
157
|
-
{
|
|
158
|
-
...this.router.node(this.adminJobDashboard.name),
|
|
159
|
-
label: "Dashboard",
|
|
160
|
-
},
|
|
161
|
-
{ ...this.router.node(this.adminJobRegistry.name) },
|
|
162
|
-
{ ...this.router.node(this.adminJobExecutions.name) },
|
|
163
|
-
],
|
|
151
|
+
...this.router.node(this.adminJobs.name),
|
|
164
152
|
},
|
|
165
153
|
{
|
|
166
154
|
...this.router.node(this.adminNotifications.name),
|
|
@@ -367,36 +355,16 @@ export class AdminRouter {
|
|
|
367
355
|
// Jobs
|
|
368
356
|
// ─────────────────────────────────────────────────────────────────────────────
|
|
369
357
|
|
|
370
|
-
public readonly
|
|
371
|
-
icon:
|
|
358
|
+
public readonly adminJobs = $page({
|
|
359
|
+
icon: IconTerminal2,
|
|
372
360
|
parent: this.adminLayout,
|
|
373
361
|
path: "/jobs",
|
|
374
362
|
label: "Jobs",
|
|
375
|
-
description: "Monitor and manage background jobs
|
|
376
|
-
lazy: () => import("./components/jobs/
|
|
363
|
+
description: "Monitor and manage background jobs.",
|
|
364
|
+
lazy: () => import("./components/jobs/AdminJobs.tsx"),
|
|
377
365
|
can: () => this.jobCtrl.getJobRegistry.can(),
|
|
378
366
|
});
|
|
379
367
|
|
|
380
|
-
public readonly adminJobRegistry = $page({
|
|
381
|
-
icon: IconListDetails,
|
|
382
|
-
parent: this.adminLayout,
|
|
383
|
-
path: "/jobs/registry",
|
|
384
|
-
label: "Registry",
|
|
385
|
-
description: "View all registered job definitions.",
|
|
386
|
-
lazy: () => import("./components/jobs/AdminJobRegistry.tsx"),
|
|
387
|
-
can: () => this.jobCtrl.getJobRegistry.can(),
|
|
388
|
-
});
|
|
389
|
-
|
|
390
|
-
public readonly adminJobExecutions = $page({
|
|
391
|
-
icon: IconClock,
|
|
392
|
-
parent: this.adminLayout,
|
|
393
|
-
path: "/jobs/executions",
|
|
394
|
-
label: "Executions",
|
|
395
|
-
description: "Browse and filter job execution history.",
|
|
396
|
-
lazy: () => import("./components/jobs/AdminJobExecutions.tsx"),
|
|
397
|
-
can: () => this.jobCtrl.findJobExecutions.can(),
|
|
398
|
-
});
|
|
399
|
-
|
|
400
368
|
// ─────────────────────────────────────────────────────────────────────────────
|
|
401
369
|
// API Keys
|
|
402
370
|
// ─────────────────────────────────────────────────────────────────────────────
|
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import { DataTable, Flex, Text } from "@alepha/ui";
|
|
1
|
+
import { DataTable, Flex, Text, useDialog, useToast } from "@alepha/ui";
|
|
2
|
+
import { HoverCard } from "@mantine/core";
|
|
3
|
+
import {
|
|
4
|
+
IconDownload,
|
|
5
|
+
IconFile,
|
|
6
|
+
IconFileCode,
|
|
7
|
+
IconFileMusic,
|
|
8
|
+
IconFileSpreadsheet,
|
|
9
|
+
IconFileText,
|
|
10
|
+
IconFileZip,
|
|
11
|
+
IconPdf,
|
|
12
|
+
IconPhoto,
|
|
13
|
+
IconTrash,
|
|
14
|
+
IconVideo,
|
|
15
|
+
} from "@tabler/icons-react";
|
|
2
16
|
import { type Page, t } from "alepha";
|
|
3
17
|
import { type FileController, type FileEntity, files } from "alepha/api/files";
|
|
4
18
|
import { useClient } from "alepha/react";
|
|
@@ -7,6 +21,8 @@ import { useI18n } from "alepha/react/i18n";
|
|
|
7
21
|
const AdminFiles = () => {
|
|
8
22
|
const client = useClient<FileController>();
|
|
9
23
|
const { l } = useI18n();
|
|
24
|
+
const dialog = useDialog();
|
|
25
|
+
const toast = useToast();
|
|
10
26
|
|
|
11
27
|
const filters = t.object({
|
|
12
28
|
bucket: t.optional(t.string()),
|
|
@@ -19,6 +35,34 @@ const AdminFiles = () => {
|
|
|
19
35
|
),
|
|
20
36
|
});
|
|
21
37
|
|
|
38
|
+
const isImage = (mime: string) => mime.startsWith("image/");
|
|
39
|
+
|
|
40
|
+
const getFileIcon = (mime: string) => {
|
|
41
|
+
if (isImage(mime)) return IconPhoto;
|
|
42
|
+
if (mime === "application/pdf") return IconPdf;
|
|
43
|
+
if (mime.startsWith("video/")) return IconVideo;
|
|
44
|
+
if (mime.startsWith("audio/")) return IconFileMusic;
|
|
45
|
+
if (mime.startsWith("text/csv") || mime.includes("spreadsheet"))
|
|
46
|
+
return IconFileSpreadsheet;
|
|
47
|
+
if (
|
|
48
|
+
mime.includes("zip") ||
|
|
49
|
+
mime.includes("tar") ||
|
|
50
|
+
mime.includes("gzip") ||
|
|
51
|
+
mime.includes("compress")
|
|
52
|
+
)
|
|
53
|
+
return IconFileZip;
|
|
54
|
+
if (
|
|
55
|
+
mime.includes("javascript") ||
|
|
56
|
+
mime.includes("json") ||
|
|
57
|
+
mime.includes("xml") ||
|
|
58
|
+
mime.includes("html") ||
|
|
59
|
+
mime.includes("css")
|
|
60
|
+
)
|
|
61
|
+
return IconFileCode;
|
|
62
|
+
if (mime.startsWith("text/")) return IconFileText;
|
|
63
|
+
return IconFile;
|
|
64
|
+
};
|
|
65
|
+
|
|
22
66
|
const formatFileSize = (bytes: number) => {
|
|
23
67
|
if (bytes === 0) return "0 B";
|
|
24
68
|
const k = 1024;
|
|
@@ -54,6 +98,53 @@ const AdminFiles = () => {
|
|
|
54
98
|
return response as Page<FileEntity>;
|
|
55
99
|
}}
|
|
56
100
|
columns={{
|
|
101
|
+
preview: {
|
|
102
|
+
label: "",
|
|
103
|
+
fit: true,
|
|
104
|
+
value: (item) => {
|
|
105
|
+
const Icon = getFileIcon(item.mimeType);
|
|
106
|
+
const url = `/api/files/${item.id}`;
|
|
107
|
+
|
|
108
|
+
if (isImage(item.mimeType)) {
|
|
109
|
+
return (
|
|
110
|
+
<HoverCard
|
|
111
|
+
width={512}
|
|
112
|
+
position="right"
|
|
113
|
+
shadow="lg"
|
|
114
|
+
openDelay={200}
|
|
115
|
+
>
|
|
116
|
+
<HoverCard.Target>
|
|
117
|
+
<img
|
|
118
|
+
src={url}
|
|
119
|
+
alt={item.name}
|
|
120
|
+
style={{
|
|
121
|
+
width: 32,
|
|
122
|
+
height: 32,
|
|
123
|
+
objectFit: "cover",
|
|
124
|
+
borderRadius: 4,
|
|
125
|
+
display: "block",
|
|
126
|
+
}}
|
|
127
|
+
/>
|
|
128
|
+
</HoverCard.Target>
|
|
129
|
+
<HoverCard.Dropdown p={4}>
|
|
130
|
+
<img
|
|
131
|
+
src={url}
|
|
132
|
+
alt={item.name}
|
|
133
|
+
style={{
|
|
134
|
+
width: 512,
|
|
135
|
+
height: 512,
|
|
136
|
+
objectFit: "contain",
|
|
137
|
+
display: "block",
|
|
138
|
+
}}
|
|
139
|
+
/>
|
|
140
|
+
</HoverCard.Dropdown>
|
|
141
|
+
</HoverCard>
|
|
142
|
+
);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
return <Icon size={20} color="var(--mantine-color-dimmed)" />;
|
|
146
|
+
},
|
|
147
|
+
},
|
|
57
148
|
name: {
|
|
58
149
|
label: "Name",
|
|
59
150
|
value: (item) => (
|
|
@@ -103,6 +194,37 @@ const AdminFiles = () => {
|
|
|
103
194
|
),
|
|
104
195
|
},
|
|
105
196
|
}}
|
|
197
|
+
rowActions={(item) => [
|
|
198
|
+
{
|
|
199
|
+
label: "Download",
|
|
200
|
+
icon: IconDownload,
|
|
201
|
+
skipRefresh: true,
|
|
202
|
+
onClick: () => {
|
|
203
|
+
window.open(`/api/files/${item.id}`, "_blank");
|
|
204
|
+
},
|
|
205
|
+
},
|
|
206
|
+
]}
|
|
207
|
+
checkboxActions={[
|
|
208
|
+
{
|
|
209
|
+
label: "Delete selected",
|
|
210
|
+
icon: <IconTrash size={14} />,
|
|
211
|
+
intent: "danger",
|
|
212
|
+
onClick: async ({ selectedItems, clearSelection }) => {
|
|
213
|
+
const confirmed = await dialog.confirm({
|
|
214
|
+
title: "Delete files",
|
|
215
|
+
message: `Permanently delete ${selectedItems.length} file(s)? This action cannot be undone.`,
|
|
216
|
+
});
|
|
217
|
+
if (!confirmed) return;
|
|
218
|
+
for (const file of selectedItems) {
|
|
219
|
+
await client.deleteFile({ params: { id: file.id } });
|
|
220
|
+
}
|
|
221
|
+
toast.success({
|
|
222
|
+
message: `${selectedItems.length} file(s) deleted`,
|
|
223
|
+
});
|
|
224
|
+
clearSelection();
|
|
225
|
+
},
|
|
226
|
+
},
|
|
227
|
+
]}
|
|
106
228
|
/>
|
|
107
229
|
</Flex>
|
|
108
230
|
);
|