@cobaltcore-dev/aurora 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +141 -0
  3. package/dist/client/AuroraApp.d.ts +7 -0
  4. package/dist/client/AuthProvider-D-5Jpa6F.mjs +100 -0
  5. package/dist/client/AuthProvider-D-5Jpa6F.mjs.map +1 -0
  6. package/dist/client/ContentHeader-H8KGY3Wd.mjs +81 -0
  7. package/dist/client/ContentHeader-H8KGY3Wd.mjs.map +1 -0
  8. package/dist/client/DeleteFlavorModal-B98oiHWx.mjs +629 -0
  9. package/dist/client/DeleteFlavorModal-B98oiHWx.mjs.map +1 -0
  10. package/dist/client/EditSecurityGroupModal-wQVNIVg1.mjs +137 -0
  11. package/dist/client/EditSecurityGroupModal-wQVNIVg1.mjs.map +1 -0
  12. package/dist/client/FloatingIpActionModals-qu1NMI5a.mjs +417 -0
  13. package/dist/client/FloatingIpActionModals-qu1NMI5a.mjs.map +1 -0
  14. package/dist/client/ImageToastNotifications-wsQDNEh7.mjs +1267 -0
  15. package/dist/client/ImageToastNotifications-wsQDNEh7.mjs.map +1 -0
  16. package/dist/client/ListToolbar-CHlkZrpl.mjs +223 -0
  17. package/dist/client/ListToolbar-CHlkZrpl.mjs.map +1 -0
  18. package/dist/client/RouteError-BwgDIwJE.mjs +25 -0
  19. package/dist/client/RouteError-BwgDIwJE.mjs.map +1 -0
  20. package/dist/client/_auth-CsliQdkJ.mjs +11 -0
  21. package/dist/client/_auth-CsliQdkJ.mjs.map +1 -0
  22. package/dist/client/_flavorId-D_A53VYa.mjs +56 -0
  23. package/dist/client/_flavorId-D_A53VYa.mjs.map +1 -0
  24. package/dist/client/_flavorId-DbhYLFxY.mjs +190 -0
  25. package/dist/client/_flavorId-DbhYLFxY.mjs.map +1 -0
  26. package/dist/client/_floatingIpId-BGgftRBQ.mjs +21 -0
  27. package/dist/client/_floatingIpId-BGgftRBQ.mjs.map +1 -0
  28. package/dist/client/_floatingIpId-D5myuLFz.mjs +228 -0
  29. package/dist/client/_floatingIpId-D5myuLFz.mjs.map +1 -0
  30. package/dist/client/_imageId-BoHX155h.mjs +27 -0
  31. package/dist/client/_imageId-BoHX155h.mjs.map +1 -0
  32. package/dist/client/_imageId-CTa0c3Av.mjs +530 -0
  33. package/dist/client/_imageId-CTa0c3Av.mjs.map +1 -0
  34. package/dist/client/_pcaId-C7Lrv1H_.mjs +242 -0
  35. package/dist/client/_pcaId-C7Lrv1H_.mjs.map +1 -0
  36. package/dist/client/_pcaId-DBgz5V_9.mjs +21 -0
  37. package/dist/client/_pcaId-DBgz5V_9.mjs.map +1 -0
  38. package/dist/client/_projectId-B9fln31N.mjs +8 -0
  39. package/dist/client/_projectId-B9fln31N.mjs.map +1 -0
  40. package/dist/client/_projectId-Be1Erj68.mjs +300 -0
  41. package/dist/client/_projectId-Be1Erj68.mjs.map +1 -0
  42. package/dist/client/_projectId-C-E4NNgo.mjs +84 -0
  43. package/dist/client/_projectId-C-E4NNgo.mjs.map +1 -0
  44. package/dist/client/_projectId-INhedXor.mjs +26 -0
  45. package/dist/client/_projectId-INhedXor.mjs.map +1 -0
  46. package/dist/client/_securityGroupId-DQoRQ-yA.mjs +1647 -0
  47. package/dist/client/_securityGroupId-DQoRQ-yA.mjs.map +1 -0
  48. package/dist/client/_securityGroupId-ihjy8Lcd.mjs +21 -0
  49. package/dist/client/_securityGroupId-ihjy8Lcd.mjs.map +1 -0
  50. package/dist/client/about-oT6ccz8T.mjs +92 -0
  51. package/dist/client/about-oT6ccz8T.mjs.map +1 -0
  52. package/dist/client/aurora-D_NPTbo-.mjs +19 -0
  53. package/dist/client/aurora-D_NPTbo-.mjs.map +1 -0
  54. package/dist/client/build-eu9eg0zF.mjs +14619 -0
  55. package/dist/client/build-eu9eg0zF.mjs.map +1 -0
  56. package/dist/client/buildFilterParams-BDOIRDeD.mjs +15 -0
  57. package/dist/client/buildFilterParams-BDOIRDeD.mjs.map +1 -0
  58. package/dist/client/cn-C3laVXMm.mjs +10 -0
  59. package/dist/client/cn-C3laVXMm.mjs.map +1 -0
  60. package/dist/client/constants-ByHCdNsI.mjs +128 -0
  61. package/dist/client/constants-ByHCdNsI.mjs.map +1 -0
  62. package/dist/client/containers-B_ozmVlx.mjs +74 -0
  63. package/dist/client/containers-B_ozmVlx.mjs.map +1 -0
  64. package/dist/client/containers-Dx7TYruP.mjs +7 -0
  65. package/dist/client/containers-Dx7TYruP.mjs.map +1 -0
  66. package/dist/client/containers-rn_ntCJu.mjs +3029 -0
  67. package/dist/client/containers-rn_ntCJu.mjs.map +1 -0
  68. package/dist/client/flavors-CT4auvLO.mjs +565 -0
  69. package/dist/client/flavors-CT4auvLO.mjs.map +1 -0
  70. package/dist/client/flavors-DRZb9LJP.mjs +8 -0
  71. package/dist/client/flavors-DRZb9LJP.mjs.map +1 -0
  72. package/dist/client/flavors-DtgMd0Ii.mjs +12 -0
  73. package/dist/client/flavors-DtgMd0Ii.mjs.map +1 -0
  74. package/dist/client/floatingips-DG5cFJSZ.mjs +12 -0
  75. package/dist/client/floatingips-DG5cFJSZ.mjs.map +1 -0
  76. package/dist/client/floatingips-iCMR0ZiL.mjs +436 -0
  77. package/dist/client/floatingips-iCMR0ZiL.mjs.map +1 -0
  78. package/dist/client/formatBytes-GYujK0dP.mjs +38 -0
  79. package/dist/client/formatBytes-GYujK0dP.mjs.map +1 -0
  80. package/dist/client/helpers--JWXi40U.mjs +6 -0
  81. package/dist/client/helpers--JWXi40U.mjs.map +1 -0
  82. package/dist/client/hooks-s-I8vWww.mjs +2 -0
  83. package/dist/client/images-BTqRflJv2.mjs +1794 -0
  84. package/dist/client/images-BTqRflJv2.mjs.map +1 -0
  85. package/dist/client/images-DRTfx8k2.mjs +8 -0
  86. package/dist/client/images-DRTfx8k2.mjs.map +1 -0
  87. package/dist/client/images-xBfsjxkX.mjs +12 -0
  88. package/dist/client/images-xBfsjxkX.mjs.map +1 -0
  89. package/dist/client/index.d.ts +1 -0
  90. package/dist/client/index.js +1033 -0
  91. package/dist/client/index.js.map +1 -0
  92. package/dist/client/md-CI9FmfYv.mjs +390 -0
  93. package/dist/client/md-CI9FmfYv.mjs.map +1 -0
  94. package/dist/client/network-DFVVVNS5.mjs +8 -0
  95. package/dist/client/network-DFVVVNS5.mjs.map +1 -0
  96. package/dist/client/objects-CKk6cST_.mjs +4762 -0
  97. package/dist/client/objects-CKk6cST_.mjs.map +1 -0
  98. package/dist/client/objects-DkDKVSmQ.mjs +8 -0
  99. package/dist/client/objects-DkDKVSmQ.mjs.map +1 -0
  100. package/dist/client/objects-r_Vl31oj.mjs +80 -0
  101. package/dist/client/objects-r_Vl31oj.mjs.map +1 -0
  102. package/dist/client/overview-B7pXx6bt.mjs +173 -0
  103. package/dist/client/overview-B7pXx6bt.mjs.map +1 -0
  104. package/dist/client/overview-CKGLIu6W.mjs +12 -0
  105. package/dist/client/overview-CKGLIu6W.mjs.map +1 -0
  106. package/dist/client/overview-Ca8r3SAz.mjs +16 -0
  107. package/dist/client/overview-Ca8r3SAz.mjs.map +1 -0
  108. package/dist/client/overview-DkPM0Od5.mjs +12 -0
  109. package/dist/client/overview-DkPM0Od5.mjs.map +1 -0
  110. package/dist/client/overview-Dxm7Ef3X.mjs +12 -0
  111. package/dist/client/overview-Dxm7Ef3X.mjs.map +1 -0
  112. package/dist/client/overview-ag4Envez.mjs +16 -0
  113. package/dist/client/overview-ag4Envez.mjs.map +1 -0
  114. package/dist/client/pca-BGv7Mprl.mjs +12 -0
  115. package/dist/client/pca-BGv7Mprl.mjs.map +1 -0
  116. package/dist/client/pca-DpULpMu5.mjs +167 -0
  117. package/dist/client/pca-DpULpMu5.mjs.map +1 -0
  118. package/dist/client/projects-BuN69cxO.mjs +144 -0
  119. package/dist/client/projects-BuN69cxO.mjs.map +1 -0
  120. package/dist/client/projects-D1pP0XdA.mjs +12 -0
  121. package/dist/client/projects-D1pP0XdA.mjs.map +1 -0
  122. package/dist/client/projects-MbS1USl2.mjs +7 -0
  123. package/dist/client/projects-MbS1USl2.mjs.map +1 -0
  124. package/dist/client/projects-_Dfn6eQT.mjs +22 -0
  125. package/dist/client/projects-_Dfn6eQT.mjs.map +1 -0
  126. package/dist/client/securitygroups-DURjFfYK.mjs +12 -0
  127. package/dist/client/securitygroups-DURjFfYK.mjs.map +1 -0
  128. package/dist/client/securitygroups-KC2qvmH8.mjs +442 -0
  129. package/dist/client/securitygroups-KC2qvmH8.mjs.map +1 -0
  130. package/dist/client/trpcClient-BxguzNYF.mjs +57 -0
  131. package/dist/client/trpcClient-BxguzNYF.mjs.map +1 -0
  132. package/dist/client/useErrorTranslation-TZVwIAzq.mjs +83 -0
  133. package/dist/client/useErrorTranslation-TZVwIAzq.mjs.map +1 -0
  134. package/dist/client/useListWithFiltering-mMX_EfyI.mjs +32 -0
  135. package/dist/client/useListWithFiltering-mMX_EfyI.mjs.map +1 -0
  136. package/dist/client/useModal-Dg4CBeqL.mjs +12 -0
  137. package/dist/client/useModal-Dg4CBeqL.mjs.map +1 -0
  138. package/dist/client/useProjectId-BWaeJZOy.mjs +11 -0
  139. package/dist/client/useProjectId-BWaeJZOy.mjs.map +1 -0
  140. package/dist/server/index.d.ts +35 -0
  141. package/dist/server/index.js +36514 -0
  142. package/package.json +129 -0
