@cobaltcore-dev/aurora 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +141 -0
- package/dist/client/AuroraApp.d.ts +7 -0
- package/dist/client/AuthProvider-D-5Jpa6F.mjs +100 -0
- package/dist/client/AuthProvider-D-5Jpa6F.mjs.map +1 -0
- package/dist/client/ContentHeader-H8KGY3Wd.mjs +81 -0
- package/dist/client/ContentHeader-H8KGY3Wd.mjs.map +1 -0
- package/dist/client/DeleteFlavorModal-B98oiHWx.mjs +629 -0
- package/dist/client/DeleteFlavorModal-B98oiHWx.mjs.map +1 -0
- package/dist/client/EditSecurityGroupModal-wQVNIVg1.mjs +137 -0
- package/dist/client/EditSecurityGroupModal-wQVNIVg1.mjs.map +1 -0
- package/dist/client/FloatingIpActionModals-qu1NMI5a.mjs +417 -0
- package/dist/client/FloatingIpActionModals-qu1NMI5a.mjs.map +1 -0
- package/dist/client/ImageToastNotifications-wsQDNEh7.mjs +1267 -0
- package/dist/client/ImageToastNotifications-wsQDNEh7.mjs.map +1 -0
- package/dist/client/ListToolbar-CHlkZrpl.mjs +223 -0
- package/dist/client/ListToolbar-CHlkZrpl.mjs.map +1 -0
- package/dist/client/RouteError-BwgDIwJE.mjs +25 -0
- package/dist/client/RouteError-BwgDIwJE.mjs.map +1 -0
- package/dist/client/_auth-CsliQdkJ.mjs +11 -0
- package/dist/client/_auth-CsliQdkJ.mjs.map +1 -0
- package/dist/client/_flavorId-D_A53VYa.mjs +56 -0
- package/dist/client/_flavorId-D_A53VYa.mjs.map +1 -0
- package/dist/client/_flavorId-DbhYLFxY.mjs +190 -0
- package/dist/client/_flavorId-DbhYLFxY.mjs.map +1 -0
- package/dist/client/_floatingIpId-BGgftRBQ.mjs +21 -0
- package/dist/client/_floatingIpId-BGgftRBQ.mjs.map +1 -0
- package/dist/client/_floatingIpId-D5myuLFz.mjs +228 -0
- package/dist/client/_floatingIpId-D5myuLFz.mjs.map +1 -0
- package/dist/client/_imageId-BoHX155h.mjs +27 -0
- package/dist/client/_imageId-BoHX155h.mjs.map +1 -0
- package/dist/client/_imageId-CTa0c3Av.mjs +530 -0
- package/dist/client/_imageId-CTa0c3Av.mjs.map +1 -0
- package/dist/client/_pcaId-C7Lrv1H_.mjs +242 -0
- package/dist/client/_pcaId-C7Lrv1H_.mjs.map +1 -0
- package/dist/client/_pcaId-DBgz5V_9.mjs +21 -0
- package/dist/client/_pcaId-DBgz5V_9.mjs.map +1 -0
- package/dist/client/_projectId-B9fln31N.mjs +8 -0
- package/dist/client/_projectId-B9fln31N.mjs.map +1 -0
- package/dist/client/_projectId-Be1Erj68.mjs +300 -0
- package/dist/client/_projectId-Be1Erj68.mjs.map +1 -0
- package/dist/client/_projectId-C-E4NNgo.mjs +84 -0
- package/dist/client/_projectId-C-E4NNgo.mjs.map +1 -0
- package/dist/client/_projectId-INhedXor.mjs +26 -0
- package/dist/client/_projectId-INhedXor.mjs.map +1 -0
- package/dist/client/_securityGroupId-DQoRQ-yA.mjs +1647 -0
- package/dist/client/_securityGroupId-DQoRQ-yA.mjs.map +1 -0
- package/dist/client/_securityGroupId-ihjy8Lcd.mjs +21 -0
- package/dist/client/_securityGroupId-ihjy8Lcd.mjs.map +1 -0
- package/dist/client/about-oT6ccz8T.mjs +92 -0
- package/dist/client/about-oT6ccz8T.mjs.map +1 -0
- package/dist/client/aurora-D_NPTbo-.mjs +19 -0
- package/dist/client/aurora-D_NPTbo-.mjs.map +1 -0
- package/dist/client/build-eu9eg0zF.mjs +14619 -0
- package/dist/client/build-eu9eg0zF.mjs.map +1 -0
- package/dist/client/buildFilterParams-BDOIRDeD.mjs +15 -0
- package/dist/client/buildFilterParams-BDOIRDeD.mjs.map +1 -0
- package/dist/client/cn-C3laVXMm.mjs +10 -0
- package/dist/client/cn-C3laVXMm.mjs.map +1 -0
- package/dist/client/constants-ByHCdNsI.mjs +128 -0
- package/dist/client/constants-ByHCdNsI.mjs.map +1 -0
- package/dist/client/containers-B_ozmVlx.mjs +74 -0
- package/dist/client/containers-B_ozmVlx.mjs.map +1 -0
- package/dist/client/containers-Dx7TYruP.mjs +7 -0
- package/dist/client/containers-Dx7TYruP.mjs.map +1 -0
- package/dist/client/containers-rn_ntCJu.mjs +3029 -0
- package/dist/client/containers-rn_ntCJu.mjs.map +1 -0
- package/dist/client/flavors-CT4auvLO.mjs +565 -0
- package/dist/client/flavors-CT4auvLO.mjs.map +1 -0
- package/dist/client/flavors-DRZb9LJP.mjs +8 -0
- package/dist/client/flavors-DRZb9LJP.mjs.map +1 -0
- package/dist/client/flavors-DtgMd0Ii.mjs +12 -0
- package/dist/client/flavors-DtgMd0Ii.mjs.map +1 -0
- package/dist/client/floatingips-DG5cFJSZ.mjs +12 -0
- package/dist/client/floatingips-DG5cFJSZ.mjs.map +1 -0
- package/dist/client/floatingips-iCMR0ZiL.mjs +436 -0
- package/dist/client/floatingips-iCMR0ZiL.mjs.map +1 -0
- package/dist/client/formatBytes-GYujK0dP.mjs +38 -0
- package/dist/client/formatBytes-GYujK0dP.mjs.map +1 -0
- package/dist/client/helpers--JWXi40U.mjs +6 -0
- package/dist/client/helpers--JWXi40U.mjs.map +1 -0
- package/dist/client/hooks-s-I8vWww.mjs +2 -0
- package/dist/client/images-BTqRflJv2.mjs +1794 -0
- package/dist/client/images-BTqRflJv2.mjs.map +1 -0
- package/dist/client/images-DRTfx8k2.mjs +8 -0
- package/dist/client/images-DRTfx8k2.mjs.map +1 -0
- package/dist/client/images-xBfsjxkX.mjs +12 -0
- package/dist/client/images-xBfsjxkX.mjs.map +1 -0
- package/dist/client/index.d.ts +1 -0
- package/dist/client/index.js +1033 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/md-CI9FmfYv.mjs +390 -0
- package/dist/client/md-CI9FmfYv.mjs.map +1 -0
- package/dist/client/network-DFVVVNS5.mjs +8 -0
- package/dist/client/network-DFVVVNS5.mjs.map +1 -0
- package/dist/client/objects-CKk6cST_.mjs +4762 -0
- package/dist/client/objects-CKk6cST_.mjs.map +1 -0
- package/dist/client/objects-DkDKVSmQ.mjs +8 -0
- package/dist/client/objects-DkDKVSmQ.mjs.map +1 -0
- package/dist/client/objects-r_Vl31oj.mjs +80 -0
- package/dist/client/objects-r_Vl31oj.mjs.map +1 -0
- package/dist/client/overview-B7pXx6bt.mjs +173 -0
- package/dist/client/overview-B7pXx6bt.mjs.map +1 -0
- package/dist/client/overview-CKGLIu6W.mjs +12 -0
- package/dist/client/overview-CKGLIu6W.mjs.map +1 -0
- package/dist/client/overview-Ca8r3SAz.mjs +16 -0
- package/dist/client/overview-Ca8r3SAz.mjs.map +1 -0
- package/dist/client/overview-DkPM0Od5.mjs +12 -0
- package/dist/client/overview-DkPM0Od5.mjs.map +1 -0
- package/dist/client/overview-Dxm7Ef3X.mjs +12 -0
- package/dist/client/overview-Dxm7Ef3X.mjs.map +1 -0
- package/dist/client/overview-ag4Envez.mjs +16 -0
- package/dist/client/overview-ag4Envez.mjs.map +1 -0
- package/dist/client/pca-BGv7Mprl.mjs +12 -0
- package/dist/client/pca-BGv7Mprl.mjs.map +1 -0
- package/dist/client/pca-DpULpMu5.mjs +167 -0
- package/dist/client/pca-DpULpMu5.mjs.map +1 -0
- package/dist/client/projects-BuN69cxO.mjs +144 -0
- package/dist/client/projects-BuN69cxO.mjs.map +1 -0
- package/dist/client/projects-D1pP0XdA.mjs +12 -0
- package/dist/client/projects-D1pP0XdA.mjs.map +1 -0
- package/dist/client/projects-MbS1USl2.mjs +7 -0
- package/dist/client/projects-MbS1USl2.mjs.map +1 -0
- package/dist/client/projects-_Dfn6eQT.mjs +22 -0
- package/dist/client/projects-_Dfn6eQT.mjs.map +1 -0
- package/dist/client/securitygroups-DURjFfYK.mjs +12 -0
- package/dist/client/securitygroups-DURjFfYK.mjs.map +1 -0
- package/dist/client/securitygroups-KC2qvmH8.mjs +442 -0
- package/dist/client/securitygroups-KC2qvmH8.mjs.map +1 -0
- package/dist/client/trpcClient-BxguzNYF.mjs +57 -0
- package/dist/client/trpcClient-BxguzNYF.mjs.map +1 -0
- package/dist/client/useErrorTranslation-TZVwIAzq.mjs +83 -0
- package/dist/client/useErrorTranslation-TZVwIAzq.mjs.map +1 -0
- package/dist/client/useListWithFiltering-mMX_EfyI.mjs +32 -0
- package/dist/client/useListWithFiltering-mMX_EfyI.mjs.map +1 -0
- package/dist/client/useModal-Dg4CBeqL.mjs +12 -0
- package/dist/client/useModal-Dg4CBeqL.mjs.map +1 -0
- package/dist/client/useProjectId-BWaeJZOy.mjs +11 -0
- package/dist/client/useProjectId-BWaeJZOy.mjs.map +1 -0
- package/dist/server/index.d.ts +35 -0
- package/dist/server/index.js +36514 -0
- package/package.json +129 -0
|
@@ -0,0 +1,417 @@
|
|
|
1
|
+
import { $ as e, D as t, H as n, S as r, W as i, b as a, i as o, q as s, s as c, x as l } from "./build-eu9eg0zF.mjs";
|
|
2
|
+
import { r as u } from "./trpcClient-BxguzNYF.mjs";
|
|
3
|
+
import { t as d } from "./useModal-Dg4CBeqL.mjs";
|
|
4
|
+
import { t as f } from "./useProjectId-BWaeJZOy.mjs";
|
|
5
|
+
import "./hooks-s-I8vWww.mjs";
|
|
6
|
+
import { Fragment as p, jsx as m, jsxs as h } from "react/jsx-runtime";
|
|
7
|
+
import { Trans as g, useLingui as _ } from "@lingui/react";
|
|
8
|
+
import { z as v } from "zod";
|
|
9
|
+
import { useForm as y, useStore as b } from "@tanstack/react-form";
|
|
10
|
+
//#region src/client/routes/_auth/projects/$projectId/network/floatingips/-hooks/useFloatingIpMutations.ts
|
|
11
|
+
var x = () => {
|
|
12
|
+
let e = f(), t = u.useUtils(), n = u.network.floatingIp.update.useMutation({
|
|
13
|
+
onMutate: async (n) => {
|
|
14
|
+
await t.network.floatingIp.list.cancel(), await t.network.floatingIp.getById.cancel({
|
|
15
|
+
project_id: e,
|
|
16
|
+
floatingip_id: n.floatingip_id
|
|
17
|
+
});
|
|
18
|
+
let r = t.network.floatingIp.getById.getData({
|
|
19
|
+
project_id: e,
|
|
20
|
+
floatingip_id: n.floatingip_id
|
|
21
|
+
});
|
|
22
|
+
return t.network.floatingIp.getById.setData({
|
|
23
|
+
project_id: e,
|
|
24
|
+
floatingip_id: n.floatingip_id
|
|
25
|
+
}, (e) => e && {
|
|
26
|
+
...e,
|
|
27
|
+
port_id: n.port_id,
|
|
28
|
+
...n.fixed_ip_address !== void 0 && { fixed_ip_address: n.fixed_ip_address },
|
|
29
|
+
...n.description !== void 0 && { description: n.description },
|
|
30
|
+
...n.distributed !== void 0 && { distributed: n.distributed }
|
|
31
|
+
}), { previousItem: r };
|
|
32
|
+
},
|
|
33
|
+
onError: (n, r, i) => {
|
|
34
|
+
i?.previousItem !== void 0 && t.network.floatingIp.getById.setData({
|
|
35
|
+
project_id: e,
|
|
36
|
+
floatingip_id: r.floatingip_id
|
|
37
|
+
}, i.previousItem);
|
|
38
|
+
},
|
|
39
|
+
onSettled: (n, r, i) => {
|
|
40
|
+
t.network.floatingIp.getById.invalidate({
|
|
41
|
+
project_id: e,
|
|
42
|
+
floatingip_id: i.floatingip_id
|
|
43
|
+
}), t.network.floatingIp.list.invalidate();
|
|
44
|
+
}
|
|
45
|
+
}), r = u.network.floatingIp.delete.useMutation({
|
|
46
|
+
onMutate: async () => {
|
|
47
|
+
await t.network.floatingIp.list.cancel();
|
|
48
|
+
},
|
|
49
|
+
onSettled: () => {
|
|
50
|
+
t.network.floatingIp.list.invalidate();
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
return {
|
|
54
|
+
handleUpdate: async (e, t) => {
|
|
55
|
+
await n.mutateAsync({
|
|
56
|
+
...t,
|
|
57
|
+
floatingip_id: e
|
|
58
|
+
});
|
|
59
|
+
},
|
|
60
|
+
handleDelete: async (t) => {
|
|
61
|
+
await r.mutateAsync({
|
|
62
|
+
project_id: e,
|
|
63
|
+
floatingip_id: t
|
|
64
|
+
});
|
|
65
|
+
},
|
|
66
|
+
isUpdatePending: n.isPending,
|
|
67
|
+
updateError: n.error?.message ?? null,
|
|
68
|
+
isDeletePending: r.isPending,
|
|
69
|
+
deleteError: r.error?.message ?? null
|
|
70
|
+
};
|
|
71
|
+
}, S = ({ floatingIp: e, open: s, onClose: l, onUpdate: d, isLoading: p = !1, error: x = null }) => {
|
|
72
|
+
let { i18n: S, _: C } = _(), w = f(), { floating_ip_address: T } = e, E = v.object({
|
|
73
|
+
port_id: v.string(),
|
|
74
|
+
fixed_ip_address: v.string()
|
|
75
|
+
}), { data: D = [] } = u.network.floatingIp.listAvailablePorts.useQuery({ project_id: w }), O = y({
|
|
76
|
+
defaultValues: {
|
|
77
|
+
port_id: e.port_id ?? "",
|
|
78
|
+
fixed_ip_address: ""
|
|
79
|
+
},
|
|
80
|
+
validators: { onSubmit: E },
|
|
81
|
+
onSubmit: async ({ value: t }) => {
|
|
82
|
+
p || (await d(e.id, {
|
|
83
|
+
project_id: w,
|
|
84
|
+
port_id: t.port_id,
|
|
85
|
+
...t.fixed_ip_address && { fixed_ip_address: t.fixed_ip_address }
|
|
86
|
+
}), k());
|
|
87
|
+
}
|
|
88
|
+
}), k = () => {
|
|
89
|
+
O.reset(), l();
|
|
90
|
+
}, A = b(O.store, (e) => e.values.port_id), j = D.find((e) => e.id === A)?.fixed_ips ?? [];
|
|
91
|
+
return /* @__PURE__ */ h(c, {
|
|
92
|
+
id: e.id,
|
|
93
|
+
open: s,
|
|
94
|
+
size: "large",
|
|
95
|
+
title: S._({
|
|
96
|
+
id: "slWh5C",
|
|
97
|
+
values: { floating_ip_address: T }
|
|
98
|
+
}),
|
|
99
|
+
onCancel: k,
|
|
100
|
+
cancelButtonLabel: S._({ id: "dEgA5A" }),
|
|
101
|
+
confirmButtonLabel: S._({ id: "YuC9dj" }),
|
|
102
|
+
onConfirm: O.handleSubmit,
|
|
103
|
+
disableConfirmButton: p || !A,
|
|
104
|
+
children: [
|
|
105
|
+
x && /* @__PURE__ */ m(a, {
|
|
106
|
+
dismissible: !1,
|
|
107
|
+
variant: "error",
|
|
108
|
+
className: "mb-4",
|
|
109
|
+
children: x
|
|
110
|
+
}),
|
|
111
|
+
p && /* @__PURE__ */ h("div", {
|
|
112
|
+
className: "mb-4 flex items-center justify-center gap-2",
|
|
113
|
+
children: [/* @__PURE__ */ m(i, { variant: "primary" }), /* @__PURE__ */ m("span", {
|
|
114
|
+
className: "text-theme-high text-sm",
|
|
115
|
+
children: /* @__PURE__ */ m(g, { id: "tejJLY" })
|
|
116
|
+
})]
|
|
117
|
+
}),
|
|
118
|
+
!p && /* @__PURE__ */ h(t, {
|
|
119
|
+
className: "mb-0",
|
|
120
|
+
id: "associate-floating-ip-form",
|
|
121
|
+
onSubmit: (e) => {
|
|
122
|
+
e.preventDefault(), O.handleSubmit();
|
|
123
|
+
},
|
|
124
|
+
children: [/* @__PURE__ */ m(o, {
|
|
125
|
+
className: "mb-4",
|
|
126
|
+
children: /* @__PURE__ */ m(O.Field, {
|
|
127
|
+
name: "port_id",
|
|
128
|
+
children: (e) => /* @__PURE__ */ m(r, {
|
|
129
|
+
id: e.name,
|
|
130
|
+
name: e.name,
|
|
131
|
+
value: e.state.value,
|
|
132
|
+
onChange: (t) => {
|
|
133
|
+
let n = typeof t == "string" ? t : "";
|
|
134
|
+
e.handleChange(n);
|
|
135
|
+
let r = D.find((e) => e.id === n)?.fixed_ips ?? [];
|
|
136
|
+
O.setFieldValue("fixed_ip_address", r.length === 1 ? r[0].ip_address : "");
|
|
137
|
+
},
|
|
138
|
+
label: S._({ id: "eks7oA" }),
|
|
139
|
+
placeholder: S._({ id: "UztfYZ" }),
|
|
140
|
+
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
141
|
+
disabled: p,
|
|
142
|
+
children: D.map((e) => /* @__PURE__ */ m(n, {
|
|
143
|
+
value: e.id,
|
|
144
|
+
label: e.name ? `${e.name} (${e.id})` : e.id
|
|
145
|
+
}, e.id))
|
|
146
|
+
})
|
|
147
|
+
})
|
|
148
|
+
}), /* @__PURE__ */ m(o, { children: /* @__PURE__ */ m(O.Field, {
|
|
149
|
+
name: "fixed_ip_address",
|
|
150
|
+
children: (e) => /* @__PURE__ */ m(r, {
|
|
151
|
+
id: e.name,
|
|
152
|
+
name: e.name,
|
|
153
|
+
value: e.state.value,
|
|
154
|
+
onChange: (t) => e.handleChange(typeof t == "string" ? t : ""),
|
|
155
|
+
label: S._({ id: "Nc7QKU" }),
|
|
156
|
+
placeholder: S._({ id: "i41Xuw" }),
|
|
157
|
+
helptext: S._({ id: "PtjzS+" }),
|
|
158
|
+
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
159
|
+
disabled: p || j.length === 0,
|
|
160
|
+
children: j.map(({ ip_address: e }) => /* @__PURE__ */ m(n, {
|
|
161
|
+
value: e,
|
|
162
|
+
label: e
|
|
163
|
+
}, e))
|
|
164
|
+
})
|
|
165
|
+
}) })]
|
|
166
|
+
})
|
|
167
|
+
]
|
|
168
|
+
});
|
|
169
|
+
}, C = ({ floatingIp: n, open: r, onClose: l, onUpdate: u, isLoading: d = !1, error: p = null }) => {
|
|
170
|
+
let { i18n: x, _: S } = _(), C = f(), { floating_ip_address: w } = n, T = y({
|
|
171
|
+
defaultValues: { detach: "" },
|
|
172
|
+
validators: { onSubmit: v.object({ detach: v.string().refine((e) => e === "detach", { message: x._({ id: "dPoCVe" }) }) }) },
|
|
173
|
+
onSubmit: async () => {
|
|
174
|
+
d || (await u(n.id, {
|
|
175
|
+
project_id: C,
|
|
176
|
+
port_id: null
|
|
177
|
+
}), D());
|
|
178
|
+
}
|
|
179
|
+
}), E = b(T.store, (e) => e.isSubmitting || e.values.detach !== "detach"), D = () => {
|
|
180
|
+
T.reset(), l();
|
|
181
|
+
};
|
|
182
|
+
return /* @__PURE__ */ h(c, {
|
|
183
|
+
open: r,
|
|
184
|
+
size: "large",
|
|
185
|
+
title: x._({
|
|
186
|
+
id: "vZUKSz",
|
|
187
|
+
values: { floating_ip_address: w }
|
|
188
|
+
}),
|
|
189
|
+
onCancel: D,
|
|
190
|
+
cancelButtonLabel: x._({ id: "dEgA5A" }),
|
|
191
|
+
confirmButtonLabel: x._({ id: "FOcBn3" }),
|
|
192
|
+
onConfirm: T.handleSubmit,
|
|
193
|
+
disableConfirmButton: d || E,
|
|
194
|
+
children: [
|
|
195
|
+
p && /* @__PURE__ */ m(a, {
|
|
196
|
+
dismissible: !1,
|
|
197
|
+
variant: "error",
|
|
198
|
+
className: "mb-4",
|
|
199
|
+
children: p
|
|
200
|
+
}),
|
|
201
|
+
d && /* @__PURE__ */ h("div", {
|
|
202
|
+
className: "mb-4 flex items-center justify-center gap-2",
|
|
203
|
+
children: [/* @__PURE__ */ m(i, { variant: "primary" }), /* @__PURE__ */ m("span", {
|
|
204
|
+
className: "text-theme-high text-sm",
|
|
205
|
+
children: /* @__PURE__ */ m(g, { id: "D3IRXw" })
|
|
206
|
+
})]
|
|
207
|
+
}),
|
|
208
|
+
/* @__PURE__ */ h(s, {
|
|
209
|
+
gap: "2.5",
|
|
210
|
+
direction: "vertical",
|
|
211
|
+
className: "mb-2.5",
|
|
212
|
+
children: [/* @__PURE__ */ m("p", { children: /* @__PURE__ */ m(g, { id: "0u9jhd" }) }), /* @__PURE__ */ m("p", { children: /* @__PURE__ */ m(g, {
|
|
213
|
+
id: "/BZLRP",
|
|
214
|
+
components: { 0: /* @__PURE__ */ m("strong", {}) }
|
|
215
|
+
}) })]
|
|
216
|
+
}),
|
|
217
|
+
!d && /* @__PURE__ */ m(t, {
|
|
218
|
+
className: "mb-0",
|
|
219
|
+
id: "detach-floating-ip-form",
|
|
220
|
+
onSubmit: (e) => {
|
|
221
|
+
e.preventDefault(), T.handleSubmit();
|
|
222
|
+
},
|
|
223
|
+
children: /* @__PURE__ */ m(o, { children: /* @__PURE__ */ m(T.Field, {
|
|
224
|
+
name: "detach",
|
|
225
|
+
children: (t) => /* @__PURE__ */ m(e, {
|
|
226
|
+
id: t.name,
|
|
227
|
+
name: t.name,
|
|
228
|
+
value: t.state.value,
|
|
229
|
+
onChange: (e) => t.handleChange(e.target.value),
|
|
230
|
+
placeholder: x._({ id: "Eq5PsT" }),
|
|
231
|
+
helptext: x._({ id: "U4fmHG" }),
|
|
232
|
+
disabled: d,
|
|
233
|
+
required: !0
|
|
234
|
+
})
|
|
235
|
+
}) })
|
|
236
|
+
})
|
|
237
|
+
]
|
|
238
|
+
});
|
|
239
|
+
}, w = ({ floatingIp: e, open: n, onClose: r, onUpdate: s, isLoading: u = !1, error: d = null }) => {
|
|
240
|
+
let { i18n: p, _: x } = _(), S = f(), { description: C, floating_ip_address: w } = e, T = v.object({ description: v.string().trim().min(1, p._({ id: "47eI0x" })).max(255, p._({ id: "lZvIXd" })) }), E = y({
|
|
241
|
+
defaultValues: { description: C ?? "" },
|
|
242
|
+
validators: { onSubmit: T },
|
|
243
|
+
onSubmit: async ({ value: t }) => {
|
|
244
|
+
if (u) return;
|
|
245
|
+
let n = {
|
|
246
|
+
project_id: S,
|
|
247
|
+
port_id: e.port_id,
|
|
248
|
+
description: t.description.trim()
|
|
249
|
+
};
|
|
250
|
+
await s(e.id, n), D();
|
|
251
|
+
}
|
|
252
|
+
}), D = () => {
|
|
253
|
+
E.reset(), r();
|
|
254
|
+
}, O = b(E.store, (e) => e.isSubmitting || !e.isDirty);
|
|
255
|
+
return /* @__PURE__ */ h(c, {
|
|
256
|
+
open: n,
|
|
257
|
+
size: "large",
|
|
258
|
+
title: p._({
|
|
259
|
+
id: "n1gB0L",
|
|
260
|
+
values: { floating_ip_address: w }
|
|
261
|
+
}),
|
|
262
|
+
onCancel: D,
|
|
263
|
+
cancelButtonLabel: p._({ id: "dEgA5A" }),
|
|
264
|
+
confirmButtonLabel: p._({ id: "tfDRzk" }),
|
|
265
|
+
disableConfirmButton: u || O,
|
|
266
|
+
onConfirm: E.handleSubmit,
|
|
267
|
+
children: [
|
|
268
|
+
d && /* @__PURE__ */ m(a, {
|
|
269
|
+
dismissible: !1,
|
|
270
|
+
variant: "error",
|
|
271
|
+
className: "mb-4",
|
|
272
|
+
children: d
|
|
273
|
+
}),
|
|
274
|
+
u && /* @__PURE__ */ h("div", {
|
|
275
|
+
className: "mb-4 flex items-center justify-center gap-2",
|
|
276
|
+
children: [/* @__PURE__ */ m(i, { variant: "primary" }), /* @__PURE__ */ m("span", {
|
|
277
|
+
className: "text-theme-high text-sm",
|
|
278
|
+
children: /* @__PURE__ */ m(g, { id: "5g7owI" })
|
|
279
|
+
})]
|
|
280
|
+
}),
|
|
281
|
+
!u && /* @__PURE__ */ m(t, {
|
|
282
|
+
className: "mb-0",
|
|
283
|
+
id: "edit-floating-ip-form",
|
|
284
|
+
onSubmit: (e) => {
|
|
285
|
+
e.preventDefault(), E.handleSubmit();
|
|
286
|
+
},
|
|
287
|
+
children: /* @__PURE__ */ m(o, { children: /* @__PURE__ */ m(E.Field, {
|
|
288
|
+
name: "description",
|
|
289
|
+
children: (e) => /* @__PURE__ */ m(l, {
|
|
290
|
+
id: e.name,
|
|
291
|
+
name: e.name,
|
|
292
|
+
value: e.state.value,
|
|
293
|
+
onChange: (t) => e.handleChange(t.target.value),
|
|
294
|
+
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
295
|
+
label: p._({ id: "Nu4oKW" }),
|
|
296
|
+
placeholder: p._({ id: "Nu4oKW" }),
|
|
297
|
+
disabled: u,
|
|
298
|
+
required: !0
|
|
299
|
+
})
|
|
300
|
+
}) })
|
|
301
|
+
})
|
|
302
|
+
]
|
|
303
|
+
}, e.id);
|
|
304
|
+
}, T = ({ floatingIp: n, open: r, onClose: l, onUpdate: u, isLoading: d = !1, error: f = null }) => {
|
|
305
|
+
let { i18n: p, _: x } = _(), { floating_ip_address: S } = n, C = y({
|
|
306
|
+
defaultValues: { release: "" },
|
|
307
|
+
validators: { onSubmit: v.object({ release: v.string().refine((e) => e === "release", { message: p._({ id: "TPMaxo" }) }) }) },
|
|
308
|
+
onSubmit: async () => {
|
|
309
|
+
d || (await u(n.id), T());
|
|
310
|
+
}
|
|
311
|
+
}), w = b(C.store, (e) => e.isSubmitting || e.values.release !== "release"), T = () => {
|
|
312
|
+
C.reset(), l();
|
|
313
|
+
};
|
|
314
|
+
return /* @__PURE__ */ h(c, {
|
|
315
|
+
open: r,
|
|
316
|
+
size: "large",
|
|
317
|
+
title: p._({
|
|
318
|
+
id: "Ovofy+",
|
|
319
|
+
values: { floating_ip_address: S }
|
|
320
|
+
}),
|
|
321
|
+
onCancel: T,
|
|
322
|
+
cancelButtonLabel: p._({ id: "dEgA5A" }),
|
|
323
|
+
confirmButtonLabel: p._({ id: "H+a5j6" }),
|
|
324
|
+
onConfirm: C.handleSubmit,
|
|
325
|
+
disableConfirmButton: d || w,
|
|
326
|
+
children: [
|
|
327
|
+
f && /* @__PURE__ */ m(a, {
|
|
328
|
+
dismissible: !1,
|
|
329
|
+
variant: "error",
|
|
330
|
+
className: "mb-4",
|
|
331
|
+
children: f
|
|
332
|
+
}),
|
|
333
|
+
d && /* @__PURE__ */ h("div", {
|
|
334
|
+
className: "mb-4 flex items-center justify-center gap-2",
|
|
335
|
+
children: [/* @__PURE__ */ m(i, { variant: "primary" }), /* @__PURE__ */ m("span", {
|
|
336
|
+
className: "text-theme-high text-sm",
|
|
337
|
+
children: /* @__PURE__ */ m(g, { id: "Yin3uB" })
|
|
338
|
+
})]
|
|
339
|
+
}),
|
|
340
|
+
/* @__PURE__ */ h(s, {
|
|
341
|
+
gap: "2.5",
|
|
342
|
+
direction: "vertical",
|
|
343
|
+
className: "mb-2.5",
|
|
344
|
+
children: [/* @__PURE__ */ m("p", { children: /* @__PURE__ */ m(g, { id: "w3bAcf" }) }), /* @__PURE__ */ m("p", { children: /* @__PURE__ */ m(g, {
|
|
345
|
+
id: "LqMb+g",
|
|
346
|
+
components: { 0: /* @__PURE__ */ m("strong", {}) }
|
|
347
|
+
}) })]
|
|
348
|
+
}),
|
|
349
|
+
!d && /* @__PURE__ */ m(t, {
|
|
350
|
+
className: "mb-0",
|
|
351
|
+
id: "release-floating-ip-form",
|
|
352
|
+
onSubmit: (e) => {
|
|
353
|
+
e.preventDefault(), C.handleSubmit();
|
|
354
|
+
},
|
|
355
|
+
children: /* @__PURE__ */ m(o, { children: /* @__PURE__ */ m(C.Field, {
|
|
356
|
+
name: "release",
|
|
357
|
+
children: (t) => /* @__PURE__ */ m(e, {
|
|
358
|
+
id: t.name,
|
|
359
|
+
name: t.name,
|
|
360
|
+
value: t.state.value,
|
|
361
|
+
onChange: (e) => t.handleChange(e.target.value),
|
|
362
|
+
placeholder: p._({ id: "N5I2RJ" }),
|
|
363
|
+
helptext: p._({ id: "mYnJeY" }),
|
|
364
|
+
disabled: d,
|
|
365
|
+
required: !0
|
|
366
|
+
})
|
|
367
|
+
}) })
|
|
368
|
+
})
|
|
369
|
+
]
|
|
370
|
+
});
|
|
371
|
+
}, E = ({ floatingIp: e, children: t }) => {
|
|
372
|
+
let [n, r] = d(!1), [i, a] = d(!1), [o, s] = d(!1), [c, l] = d(!1), { handleUpdate: u, handleDelete: f, isUpdatePending: g, updateError: _, isDeletePending: v, deleteError: y } = x();
|
|
373
|
+
return /* @__PURE__ */ h(p, { children: [
|
|
374
|
+
t({
|
|
375
|
+
toggleEditModal: r,
|
|
376
|
+
toggleAttachModal: a,
|
|
377
|
+
toggleDetachModal: s,
|
|
378
|
+
toggleReleaseModal: l
|
|
379
|
+
}),
|
|
380
|
+
n && /* @__PURE__ */ m(w, {
|
|
381
|
+
floatingIp: e,
|
|
382
|
+
open: n,
|
|
383
|
+
onClose: r,
|
|
384
|
+
onUpdate: u,
|
|
385
|
+
isLoading: g,
|
|
386
|
+
error: _
|
|
387
|
+
}),
|
|
388
|
+
i && /* @__PURE__ */ m(S, {
|
|
389
|
+
floatingIp: e,
|
|
390
|
+
open: i,
|
|
391
|
+
onClose: a,
|
|
392
|
+
onUpdate: u,
|
|
393
|
+
isLoading: g,
|
|
394
|
+
error: _
|
|
395
|
+
}),
|
|
396
|
+
o && /* @__PURE__ */ m(C, {
|
|
397
|
+
floatingIp: e,
|
|
398
|
+
open: o,
|
|
399
|
+
onClose: s,
|
|
400
|
+
onUpdate: u,
|
|
401
|
+
isLoading: g,
|
|
402
|
+
error: _
|
|
403
|
+
}),
|
|
404
|
+
c && /* @__PURE__ */ m(T, {
|
|
405
|
+
floatingIp: e,
|
|
406
|
+
open: c,
|
|
407
|
+
onClose: l,
|
|
408
|
+
onUpdate: f,
|
|
409
|
+
isLoading: v,
|
|
410
|
+
error: y
|
|
411
|
+
})
|
|
412
|
+
] });
|
|
413
|
+
};
|
|
414
|
+
//#endregion
|
|
415
|
+
export { E as t };
|
|
416
|
+
|
|
417
|
+
//# sourceMappingURL=FloatingIpActionModals-qu1NMI5a.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FloatingIpActionModals-qu1NMI5a.mjs","names":["trpcReact","useProjectId","useFloatingIpMutations","projectId","utils","useUtils","updateMutation","network","floatingIp","update","useMutation","onMutate","variables","list","cancel","getById","project_id","floatingip_id","previousItem","getData","setData","old","port_id","fixed_ip_address","undefined","description","distributed","onError","_err","context","onSettled","_data","_error","invalidate","deleteMutation","delete","handleUpdate","floatingIpId","data","mutateAsync","handleDelete","isUpdatePending","isPending","updateError","error","message","isDeletePending","deleteError","z","useForm","useStore","Modal","Form","FormSection","Spinner","Message","Select","SelectOption","trpcReact","useProjectId","AssociateFloatingIpModal","floatingIp","open","onClose","onUpdate","isLoading","error","useLingui","projectId","floating_ip_address","formSchema","object","port_id","string","fixed_ip_address","data","availablePorts","network","listAvailablePorts","useQuery","project_id","form","defaultValues","validators","onSubmit","value","id","handleClose","reset","currentPortId","store","state","values","selectedPort","find","port","portFixedIps","fixed_ips","size","title","t","onCancel","cancelButtonLabel","confirmButtonLabel","onConfirm","handleSubmit","disableConfirmButton","dismissible","variant","className","div","span","e","preventDefault","Field","name","children","field","onChange","portId","handleChange","p","ips","setFieldValue","length","ip_address","label","placeholder","errortext","meta","errors","map","message","join","disabled","helptext","z","useForm","useStore","Modal","Form","FormSection","Spinner","Message","TextInput","Stack","useProjectId","DetachFloatingIpModal","floatingIp","open","onClose","onUpdate","isLoading","error","useLingui","projectId","floating_ip_address","formSchema","object","detach","string","refine","value","message","t","form","defaultValues","validators","onSubmit","id","project_id","port_id","handleClose","canDetach","store","state","isSubmitting","values","reset","size","title","onCancel","cancelButtonLabel","confirmButtonLabel","onConfirm","handleSubmit","disableConfirmButton","dismissible","variant","className","div","span","gap","direction","p","strong","e","preventDefault","Field","name","children","field","onChange","handleChange","target","placeholder","helptext","disabled","required","z","useForm","useStore","Modal","Form","FormSection","Spinner","Textarea","Message","useProjectId","EditFloatingIpModal","floatingIp","open","onClose","onUpdate","isLoading","error","useLingui","projectId","description","floating_ip_address","formSchema","object","string","trim","min","t","max","form","defaultValues","validators","onSubmit","value","updateData","project_id","port_id","id","handleClose","reset","enableConfirmButton","store","state","isSubmitting","isDirty","size","title","onCancel","cancelButtonLabel","confirmButtonLabel","disableConfirmButton","onConfirm","handleSubmit","dismissible","variant","className","div","span","e","preventDefault","Field","name","children","field","onChange","handleChange","target","errortext","meta","errors","map","message","join","label","placeholder","disabled","required","z","useForm","useStore","Modal","Form","FormSection","Spinner","Message","TextInput","Stack","ReleaseFloatingIpModal","floatingIp","open","onClose","onUpdate","isLoading","error","useLingui","floating_ip_address","formSchema","object","release","string","refine","value","message","t","form","defaultValues","validators","onSubmit","id","handleClose","canRelease","store","state","isSubmitting","values","reset","size","title","onCancel","cancelButtonLabel","confirmButtonLabel","onConfirm","handleSubmit","disableConfirmButton","dismissible","variant","className","div","span","gap","direction","p","strong","e","preventDefault","Field","name","children","field","onChange","handleChange","target","placeholder","helptext","disabled","required","useModal","useFloatingIpMutations","AssociateFloatingIpModal","DetachFloatingIpModal","EditFloatingIpModal","ReleaseFloatingIpModal","FloatingIpActionModals","floatingIp","children","editModalOpen","toggleEditModal","attachModalOpen","toggleAttachModal","detachModalOpen","toggleDetachModal","releaseModalOpen","toggleReleaseModal","handleUpdate","handleDelete","isUpdatePending","updateError","isDeletePending","deleteError","open","onClose","onUpdate","isLoading","error"],"sources":["../../src/client/routes/_auth/projects/$projectId/network/floatingips/-hooks/useFloatingIpMutations.ts","../../src/client/routes/_auth/projects/$projectId/network/floatingips/-components/-modals/AssociateFloatingIpModal.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/-components/-modals/DetachFloatingIpModal.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/-components/-modals/EditFloatingIpModal.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/-components/-modals/ReleaseFloatingIpModal.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/-components/-modals/FloatingIpActionModals.tsx"],"sourcesContent":["import { trpcReact } from \"@/client/trpcClient\"\nimport { useProjectId } from \"@/client/hooks\"\nimport type { FloatingIpUpdateFields } from \"../-components/-modals/EditFloatingIpModal\"\n\nexport const useFloatingIpMutations = () => {\n const projectId = useProjectId()\n const utils = trpcReact.useUtils()\n\n const updateMutation = trpcReact.network.floatingIp.update.useMutation({\n onMutate: async (variables) => {\n await utils.network.floatingIp.list.cancel()\n await utils.network.floatingIp.getById.cancel({ project_id: projectId, floatingip_id: variables.floatingip_id })\n const previousItem = utils.network.floatingIp.getById.getData({\n project_id: projectId,\n floatingip_id: variables.floatingip_id,\n })\n utils.network.floatingIp.getById.setData(\n { project_id: projectId, floatingip_id: variables.floatingip_id },\n (old) =>\n old\n ? {\n ...old,\n port_id: variables.port_id,\n ...(variables.fixed_ip_address !== undefined && { fixed_ip_address: variables.fixed_ip_address }),\n ...(variables.description !== undefined && { description: variables.description }),\n ...(variables.distributed !== undefined && { distributed: variables.distributed }),\n }\n : old\n )\n return { previousItem }\n },\n onError: (_err, variables, context) => {\n if (context?.previousItem !== undefined) {\n utils.network.floatingIp.getById.setData(\n { project_id: projectId, floatingip_id: variables.floatingip_id },\n context.previousItem\n )\n }\n },\n onSettled: (_data, _error, variables) => {\n utils.network.floatingIp.getById.invalidate({ project_id: projectId, floatingip_id: variables.floatingip_id })\n utils.network.floatingIp.list.invalidate()\n },\n })\n\n const deleteMutation = trpcReact.network.floatingIp.delete.useMutation({\n onMutate: async () => {\n await utils.network.floatingIp.list.cancel()\n },\n onSettled: () => {\n utils.network.floatingIp.list.invalidate()\n },\n })\n\n const handleUpdate = async (floatingIpId: string, data: FloatingIpUpdateFields) => {\n await updateMutation.mutateAsync({\n ...data,\n floatingip_id: floatingIpId,\n })\n }\n\n const handleDelete = async (floatingIpId: string) => {\n await deleteMutation.mutateAsync({\n project_id: projectId,\n floatingip_id: floatingIpId,\n })\n }\n\n return {\n handleUpdate,\n handleDelete,\n isUpdatePending: updateMutation.isPending,\n updateError: updateMutation.error?.message ?? null,\n isDeletePending: deleteMutation.isPending,\n deleteError: deleteMutation.error?.message ?? null,\n }\n}\n","import { z } from \"zod\"\nimport { useForm, useStore } from \"@tanstack/react-form\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Modal, Form, FormSection, Spinner, Message, Select, SelectOption } from \"@cloudoperators/juno-ui-components\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { FloatingIpUpdateFields } from \"./EditFloatingIpModal\"\n\nexport interface AssociateFloatingIpModalProps {\n floatingIp: FloatingIp\n open: boolean\n onClose: () => void\n onUpdate: (floatingIpId: string, data: FloatingIpUpdateFields) => Promise<void>\n isLoading?: boolean\n error?: string | null\n}\n\nexport const AssociateFloatingIpModal = ({\n floatingIp,\n open,\n onClose,\n onUpdate,\n isLoading = false,\n error = null,\n}: AssociateFloatingIpModalProps) => {\n const { t } = useLingui()\n const projectId = useProjectId()\n const { floating_ip_address } = floatingIp\n\n const formSchema = z.object({\n port_id: z.string(),\n fixed_ip_address: z.string(),\n })\n\n const { data: availablePorts = [] } = trpcReact.network.floatingIp.listAvailablePorts.useQuery({\n project_id: projectId,\n })\n\n const form = useForm({\n defaultValues: {\n port_id: floatingIp.port_id ?? \"\",\n fixed_ip_address: \"\",\n },\n validators: {\n onSubmit: formSchema,\n },\n onSubmit: async ({ value }) => {\n if (isLoading) return\n\n await onUpdate(floatingIp.id, {\n project_id: projectId,\n port_id: value.port_id,\n ...(value.fixed_ip_address && {\n fixed_ip_address: value.fixed_ip_address,\n }),\n })\n handleClose()\n },\n })\n\n const handleClose = () => {\n form.reset()\n onClose()\n }\n\n const currentPortId = useStore(form.store, (state) => state.values.port_id)\n const selectedPort = availablePorts.find((port) => port.id === currentPortId)\n const portFixedIps = selectedPort?.fixed_ips ?? []\n\n return (\n <Modal\n id={floatingIp.id}\n open={open}\n size=\"large\"\n title={t`Associate Floating IP ${floating_ip_address} with Port`}\n onCancel={handleClose}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Associate`}\n onConfirm={form.handleSubmit}\n disableConfirmButton={isLoading || !currentPortId}\n >\n {error && (\n <Message dismissible={false} variant=\"error\" className=\"mb-4\">\n {error}\n </Message>\n )}\n\n {isLoading && (\n <div className=\"mb-4 flex items-center justify-center gap-2\">\n <Spinner variant=\"primary\" />\n <span className=\"text-theme-high text-sm\">\n <Trans>Associating Floating IP...</Trans>\n </span>\n </div>\n )}\n\n {!isLoading && (\n <Form\n className=\"mb-0\"\n id=\"associate-floating-ip-form\"\n onSubmit={(e) => {\n e.preventDefault()\n form.handleSubmit()\n }}\n >\n <FormSection className=\"mb-4\">\n <form.Field\n name=\"port_id\"\n children={(field) => (\n <Select\n id={field.name}\n name={field.name}\n value={field.state.value}\n onChange={(value) => {\n const portId = typeof value === \"string\" ? value : \"\"\n field.handleChange(portId)\n const port = availablePorts.find((p) => p.id === portId)\n const ips = port?.fixed_ips ?? []\n form.setFieldValue(\"fixed_ip_address\", ips.length === 1 ? ips[0].ip_address : \"\")\n }}\n label={t`Port ID`}\n placeholder={t`Select port to associate`}\n errortext={field.state.meta.errors.map((e) => e?.message).join(\", \")}\n disabled={isLoading}\n >\n {availablePorts.map((port) => (\n <SelectOption\n key={port.id}\n value={port.id}\n label={port.name ? `${port.name} (${port.id})` : port.id}\n />\n ))}\n </Select>\n )}\n />\n </FormSection>\n <FormSection>\n <form.Field\n name=\"fixed_ip_address\"\n children={(field) => (\n <Select\n id={field.name}\n name={field.name}\n value={field.state.value}\n onChange={(value) => field.handleChange(typeof value === \"string\" ? value : \"\")}\n label={t`Fixed IP Address`}\n placeholder={t`Select a fixed IP address`}\n helptext={t`Associates on the selected port. If the port has multiple IPs, select the desired fixed IP address.`}\n errortext={field.state.meta.errors.map((e) => e?.message).join(\", \")}\n disabled={isLoading || portFixedIps.length === 0}\n >\n {portFixedIps.map(({ ip_address }) => (\n <SelectOption key={ip_address} value={ip_address} label={ip_address} />\n ))}\n </Select>\n )}\n />\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import { z } from \"zod\"\nimport { useForm, useStore } from \"@tanstack/react-form\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Modal, Form, FormSection, Spinner, Message, TextInput, Stack } from \"@cloudoperators/juno-ui-components\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { FloatingIpUpdateFields } from \"./EditFloatingIpModal\"\n\nexport interface DetachFloatingIpModalProps {\n floatingIp: FloatingIp\n open: boolean\n onClose: () => void\n onUpdate: (floatingIpId: string, data: FloatingIpUpdateFields) => Promise<void>\n isLoading?: boolean\n error?: string | null\n}\n\nexport const DetachFloatingIpModal = ({\n floatingIp,\n open,\n onClose,\n onUpdate,\n isLoading = false,\n error = null,\n}: DetachFloatingIpModalProps) => {\n const { t } = useLingui()\n const projectId = useProjectId()\n const { floating_ip_address } = floatingIp\n\n const formSchema = z.object({\n detach: z.string().refine((value) => value === \"detach\", {\n message: t`Type “detach” to confirm`,\n }),\n })\n\n const form = useForm({\n defaultValues: {\n detach: \"\",\n },\n validators: {\n onSubmit: formSchema,\n },\n onSubmit: async () => {\n if (isLoading) return\n\n await onUpdate(floatingIp.id, {\n project_id: projectId,\n port_id: null, // Detach by clearing the port association\n })\n handleClose()\n },\n })\n\n // creates a reactive subscription so the component re-renders, which allows the confirm button to enable once the user types \"detach\".\n const canDetach = useStore(form.store, (state) => state.isSubmitting || state.values.detach !== \"detach\")\n\n const handleClose = () => {\n form.reset()\n onClose()\n }\n\n return (\n <Modal\n open={open}\n size=\"large\"\n title={t`Detach Floating IP ${floating_ip_address}`}\n onCancel={handleClose}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Detach`}\n onConfirm={form.handleSubmit}\n disableConfirmButton={isLoading || canDetach}\n >\n {error && (\n <Message dismissible={false} variant=\"error\" className=\"mb-4\">\n {error}\n </Message>\n )}\n\n {isLoading && (\n <div className=\"mb-4 flex items-center justify-center gap-2\">\n <Spinner variant=\"primary\" />\n <span className=\"text-theme-high text-sm\">\n <Trans>Detaching Floating IP...</Trans>\n </span>\n </div>\n )}\n\n <Stack gap=\"2.5\" direction=\"vertical\" className=\"mb-2.5\">\n <p>\n <Trans>\n Detaching this Floating IP will remove its association with the current port. The instance will no longer be\n reachable through this address.\n </Trans>\n </p>\n <p>\n <Trans>\n To confirm this action, type the word <strong>“detach”</strong> in the field below.\n </Trans>\n </p>\n </Stack>\n\n {!isLoading && (\n <Form\n className=\"mb-0\"\n id=\"detach-floating-ip-form\"\n onSubmit={(e) => {\n e.preventDefault()\n form.handleSubmit()\n }}\n >\n <FormSection>\n <form.Field\n name=\"detach\"\n children={(field) => (\n <TextInput\n id={field.name}\n name={field.name}\n value={field.state.value}\n onChange={(e) => field.handleChange(e.target.value)}\n placeholder={t`Type \"detach\" to confirm`}\n helptext={t`The text must match “detach” in lowercase.`}\n disabled={isLoading}\n required\n />\n )}\n />\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import { z } from \"zod\"\nimport { useForm, useStore } from \"@tanstack/react-form\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Modal, Form, FormSection, Spinner, Textarea, Message } from \"@cloudoperators/juno-ui-components\"\nimport { useProjectId } from \"@/client/hooks\"\nimport type { FloatingIp, FloatingIpUpdateRequest } from \"@/server/Network/types/floatingIp\"\n\nexport type FloatingIpUpdateFields = Omit<FloatingIpUpdateRequest, \"floatingip_id\">\n\nexport interface EditFloatingIpModalProps {\n floatingIp: FloatingIp\n open: boolean\n onClose: () => void\n onUpdate: (floatingIpId: string, data: FloatingIpUpdateFields) => Promise<void>\n isLoading?: boolean\n error?: string | null\n}\n\nexport const EditFloatingIpModal = ({\n floatingIp,\n open,\n onClose,\n onUpdate,\n isLoading = false,\n error = null,\n}: EditFloatingIpModalProps) => {\n const { t } = useLingui()\n const projectId = useProjectId()\n const { description, floating_ip_address } = floatingIp\n\n const formSchema = z.object({\n description: z\n .string()\n .trim()\n .min(1, t`Description must be at least 1 character.`)\n .max(255, t`Description must be at most 255 characters.`),\n })\n\n const form = useForm({\n defaultValues: {\n description: description ?? \"\",\n },\n validators: {\n onSubmit: formSchema,\n },\n onSubmit: async ({ value }) => {\n if (isLoading) return\n\n const updateData: FloatingIpUpdateFields = {\n project_id: projectId,\n // we are passing port so that port association is not lost when updating description as api requires this field\n port_id: floatingIp.port_id,\n description: value.description.trim(),\n }\n await onUpdate(floatingIp.id, updateData)\n handleClose()\n },\n })\n\n const handleClose = () => {\n form.reset()\n onClose()\n }\n\n // creates a reactive subscription so the component re-renders, which allows the confirm button to be enabled once the user edit description field.\n const enableConfirmButton = useStore(form.store, (state) => state.isSubmitting || !state.isDirty)\n\n return (\n <Modal\n // Remount the modal when a different Floating IP is selected so TanStack Form picks up fresh defaultValues.\n key={floatingIp.id}\n open={open}\n size=\"large\"\n title={t`Edit Floating IP ${floating_ip_address}`}\n onCancel={handleClose}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Save`}\n disableConfirmButton={isLoading || enableConfirmButton}\n onConfirm={form.handleSubmit}\n >\n {error && (\n <Message dismissible={false} variant=\"error\" className=\"mb-4\">\n {error}\n </Message>\n )}\n\n {isLoading && (\n <div className=\"mb-4 flex items-center justify-center gap-2\">\n <Spinner variant=\"primary\" />\n <span className=\"text-theme-high text-sm\">\n <Trans>Updating Floating IP...</Trans>\n </span>\n </div>\n )}\n\n {!isLoading && (\n <Form\n className=\"mb-0\"\n id=\"edit-floating-ip-form\"\n onSubmit={(e) => {\n e.preventDefault()\n form.handleSubmit()\n }}\n >\n <FormSection>\n <form.Field\n name=\"description\"\n children={(field) => (\n <Textarea\n id={field.name}\n name={field.name}\n value={field.state.value}\n onChange={(e) => field.handleChange(e.target.value)}\n errortext={field.state.meta.errors.map((e) => e?.message).join(\", \")}\n label={t`Description`}\n placeholder={t`Description`}\n disabled={isLoading}\n required\n />\n )}\n />\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import { z } from \"zod\"\nimport { useForm, useStore } from \"@tanstack/react-form\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Modal, Form, FormSection, Spinner, Message, TextInput, Stack } from \"@cloudoperators/juno-ui-components\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\n\nexport interface ReleaseFloatingIpModalProps {\n floatingIp: FloatingIp\n open: boolean\n onClose: () => void\n onUpdate: (floatingIpId: string) => Promise<void>\n isLoading?: boolean\n error?: string | null\n}\n\nexport const ReleaseFloatingIpModal = ({\n floatingIp,\n open,\n onClose,\n onUpdate,\n isLoading = false,\n error = null,\n}: ReleaseFloatingIpModalProps) => {\n const { t } = useLingui()\n const { floating_ip_address } = floatingIp\n\n const formSchema = z.object({\n release: z.string().refine((value) => value === \"release\", {\n message: t`Type “release” to confirm`,\n }),\n })\n\n const form = useForm({\n defaultValues: {\n release: \"\",\n },\n validators: {\n onSubmit: formSchema,\n },\n onSubmit: async () => {\n if (isLoading) return\n\n await onUpdate(floatingIp.id)\n handleClose()\n },\n })\n\n // creates a reactive subscription so the component re-renders, which allows the confirm button to enable once the user types \"release\".\n const canRelease = useStore(form.store, (state) => state.isSubmitting || state.values.release !== \"release\")\n\n const handleClose = () => {\n form.reset()\n onClose()\n }\n\n return (\n <Modal\n open={open}\n size=\"large\"\n title={t`Release Floating IP ${floating_ip_address}`}\n onCancel={handleClose}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Release`}\n onConfirm={form.handleSubmit}\n disableConfirmButton={isLoading || canRelease}\n >\n {error && (\n <Message dismissible={false} variant=\"error\" className=\"mb-4\">\n {error}\n </Message>\n )}\n\n {isLoading && (\n <div className=\"mb-4 flex items-center justify-center gap-2\">\n <Spinner variant=\"primary\" />\n <span className=\"text-theme-high text-sm\">\n <Trans>Releasing Floating IP...</Trans>\n </span>\n </div>\n )}\n\n <Stack gap=\"2.5\" direction=\"vertical\" className=\"mb-2.5\">\n <p>\n <Trans>\n This action is permanent. The address will be removed from your project and returned to the public pool.\n This action cannot be undone.\n </Trans>\n </p>\n <p>\n <Trans>\n To confirm this action, type the word <strong>\"release\"</strong> in the field below.\n </Trans>\n </p>\n </Stack>\n\n {!isLoading && (\n <Form\n className=\"mb-0\"\n id=\"release-floating-ip-form\"\n onSubmit={(e) => {\n e.preventDefault()\n form.handleSubmit()\n }}\n >\n <FormSection>\n <form.Field\n name=\"release\"\n children={(field) => (\n <TextInput\n id={field.name}\n name={field.name}\n value={field.state.value}\n onChange={(e) => field.handleChange(e.target.value)}\n placeholder={t`Type \"release\" to confirm`}\n helptext={t`The text must match “release” in lowercase.`}\n disabled={isLoading}\n required\n />\n )}\n />\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import type { ReactNode } from \"react\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\nimport { useModal } from \"@/client/utils/useModal\"\nimport { useFloatingIpMutations } from \"../../-hooks/useFloatingIpMutations\"\nimport { AssociateFloatingIpModal } from \"./AssociateFloatingIpModal\"\nimport { DetachFloatingIpModal } from \"./DetachFloatingIpModal\"\nimport { EditFloatingIpModal } from \"./EditFloatingIpModal\"\nimport { ReleaseFloatingIpModal } from \"./ReleaseFloatingIpModal\"\n\nexport interface FloatingIpActionModalTriggers {\n toggleEditModal: () => void\n toggleAttachModal: () => void\n toggleDetachModal: () => void\n toggleReleaseModal: () => void\n}\n\ninterface FloatingIpActionModalsProps {\n floatingIp: FloatingIp\n children: (triggers: FloatingIpActionModalTriggers) => ReactNode\n}\n\nexport const FloatingIpActionModals = ({ floatingIp, children }: FloatingIpActionModalsProps) => {\n const [editModalOpen, toggleEditModal] = useModal(false)\n const [attachModalOpen, toggleAttachModal] = useModal(false)\n const [detachModalOpen, toggleDetachModal] = useModal(false)\n const [releaseModalOpen, toggleReleaseModal] = useModal(false)\n\n const { handleUpdate, handleDelete, isUpdatePending, updateError, isDeletePending, deleteError } =\n useFloatingIpMutations()\n\n return (\n <>\n {children({\n toggleEditModal,\n toggleAttachModal,\n toggleDetachModal,\n toggleReleaseModal,\n })}\n\n {editModalOpen && (\n <EditFloatingIpModal\n floatingIp={floatingIp}\n open={editModalOpen}\n onClose={toggleEditModal}\n onUpdate={handleUpdate}\n isLoading={isUpdatePending}\n error={updateError}\n />\n )}\n\n {attachModalOpen && (\n <AssociateFloatingIpModal\n floatingIp={floatingIp}\n open={attachModalOpen}\n onClose={toggleAttachModal}\n onUpdate={handleUpdate}\n isLoading={isUpdatePending}\n error={updateError}\n />\n )}\n\n {detachModalOpen && (\n <DetachFloatingIpModal\n floatingIp={floatingIp}\n open={detachModalOpen}\n onClose={toggleDetachModal}\n onUpdate={handleUpdate}\n isLoading={isUpdatePending}\n error={updateError}\n />\n )}\n\n {releaseModalOpen && (\n <ReleaseFloatingIpModal\n floatingIp={floatingIp}\n open={releaseModalOpen}\n onClose={toggleReleaseModal}\n onUpdate={handleDelete}\n isLoading={isDeletePending}\n error={deleteError}\n />\n )}\n </>\n )\n}\n"],"mappings":"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"}
|