@cobaltcore-dev/aurora 0.3.1 → 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/README.md +73 -77
- package/dist/client/AuroraApp.d.ts +15 -0
- package/dist/client/{AuthProvider-D-5Jpa6F.mjs → AuthProvider-Co4d0WzB.mjs} +3 -3
- package/dist/client/{AuthProvider-D-5Jpa6F.mjs.map → AuthProvider-Co4d0WzB.mjs.map} +1 -1
- package/dist/client/{ContentHeader-BXZoN3B9.mjs → ContentHeader-xQVhO2yT.mjs} +20 -20
- package/dist/client/{ContentHeader-BXZoN3B9.mjs.map → ContentHeader-xQVhO2yT.mjs.map} +1 -1
- package/dist/client/{DeleteFlavorModal-BusYn32r.mjs → DeleteFlavorModal-CHTUZ3YV.mjs} +211 -202
- package/dist/client/DeleteFlavorModal-CHTUZ3YV.mjs.map +1 -0
- package/dist/client/{EditSecurityGroupModal-Dl6m7wUe.mjs → EditSecurityGroupModal-CWHHx2Xk.mjs} +22 -22
- package/dist/client/{EditSecurityGroupModal-Dl6m7wUe.mjs.map → EditSecurityGroupModal-CWHHx2Xk.mjs.map} +1 -1
- package/dist/client/{FiltersInput-BgNaHFBt.mjs → FiltersInput-UKJpNFdr.mjs} +11 -11
- package/dist/client/FiltersInput-UKJpNFdr.mjs.map +1 -0
- package/dist/client/{FloatingIpActionModals-By2hXR9m.mjs → FloatingIpActionModals-caXn6bYo.mjs} +54 -54
- package/dist/client/{FloatingIpActionModals-By2hXR9m.mjs.map → FloatingIpActionModals-caXn6bYo.mjs.map} +1 -1
- package/dist/client/{ImageToastNotifications-fHI8jB2j.mjs → ImageToastNotifications-BWimIzu_.mjs} +227 -227
- package/dist/client/{ImageToastNotifications-fHI8jB2j.mjs.map → ImageToastNotifications-BWimIzu_.mjs.map} +1 -1
- package/dist/client/{RouteError-pDEWC_k7.mjs → RouteError-CUj_m3gu.mjs} +6 -6
- package/dist/client/{RouteError-pDEWC_k7.mjs.map → RouteError-CUj_m3gu.mjs.map} +1 -1
- package/dist/client/{SortInput-DXWSqSny.mjs → SortInput-GQlQBlAj.mjs} +6 -6
- package/dist/client/{SortInput-DXWSqSny.mjs.map → SortInput-GQlQBlAj.mjs.map} +1 -1
- package/dist/client/{_auth-CJj1Cnbm.mjs → _auth-DXJkv9QO.mjs} +3 -3
- package/dist/client/{_auth-CJj1Cnbm.mjs.map → _auth-DXJkv9QO.mjs.map} +1 -1
- package/dist/client/_flavorId-C5dc1N_j.mjs +194 -0
- package/dist/client/_flavorId-C5dc1N_j.mjs.map +1 -0
- package/dist/client/{_flavorId-BoNcxYmF.mjs → _flavorId-sUWG0xuy.mjs} +15 -15
- package/dist/client/_flavorId-sUWG0xuy.mjs.map +1 -0
- package/dist/client/{_floatingIpId-BpUfL8Im2.mjs → _floatingIpId-COK_TBrz2.mjs} +42 -42
- package/dist/client/{_floatingIpId-BpUfL8Im2.mjs.map → _floatingIpId-COK_TBrz2.mjs.map} +1 -1
- package/dist/client/{_floatingIpId-CwHiXazi.mjs → _floatingIpId-CT4y-60o.mjs} +3 -3
- package/dist/client/{_floatingIpId-CwHiXazi.mjs.map → _floatingIpId-CT4y-60o.mjs.map} +1 -1
- package/dist/client/_imageId-n3RcnhAR.mjs +534 -0
- package/dist/client/_imageId-n3RcnhAR.mjs.map +1 -0
- package/dist/client/_pcaId-B-f_6kqs.mjs +466 -0
- package/dist/client/_pcaId-B-f_6kqs.mjs.map +1 -0
- package/dist/client/{_pcaId-D1ZEaCdp.mjs → _pcaId-ChnM_t-9.mjs} +3 -3
- package/dist/client/{_pcaId-D1ZEaCdp.mjs.map → _pcaId-ChnM_t-9.mjs.map} +1 -1
- package/dist/client/_projectId-26bw-_rm.mjs +46 -0
- package/dist/client/_projectId-26bw-_rm.mjs.map +1 -0
- package/dist/client/{_projectId-DhLpIalx.mjs → _projectId-BK9UqeYw.mjs} +14 -14
- package/dist/client/{_projectId-DhLpIalx.mjs.map → _projectId-BK9UqeYw.mjs.map} +1 -1
- package/dist/client/{_projectId-D1gGribM.mjs → _projectId-CCtpAQ8m.mjs} +79 -96
- package/dist/client/_projectId-CCtpAQ8m.mjs.map +1 -0
- package/dist/client/{_projectId-OW2xkK43.mjs → _projectId-Dhb4AyBD.mjs} +3 -3
- package/dist/client/{_projectId-OW2xkK43.mjs.map → _projectId-Dhb4AyBD.mjs.map} +1 -1
- package/dist/client/{_securityGroupId-B0llWH9A.mjs → _securityGroupId-CR1mKICQ.mjs} +3 -3
- package/dist/client/{_securityGroupId-B0llWH9A.mjs.map → _securityGroupId-CR1mKICQ.mjs.map} +1 -1
- package/dist/client/{_securityGroupId-gbUnd5Wv.mjs → _securityGroupId-DroYG6cA.mjs} +254 -255
- package/dist/client/{_securityGroupId-gbUnd5Wv.mjs.map → _securityGroupId-DroYG6cA.mjs.map} +1 -1
- package/dist/client/about-969pIiZ9.mjs +92 -0
- package/dist/client/{about-DCe6LsKz.mjs.map → about-969pIiZ9.mjs.map} +1 -1
- package/dist/client/aurora-DDzsst74.mjs +19 -0
- package/dist/client/{aurora-CRcxVUCo.mjs.map → aurora-DDzsst74.mjs.map} +1 -1
- package/dist/client/{build-BJDfnAyi.mjs → build-DracvfrJ.mjs} +5 -5
- package/dist/client/{build-BJDfnAyi.mjs.map → build-DracvfrJ.mjs.map} +1 -1
- package/dist/client/{buildFilterParams-By33pG59.mjs → buildFilterParams-DoZzMKX9.mjs} +1 -1
- package/dist/client/{buildFilterParams-By33pG59.mjs.map → buildFilterParams-DoZzMKX9.mjs.map} +1 -1
- package/dist/client/{cn-C3laVXMm.mjs → cn-DM4Cy3jv.mjs} +1 -1
- package/dist/client/{cn-C3laVXMm.mjs.map → cn-DM4Cy3jv.mjs.map} +1 -1
- package/dist/client/{constants-CAjjRTo_.mjs → constants-4lVQXort.mjs} +22 -22
- package/dist/client/{constants-CAjjRTo_.mjs.map → constants-4lVQXort.mjs.map} +1 -1
- package/dist/client/{containers-NW7RnHTI.mjs → containers-DGY2hoWw.mjs} +3 -3
- package/dist/client/containers-DGY2hoWw.mjs.map +1 -0
- package/dist/client/containers-ZMFTRaQL.mjs +3277 -0
- package/dist/client/containers-ZMFTRaQL.mjs.map +1 -0
- package/dist/client/{containers-Ca5V1EBS.mjs → containers-xfsYgRyf.mjs} +2 -2
- package/dist/client/containers-xfsYgRyf.mjs.map +1 -0
- package/dist/client/{flavors-D8oElC2K.mjs → flavors-C4GtoybP.mjs} +2 -2
- package/dist/client/{flavors-D8oElC2K.mjs.map → flavors-C4GtoybP.mjs.map} +1 -1
- package/dist/client/{flavors-qvgPSI7J.mjs → flavors-CpirO_nr.mjs} +167 -148
- package/dist/client/flavors-CpirO_nr.mjs.map +1 -0
- package/dist/client/{flavors-BXPYAFyQ.mjs → flavors-DWMZ6TuJ.mjs} +2 -2
- package/dist/client/{flavors-BXPYAFyQ.mjs.map → flavors-DWMZ6TuJ.mjs.map} +1 -1
- package/dist/client/{floatingips-Be3zLoaD.mjs → floatingips-BUf_oLRl.mjs} +74 -75
- package/dist/client/{floatingips-Be3zLoaD.mjs.map → floatingips-BUf_oLRl.mjs.map} +1 -1
- package/dist/client/{formatBytes-D6oa0wU9.mjs → formatBytes-CZv_XyCY.mjs} +1 -1
- package/dist/client/{formatBytes-D6oa0wU9.mjs.map → formatBytes-CZv_XyCY.mjs.map} +1 -1
- package/dist/client/{helpers--JWXi40U.mjs → helpers-1PpYf-fC.mjs} +1 -1
- package/dist/client/{helpers--JWXi40U.mjs.map → helpers-1PpYf-fC.mjs.map} +1 -1
- package/dist/client/hooks-dSArr2Ca.mjs +2 -0
- package/dist/client/images-CsonlmFx.mjs +8 -0
- package/dist/client/images-CsonlmFx.mjs.map +1 -0
- package/dist/client/{images-CCYBAphP2.mjs → images-Da1t5KPh.mjs} +509 -536
- package/dist/client/images-Da1t5KPh.mjs.map +1 -0
- package/dist/client/{images-DM9I8G0p.mjs → images-NBf2bV43.mjs} +2 -2
- package/dist/client/images-NBf2bV43.mjs.map +1 -0
- package/dist/client/{images-BiEBENaj.mjs → images-QnWf63uj.mjs} +2 -2
- package/dist/client/{images-BiEBENaj.mjs.map → images-QnWf63uj.mjs.map} +1 -1
- package/dist/client/index.js +232 -236
- package/dist/client/index.js.map +1 -1
- package/dist/client/{md-BivyCkGC.mjs → md-sBiSNVSQ.mjs} +7 -7
- package/dist/client/{md-BivyCkGC.mjs.map → md-sBiSNVSQ.mjs.map} +1 -1
- package/dist/client/{network-nbSbl0X0.mjs → network-DuZm76BZ.mjs} +2 -2
- package/dist/client/{network-nbSbl0X0.mjs.map → network-DuZm76BZ.mjs.map} +1 -1
- package/dist/client/{objects-CU5ws07o.mjs → objects-B89dYCBq.mjs} +3 -3
- package/dist/client/objects-B89dYCBq.mjs.map +1 -0
- package/dist/client/{objects-GmuIOaHd.mjs → objects-CuFLUOe1.mjs} +2 -2
- package/dist/client/objects-CuFLUOe1.mjs.map +1 -0
- package/dist/client/objects-H0NN_Sja.mjs +5460 -0
- package/dist/client/objects-H0NN_Sja.mjs.map +1 -0
- package/dist/client/{pca-x9if8xU-.mjs → pca-C-UFjicP.mjs} +51 -51
- package/dist/client/pca-C-UFjicP.mjs.map +1 -0
- package/dist/client/{pca-DSM71LhW.mjs → pca-CtU6REww.mjs} +2 -2
- package/dist/client/{pca-DSM71LhW.mjs.map → pca-CtU6REww.mjs.map} +1 -1
- package/dist/client/{projects-B6BPo2Ar.mjs → projects-C-sjd9T5.mjs} +3 -3
- package/dist/client/{projects-B6BPo2Ar.mjs.map → projects-C-sjd9T5.mjs.map} +1 -1
- package/dist/client/{projects-CnmZIB2Q.mjs → projects-DNXsDnJM.mjs} +29 -25
- package/dist/client/projects-DNXsDnJM.mjs.map +1 -0
- package/dist/client/{projects-Bt0XptpG.mjs → projects-dhnQkuvV.mjs} +2 -2
- package/dist/client/{projects-Bt0XptpG.mjs.map → projects-dhnQkuvV.mjs.map} +1 -1
- package/dist/client/{projects-BilrmHLu.mjs → projects-yiK0HGSA.mjs} +2 -2
- package/dist/client/{projects-BilrmHLu.mjs.map → projects-yiK0HGSA.mjs.map} +1 -1
- package/dist/client/{securitygroups-BdzieS7Z.mjs → securitygroups-wHdrxZXd.mjs} +72 -73
- package/dist/client/{securitygroups-BdzieS7Z.mjs.map → securitygroups-wHdrxZXd.mjs.map} +1 -1
- package/dist/client/{trpcClient-BxguzNYF.mjs → trpcClient-BzPUgiM2.mjs} +1 -1
- package/dist/client/{trpcClient-BxguzNYF.mjs.map → trpcClient-BzPUgiM2.mjs.map} +1 -1
- package/dist/client/{useErrorTranslation-TZVwIAzq.mjs → useErrorTranslation-Dc0eE8Zt.mjs} +1 -1
- package/dist/client/{useErrorTranslation-TZVwIAzq.mjs.map → useErrorTranslation-Dc0eE8Zt.mjs.map} +1 -1
- package/dist/client/useListWithFiltering-DrgUwXef.mjs +157 -0
- package/dist/client/useListWithFiltering-DrgUwXef.mjs.map +1 -0
- package/dist/client/{useModal-DxxlilRm.mjs → useModal-DCs1OJh7.mjs} +1 -1
- package/dist/client/{useModal-DxxlilRm.mjs.map → useModal-DCs1OJh7.mjs.map} +1 -1
- package/dist/client/{useProjectId-CgOTejka.mjs → useProjectId-DBc5lpoU.mjs} +1 -1
- package/dist/client/{useProjectId-CgOTejka.mjs.map → useProjectId-DBc5lpoU.mjs.map} +1 -1
- package/dist/server/index.d.ts +7 -1
- package/dist/server/index.js +1363 -453
- package/package.json +7 -7
- package/dist/client/DeleteFlavorModal-BusYn32r.mjs.map +0 -1
- package/dist/client/FiltersInput-BgNaHFBt.mjs.map +0 -1
- package/dist/client/ListToolbar-BvtCo8dk.mjs +0 -129
- package/dist/client/ListToolbar-BvtCo8dk.mjs.map +0 -1
- package/dist/client/_flavorId-BRonXvCo.mjs +0 -188
- package/dist/client/_flavorId-BRonXvCo.mjs.map +0 -1
- package/dist/client/_flavorId-BoNcxYmF.mjs.map +0 -1
- package/dist/client/_imageId-CdOOJjw0.mjs +0 -527
- package/dist/client/_imageId-CdOOJjw0.mjs.map +0 -1
- package/dist/client/_pcaId-CwlH1Kvl.mjs +0 -369
- package/dist/client/_pcaId-CwlH1Kvl.mjs.map +0 -1
- package/dist/client/_projectId-D1gGribM.mjs.map +0 -1
- package/dist/client/_projectId-Dj_InfSc.mjs +0 -26
- package/dist/client/_projectId-Dj_InfSc.mjs.map +0 -1
- package/dist/client/about-DCe6LsKz.mjs +0 -92
- package/dist/client/aurora-CRcxVUCo.mjs +0 -19
- package/dist/client/containers-BuXUVb1N.mjs +0 -3031
- package/dist/client/containers-BuXUVb1N.mjs.map +0 -1
- package/dist/client/containers-Ca5V1EBS.mjs.map +0 -1
- package/dist/client/containers-NW7RnHTI.mjs.map +0 -1
- package/dist/client/flavors-qvgPSI7J.mjs.map +0 -1
- package/dist/client/hooks-D0krAKvo.mjs +0 -2
- package/dist/client/images-CCYBAphP2.mjs.map +0 -1
- package/dist/client/images-DM9I8G0p.mjs.map +0 -1
- package/dist/client/objects-CU5ws07o.mjs.map +0 -1
- package/dist/client/objects-FXN0VWLI.mjs +0 -4760
- package/dist/client/objects-FXN0VWLI.mjs.map +0 -1
- package/dist/client/objects-GmuIOaHd.mjs.map +0 -1
- package/dist/client/overview-B3gdnWTG.mjs +0 -15
- package/dist/client/overview-B3gdnWTG.mjs.map +0 -1
- package/dist/client/overview-DzYBiNfD.mjs +0 -15
- package/dist/client/overview-DzYBiNfD.mjs.map +0 -1
- package/dist/client/overview-EhfPY8Je.mjs +0 -15
- package/dist/client/overview-EhfPY8Je.mjs.map +0 -1
- package/dist/client/overview-XueZI4LQ.mjs +0 -173
- package/dist/client/overview-XueZI4LQ.mjs.map +0 -1
- package/dist/client/pca-x9if8xU-.mjs.map +0 -1
- package/dist/client/projects-CnmZIB2Q.mjs.map +0 -1
- package/dist/client/useListWithFiltering-CqQbAjEe.mjs +0 -32
- package/dist/client/useListWithFiltering-CqQbAjEe.mjs.map +0 -1
- package/permission_policies/compute.yaml +0 -975
- package/permission_policies/image.yaml +0 -71
|
@@ -0,0 +1,534 @@
|
|
|
1
|
+
import { E as e, J as t, L as n, N as r, Q as i, R as a, W as o, Y as s, b as c, c as l, et as u, h as d, j as f, nt as p, q as m, z as h } from "./build-DracvfrJ.mjs";
|
|
2
|
+
import { r as g } from "./trpcClient-BzPUgiM2.mjs";
|
|
3
|
+
import { n as _, t as ee } from "./ContentHeader-xQVhO2yT.mjs";
|
|
4
|
+
import { A as te, D as ne, E as re, F as v, I as y, N as ie, O as ae, P as b, T as oe, d as se, k as ce, u as le } from "./ImageToastNotifications-BWimIzu_.mjs";
|
|
5
|
+
import { Fragment as x, jsx as S, jsxs as C } from "react/jsx-runtime";
|
|
6
|
+
import w, { useState as T } from "react";
|
|
7
|
+
import { useNavigate as ue, useParams as de, useSearch as fe } from "@tanstack/react-router";
|
|
8
|
+
import { Trans as E, useLingui as D } from "@lingui/react";
|
|
9
|
+
//#region src/client/routes/_auth/projects/$projectId/compute/-components/Images/-components/ImageDetailsView.tsx
|
|
10
|
+
var O = ({ image: e, myMemberData: t, canUpdateMember: n, onStatusChange: r, isLoading: i }) => {
|
|
11
|
+
let { i18n: a, _: o } = D(), s = t.status === v.PENDING, u = t.status === v.REJECTED, f = t.created_at ? new Date(t.created_at).toLocaleString() : a._({ id: "fj5byd" }), p = t.updated_at ? new Date(t.updated_at).toLocaleString() : a._({ id: "fj5byd" }), m = e.owner ?? "";
|
|
12
|
+
return /*#__PURE__*/ C(c, { children: [
|
|
13
|
+
s && /*#__PURE__*/ S("p", {
|
|
14
|
+
className: "text-theme-highest font-semibold",
|
|
15
|
+
children: /*#__PURE__*/ S(E, { id: "/EcdUM" })
|
|
16
|
+
}),
|
|
17
|
+
/*#__PURE__*/ S("p", { children: /*#__PURE__*/ S(E, {
|
|
18
|
+
id: "Uwo8Xw",
|
|
19
|
+
values: {
|
|
20
|
+
ownerProject: m,
|
|
21
|
+
sharedAt: f
|
|
22
|
+
},
|
|
23
|
+
components: { 0: /*#__PURE__*/ S("span", { className: "font-semibold" }) }
|
|
24
|
+
}) }),
|
|
25
|
+
/*#__PURE__*/ C("ul", { children: [
|
|
26
|
+
/*#__PURE__*/ C("li", { children: [
|
|
27
|
+
/*#__PURE__*/ S("span", {
|
|
28
|
+
className: "font-semibold",
|
|
29
|
+
children: /*#__PURE__*/ S(E, { id: "azXlY+" })
|
|
30
|
+
}),
|
|
31
|
+
" ",
|
|
32
|
+
t.status
|
|
33
|
+
] }),
|
|
34
|
+
/*#__PURE__*/ C("li", { children: [
|
|
35
|
+
/*#__PURE__*/ S("span", {
|
|
36
|
+
className: "font-semibold",
|
|
37
|
+
children: /*#__PURE__*/ S(E, { id: "G6AP+o" })
|
|
38
|
+
}),
|
|
39
|
+
" ",
|
|
40
|
+
f
|
|
41
|
+
] }),
|
|
42
|
+
/*#__PURE__*/ C("li", { children: [
|
|
43
|
+
/*#__PURE__*/ S("span", {
|
|
44
|
+
className: "font-semibold",
|
|
45
|
+
children: /*#__PURE__*/ S(E, { id: "pFg+7w" })
|
|
46
|
+
}),
|
|
47
|
+
" ",
|
|
48
|
+
p
|
|
49
|
+
] })
|
|
50
|
+
] }),
|
|
51
|
+
n && (s || u) && /*#__PURE__*/ C(d, { children: [/*#__PURE__*/ S(l, {
|
|
52
|
+
onClick: () => r(v.ACCEPTED),
|
|
53
|
+
disabled: i,
|
|
54
|
+
children: /*#__PURE__*/ S(E, { id: "g3UF2V" })
|
|
55
|
+
}), s && /*#__PURE__*/ S(l, {
|
|
56
|
+
onClick: () => r(v.REJECTED),
|
|
57
|
+
disabled: i,
|
|
58
|
+
children: /*#__PURE__*/ S(E, { id: "1t/NnN" })
|
|
59
|
+
})] })
|
|
60
|
+
] });
|
|
61
|
+
}, k = ({ image: e }) => {
|
|
62
|
+
let { i18n: t, _: i } = D();
|
|
63
|
+
return /*#__PURE__*/ C(h, {
|
|
64
|
+
px: !1,
|
|
65
|
+
py: !0,
|
|
66
|
+
children: [/*#__PURE__*/ S(f, { children: t._({ id: "nW/hX9" }) }), /*#__PURE__*/ C(o, {
|
|
67
|
+
alignTerms: "right",
|
|
68
|
+
children: [
|
|
69
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "S0kLOH" }) }),
|
|
70
|
+
/*#__PURE__*/ S(n, { children: /*#__PURE__*/ S(_, { text: e.id }) }),
|
|
71
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "6YtxFj" }) }),
|
|
72
|
+
/*#__PURE__*/ S(n, { children: e.name }),
|
|
73
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "uAQUqI" }) }),
|
|
74
|
+
/*#__PURE__*/ S(n, { children: e.status }),
|
|
75
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "Cj2Gtd" }) }),
|
|
76
|
+
/*#__PURE__*/ S(n, { children: /*#__PURE__*/ S(y, { size: e.size }) }),
|
|
77
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "Cxgv2U" }) }),
|
|
78
|
+
/*#__PURE__*/ C(n, { children: [e.min_disk, " GB"] }),
|
|
79
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "B2Czeb" }) }),
|
|
80
|
+
/*#__PURE__*/ C(n, { children: [e.min_ram, " MB"] }),
|
|
81
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "NopYGU" }) }),
|
|
82
|
+
/*#__PURE__*/ S(n, { children: /*#__PURE__*/ S("span", {
|
|
83
|
+
className: "uppercase",
|
|
84
|
+
children: e.disk_format
|
|
85
|
+
}) }),
|
|
86
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "6/xipy" }) }),
|
|
87
|
+
/*#__PURE__*/ S(n, { children: /*#__PURE__*/ S("span", {
|
|
88
|
+
className: "uppercase",
|
|
89
|
+
children: e.container_format
|
|
90
|
+
}) }),
|
|
91
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "88kg0+" }) }),
|
|
92
|
+
/*#__PURE__*/ S(n, { children: e.created_at ? new Date(e.created_at).toLocaleDateString() : t._({ id: "fj5byd" }) }),
|
|
93
|
+
/*#__PURE__*/ S(r, { children: t._({ id: "Llcakz" }) }),
|
|
94
|
+
/*#__PURE__*/ S(n, { children: e.updated_at ? new Date(e.updated_at).toLocaleDateString() : t._({ id: "fj5byd" }) })
|
|
95
|
+
]
|
|
96
|
+
})]
|
|
97
|
+
});
|
|
98
|
+
}, A = ({ image: e, currentProjectId: t }) => {
|
|
99
|
+
let { i18n: i, _: a } = D(), s = e.visibility === "shared" && e.owner !== void 0 && e.owner !== t;
|
|
100
|
+
return /*#__PURE__*/ C(h, {
|
|
101
|
+
px: !1,
|
|
102
|
+
py: !0,
|
|
103
|
+
children: [/*#__PURE__*/ S(f, { children: i._({ id: "a3LDKx" }) }), /*#__PURE__*/ C(o, {
|
|
104
|
+
alignTerms: "right",
|
|
105
|
+
children: [
|
|
106
|
+
/*#__PURE__*/ S(r, { children: s ? i._({ id: "20axE5" }) : i._({ id: "YsrbQh" }) }),
|
|
107
|
+
/*#__PURE__*/ S(n, { children: e.owner ? /*#__PURE__*/ S(_, { text: e.owner }) : "" }),
|
|
108
|
+
/*#__PURE__*/ S(r, { children: i._({ id: "2q/Q7x" }) }),
|
|
109
|
+
/*#__PURE__*/ S(n, { children: e.visibility }),
|
|
110
|
+
/*#__PURE__*/ S(r, { children: i._({ id: "644xgx" }) }),
|
|
111
|
+
/*#__PURE__*/ S(n, { children: e.protected ? i._({ id: "l75CjT" }) : i._({ id: "1UzENP" }) }),
|
|
112
|
+
/*#__PURE__*/ S(r, { children: i._({ id: "PzgYM9" }) }),
|
|
113
|
+
/*#__PURE__*/ S(n, { children: e?.checksum ? e.checksum : "" })
|
|
114
|
+
]
|
|
115
|
+
})]
|
|
116
|
+
});
|
|
117
|
+
}, j = ({ image: e }) => {
|
|
118
|
+
let { i18n: t, _: i } = D(), a = new Set([
|
|
119
|
+
"id",
|
|
120
|
+
"name",
|
|
121
|
+
"status",
|
|
122
|
+
"visibility",
|
|
123
|
+
"size",
|
|
124
|
+
"disk_format",
|
|
125
|
+
"container_format",
|
|
126
|
+
"min_disk",
|
|
127
|
+
"min_ram",
|
|
128
|
+
"owner",
|
|
129
|
+
"protected",
|
|
130
|
+
"created_at",
|
|
131
|
+
"updated_at",
|
|
132
|
+
"checksum"
|
|
133
|
+
]), s = Object.entries(e).filter(([e]) => !a.has(e)).sort(([e], [t]) => e.localeCompare(t)), c = s.length > 0;
|
|
134
|
+
return /*#__PURE__*/ C(h, {
|
|
135
|
+
px: !1,
|
|
136
|
+
py: !0,
|
|
137
|
+
children: [/*#__PURE__*/ S(f, { children: t._({ id: "bc67JN" }) }), c ? /*#__PURE__*/ S(o, {
|
|
138
|
+
alignTerms: "right",
|
|
139
|
+
className: "grid-cols-4",
|
|
140
|
+
children: s.map(([e, i]) => /*#__PURE__*/ C(w.Fragment, { children: [/*#__PURE__*/ S(r, {
|
|
141
|
+
className: "col-span-1",
|
|
142
|
+
children: e
|
|
143
|
+
}), /*#__PURE__*/ S(n, {
|
|
144
|
+
className: "col-span-1",
|
|
145
|
+
children: i == null ? /*#__PURE__*/ S("span", { children: "null" }) : typeof i == "object" ? /*#__PURE__*/ S("span", {
|
|
146
|
+
className: "break-all",
|
|
147
|
+
children: JSON.stringify(i)
|
|
148
|
+
}) : typeof i == "boolean" ? i ? t._({ id: "c+xCSz" }) : t._({ id: "ocUvR+" }) : /*#__PURE__*/ S("span", {
|
|
149
|
+
className: "break-all",
|
|
150
|
+
children: String(i)
|
|
151
|
+
})
|
|
152
|
+
})] }, e))
|
|
153
|
+
}) : /*#__PURE__*/ S("p", {
|
|
154
|
+
className: "text-theme-light",
|
|
155
|
+
children: t._({ id: "9v5VLp" })
|
|
156
|
+
})]
|
|
157
|
+
});
|
|
158
|
+
}, M = (e) => {
|
|
159
|
+
let t = "px-6 py-3 font-semibold border-b-2 transition-colors";
|
|
160
|
+
return e ? `${t} border-theme-accent text-theme-highest` : `${t} border-transparent text-theme-secondary hover:text-theme-high`;
|
|
161
|
+
}, N = ({ image: e, permissions: t, currentProjectId: n }) => {
|
|
162
|
+
let [r, i] = T(!1), [a, o] = T(null), { data: s, isLoading: c } = g.compute.listImageMembers.useQuery({
|
|
163
|
+
project_id: n,
|
|
164
|
+
imageId: e.id
|
|
165
|
+
}, { enabled: !!e.id && !!n });
|
|
166
|
+
return /*#__PURE__*/ C(h, {
|
|
167
|
+
px: !1,
|
|
168
|
+
py: !0,
|
|
169
|
+
children: [a && /*#__PURE__*/ S(m, {
|
|
170
|
+
text: a.text,
|
|
171
|
+
variant: a.type,
|
|
172
|
+
onDismiss: () => o(null),
|
|
173
|
+
className: "mb-4"
|
|
174
|
+
}), /*#__PURE__*/ S(te, {
|
|
175
|
+
image: e,
|
|
176
|
+
imageMembers: s,
|
|
177
|
+
isMembersLoading: c,
|
|
178
|
+
canAdd: t?.canCreateMember ?? !1,
|
|
179
|
+
canRemove: t?.canDeleteMember ?? !1,
|
|
180
|
+
isAddingMember: r,
|
|
181
|
+
setIsAddingMember: i,
|
|
182
|
+
setMessage: o,
|
|
183
|
+
projectId: n
|
|
184
|
+
})]
|
|
185
|
+
});
|
|
186
|
+
}, pe = ({ image: e, currentProjectId: t, activeTab: n = "details", onTabChange: r, permissions: i, myMemberData: a, onMemberStatusChange: o, isMemberStatusChanging: s, actions: c }) => {
|
|
187
|
+
let { i18n: l, _: u } = D(), d = e.visibility === "shared" && e.owner !== void 0 && e.owner !== t, f = e.owner === t && e.visibility === "shared";
|
|
188
|
+
return /*#__PURE__*/ C(p, {
|
|
189
|
+
direction: "vertical",
|
|
190
|
+
gap: "6",
|
|
191
|
+
children: [
|
|
192
|
+
d && a && o && /*#__PURE__*/ S(O, {
|
|
193
|
+
image: e,
|
|
194
|
+
myMemberData: a,
|
|
195
|
+
canUpdateMember: i?.canUpdateMember ?? !1,
|
|
196
|
+
onStatusChange: o,
|
|
197
|
+
isLoading: s ?? !1
|
|
198
|
+
}),
|
|
199
|
+
f && /*#__PURE__*/ S("div", {
|
|
200
|
+
className: "border-theme-background-lvl-3 border-b",
|
|
201
|
+
children: /*#__PURE__*/ C(p, {
|
|
202
|
+
direction: "horizontal",
|
|
203
|
+
gap: "0",
|
|
204
|
+
children: [/*#__PURE__*/ S("button", {
|
|
205
|
+
className: M(n === "details"),
|
|
206
|
+
onClick: () => r?.("details"),
|
|
207
|
+
children: l._({ id: "URmyfc" })
|
|
208
|
+
}), /*#__PURE__*/ S("button", {
|
|
209
|
+
className: M(n === "sharing"),
|
|
210
|
+
onClick: () => r?.("sharing"),
|
|
211
|
+
children: l._({ id: "aG9OiI" })
|
|
212
|
+
})]
|
|
213
|
+
})
|
|
214
|
+
}),
|
|
215
|
+
(n === "details" || !f) && /*#__PURE__*/ C(x, { children: [
|
|
216
|
+
c,
|
|
217
|
+
/*#__PURE__*/ S(k, { image: e }),
|
|
218
|
+
/*#__PURE__*/ S(A, {
|
|
219
|
+
image: e,
|
|
220
|
+
currentProjectId: t
|
|
221
|
+
}),
|
|
222
|
+
/*#__PURE__*/ S(j, { image: e })
|
|
223
|
+
] }),
|
|
224
|
+
n === "sharing" && f && /*#__PURE__*/ S(N, {
|
|
225
|
+
image: e,
|
|
226
|
+
permissions: i
|
|
227
|
+
})
|
|
228
|
+
]
|
|
229
|
+
});
|
|
230
|
+
};
|
|
231
|
+
//#endregion
|
|
232
|
+
//#region src/client/routes/_auth/projects/$projectId/compute/images/$imageId.tsx?tsr-split=component
|
|
233
|
+
function P() {
|
|
234
|
+
let { projectId: n, imageId: r } = de({ from: "/_auth/projects/$projectId/compute/images/$imageId" }), { tab: o } = fe({ from: "/_auth/projects/$projectId/compute/images/$imageId" }), c = ue(), { i18n: f, _: m } = D(), { data: h, status: _, error: te } = g.compute.getImageById.useQuery({
|
|
235
|
+
project_id: n,
|
|
236
|
+
imageId: r
|
|
237
|
+
}), { data: v } = g.compute.canUser.useQuery({
|
|
238
|
+
project_id: n,
|
|
239
|
+
permission: [
|
|
240
|
+
"images:delete",
|
|
241
|
+
"images:update",
|
|
242
|
+
"images:create_member",
|
|
243
|
+
"images:delete_member",
|
|
244
|
+
"images:update_member"
|
|
245
|
+
]
|
|
246
|
+
}), y = {
|
|
247
|
+
canDelete: v?.[0] ?? !1,
|
|
248
|
+
canUpdate: v?.[1] ?? !1,
|
|
249
|
+
canCreateMember: v?.[2] ?? !1,
|
|
250
|
+
canDeleteMember: v?.[3] ?? !1,
|
|
251
|
+
canUpdateMember: v?.[4] ?? !1
|
|
252
|
+
}, w = g.useUtils(), [O, k] = T(!1), [A, j] = T(!1), [M, N] = T(!1), [P, F] = T(!1), [I, L] = T(!1), [R, z] = T(null), B = g.compute.updateImage.useMutation({ onSuccess: (e) => {
|
|
253
|
+
w.compute.getImageById.setData({
|
|
254
|
+
project_id: n,
|
|
255
|
+
imageId: r
|
|
256
|
+
}, e), w.compute.listImagesWithPagination.invalidate();
|
|
257
|
+
} }), V = g.compute.deleteImage.useMutation({ onSuccess: () => {
|
|
258
|
+
w.compute.listImagesWithPagination.invalidate();
|
|
259
|
+
} }), H = g.compute.deactivateImage.useMutation({ onSuccess: () => {
|
|
260
|
+
w.compute.getImageById.invalidate({
|
|
261
|
+
project_id: n,
|
|
262
|
+
imageId: r
|
|
263
|
+
});
|
|
264
|
+
} }), U = g.compute.reactivateImage.useMutation({ onSuccess: () => {
|
|
265
|
+
w.compute.getImageById.invalidate({
|
|
266
|
+
project_id: n,
|
|
267
|
+
imageId: r
|
|
268
|
+
});
|
|
269
|
+
} }), W = g.compute.updateImageVisibility.useMutation({ onSuccess: (e) => {
|
|
270
|
+
w.compute.getImageById.setData({
|
|
271
|
+
project_id: n,
|
|
272
|
+
imageId: r
|
|
273
|
+
}, e);
|
|
274
|
+
} }), G = h?.visibility === b.SHARED && h?.owner !== void 0 && h?.owner !== n, { data: K } = g.compute.getImageMember.useQuery({
|
|
275
|
+
project_id: n,
|
|
276
|
+
imageId: r,
|
|
277
|
+
memberId: n
|
|
278
|
+
}, { enabled: G && !!r && !!n }), q = g.compute.updateImageMember.useMutation({ onSuccess: () => {
|
|
279
|
+
w.compute.getImageMember.invalidate({
|
|
280
|
+
project_id: n,
|
|
281
|
+
imageId: r,
|
|
282
|
+
memberId: n
|
|
283
|
+
}), w.compute.listImageMembers.invalidate({
|
|
284
|
+
project_id: n,
|
|
285
|
+
imageId: r
|
|
286
|
+
}), w.compute.listImagesWithPagination.invalidate(), w.compute.listSharedImagesByMemberStatus.invalidate();
|
|
287
|
+
} }), J = async (e) => {
|
|
288
|
+
try {
|
|
289
|
+
await q.mutateAsync({
|
|
290
|
+
project_id: n,
|
|
291
|
+
imageId: r,
|
|
292
|
+
memberId: n,
|
|
293
|
+
status: e
|
|
294
|
+
}), z(se(e, { onDismiss: () => z(null) }));
|
|
295
|
+
} catch (e) {
|
|
296
|
+
let t = e?.message;
|
|
297
|
+
z(le(t, { onDismiss: () => z(null) }));
|
|
298
|
+
}
|
|
299
|
+
}, Y = () => {
|
|
300
|
+
c({
|
|
301
|
+
to: "/projects/$projectId/compute/images",
|
|
302
|
+
params: { projectId: n }
|
|
303
|
+
});
|
|
304
|
+
}, X = B.isPending || V.isPending || H.isPending || U.isPending || W.isPending, me = (e, t) => {
|
|
305
|
+
let n = [];
|
|
306
|
+
return Object.entries(e).forEach(([e, r]) => {
|
|
307
|
+
let i = `/${e}`;
|
|
308
|
+
if (r == null) e in t && n.push({
|
|
309
|
+
op: "remove",
|
|
310
|
+
path: i
|
|
311
|
+
});
|
|
312
|
+
else {
|
|
313
|
+
let a = e in t;
|
|
314
|
+
n.push({
|
|
315
|
+
op: a ? "replace" : "add",
|
|
316
|
+
path: i,
|
|
317
|
+
value: r
|
|
318
|
+
});
|
|
319
|
+
}
|
|
320
|
+
}), n;
|
|
321
|
+
}, Z = async (e) => {
|
|
322
|
+
if (!h) return !1;
|
|
323
|
+
let t = me(e, h);
|
|
324
|
+
try {
|
|
325
|
+
return await B.mutateAsync({
|
|
326
|
+
project_id: n,
|
|
327
|
+
imageId: r,
|
|
328
|
+
operations: t
|
|
329
|
+
}), k(!1), !0;
|
|
330
|
+
} catch {
|
|
331
|
+
return !1;
|
|
332
|
+
}
|
|
333
|
+
}, he = async (e) => {
|
|
334
|
+
try {
|
|
335
|
+
await V.mutateAsync({
|
|
336
|
+
project_id: n,
|
|
337
|
+
imageId: e.id
|
|
338
|
+
}), N(!1), Y();
|
|
339
|
+
} catch {
|
|
340
|
+
N(!1);
|
|
341
|
+
}
|
|
342
|
+
}, ge = async (e) => {
|
|
343
|
+
try {
|
|
344
|
+
await U.mutateAsync({
|
|
345
|
+
project_id: n,
|
|
346
|
+
imageId: e.id
|
|
347
|
+
}), F(!1);
|
|
348
|
+
} catch {
|
|
349
|
+
F(!1);
|
|
350
|
+
}
|
|
351
|
+
}, _e = async (e) => {
|
|
352
|
+
try {
|
|
353
|
+
await H.mutateAsync({
|
|
354
|
+
project_id: n,
|
|
355
|
+
imageId: e.id
|
|
356
|
+
}), L(!1);
|
|
357
|
+
} catch {
|
|
358
|
+
L(!1);
|
|
359
|
+
}
|
|
360
|
+
}, ve = async (e) => {
|
|
361
|
+
if (h) try {
|
|
362
|
+
await W.mutateAsync({
|
|
363
|
+
project_id: n,
|
|
364
|
+
imageId: h.id,
|
|
365
|
+
visibility: e
|
|
366
|
+
});
|
|
367
|
+
} catch {}
|
|
368
|
+
};
|
|
369
|
+
if (_ === "pending") return /*#__PURE__*/ C(p, {
|
|
370
|
+
className: "fixed inset-0",
|
|
371
|
+
distribution: "center",
|
|
372
|
+
alignment: "center",
|
|
373
|
+
direction: "vertical",
|
|
374
|
+
children: [/*#__PURE__*/ S(i, {
|
|
375
|
+
variant: "primary",
|
|
376
|
+
size: "large",
|
|
377
|
+
className: "mb-2"
|
|
378
|
+
}), /*#__PURE__*/ S(E, { id: "hH3kDo" })]
|
|
379
|
+
});
|
|
380
|
+
if (_ === "error") {
|
|
381
|
+
let e = te?.message || "Unknown error";
|
|
382
|
+
return /*#__PURE__*/ C(p, {
|
|
383
|
+
className: "fixed inset-0",
|
|
384
|
+
distribution: "center",
|
|
385
|
+
alignment: "center",
|
|
386
|
+
direction: "vertical",
|
|
387
|
+
gap: "5",
|
|
388
|
+
children: [
|
|
389
|
+
/*#__PURE__*/ S("p", {
|
|
390
|
+
className: "text-theme-error font-semibold",
|
|
391
|
+
children: /*#__PURE__*/ S(E, { id: "Jh4rAZ" })
|
|
392
|
+
}),
|
|
393
|
+
/*#__PURE__*/ S("p", {
|
|
394
|
+
className: "text-theme-highest",
|
|
395
|
+
children: e
|
|
396
|
+
}),
|
|
397
|
+
/*#__PURE__*/ S(l, {
|
|
398
|
+
onClick: Y,
|
|
399
|
+
variant: "primary",
|
|
400
|
+
children: /*#__PURE__*/ S(E, { id: "bnql/K" })
|
|
401
|
+
})
|
|
402
|
+
]
|
|
403
|
+
});
|
|
404
|
+
}
|
|
405
|
+
if (!h) return /*#__PURE__*/ C(p, {
|
|
406
|
+
className: "fixed inset-0",
|
|
407
|
+
distribution: "center",
|
|
408
|
+
alignment: "center",
|
|
409
|
+
direction: "vertical",
|
|
410
|
+
gap: "5",
|
|
411
|
+
children: [/*#__PURE__*/ S("p", {
|
|
412
|
+
className: "text-theme-highest",
|
|
413
|
+
children: /*#__PURE__*/ S(E, { id: "1pdLQw" })
|
|
414
|
+
}), /*#__PURE__*/ S(l, {
|
|
415
|
+
onClick: Y,
|
|
416
|
+
variant: "primary",
|
|
417
|
+
children: /*#__PURE__*/ S(E, { id: "bnql/K" })
|
|
418
|
+
})]
|
|
419
|
+
});
|
|
420
|
+
let ye = h.status === ie.DEACTIVATED, be = h.visibility === b.PRIVATE, xe = K?.status === "accepted", Se = h.owner === n, Q = G && xe && y.canUpdateMember, Ce = !G && y.canUpdate, we = !G && y.canDelete && !h.protected, Te = !G && Se && h.visibility === b.SHARED && (y.canCreateMember || y.canDeleteMember), $ = Q || Ce || we || Te, Ee = $ || !G && y.canUpdate ? /*#__PURE__*/ C(d, { children: [
|
|
421
|
+
$ && /*#__PURE__*/ C(u, { children: [/*#__PURE__*/ S(a, {
|
|
422
|
+
as: "div",
|
|
423
|
+
children: /*#__PURE__*/ S(l, {
|
|
424
|
+
icon: "moreVert",
|
|
425
|
+
disabled: X,
|
|
426
|
+
children: /*#__PURE__*/ S(E, { id: "PgNNGl" })
|
|
427
|
+
})
|
|
428
|
+
}), /*#__PURE__*/ C(e, { children: [
|
|
429
|
+
Q && /*#__PURE__*/ S(s, {
|
|
430
|
+
label: f._({ id: "1t/NnN" }),
|
|
431
|
+
onClick: () => J("rejected")
|
|
432
|
+
}),
|
|
433
|
+
!G && y.canUpdate && /*#__PURE__*/ S(s, {
|
|
434
|
+
label: ye ? f._({ id: "FQBaXG" }) : f._({ id: "5y3O+A" }),
|
|
435
|
+
onClick: () => ye ? F(!0) : L(!0)
|
|
436
|
+
}),
|
|
437
|
+
!G && y.canUpdate && be && /*#__PURE__*/ S(s, {
|
|
438
|
+
label: f._({ id: "gMYsdZ" }),
|
|
439
|
+
onClick: () => ve("shared")
|
|
440
|
+
}),
|
|
441
|
+
!G && Se && h.visibility === b.SHARED && (y.canCreateMember || y.canDeleteMember) && /*#__PURE__*/ S(s, {
|
|
442
|
+
label: f._({ id: "cWbW6w" }),
|
|
443
|
+
onClick: () => c({
|
|
444
|
+
to: "/projects/$projectId/compute/images/$imageId",
|
|
445
|
+
params: {
|
|
446
|
+
projectId: n,
|
|
447
|
+
imageId: h.id
|
|
448
|
+
},
|
|
449
|
+
search: { tab: "sharing" }
|
|
450
|
+
})
|
|
451
|
+
}),
|
|
452
|
+
!G && y.canDelete && !h.protected && /*#__PURE__*/ S(s, {
|
|
453
|
+
label: f._({ id: "cnGeoo" }),
|
|
454
|
+
onClick: () => N(!0)
|
|
455
|
+
})
|
|
456
|
+
] })] }),
|
|
457
|
+
!G && y.canUpdate && /*#__PURE__*/ S(l, {
|
|
458
|
+
onClick: () => j(!0),
|
|
459
|
+
disabled: X,
|
|
460
|
+
children: /*#__PURE__*/ S(E, { id: "SIfYq6" })
|
|
461
|
+
}),
|
|
462
|
+
!G && y.canUpdate && /*#__PURE__*/ S(l, {
|
|
463
|
+
onClick: () => k(!0),
|
|
464
|
+
variant: "primary",
|
|
465
|
+
disabled: X,
|
|
466
|
+
children: /*#__PURE__*/ S(E, { id: "Y1YKad" })
|
|
467
|
+
})
|
|
468
|
+
] }) : void 0;
|
|
469
|
+
return /*#__PURE__*/ C(x, { children: [
|
|
470
|
+
/*#__PURE__*/ S(ee, {
|
|
471
|
+
title: String(h.name ?? h.id),
|
|
472
|
+
projectId: n,
|
|
473
|
+
actions: Ee
|
|
474
|
+
}),
|
|
475
|
+
/*#__PURE__*/ S("div", {
|
|
476
|
+
className: "mt-3",
|
|
477
|
+
children: /*#__PURE__*/ S(pe, {
|
|
478
|
+
image: h,
|
|
479
|
+
currentProjectId: n,
|
|
480
|
+
activeTab: o ?? "details",
|
|
481
|
+
onTabChange: (e) => c({ search: { tab: e === "details" ? void 0 : e } }),
|
|
482
|
+
permissions: {
|
|
483
|
+
canCreateMember: y.canCreateMember,
|
|
484
|
+
canDeleteMember: y.canDeleteMember,
|
|
485
|
+
canUpdateMember: y.canUpdateMember
|
|
486
|
+
},
|
|
487
|
+
myMemberData: K,
|
|
488
|
+
onMemberStatusChange: J,
|
|
489
|
+
isMemberStatusChanging: q.isPending
|
|
490
|
+
}, h.id)
|
|
491
|
+
}),
|
|
492
|
+
R && /*#__PURE__*/ S(t, { ...R }),
|
|
493
|
+
O && /*#__PURE__*/ S(ce, {
|
|
494
|
+
image: h,
|
|
495
|
+
isOpen: O,
|
|
496
|
+
isLoading: B.isPending,
|
|
497
|
+
onClose: () => k(!1),
|
|
498
|
+
onSave: Z
|
|
499
|
+
}),
|
|
500
|
+
A && /*#__PURE__*/ S(ae, {
|
|
501
|
+
image: h,
|
|
502
|
+
isOpen: A,
|
|
503
|
+
isLoading: B.isPending,
|
|
504
|
+
onClose: () => j(!1),
|
|
505
|
+
onSave: Z
|
|
506
|
+
}),
|
|
507
|
+
M && /*#__PURE__*/ S(ne, {
|
|
508
|
+
image: h,
|
|
509
|
+
isOpen: M,
|
|
510
|
+
isLoading: V.isPending,
|
|
511
|
+
isDisabled: !!h.protected,
|
|
512
|
+
onClose: () => N(!1),
|
|
513
|
+
onDelete: he
|
|
514
|
+
}),
|
|
515
|
+
P && /*#__PURE__*/ S(re, {
|
|
516
|
+
image: h,
|
|
517
|
+
isOpen: P,
|
|
518
|
+
isLoading: U.isPending,
|
|
519
|
+
onClose: () => F(!1),
|
|
520
|
+
onActivate: ge
|
|
521
|
+
}),
|
|
522
|
+
I && /*#__PURE__*/ S(oe, {
|
|
523
|
+
image: h,
|
|
524
|
+
isOpen: I,
|
|
525
|
+
isLoading: H.isPending,
|
|
526
|
+
onClose: () => L(!1),
|
|
527
|
+
onDeactivate: _e
|
|
528
|
+
})
|
|
529
|
+
] });
|
|
530
|
+
}
|
|
531
|
+
//#endregion
|
|
532
|
+
export { P as component };
|
|
533
|
+
|
|
534
|
+
//# sourceMappingURL=_imageId-n3RcnhAR.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_imageId-n3RcnhAR.mjs","names":["React","useState","DescriptionList","DescriptionTerm","DescriptionDefinition","Container","ContentHeading","Stack","Message","Box","Button","ButtonRow","SizeDisplay","trpcReact","MEMBER_STATUSES","ClipboardText","ImageMembersTable","SharedImageBox","image","myMemberData","canUpdateMember","onStatusChange","isLoading","useLingui","isPending","status","PENDING","isRejected","REJECTED","sharedAt","created_at","Date","toLocaleString","t","updatedAt","updated_at","ownerProject","owner","p","className","span","ul","li","onClick","ACCEPTED","disabled","GeneralImageData","px","py","alignTerms","text","id","name","size","min_disk","min_ram","disk_format","container_format","toLocaleDateString","SecuritySection","currentProjectId","isSharedWithMe","visibility","undefined","protected","checksum","CustomPropertiesSection","knownFields","Set","customProperties","Object","entries","filter","key","has","sort","a","b","localeCompare","hasProperties","length","map","value","Fragment","JSON","stringify","String","getTabClassName","active","base","SharingDetailsTab","permissions","isAddingMember","setIsAddingMember","message","setMessage","data","imageMembers","isMembersLoading","compute","listImageMembers","useQuery","project_id","imageId","enabled","variant","type","onDismiss","canAdd","canCreateMember","canRemove","canDeleteMember","projectId","ImageDetailsView","activeTab","onTabChange","onMemberStatusChange","isMemberStatusChanging","actions","isImageOwner","showTabs","direction","gap","div","button","Button","ButtonRow","Stack","Spinner","PopupMenu","PopupMenuToggle","PopupMenuOptions","PopupMenuItem","Toast","ToastProps","useNavigate","useParams","useSearch","Trans","useLingui","trpcReact","ImageDetailsView","EditImageDetailsModal","EditImageMetadataModal","DeleteImageModal","ActivateImageModal","DeactivateImageModal","IMAGE_STATUSES","IMAGE_VISIBILITY","GlanceImage","MemberStatus","TRPCClientError","InferrableClientTypes","getImageAccessStatusUpdatedToast","getImageAccessStatusErrorToast","useState","ContentHeader","RouteComponent","projectId","imageId","from","tab","navigate","t","data","image","status","error","compute","getImageById","useQuery","project_id","permissionsData","canUser","permission","permissions","canDelete","canUpdate","canCreateMember","canDeleteMember","canUpdateMember","utils","useUtils","editDetailsModalOpen","setEditDetailsModalOpen","editMetadataModalOpen","setEditMetadataModalOpen","deleteModalOpen","setDeleteModalOpen","activateModalOpen","setActivateModalOpen","deactivateModalOpen","setDeactivateModalOpen","toastData","setToastData","updateImageMutation","updateImage","useMutation","onSuccess","updatedImage","setData","listImagesWithPagination","invalidate","deleteImageMutation","deleteImage","deactivateImageMutation","deactivateImage","reactivateImageMutation","reactivateImage","updateImageVisibilityMutation","updateImageVisibility","isSharedWithMe","visibility","SHARED","owner","undefined","myMemberData","getImageMember","memberId","enabled","updateMemberMutation","updateImageMember","listImageMembers","listSharedImagesByMemberStatus","handleMemberStatusChange","newStatus","mutateAsync","onDismiss","errorMessage","message","handleBack","to","params","isLoading","isPending","convertToJsonPatchOperations","updatedProperties","Partial","originalImage","Array","op","path","value","operations","Object","entries","forEach","key","push","propertyExists","handleSaveEdit","Promise","handleDelete","deletedImage","id","handleActivate","img","handleDeactivate","handleUpdateVisibility","newVisibility","isDeactivated","DEACTIVATED","isPrivate","PRIVATE","isMemberAccepted","isImageOwner","canRejectSharedImage","canUpdateOwnImage","canDeleteOwnImage","protected","canManageSharing","hasMoreActions","headerActions","search","String","name","newTab","component"],"sources":["../../src/client/routes/_auth/projects/$projectId/compute/-components/Images/-components/ImageDetailsView.tsx","../../src/client/routes/_auth/projects/$projectId/compute/images/$imageId.tsx?tsr-split=component"],"sourcesContent":["import React, { useState } from \"react\"\nimport {\n DescriptionList,\n DescriptionTerm,\n DescriptionDefinition,\n Container,\n ContentHeading,\n Stack,\n Message,\n Box,\n Button,\n ButtonRow,\n} from \"@cloudoperators/juno-ui-components\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { GlanceImage, ImageMember, MemberStatus } from \"@/server/Compute/types/image\"\nimport { SizeDisplay } from \"./SizeDisplay\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { MEMBER_STATUSES } from \"../../../-constants/filters\"\nimport ClipboardText from \"@/client/components/ClipboardText\"\nimport { ImageMembersTable } from \"./ImageMembersTable\"\n\ninterface ImageDetailsViewProps {\n image: GlanceImage\n currentProjectId?: string\n activeTab?: \"details\" | \"sharing\"\n onTabChange?: (tab: \"details\" | \"sharing\") => void\n permissions?: {\n canCreateMember: boolean\n canDeleteMember: boolean\n canUpdateMember: boolean\n }\n myMemberData?: ImageMember\n onMemberStatusChange?: (status: MemberStatus) => void\n isMemberStatusChanging?: boolean\n actions?: React.ReactNode\n}\n\nconst SharedImageBox: React.FC<{\n image: GlanceImage\n myMemberData: ImageMember\n canUpdateMember: boolean\n onStatusChange: (status: MemberStatus) => void\n isLoading: boolean\n}> = ({ image, myMemberData, canUpdateMember, onStatusChange, isLoading }) => {\n const { t } = useLingui()\n const isPending = myMemberData.status === MEMBER_STATUSES.PENDING\n const isRejected = myMemberData.status === MEMBER_STATUSES.REJECTED\n\n const sharedAt = myMemberData.created_at ? new Date(myMemberData.created_at).toLocaleString() : t`N/A`\n const updatedAt = myMemberData.updated_at ? new Date(myMemberData.updated_at).toLocaleString() : t`N/A`\n const ownerProject = image.owner ?? \"\"\n\n return (\n <Box>\n {isPending && (\n <p className=\"text-theme-highest font-semibold\">\n <Trans>Your action is required</Trans>\n </p>\n )}\n <p>\n <Trans>\n This image was shared with you by <span className=\"font-semibold\">{ownerProject}</span> on {sharedAt}.\n </Trans>\n </p>\n <ul>\n <li>\n <span className=\"font-semibold\">\n <Trans>Access Status:</Trans>\n </span>{\" \"}\n {myMemberData.status}\n </li>\n <li>\n <span className=\"font-semibold\">\n <Trans>Shared:</Trans>\n </span>{\" \"}\n {sharedAt}\n </li>\n <li>\n <span className=\"font-semibold\">\n <Trans>Updated:</Trans>\n </span>{\" \"}\n {updatedAt}\n </li>\n </ul>\n\n {canUpdateMember && (isPending || isRejected) && (\n <ButtonRow>\n <Button onClick={() => onStatusChange(MEMBER_STATUSES.ACCEPTED)} disabled={isLoading}>\n <Trans>Accept</Trans>\n </Button>\n {isPending && (\n <Button onClick={() => onStatusChange(MEMBER_STATUSES.REJECTED)} disabled={isLoading}>\n <Trans>Reject</Trans>\n </Button>\n )}\n </ButtonRow>\n )}\n </Box>\n )\n}\n\nexport const GeneralImageData: React.FC<{ image: GlanceImage }> = ({ image }) => {\n const { t } = useLingui()\n\n return (\n <Container px={false} py>\n <ContentHeading>{t`General Image Data`}</ContentHeading>\n <DescriptionList alignTerms=\"right\">\n <DescriptionTerm>{t`ID`}</DescriptionTerm>\n <DescriptionDefinition>\n <ClipboardText text={image.id} />\n </DescriptionDefinition>\n\n <DescriptionTerm>{t`Name`}</DescriptionTerm>\n <DescriptionDefinition>{image.name}</DescriptionDefinition>\n\n <DescriptionTerm>{t`Status`}</DescriptionTerm>\n <DescriptionDefinition>{image.status}</DescriptionDefinition>\n\n <DescriptionTerm>{t`Size`}</DescriptionTerm>\n <DescriptionDefinition>\n <SizeDisplay size={image.size} />\n </DescriptionDefinition>\n\n <DescriptionTerm>{t`Min. Disk`}</DescriptionTerm>\n <DescriptionDefinition>{image.min_disk} GB</DescriptionDefinition>\n\n <DescriptionTerm>{t`Min. RAM`}</DescriptionTerm>\n <DescriptionDefinition>{image.min_ram} MB</DescriptionDefinition>\n\n <DescriptionTerm>{t`Disk Format`}</DescriptionTerm>\n <DescriptionDefinition>\n <span className=\"uppercase\">{image.disk_format}</span>\n </DescriptionDefinition>\n\n <DescriptionTerm>{t`Container Format`}</DescriptionTerm>\n <DescriptionDefinition>\n <span className=\"uppercase\">{image.container_format}</span>\n </DescriptionDefinition>\n\n <DescriptionTerm>{t`Created At`}</DescriptionTerm>\n <DescriptionDefinition>\n {image.created_at ? new Date(image.created_at).toLocaleDateString() : t`N/A`}\n </DescriptionDefinition>\n\n <DescriptionTerm>{t`Updated At`}</DescriptionTerm>\n <DescriptionDefinition>\n {image.updated_at ? new Date(image.updated_at).toLocaleDateString() : t`N/A`}\n </DescriptionDefinition>\n </DescriptionList>\n </Container>\n )\n}\n\nexport const SecuritySection: React.FC<{ image: GlanceImage; currentProjectId?: string }> = ({\n image,\n currentProjectId,\n}) => {\n const { t } = useLingui()\n\n const isSharedWithMe = image.visibility === \"shared\" && image.owner !== undefined && image.owner !== currentProjectId\n\n return (\n <Container px={false} py>\n <ContentHeading>{t`Security`}</ContentHeading>\n <DescriptionList alignTerms=\"right\">\n <DescriptionTerm>{isSharedWithMe ? t`Shared by Project` : t`Owner Project ID`}</DescriptionTerm>\n <DescriptionDefinition>{image.owner ? <ClipboardText text={image.owner} /> : \"\"}</DescriptionDefinition>\n\n <DescriptionTerm>{t`Visibility`}</DescriptionTerm>\n <DescriptionDefinition>{image.visibility}</DescriptionDefinition>\n\n <DescriptionTerm>{t`Protected`}</DescriptionTerm>\n <DescriptionDefinition>{image.protected ? t`Yes` : t`No`}</DescriptionDefinition>\n\n <DescriptionTerm>{t`Checksum`}</DescriptionTerm>\n <DescriptionDefinition>{image?.checksum ? image.checksum : \"\"}</DescriptionDefinition>\n </DescriptionList>\n </Container>\n )\n}\n\nexport const CustomPropertiesSection: React.FC<{ image: GlanceImage }> = ({ image }) => {\n const { t } = useLingui()\n\n const knownFields = new Set([\n \"id\",\n \"name\",\n \"status\",\n \"visibility\",\n \"size\",\n \"disk_format\",\n \"container_format\",\n \"min_disk\",\n \"min_ram\",\n \"owner\",\n \"protected\",\n \"created_at\",\n \"updated_at\",\n \"checksum\",\n ])\n\n const customProperties = Object.entries(image)\n .filter(([key]) => !knownFields.has(key))\n .sort(([a], [b]) => a.localeCompare(b))\n\n const hasProperties = customProperties.length > 0\n\n return (\n <Container px={false} py>\n <ContentHeading>{t`Custom Properties / Metadata`}</ContentHeading>\n {hasProperties ? (\n <DescriptionList alignTerms=\"right\" className=\"grid-cols-4\">\n {customProperties.map(([key, value]) => (\n <React.Fragment key={key}>\n <DescriptionTerm className=\"col-span-1\">{key}</DescriptionTerm>\n <DescriptionDefinition className=\"col-span-1\">\n {value === null || value === undefined ? (\n <span>null</span>\n ) : typeof value === \"object\" ? (\n <span className=\"break-all\">{JSON.stringify(value)}</span>\n ) : typeof value === \"boolean\" ? (\n value ? (\n t`True`\n ) : (\n t`False`\n )\n ) : (\n <span className=\"break-all\">{String(value)}</span>\n )}\n </DescriptionDefinition>\n </React.Fragment>\n ))}\n </DescriptionList>\n ) : (\n <p className=\"text-theme-light\">{t`No custom properties defined`}</p>\n )}\n </Container>\n )\n}\n\nconst getTabClassName = (active: boolean) => {\n const base = \"px-6 py-3 font-semibold border-b-2 transition-colors\"\n return active\n ? `${base} border-theme-accent text-theme-highest`\n : `${base} border-transparent text-theme-secondary hover:text-theme-high`\n}\n\nconst SharingDetailsTab: React.FC<ImageDetailsViewProps> = ({ image, permissions, currentProjectId }) => {\n const [isAddingMember, setIsAddingMember] = useState(false)\n const [message, setMessage] = useState<{ text: string; type: \"error\" | \"info\" } | null>(null)\n\n const { data: imageMembers, isLoading: isMembersLoading } = trpcReact.compute.listImageMembers.useQuery(\n { project_id: currentProjectId!, imageId: image.id },\n { enabled: !!image.id && !!currentProjectId }\n )\n\n return (\n <Container px={false} py>\n {message && (\n <Message text={message.text} variant={message.type} onDismiss={() => setMessage(null)} className=\"mb-4\" />\n )}\n <ImageMembersTable\n image={image}\n imageMembers={imageMembers}\n isMembersLoading={isMembersLoading}\n canAdd={permissions?.canCreateMember ?? false}\n canRemove={permissions?.canDeleteMember ?? false}\n isAddingMember={isAddingMember}\n setIsAddingMember={setIsAddingMember}\n setMessage={setMessage}\n projectId={currentProjectId!}\n />\n </Container>\n )\n}\n\nexport const ImageDetailsView: React.FC<ImageDetailsViewProps> = ({\n image,\n currentProjectId,\n activeTab = \"details\",\n onTabChange,\n permissions,\n myMemberData,\n onMemberStatusChange,\n isMemberStatusChanging,\n actions,\n}) => {\n const { t } = useLingui()\n\n const isSharedWithMe = image.visibility === \"shared\" && image.owner !== undefined && image.owner !== currentProjectId\n const isImageOwner = image.owner === currentProjectId\n const showTabs = isImageOwner && image.visibility === \"shared\"\n\n return (\n <Stack direction=\"vertical\" gap=\"6\">\n {isSharedWithMe && myMemberData && onMemberStatusChange && (\n <SharedImageBox\n image={image}\n myMemberData={myMemberData}\n canUpdateMember={permissions?.canUpdateMember ?? false}\n onStatusChange={onMemberStatusChange}\n isLoading={isMemberStatusChanging ?? false}\n />\n )}\n\n {showTabs && (\n <div className=\"border-theme-background-lvl-3 border-b\">\n <Stack direction=\"horizontal\" gap=\"0\">\n <button className={getTabClassName(activeTab === \"details\")} onClick={() => onTabChange?.(\"details\")}>\n {t`Details`}\n </button>\n <button className={getTabClassName(activeTab === \"sharing\")} onClick={() => onTabChange?.(\"sharing\")}>\n {t`Sharing Details`}\n </button>\n </Stack>\n </div>\n )}\n\n {(activeTab === \"details\" || !showTabs) && (\n <>\n {actions}\n <GeneralImageData image={image} />\n <SecuritySection image={image} currentProjectId={currentProjectId} />\n <CustomPropertiesSection image={image} />\n </>\n )}\n\n {activeTab === \"sharing\" && showTabs && <SharingDetailsTab image={image} permissions={permissions} />}\n </Stack>\n )\n}\n","import {\n Button,\n ButtonRow,\n Stack,\n Spinner,\n PopupMenu,\n PopupMenuToggle,\n PopupMenuOptions,\n PopupMenuItem,\n Toast,\n ToastProps,\n} from \"@cloudoperators/juno-ui-components/index\"\nimport { createFileRoute, redirect, useNavigate, useParams, useSearch } from \"@tanstack/react-router\"\nimport { z } from \"zod\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { getServiceIndex } from \"@/server/Authentication/helpers\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { ImageDetailsView } from \"../-components/Images/-components/ImageDetailsView\"\nimport { EditImageDetailsModal } from \"../-components/Images/-components/EditImageDetailsModal\"\nimport { EditImageMetadataModal } from \"../-components/Images/-components/EditImageMetadataModal\"\nimport { DeleteImageModal } from \"../-components/Images/-components/DeleteImageModal\"\nimport { ActivateImageModal } from \"../-components/Images/-components/ActivateImageModal\"\nimport { DeactivateImageModal } from \"../-components/Images/-components/DeactivateImageModal\"\nimport { IMAGE_STATUSES, IMAGE_VISIBILITY } from \"../-constants/filters\"\nimport { GlanceImage, MemberStatus } from \"@/server/Compute/types/image\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { InferrableClientTypes } from \"@trpc/server/unstable-core-do-not-import\"\nimport {\n getImageAccessStatusUpdatedToast,\n getImageAccessStatusErrorToast,\n} from \"../-components/Images/-components/ImageToastNotifications\"\nimport { useState } from \"react\"\nimport { ContentHeader } from \"@/client/components/ContentHeader/ContentHeader\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/compute/images/$imageId\")({\n staticData: {\n section: \"compute\",\n service: \"images\",\n isDetail: true,\n sectionCrumb: { labelKey: \"Compute\" },\n crumb: { labelKey: \"Images\", to: \"/projects/$projectId/compute/images\" },\n } satisfies RouteInfo,\n validateSearch: z.object({\n tab: z.enum([\"details\", \"sharing\"]).optional(),\n }),\n loader: async ({ context, params }) => {\n try {\n const image = await context.trpcClient?.compute.getImageById.query({\n project_id: params.projectId,\n imageId: params.imageId,\n })\n return { imageTitle: (image?.name as string | undefined) ?? image?.id ?? null }\n } catch {\n return { imageTitle: null }\n }\n },\n head: ({ loaderData }) => ({\n meta: [{ title: loaderData?.imageTitle ?? \"Image Details\" }],\n }),\n component: RouteComponent,\n beforeLoad: async ({ context, params }) => {\n const { trpcClient } = context\n const { projectId } = params\n\n const availableServices = (await trpcClient?.auth.getAvailableServices.query()) || []\n\n const serviceIndex = getServiceIndex(availableServices)\n\n // Redirect to the \"Projects Overview\" page if none of compute services available\n if (!serviceIndex[\"image\"] && !serviceIndex[\"compute\"]) {\n throw redirect({\n to: \"/projects/$projectId\",\n params: { projectId },\n })\n }\n\n if (!serviceIndex[\"image\"][\"glance\"]) {\n // Redirect to the \"Compute Services Overview\" page if the \"Glance\" service is not available\n throw redirect({\n to: \"/projects/$projectId\",\n params: { projectId: params.projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { projectId, imageId } = useParams({\n from: \"/_auth/projects/$projectId/compute/images/$imageId\",\n })\n const { tab } = useSearch({\n from: \"/_auth/projects/$projectId/compute/images/$imageId\",\n })\n\n const navigate = useNavigate()\n const { t } = useLingui()\n\n const {\n data: image,\n status,\n error,\n } = trpcReact.compute.getImageById.useQuery({ project_id: projectId, imageId: imageId })\n\n const { data: permissionsData } = trpcReact.compute.canUser.useQuery({\n project_id: projectId,\n permission: [\n \"images:delete\",\n \"images:update\",\n \"images:create_member\",\n \"images:delete_member\",\n \"images:update_member\",\n ],\n })\n\n const permissions = {\n canDelete: permissionsData?.[0] ?? false,\n canUpdate: permissionsData?.[1] ?? false,\n canCreateMember: permissionsData?.[2] ?? false,\n canDeleteMember: permissionsData?.[3] ?? false,\n canUpdateMember: permissionsData?.[4] ?? false,\n }\n\n const utils = trpcReact.useUtils()\n\n const [editDetailsModalOpen, setEditDetailsModalOpen] = useState(false)\n const [editMetadataModalOpen, setEditMetadataModalOpen] = useState(false)\n const [deleteModalOpen, setDeleteModalOpen] = useState(false)\n const [activateModalOpen, setActivateModalOpen] = useState(false)\n const [deactivateModalOpen, setDeactivateModalOpen] = useState(false)\n const [toastData, setToastData] = useState<ToastProps | null>(null)\n\n const updateImageMutation = trpcReact.compute.updateImage.useMutation({\n onSuccess: (updatedImage) => {\n utils.compute.getImageById.setData({ project_id: projectId, imageId }, updatedImage)\n utils.compute.listImagesWithPagination.invalidate()\n },\n })\n\n const deleteImageMutation = trpcReact.compute.deleteImage.useMutation({\n onSuccess: () => {\n utils.compute.listImagesWithPagination.invalidate()\n },\n })\n\n const deactivateImageMutation = trpcReact.compute.deactivateImage.useMutation({\n onSuccess: () => {\n utils.compute.getImageById.invalidate({ project_id: projectId, imageId })\n },\n })\n\n const reactivateImageMutation = trpcReact.compute.reactivateImage.useMutation({\n onSuccess: () => {\n utils.compute.getImageById.invalidate({ project_id: projectId, imageId })\n },\n })\n\n const updateImageVisibilityMutation = trpcReact.compute.updateImageVisibility.useMutation({\n onSuccess: (updatedImage) => {\n utils.compute.getImageById.setData({ project_id: projectId, imageId }, updatedImage)\n },\n })\n\n const isSharedWithMe =\n image?.visibility === IMAGE_VISIBILITY.SHARED && image?.owner !== undefined && image?.owner !== projectId\n\n const { data: myMemberData } = trpcReact.compute.getImageMember.useQuery(\n { project_id: projectId, imageId: imageId, memberId: projectId },\n { enabled: isSharedWithMe && !!imageId && !!projectId }\n )\n\n const updateMemberMutation = trpcReact.compute.updateImageMember.useMutation({\n onSuccess: () => {\n utils.compute.getImageMember.invalidate({ project_id: projectId, imageId: imageId, memberId: projectId })\n utils.compute.listImageMembers.invalidate({ project_id: projectId, imageId: imageId })\n utils.compute.listImagesWithPagination.invalidate()\n utils.compute.listSharedImagesByMemberStatus.invalidate()\n },\n })\n\n const handleMemberStatusChange = async (newStatus: MemberStatus) => {\n try {\n await updateMemberMutation.mutateAsync({ project_id: projectId, imageId, memberId: projectId, status: newStatus })\n setToastData(getImageAccessStatusUpdatedToast(newStatus, { onDismiss: () => setToastData(null) }))\n } catch (error) {\n const errorMessage = (error as TRPCClientError<InferrableClientTypes>)?.message\n setToastData(getImageAccessStatusErrorToast(errorMessage, { onDismiss: () => setToastData(null) }))\n }\n }\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/compute/images\",\n params: { projectId },\n })\n }\n\n const isLoading =\n updateImageMutation.isPending ||\n deleteImageMutation.isPending ||\n deactivateImageMutation.isPending ||\n reactivateImageMutation.isPending ||\n updateImageVisibilityMutation.isPending\n\n const convertToJsonPatchOperations = (\n updatedProperties: Partial<GlanceImage>,\n originalImage: GlanceImage\n ): Array<{ op: \"add\" | \"replace\" | \"remove\"; path: string; value?: unknown }> => {\n const operations: Array<{ op: \"add\" | \"replace\" | \"remove\"; path: string; value?: unknown }> = []\n Object.entries(updatedProperties).forEach(([key, value]) => {\n const path = `/${key}`\n if (value === null || value === undefined) {\n if (key in originalImage) operations.push({ op: \"remove\", path })\n } else {\n const propertyExists = key in originalImage\n operations.push({ op: propertyExists ? \"replace\" : \"add\", path, value })\n }\n })\n return operations\n }\n\n const handleSaveEdit = async (updatedProperties: Partial<GlanceImage>): Promise<boolean> => {\n if (!image) return false\n const operations = convertToJsonPatchOperations(updatedProperties, image)\n try {\n await updateImageMutation.mutateAsync({ project_id: projectId, imageId, operations })\n setEditDetailsModalOpen(false)\n return true\n } catch {\n return false\n }\n }\n\n const handleDelete = async (deletedImage: GlanceImage) => {\n try {\n await deleteImageMutation.mutateAsync({ project_id: projectId, imageId: deletedImage.id })\n setDeleteModalOpen(false)\n handleBack()\n } catch {\n setDeleteModalOpen(false)\n }\n }\n\n const handleActivate = async (img: GlanceImage) => {\n try {\n await reactivateImageMutation.mutateAsync({ project_id: projectId, imageId: img.id })\n setActivateModalOpen(false)\n } catch {\n setActivateModalOpen(false)\n }\n }\n\n const handleDeactivate = async (img: GlanceImage) => {\n try {\n await deactivateImageMutation.mutateAsync({ project_id: projectId, imageId: img.id })\n setDeactivateModalOpen(false)\n } catch {\n setDeactivateModalOpen(false)\n }\n }\n\n const handleUpdateVisibility = async (newVisibility: \"public\" | \"private\" | \"shared\" | \"community\") => {\n if (!image) return\n try {\n await updateImageVisibilityMutation.mutateAsync({\n project_id: projectId,\n imageId: image.id,\n visibility: newVisibility,\n })\n } catch {\n // error handled by mutation state\n }\n }\n\n // Handle loading state\n if (status === \"pending\") {\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\">\n <Spinner variant=\"primary\" size=\"large\" className=\"mb-2\" />\n <Trans>Loading Image Details...</Trans>\n </Stack>\n )\n }\n\n // Handle error state\n if (status === \"error\") {\n const errorMessage = error?.message || \"Unknown error\"\n\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\" gap=\"5\">\n <p className=\"text-theme-error font-semibold\">\n <Trans>Error loading image</Trans>\n </p>\n <p className=\"text-theme-highest\">{errorMessage}</p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Images</Trans>\n </Button>\n </Stack>\n )\n }\n\n // Handle no data state\n if (!image) {\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\" gap=\"5\">\n <p className=\"text-theme-highest\">\n <Trans>Image not found</Trans>\n </p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Images</Trans>\n </Button>\n </Stack>\n )\n }\n\n const isDeactivated = image.status === IMAGE_STATUSES.DEACTIVATED\n const isPrivate = image.visibility === IMAGE_VISIBILITY.PRIVATE\n const isMemberAccepted = myMemberData?.status === \"accepted\"\n const isImageOwner = image.owner === projectId\n\n const canRejectSharedImage = isSharedWithMe && isMemberAccepted && permissions.canUpdateMember\n const canUpdateOwnImage = !isSharedWithMe && permissions.canUpdate\n const canDeleteOwnImage = !isSharedWithMe && permissions.canDelete && !image.protected\n const canManageSharing =\n !isSharedWithMe &&\n isImageOwner &&\n image.visibility === IMAGE_VISIBILITY.SHARED &&\n (permissions.canCreateMember || permissions.canDeleteMember)\n\n const hasMoreActions = canRejectSharedImage || canUpdateOwnImage || canDeleteOwnImage || canManageSharing\n\n const headerActions =\n hasMoreActions || (!isSharedWithMe && permissions.canUpdate) ? (\n <ButtonRow>\n {hasMoreActions && (\n <PopupMenu>\n <PopupMenuToggle as=\"div\">\n <Button icon=\"moreVert\" disabled={isLoading}>\n <Trans>More Actions</Trans>\n </Button>\n </PopupMenuToggle>\n <PopupMenuOptions>\n {canRejectSharedImage && (\n <PopupMenuItem label={t`Reject`} onClick={() => handleMemberStatusChange(\"rejected\")} />\n )}\n {!isSharedWithMe && permissions.canUpdate && (\n <PopupMenuItem\n label={isDeactivated ? t`Activate` : t`Deactivate`}\n onClick={() => (isDeactivated ? setActivateModalOpen(true) : setDeactivateModalOpen(true))}\n />\n )}\n {!isSharedWithMe && permissions.canUpdate && isPrivate && (\n <PopupMenuItem label={t`Set to \"Shared\"`} onClick={() => handleUpdateVisibility(\"shared\")} />\n )}\n {!isSharedWithMe &&\n isImageOwner &&\n image.visibility === IMAGE_VISIBILITY.SHARED &&\n (permissions.canCreateMember || permissions.canDeleteMember) && (\n <PopupMenuItem\n label={t`Manage Access`}\n onClick={() =>\n navigate({\n to: \"/projects/$projectId/compute/images/$imageId\",\n params: { projectId, imageId: image.id },\n search: { tab: \"sharing\" },\n })\n }\n />\n )}\n {!isSharedWithMe && permissions.canDelete && !image.protected && (\n <PopupMenuItem label={t`Delete`} onClick={() => setDeleteModalOpen(true)} />\n )}\n </PopupMenuOptions>\n </PopupMenu>\n )}\n {!isSharedWithMe && permissions.canUpdate && (\n <Button onClick={() => setEditMetadataModalOpen(true)} disabled={isLoading}>\n <Trans>Edit Metadata</Trans>\n </Button>\n )}\n {!isSharedWithMe && permissions.canUpdate && (\n <Button onClick={() => setEditDetailsModalOpen(true)} variant=\"primary\" disabled={isLoading}>\n <Trans>Edit Details</Trans>\n </Button>\n )}\n </ButtonRow>\n ) : undefined\n\n // Render success state\n return (\n <>\n <ContentHeader title={String(image.name ?? image.id)} projectId={projectId} actions={headerActions} />\n <div className=\"mt-3\">\n <ImageDetailsView\n key={image.id}\n image={image}\n currentProjectId={projectId}\n activeTab={tab ?? \"details\"}\n onTabChange={(newTab) =>\n navigate({\n search: { tab: newTab === \"details\" ? undefined : newTab } as unknown as true,\n })\n }\n permissions={{\n canCreateMember: permissions.canCreateMember,\n canDeleteMember: permissions.canDeleteMember,\n canUpdateMember: permissions.canUpdateMember,\n }}\n myMemberData={myMemberData}\n onMemberStatusChange={handleMemberStatusChange}\n isMemberStatusChanging={updateMemberMutation.isPending}\n />\n </div>\n\n {toastData && <Toast {...toastData} />}\n\n {editDetailsModalOpen && (\n <EditImageDetailsModal\n image={image}\n isOpen={editDetailsModalOpen}\n isLoading={updateImageMutation.isPending}\n onClose={() => setEditDetailsModalOpen(false)}\n onSave={handleSaveEdit}\n />\n )}\n\n {editMetadataModalOpen && (\n <EditImageMetadataModal\n image={image}\n isOpen={editMetadataModalOpen}\n isLoading={updateImageMutation.isPending}\n onClose={() => setEditMetadataModalOpen(false)}\n onSave={handleSaveEdit}\n />\n )}\n\n {deleteModalOpen && (\n <DeleteImageModal\n image={image}\n isOpen={deleteModalOpen}\n isLoading={deleteImageMutation.isPending}\n isDisabled={!!image.protected}\n onClose={() => setDeleteModalOpen(false)}\n onDelete={handleDelete}\n />\n )}\n\n {activateModalOpen && (\n <ActivateImageModal\n image={image}\n isOpen={activateModalOpen}\n isLoading={reactivateImageMutation.isPending}\n onClose={() => setActivateModalOpen(false)}\n onActivate={handleActivate}\n />\n )}\n\n {deactivateModalOpen && (\n <DeactivateImageModal\n image={image}\n isOpen={deactivateModalOpen}\n isLoading={deactivateImageMutation.isPending}\n onClose={() => setDeactivateModalOpen(false)}\n onDeactivate={handleDeactivate}\n />\n )}\n </>\n )\n}\n"],"mappings":"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"}
|