@cobaltcore-dev/aurora 0.9.0 → 0.11.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 +2 -1
- package/dist/client/AuroraApp.d.ts +2 -0
- package/dist/client/AuthProvider-DZqOvceF.mjs +64 -0
- package/dist/client/AuthProvider-DZqOvceF.mjs.map +1 -0
- package/dist/client/ContentHeader-DsuZD8fa.mjs +110 -0
- package/dist/client/ContentHeader-DsuZD8fa.mjs.map +1 -0
- package/dist/client/{DeleteFlavorModal-C3m7bQJu.mjs → DeleteFlavorModal-RnbspW_2.mjs} +135 -135
- package/dist/client/{DeleteFlavorModal-C3m7bQJu.mjs.map → DeleteFlavorModal-RnbspW_2.mjs.map} +1 -1
- package/dist/client/DeleteVersionsModal-CsBJzXoW.mjs +331 -0
- package/dist/client/DeleteVersionsModal-CsBJzXoW.mjs.map +1 -0
- package/dist/client/{EditSecurityGroupModal-DKusxfta.mjs → EditSecurityGroupModal-BPv3d7am.mjs} +15 -15
- package/dist/client/{EditSecurityGroupModal-DKusxfta.mjs.map → EditSecurityGroupModal-BPv3d7am.mjs.map} +1 -1
- package/dist/client/{FiltersInput-GzR4D0q6.mjs → FiltersInput-CViamP59.mjs} +2 -2
- package/dist/client/{FiltersInput-GzR4D0q6.mjs.map → FiltersInput-CViamP59.mjs.map} +1 -1
- package/dist/client/{FloatingIpActionModals-CRvROJ3H.mjs → FloatingIpActionModals-DTn3HFei.mjs} +45 -45
- package/dist/client/{FloatingIpActionModals-CRvROJ3H.mjs.map → FloatingIpActionModals-DTn3HFei.mjs.map} +1 -1
- package/dist/client/{ImageToastNotifications-BuDXpTkl.mjs → ImageToastNotifications-CFKQZTgf.mjs} +261 -261
- package/dist/client/{ImageToastNotifications-BuDXpTkl.mjs.map → ImageToastNotifications-CFKQZTgf.mjs.map} +1 -1
- package/dist/client/{RouteError-DVAiT0mT.mjs → RouteError-BebIhFpQ.mjs} +2 -2
- package/dist/client/{RouteError-DVAiT0mT.mjs.map → RouteError-BebIhFpQ.mjs.map} +1 -1
- package/dist/client/{SortInput-VK7IYqQv.mjs → SortInput-D0Vb864D.mjs} +9 -9
- package/dist/client/SortInput-D0Vb864D.mjs.map +1 -0
- package/dist/client/{_auth-DXJkv9QO.mjs → _auth-DnImOqR-.mjs} +2 -2
- package/dist/client/_auth-DnImOqR-.mjs.map +1 -0
- package/dist/client/{_flavorId-Dy7EYQum.mjs → _flavorId-C9SZd1jL.mjs} +8 -8
- package/dist/client/{_flavorId-Dy7EYQum.mjs.map → _flavorId-C9SZd1jL.mjs.map} +1 -1
- package/dist/client/{_flavorId-DsD2VTKA.mjs → _flavorId-DINgWoeV.mjs} +38 -38
- package/dist/client/{_flavorId-DsD2VTKA.mjs.map → _flavorId-DINgWoeV.mjs.map} +1 -1
- package/dist/client/{_floatingIpId-j17rCQqG2.mjs → _floatingIpId-BACLbMzi2.mjs} +32 -32
- package/dist/client/{_floatingIpId-j17rCQqG2.mjs.map → _floatingIpId-BACLbMzi2.mjs.map} +1 -1
- package/dist/client/{_floatingIpId-BjVbeNw_.mjs → _floatingIpId-BzVMOv97.mjs} +2 -2
- package/dist/client/{_floatingIpId-BjVbeNw_.mjs.map → _floatingIpId-BzVMOv97.mjs.map} +1 -1
- package/dist/client/_imageId-DCvaU7-S.mjs +534 -0
- package/dist/client/_imageId-DCvaU7-S.mjs.map +1 -0
- package/dist/client/{_pcaId-BwTvJJgh.mjs → _pcaId-B3PqECyO.mjs} +115 -115
- package/dist/client/{_pcaId-BwTvJJgh.mjs.map → _pcaId-B3PqECyO.mjs.map} +1 -1
- package/dist/client/{_pcaId-DUHQd0rB.mjs → _pcaId-DAJEt3ZI.mjs} +2 -2
- package/dist/client/{_pcaId-DUHQd0rB.mjs.map → _pcaId-DAJEt3ZI.mjs.map} +1 -1
- package/dist/client/{_projectId-CARHuZTU.mjs → _projectId-B2hG5peP.mjs} +3 -3
- package/dist/client/_projectId-B2hG5peP.mjs.map +1 -0
- package/dist/client/{_projectId-DR_2U10f.mjs → _projectId-BnWXWTBR.mjs} +3 -3
- package/dist/client/_projectId-BnWXWTBR.mjs.map +1 -0
- package/dist/client/{_projectId-BaqZ4W50.mjs → _projectId-DRr9rLST.mjs} +103 -109
- package/dist/client/_projectId-DRr9rLST.mjs.map +1 -0
- package/dist/client/{_projectId-B_2sZKk-.mjs → _projectId-DU8qRiZk.mjs} +2 -2
- package/dist/client/_projectId-DU8qRiZk.mjs.map +1 -0
- package/dist/client/{_securityGroupId-fhK1CuZh.mjs → _securityGroupId-Cj9IotMJ.mjs} +2 -2
- package/dist/client/{_securityGroupId-fhK1CuZh.mjs.map → _securityGroupId-Cj9IotMJ.mjs.map} +1 -1
- package/dist/client/{_securityGroupId-DYxmXUOP.mjs → _securityGroupId-ClJiFh4R.mjs} +267 -267
- package/dist/client/{_securityGroupId-DYxmXUOP.mjs.map → _securityGroupId-ClJiFh4R.mjs.map} +1 -1
- package/dist/client/_storageType-BrHDa2bD.mjs +3005 -0
- package/dist/client/_storageType-BrHDa2bD.mjs.map +1 -0
- package/dist/client/{_storageType-D7-_Xwwl.mjs → _storageType-CSLH93js.mjs} +2 -2
- package/dist/client/{_storageType-D7-_Xwwl.mjs.map → _storageType-CSLH93js.mjs.map} +1 -1
- package/dist/client/_storageType-zeSZe--V.mjs.map +1 -1
- package/dist/client/{about-Nsxkyh9U.mjs → about-BnU297yB.mjs} +2 -2
- package/dist/client/about-BnU297yB.mjs.map +1 -0
- package/dist/client/{aurora-DDzsst74.mjs → aurora-6RsAZtnz.mjs} +2 -2
- package/dist/client/aurora-6RsAZtnz.mjs.map +1 -0
- package/dist/client/{build-BdRRmNf5.mjs → build-DF7MTyXG.mjs} +3582 -3114
- package/dist/client/{build-BdRRmNf5.mjs.map → build-DF7MTyXG.mjs.map} +1 -1
- package/dist/client/{constants-J5nm9hbP.mjs → constants-BskfpGYY.mjs} +17 -17
- package/dist/client/{constants-J5nm9hbP.mjs.map → constants-BskfpGYY.mjs.map} +1 -1
- package/dist/client/{flavors-C-gY4XeQ.mjs → flavors-DAbtRoep.mjs} +151 -151
- package/dist/client/{flavors-C-gY4XeQ.mjs.map → flavors-DAbtRoep.mjs.map} +1 -1
- package/dist/client/{flavors-Dwy1ID_f.mjs → flavors-DODudzrA.mjs} +2 -2
- package/dist/client/{flavors-Dwy1ID_f.mjs.map → flavors-DODudzrA.mjs.map} +1 -1
- package/dist/client/flavors-DWMZ6TuJ.mjs.map +1 -1
- package/dist/client/{floatingips-Dq4DXQYb.mjs → floatingips-DJW9ftN_.mjs} +84 -84
- package/dist/client/floatingips-DJW9ftN_.mjs.map +1 -0
- package/dist/client/{hooks-dSArr2Ca.mjs → hooks-CMgoYcDG.mjs} +1 -1
- package/dist/client/{images-bG-MZZ7V.mjs → images-BbLnuYrL.mjs} +2 -2
- package/dist/client/{images-bG-MZZ7V.mjs.map → images-BbLnuYrL.mjs.map} +1 -1
- package/dist/client/{images-Dbjo4yKn.mjs → images-C3JyPwer.mjs} +2 -2
- package/dist/client/images-C3JyPwer.mjs.map +1 -0
- package/dist/client/{images-HG7TneK0.mjs → images-Cp6V1nF5.mjs} +455 -455
- package/dist/client/{images-HG7TneK0.mjs.map → images-Cp6V1nF5.mjs.map} +1 -1
- package/dist/client/images-NBf2bV43.mjs.map +1 -1
- package/dist/client/index.js +270 -266
- package/dist/client/index.js.map +1 -1
- package/dist/client/{md-CYTrL5dq.mjs → md-CyCflQee.mjs} +10 -28
- package/dist/client/{md-CYTrL5dq.mjs.map → md-CyCflQee.mjs.map} +1 -1
- package/dist/client/network-DuZm76BZ.mjs.map +1 -1
- package/dist/client/{objects-DKWp9RtR.mjs → objects-Bw96WXOs.mjs} +4 -3
- package/dist/client/objects-Bw96WXOs.mjs.map +1 -0
- package/dist/client/objects-DUmK3WgA.mjs +5998 -0
- package/dist/client/objects-DUmK3WgA.mjs.map +1 -0
- package/dist/client/objects-o2Cj_ndZ.mjs.map +1 -1
- package/dist/client/{pca-D7DF_BZZ.mjs → pca-DKeGzbww.mjs} +2 -2
- package/dist/client/{pca-D7DF_BZZ.mjs.map → pca-DKeGzbww.mjs.map} +1 -1
- package/dist/client/{pca-BBxPCAH0.mjs → pca-Dc_tdh4-.mjs} +47 -47
- package/dist/client/{pca-BBxPCAH0.mjs.map → pca-Dc_tdh4-.mjs.map} +1 -1
- package/dist/client/{projects-DNd3UTas.mjs → projects-CRL37ftA.mjs} +16 -16
- package/dist/client/{projects-DNd3UTas.mjs.map → projects-CRL37ftA.mjs.map} +1 -1
- package/dist/client/{projects-B5topuei.mjs → projects-DUWOgB3m.mjs} +2 -2
- package/dist/client/{projects-B5topuei.mjs.map → projects-DUWOgB3m.mjs.map} +1 -1
- package/dist/client/{projects-CHYn7L5e.mjs → projects-DpXQYfKc.mjs} +2 -2
- package/dist/client/projects-DpXQYfKc.mjs.map +1 -0
- package/dist/client/{securitygroups-CNFLu9zS.mjs → securitygroups-CWWFSjjj.mjs} +94 -94
- package/dist/client/securitygroups-CWWFSjjj.mjs.map +1 -0
- package/dist/client/{useListWithFiltering-v2A0-SZb.mjs → useListWithFiltering-C9k7xWqz.mjs} +7 -7
- package/dist/client/{useListWithFiltering-v2A0-SZb.mjs.map → useListWithFiltering-C9k7xWqz.mjs.map} +1 -1
- package/dist/server/index.js +979 -454
- package/package.json +3 -3
- package/dist/client/AuthProvider-Co4d0WzB.mjs +0 -100
- package/dist/client/AuthProvider-Co4d0WzB.mjs.map +0 -1
- package/dist/client/ContentHeader-D4jlOG-9.mjs +0 -96
- package/dist/client/ContentHeader-D4jlOG-9.mjs.map +0 -1
- package/dist/client/SortInput-VK7IYqQv.mjs.map +0 -1
- package/dist/client/_auth-DXJkv9QO.mjs.map +0 -1
- package/dist/client/_imageId-BjfhqAje.mjs +0 -534
- package/dist/client/_imageId-BjfhqAje.mjs.map +0 -1
- package/dist/client/_projectId-B_2sZKk-.mjs.map +0 -1
- package/dist/client/_projectId-BaqZ4W50.mjs.map +0 -1
- package/dist/client/_projectId-CARHuZTU.mjs.map +0 -1
- package/dist/client/_projectId-DR_2U10f.mjs.map +0 -1
- package/dist/client/_storageType-B0eJODiQ.mjs +0 -3244
- package/dist/client/_storageType-B0eJODiQ.mjs.map +0 -1
- package/dist/client/about-Nsxkyh9U.mjs.map +0 -1
- package/dist/client/aurora-DDzsst74.mjs.map +0 -1
- package/dist/client/floatingips-Dq4DXQYb.mjs.map +0 -1
- package/dist/client/images-Dbjo4yKn.mjs.map +0 -1
- package/dist/client/objects-DKWp9RtR.mjs.map +0 -1
- package/dist/client/objects-DaCuy_CB.mjs +0 -5708
- package/dist/client/objects-DaCuy_CB.mjs.map +0 -1
- package/dist/client/projects-CHYn7L5e.mjs.map +0 -1
- package/dist/client/securitygroups-CNFLu9zS.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_floatingIpId-j17rCQqG2.mjs","names":["formatFloatingIpStatus","status","charAt","slice","toLowerCase","Fragment","DescriptionDefinition","DescriptionList","DescriptionTerm","Stack","TwoColumnDescriptionList","items","mid","Math","ceil","length","firstColumn","slice","secondColumn","gap","className","alignTerms","map","label","value","Stack","ButtonRow","Button","ContentHeading","formatFloatingIpStatus","TwoColumnDescriptionList","FloatingIpActionModals","FloatingIpDetailsView","floatingIp","useLingui","basicInfoItems","label","t","value","id","description","project_id","status","created_at","Date","toLocaleString","updated_at","tags","join","networkRoutingItems","floating_ip_address","floating_network_id","fixed_ip_address","port_details","name","mac_address","network_id","device_owner","device_id","router_id","port_id","qos_policy_id","port_forwardings","map","port","dnsItems","dns_domain","dns_name","p","className","toggleEditModal","toggleAttachModal","toggleDetachModal","toggleReleaseModal","onClick","direction","gap","items","useNavigate","Button","ContentHeading","Stack","Spinner","Trans","useProjectId","trpcReact","FloatingIpDetailsView","Route","RouteComponent","floatingIpId","useParams","projectId","navigate","data","floatingIp","isLoading","isError","error","network","getById","useQuery","project_id","floatingip_id","handleBack","to","params","errorMessage","message","floating_ip_address","component"],"sources":["../../src/client/utils/formatFloatingIpStatus.ts","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/-components/TwoColumnDescriptionList.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/-components/-details/FloatingIpDetailsView.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/index.tsx?tsr-split=component"],"sourcesContent":["import type { FloatingIpStatus } from \"@/server/Network/types/floatingIp\"\n\n/**\n * Formats a floating IP status value from uppercase enum to title case.\n * Example: \"ACTIVE\" → \"Active\", \"DOWN\" → \"Down\", \"ERROR\" → \"Error\"\n */\nexport const formatFloatingIpStatus = (status: FloatingIpStatus) => {\n return status.charAt(0) + status.slice(1).toLowerCase()\n}\n","import { Fragment } from \"react\"\nimport { DescriptionDefinition, DescriptionList, DescriptionTerm, Stack } from \"@cloudoperators/juno-ui-components\"\n\nexport type DetailListItem = {\n label: string\n value: string\n}\n\ninterface TwoColumnDescriptionListProps {\n items: DetailListItem[]\n}\n\nexport const TwoColumnDescriptionList = ({ items }: TwoColumnDescriptionListProps) => {\n const mid = Math.ceil(items.length / 2)\n const firstColumn = items.slice(0, mid)\n const secondColumn = items.slice(mid)\n\n return (\n <Stack gap=\"6\" className=\"grid grid-cols-2\">\n <DescriptionList alignTerms=\"right\">\n {firstColumn.map(({ label, value }) => (\n <Fragment key={label}>\n <DescriptionTerm>{label}</DescriptionTerm>\n <DescriptionDefinition>{value}</DescriptionDefinition>\n </Fragment>\n ))}\n </DescriptionList>\n\n <DescriptionList alignTerms=\"right\">\n {secondColumn.map(({ label, value }) => (\n <Fragment key={label}>\n <DescriptionTerm>{label}</DescriptionTerm>\n <DescriptionDefinition>{value}</DescriptionDefinition>\n </Fragment>\n ))}\n </DescriptionList>\n </Stack>\n )\n}\n","import { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Stack, ButtonRow, Button, ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\nimport { formatFloatingIpStatus } from \"@/client/utils/formatFloatingIpStatus\"\nimport { DetailListItem, TwoColumnDescriptionList } from \"../TwoColumnDescriptionList\"\nimport { FloatingIpActionModals } from \"../../../-components/-modals/FloatingIpActionModals\"\n\ninterface FloatingIpDetailsViewProps {\n floatingIp: FloatingIp\n}\n\nexport const FloatingIpDetailsView = ({ floatingIp }: FloatingIpDetailsViewProps) => {\n const { t } = useLingui()\n\n const basicInfoItems: DetailListItem[] = [\n { label: t`ID`, value: floatingIp.id },\n { label: t`Description`, value: floatingIp.description || `—` },\n { label: t`Project ID`, value: floatingIp.project_id || `—` },\n { label: t`Status`, value: formatFloatingIpStatus(floatingIp.status) },\n { label: t`Created At`, value: floatingIp.created_at ? new Date(floatingIp.created_at).toLocaleString() : `—` },\n { label: t`Updated At`, value: floatingIp.updated_at ? new Date(floatingIp.updated_at).toLocaleString() : `—` },\n { label: t`Tags`, value: floatingIp.tags?.join(\", \") || `—` },\n ]\n\n const networkRoutingItems: DetailListItem[] = [\n { label: t`Floating IP Address`, value: floatingIp.floating_ip_address || `—` },\n { label: t`Floating Network`, value: floatingIp.floating_network_id || `—` },\n { label: t`Fixed IP Address`, value: floatingIp.fixed_ip_address || `—` },\n { label: t`Port Name`, value: floatingIp.port_details?.name || `—` },\n { label: t`MAC Address`, value: floatingIp.port_details?.mac_address || `—` },\n { label: t`Network ID`, value: floatingIp.port_details?.network_id || `—` },\n { label: t`Device Owner`, value: floatingIp.port_details?.device_owner || `—` },\n { label: t`Device ID`, value: floatingIp.port_details?.device_id || `—` },\n { label: t`Router ID`, value: floatingIp.router_id || `—` },\n { label: t`Port ID`, value: floatingIp.port_id || `—` },\n { label: t`QoS Policy ID`, value: floatingIp.qos_policy_id || `—` },\n { label: t`Port Forwarding`, value: floatingIp.port_forwardings?.map((port) => port.id).join(\", \") || `—` },\n ]\n\n const dnsItems: DetailListItem[] = [\n { label: t`DNS Domain`, value: floatingIp.dns_domain || `—` },\n { label: t`DNS Name`, value: floatingIp.dns_name || `—` },\n ]\n\n return (\n <>\n <p className=\"text-theme-secondary mt-2 text-sm\">\n <Trans>\n Full lifecycle management of Floating IPs, including attachment, port association/disassociation, DNS\n settings, and deletion\n </Trans>\n </p>\n\n <FloatingIpActionModals floatingIp={floatingIp}>\n {({ toggleEditModal, toggleAttachModal, toggleDetachModal, toggleReleaseModal }) => (\n <ButtonRow>\n <Button onClick={toggleEditModal}>{t`Edit Description`}</Button>\n <Button onClick={toggleAttachModal}>{t`Attach`}</Button>\n <Button onClick={toggleDetachModal}>{t`Detach`}</Button>\n <Button onClick={toggleReleaseModal}>{t`Release`}</Button>\n </ButtonRow>\n )}\n </FloatingIpActionModals>\n\n <Stack direction=\"vertical\" gap=\"6\" className=\"my-6\">\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Basic Info</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={basicInfoItems} />\n </Stack>\n\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Network & Routing</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={networkRoutingItems} />\n </Stack>\n\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>DNS</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={dnsItems} />\n </Stack>\n </Stack>\n </>\n )\n}\n","import { createFileRoute, redirect, useNavigate } from \"@tanstack/react-router\"\nimport { Button, ContentHeading, Stack, Spinner } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { getServiceIndex } from \"@/server/Authentication/helpers\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { FloatingIpDetailsView } from \"./-components/-details/FloatingIpDetailsView\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/network/floatingips/$floatingIpId/\")({\n staticData: {\n section: \"network\",\n service: \"floatingips\",\n isDetail: true,\n sectionCrumb: { labelKey: \"Network\" },\n crumb: { labelKey: \"Floating IPs\", to: \"/projects/$projectId/network/floatingips\" },\n } satisfies RouteInfo,\n loader: async ({ context, params }) => {\n const floatingIp = await context.trpcClient?.network.floatingIp.getById.query({\n project_id: params.projectId,\n floatingip_id: params.floatingIpId,\n })\n return { floatingIpAddress: floatingIp?.floating_ip_address ?? null }\n },\n head: ({ loaderData }) => ({\n meta: [{ title: loaderData?.floatingIpAddress ?? \"Floating IP\" }],\n }),\n component: RouteComponent,\n beforeLoad: async ({ context, params }) => {\n const { trpcClient } = context\n\n const availableServices = (await trpcClient?.auth.getAvailableServices.query()) || []\n const serviceIndex = getServiceIndex(availableServices)\n\n // Redirect if network service not available\n if (!serviceIndex[\"network\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n\n if (!serviceIndex[\"network\"][\"neutron\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { floatingIpId } = Route.useParams()\n const projectId = useProjectId()\n const navigate = useNavigate()\n\n // Fetch floating IP details\n const {\n data: floatingIp,\n isLoading,\n isError,\n error,\n } = trpcReact.network.floatingIp.getById.useQuery({\n project_id: projectId,\n floatingip_id: floatingIpId,\n })\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId },\n })\n }\n\n // Loading state\n if (isLoading) {\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 Floating IP Details...</Trans>\n </Stack>\n )\n }\n\n // Error state\n if (isError) {\n const errorMessage = error?.message || \"Unknown error\"\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 floating IP</Trans>\n </p>\n <p className=\"text-theme-highest\">{errorMessage}</p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // No data state\n if (!floatingIp) {\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\" gap=\"5\">\n <p className=\"text-theme-secondary\">\n <Trans>Floating IP not found</Trans>\n </p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // Success state\n return (\n <>\n <ContentHeading>{floatingIp.floating_ip_address}</ContentHeading>\n <FloatingIpDetailsView floatingIp={floatingIp} />\n </>\n )\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"_floatingIpId-BACLbMzi2.mjs","names":["formatFloatingIpStatus","status","charAt","slice","toLowerCase","Fragment","DescriptionDefinition","DescriptionList","DescriptionTerm","Stack","TwoColumnDescriptionList","items","mid","Math","ceil","length","firstColumn","slice","secondColumn","gap","className","alignTerms","map","label","value","Stack","ButtonRow","Button","ContentHeading","formatFloatingIpStatus","TwoColumnDescriptionList","FloatingIpActionModals","FloatingIpDetailsView","floatingIp","useLingui","basicInfoItems","label","t","value","id","description","project_id","status","created_at","Date","toLocaleString","updated_at","tags","join","networkRoutingItems","floating_ip_address","floating_network_id","fixed_ip_address","port_details","name","mac_address","network_id","device_owner","device_id","router_id","port_id","qos_policy_id","port_forwardings","map","port","dnsItems","dns_domain","dns_name","p","className","toggleEditModal","toggleAttachModal","toggleDetachModal","toggleReleaseModal","onClick","direction","gap","items","useNavigate","Button","ContentHeading","Stack","Spinner","Trans","useProjectId","trpcReact","FloatingIpDetailsView","Route","RouteComponent","floatingIpId","useParams","projectId","navigate","data","floatingIp","isLoading","isError","error","network","getById","useQuery","project_id","floatingip_id","handleBack","to","params","errorMessage","message","floating_ip_address","component"],"sources":["../../src/client/utils/formatFloatingIpStatus.ts","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/-components/TwoColumnDescriptionList.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/-components/-details/FloatingIpDetailsView.tsx","../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/index.tsx?tsr-split=component"],"sourcesContent":["import type { FloatingIpStatus } from \"@/server/Network/types/floatingIp\"\n\n/**\n * Formats a floating IP status value from uppercase enum to title case.\n * Example: \"ACTIVE\" → \"Active\", \"DOWN\" → \"Down\", \"ERROR\" → \"Error\"\n */\nexport const formatFloatingIpStatus = (status: FloatingIpStatus) => {\n return status.charAt(0) + status.slice(1).toLowerCase()\n}\n","import { Fragment } from \"react\"\nimport { DescriptionDefinition, DescriptionList, DescriptionTerm, Stack } from \"@cloudoperators/juno-ui-components\"\n\nexport type DetailListItem = {\n label: string\n value: string\n}\n\ninterface TwoColumnDescriptionListProps {\n items: DetailListItem[]\n}\n\nexport const TwoColumnDescriptionList = ({ items }: TwoColumnDescriptionListProps) => {\n const mid = Math.ceil(items.length / 2)\n const firstColumn = items.slice(0, mid)\n const secondColumn = items.slice(mid)\n\n return (\n <Stack gap=\"6\" className=\"grid grid-cols-2\">\n <DescriptionList alignTerms=\"right\">\n {firstColumn.map(({ label, value }) => (\n <Fragment key={label}>\n <DescriptionTerm>{label}</DescriptionTerm>\n <DescriptionDefinition>{value}</DescriptionDefinition>\n </Fragment>\n ))}\n </DescriptionList>\n\n <DescriptionList alignTerms=\"right\">\n {secondColumn.map(({ label, value }) => (\n <Fragment key={label}>\n <DescriptionTerm>{label}</DescriptionTerm>\n <DescriptionDefinition>{value}</DescriptionDefinition>\n </Fragment>\n ))}\n </DescriptionList>\n </Stack>\n )\n}\n","import { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Stack, ButtonRow, Button, ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport type { FloatingIp } from \"@/server/Network/types/floatingIp\"\nimport { formatFloatingIpStatus } from \"@/client/utils/formatFloatingIpStatus\"\nimport { DetailListItem, TwoColumnDescriptionList } from \"../TwoColumnDescriptionList\"\nimport { FloatingIpActionModals } from \"../../../-components/-modals/FloatingIpActionModals\"\n\ninterface FloatingIpDetailsViewProps {\n floatingIp: FloatingIp\n}\n\nexport const FloatingIpDetailsView = ({ floatingIp }: FloatingIpDetailsViewProps) => {\n const { t } = useLingui()\n\n const basicInfoItems: DetailListItem[] = [\n { label: t`ID`, value: floatingIp.id },\n { label: t`Description`, value: floatingIp.description || `—` },\n { label: t`Project ID`, value: floatingIp.project_id || `—` },\n { label: t`Status`, value: formatFloatingIpStatus(floatingIp.status) },\n { label: t`Created At`, value: floatingIp.created_at ? new Date(floatingIp.created_at).toLocaleString() : `—` },\n { label: t`Updated At`, value: floatingIp.updated_at ? new Date(floatingIp.updated_at).toLocaleString() : `—` },\n { label: t`Tags`, value: floatingIp.tags?.join(\", \") || `—` },\n ]\n\n const networkRoutingItems: DetailListItem[] = [\n { label: t`Floating IP Address`, value: floatingIp.floating_ip_address || `—` },\n { label: t`Floating Network`, value: floatingIp.floating_network_id || `—` },\n { label: t`Fixed IP Address`, value: floatingIp.fixed_ip_address || `—` },\n { label: t`Port Name`, value: floatingIp.port_details?.name || `—` },\n { label: t`MAC Address`, value: floatingIp.port_details?.mac_address || `—` },\n { label: t`Network ID`, value: floatingIp.port_details?.network_id || `—` },\n { label: t`Device Owner`, value: floatingIp.port_details?.device_owner || `—` },\n { label: t`Device ID`, value: floatingIp.port_details?.device_id || `—` },\n { label: t`Router ID`, value: floatingIp.router_id || `—` },\n { label: t`Port ID`, value: floatingIp.port_id || `—` },\n { label: t`QoS Policy ID`, value: floatingIp.qos_policy_id || `—` },\n { label: t`Port Forwarding`, value: floatingIp.port_forwardings?.map((port) => port.id).join(\", \") || `—` },\n ]\n\n const dnsItems: DetailListItem[] = [\n { label: t`DNS Domain`, value: floatingIp.dns_domain || `—` },\n { label: t`DNS Name`, value: floatingIp.dns_name || `—` },\n ]\n\n return (\n <>\n <p className=\"text-theme-secondary mt-2 text-sm\">\n <Trans>\n Full lifecycle management of Floating IPs, including attachment, port association/disassociation, DNS\n settings, and deletion\n </Trans>\n </p>\n\n <FloatingIpActionModals floatingIp={floatingIp}>\n {({ toggleEditModal, toggleAttachModal, toggleDetachModal, toggleReleaseModal }) => (\n <ButtonRow>\n <Button onClick={toggleEditModal}>{t`Edit Description`}</Button>\n <Button onClick={toggleAttachModal}>{t`Attach`}</Button>\n <Button onClick={toggleDetachModal}>{t`Detach`}</Button>\n <Button onClick={toggleReleaseModal}>{t`Release`}</Button>\n </ButtonRow>\n )}\n </FloatingIpActionModals>\n\n <Stack direction=\"vertical\" gap=\"6\" className=\"my-6\">\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Basic Info</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={basicInfoItems} />\n </Stack>\n\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Network & Routing</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={networkRoutingItems} />\n </Stack>\n\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>DNS</Trans>\n </ContentHeading>\n <TwoColumnDescriptionList items={dnsItems} />\n </Stack>\n </Stack>\n </>\n )\n}\n","import { createFileRoute, redirect, useNavigate } from \"@tanstack/react-router\"\nimport { Button, ContentHeading, Stack, Spinner } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { getServiceIndex } from \"@/server/Authentication/helpers\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { FloatingIpDetailsView } from \"./-components/-details/FloatingIpDetailsView\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/network/floatingips/$floatingIpId/\")({\n staticData: {\n section: \"network\",\n service: \"floatingips\",\n isDetail: true,\n sectionCrumb: { labelKey: \"Network\" },\n crumb: { labelKey: \"Floating IPs\", to: \"/projects/$projectId/network/floatingips\" },\n } satisfies RouteInfo,\n loader: async ({ context, params }) => {\n const floatingIp = await context.trpcClient?.network.floatingIp.getById.query({\n project_id: params.projectId,\n floatingip_id: params.floatingIpId,\n })\n return { floatingIpAddress: floatingIp?.floating_ip_address ?? null }\n },\n head: ({ loaderData }) => ({\n meta: [{ title: loaderData?.floatingIpAddress ?? \"Floating IP\" }],\n }),\n component: RouteComponent,\n beforeLoad: async ({ context, params }) => {\n const { trpcClient } = context\n\n const availableServices = (await trpcClient?.auth.getAvailableServices.query()) || []\n const serviceIndex = getServiceIndex(availableServices)\n\n // Redirect if network service not available\n if (!serviceIndex[\"network\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n\n if (!serviceIndex[\"network\"][\"neutron\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { floatingIpId } = Route.useParams()\n const projectId = useProjectId()\n const navigate = useNavigate()\n\n // Fetch floating IP details\n const {\n data: floatingIp,\n isLoading,\n isError,\n error,\n } = trpcReact.network.floatingIp.getById.useQuery({\n project_id: projectId,\n floatingip_id: floatingIpId,\n })\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId },\n })\n }\n\n // Loading state\n if (isLoading) {\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 Floating IP Details...</Trans>\n </Stack>\n )\n }\n\n // Error state\n if (isError) {\n const errorMessage = error?.message || \"Unknown error\"\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 floating IP</Trans>\n </p>\n <p className=\"text-theme-highest\">{errorMessage}</p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // No data state\n if (!floatingIp) {\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\" gap=\"5\">\n <p className=\"text-theme-secondary\">\n <Trans>Floating IP not found</Trans>\n </p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // Success state\n return (\n <>\n <ContentHeading>{floatingIp.floating_ip_address}</ContentHeading>\n <FloatingIpDetailsView floatingIp={floatingIp} />\n </>\n )\n}\n"],"mappings":"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"}
|
|
@@ -16,7 +16,7 @@ var i = t("/_auth/projects/$projectId/network/floatingips/$floatingIpId/")({
|
|
|
16
16
|
floatingip_id: t.floatingIpId
|
|
17
17
|
}))?.floating_ip_address ?? null }),
|
|
18
18
|
head: ({ loaderData: e }) => ({ meta: [{ title: e?.floatingIpAddress ?? "Floating IP" }] }),
|
|
19
|
-
component: n(() => import("./_floatingIpId-
|
|
19
|
+
component: n(() => import("./_floatingIpId-BACLbMzi2.mjs"), "component"),
|
|
20
20
|
beforeLoad: async ({ context: t, params: n }) => {
|
|
21
21
|
let { trpcClient: i } = t, a = e(await i?.auth.getAvailableServices.query() || []);
|
|
22
22
|
if (!a.network || !a.network.neutron) throw r({
|
|
@@ -28,4 +28,4 @@ var i = t("/_auth/projects/$projectId/network/floatingips/$floatingIpId/")({
|
|
|
28
28
|
//#endregion
|
|
29
29
|
export { i as t };
|
|
30
30
|
|
|
31
|
-
//# sourceMappingURL=_floatingIpId-
|
|
31
|
+
//# sourceMappingURL=_floatingIpId-BzVMOv97.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_floatingIpId-
|
|
1
|
+
{"version":3,"file":"_floatingIpId-BzVMOv97.mjs","names":["createFileRoute","redirect","getServiceIndex","Route","staticData","section","service","isDetail","sectionCrumb","labelKey","crumb","to","RouteInfo","loader","context","params","floatingIp","trpcClient","network","getById","query","project_id","projectId","floatingip_id","floatingIpId","floatingIpAddress","floating_ip_address","head","loaderData","meta","title","component","lazyRouteComponent","$$splitComponentImporter","beforeLoad","availableServices","auth","getAvailableServices","serviceIndex"],"sources":["../../src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/index.tsx"],"sourcesContent":["import { createFileRoute, redirect, useNavigate } from \"@tanstack/react-router\"\nimport { Button, ContentHeading, Stack, Spinner } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { getServiceIndex } from \"@/server/Authentication/helpers\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { FloatingIpDetailsView } from \"./-components/-details/FloatingIpDetailsView\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/network/floatingips/$floatingIpId/\")({\n staticData: {\n section: \"network\",\n service: \"floatingips\",\n isDetail: true,\n sectionCrumb: { labelKey: \"Network\" },\n crumb: { labelKey: \"Floating IPs\", to: \"/projects/$projectId/network/floatingips\" },\n } satisfies RouteInfo,\n loader: async ({ context, params }) => {\n const floatingIp = await context.trpcClient?.network.floatingIp.getById.query({\n project_id: params.projectId,\n floatingip_id: params.floatingIpId,\n })\n return { floatingIpAddress: floatingIp?.floating_ip_address ?? null }\n },\n head: ({ loaderData }) => ({\n meta: [{ title: loaderData?.floatingIpAddress ?? \"Floating IP\" }],\n }),\n component: RouteComponent,\n beforeLoad: async ({ context, params }) => {\n const { trpcClient } = context\n\n const availableServices = (await trpcClient?.auth.getAvailableServices.query()) || []\n const serviceIndex = getServiceIndex(availableServices)\n\n // Redirect if network service not available\n if (!serviceIndex[\"network\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n\n if (!serviceIndex[\"network\"][\"neutron\"]) {\n throw redirect({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId: params.projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { floatingIpId } = Route.useParams()\n const projectId = useProjectId()\n const navigate = useNavigate()\n\n // Fetch floating IP details\n const {\n data: floatingIp,\n isLoading,\n isError,\n error,\n } = trpcReact.network.floatingIp.getById.useQuery({\n project_id: projectId,\n floatingip_id: floatingIpId,\n })\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/network/floatingips\",\n params: { projectId },\n })\n }\n\n // Loading state\n if (isLoading) {\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 Floating IP Details...</Trans>\n </Stack>\n )\n }\n\n // Error state\n if (isError) {\n const errorMessage = error?.message || \"Unknown error\"\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 floating IP</Trans>\n </p>\n <p className=\"text-theme-highest\">{errorMessage}</p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // No data state\n if (!floatingIp) {\n return (\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\" gap=\"5\">\n <p className=\"text-theme-secondary\">\n <Trans>Floating IP not found</Trans>\n </p>\n <Button onClick={handleBack} variant=\"primary\">\n <Trans>Back to Floating IPs</Trans>\n </Button>\n </Stack>\n )\n }\n\n // Success state\n return (\n <>\n <ContentHeading>{floatingIp.floating_ip_address}</ContentHeading>\n <FloatingIpDetailsView floatingIp={floatingIp} />\n </>\n )\n}\n"],"mappings":";;AASA,IAAaG,IAAQH,EAAgB,+DAAA,EAAiE;CACpGI,YAAY;EACVC,SAAS;EACTC,SAAS;EACTC,UAAU;EACVC,cAAc,EAAEC,UAAU,UAAU;EACpCC,OAAO;GAAED,UAAU;GAAgBE,IAAI;EAA2C;CACpF;CACAE,QAAQ,OAAO,EAAEC,YAASC,iBAKjB,EAAEU,oBAAmBT,MAJHF,EAAQG,YAAYC,QAAQF,WAAWG,QAAQC,MAAM;EAC5EC,YAAYN,EAAOO;EACnBC,eAAeR,EAAOS;CACxB,CAAA,IACwCE,uBAAuB,KAAK;CAEtEC,OAAO,EAAEC,qBAAkB,EACzBC,MAAM,CAAC,EAAEC,OAAOF,GAAYH,qBAAqB,cAAc,CAAA,EACjE;CACAM,WAASC,iDAAA,WAAA;CACTE,YAAY,OAAO,EAAEpB,YAASC,gBAAQ;EACpC,IAAM,EAAEE,kBAAeH,GAGjBwB,IAAepC,EADK,MAAOe,GAAYmB,KAAKC,qBAAqBjB,MAAAA,KAAY,CAAA,CAC9Ce;EAUrC,IAPI,CAACG,EAAa,WAOd,CAACA,EAAa,QAAW,SAC3B,MAAMrC,EAAS;GACbU,IAAI;GACJI,QAAQ,EAAEO,WAAWP,EAAOO,UAAU;EACxC,CAAA;CAEJ;AACF,CAAA"}
|
|
@@ -0,0 +1,534 @@
|
|
|
1
|
+
import { D as e, F as t, O as n, U as r, X as i, Y as a, _ as o, ct as s, dt as c, et as l, g as u, it as d, k as f, q as p, rt as m, tt as ee } from "./build-DF7MTyXG.mjs";
|
|
2
|
+
import { r as h } from "./trpcClient-BzPUgiM2.mjs";
|
|
3
|
+
import { n as g, t as te } from "./ContentHeader-DsuZD8fa.mjs";
|
|
4
|
+
import { A as _, 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-CFKQZTgf.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, _: s } = D(), l = t.status === v.PENDING, d = 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(u, { children: [
|
|
13
|
+
l && /*#__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 && (l || d) && /*#__PURE__*/ C(c, { children: [/*#__PURE__*/ S(o, {
|
|
52
|
+
onClick: () => r(v.ACCEPTED),
|
|
53
|
+
disabled: i,
|
|
54
|
+
children: /*#__PURE__*/ S(E, { id: "g3UF2V" })
|
|
55
|
+
}), l && /*#__PURE__*/ S(o, {
|
|
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: r, _: i } = D();
|
|
63
|
+
return /*#__PURE__*/ C(n, {
|
|
64
|
+
px: !1,
|
|
65
|
+
py: !0,
|
|
66
|
+
children: [/*#__PURE__*/ S(l, { children: r._({ id: "nW/hX9" }) }), /*#__PURE__*/ C(m, {
|
|
67
|
+
alignTerms: "right",
|
|
68
|
+
children: [
|
|
69
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "S0kLOH" }) }),
|
|
70
|
+
/*#__PURE__*/ S(t, { children: /*#__PURE__*/ S(g, { text: e.id }) }),
|
|
71
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "6YtxFj" }) }),
|
|
72
|
+
/*#__PURE__*/ S(t, { children: e.name }),
|
|
73
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "uAQUqI" }) }),
|
|
74
|
+
/*#__PURE__*/ S(t, { children: e.status }),
|
|
75
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "Cj2Gtd" }) }),
|
|
76
|
+
/*#__PURE__*/ S(t, { children: /*#__PURE__*/ S(y, { size: e.size }) }),
|
|
77
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "Cxgv2U" }) }),
|
|
78
|
+
/*#__PURE__*/ C(t, { children: [e.min_disk, " GB"] }),
|
|
79
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "B2Czeb" }) }),
|
|
80
|
+
/*#__PURE__*/ C(t, { children: [e.min_ram, " MB"] }),
|
|
81
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "NopYGU" }) }),
|
|
82
|
+
/*#__PURE__*/ S(t, { children: /*#__PURE__*/ S("span", {
|
|
83
|
+
className: "uppercase",
|
|
84
|
+
children: e.disk_format
|
|
85
|
+
}) }),
|
|
86
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "6/xipy" }) }),
|
|
87
|
+
/*#__PURE__*/ S(t, { children: /*#__PURE__*/ S("span", {
|
|
88
|
+
className: "uppercase",
|
|
89
|
+
children: e.container_format
|
|
90
|
+
}) }),
|
|
91
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "88kg0+" }) }),
|
|
92
|
+
/*#__PURE__*/ S(t, { children: e.created_at ? new Date(e.created_at).toLocaleDateString() : r._({ id: "fj5byd" }) }),
|
|
93
|
+
/*#__PURE__*/ S(p, { children: r._({ id: "Llcakz" }) }),
|
|
94
|
+
/*#__PURE__*/ S(t, { children: e.updated_at ? new Date(e.updated_at).toLocaleDateString() : r._({ id: "fj5byd" }) })
|
|
95
|
+
]
|
|
96
|
+
})]
|
|
97
|
+
});
|
|
98
|
+
}, A = ({ image: e, currentProjectId: r }) => {
|
|
99
|
+
let { i18n: i, _: a } = D(), o = e.visibility === "shared" && e.owner !== void 0 && e.owner !== r;
|
|
100
|
+
return /*#__PURE__*/ C(n, {
|
|
101
|
+
px: !1,
|
|
102
|
+
py: !0,
|
|
103
|
+
children: [/*#__PURE__*/ S(l, { children: i._({ id: "a3LDKx" }) }), /*#__PURE__*/ C(m, {
|
|
104
|
+
alignTerms: "right",
|
|
105
|
+
children: [
|
|
106
|
+
/*#__PURE__*/ S(p, { children: o ? i._({ id: "20axE5" }) : i._({ id: "YsrbQh" }) }),
|
|
107
|
+
/*#__PURE__*/ S(t, { children: e.owner ? /*#__PURE__*/ S(g, { text: e.owner }) : "" }),
|
|
108
|
+
/*#__PURE__*/ S(p, { children: i._({ id: "2q/Q7x" }) }),
|
|
109
|
+
/*#__PURE__*/ S(t, { children: e.visibility }),
|
|
110
|
+
/*#__PURE__*/ S(p, { children: i._({ id: "644xgx" }) }),
|
|
111
|
+
/*#__PURE__*/ S(t, { children: e.protected ? i._({ id: "l75CjT" }) : i._({ id: "1UzENP" }) }),
|
|
112
|
+
/*#__PURE__*/ S(p, { children: i._({ id: "PzgYM9" }) }),
|
|
113
|
+
/*#__PURE__*/ S(t, { children: e?.checksum ? e.checksum : "" })
|
|
114
|
+
]
|
|
115
|
+
})]
|
|
116
|
+
});
|
|
117
|
+
}, j = ({ image: e }) => {
|
|
118
|
+
let { i18n: r, _: 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
|
+
]), o = Object.entries(e).filter(([e]) => !a.has(e)).sort(([e], [t]) => e.localeCompare(t)), s = o.length > 0;
|
|
134
|
+
return /*#__PURE__*/ C(n, {
|
|
135
|
+
px: !1,
|
|
136
|
+
py: !0,
|
|
137
|
+
children: [/*#__PURE__*/ S(l, { children: r._({ id: "bc67JN" }) }), s ? /*#__PURE__*/ S(m, {
|
|
138
|
+
alignTerms: "right",
|
|
139
|
+
className: "grid-cols-4",
|
|
140
|
+
children: o.map(([e, n]) => /*#__PURE__*/ C(w.Fragment, { children: [/*#__PURE__*/ S(p, {
|
|
141
|
+
className: "col-span-1",
|
|
142
|
+
children: e
|
|
143
|
+
}), /*#__PURE__*/ S(t, {
|
|
144
|
+
className: "col-span-1",
|
|
145
|
+
children: n == null ? /*#__PURE__*/ S("span", { children: "null" }) : typeof n == "object" ? /*#__PURE__*/ S("span", {
|
|
146
|
+
className: "break-all",
|
|
147
|
+
children: JSON.stringify(n)
|
|
148
|
+
}) : typeof n == "boolean" ? n ? r._({ id: "c+xCSz" }) : r._({ id: "ocUvR+" }) : /*#__PURE__*/ S("span", {
|
|
149
|
+
className: "break-all",
|
|
150
|
+
children: String(n)
|
|
151
|
+
})
|
|
152
|
+
})] }, e))
|
|
153
|
+
}) : /*#__PURE__*/ S("p", {
|
|
154
|
+
className: "text-theme-light",
|
|
155
|
+
children: r._({ 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: r }) => {
|
|
162
|
+
let [i, o] = T(!1), [s, c] = T(null), { data: l, isLoading: u } = h.compute.listImageMembers.useQuery({
|
|
163
|
+
project_id: r,
|
|
164
|
+
imageId: e.id
|
|
165
|
+
}, { enabled: !!e.id && !!r });
|
|
166
|
+
return /*#__PURE__*/ C(n, {
|
|
167
|
+
px: !1,
|
|
168
|
+
py: !0,
|
|
169
|
+
children: [s && /*#__PURE__*/ S(a, {
|
|
170
|
+
text: s.text,
|
|
171
|
+
variant: s.type,
|
|
172
|
+
onDismiss: () => c(null),
|
|
173
|
+
className: "mb-4"
|
|
174
|
+
}), /*#__PURE__*/ S(_, {
|
|
175
|
+
image: e,
|
|
176
|
+
imageMembers: l,
|
|
177
|
+
isMembersLoading: u,
|
|
178
|
+
canAdd: t?.canCreateMember ?? !1,
|
|
179
|
+
canRemove: t?.canDeleteMember ?? !1,
|
|
180
|
+
isAddingMember: i,
|
|
181
|
+
setIsAddingMember: o,
|
|
182
|
+
setMessage: c,
|
|
183
|
+
projectId: r
|
|
184
|
+
})]
|
|
185
|
+
});
|
|
186
|
+
}, pe = ({ image: e, currentProjectId: t, activeTab: n = "details", onTabChange: r, permissions: a, myMemberData: o, onMemberStatusChange: s, isMemberStatusChanging: c, actions: l }) => {
|
|
187
|
+
let { i18n: u, _: d } = D(), f = e.visibility === "shared" && e.owner !== void 0 && e.owner !== t, p = e.owner === t && e.visibility === "shared";
|
|
188
|
+
return /*#__PURE__*/ C(i, {
|
|
189
|
+
direction: "vertical",
|
|
190
|
+
gap: "6",
|
|
191
|
+
children: [
|
|
192
|
+
f && o && s && /*#__PURE__*/ S(O, {
|
|
193
|
+
image: e,
|
|
194
|
+
myMemberData: o,
|
|
195
|
+
canUpdateMember: a?.canUpdateMember ?? !1,
|
|
196
|
+
onStatusChange: s,
|
|
197
|
+
isLoading: c ?? !1
|
|
198
|
+
}),
|
|
199
|
+
p && /*#__PURE__*/ S("div", {
|
|
200
|
+
className: "border-theme-background-lvl-3 border-b",
|
|
201
|
+
children: /*#__PURE__*/ C(i, {
|
|
202
|
+
direction: "horizontal",
|
|
203
|
+
gap: "0",
|
|
204
|
+
children: [/*#__PURE__*/ S("button", {
|
|
205
|
+
className: M(n === "details"),
|
|
206
|
+
onClick: () => r?.("details"),
|
|
207
|
+
children: u._({ id: "URmyfc" })
|
|
208
|
+
}), /*#__PURE__*/ S("button", {
|
|
209
|
+
className: M(n === "sharing"),
|
|
210
|
+
onClick: () => r?.("sharing"),
|
|
211
|
+
children: u._({ id: "aG9OiI" })
|
|
212
|
+
})]
|
|
213
|
+
})
|
|
214
|
+
}),
|
|
215
|
+
(n === "details" || !p) && /*#__PURE__*/ C(x, { children: [
|
|
216
|
+
l,
|
|
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" && p && /*#__PURE__*/ S(N, {
|
|
225
|
+
image: e,
|
|
226
|
+
permissions: a
|
|
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: t, imageId: n } = de({ from: "/_auth/projects/$projectId/compute/images/$imageId" }), { tab: a } = fe({ from: "/_auth/projects/$projectId/compute/images/$imageId" }), l = ue(), { i18n: u, _: p } = D(), { data: m, status: g, error: _ } = h.compute.getImageById.useQuery({
|
|
235
|
+
project_id: t,
|
|
236
|
+
imageId: n
|
|
237
|
+
}), { data: v } = h.compute.canUser.useQuery({
|
|
238
|
+
project_id: t,
|
|
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 = h.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 = h.compute.updateImage.useMutation({ onSuccess: (e) => {
|
|
253
|
+
w.compute.getImageById.setData({
|
|
254
|
+
project_id: t,
|
|
255
|
+
imageId: n
|
|
256
|
+
}, e), w.compute.listImagesWithPagination.invalidate();
|
|
257
|
+
} }), V = h.compute.deleteImage.useMutation({ onSuccess: () => {
|
|
258
|
+
w.compute.listImagesWithPagination.invalidate();
|
|
259
|
+
} }), H = h.compute.deactivateImage.useMutation({ onSuccess: () => {
|
|
260
|
+
w.compute.getImageById.invalidate({
|
|
261
|
+
project_id: t,
|
|
262
|
+
imageId: n
|
|
263
|
+
});
|
|
264
|
+
} }), U = h.compute.reactivateImage.useMutation({ onSuccess: () => {
|
|
265
|
+
w.compute.getImageById.invalidate({
|
|
266
|
+
project_id: t,
|
|
267
|
+
imageId: n
|
|
268
|
+
});
|
|
269
|
+
} }), W = h.compute.updateImageVisibility.useMutation({ onSuccess: (e) => {
|
|
270
|
+
w.compute.getImageById.setData({
|
|
271
|
+
project_id: t,
|
|
272
|
+
imageId: n
|
|
273
|
+
}, e);
|
|
274
|
+
} }), G = m?.visibility === b.SHARED && m?.owner !== void 0 && m?.owner !== t, { data: K } = h.compute.getImageMember.useQuery({
|
|
275
|
+
project_id: t,
|
|
276
|
+
imageId: n,
|
|
277
|
+
memberId: t
|
|
278
|
+
}, { enabled: G && !!n && !!t }), q = h.compute.updateImageMember.useMutation({ onSuccess: () => {
|
|
279
|
+
w.compute.getImageMember.invalidate({
|
|
280
|
+
project_id: t,
|
|
281
|
+
imageId: n,
|
|
282
|
+
memberId: t
|
|
283
|
+
}), w.compute.listImageMembers.invalidate({
|
|
284
|
+
project_id: t,
|
|
285
|
+
imageId: n
|
|
286
|
+
}), w.compute.listImagesWithPagination.invalidate(), w.compute.listSharedImagesByMemberStatus.invalidate();
|
|
287
|
+
} }), J = async (e) => {
|
|
288
|
+
try {
|
|
289
|
+
await q.mutateAsync({
|
|
290
|
+
project_id: t,
|
|
291
|
+
imageId: n,
|
|
292
|
+
memberId: t,
|
|
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
|
+
l({
|
|
301
|
+
to: "/projects/$projectId/compute/images",
|
|
302
|
+
params: { projectId: t }
|
|
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 (!m) return !1;
|
|
323
|
+
let r = me(e, m);
|
|
324
|
+
try {
|
|
325
|
+
return await B.mutateAsync({
|
|
326
|
+
project_id: t,
|
|
327
|
+
imageId: n,
|
|
328
|
+
operations: r
|
|
329
|
+
}), k(!1), !0;
|
|
330
|
+
} catch {
|
|
331
|
+
return !1;
|
|
332
|
+
}
|
|
333
|
+
}, he = async (e) => {
|
|
334
|
+
try {
|
|
335
|
+
await V.mutateAsync({
|
|
336
|
+
project_id: t,
|
|
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: t,
|
|
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: t,
|
|
355
|
+
imageId: e.id
|
|
356
|
+
}), L(!1);
|
|
357
|
+
} catch {
|
|
358
|
+
L(!1);
|
|
359
|
+
}
|
|
360
|
+
}, ve = async (e) => {
|
|
361
|
+
if (m) try {
|
|
362
|
+
await W.mutateAsync({
|
|
363
|
+
project_id: t,
|
|
364
|
+
imageId: m.id,
|
|
365
|
+
visibility: e
|
|
366
|
+
});
|
|
367
|
+
} catch {}
|
|
368
|
+
};
|
|
369
|
+
if (g === "pending") return /*#__PURE__*/ C(i, {
|
|
370
|
+
className: "fixed inset-0",
|
|
371
|
+
distribution: "center",
|
|
372
|
+
alignment: "center",
|
|
373
|
+
direction: "vertical",
|
|
374
|
+
children: [/*#__PURE__*/ S(r, {
|
|
375
|
+
variant: "primary",
|
|
376
|
+
size: "large",
|
|
377
|
+
className: "mb-2"
|
|
378
|
+
}), /*#__PURE__*/ S(E, { id: "hH3kDo" })]
|
|
379
|
+
});
|
|
380
|
+
if (g === "error") {
|
|
381
|
+
let e = _?.message || "Unknown error";
|
|
382
|
+
return /*#__PURE__*/ C(i, {
|
|
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(o, {
|
|
398
|
+
onClick: Y,
|
|
399
|
+
variant: "primary",
|
|
400
|
+
children: /*#__PURE__*/ S(E, { id: "bnql/K" })
|
|
401
|
+
})
|
|
402
|
+
]
|
|
403
|
+
});
|
|
404
|
+
}
|
|
405
|
+
if (!m) return /*#__PURE__*/ C(i, {
|
|
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(o, {
|
|
415
|
+
onClick: Y,
|
|
416
|
+
variant: "primary",
|
|
417
|
+
children: /*#__PURE__*/ S(E, { id: "bnql/K" })
|
|
418
|
+
})]
|
|
419
|
+
});
|
|
420
|
+
let Q = m.status === ie.DEACTIVATED, ye = m.visibility === b.PRIVATE, be = K?.status === "accepted", $ = m.owner === t, xe = G && be && y.canUpdateMember, Se = !G && y.canUpdate, Ce = !G && y.canDelete && !m.protected, we = !G && $ && m.visibility === b.SHARED && (y.canCreateMember || y.canDeleteMember), Te = xe || Se || Ce || we, Ee = Te || !G && y.canUpdate ? /*#__PURE__*/ C(c, { children: [
|
|
421
|
+
Te && /*#__PURE__*/ C(e, { children: [/*#__PURE__*/ S(d, {
|
|
422
|
+
as: "div",
|
|
423
|
+
children: /*#__PURE__*/ S(o, {
|
|
424
|
+
icon: "moreVert",
|
|
425
|
+
disabled: X,
|
|
426
|
+
children: /*#__PURE__*/ S(E, { id: "PgNNGl" })
|
|
427
|
+
})
|
|
428
|
+
}), /*#__PURE__*/ C(s, { children: [
|
|
429
|
+
xe && /*#__PURE__*/ S(f, {
|
|
430
|
+
label: u._({ id: "1t/NnN" }),
|
|
431
|
+
onClick: () => J("rejected")
|
|
432
|
+
}),
|
|
433
|
+
!G && y.canUpdate && /*#__PURE__*/ S(f, {
|
|
434
|
+
label: Q ? u._({ id: "FQBaXG" }) : u._({ id: "5y3O+A" }),
|
|
435
|
+
onClick: () => Q ? F(!0) : L(!0)
|
|
436
|
+
}),
|
|
437
|
+
!G && y.canUpdate && ye && /*#__PURE__*/ S(f, {
|
|
438
|
+
label: u._({ id: "gMYsdZ" }),
|
|
439
|
+
onClick: () => ve("shared")
|
|
440
|
+
}),
|
|
441
|
+
!G && $ && m.visibility === b.SHARED && (y.canCreateMember || y.canDeleteMember) && /*#__PURE__*/ S(f, {
|
|
442
|
+
label: u._({ id: "cWbW6w" }),
|
|
443
|
+
onClick: () => l({
|
|
444
|
+
to: "/projects/$projectId/compute/images/$imageId",
|
|
445
|
+
params: {
|
|
446
|
+
projectId: t,
|
|
447
|
+
imageId: m.id
|
|
448
|
+
},
|
|
449
|
+
search: { tab: "sharing" }
|
|
450
|
+
})
|
|
451
|
+
}),
|
|
452
|
+
!G && y.canDelete && !m.protected && /*#__PURE__*/ S(f, {
|
|
453
|
+
label: u._({ id: "cnGeoo" }),
|
|
454
|
+
onClick: () => N(!0)
|
|
455
|
+
})
|
|
456
|
+
] })] }),
|
|
457
|
+
!G && y.canUpdate && /*#__PURE__*/ S(o, {
|
|
458
|
+
onClick: () => j(!0),
|
|
459
|
+
disabled: X,
|
|
460
|
+
children: /*#__PURE__*/ S(E, { id: "SIfYq6" })
|
|
461
|
+
}),
|
|
462
|
+
!G && y.canUpdate && /*#__PURE__*/ S(o, {
|
|
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(te, {
|
|
471
|
+
title: String(m.name ?? m.id),
|
|
472
|
+
projectId: t,
|
|
473
|
+
actions: Ee
|
|
474
|
+
}),
|
|
475
|
+
/*#__PURE__*/ S("div", {
|
|
476
|
+
className: "mt-3",
|
|
477
|
+
children: /*#__PURE__*/ S(pe, {
|
|
478
|
+
image: m,
|
|
479
|
+
currentProjectId: t,
|
|
480
|
+
activeTab: a ?? "details",
|
|
481
|
+
onTabChange: (e) => l({ 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
|
+
}, m.id)
|
|
491
|
+
}),
|
|
492
|
+
R && /*#__PURE__*/ S(ee, { ...R }),
|
|
493
|
+
O && /*#__PURE__*/ S(ce, {
|
|
494
|
+
image: m,
|
|
495
|
+
isOpen: O,
|
|
496
|
+
isLoading: B.isPending,
|
|
497
|
+
onClose: () => k(!1),
|
|
498
|
+
onSave: Z
|
|
499
|
+
}),
|
|
500
|
+
A && /*#__PURE__*/ S(ae, {
|
|
501
|
+
image: m,
|
|
502
|
+
isOpen: A,
|
|
503
|
+
isLoading: B.isPending,
|
|
504
|
+
onClose: () => j(!1),
|
|
505
|
+
onSave: Z
|
|
506
|
+
}),
|
|
507
|
+
M && /*#__PURE__*/ S(ne, {
|
|
508
|
+
image: m,
|
|
509
|
+
isOpen: M,
|
|
510
|
+
isLoading: V.isPending,
|
|
511
|
+
isDisabled: !!m.protected,
|
|
512
|
+
onClose: () => N(!1),
|
|
513
|
+
onDelete: he
|
|
514
|
+
}),
|
|
515
|
+
P && /*#__PURE__*/ S(re, {
|
|
516
|
+
image: m,
|
|
517
|
+
isOpen: P,
|
|
518
|
+
isLoading: U.isPending,
|
|
519
|
+
onClose: () => F(!1),
|
|
520
|
+
onActivate: ge
|
|
521
|
+
}),
|
|
522
|
+
I && /*#__PURE__*/ S(oe, {
|
|
523
|
+
image: m,
|
|
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-DCvaU7-S.mjs.map
|