@mesob/auth-react 0.4.6 → 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.
- package/dist/{chunk-WQ3UUUKF.js → chunk-2PV7RYNK.js} +12 -4
- package/dist/chunk-2PV7RYNK.js.map +1 -0
- package/dist/{chunk-TB2ZPGLW.js → chunk-4X3CJHKR.js} +2 -2
- package/dist/{chunk-PG65ZD7A.js → chunk-5BFG47VF.js} +4 -4
- package/dist/{chunk-OQUUS5ZX.js → chunk-5E3XN6SW.js} +2 -2
- package/dist/{chunk-KOBZ34XU.js → chunk-6THPM5LB.js} +7 -1
- package/dist/chunk-6THPM5LB.js.map +1 -0
- package/dist/{chunk-RBXITSE2.js → chunk-73ZNGEWU.js} +5 -5
- package/dist/{chunk-DY3NVBLJ.js → chunk-7CLKBH5Z.js} +10 -1
- package/dist/chunk-7CLKBH5Z.js.map +1 -0
- package/dist/{chunk-FPYQ7XGV.js → chunk-ECF6S2Y2.js} +90 -20
- package/dist/chunk-ECF6S2Y2.js.map +1 -0
- package/dist/{chunk-G74DDR4O.js → chunk-GBDNBY6K.js} +2 -2
- package/dist/{chunk-LHZ4EEN6.js → chunk-H5PUZDNU.js} +7 -1
- package/dist/chunk-H5PUZDNU.js.map +1 -0
- package/dist/{chunk-A3GIMM2R.js → chunk-H7JRQFFI.js} +2 -2
- package/dist/{chunk-IFAVSKHE.js → chunk-IQNQGPIT.js} +7 -1
- package/dist/chunk-IQNQGPIT.js.map +1 -0
- package/dist/chunk-MWMSZVH3.js +601 -0
- package/dist/chunk-MWMSZVH3.js.map +1 -0
- package/dist/{chunk-L32Z3TPA.js → chunk-N4JFMKGK.js} +67 -12
- package/dist/chunk-N4JFMKGK.js.map +1 -0
- package/dist/{chunk-A7ORWWM5.js → chunk-NFGFJPCX.js} +9 -1
- package/dist/chunk-NFGFJPCX.js.map +1 -0
- package/dist/{chunk-SW7WD64K.js → chunk-NJMNRSJH.js} +7 -1
- package/dist/chunk-NJMNRSJH.js.map +1 -0
- package/dist/{chunk-HXHI4FU6.js → chunk-OXUOGOG3.js} +111 -91
- package/dist/chunk-OXUOGOG3.js.map +1 -0
- package/dist/{chunk-ETOCBXDT.js → chunk-QPEUVMSP.js} +9 -1
- package/dist/chunk-QPEUVMSP.js.map +1 -0
- package/dist/{chunk-YN7OEQI7.js → chunk-RCQTWNAG.js} +7 -1
- package/dist/chunk-RCQTWNAG.js.map +1 -0
- package/dist/{chunk-55BMNC4S.js → chunk-RRLFPSSM.js} +25 -11
- package/dist/chunk-RRLFPSSM.js.map +1 -0
- package/dist/{chunk-NUWAI3FE.js → chunk-SGUROG23.js} +8 -2
- package/dist/chunk-SGUROG23.js.map +1 -0
- package/dist/{chunk-SXVTYYUT.js → chunk-T34HJRUW.js} +7 -1
- package/dist/chunk-T34HJRUW.js.map +1 -0
- package/dist/{chunk-UAKGEJUN.js → chunk-TEHMLZFI.js} +2 -2
- package/dist/chunk-V6ZHX4LT.js +15 -0
- package/dist/chunk-V6ZHX4LT.js.map +1 -0
- package/dist/{chunk-CXMPZWMX.js → chunk-VVKXFEAN.js} +2 -2
- package/dist/{chunk-ZXKEG3X5.js → chunk-X6EUQZSZ.js} +10 -1
- package/dist/chunk-X6EUQZSZ.js.map +1 -0
- package/dist/components/auth/forgot-password.js +2 -2
- package/dist/components/auth/reset-password-form.js +2 -2
- package/dist/components/auth/set-password.js +2 -2
- package/dist/components/auth/sign-in.js +2 -2
- package/dist/components/auth/sign-up.js +2 -2
- package/dist/components/auth/verify-email.js +2 -2
- package/dist/components/auth/verify-phone.js +2 -2
- package/dist/components/iam/domains-page.d.ts +1 -0
- package/dist/components/iam/domains-page.js +14 -0
- package/dist/components/iam/domains-page.js.map +1 -0
- package/dist/components/iam/iam-guard.d.ts +7 -0
- package/dist/components/iam/iam-guard.js +10 -0
- package/dist/components/iam/iam-guard.js.map +1 -0
- package/dist/components/iam/permissions-page.js +3 -1
- package/dist/components/iam/role-detail-page.d.ts +1 -1
- package/dist/components/iam/role-detail-page.js +3 -1
- package/dist/components/iam/role-permissions-page.d.ts +1 -1
- package/dist/components/iam/role-permissions-page.js +3 -1
- package/dist/components/iam/roles-page.js +3 -1
- package/dist/components/iam/sessions-page.js +3 -1
- package/dist/components/iam/tenants-page.js +3 -1
- package/dist/components/iam/users-page.js +4 -2
- package/dist/components/profile/change-email-form.js +2 -2
- package/dist/components/profile/change-phone-form.js +1 -1
- package/dist/components/profile/security.js +6 -6
- package/dist/index.d.ts +2 -0
- package/dist/index.js +60 -52
- package/dist/index.js.map +1 -1
- package/dist/pages/auth/forgot-password.js +2 -2
- package/dist/pages/auth/reset-password.js +2 -2
- package/dist/pages/auth/set-password.js +2 -2
- package/dist/pages/auth/sign-in.js +2 -2
- package/dist/pages/auth/sign-up.js +2 -2
- package/dist/pages/auth/verify-email.js +2 -2
- package/dist/pages/auth/verify-phone.js +2 -2
- package/dist/pages/iam/domains/_components/domain-card.d.ts +6 -0
- package/dist/pages/iam/domains/_components/domain-form.d.ts +9 -0
- package/dist/pages/iam/domains/_components/domains-data.d.ts +10 -0
- package/dist/pages/iam/domains/_components/domains-list.d.ts +15 -0
- package/dist/pages/iam/domains.d.ts +1 -0
- package/dist/pages/iam/permissions.js +3 -1
- package/dist/pages/iam/role-detail.js +3 -1
- package/dist/pages/iam/role-detail.js.map +1 -1
- package/dist/pages/iam/role-permissions.js +3 -1
- package/dist/pages/iam/role-permissions.js.map +1 -1
- package/dist/pages/iam/role-users.js +5 -3
- package/dist/pages/iam/role-users.js.map +1 -1
- package/dist/pages/iam/roles/users/_components/role-users-page.d.ts +1 -1
- package/dist/pages/iam/roles.js +3 -1
- package/dist/pages/iam/sessions.js +3 -1
- package/dist/pages/iam/tenant-detail.js +3 -1
- package/dist/pages/iam/tenant-detail.js.map +1 -1
- package/dist/pages/iam/tenants/tenant-detail-page-content.d.ts +1 -1
- package/dist/pages/iam/tenants.js +3 -1
- package/dist/pages/iam/user-activity.js +3 -1
- package/dist/pages/iam/user-activity.js.map +1 -1
- package/dist/pages/iam/user-detail-layout.js +3 -1
- package/dist/pages/iam/user-detail-layout.js.map +1 -1
- package/dist/pages/iam/user-detail.js +3 -1
- package/dist/pages/iam/user-detail.js.map +1 -1
- package/dist/pages/iam/users/_components/user-detail-layout-content.d.ts +1 -1
- package/dist/pages/iam/users/_components/user-detail-page-content.d.ts +1 -1
- package/dist/pages/iam/users/activity/user-activity-page-content.d.ts +1 -1
- package/dist/pages/iam/users/user-selector.js +2 -2
- package/dist/pages/iam/users.js +4 -2
- package/dist/pages/profile/security.js +6 -6
- package/dist/utils/handle-error.d.ts +4 -1
- package/package.json +4 -4
- package/dist/chunk-55BMNC4S.js.map +0 -1
- package/dist/chunk-A7ORWWM5.js.map +0 -1
- package/dist/chunk-DY3NVBLJ.js.map +0 -1
- package/dist/chunk-ETOCBXDT.js.map +0 -1
- package/dist/chunk-FPYQ7XGV.js.map +0 -1
- package/dist/chunk-HXHI4FU6.js.map +0 -1
- package/dist/chunk-IFAVSKHE.js.map +0 -1
- package/dist/chunk-KOBZ34XU.js.map +0 -1
- package/dist/chunk-L32Z3TPA.js.map +0 -1
- package/dist/chunk-LHZ4EEN6.js.map +0 -1
- package/dist/chunk-NUWAI3FE.js.map +0 -1
- package/dist/chunk-SW7WD64K.js.map +0 -1
- package/dist/chunk-SXVTYYUT.js.map +0 -1
- package/dist/chunk-WQ3UUUKF.js.map +0 -1
- package/dist/chunk-YN7OEQI7.js.map +0 -1
- package/dist/chunk-ZXKEG3X5.js.map +0 -1
- /package/dist/{chunk-TB2ZPGLW.js.map → chunk-4X3CJHKR.js.map} +0 -0
- /package/dist/{chunk-PG65ZD7A.js.map → chunk-5BFG47VF.js.map} +0 -0
- /package/dist/{chunk-OQUUS5ZX.js.map → chunk-5E3XN6SW.js.map} +0 -0
- /package/dist/{chunk-RBXITSE2.js.map → chunk-73ZNGEWU.js.map} +0 -0
- /package/dist/{chunk-G74DDR4O.js.map → chunk-GBDNBY6K.js.map} +0 -0
- /package/dist/{chunk-A3GIMM2R.js.map → chunk-H7JRQFFI.js.map} +0 -0
- /package/dist/{chunk-UAKGEJUN.js.map → chunk-TEHMLZFI.js.map} +0 -0
- /package/dist/{chunk-CXMPZWMX.js.map → chunk-VVKXFEAN.js.map} +0 -0
|
@@ -0,0 +1,601 @@
|
|
|
1
|
+
import {
|
|
2
|
+
authApi$
|
|
3
|
+
} from "./chunk-W3D4HG5W.js";
|
|
4
|
+
import {
|
|
5
|
+
defaultEntityQueryOptions
|
|
6
|
+
} from "./chunk-NPW7D2HZ.js";
|
|
7
|
+
import {
|
|
8
|
+
IAMGuard
|
|
9
|
+
} from "./chunk-V6ZHX4LT.js";
|
|
10
|
+
import {
|
|
11
|
+
useApi,
|
|
12
|
+
useConfig
|
|
13
|
+
} from "./chunk-AWSAC7RT.js";
|
|
14
|
+
|
|
15
|
+
// src/components/iam/domains-page.tsx
|
|
16
|
+
import {
|
|
17
|
+
EntityDrawerTrigger,
|
|
18
|
+
EntityHeader,
|
|
19
|
+
EntitySearch,
|
|
20
|
+
EntitySort,
|
|
21
|
+
EntityViewToggle,
|
|
22
|
+
PageBody,
|
|
23
|
+
PageContainer,
|
|
24
|
+
Select as Select2,
|
|
25
|
+
SelectContent as SelectContent2,
|
|
26
|
+
SelectItem as SelectItem2,
|
|
27
|
+
SelectTrigger as SelectTrigger2,
|
|
28
|
+
useBreadcrumbs,
|
|
29
|
+
useEntityPagination,
|
|
30
|
+
useEntityParams
|
|
31
|
+
} from "@mesob/ui/components";
|
|
32
|
+
import { IconWorld as IconWorld2 } from "@tabler/icons-react";
|
|
33
|
+
import { useMemo, useState as useState3 } from "react";
|
|
34
|
+
|
|
35
|
+
// src/pages/iam/domains/_components/domain-form.tsx
|
|
36
|
+
import { zodResolver } from "@hookform/resolvers/zod";
|
|
37
|
+
import {
|
|
38
|
+
Checkbox,
|
|
39
|
+
EntityDrawer,
|
|
40
|
+
EntityFormActions,
|
|
41
|
+
Form,
|
|
42
|
+
FormControl,
|
|
43
|
+
FormField,
|
|
44
|
+
FormItem,
|
|
45
|
+
FormLabel,
|
|
46
|
+
FormMessage,
|
|
47
|
+
Input,
|
|
48
|
+
Select,
|
|
49
|
+
SelectContent,
|
|
50
|
+
SelectItem,
|
|
51
|
+
SelectTrigger,
|
|
52
|
+
Skeleton,
|
|
53
|
+
Stack
|
|
54
|
+
} from "@mesob/ui/components";
|
|
55
|
+
import { useQueryClient } from "@tanstack/react-query";
|
|
56
|
+
import { useEffect } from "react";
|
|
57
|
+
import { useForm } from "react-hook-form";
|
|
58
|
+
import { z } from "zod";
|
|
59
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
60
|
+
var statusOptions = [
|
|
61
|
+
{ value: "pending", label: "Pending" },
|
|
62
|
+
{ value: "active", label: "Active" },
|
|
63
|
+
{ value: "disabled", label: "Disabled" },
|
|
64
|
+
{ value: "deleted", label: "Deleted" }
|
|
65
|
+
];
|
|
66
|
+
var schema = z.object({
|
|
67
|
+
domain: z.string().min(1, "Domain is required").regex(
|
|
68
|
+
/^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)+$/,
|
|
69
|
+
"Invalid domain format (e.g. example.com)"
|
|
70
|
+
),
|
|
71
|
+
status: z.enum(["pending", "active", "disabled", "deleted"]),
|
|
72
|
+
isPrimary: z.boolean()
|
|
73
|
+
});
|
|
74
|
+
var defaults = {
|
|
75
|
+
domain: "",
|
|
76
|
+
status: "pending",
|
|
77
|
+
isPrimary: false
|
|
78
|
+
};
|
|
79
|
+
function DomainForm({
|
|
80
|
+
mode,
|
|
81
|
+
domainId,
|
|
82
|
+
open,
|
|
83
|
+
onClose,
|
|
84
|
+
onSuccess
|
|
85
|
+
}) {
|
|
86
|
+
const qc = useQueryClient();
|
|
87
|
+
const { data, isLoading } = authApi$.useQuery(
|
|
88
|
+
"get",
|
|
89
|
+
"/domains/{id}",
|
|
90
|
+
{ params: { path: { id: domainId ?? "" } } },
|
|
91
|
+
{ enabled: mode === "edit" && !!domainId && open }
|
|
92
|
+
);
|
|
93
|
+
const domain = data?.domain;
|
|
94
|
+
const form = useForm({
|
|
95
|
+
resolver: zodResolver(schema),
|
|
96
|
+
defaultValues: defaults
|
|
97
|
+
});
|
|
98
|
+
const { control, formState, reset } = form;
|
|
99
|
+
useEffect(() => {
|
|
100
|
+
if (!open) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
if (mode === "edit" && domain && !isLoading) {
|
|
104
|
+
reset({
|
|
105
|
+
domain: domain.domain,
|
|
106
|
+
status: domain.status?.toLowerCase() ?? "pending",
|
|
107
|
+
isPrimary: domain.isPrimary ?? false
|
|
108
|
+
});
|
|
109
|
+
} else {
|
|
110
|
+
reset(defaults);
|
|
111
|
+
}
|
|
112
|
+
}, [mode, domain, open, isLoading, reset]);
|
|
113
|
+
const create = authApi$.useMutation("post", "/domains", {
|
|
114
|
+
onSuccess: () => {
|
|
115
|
+
qc.invalidateQueries({ queryKey: ["get", "/domains"] });
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
const update = authApi$.useMutation("put", "/domains/{id}", {
|
|
119
|
+
onSuccess: () => {
|
|
120
|
+
qc.invalidateQueries({ queryKey: ["get", "/domains"] });
|
|
121
|
+
if (domainId) {
|
|
122
|
+
qc.invalidateQueries({ queryKey: ["get", "/domains/{id}"] });
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
const del = authApi$.useMutation("delete", "/domains/{id}", {
|
|
127
|
+
onSuccess: () => {
|
|
128
|
+
qc.invalidateQueries({ queryKey: ["get", "/domains"] });
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
const onSubmit = form.handleSubmit(async (d) => {
|
|
132
|
+
if (mode === "new") {
|
|
133
|
+
await create.mutateAsync({
|
|
134
|
+
body: {
|
|
135
|
+
domain: d.domain,
|
|
136
|
+
status: d.status,
|
|
137
|
+
isPrimary: d.isPrimary
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
} else if (domainId) {
|
|
141
|
+
await update.mutateAsync({
|
|
142
|
+
params: { path: { id: domainId } },
|
|
143
|
+
body: {
|
|
144
|
+
domain: d.domain,
|
|
145
|
+
status: d.status,
|
|
146
|
+
isPrimary: d.isPrimary
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
onSuccess?.();
|
|
151
|
+
onClose();
|
|
152
|
+
});
|
|
153
|
+
const onDelete = async () => {
|
|
154
|
+
if (!domainId) {
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
await del.mutateAsync({ params: { path: { id: domainId } } });
|
|
158
|
+
onSuccess?.();
|
|
159
|
+
onClose();
|
|
160
|
+
};
|
|
161
|
+
const isSubmitting = create.isPending || update.isPending;
|
|
162
|
+
return /* @__PURE__ */ jsx(
|
|
163
|
+
EntityDrawer,
|
|
164
|
+
{
|
|
165
|
+
title: mode === "new" ? "New domain" : "Edit domain",
|
|
166
|
+
open,
|
|
167
|
+
onClose,
|
|
168
|
+
isDirty: formState.isDirty,
|
|
169
|
+
form: isLoading && mode === "edit" ? /* @__PURE__ */ jsx(FormSkeleton, {}) : /* @__PURE__ */ jsx(Form, { ...form, children: /* @__PURE__ */ jsx("form", { onSubmit, className: "space-y-6", children: /* @__PURE__ */ jsxs(Stack, { children: [
|
|
170
|
+
/* @__PURE__ */ jsx(
|
|
171
|
+
FormField,
|
|
172
|
+
{
|
|
173
|
+
control,
|
|
174
|
+
name: "domain",
|
|
175
|
+
render: ({ field }) => /* @__PURE__ */ jsxs(FormItem, { children: [
|
|
176
|
+
/* @__PURE__ */ jsxs(FormLabel, { children: [
|
|
177
|
+
"Domain ",
|
|
178
|
+
/* @__PURE__ */ jsx("span", { className: "text-destructive", children: "*" })
|
|
179
|
+
] }),
|
|
180
|
+
/* @__PURE__ */ jsx(FormControl, { children: /* @__PURE__ */ jsx(
|
|
181
|
+
Input,
|
|
182
|
+
{
|
|
183
|
+
placeholder: "example.com",
|
|
184
|
+
...field,
|
|
185
|
+
disabled: mode === "edit"
|
|
186
|
+
}
|
|
187
|
+
) }),
|
|
188
|
+
/* @__PURE__ */ jsx(FormMessage, {})
|
|
189
|
+
] })
|
|
190
|
+
}
|
|
191
|
+
),
|
|
192
|
+
/* @__PURE__ */ jsx(
|
|
193
|
+
FormField,
|
|
194
|
+
{
|
|
195
|
+
control,
|
|
196
|
+
name: "status",
|
|
197
|
+
render: ({ field }) => /* @__PURE__ */ jsxs(FormItem, { children: [
|
|
198
|
+
/* @__PURE__ */ jsx(FormLabel, { children: "Status" }),
|
|
199
|
+
/* @__PURE__ */ jsxs(
|
|
200
|
+
Select,
|
|
201
|
+
{
|
|
202
|
+
value: field.value,
|
|
203
|
+
onValueChange: (v) => field.onChange(v),
|
|
204
|
+
children: [
|
|
205
|
+
/* @__PURE__ */ jsx(FormControl, { children: /* @__PURE__ */ jsx(SelectTrigger, { children: statusOptions.find((o) => o.value === field.value)?.label ?? field.value }) }),
|
|
206
|
+
/* @__PURE__ */ jsx(SelectContent, { children: statusOptions.map((o) => /* @__PURE__ */ jsx(SelectItem, { value: o.value, children: o.label }, o.value)) })
|
|
207
|
+
]
|
|
208
|
+
}
|
|
209
|
+
),
|
|
210
|
+
/* @__PURE__ */ jsx(FormMessage, {})
|
|
211
|
+
] })
|
|
212
|
+
}
|
|
213
|
+
),
|
|
214
|
+
/* @__PURE__ */ jsx(
|
|
215
|
+
FormField,
|
|
216
|
+
{
|
|
217
|
+
control,
|
|
218
|
+
name: "isPrimary",
|
|
219
|
+
render: ({ field }) => /* @__PURE__ */ jsxs(FormItem, { className: "flex flex-row items-center gap-2 space-y-0", children: [
|
|
220
|
+
/* @__PURE__ */ jsx(FormControl, { children: /* @__PURE__ */ jsx(
|
|
221
|
+
Checkbox,
|
|
222
|
+
{
|
|
223
|
+
size: "lg",
|
|
224
|
+
checked: field.value,
|
|
225
|
+
onCheckedChange: (c) => field.onChange(c === true)
|
|
226
|
+
}
|
|
227
|
+
) }),
|
|
228
|
+
/* @__PURE__ */ jsx(FormLabel, { className: "cursor-pointer font-normal", children: "Primary domain" }),
|
|
229
|
+
/* @__PURE__ */ jsx(FormMessage, {})
|
|
230
|
+
] })
|
|
231
|
+
}
|
|
232
|
+
)
|
|
233
|
+
] }) }) }),
|
|
234
|
+
actions: /* @__PURE__ */ jsx(
|
|
235
|
+
EntityFormActions,
|
|
236
|
+
{
|
|
237
|
+
mode,
|
|
238
|
+
onSubmit,
|
|
239
|
+
onReset: mode === "new" ? () => reset(defaults) : void 0,
|
|
240
|
+
onDelete: mode === "edit" ? onDelete : void 0,
|
|
241
|
+
isSubmitting,
|
|
242
|
+
isDeleting: del.isPending,
|
|
243
|
+
disabled: isLoading && mode === "edit",
|
|
244
|
+
itemName: "domain"
|
|
245
|
+
}
|
|
246
|
+
)
|
|
247
|
+
}
|
|
248
|
+
);
|
|
249
|
+
}
|
|
250
|
+
function FormSkeleton() {
|
|
251
|
+
return /* @__PURE__ */ jsx("div", { className: "space-y-4", children: [1, 2, 3].map((i) => /* @__PURE__ */ jsxs("div", { className: "space-y-2", children: [
|
|
252
|
+
/* @__PURE__ */ jsx(Skeleton, { className: "h-4 w-20" }),
|
|
253
|
+
/* @__PURE__ */ jsx(Skeleton, { className: "h-10 w-full" })
|
|
254
|
+
] }, i)) });
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
// src/pages/iam/domains/_components/domains-list.tsx
|
|
258
|
+
import {
|
|
259
|
+
Badge as Badge2,
|
|
260
|
+
DataTableAction,
|
|
261
|
+
DataTablePagination,
|
|
262
|
+
DisplayTable,
|
|
263
|
+
EntityEmptyState,
|
|
264
|
+
EntityLoadingState,
|
|
265
|
+
Tbody,
|
|
266
|
+
Td,
|
|
267
|
+
Th,
|
|
268
|
+
Thead,
|
|
269
|
+
Tr
|
|
270
|
+
} from "@mesob/ui/components";
|
|
271
|
+
import { IconWorld } from "@tabler/icons-react";
|
|
272
|
+
import { useState as useState2 } from "react";
|
|
273
|
+
|
|
274
|
+
// src/pages/iam/domains/_components/domain-card.tsx
|
|
275
|
+
import {
|
|
276
|
+
Badge,
|
|
277
|
+
Button,
|
|
278
|
+
Card,
|
|
279
|
+
CardContent,
|
|
280
|
+
CardHeader,
|
|
281
|
+
DropdownMenu,
|
|
282
|
+
DropdownMenuContent,
|
|
283
|
+
DropdownMenuItem,
|
|
284
|
+
DropdownMenuPortal,
|
|
285
|
+
DropdownMenuTrigger
|
|
286
|
+
} from "@mesob/ui/components";
|
|
287
|
+
import { IconDots, IconPencil } from "@tabler/icons-react";
|
|
288
|
+
import { useState } from "react";
|
|
289
|
+
import { Fragment, jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
|
|
290
|
+
function statusVariant(s) {
|
|
291
|
+
const v = s?.toLowerCase();
|
|
292
|
+
if (v === "active") {
|
|
293
|
+
return "default";
|
|
294
|
+
}
|
|
295
|
+
if (v === "pending") {
|
|
296
|
+
return "secondary";
|
|
297
|
+
}
|
|
298
|
+
if (v === "disabled" || v === "deleted") {
|
|
299
|
+
return "destructive";
|
|
300
|
+
}
|
|
301
|
+
return "outline";
|
|
302
|
+
}
|
|
303
|
+
function DomainCard({ domain }) {
|
|
304
|
+
const [editOpen, setEditOpen] = useState(false);
|
|
305
|
+
return /* @__PURE__ */ jsxs2(Fragment, { children: [
|
|
306
|
+
/* @__PURE__ */ jsxs2(Card, { className: "group hover:shadow-md transition-shadow", children: [
|
|
307
|
+
/* @__PURE__ */ jsx2(CardHeader, { className: "pb-2", children: /* @__PURE__ */ jsxs2("div", { className: "flex items-start justify-between gap-2", children: [
|
|
308
|
+
/* @__PURE__ */ jsx2("span", { className: "font-semibold truncate", children: domain.domain }),
|
|
309
|
+
/* @__PURE__ */ jsxs2(DropdownMenu, { children: [
|
|
310
|
+
/* @__PURE__ */ jsx2(
|
|
311
|
+
DropdownMenuTrigger,
|
|
312
|
+
{
|
|
313
|
+
render: /* @__PURE__ */ jsx2(
|
|
314
|
+
Button,
|
|
315
|
+
{
|
|
316
|
+
variant: "ghost",
|
|
317
|
+
size: "icon",
|
|
318
|
+
className: "h-8 w-8 opacity-0 group-hover:opacity-100 transition-opacity"
|
|
319
|
+
}
|
|
320
|
+
),
|
|
321
|
+
children: /* @__PURE__ */ jsx2(IconDots, { className: "h-4 w-4" })
|
|
322
|
+
}
|
|
323
|
+
),
|
|
324
|
+
/* @__PURE__ */ jsx2(DropdownMenuPortal, { children: /* @__PURE__ */ jsx2(DropdownMenuContent, { children: /* @__PURE__ */ jsxs2(DropdownMenuItem, { onClick: () => setEditOpen(true), children: [
|
|
325
|
+
/* @__PURE__ */ jsx2(IconPencil, { className: "mr-2 h-4 w-4" }),
|
|
326
|
+
"Edit"
|
|
327
|
+
] }) }) })
|
|
328
|
+
] })
|
|
329
|
+
] }) }),
|
|
330
|
+
/* @__PURE__ */ jsxs2(CardContent, { className: "space-y-2", children: [
|
|
331
|
+
/* @__PURE__ */ jsxs2("div", { className: "flex flex-wrap gap-1", children: [
|
|
332
|
+
/* @__PURE__ */ jsx2(Badge, { variant: statusVariant(domain.status), className: "text-xs", children: domain.status }),
|
|
333
|
+
domain.isPrimary && /* @__PURE__ */ jsx2(Badge, { variant: "outline", className: "text-xs", children: "Primary" })
|
|
334
|
+
] }),
|
|
335
|
+
/* @__PURE__ */ jsxs2("p", { className: "text-xs text-muted-foreground", children: [
|
|
336
|
+
"Updated",
|
|
337
|
+
" ",
|
|
338
|
+
domain.updatedAt ? new Date(domain.updatedAt).toLocaleDateString() : "\u2014"
|
|
339
|
+
] })
|
|
340
|
+
] })
|
|
341
|
+
] }),
|
|
342
|
+
editOpen && /* @__PURE__ */ jsx2(
|
|
343
|
+
DomainForm,
|
|
344
|
+
{
|
|
345
|
+
mode: "edit",
|
|
346
|
+
domainId: domain.id,
|
|
347
|
+
open: editOpen,
|
|
348
|
+
onClose: () => setEditOpen(false)
|
|
349
|
+
}
|
|
350
|
+
)
|
|
351
|
+
] });
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
// src/pages/iam/domains/_components/domains-list.tsx
|
|
355
|
+
import { jsx as jsx3, jsxs as jsxs3 } from "react/jsx-runtime";
|
|
356
|
+
var TABLE_COLUMN_COUNT = 5;
|
|
357
|
+
function statusVariant2(s) {
|
|
358
|
+
const v = s?.toLowerCase();
|
|
359
|
+
if (v === "active") {
|
|
360
|
+
return "default";
|
|
361
|
+
}
|
|
362
|
+
if (v === "pending") {
|
|
363
|
+
return "secondary";
|
|
364
|
+
}
|
|
365
|
+
if (v === "disabled" || v === "deleted") {
|
|
366
|
+
return "destructive";
|
|
367
|
+
}
|
|
368
|
+
return "outline";
|
|
369
|
+
}
|
|
370
|
+
function DomainTableRow({
|
|
371
|
+
domain,
|
|
372
|
+
onEdit
|
|
373
|
+
}) {
|
|
374
|
+
return /* @__PURE__ */ jsxs3(Tr, { className: "group", children: [
|
|
375
|
+
/* @__PURE__ */ jsx3(Td, { className: "font-medium", children: domain.domain }),
|
|
376
|
+
/* @__PURE__ */ jsx3(Td, { children: /* @__PURE__ */ jsx3(Badge2, { variant: statusVariant2(domain.status), className: "text-xs", children: domain.status }) }),
|
|
377
|
+
/* @__PURE__ */ jsx3(Td, { children: domain.isPrimary ? "Yes" : "No" }),
|
|
378
|
+
/* @__PURE__ */ jsx3(Td, { className: "text-muted-foreground text-sm", children: domain.updatedAt ? new Date(domain.updatedAt).toLocaleDateString() : "\u2014" }),
|
|
379
|
+
/* @__PURE__ */ jsx3(Td, { children: /* @__PURE__ */ jsx3(DataTableAction, { onClick: () => onEdit(domain.id) }) })
|
|
380
|
+
] });
|
|
381
|
+
}
|
|
382
|
+
function DomainsList({
|
|
383
|
+
data,
|
|
384
|
+
isLoading,
|
|
385
|
+
view,
|
|
386
|
+
pageIndex,
|
|
387
|
+
pageSize,
|
|
388
|
+
pageCount,
|
|
389
|
+
totalRows,
|
|
390
|
+
onPageChange,
|
|
391
|
+
onPageSizeChange,
|
|
392
|
+
onCreateNew
|
|
393
|
+
}) {
|
|
394
|
+
const [editingId, setEditingId] = useState2(null);
|
|
395
|
+
if (isLoading) {
|
|
396
|
+
return /* @__PURE__ */ jsx3(
|
|
397
|
+
EntityLoadingState,
|
|
398
|
+
{
|
|
399
|
+
view,
|
|
400
|
+
rowCount: pageSize,
|
|
401
|
+
columnCount: TABLE_COLUMN_COUNT,
|
|
402
|
+
cardCount: pageSize
|
|
403
|
+
}
|
|
404
|
+
);
|
|
405
|
+
}
|
|
406
|
+
if (totalRows === 0) {
|
|
407
|
+
return /* @__PURE__ */ jsx3(
|
|
408
|
+
EntityEmptyState,
|
|
409
|
+
{
|
|
410
|
+
icon: IconWorld,
|
|
411
|
+
entityName: "domain",
|
|
412
|
+
title: "No domains yet",
|
|
413
|
+
description: "Add your first domain to get started.",
|
|
414
|
+
actionLabel: "Add domain",
|
|
415
|
+
onAction: onCreateNew
|
|
416
|
+
}
|
|
417
|
+
);
|
|
418
|
+
}
|
|
419
|
+
if (view === "table") {
|
|
420
|
+
return /* @__PURE__ */ jsxs3("div", { className: "space-y-4", children: [
|
|
421
|
+
editingId && /* @__PURE__ */ jsx3(
|
|
422
|
+
DomainForm,
|
|
423
|
+
{
|
|
424
|
+
mode: "edit",
|
|
425
|
+
domainId: editingId,
|
|
426
|
+
open: true,
|
|
427
|
+
onClose: () => setEditingId(null)
|
|
428
|
+
}
|
|
429
|
+
),
|
|
430
|
+
/* @__PURE__ */ jsxs3(DisplayTable, { withTableBorder: true, children: [
|
|
431
|
+
/* @__PURE__ */ jsx3(Thead, { children: /* @__PURE__ */ jsxs3(Tr, { children: [
|
|
432
|
+
/* @__PURE__ */ jsx3(Th, { children: "Domain" }),
|
|
433
|
+
/* @__PURE__ */ jsx3(Th, { children: "Status" }),
|
|
434
|
+
/* @__PURE__ */ jsx3(Th, { children: "Primary" }),
|
|
435
|
+
/* @__PURE__ */ jsx3(Th, { children: "Updated" }),
|
|
436
|
+
/* @__PURE__ */ jsx3(Th, { className: "w-[50px]" })
|
|
437
|
+
] }) }),
|
|
438
|
+
/* @__PURE__ */ jsx3(Tbody, { children: data.map((d) => /* @__PURE__ */ jsx3(DomainTableRow, { domain: d, onEdit: setEditingId }, d.id)) })
|
|
439
|
+
] }),
|
|
440
|
+
/* @__PURE__ */ jsx3(
|
|
441
|
+
DataTablePagination,
|
|
442
|
+
{
|
|
443
|
+
pageIndex,
|
|
444
|
+
pageSize,
|
|
445
|
+
pageCount,
|
|
446
|
+
totalRows,
|
|
447
|
+
onPageChange,
|
|
448
|
+
onPageSizeChange
|
|
449
|
+
}
|
|
450
|
+
)
|
|
451
|
+
] });
|
|
452
|
+
}
|
|
453
|
+
return /* @__PURE__ */ jsxs3("div", { className: "space-y-4", children: [
|
|
454
|
+
/* @__PURE__ */ jsx3("div", { className: "grid grid-cols-1 gap-4 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4", children: data.map((d) => /* @__PURE__ */ jsx3(DomainCard, { domain: d }, d.id)) }),
|
|
455
|
+
/* @__PURE__ */ jsx3(
|
|
456
|
+
DataTablePagination,
|
|
457
|
+
{
|
|
458
|
+
pageIndex,
|
|
459
|
+
pageSize,
|
|
460
|
+
pageCount,
|
|
461
|
+
totalRows,
|
|
462
|
+
onPageChange,
|
|
463
|
+
onPageSizeChange
|
|
464
|
+
}
|
|
465
|
+
)
|
|
466
|
+
] });
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
// src/components/iam/domains-page.tsx
|
|
470
|
+
import { jsx as jsx4, jsxs as jsxs4 } from "react/jsx-runtime";
|
|
471
|
+
function DomainsPage() {
|
|
472
|
+
return /* @__PURE__ */ jsx4(IAMGuard, { children: /* @__PURE__ */ jsx4(DomainsPageContent, {}) });
|
|
473
|
+
}
|
|
474
|
+
function DomainsPageContent() {
|
|
475
|
+
const { hooks } = useApi();
|
|
476
|
+
const { config } = useConfig();
|
|
477
|
+
const homeHref = config.navigation?.defaultRedirectUrl || "/";
|
|
478
|
+
useBreadcrumbs({
|
|
479
|
+
items: [
|
|
480
|
+
{ label: "Home", href: homeHref },
|
|
481
|
+
{ label: "IAM", href: "/iam/users" },
|
|
482
|
+
{ label: "Domains" }
|
|
483
|
+
]
|
|
484
|
+
});
|
|
485
|
+
const [createOpen, setCreateOpen] = useState3(false);
|
|
486
|
+
const { params, setParams } = useEntityParams({
|
|
487
|
+
searchKey: "search",
|
|
488
|
+
searchParamName: "search"
|
|
489
|
+
});
|
|
490
|
+
const [statusFilter, setStatusFilter] = useState3("");
|
|
491
|
+
const domainsQuery = useMemo(
|
|
492
|
+
() => ({
|
|
493
|
+
params: {
|
|
494
|
+
query: {
|
|
495
|
+
page: params.page,
|
|
496
|
+
limit: params.pageSize,
|
|
497
|
+
...statusFilter ? {
|
|
498
|
+
status: statusFilter
|
|
499
|
+
} : {}
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
}),
|
|
503
|
+
[params.page, params.pageSize, statusFilter]
|
|
504
|
+
);
|
|
505
|
+
const { data, isPending, isFetching } = hooks.useQuery(
|
|
506
|
+
"get",
|
|
507
|
+
"/domains",
|
|
508
|
+
domainsQuery,
|
|
509
|
+
defaultEntityQueryOptions
|
|
510
|
+
);
|
|
511
|
+
const isLoading = isPending || isFetching;
|
|
512
|
+
const domains = data?.domains ?? [];
|
|
513
|
+
const { total, pageCount } = useEntityPagination({
|
|
514
|
+
items: domains,
|
|
515
|
+
total: data?.total,
|
|
516
|
+
pageSize: params.pageSize
|
|
517
|
+
});
|
|
518
|
+
return /* @__PURE__ */ jsx4(PageContainer, { className: "flex flex-1 flex-col gap-4 p-4 pt-0", children: /* @__PURE__ */ jsxs4(PageBody, { className: "px-0", children: [
|
|
519
|
+
/* @__PURE__ */ jsx4(
|
|
520
|
+
EntityHeader,
|
|
521
|
+
{
|
|
522
|
+
icon: /* @__PURE__ */ jsx4(IconWorld2, { className: "h-5 w-5" }),
|
|
523
|
+
title: "Domains",
|
|
524
|
+
actions: /* @__PURE__ */ jsx4(
|
|
525
|
+
EntityDrawerTrigger,
|
|
526
|
+
{
|
|
527
|
+
mode: "new",
|
|
528
|
+
entity: "Domain",
|
|
529
|
+
label: "Add domain",
|
|
530
|
+
open: createOpen,
|
|
531
|
+
onOpenChange: setCreateOpen,
|
|
532
|
+
children: (open, onClose) => /* @__PURE__ */ jsx4(
|
|
533
|
+
DomainForm,
|
|
534
|
+
{
|
|
535
|
+
open,
|
|
536
|
+
onClose,
|
|
537
|
+
mode: "new",
|
|
538
|
+
onSuccess: () => setCreateOpen(false)
|
|
539
|
+
}
|
|
540
|
+
)
|
|
541
|
+
}
|
|
542
|
+
),
|
|
543
|
+
search: /* @__PURE__ */ jsx4(EntitySearch, { paramKey: "search", placeholder: "Search domains..." }),
|
|
544
|
+
filter: /* @__PURE__ */ jsxs4(
|
|
545
|
+
Select2,
|
|
546
|
+
{
|
|
547
|
+
value: statusFilter || "all",
|
|
548
|
+
onValueChange: (v) => {
|
|
549
|
+
setStatusFilter(v === "all" || v == null ? "" : v);
|
|
550
|
+
setParams({ page: 1 });
|
|
551
|
+
},
|
|
552
|
+
children: [
|
|
553
|
+
/* @__PURE__ */ jsx4(SelectTrigger2, { className: "h-9 min-w-[120px] w-[120px]", children: /* @__PURE__ */ jsx4("span", { className: statusFilter ? "" : "text-muted-foreground", children: statusFilter ? statusFilter : "Status" }) }),
|
|
554
|
+
/* @__PURE__ */ jsxs4(SelectContent2, { children: [
|
|
555
|
+
/* @__PURE__ */ jsx4(SelectItem2, { value: "all", children: "All" }),
|
|
556
|
+
/* @__PURE__ */ jsx4(SelectItem2, { value: "pending", children: "Pending" }),
|
|
557
|
+
/* @__PURE__ */ jsx4(SelectItem2, { value: "active", children: "Active" }),
|
|
558
|
+
/* @__PURE__ */ jsx4(SelectItem2, { value: "disabled", children: "Disabled" }),
|
|
559
|
+
/* @__PURE__ */ jsx4(SelectItem2, { value: "deleted", children: "Deleted" })
|
|
560
|
+
] })
|
|
561
|
+
]
|
|
562
|
+
}
|
|
563
|
+
),
|
|
564
|
+
sort: /* @__PURE__ */ jsx4(
|
|
565
|
+
EntitySort,
|
|
566
|
+
{
|
|
567
|
+
defaultSort: "updatedAt",
|
|
568
|
+
defaultOrder: "desc",
|
|
569
|
+
options: [
|
|
570
|
+
{ label: "Domain", value: "domain" },
|
|
571
|
+
{ label: "Status", value: "status" },
|
|
572
|
+
{ label: "Updated", value: "updatedAt" },
|
|
573
|
+
{ label: "Created", value: "createdAt" }
|
|
574
|
+
]
|
|
575
|
+
}
|
|
576
|
+
),
|
|
577
|
+
view: /* @__PURE__ */ jsx4(EntityViewToggle, { views: ["table", "card"] })
|
|
578
|
+
}
|
|
579
|
+
),
|
|
580
|
+
/* @__PURE__ */ jsx4(
|
|
581
|
+
DomainsList,
|
|
582
|
+
{
|
|
583
|
+
data: domains,
|
|
584
|
+
isLoading,
|
|
585
|
+
view: params.view || "table",
|
|
586
|
+
pageIndex: params.page - 1,
|
|
587
|
+
pageSize: params.pageSize,
|
|
588
|
+
pageCount,
|
|
589
|
+
totalRows: total,
|
|
590
|
+
onCreateNew: () => setCreateOpen(true),
|
|
591
|
+
onPageChange: (p) => setParams({ page: p + 1 }),
|
|
592
|
+
onPageSizeChange: (size) => setParams({ pageSize: size, page: 1 })
|
|
593
|
+
}
|
|
594
|
+
)
|
|
595
|
+
] }) });
|
|
596
|
+
}
|
|
597
|
+
|
|
598
|
+
export {
|
|
599
|
+
DomainsPage
|
|
600
|
+
};
|
|
601
|
+
//# sourceMappingURL=chunk-MWMSZVH3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/components/iam/domains-page.tsx","../src/pages/iam/domains/_components/domain-form.tsx","../src/pages/iam/domains/_components/domains-list.tsx","../src/pages/iam/domains/_components/domain-card.tsx"],"sourcesContent":["'use client';\n\nimport {\n EntityDrawerTrigger,\n EntityHeader,\n EntitySearch,\n EntitySort,\n EntityViewToggle,\n PageBody,\n PageContainer,\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n useBreadcrumbs,\n useEntityPagination,\n useEntityParams,\n} from '@mesob/ui/components';\nimport { IconWorld } from '@tabler/icons-react';\nimport { useMemo, useState } from 'react';\nimport type { paths } from '../../data/openapi';\nimport { defaultEntityQueryOptions } from '../../lib/query-options';\nimport { DomainForm } from '../../pages/iam/domains/_components/domain-form';\nimport { DomainsList } from '../../pages/iam/domains/_components/domains-list';\nimport { useApi, useConfig } from '../../provider';\nimport { IAMGuard } from './iam-guard';\n\nexport function DomainsPage() {\n return (\n <IAMGuard>\n <DomainsPageContent />\n </IAMGuard>\n );\n}\n\nfunction DomainsPageContent() {\n const { hooks } = useApi();\n const { config } = useConfig();\n const homeHref = config.navigation?.defaultRedirectUrl || '/';\n useBreadcrumbs({\n items: [\n { label: 'Home', href: homeHref },\n { label: 'IAM', href: '/iam/users' },\n { label: 'Domains' },\n ],\n });\n const [createOpen, setCreateOpen] = useState(false);\n\n const { params, setParams } = useEntityParams({\n searchKey: 'search',\n searchParamName: 'search',\n });\n const [statusFilter, setStatusFilter] = useState<string>('');\n\n const domainsQuery = useMemo(\n () =>\n ({\n params: {\n query: {\n page: params.page,\n limit: params.pageSize,\n ...(statusFilter\n ? {\n status: statusFilter as\n | 'pending'\n | 'active'\n | 'disabled'\n | 'deleted',\n }\n : {}),\n },\n },\n }) as {\n params: {\n query: NonNullable<paths['/domains']['get']['parameters']['query']>;\n };\n },\n [params.page, params.pageSize, statusFilter],\n );\n\n const { data, isPending, isFetching } = hooks.useQuery(\n 'get',\n '/domains',\n domainsQuery,\n defaultEntityQueryOptions,\n );\n\n const isLoading = isPending || isFetching;\n const domains = data?.domains ?? [];\n const { total, pageCount } = useEntityPagination({\n items: domains,\n total: data?.total,\n pageSize: params.pageSize,\n });\n\n return (\n <PageContainer className=\"flex flex-1 flex-col gap-4 p-4 pt-0\">\n <PageBody className=\"px-0\">\n <EntityHeader\n icon={<IconWorld className=\"h-5 w-5\" />}\n title=\"Domains\"\n actions={\n <EntityDrawerTrigger\n mode=\"new\"\n entity=\"Domain\"\n label=\"Add domain\"\n open={createOpen}\n onOpenChange={setCreateOpen}\n >\n {(open, onClose) => (\n <DomainForm\n open={open}\n onClose={onClose}\n mode=\"new\"\n onSuccess={() => setCreateOpen(false)}\n />\n )}\n </EntityDrawerTrigger>\n }\n search={\n <EntitySearch paramKey=\"search\" placeholder=\"Search domains...\" />\n }\n filter={\n <Select\n value={statusFilter || 'all'}\n onValueChange={(v) => {\n setStatusFilter(v === 'all' || v == null ? '' : v);\n setParams({ page: 1 });\n }}\n >\n <SelectTrigger className=\"h-9 min-w-[120px] w-[120px]\">\n <span className={statusFilter ? '' : 'text-muted-foreground'}>\n {statusFilter ? statusFilter : 'Status'}\n </span>\n </SelectTrigger>\n <SelectContent>\n <SelectItem value=\"all\">All</SelectItem>\n <SelectItem value=\"pending\">Pending</SelectItem>\n <SelectItem value=\"active\">Active</SelectItem>\n <SelectItem value=\"disabled\">Disabled</SelectItem>\n <SelectItem value=\"deleted\">Deleted</SelectItem>\n </SelectContent>\n </Select>\n }\n sort={\n <EntitySort\n defaultSort=\"updatedAt\"\n defaultOrder=\"desc\"\n options={[\n { label: 'Domain', value: 'domain' },\n { label: 'Status', value: 'status' },\n { label: 'Updated', value: 'updatedAt' },\n { label: 'Created', value: 'createdAt' },\n ]}\n />\n }\n view={<EntityViewToggle views={['table', 'card']} />}\n />\n <DomainsList\n data={domains}\n isLoading={isLoading}\n view={(params.view || 'table') as 'table' | 'card'}\n pageIndex={params.page - 1}\n pageSize={params.pageSize}\n pageCount={pageCount}\n totalRows={total}\n onCreateNew={() => setCreateOpen(true)}\n onPageChange={(p) => setParams({ page: p + 1 })}\n onPageSizeChange={(size) => setParams({ pageSize: size, page: 1 })}\n />\n </PageBody>\n </PageContainer>\n );\n}\n","'use client';\n\nimport { zodResolver } from '@hookform/resolvers/zod';\nimport {\n Checkbox,\n EntityDrawer,\n EntityFormActions,\n Form,\n FormControl,\n FormField,\n FormItem,\n FormLabel,\n FormMessage,\n Input,\n Select,\n SelectContent,\n SelectItem,\n SelectTrigger,\n Skeleton,\n Stack,\n} from '@mesob/ui/components';\nimport { useQueryClient } from '@tanstack/react-query';\nimport { useEffect } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { z } from 'zod';\nimport { authApi$ } from '../../shared/page-helpers';\n\nconst statusOptions = [\n { value: 'pending', label: 'Pending' },\n { value: 'active', label: 'Active' },\n { value: 'disabled', label: 'Disabled' },\n { value: 'deleted', label: 'Deleted' },\n] as const;\n\nconst schema = z.object({\n domain: z\n .string()\n .min(1, 'Domain is required')\n .regex(\n /^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)+$/,\n 'Invalid domain format (e.g. example.com)',\n ),\n status: z.enum(['pending', 'active', 'disabled', 'deleted']),\n isPrimary: z.boolean(),\n});\n\ntype FormData = z.infer<typeof schema>;\n\nconst defaults: FormData = {\n domain: '',\n status: 'pending',\n isPrimary: false,\n};\n\ntype DomainFormProps = {\n mode: 'new' | 'edit';\n domainId?: string;\n open: boolean;\n onClose: () => void;\n onSuccess?: () => void;\n};\n\nexport function DomainForm({\n mode,\n domainId,\n open,\n onClose,\n onSuccess,\n}: DomainFormProps) {\n const qc = useQueryClient();\n const { data, isLoading } = authApi$.useQuery(\n 'get',\n '/domains/{id}',\n { params: { path: { id: domainId ?? '' } } },\n { enabled: mode === 'edit' && !!domainId && open },\n );\n const domain = data?.domain;\n\n const form = useForm<FormData>({\n resolver: zodResolver(schema),\n defaultValues: defaults,\n });\n const { control, formState, reset } = form;\n\n useEffect(() => {\n if (!open) {\n return;\n }\n if (mode === 'edit' && domain && !isLoading) {\n reset({\n domain: domain.domain,\n status: (domain.status?.toLowerCase() ??\n 'pending') as FormData['status'],\n isPrimary: domain.isPrimary ?? false,\n });\n } else {\n reset(defaults);\n }\n }, [mode, domain, open, isLoading, reset]);\n\n const create = authApi$.useMutation('post', '/domains', {\n onSuccess: () => {\n qc.invalidateQueries({ queryKey: ['get', '/domains'] });\n },\n });\n const update = authApi$.useMutation('put', '/domains/{id}', {\n onSuccess: () => {\n qc.invalidateQueries({ queryKey: ['get', '/domains'] });\n if (domainId) {\n qc.invalidateQueries({ queryKey: ['get', '/domains/{id}'] });\n }\n },\n });\n const del = authApi$.useMutation('delete', '/domains/{id}', {\n onSuccess: () => {\n qc.invalidateQueries({ queryKey: ['get', '/domains'] });\n },\n });\n\n const onSubmit = form.handleSubmit(async (d) => {\n if (mode === 'new') {\n await create.mutateAsync({\n body: {\n domain: d.domain,\n status: d.status,\n isPrimary: d.isPrimary,\n },\n });\n } else if (domainId) {\n await update.mutateAsync({\n params: { path: { id: domainId } },\n body: {\n domain: d.domain,\n status: d.status,\n isPrimary: d.isPrimary,\n },\n });\n }\n onSuccess?.();\n onClose();\n });\n\n const onDelete = async () => {\n if (!domainId) {\n return;\n }\n await del.mutateAsync({ params: { path: { id: domainId } } });\n onSuccess?.();\n onClose();\n };\n\n const isSubmitting = create.isPending || update.isPending;\n\n return (\n <EntityDrawer\n title={mode === 'new' ? 'New domain' : 'Edit domain'}\n open={open}\n onClose={onClose}\n isDirty={formState.isDirty}\n form={\n isLoading && mode === 'edit' ? (\n <FormSkeleton />\n ) : (\n <Form {...form}>\n <form onSubmit={onSubmit} className=\"space-y-6\">\n <Stack>\n <FormField\n control={control}\n name=\"domain\"\n render={({ field }) => (\n <FormItem>\n <FormLabel>\n Domain <span className=\"text-destructive\">*</span>\n </FormLabel>\n <FormControl>\n <Input\n placeholder=\"example.com\"\n {...field}\n disabled={mode === 'edit'}\n />\n </FormControl>\n <FormMessage />\n </FormItem>\n )}\n />\n <FormField\n control={control}\n name=\"status\"\n render={({ field }) => (\n <FormItem>\n <FormLabel>Status</FormLabel>\n <Select\n value={field.value}\n onValueChange={(v) =>\n field.onChange(v as FormData['status'])\n }\n >\n <FormControl>\n <SelectTrigger>\n {statusOptions.find((o) => o.value === field.value)\n ?.label ?? field.value}\n </SelectTrigger>\n </FormControl>\n <SelectContent>\n {statusOptions.map((o) => (\n <SelectItem key={o.value} value={o.value}>\n {o.label}\n </SelectItem>\n ))}\n </SelectContent>\n </Select>\n <FormMessage />\n </FormItem>\n )}\n />\n <FormField\n control={control}\n name=\"isPrimary\"\n render={({ field }) => (\n <FormItem className=\"flex flex-row items-center gap-2 space-y-0\">\n <FormControl>\n <Checkbox\n size=\"lg\"\n checked={field.value}\n onCheckedChange={(c) => field.onChange(c === true)}\n />\n </FormControl>\n <FormLabel className=\"cursor-pointer font-normal\">\n Primary domain\n </FormLabel>\n <FormMessage />\n </FormItem>\n )}\n />\n </Stack>\n </form>\n </Form>\n )\n }\n actions={\n <EntityFormActions\n mode={mode}\n onSubmit={onSubmit}\n onReset={mode === 'new' ? () => reset(defaults) : undefined}\n onDelete={mode === 'edit' ? onDelete : undefined}\n isSubmitting={isSubmitting}\n isDeleting={del.isPending}\n disabled={isLoading && mode === 'edit'}\n itemName=\"domain\"\n />\n }\n />\n );\n}\n\nfunction FormSkeleton() {\n return (\n <div className=\"space-y-4\">\n {[1, 2, 3].map((i) => (\n <div key={i} className=\"space-y-2\">\n <Skeleton className=\"h-4 w-20\" />\n <Skeleton className=\"h-10 w-full\" />\n </div>\n ))}\n </div>\n );\n}\n","'use client';\n\nimport {\n Badge,\n DataTableAction,\n DataTablePagination,\n DisplayTable,\n EntityEmptyState,\n EntityLoadingState,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n} from '@mesob/ui/components';\nimport { IconWorld } from '@tabler/icons-react';\nimport { useState } from 'react';\nimport { DomainCard } from './domain-card';\nimport { DomainForm } from './domain-form';\nimport type { Domain } from './domains-data';\n\nconst TABLE_COLUMN_COUNT = 5;\n\nfunction statusVariant(\n s: string,\n): 'default' | 'secondary' | 'destructive' | 'outline' {\n const v = s?.toLowerCase();\n if (v === 'active') {\n return 'default';\n }\n if (v === 'pending') {\n return 'secondary';\n }\n if (v === 'disabled' || v === 'deleted') {\n return 'destructive';\n }\n return 'outline';\n}\n\nfunction DomainTableRow({\n domain,\n onEdit,\n}: {\n domain: Domain;\n onEdit: (id: string) => void;\n}) {\n return (\n <Tr className=\"group\">\n <Td className=\"font-medium\">{domain.domain}</Td>\n <Td>\n <Badge variant={statusVariant(domain.status)} className=\"text-xs\">\n {domain.status}\n </Badge>\n </Td>\n <Td>{domain.isPrimary ? 'Yes' : 'No'}</Td>\n <Td className=\"text-muted-foreground text-sm\">\n {domain.updatedAt\n ? new Date(domain.updatedAt).toLocaleDateString()\n : '—'}\n </Td>\n <Td>\n <DataTableAction onClick={() => onEdit(domain.id)} />\n </Td>\n </Tr>\n );\n}\n\ntype DomainsListProps = {\n data: Domain[];\n isLoading?: boolean;\n view: 'table' | 'card';\n pageIndex: number;\n pageSize: number;\n pageCount: number;\n totalRows: number;\n onPageChange: (page: number) => void;\n onPageSizeChange: (size: number) => void;\n onCreateNew?: () => void;\n};\n\nexport function DomainsList({\n data,\n isLoading,\n view,\n pageIndex,\n pageSize,\n pageCount,\n totalRows,\n onPageChange,\n onPageSizeChange,\n onCreateNew,\n}: DomainsListProps) {\n const [editingId, setEditingId] = useState<string | null>(null);\n\n if (isLoading) {\n return (\n <EntityLoadingState\n view={view}\n rowCount={pageSize}\n columnCount={TABLE_COLUMN_COUNT}\n cardCount={pageSize}\n />\n );\n }\n if (totalRows === 0) {\n return (\n <EntityEmptyState\n icon={IconWorld}\n entityName=\"domain\"\n title=\"No domains yet\"\n description=\"Add your first domain to get started.\"\n actionLabel=\"Add domain\"\n onAction={onCreateNew}\n />\n );\n }\n if (view === 'table') {\n return (\n <div className=\"space-y-4\">\n {editingId && (\n <DomainForm\n mode=\"edit\"\n domainId={editingId}\n open\n onClose={() => setEditingId(null)}\n />\n )}\n <DisplayTable withTableBorder>\n <Thead>\n <Tr>\n <Th>Domain</Th>\n <Th>Status</Th>\n <Th>Primary</Th>\n <Th>Updated</Th>\n <Th className=\"w-[50px]\" />\n </Tr>\n </Thead>\n <Tbody>\n {data.map((d) => (\n <DomainTableRow key={d.id} domain={d} onEdit={setEditingId} />\n ))}\n </Tbody>\n </DisplayTable>\n <DataTablePagination\n pageIndex={pageIndex}\n pageSize={pageSize}\n pageCount={pageCount}\n totalRows={totalRows}\n onPageChange={onPageChange}\n onPageSizeChange={onPageSizeChange}\n />\n </div>\n );\n }\n return (\n <div className=\"space-y-4\">\n <div className=\"grid grid-cols-1 gap-4 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4\">\n {data.map((d) => (\n <DomainCard key={d.id} domain={d} />\n ))}\n </div>\n <DataTablePagination\n pageIndex={pageIndex}\n pageSize={pageSize}\n pageCount={pageCount}\n totalRows={totalRows}\n onPageChange={onPageChange}\n onPageSizeChange={onPageSizeChange}\n />\n </div>\n );\n}\n","'use client';\n\nimport {\n Badge,\n Button,\n Card,\n CardContent,\n CardHeader,\n DropdownMenu,\n DropdownMenuContent,\n DropdownMenuItem,\n DropdownMenuPortal,\n DropdownMenuTrigger,\n} from '@mesob/ui/components';\nimport { IconDots, IconPencil } from '@tabler/icons-react';\nimport { useState } from 'react';\nimport { DomainForm } from './domain-form';\nimport type { Domain } from './domains-data';\n\ntype DomainCardProps = { domain: Domain };\n\nfunction statusVariant(\n s: string,\n): 'default' | 'secondary' | 'destructive' | 'outline' {\n const v = s?.toLowerCase();\n if (v === 'active') {\n return 'default';\n }\n if (v === 'pending') {\n return 'secondary';\n }\n if (v === 'disabled' || v === 'deleted') {\n return 'destructive';\n }\n return 'outline';\n}\n\nexport function DomainCard({ domain }: DomainCardProps) {\n const [editOpen, setEditOpen] = useState(false);\n return (\n <>\n <Card className=\"group hover:shadow-md transition-shadow\">\n <CardHeader className=\"pb-2\">\n <div className=\"flex items-start justify-between gap-2\">\n <span className=\"font-semibold truncate\">{domain.domain}</span>\n <DropdownMenu>\n <DropdownMenuTrigger\n render={\n <Button\n variant=\"ghost\"\n size=\"icon\"\n className=\"h-8 w-8 opacity-0 group-hover:opacity-100 transition-opacity\"\n />\n }\n >\n <IconDots className=\"h-4 w-4\" />\n </DropdownMenuTrigger>\n <DropdownMenuPortal>\n <DropdownMenuContent>\n <DropdownMenuItem onClick={() => setEditOpen(true)}>\n <IconPencil className=\"mr-2 h-4 w-4\" />\n Edit\n </DropdownMenuItem>\n </DropdownMenuContent>\n </DropdownMenuPortal>\n </DropdownMenu>\n </div>\n </CardHeader>\n <CardContent className=\"space-y-2\">\n <div className=\"flex flex-wrap gap-1\">\n <Badge variant={statusVariant(domain.status)} className=\"text-xs\">\n {domain.status}\n </Badge>\n {domain.isPrimary && (\n <Badge variant=\"outline\" className=\"text-xs\">\n Primary\n </Badge>\n )}\n </div>\n <p className=\"text-xs text-muted-foreground\">\n Updated{' '}\n {domain.updatedAt\n ? new Date(domain.updatedAt).toLocaleDateString()\n : '—'}\n </p>\n </CardContent>\n </Card>\n {editOpen && (\n <DomainForm\n mode=\"edit\"\n domainId={domain.id}\n open={editOpen}\n onClose={() => setEditOpen(false)}\n />\n )}\n </>\n );\n}\n"],"mappings":"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","names":["Select","SelectContent","SelectItem","SelectTrigger","IconWorld","useState","Badge","useState","jsx","jsxs","jsx","jsxs","statusVariant","Badge","useState","jsx","jsxs","useState","IconWorld","Select","SelectTrigger","SelectContent","SelectItem"]}
|