@@ -0,0 +1,56 @@
1
+ import { g as e, v as t, w as n, z as r } from "./build-eu9eg0zF.mjs";
2
+ import { t as i } from "./helpers--JWXi40U.mjs";
3
+ import { jsx as a, jsxs as o } from "react/jsx-runtime";
4
+ import { createFileRoute as s, lazyRouteComponent as c, redirect as l } from "@tanstack/react-router";
5
+ import { Trans as u } from "@lingui/react";
6
+ //#region src/client/components/Error/StatusError.tsx
7
+ function d({ message: i, statusCode: s, onHomeClick: c, onBackClick: l, title: d, reset: f }) {
8
+ return /* @__PURE__ */ o(r, {
9
+ className: "mx-auto flex min-h-full max-w-3xl flex-col items-center justify-center px-6 py-12 sm:px-12 md:px-20",
10
+ children: [
11
+ s && /* @__PURE__ */ a("div", {
12
+ className: "text-theme-high text-6xl font-bold",
13
+ children: s
14
+ }),
15
+ /* @__PURE__ */ a(n, { children: d }),
16
+ /* @__PURE__ */ a("p", { children: i }),
17
+ (l || c || f) && /* @__PURE__ */ o(t, {
18
+ className: "mt-6",
19
+ children: [
20
+ l && /* @__PURE__ */ a(e, {
21
+ onClick: l,
22
+ variant: "primary",
23
+ children: /* @__PURE__ */ a(u, { id: "iH8pgl" })
24
+ }),
25
+ c && /* @__PURE__ */ a(e, {
26
+ onClick: c,
27
+ children: /* @__PURE__ */ a(u, { id: "i0qMbr" })
28
+ }),
29
+ f && /* @__PURE__ */ a(e, {
30
+ onClick: f,
31
+ children: /* @__PURE__ */ a(u, { id: "qJb6G2" })
32
+ })
33
+ ]
34
+ })
35
+ ]
36
+ });
37
+ }
38
+ var f = s("/_auth/projects/$projectId/compute/flavors/$flavorId")({
39
+ staticData: {
40
+ section: "compute",
41
+ service: "flavors",
42
+ isDetail: !0
43
+ },
44
+ component: c(() => import("./_flavorId-DbhYLFxY.mjs"), "component"),
45
+ beforeLoad: async ({ context: e, params: t }) => {
46
+ let { trpcClient: n } = e, { projectId: r } = t, a = i(await n?.auth.getAvailableServices.query() || []);
47
+ if (!a.flavor && !a.compute) throw l({
48
+ to: "/projects/$projectId/compute/overview",
49
+ params: { projectId: r }
50
+ });
51
+ }
52
+ });
53
+ //#endregion
54
+ export { d as n, f as t };
55
+
56
+ //# sourceMappingURL=_flavorId-D_A53VYa.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_flavorId-D_A53VYa.mjs","names":["Button","ButtonRow","Container","ContentHeading","StatusError","message","statusCode","onHomeClick","onBackClick","title","reset","className","div","p","onClick","variant","createFileRoute","redirect","getServiceIndex","Route","staticData","section","service","isDetail","RouteInfo","component","lazyRouteComponent","$$splitComponentImporter","beforeLoad","context","params","trpcClient","projectId","availableServices","auth","getAvailableServices","query","serviceIndex","to"],"sources":["../../src/client/components/Error/StatusError.tsx","../../src/client/routes/_auth/projects/$projectId/compute/flavors/$flavorId.tsx"],"sourcesContent":["import { Button, ButtonRow, Container, ContentHeading } from \"@cloudoperators/juno-ui-components/index\"\nimport { Trans } from \"@lingui/react/macro\"\n\ninterface StatusErrorProps {\n message: string\n statusCode?: number\n onHomeClick?: () => void\n onBackClick?: () => void\n title: string\n showHeader?: boolean\n reset?: () => void\n}\n\nexport function StatusError({ message, statusCode, onHomeClick, onBackClick, title, reset }: StatusErrorProps) {\n return (\n <Container className=\"mx-auto flex min-h-full max-w-3xl flex-col items-center justify-center px-6 py-12 sm:px-12 md:px-20\">\n {statusCode && <div className=\"text-theme-high text-6xl font-bold\">{statusCode}</div>}\n <ContentHeading>{title}</ContentHeading>\n <p>{message}</p>\n {(onBackClick || onHomeClick || reset) && (\n <ButtonRow className=\"mt-6\">\n {onBackClick && (\n <Button onClick={onBackClick} variant=\"primary\">\n <Trans>Back</Trans>\n </Button>\n )}\n {onHomeClick && (\n <Button onClick={onHomeClick}>\n <Trans>Home</Trans>\n </Button>\n )}\n\n {reset && (\n <Button onClick={reset}>\n <Trans>Try Again</Trans>\n </Button>\n )}\n </ButtonRow>\n )}\n </Container>\n )\n}\n","import {\n Button,\n ButtonRow,\n Stack,\n Spinner,\n PopupMenu,\n PopupMenuToggle,\n PopupMenuOptions,\n PopupMenuItem,\n} from \"@cloudoperators/juno-ui-components/index\"\nimport { createFileRoute, redirect, useNavigate, useParams } from \"@tanstack/react-router\"\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 { FlavorDetailsView } from \"./-components/FlavorDetailsView\"\nimport { StatusError } from \"@/client/components/Error/StatusError\"\nimport { useErrorTranslation } from \"@/client/utils/useErrorTranslation\"\nimport { EditSpecModal } from \"../-components/Flavors/-components/EditSpecModal\"\nimport { ManageAccessModal } from \"../-components/Flavors/-components/ManageAccessModal\"\nimport { DeleteFlavorModal } from \"../-components/Flavors/-components/DeleteFlavorModal\"\nimport { useModal } from \"@/client/utils/useModal\"\nimport { ContentHeader } from \"@/client/components/ContentHeader/ContentHeader\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/compute/flavors/$flavorId\")({\n staticData: { section: \"compute\", service: \"flavors\", isDetail: true } satisfies RouteInfo,\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 if (!serviceIndex[\"flavor\"] && !serviceIndex[\"compute\"]) {\n throw redirect({\n to: \"/projects/$projectId/compute/overview\",\n params: { projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { projectId, flavorId } = useParams({\n from: \"/_auth/projects/$projectId/compute/flavors/$flavorId\",\n })\n const { setPageTitle, trpcClient } = Route.useRouteContext()\n const navigate = useNavigate()\n const { t } = useLingui()\n const { translateError, isRetryableError } = useErrorTranslation()\n\n const {\n data: flavor,\n status,\n error,\n refetch,\n } = trpcReact.compute.getFlavorById.useQuery({\n project_id: projectId,\n flavorId,\n })\n\n const { data: permissionsData } = trpcReact.compute.canUser.useQuery({\n project_id: projectId,\n permission: [\"flavors:delete\", \"flavors:list_projects\", \"flavor_specs:create\", \"flavor_specs:delete\"],\n })\n\n const canDeleteFlavor = permissionsData?.[0] ?? false\n const canManageAccess = permissionsData?.[1] ?? false\n const canManageSpecs = (permissionsData?.[2] ?? false) || (permissionsData?.[3] ?? false)\n\n const [specModalOpen, toggleSpecModal] = useModal()\n const [accessModalOpen, toggleAccessModal] = useModal()\n const [deleteModalOpen, toggleDeleteModal] = useModal()\n\n if (flavor?.name) {\n setPageTitle(flavor.name)\n } else if (status === \"error\") {\n setPageTitle(t`Error - Flavor Details`)\n } else if (status === \"pending\") {\n setPageTitle(t`Loading Flavor...`)\n } else {\n setPageTitle(t`Flavor Details`)\n }\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/compute/flavors\",\n params: { projectId },\n })\n }\n\n const handleHome = () => {\n navigate({\n to: \"/projects/$projectId/compute/overview\",\n params: { projectId },\n })\n }\n\n const handleRetry = () => {\n refetch()\n }\n\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 Flavor Details...</Trans>\n </Stack>\n )\n }\n\n if (status === \"error\") {\n const errorCode = error?.message || \"UNKNOWN_ERROR\"\n const translatedError = translateError(errorCode)\n const canRetry = isRetryableError(errorCode)\n\n const getStatusCode = (code: string): number | undefined => {\n if (code.includes(\"UNAUTHORIZED\")) return 401\n if (code.includes(\"FORBIDDEN\")) return 403\n if (code.includes(\"NOT_FOUND\")) return 404\n if (code.includes(\"SERVER_ERROR\")) return 500\n return undefined\n }\n\n return (\n <StatusError\n message={translatedError}\n statusCode={getStatusCode(errorCode)}\n title={t`Error Loading Flavor`}\n onBackClick={handleBack}\n onHomeClick={handleHome}\n reset={canRetry ? handleRetry : undefined}\n />\n )\n }\n\n if (!flavor) {\n return (\n <StatusError\n message={t`The requested flavor could not be found. It may have been deleted or you may not have access to it.`}\n statusCode={404}\n title={t`Flavor Not Found`}\n onBackClick={handleBack}\n onHomeClick={handleHome}\n />\n )\n }\n\n const hasMoreActions = canManageAccess || canDeleteFlavor\n\n const headerActions =\n hasMoreActions || canManageSpecs ? (\n <ButtonRow>\n {hasMoreActions && (\n <PopupMenu>\n <PopupMenuToggle as=\"div\">\n <Button icon=\"moreVert\">\n <Trans>More Actions</Trans>\n </Button>\n </PopupMenuToggle>\n <PopupMenuOptions>\n {canManageAccess && <PopupMenuItem label={t`Manage Access`} onClick={toggleAccessModal} />}\n {canDeleteFlavor && <PopupMenuItem label={t`Delete Flavor`} onClick={toggleDeleteModal} />}\n </PopupMenuOptions>\n </PopupMenu>\n )}\n {canManageSpecs && (\n <Button onClick={toggleSpecModal} variant=\"primary\">\n <Trans>Metadata</Trans>\n </Button>\n )}\n </ButtonRow>\n ) : undefined\n\n return (\n <>\n <ContentHeader title={flavor.name} projectId={projectId} actions={headerActions} />\n <Stack direction=\"vertical\">\n <FlavorDetailsView flavor={flavor} />\n </Stack>\n\n {trpcClient && (\n <>\n {specModalOpen && (\n <EditSpecModal\n client={trpcClient}\n isOpen={specModalOpen}\n onClose={toggleSpecModal}\n project={projectId}\n flavor={flavor}\n />\n )}\n\n {accessModalOpen && (\n <ManageAccessModal\n client={trpcClient}\n isOpen={accessModalOpen}\n onClose={toggleAccessModal}\n project={projectId}\n flavor={flavor}\n />\n )}\n\n {deleteModalOpen && (\n <DeleteFlavorModal\n client={trpcClient}\n isOpen={deleteModalOpen}\n onClose={toggleDeleteModal}\n project={projectId}\n flavor={flavor}\n onSuccess={handleBack}\n />\n )}\n </>\n )}\n </>\n )\n}\n"],"mappings":";;;;;;AAaA,SAAgBI,EAAY,EAAEC,YAASC,eAAYC,gBAAaC,gBAAaC,UAAOC,YAAyB;AAC3G,QACE,kBAACR,GAAAA;EAAUS,WAAU;;GAClBL,KAAc,kBAACM,OAAAA;IAAID,WAAU;cAAsCL;;GACpE,kBAACH,GAAAA,EAAAA,UAAgBM,GAAAA,CAAAA;GACjB,kBAACI,KAAAA,EAAAA,UAAGR,GAAAA,CAAAA;IACFG,KAAeD,KAAeG,MAC9B,kBAACT,GAAAA;IAAUU,WAAU;;KAClBH,KACC,kBAACR,GAAAA;MAAOc,SAASN;MAAaO,SAAQ;gBACpC,kBAAA,GAAA,EAAA,IAAA,UAAA,CAAA;;KAGHR,KACC,kBAACP,GAAAA;MAAOc,SAASP;gBACf,kBAAA,GAAA,EAAA,IAAA,UAAA,CAAA;;KAIHG,KACC,kBAACV,GAAAA;MAAOc,SAASJ;gBACf,kBAAA,GAAA,EAAA,IAAA,UAAA,CAAA;;;;;;;ACVd,IAAaS,IAAQH,EAAgB,uDAAA,CAAwD;CAC3FI,YAAY;EAAEC,SAAS;EAAWC,SAAS;EAAWC,UAAU;EAAK;CACrEE,WAASC,4CAAA,YAAA;CACTE,YAAY,OAAO,EAAEC,YAASC,gBAAQ;EACpC,IAAM,EAAEC,kBAAeF,GACjB,EAAEG,iBAAcF,GAIhBO,IAAenB,EAFK,MAAOa,GAAYG,KAAKC,qBAAqBC,OAAAA,IAAY,EAAE,CAEhDH;AAErC,MAAI,CAACI,EAAa,UAAa,CAACA,EAAa,QAC3C,OAAMpB,EAAS;GACbqB,IAAI;GACJR,QAAQ,EAAEE,cAAU;GACtB,CAAA;;CAGN,CAAA"}
@@ -0,0 +1,190 @@
1
+ import { A as e, K as t, L as n, P as r, R as i, W as a, g as o, n as s, q as c, rt as l, v as u, w as d } from "./build-eu9eg0zF.mjs";
2
+ import { r as f } from "./trpcClient-BxguzNYF.mjs";
3
+ import { n as p, t as m } from "./_flavorId-D_A53VYa.mjs";
4
+ import { t as h } from "./useErrorTranslation-TZVwIAzq.mjs";
5
+ import { n as g, r as _, t as v } from "./DeleteFlavorModal-B98oiHWx.mjs";
6
+ import { t as y } from "./useModal-Dg4CBeqL.mjs";
7
+ import { t as b } from "./ContentHeader-H8KGY3Wd.mjs";
8
+ import { Fragment as x, jsx as S, jsxs as C } from "react/jsx-runtime";
9
+ import w from "react";
10
+ import { useNavigate as T, useParams as E } from "@tanstack/react-router";
11
+ import { Trans as D, useLingui as O } from "@lingui/react";
12
+ //#region src/client/routes/_auth/projects/$projectId/compute/flavors/-components/FlavorDetailsView.tsx
13
+ function k({ flavor: t }) {
14
+ let i = (e, t = "MB") => e === 0 ? `0 ${t}` : `${e} ${t}`;
15
+ return /* @__PURE__ */ C(c, {
16
+ direction: "vertical",
17
+ gap: "6",
18
+ className: "mt-6",
19
+ children: [
20
+ /* @__PURE__ */ C(c, {
21
+ direction: "vertical",
22
+ gap: "2",
23
+ children: [/* @__PURE__ */ S(d, { children: /* @__PURE__ */ S(D, { id: "jIPNJG" }) }), /* @__PURE__ */ C(e, {
24
+ alignTerms: "right",
25
+ children: [
26
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "S0kLOH" }) }),
27
+ /* @__PURE__ */ S(n, { children: t.id }),
28
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "6YtxFj" }) }),
29
+ /* @__PURE__ */ S(n, { children: t.name }),
30
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "Nu4oKW" }) }),
31
+ /* @__PURE__ */ S(n, { children: t?.description }),
32
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "7d1a0d" }) }),
33
+ /* @__PURE__ */ S(n, { children: t["os-flavor-access:is_public"] ? /* @__PURE__ */ S(D, { id: "l75CjT" }) : /* @__PURE__ */ S(D, { id: "1UzENP" }) }),
34
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "E/QGRL" }) }),
35
+ /* @__PURE__ */ S(n, { children: t["OS-FLV-DISABLED:disabled"] ? /* @__PURE__ */ S(D, { id: "l75CjT" }) : /* @__PURE__ */ S(D, { id: "1UzENP" }) })
36
+ ]
37
+ })]
38
+ }),
39
+ /* @__PURE__ */ C(c, {
40
+ direction: "vertical",
41
+ gap: "2",
42
+ children: [/* @__PURE__ */ S(d, { children: /* @__PURE__ */ S(D, { id: "qQ1QBh" }) }), /* @__PURE__ */ C(e, {
43
+ alignTerms: "right",
44
+ children: [
45
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "MZGbkp" }) }),
46
+ /* @__PURE__ */ S(n, { children: t.vcpus }),
47
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "RGhYAo" }) }),
48
+ /* @__PURE__ */ S(n, { children: i(t.ram, "MiB") }),
49
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "sPFHpI" }) }),
50
+ /* @__PURE__ */ S(n, { children: i(t.disk, "GiB") }),
51
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "r9Aac8" }) }),
52
+ /* @__PURE__ */ S(n, { children: i(t["OS-FLV-EXT-DATA:ephemeral"] || 0, "GiB") }),
53
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "vH2C/2" }) }),
54
+ /* @__PURE__ */ S(n, { children: t.swap === 0 || t.swap === "" ? /* @__PURE__ */ S(D, { id: "EdQY6l" }) : i(Number(t.swap), "MiB") }),
55
+ /* @__PURE__ */ S(r, { children: /* @__PURE__ */ S(D, { id: "u5HztT" }) }),
56
+ /* @__PURE__ */ S(n, { children: t.rxtx_factor })
57
+ ]
58
+ })]
59
+ }),
60
+ t.extra_specs && Object.keys(t.extra_specs).length > 0 && /* @__PURE__ */ C(c, {
61
+ direction: "vertical",
62
+ gap: "2",
63
+ children: [/* @__PURE__ */ S(d, { children: /* @__PURE__ */ S(D, { id: "DKkOPx" }) }), /* @__PURE__ */ S(e, {
64
+ alignTerms: "right",
65
+ children: Object.entries(t.extra_specs).map(([e, t]) => /* @__PURE__ */ C(w.Fragment, { children: [/* @__PURE__ */ S(r, { children: e }), /* @__PURE__ */ S(n, { children: t })] }, e))
66
+ })]
67
+ })
68
+ ]
69
+ });
70
+ }
71
+ //#endregion
72
+ //#region src/client/routes/_auth/projects/$projectId/compute/flavors/$flavorId.tsx?tsr-split=component
73
+ function A() {
74
+ let { projectId: e, flavorId: n } = E({ from: "/_auth/projects/$projectId/compute/flavors/$flavorId" }), { setPageTitle: r, trpcClient: d } = m.useRouteContext(), w = T(), { i18n: A, _: j } = O(), { translateError: M, isRetryableError: N } = h(), { data: P, status: F, error: I, refetch: L } = f.compute.getFlavorById.useQuery({
75
+ project_id: e,
76
+ flavorId: n
77
+ }), { data: R } = f.compute.canUser.useQuery({
78
+ project_id: e,
79
+ permission: [
80
+ "flavors:delete",
81
+ "flavors:list_projects",
82
+ "flavor_specs:create",
83
+ "flavor_specs:delete"
84
+ ]
85
+ }), z = R?.[0] ?? !1, B = R?.[1] ?? !1, V = (R?.[2] ?? !1) || (R?.[3] ?? !1), [H, U] = y(), [W, G] = y(), [K, q] = y();
86
+ P?.name ? r(P.name) : r(F === "error" ? A._({ id: "vcvCXq" }) : F === "pending" ? A._({ id: "/2a/eI" }) : A._({ id: "SysqAR" }));
87
+ let J = () => {
88
+ w({
89
+ to: "/projects/$projectId/compute/flavors",
90
+ params: { projectId: e }
91
+ });
92
+ }, Y = () => {
93
+ w({
94
+ to: "/projects/$projectId/compute/overview",
95
+ params: { projectId: e }
96
+ });
97
+ }, X = () => {
98
+ L();
99
+ };
100
+ if (F === "pending") return /* @__PURE__ */ C(c, {
101
+ className: "fixed inset-0",
102
+ distribution: "center",
103
+ alignment: "center",
104
+ direction: "vertical",
105
+ children: [/* @__PURE__ */ S(a, {
106
+ variant: "primary",
107
+ size: "large",
108
+ className: "mb-2"
109
+ }), /* @__PURE__ */ S(D, { id: "YNgcgc" })]
110
+ });
111
+ if (F === "error") {
112
+ let e = I?.message || "UNKNOWN_ERROR", t = M(e), n = N(e);
113
+ return /* @__PURE__ */ S(p, {
114
+ message: t,
115
+ statusCode: ((e) => {
116
+ if (e.includes("UNAUTHORIZED")) return 401;
117
+ if (e.includes("FORBIDDEN")) return 403;
118
+ if (e.includes("NOT_FOUND")) return 404;
119
+ if (e.includes("SERVER_ERROR")) return 500;
120
+ })(e),
121
+ title: A._({ id: "FjONW3" }),
122
+ onBackClick: J,
123
+ onHomeClick: Y,
124
+ reset: n ? X : void 0
125
+ });
126
+ }
127
+ if (!P) return /* @__PURE__ */ S(p, {
128
+ message: A._({ id: "y0u86k" }),
129
+ statusCode: 404,
130
+ title: A._({ id: "bpme7e" }),
131
+ onBackClick: J,
132
+ onHomeClick: Y
133
+ });
134
+ let Z = B || z, Q = Z || V ? /* @__PURE__ */ C(u, { children: [Z && /* @__PURE__ */ C(s, { children: [/* @__PURE__ */ S(i, {
135
+ as: "div",
136
+ children: /* @__PURE__ */ S(o, {
137
+ icon: "moreVert",
138
+ children: /* @__PURE__ */ S(D, { id: "PgNNGl" })
139
+ })
140
+ }), /* @__PURE__ */ C(l, { children: [B && /* @__PURE__ */ S(t, {
141
+ label: A._({ id: "cWbW6w" }),
142
+ onClick: G
143
+ }), z && /* @__PURE__ */ S(t, {
144
+ label: A._({ id: "JT3I1g" }),
145
+ onClick: q
146
+ })] })] }), V && /* @__PURE__ */ S(o, {
147
+ onClick: U,
148
+ variant: "primary",
149
+ children: /* @__PURE__ */ S(D, { id: "6GBt0m" })
150
+ })] }) : void 0;
151
+ return /* @__PURE__ */ C(x, { children: [
152
+ /* @__PURE__ */ S(b, {
153
+ title: P.name,
154
+ projectId: e,
155
+ actions: Q
156
+ }),
157
+ /* @__PURE__ */ S(c, {
158
+ direction: "vertical",
159
+ children: /* @__PURE__ */ S(k, { flavor: P })
160
+ }),
161
+ d && /* @__PURE__ */ C(x, { children: [
162
+ H && /* @__PURE__ */ S(_, {
163
+ client: d,
164
+ isOpen: H,
165
+ onClose: U,
166
+ project: e,
167
+ flavor: P
168
+ }),
169
+ W && /* @__PURE__ */ S(g, {
170
+ client: d,
171
+ isOpen: W,
172
+ onClose: G,
173
+ project: e,
174
+ flavor: P
175
+ }),
176
+ K && /* @__PURE__ */ S(v, {
177
+ client: d,
178
+ isOpen: K,
179
+ onClose: q,
180
+ project: e,
181
+ flavor: P,
182
+ onSuccess: J
183
+ })
184
+ ] })
185
+ ] });
186
+ }
187
+ //#endregion
188
+ export { A as component };
189
+
190
+ //# sourceMappingURL=_flavorId-DbhYLFxY.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_flavorId-DbhYLFxY.mjs","names":["React","Stack","DescriptionList","DescriptionTerm","DescriptionDefinition","ContentHeading","FlavorDetailsView","flavor","formatBytes","bytes","unit","direction","gap","className","alignTerms","id","name","description","vcpus","ram","disk","swap","Number","rxtx_factor","extra_specs","Object","keys","length","entries","map","key","value","Fragment","Button","ButtonRow","Stack","Spinner","PopupMenu","PopupMenuToggle","PopupMenuOptions","PopupMenuItem","useNavigate","useParams","Trans","useLingui","trpcReact","FlavorDetailsView","StatusError","useErrorTranslation","EditSpecModal","ManageAccessModal","DeleteFlavorModal","useModal","ContentHeader","Route","RouteComponent","projectId","flavorId","from","setPageTitle","trpcClient","useRouteContext","navigate","t","translateError","isRetryableError","data","flavor","status","error","refetch","compute","getFlavorById","useQuery","project_id","permissionsData","canUser","permission","canDeleteFlavor","canManageAccess","canManageSpecs","specModalOpen","toggleSpecModal","accessModalOpen","toggleAccessModal","deleteModalOpen","toggleDeleteModal","name","handleBack","to","params","handleHome","handleRetry","errorCode","message","translatedError","canRetry","getStatusCode","code","includes","undefined","hasMoreActions","headerActions","component"],"sources":["../../src/client/routes/_auth/projects/$projectId/compute/flavors/-components/FlavorDetailsView.tsx","../../src/client/routes/_auth/projects/$projectId/compute/flavors/$flavorId.tsx?tsr-split=component"],"sourcesContent":["import React from \"react\"\nimport {\n Stack,\n DescriptionList,\n DescriptionTerm,\n DescriptionDefinition,\n ContentHeading,\n} from \"@cloudoperators/juno-ui-components/index\"\nimport { Trans } from \"@lingui/react/macro\"\nimport type { Flavor } from \"@/server/Compute/types/flavor\"\n\ninterface FlavorDetailsViewProps {\n flavor: Flavor\n}\n\nexport function FlavorDetailsView({ flavor }: FlavorDetailsViewProps) {\n const formatBytes = (bytes: number, unit: string = \"MB\") => {\n if (bytes === 0) return `0 ${unit}`\n return `${bytes} ${unit}`\n }\n\n return (\n <Stack direction=\"vertical\" gap=\"6\" className=\"mt-6\">\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Basic Information</Trans>\n </ContentHeading>\n <DescriptionList alignTerms=\"right\">\n <DescriptionTerm>\n <Trans>ID</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{flavor.id}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Name</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{flavor.name}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Description</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{flavor?.description}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Public</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>\n {flavor[\"os-flavor-access:is_public\"] ? <Trans>Yes</Trans> : <Trans>No</Trans>}\n </DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Disabled</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>\n {flavor[\"OS-FLV-DISABLED:disabled\"] ? <Trans>Yes</Trans> : <Trans>No</Trans>}\n </DescriptionDefinition>\n </DescriptionList>\n </Stack>\n\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Hardware Specifications</Trans>\n </ContentHeading>\n <DescriptionList alignTerms=\"right\">\n <DescriptionTerm>\n <Trans>VCPUs</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{flavor.vcpus}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>RAM</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{formatBytes(flavor.ram, \"MiB\")}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Disk</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{formatBytes(flavor.disk, \"GiB\")}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Ephemeral Disk</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{formatBytes(flavor[\"OS-FLV-EXT-DATA:ephemeral\"] || 0, \"GiB\")}</DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>Swap</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>\n {flavor.swap === 0 || flavor.swap === \"\" ? <Trans>None</Trans> : formatBytes(Number(flavor.swap), \"MiB\")}\n </DescriptionDefinition>\n\n <DescriptionTerm>\n <Trans>RX/TX Factor</Trans>\n </DescriptionTerm>\n <DescriptionDefinition>{flavor.rxtx_factor}</DescriptionDefinition>\n </DescriptionList>\n </Stack>\n\n {flavor.extra_specs && Object.keys(flavor.extra_specs).length > 0 && (\n <Stack direction=\"vertical\" gap=\"2\">\n <ContentHeading>\n <Trans>Extra Specs</Trans>\n </ContentHeading>\n <DescriptionList alignTerms=\"right\">\n {Object.entries(flavor.extra_specs).map(([key, value]) => (\n <React.Fragment key={key}>\n <DescriptionTerm>{key}</DescriptionTerm>\n <DescriptionDefinition>{value}</DescriptionDefinition>\n </React.Fragment>\n ))}\n </DescriptionList>\n </Stack>\n )}\n </Stack>\n )\n}\n","import {\n Button,\n ButtonRow,\n Stack,\n Spinner,\n PopupMenu,\n PopupMenuToggle,\n PopupMenuOptions,\n PopupMenuItem,\n} from \"@cloudoperators/juno-ui-components/index\"\nimport { createFileRoute, redirect, useNavigate, useParams } from \"@tanstack/react-router\"\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 { FlavorDetailsView } from \"./-components/FlavorDetailsView\"\nimport { StatusError } from \"@/client/components/Error/StatusError\"\nimport { useErrorTranslation } from \"@/client/utils/useErrorTranslation\"\nimport { EditSpecModal } from \"../-components/Flavors/-components/EditSpecModal\"\nimport { ManageAccessModal } from \"../-components/Flavors/-components/ManageAccessModal\"\nimport { DeleteFlavorModal } from \"../-components/Flavors/-components/DeleteFlavorModal\"\nimport { useModal } from \"@/client/utils/useModal\"\nimport { ContentHeader } from \"@/client/components/ContentHeader/ContentHeader\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/compute/flavors/$flavorId\")({\n staticData: { section: \"compute\", service: \"flavors\", isDetail: true } satisfies RouteInfo,\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 if (!serviceIndex[\"flavor\"] && !serviceIndex[\"compute\"]) {\n throw redirect({\n to: \"/projects/$projectId/compute/overview\",\n params: { projectId },\n })\n }\n },\n})\n\nfunction RouteComponent() {\n const { projectId, flavorId } = useParams({\n from: \"/_auth/projects/$projectId/compute/flavors/$flavorId\",\n })\n const { setPageTitle, trpcClient } = Route.useRouteContext()\n const navigate = useNavigate()\n const { t } = useLingui()\n const { translateError, isRetryableError } = useErrorTranslation()\n\n const {\n data: flavor,\n status,\n error,\n refetch,\n } = trpcReact.compute.getFlavorById.useQuery({\n project_id: projectId,\n flavorId,\n })\n\n const { data: permissionsData } = trpcReact.compute.canUser.useQuery({\n project_id: projectId,\n permission: [\"flavors:delete\", \"flavors:list_projects\", \"flavor_specs:create\", \"flavor_specs:delete\"],\n })\n\n const canDeleteFlavor = permissionsData?.[0] ?? false\n const canManageAccess = permissionsData?.[1] ?? false\n const canManageSpecs = (permissionsData?.[2] ?? false) || (permissionsData?.[3] ?? false)\n\n const [specModalOpen, toggleSpecModal] = useModal()\n const [accessModalOpen, toggleAccessModal] = useModal()\n const [deleteModalOpen, toggleDeleteModal] = useModal()\n\n if (flavor?.name) {\n setPageTitle(flavor.name)\n } else if (status === \"error\") {\n setPageTitle(t`Error - Flavor Details`)\n } else if (status === \"pending\") {\n setPageTitle(t`Loading Flavor...`)\n } else {\n setPageTitle(t`Flavor Details`)\n }\n\n const handleBack = () => {\n navigate({\n to: \"/projects/$projectId/compute/flavors\",\n params: { projectId },\n })\n }\n\n const handleHome = () => {\n navigate({\n to: \"/projects/$projectId/compute/overview\",\n params: { projectId },\n })\n }\n\n const handleRetry = () => {\n refetch()\n }\n\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 Flavor Details...</Trans>\n </Stack>\n )\n }\n\n if (status === \"error\") {\n const errorCode = error?.message || \"UNKNOWN_ERROR\"\n const translatedError = translateError(errorCode)\n const canRetry = isRetryableError(errorCode)\n\n const getStatusCode = (code: string): number | undefined => {\n if (code.includes(\"UNAUTHORIZED\")) return 401\n if (code.includes(\"FORBIDDEN\")) return 403\n if (code.includes(\"NOT_FOUND\")) return 404\n if (code.includes(\"SERVER_ERROR\")) return 500\n return undefined\n }\n\n return (\n <StatusError\n message={translatedError}\n statusCode={getStatusCode(errorCode)}\n title={t`Error Loading Flavor`}\n onBackClick={handleBack}\n onHomeClick={handleHome}\n reset={canRetry ? handleRetry : undefined}\n />\n )\n }\n\n if (!flavor) {\n return (\n <StatusError\n message={t`The requested flavor could not be found. It may have been deleted or you may not have access to it.`}\n statusCode={404}\n title={t`Flavor Not Found`}\n onBackClick={handleBack}\n onHomeClick={handleHome}\n />\n )\n }\n\n const hasMoreActions = canManageAccess || canDeleteFlavor\n\n const headerActions =\n hasMoreActions || canManageSpecs ? (\n <ButtonRow>\n {hasMoreActions && (\n <PopupMenu>\n <PopupMenuToggle as=\"div\">\n <Button icon=\"moreVert\">\n <Trans>More Actions</Trans>\n </Button>\n </PopupMenuToggle>\n <PopupMenuOptions>\n {canManageAccess && <PopupMenuItem label={t`Manage Access`} onClick={toggleAccessModal} />}\n {canDeleteFlavor && <PopupMenuItem label={t`Delete Flavor`} onClick={toggleDeleteModal} />}\n </PopupMenuOptions>\n </PopupMenu>\n )}\n {canManageSpecs && (\n <Button onClick={toggleSpecModal} variant=\"primary\">\n <Trans>Metadata</Trans>\n </Button>\n )}\n </ButtonRow>\n ) : undefined\n\n return (\n <>\n <ContentHeader title={flavor.name} projectId={projectId} actions={headerActions} />\n <Stack direction=\"vertical\">\n <FlavorDetailsView flavor={flavor} />\n </Stack>\n\n {trpcClient && (\n <>\n {specModalOpen && (\n <EditSpecModal\n client={trpcClient}\n isOpen={specModalOpen}\n onClose={toggleSpecModal}\n project={projectId}\n flavor={flavor}\n />\n )}\n\n {accessModalOpen && (\n <ManageAccessModal\n client={trpcClient}\n isOpen={accessModalOpen}\n onClose={toggleAccessModal}\n project={projectId}\n flavor={flavor}\n />\n )}\n\n {deleteModalOpen && (\n <DeleteFlavorModal\n client={trpcClient}\n isOpen={deleteModalOpen}\n onClose={toggleDeleteModal}\n project={projectId}\n flavor={flavor}\n onSuccess={handleBack}\n />\n )}\n </>\n )}\n </>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ import { t as e } from "./helpers--JWXi40U.mjs";
2
+ import { createFileRoute as t, lazyRouteComponent as n, redirect as r } from "@tanstack/react-router";
3
+ var i = t("/_auth/projects/$projectId/network/floatingips/$floatingIpId/")({
4
+ staticData: {
5
+ section: "network",
6
+ service: "floatingips",
7
+ isDetail: !0
8
+ },
9
+ component: n(() => import("./_floatingIpId-D5myuLFz.mjs"), "component"),
10
+ beforeLoad: async ({ context: t, params: n }) => {
11
+ let { trpcClient: i } = t, a = e(await i?.auth.getAvailableServices.query() || []);
12
+ if (!a.network || !a.network.neutron) throw r({
13
+ to: "/projects/$projectId/network/floatingips",
14
+ params: { projectId: n.projectId }
15
+ });
16
+ }
17
+ });
18
+ //#endregion
19
+ export { i as t };
20
+
21
+ //# sourceMappingURL=_floatingIpId-BGgftRBQ.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_floatingIpId-BGgftRBQ.mjs","names":["createFileRoute","redirect","getServiceIndex","Route","staticData","section","service","isDetail","RouteInfo","component","lazyRouteComponent","$$splitComponentImporter","beforeLoad","context","params","trpcClient","availableServices","auth","getAvailableServices","query","serviceIndex","to","projectId"],"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, useLingui } 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: { section: \"network\", service: \"floatingips\", isDetail: true } satisfies RouteInfo,\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 const { t } = useLingui()\n const { setPageTitle } = Route.useRouteContext()\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 setPageTitle(t`Loading...`)\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 setPageTitle(floatingIp.floating_ip_address)\n return (\n <>\n <ContentHeading>{floatingIp.floating_ip_address}</ContentHeading>\n <FloatingIpDetailsView floatingIp={floatingIp} />\n </>\n )\n}\n"],"mappings":";;AASA,IAAaG,IAAQH,EAAgB,gEAAA,CAAiE;CACpGI,YAAY;EAAEC,SAAS;EAAWC,SAAS;EAAeC,UAAU;EAAK;CACzEE,WAASC,gDAAA,YAAA;CACTE,YAAY,OAAO,EAAEC,YAASC,gBAAQ;EACpC,IAAM,EAAEC,kBAAeF,GAGjBO,IAAelB,EADK,MAAOa,GAAYE,KAAKC,qBAAqBC,OAAAA,IAAY,EAAE,CAChDH;AAUrC,MAPI,CAACI,EAAa,WAOd,CAACA,EAAa,QAAW,QAC3B,OAAMnB,EAAS;GACboB,IAAI;GACJP,QAAQ,EAAEQ,WAAWR,EAAOQ,WAAU;GACxC,CAAA;;CAGN,CAAA"}
@@ -0,0 +1,228 @@
1
+ import { A as e, L as t, P as n, W as r, g as i, q as a, v as o, w as s } from "./build-eu9eg0zF.mjs";
2
+ import { r as c } from "./trpcClient-BxguzNYF.mjs";
3
+ import { t as l } from "./_floatingIpId-BGgftRBQ.mjs";
4
+ import { t as u } from "./useProjectId-BWaeJZOy.mjs";
5
+ import "./hooks-s-I8vWww.mjs";
6
+ import { t as d } from "./FloatingIpActionModals-qu1NMI5a.mjs";
7
+ import { Fragment as f, jsx as p, jsxs as m } from "react/jsx-runtime";
8
+ import { Fragment as h } from "react";
9
+ import { useNavigate as g } from "@tanstack/react-router";
10
+ import { Trans as _, useLingui as v } from "@lingui/react";
11
+ //#region src/client/utils/formatFloatingIpStatus.ts
12
+ var y = (e) => e.charAt(0) + e.slice(1).toLowerCase(), b = ({ items: r }) => {
13
+ let i = Math.ceil(r.length / 2), o = r.slice(0, i), s = r.slice(i);
14
+ return /* @__PURE__ */ m(a, {
15
+ gap: "6",
16
+ className: "grid grid-cols-2",
17
+ children: [/* @__PURE__ */ p(e, {
18
+ alignTerms: "right",
19
+ children: o.map(({ label: e, value: r }) => /* @__PURE__ */ m(h, { children: [/* @__PURE__ */ p(n, { children: e }), /* @__PURE__ */ p(t, { children: r })] }, e))
20
+ }), /* @__PURE__ */ p(e, {
21
+ alignTerms: "right",
22
+ children: s.map(({ label: e, value: r }) => /* @__PURE__ */ m(h, { children: [/* @__PURE__ */ p(n, { children: e }), /* @__PURE__ */ p(t, { children: r })] }, e))
23
+ })]
24
+ });
25
+ }, x = ({ floatingIp: e }) => {
26
+ let { i18n: t, _: n } = v(), r = [
27
+ {
28
+ label: t._({ id: "S0kLOH" }),
29
+ value: e.id
30
+ },
31
+ {
32
+ label: t._({ id: "Nu4oKW" }),
33
+ value: e.description || "—"
34
+ },
35
+ {
36
+ label: t._({ id: "mSfwLL" }),
37
+ value: e.project_id || "—"
38
+ },
39
+ {
40
+ label: t._({ id: "uAQUqI" }),
41
+ value: y(e.status)
42
+ },
43
+ {
44
+ label: t._({ id: "88kg0+" }),
45
+ value: e.created_at ? new Date(e.created_at).toLocaleString() : "—"
46
+ },
47
+ {
48
+ label: t._({ id: "Llcakz" }),
49
+ value: e.updated_at ? new Date(e.updated_at).toLocaleString() : "—"
50
+ },
51
+ {
52
+ label: t._({ id: "OYHzN1" }),
53
+ value: e.tags?.join(", ") || "—"
54
+ }
55
+ ], c = [
56
+ {
57
+ label: t._({ id: "xNG/3n" }),
58
+ value: e.floating_ip_address || "—"
59
+ },
60
+ {
61
+ label: t._({ id: "7AfIPZ" }),
62
+ value: e.floating_network_id || "—"
63
+ },
64
+ {
65
+ label: t._({ id: "Nc7QKU" }),
66
+ value: e.fixed_ip_address || "—"
67
+ },
68
+ {
69
+ label: t._({ id: "6sxz+g" }),
70
+ value: e.port_details?.name || "—"
71
+ },
72
+ {
73
+ label: t._({ id: "sNVNmf" }),
74
+ value: e.port_details?.mac_address || "—"
75
+ },
76
+ {
77
+ label: t._({ id: "hrBow7" }),
78
+ value: e.port_details?.network_id || "—"
79
+ },
80
+ {
81
+ label: t._({ id: "OaSktR" }),
82
+ value: e.port_details?.device_owner || "—"
83
+ },
84
+ {
85
+ label: t._({ id: "9rz81C" }),
86
+ value: e.port_details?.device_id || "—"
87
+ },
88
+ {
89
+ label: t._({ id: "/bUiYk" }),
90
+ value: e.router_id || "—"
91
+ },
92
+ {
93
+ label: t._({ id: "eks7oA" }),
94
+ value: e.port_id || "—"
95
+ },
96
+ {
97
+ label: t._({ id: "W9kfjU" }),
98
+ value: e.qos_policy_id || "—"
99
+ },
100
+ {
101
+ label: t._({ id: "mQSO1Y" }),
102
+ value: e.port_forwardings?.map((e) => e.id).join(", ") || "—"
103
+ }
104
+ ], l = [{
105
+ label: t._({ id: "WlpcJv" }),
106
+ value: e.dns_domain || "—"
107
+ }, {
108
+ label: t._({ id: "eGEHJE" }),
109
+ value: e.dns_name || "—"
110
+ }];
111
+ return /* @__PURE__ */ m(f, { children: [
112
+ /* @__PURE__ */ p("p", {
113
+ className: "text-theme-secondary mt-2 text-sm",
114
+ children: /* @__PURE__ */ p(_, { id: "DNVql8" })
115
+ }),
116
+ /* @__PURE__ */ p(d, {
117
+ floatingIp: e,
118
+ children: ({ toggleEditModal: e, toggleAttachModal: n, toggleDetachModal: r, toggleReleaseModal: a }) => /* @__PURE__ */ m(o, { children: [
119
+ /* @__PURE__ */ p(i, {
120
+ onClick: e,
121
+ children: t._({ id: "n22YIM" })
122
+ }),
123
+ /* @__PURE__ */ p(i, {
124
+ onClick: n,
125
+ children: t._({ id: "igVDFt" })
126
+ }),
127
+ /* @__PURE__ */ p(i, {
128
+ onClick: r,
129
+ children: t._({ id: "FOcBn3" })
130
+ }),
131
+ /* @__PURE__ */ p(i, {
132
+ onClick: a,
133
+ children: t._({ id: "H+a5j6" })
134
+ })
135
+ ] })
136
+ }),
137
+ /* @__PURE__ */ m(a, {
138
+ direction: "vertical",
139
+ gap: "6",
140
+ className: "my-6",
141
+ children: [
142
+ /* @__PURE__ */ m(a, {
143
+ direction: "vertical",
144
+ gap: "2",
145
+ children: [/* @__PURE__ */ p(s, { children: /* @__PURE__ */ p(_, { id: "SuX2Ca" }) }), /* @__PURE__ */ p(b, { items: r })]
146
+ }),
147
+ /* @__PURE__ */ m(a, {
148
+ direction: "vertical",
149
+ gap: "2",
150
+ children: [/* @__PURE__ */ p(s, { children: /* @__PURE__ */ p(_, { id: "jKopCP" }) }), /* @__PURE__ */ p(b, { items: c })]
151
+ }),
152
+ /* @__PURE__ */ m(a, {
153
+ direction: "vertical",
154
+ gap: "2",
155
+ children: [/* @__PURE__ */ p(s, { children: /* @__PURE__ */ p(_, { id: "5M4Te3" }) }), /* @__PURE__ */ p(b, { items: l })]
156
+ })
157
+ ]
158
+ })
159
+ ] });
160
+ };
161
+ //#endregion
162
+ //#region src/client/routes/_auth/projects/$projectId/network/floatingips/$floatingIpId/index.tsx?tsr-split=component
163
+ function S() {
164
+ let { floatingIpId: e } = l.useParams(), t = u(), n = g(), { i18n: o, _: d } = v(), { setPageTitle: h } = l.useRouteContext(), { data: y, isLoading: b, isError: S, error: C } = c.network.floatingIp.getById.useQuery({
165
+ project_id: t,
166
+ floatingip_id: e
167
+ }), w = () => {
168
+ n({
169
+ to: "/projects/$projectId/network/floatingips",
170
+ params: { projectId: t }
171
+ });
172
+ };
173
+ if (b) return h(o._({ id: "Z3FXyt" })), /* @__PURE__ */ m(a, {
174
+ className: "fixed inset-0",
175
+ distribution: "center",
176
+ alignment: "center",
177
+ direction: "vertical",
178
+ children: [/* @__PURE__ */ p(r, {
179
+ variant: "primary",
180
+ size: "large",
181
+ className: "mb-2"
182
+ }), /* @__PURE__ */ p(_, { id: "VLI9eO" })]
183
+ });
184
+ if (S) {
185
+ let e = C?.message || "Unknown error";
186
+ return /* @__PURE__ */ m(a, {
187
+ className: "fixed inset-0",
188
+ distribution: "center",
189
+ alignment: "center",
190
+ direction: "vertical",
191
+ gap: "5",
192
+ children: [
193
+ /* @__PURE__ */ p("p", {
194
+ className: "text-theme-error font-semibold",
195
+ children: /* @__PURE__ */ p(_, { id: "Smk7M2" })
196
+ }),
197
+ /* @__PURE__ */ p("p", {
198
+ className: "text-theme-highest",
199
+ children: e
200
+ }),
201
+ /* @__PURE__ */ p(i, {
202
+ onClick: w,
203
+ variant: "primary",
204
+ children: /* @__PURE__ */ p(_, { id: "z1JceR" })
205
+ })
206
+ ]
207
+ });
208
+ }
209
+ return y ? (h(y.floating_ip_address), /* @__PURE__ */ m(f, { children: [/* @__PURE__ */ p(s, { children: y.floating_ip_address }), /* @__PURE__ */ p(x, { floatingIp: y })] })) : /* @__PURE__ */ m(a, {
210
+ className: "fixed inset-0",
211
+ distribution: "center",
212
+ alignment: "center",
213
+ direction: "vertical",
214
+ gap: "5",
215
+ children: [/* @__PURE__ */ p("p", {
216
+ className: "text-theme-secondary",
217
+ children: /* @__PURE__ */ p(_, { id: "ChOuUj" })
218
+ }), /* @__PURE__ */ p(i, {
219
+ onClick: w,
220
+ variant: "primary",
221
+ children: /* @__PURE__ */ p(_, { id: "z1JceR" })
222
+ })]
223
+ });
224
+ }
225
+ //#endregion
226
+ export { S as component };
227
+
228
+ //# sourceMappingURL=_floatingIpId-D5myuLFz.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_floatingIpId-D5myuLFz.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","useLingui","useProjectId","trpcReact","FloatingIpDetailsView","Route","RouteComponent","floatingIpId","useParams","projectId","navigate","t","setPageTitle","useRouteContext","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, useLingui } 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: { section: \"network\", service: \"floatingips\", isDetail: true } satisfies RouteInfo,\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 const { t } = useLingui()\n const { setPageTitle } = Route.useRouteContext()\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 setPageTitle(t`Loading...`)\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 setPageTitle(floatingIp.floating_ip_address)\n return (\n <>\n <ContentHeading>{floatingIp.floating_ip_address}</ContentHeading>\n <FloatingIpDetailsView floatingIp={floatingIp} />\n </>\n )\n}\n"],"mappings":"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"}