@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 @@
1
+ {"version":3,"file":"pca-DpULpMu5.mjs","names":["useNavigate","DataGridCell","DataGridRow","PopupMenu","PopupMenuItem","PopupMenuOptions","useModal","useProjectId","DeletePcaModal","STATE_CONFIG","PcaTableRow","pca","useLingui","navigate","projectId","deletePcaModalOpen","toggleDeletePcaModal","navigateToDetailsPage","to","params","pcaId","id","data-testid","onClick","div","className","state","icon","text","configuration","subject","common_name","e","stopPropagation","label","t","open","onClose","z","useForm","Modal","Form","FormSection","Spinner","TextInput","Message","trpcReact","useProjectId","csrRegex","isValidCommonName","value","test","CreatePcaModal","open","onClose","useLingui","projectId","utils","useUtils","isPending","createPcaMutation","services","pca","create","useMutation","onSettled","list","invalidate","formSchema","object","common_name","string","trim","min","t","refine","message","form","defaultValues","validators","onSubmit","mutateAsync","project_id","configuration","subject","handleClose","reset","size","title","onCancel","cancelButtonLabel","confirmButtonLabel","onConfirm","handleSubmit","disableConfirmButton","error","dismissible","variant","className","div","span","id","e","preventDefault","Field","name","children","field","state","onBlur","handleBlur","onChange","handleChange","target","label","placeholder","helptext","errortext","meta","errors","map","join","disabled","Stack","Spinner","DataGrid","DataGridRow","DataGridCell","ContentHeading","DataGridHeadCell","Button","trpcReact","useProjectId","TABLE_COLUMNS","PcaTableRow","useModal","CreatePcaModal","PcaListContainer","useLingui","projectId","columns","createCaOpen","toggleCreateCa","data","pcas","isLoading","isError","error","services","pca","list","useQuery","project_id","className","distribution","alignment","direction","variant","size","message","t","length","data-testid","colSpan","p","div","label","onClick","map","id","open","onClose","useLingui","ContentHeader","PcaListContainer","Route","RouteComponent","t","projectId","useParams","setPageTitle","useRouteContext","component"],"sources":["../../src/client/routes/_auth/projects/$projectId/services/pca/-components/-table/PcaTableRow.tsx","../../src/client/routes/_auth/projects/$projectId/services/pca/-components/-modals/CreatePcaModal.tsx","../../src/client/routes/_auth/projects/$projectId/services/pca/-components/PcaListContainer.tsx","../../src/client/routes/_auth/projects/$projectId/services/pca/index.tsx?tsr-split=component"],"sourcesContent":["import { useNavigate } from \"@tanstack/react-router\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport {\n DataGridCell,\n DataGridRow,\n PopupMenu,\n PopupMenuItem,\n PopupMenuOptions,\n} from \"@cloudoperators/juno-ui-components\"\nimport { CertificateAuthority } from \"@/server/Services/types/pca\"\nimport { useModal } from \"@/client/utils/useModal\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { DeletePcaModal } from \"../-modals/DeletePcaModal\"\nimport { STATE_CONFIG } from \"./constants\"\n\ninterface PcaTableRowProps {\n pca: CertificateAuthority\n}\n\nexport const PcaTableRow = ({ pca }: PcaTableRowProps) => {\n const { t } = useLingui()\n const navigate = useNavigate()\n const projectId = useProjectId()\n const [deletePcaModalOpen, toggleDeletePcaModal] = useModal(false)\n\n const navigateToDetailsPage = () =>\n navigate({\n to: \"/projects/$projectId/services/pca/$pcaId\",\n params: { projectId, pcaId: pca.id },\n })\n\n return (\n <>\n <DataGridRow key={pca.id} data-testid={`pca-row-${pca.id}`} onClick={navigateToDetailsPage}>\n <DataGridCell>\n <div className=\"flex items-center gap-2\">\n {STATE_CONFIG[pca.state].icon}\n {STATE_CONFIG[pca.state].text}\n </div>\n </DataGridCell>\n <DataGridCell>{pca.id}</DataGridCell>\n <DataGridCell>{pca.configuration?.subject?.common_name || \"—\"}</DataGridCell>\n <DataGridCell onClick={(e) => e.stopPropagation()} className=\"items-end pr-0\">\n <PopupMenu>\n <PopupMenuOptions>\n <PopupMenuItem label={t`Delete CA`} onClick={toggleDeletePcaModal} />\n </PopupMenuOptions>\n </PopupMenu>\n </DataGridCell>\n </DataGridRow>\n\n {deletePcaModalOpen && <DeletePcaModal pca={pca} open={deletePcaModalOpen} onClose={toggleDeletePcaModal} />}\n </>\n )\n}\n","import { z } from \"zod\"\nimport { useForm } from \"@tanstack/react-form\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { Modal, Form, FormSection, Spinner, TextInput, Message } from \"@cloudoperators/juno-ui-components\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { useProjectId } from \"@/client/hooks\"\n\nexport interface CreateCaModalProps {\n open: boolean\n onClose: () => void\n}\n\nconst csrRegex = /^(?=.{1,253}$)(?:\\*\\.)?(?:[A-Za-z0-9](?:[A-Za-z0-9-]{0,61}[A-Za-z0-9])?\\.)+[A-Za-z]{2,63}$/\nconst isValidCommonName = (value: string) => csrRegex.test(value)\n\nexport const CreatePcaModal = ({ open, onClose }: CreateCaModalProps) => {\n const { t } = useLingui()\n const projectId = useProjectId()\n const utils = trpcReact.useUtils()\n\n const { isPending, ...createPcaMutation } = trpcReact.services.pca.create.useMutation({\n onSettled: () => utils.services.pca.list.invalidate(),\n })\n\n const formSchema = z.object({\n common_name: z\n .string()\n .trim()\n .min(1, t`Common name is required.`)\n .refine((value) => isValidCommonName(value), { message: t`Must be a valid common name (FQDN).` }),\n })\n\n const form = useForm({\n defaultValues: {\n common_name: \"\",\n },\n validators: {\n onSubmit: formSchema,\n },\n onSubmit: async ({ value }) => {\n if (isPending) return\n\n await createPcaMutation.mutateAsync({\n project_id: projectId,\n configuration: {\n subject: { common_name: value.common_name },\n },\n })\n handleClose()\n },\n })\n\n const handleClose = () => {\n if (isPending) return\n\n form.reset()\n createPcaMutation.reset()\n onClose()\n }\n\n return (\n <Modal\n open={open}\n size=\"large\"\n title={t`Create Certificate Authority`}\n onCancel={handleClose}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Save`}\n onConfirm={form.handleSubmit}\n disableConfirmButton={isPending}\n >\n {createPcaMutation.error?.message && (\n <Message dismissible={false} variant=\"error\" className=\"mb-4\">\n {createPcaMutation.error.message}\n </Message>\n )}\n\n {isPending && (\n <div className=\"mb-4 flex items-center justify-center gap-2\">\n <Spinner variant=\"primary\" />\n <span className=\"text-theme-high text-sm\">\n <Trans>Creating Certificate Authority...</Trans>\n </span>\n </div>\n )}\n\n {!isPending && (\n <Form\n className=\"mb-0\"\n id=\"create-certificate-authority-form\"\n onSubmit={(e) => {\n e.preventDefault()\n form.handleSubmit()\n }}\n >\n <FormSection className=\"mb-4\">\n <form.Field\n name=\"common_name\"\n children={(field) => (\n <TextInput\n id={field.name}\n name={field.name}\n value={field.state.value}\n onBlur={field.handleBlur}\n onChange={(e) => field.handleChange(e.target.value)}\n label={t`Common name`}\n placeholder={t`Enter Common name (e.g., demo-ca.test.sci)`}\n helptext={t`Enter a valid common name in FQDN format (e.g., demo-ca.test.sci).`}\n errortext={field.state.meta.errors.map((e) => e?.message).join(\", \")}\n disabled={isPending}\n />\n )}\n />\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import {\n Stack,\n Spinner,\n DataGrid,\n DataGridRow,\n DataGridCell,\n ContentHeading,\n DataGridHeadCell,\n Button,\n} from \"@cloudoperators/juno-ui-components\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { trpcReact } from \"@/client/trpcClient\"\nimport { useProjectId } from \"@/client/hooks\"\nimport { TABLE_COLUMNS } from \"./-table/constants\"\nimport { PcaTableRow } from \"./-table/PcaTableRow\"\nimport { useModal } from \"@/client/utils/useModal\"\nimport { CreatePcaModal } from \"./-modals/CreatePcaModal\"\n\nexport const PcaListContainer = () => {\n const { t } = useLingui()\n const projectId = useProjectId()\n const columns = TABLE_COLUMNS()\n const [createCaOpen, toggleCreateCa] = useModal(false)\n\n // Check filtering, sorting and search API compatibility with OpenStack -> implement with <ListToolbar />\n const { data: pcas = [], isLoading, isError, error } = trpcReact.services.pca.list.useQuery({ project_id: projectId })\n\n if (isLoading) {\n return (\n <Stack className=\"py-8\" distribution=\"center\" alignment=\"center\" direction=\"vertical\">\n <Spinner variant=\"primary\" size=\"large\" className=\"mb-2\" />\n <Trans>Loading...</Trans>\n </Stack>\n )\n }\n\n if (isError) {\n return (\n <Stack className=\"py-8\" distribution=\"center\" alignment=\"center\" direction=\"vertical\">\n {error?.message ?? t`Failed to load PCAs`}\n </Stack>\n )\n }\n\n if (pcas.length === 0) {\n return (\n <DataGrid columns={columns.length} className=\"pca\" data-testid=\"no-pcas\">\n <DataGridRow>\n <DataGridCell colSpan={columns.length}>\n <ContentHeading>\n <Trans>No PCAs found</Trans>\n </ContentHeading>\n <p>\n <Trans>There are no PCAs available for this project.</Trans>\n </p>\n </DataGridCell>\n </DataGridRow>\n </DataGrid>\n )\n }\n\n return (\n <div className=\"relative\">\n <Button variant=\"primary\" label={t`Create Certificate Authority`} onClick={toggleCreateCa} />\n <DataGrid columns={columns.length}>\n <DataGridRow>\n {columns.map((label) => (\n <DataGridHeadCell key={label}>{label}</DataGridHeadCell>\n ))}\n </DataGridRow>\n {pcas.map((pca) => (\n <PcaTableRow key={pca.id} pca={pca} />\n ))}\n </DataGrid>\n\n {createCaOpen && <CreatePcaModal open={createCaOpen} onClose={toggleCreateCa} />}\n </div>\n )\n}\n","import { createFileRoute } from \"@tanstack/react-router\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { ContentHeader } from \"@/client/components/ContentHeader/ContentHeader\"\nimport { PcaListContainer } from \"./-components/PcaListContainer\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/services/pca/\")({\n staticData: { section: \"services\", service: \"pca\" } satisfies RouteInfo,\n component: RouteComponent,\n})\n\nfunction RouteComponent() {\n const { t } = useLingui()\n const { projectId } = Route.useParams()\n const { setPageTitle } = Route.useRouteContext()\n\n setPageTitle(t`PCA`)\n\n return (\n <>\n <ContentHeader title={t`PCA`} projectId={projectId} />\n <PcaListContainer />\n </>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,144 @@
1
+ import { E as e, I as t, N as n, at as r, g as i, k as a, l as o, q as s, w as c } from "./build-eu9eg0zF.mjs";
2
+ import { t as l } from "./projects-_Dfn6eQT.mjs";
3
+ import { Fragment as u, jsx as d, jsxs as f } from "react/jsx-runtime";
4
+ import { useEffect as p, useRef as m, useState as h } from "react";
5
+ import { Link as g } from "@tanstack/react-router";
6
+ import { Trans as _, useLingui as v } from "@lingui/react";
7
+ //#region src/client/routes/_auth/projects/-components/ProjectOverviewNavBar.tsx
8
+ function y({ viewMode: e, setViewMode: t, onSearch: n, searchTerm: a = "" }) {
9
+ let { i18n: c, _: l } = v(), g = m(null), _ = m(!1), [y, b] = h(a);
10
+ return p(() => {
11
+ !_.current && !g.current && a !== y && b(a);
12
+ }, [a]), p(() => () => {
13
+ g.current && clearTimeout(g.current);
14
+ }, []), /* @__PURE__ */ d(u, { children: /* @__PURE__ */ d(s, {
15
+ alignment: "center",
16
+ gap: "8",
17
+ className: "my-px mt-4 px-4",
18
+ children: /* @__PURE__ */ d(s, {
19
+ direction: "vertical",
20
+ gap: "3",
21
+ className: "w-full",
22
+ children: /* @__PURE__ */ f(s, {
23
+ gap: "6",
24
+ className: "flex w-full flex-wrap",
25
+ children: [/* @__PURE__ */ d(r, {
26
+ className: "shrink-0 grow basis-0",
27
+ type: "text",
28
+ placeholder: c._({ id: "YIix5Y" }),
29
+ onChange: (e) => {
30
+ let t = e.target.value;
31
+ b(t), g.current && clearTimeout(g.current), g.current = setTimeout(() => {
32
+ g.current = null, n(t);
33
+ }, 300);
34
+ },
35
+ onFocus: () => {
36
+ _.current = !0;
37
+ },
38
+ onBlur: () => {
39
+ _.current = !1;
40
+ },
41
+ onClear: () => {
42
+ g.current &&= (clearTimeout(g.current), null), b(""), n("");
43
+ },
44
+ value: y
45
+ }), /* @__PURE__ */ f(o, { children: [/* @__PURE__ */ d(i, {
46
+ variant: e === "list" ? "default" : "subdued",
47
+ onClick: () => t("list"),
48
+ icon: "dns"
49
+ }), /* @__PURE__ */ d(i, {
50
+ variant: e === "card" ? "default" : "subdued",
51
+ onClick: () => t("card"),
52
+ icon: "autoAwesomeMotion"
53
+ })] })]
54
+ })
55
+ })
56
+ }) });
57
+ }
58
+ //#endregion
59
+ //#region src/client/routes/_auth/projects/-components/ProjectCardView.tsx
60
+ function b({ project: t }) {
61
+ return /* @__PURE__ */ d(g, {
62
+ to: "/projects/$projectId",
63
+ params: { projectId: t.id },
64
+ className: "block text-inherit no-underline",
65
+ children: /* @__PURE__ */ d(e, {
66
+ className: "hover:bg-theme-background-lvl-2 min-h-50 rounded-lg p-6 shadow-md",
67
+ children: /* @__PURE__ */ f("div", {
68
+ className: "w-full",
69
+ children: [/* @__PURE__ */ d(c, {
70
+ className: "text-theme-accent",
71
+ children: t.name
72
+ }), /* @__PURE__ */ d("p", {
73
+ className: "mt-4 line-clamp-3 pr-4 leading-relaxed",
74
+ children: t.description
75
+ })]
76
+ })
77
+ })
78
+ });
79
+ }
80
+ function x({ projects: e }) {
81
+ return /* @__PURE__ */ d("div", {
82
+ className: "mx-auto h-full w-full max-w-[95vw] px-4",
83
+ children: /* @__PURE__ */ d("div", {
84
+ className: "grid grid-cols-1 gap-6 sm:grid-cols-2 lg:grid-cols-3",
85
+ children: e?.length ? e.map((e) => /* @__PURE__ */ d(b, { project: e }, e.id)) : /* @__PURE__ */ d("p", {
86
+ className: "text-center",
87
+ children: /* @__PURE__ */ d(_, { id: "Zgp2Sm" })
88
+ })
89
+ })
90
+ });
91
+ }
92
+ //#endregion
93
+ //#region src/client/routes/_auth/projects/-components/ProjectListView.tsx
94
+ function S({ projects: e }) {
95
+ return /* @__PURE__ */ d(a, {
96
+ className: "overflow-hidden",
97
+ columns: 2,
98
+ children: e?.length ? e.map((e) => /* @__PURE__ */ f(t, { children: [/* @__PURE__ */ d(n, { children: /* @__PURE__ */ d(g, {
99
+ to: "/projects/$projectId",
100
+ params: { projectId: e.id },
101
+ className: "text-inherit no-underline",
102
+ children: e.name
103
+ }) }), /* @__PURE__ */ d(n, { children: e.description })] }, e.id)) : /* @__PURE__ */ d("div", {
104
+ className: "py-6 text-center",
105
+ children: /* @__PURE__ */ d(_, { id: "i30J2U" })
106
+ })
107
+ });
108
+ }
109
+ //#endregion
110
+ //#region src/client/routes/_auth/projects/index.tsx?tsr-split=component
111
+ function C() {
112
+ let [e, t] = h("card"), { projects: n } = l.useLoaderData(), { search: r = "" } = l.useSearch(), i = l.useNavigate();
113
+ return /* @__PURE__ */ d("div", { children: /* @__PURE__ */ d("div", {
114
+ className: "mx-auto h-full w-full max-w-full p-4 lg:w-3/4 xl:w-2/3 2xl:w-5/8",
115
+ children: /* @__PURE__ */ f("div", {
116
+ className: "mx-auto w-full",
117
+ children: [
118
+ /* @__PURE__ */ d(c, {
119
+ className: "px-4 pt-4",
120
+ children: /* @__PURE__ */ d(_, { id: "+0B+ue" })
121
+ }),
122
+ /* @__PURE__ */ d(y, {
123
+ viewMode: e,
124
+ setViewMode: t,
125
+ searchTerm: r,
126
+ onSearch: (e) => {
127
+ i({
128
+ search: { search: e },
129
+ replace: !0
130
+ });
131
+ }
132
+ }),
133
+ /* @__PURE__ */ d("div", {
134
+ className: "w-full pt-5",
135
+ children: d(e === "list" ? S : x, { projects: n })
136
+ })
137
+ ]
138
+ })
139
+ }) });
140
+ }
141
+ //#endregion
142
+ export { C as component };
143
+
144
+ //# sourceMappingURL=projects-BuN69cxO.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projects-BuN69cxO.mjs","names":["useEffect","useRef","useState","Button","InputGroup","SearchInput","Stack","ProjectsOverviewNavBar","viewMode","setViewMode","onSearch","searchTerm","useLingui","timerRef","inputFocusedRef","inputValue","setInputValue","current","clearTimeout","handleSearchChange","e","value","target","setTimeout","handleClear","alignment","gap","className","direction","type","placeholder","t","onChange","onFocus","onBlur","onClear","variant","onClick","icon","Link","Box","ContentHeading","ProjectCard","project","to","params","projectId","id","className","div","name","p","description","ProjectCardView","projects","length","map","DataGrid","DataGridCell","DataGridRow","Link","ProjectListView","projects","className","columns","length","map","project","to","params","projectId","id","name","description","div","useState","ProjectsOverviewNavBar","ViewMode","ProjectCardView","ProjectListView","ContentHeading","Trans","Route","ProjectsOverview","viewMode","setViewMode","projects","useLoaderData","search","useSearch","navigate","useNavigate","handleSearch","value","replace","component"],"sources":["../../src/client/routes/_auth/projects/-components/ProjectOverviewNavBar.tsx","../../src/client/routes/_auth/projects/-components/ProjectCardView.tsx","../../src/client/routes/_auth/projects/-components/ProjectListView.tsx","../../src/client/routes/_auth/projects/index.tsx?tsr-split=component"],"sourcesContent":["import { ChangeEvent, useEffect, useRef, useState } from \"react\"\nimport { Button, InputGroup, SearchInput, Stack } from \"@cloudoperators/juno-ui-components\"\nimport { useLingui } from \"@lingui/react/macro\"\nexport type ViewMode = \"list\" | \"card\"\n\ntype ProjectsOverviewNavBarProps = {\n viewMode: ViewMode\n setViewMode: (mode: ViewMode) => void\n searchPlaceholder?: string\n filters?: { label: string; value: string }[]\n searchTerm?: string\n onSearch: (value: string) => void\n}\n\nexport function ProjectsOverviewNavBar({\n viewMode,\n setViewMode,\n onSearch,\n searchTerm = \"\",\n}: ProjectsOverviewNavBarProps) {\n const { t } = useLingui()\n const timerRef = useRef<NodeJS.Timeout | null>(null)\n const inputFocusedRef = useRef(false)\n const [inputValue, setInputValue] = useState(searchTerm)\n\n // Sync from URL (e.g. back/forward navigation) only when user isn't actively editing\n useEffect(() => {\n if (!inputFocusedRef.current && !timerRef.current && searchTerm !== inputValue) {\n setInputValue(searchTerm)\n }\n }, [searchTerm])\n\n useEffect(() => {\n return () => {\n if (timerRef.current) {\n clearTimeout(timerRef.current)\n }\n }\n }, [])\n\n const handleSearchChange = (e: ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value\n setInputValue(value)\n\n if (timerRef.current) {\n clearTimeout(timerRef.current)\n }\n\n timerRef.current = setTimeout(() => {\n timerRef.current = null\n onSearch(value)\n }, 300)\n }\n\n const handleClear = () => {\n if (timerRef.current) {\n clearTimeout(timerRef.current)\n timerRef.current = null\n }\n setInputValue(\"\")\n onSearch(\"\")\n }\n\n return (\n <>\n <Stack alignment=\"center\" gap=\"8\" className=\"my-px mt-4 px-4\">\n <Stack direction=\"vertical\" gap=\"3\" className=\"w-full\">\n <Stack gap=\"6\" className=\"flex w-full flex-wrap\">\n <SearchInput\n className=\"shrink-0 grow basis-0\"\n type=\"text\"\n placeholder={t`Search...`}\n onChange={handleSearchChange}\n onFocus={() => {\n inputFocusedRef.current = true\n }}\n onBlur={() => {\n inputFocusedRef.current = false\n }}\n onClear={handleClear}\n value={inputValue}\n />\n\n <InputGroup>\n <Button\n variant={viewMode === \"list\" ? \"default\" : \"subdued\"}\n onClick={() => setViewMode(\"list\")}\n icon=\"dns\"\n />\n\n <Button\n variant={viewMode === \"card\" ? \"default\" : \"subdued\"}\n onClick={() => setViewMode(\"card\")}\n icon=\"autoAwesomeMotion\"\n />\n </InputGroup>\n </Stack>\n </Stack>\n </Stack>\n </>\n )\n}\n","import { Link } from \"@tanstack/react-router\"\nimport { Project } from \"@/server/Project/types/models\"\nimport { Box, ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\n\ntype ProjectCardProps = {\n project: Project\n}\ntype ProjectCardViewProps = {\n projects: Project[] | undefined\n}\n\nexport function ProjectCard({ project }: ProjectCardProps) {\n return (\n <Link to=\"/projects/$projectId\" params={{ projectId: project.id }} className=\"block text-inherit no-underline\">\n <Box className=\"hover:bg-theme-background-lvl-2 min-h-50 rounded-lg p-6 shadow-md\">\n <div className=\"w-full\">\n <ContentHeading className=\"text-theme-accent\">{project.name}</ContentHeading>\n\n <p className=\"mt-4 line-clamp-3 pr-4 leading-relaxed\">{project.description}</p>\n </div>\n </Box>\n </Link>\n )\n}\nexport function ProjectCardView({ projects }: ProjectCardViewProps) {\n return (\n <div className=\"mx-auto h-full w-full max-w-[95vw] px-4\">\n {/* Adaptive Grid: max 3 columns, adjusts on smaller screens */}\n <div className=\"grid grid-cols-1 gap-6 sm:grid-cols-2 lg:grid-cols-3\">\n {projects?.length ? (\n projects.map((project) => <ProjectCard key={project.id} project={project} />)\n ) : (\n <p className=\"text-center\">\n <Trans>No projects available.</Trans>\n </p>\n )}\n </div>\n </div>\n )\n}\n","import { Project } from \"@/server/Project/types/models\"\nimport { DataGrid, DataGridCell, DataGridRow } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\nimport { Link } from \"@tanstack/react-router\"\n\ntype ProjectListViewProps = {\n projects: Project[] | undefined\n}\n\nexport function ProjectListView({ projects }: ProjectListViewProps) {\n return (\n <DataGrid className=\"overflow-hidden\" columns={2}>\n {projects?.length ? (\n projects.map((project) => {\n return (\n <DataGridRow key={project.id}>\n <DataGridCell>\n <Link\n to=\"/projects/$projectId\"\n params={{ projectId: project.id }}\n className=\"text-inherit no-underline\"\n >\n {project.name}\n </Link>\n </DataGridCell>\n <DataGridCell>{project.description}</DataGridCell>\n </DataGridRow>\n )\n })\n ) : (\n <div className=\"py-6 text-center\">\n <Trans>No projects found</Trans>\n </div>\n )}\n </DataGrid>\n )\n}\n","import { createFileRoute } from \"@tanstack/react-router\"\nimport { useState } from \"react\"\nimport { ProjectsOverviewNavBar, ViewMode } from \"@/client/routes/_auth/projects/-components/ProjectOverviewNavBar\"\nimport { ProjectCardView } from \"@/client/routes/_auth/projects/-components/ProjectCardView\"\nimport { ProjectListView } from \"@/client/routes/_auth/projects/-components/ProjectListView\"\nimport { RouteError } from \"@/client/components/Error/RouteError\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\n\nimport { z } from \"zod\"\n\nconst searchSchema = z.object({\n search: z.string().optional(),\n})\n\nexport const Route = createFileRoute(\"/_auth/projects/\")({\n component: ProjectsOverview,\n errorComponent: ({ error }) => (\n <RouteError error={error} safeErrorMessage={error instanceof TRPCClientError ? error.message : undefined} />\n ),\n notFoundComponent: () => {\n return <p>Projects not found</p>\n },\n\n validateSearch: searchSchema,\n\n loaderDeps: ({ search }) => ({\n search: search.search || \"\",\n }),\n\n loader: async ({ context, deps }) => {\n const allProjects = await context.trpcClient?.project.getAuthProjects.query()\n\n // Filter projects based on search term\n let projects = allProjects\n if (deps.search && deps.search.trim() !== \"\") {\n const searchTermLower = deps.search.toLowerCase()\n projects = allProjects?.filter(\n (project) =>\n project.name?.toLowerCase().includes(searchTermLower) ||\n project.description?.toLowerCase().includes(searchTermLower)\n )\n }\n\n return {\n projects,\n }\n },\n})\n\nfunction ProjectsOverview() {\n const [viewMode, setViewMode] = useState<ViewMode>(\"card\")\n const { projects } = Route.useLoaderData()\n const { search = \"\" } = Route.useSearch()\n const navigate = Route.useNavigate()\n\n const handleSearch = (value: string) => {\n navigate({\n search: { search: value },\n replace: true,\n })\n }\n\n return (\n <div>\n <div className=\"mx-auto h-full w-full max-w-full p-4 lg:w-3/4 xl:w-2/3 2xl:w-5/8\">\n <div className=\"mx-auto w-full\">\n <ContentHeading className=\"px-4 pt-4\">\n <Trans>Projects</Trans>\n </ContentHeading>\n <ProjectsOverviewNavBar\n viewMode={viewMode}\n setViewMode={setViewMode}\n searchTerm={search}\n onSearch={handleSearch}\n />\n <div className=\"w-full pt-5\">\n {viewMode === \"list\" ? <ProjectListView projects={projects} /> : <ProjectCardView projects={projects} />}\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { t as e } from "./RouteError-BwgDIwJE.mjs";
2
+ import { jsx as t } from "react/jsx-runtime";
3
+ import { TRPCClientError as n } from "@trpc/client";
4
+ //#region src/client/routes/_auth/projects/index.tsx?tsr-split=errorComponent
5
+ var r = ({ error: r }) => /* @__PURE__ */ t(e, {
6
+ error: r,
7
+ safeErrorMessage: r instanceof n ? r.message : void 0
8
+ });
9
+ //#endregion
10
+ export { r as errorComponent };
11
+
12
+ //# sourceMappingURL=projects-D1pP0XdA.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projects-D1pP0XdA.mjs","names":["RouteError","TRPCClientError","SplitErrorComponent","error","message","undefined","errorComponent"],"sources":["../../src/client/routes/_auth/projects/index.tsx?tsr-split=errorComponent"],"sourcesContent":["import { createFileRoute } from \"@tanstack/react-router\"\nimport { useState } from \"react\"\nimport { ProjectsOverviewNavBar, ViewMode } from \"@/client/routes/_auth/projects/-components/ProjectOverviewNavBar\"\nimport { ProjectCardView } from \"@/client/routes/_auth/projects/-components/ProjectCardView\"\nimport { ProjectListView } from \"@/client/routes/_auth/projects/-components/ProjectListView\"\nimport { RouteError } from \"@/client/components/Error/RouteError\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\n\nimport { z } from \"zod\"\n\nconst searchSchema = z.object({\n search: z.string().optional(),\n})\n\nexport const Route = createFileRoute(\"/_auth/projects/\")({\n component: ProjectsOverview,\n errorComponent: ({ error }) => (\n <RouteError error={error} safeErrorMessage={error instanceof TRPCClientError ? error.message : undefined} />\n ),\n notFoundComponent: () => {\n return <p>Projects not found</p>\n },\n\n validateSearch: searchSchema,\n\n loaderDeps: ({ search }) => ({\n search: search.search || \"\",\n }),\n\n loader: async ({ context, deps }) => {\n const allProjects = await context.trpcClient?.project.getAuthProjects.query()\n\n // Filter projects based on search term\n let projects = allProjects\n if (deps.search && deps.search.trim() !== \"\") {\n const searchTermLower = deps.search.toLowerCase()\n projects = allProjects?.filter(\n (project) =>\n project.name?.toLowerCase().includes(searchTermLower) ||\n project.description?.toLowerCase().includes(searchTermLower)\n )\n }\n\n return {\n projects,\n }\n },\n})\n\nfunction ProjectsOverview() {\n const [viewMode, setViewMode] = useState<ViewMode>(\"card\")\n const { projects } = Route.useLoaderData()\n const { search = \"\" } = Route.useSearch()\n const navigate = Route.useNavigate()\n\n const handleSearch = (value: string) => {\n navigate({\n search: { search: value },\n replace: true,\n })\n }\n\n return (\n <div>\n <div className=\"mx-auto h-full w-full max-w-full p-4 lg:w-3/4 xl:w-2/3 2xl:w-5/8\">\n <div className=\"mx-auto w-full\">\n <ContentHeading className=\"px-4 pt-4\">\n <Trans>Projects</Trans>\n </ContentHeading>\n <ProjectsOverviewNavBar\n viewMode={viewMode}\n setViewMode={setViewMode}\n searchTerm={search}\n onSearch={handleSearch}\n />\n <div className=\"w-full pt-5\">\n {viewMode === \"list\" ? <ProjectListView projects={projects} /> : <ProjectCardView projects={projects} />}\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":";;;;AAM8C,IAAAE,KAY3B,EAAEC,eACjB,kBAAC,GAAA;CAAkBA;CAAO,kBAAkBA,aAAiBF,IAAkBE,EAAMC,UAAUC,KAAAA"}
@@ -0,0 +1,7 @@
1
+ import { jsx as e } from "react/jsx-runtime";
2
+ //#region src/client/routes/_auth/projects/index.tsx?tsr-split=notFoundComponent
3
+ var t = () => /* @__PURE__ */ e("p", { children: "Projects not found" });
4
+ //#endregion
5
+ export { t as notFoundComponent };
6
+
7
+ //# sourceMappingURL=projects-MbS1USl2.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projects-MbS1USl2.mjs","names":["SplitNotFoundComponent","notFoundComponent"],"sources":["../../src/client/routes/_auth/projects/index.tsx?tsr-split=notFoundComponent"],"sourcesContent":["import { createFileRoute } from \"@tanstack/react-router\"\nimport { useState } from \"react\"\nimport { ProjectsOverviewNavBar, ViewMode } from \"@/client/routes/_auth/projects/-components/ProjectOverviewNavBar\"\nimport { ProjectCardView } from \"@/client/routes/_auth/projects/-components/ProjectCardView\"\nimport { ProjectListView } from \"@/client/routes/_auth/projects/-components/ProjectListView\"\nimport { RouteError } from \"@/client/components/Error/RouteError\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\n\nimport { z } from \"zod\"\n\nconst searchSchema = z.object({\n search: z.string().optional(),\n})\n\nexport const Route = createFileRoute(\"/_auth/projects/\")({\n component: ProjectsOverview,\n errorComponent: ({ error }) => (\n <RouteError error={error} safeErrorMessage={error instanceof TRPCClientError ? error.message : undefined} />\n ),\n notFoundComponent: () => {\n return <p>Projects not found</p>\n },\n\n validateSearch: searchSchema,\n\n loaderDeps: ({ search }) => ({\n search: search.search || \"\",\n }),\n\n loader: async ({ context, deps }) => {\n const allProjects = await context.trpcClient?.project.getAuthProjects.query()\n\n // Filter projects based on search term\n let projects = allProjects\n if (deps.search && deps.search.trim() !== \"\") {\n const searchTermLower = deps.search.toLowerCase()\n projects = allProjects?.filter(\n (project) =>\n project.name?.toLowerCase().includes(searchTermLower) ||\n project.description?.toLowerCase().includes(searchTermLower)\n )\n }\n\n return {\n projects,\n }\n },\n})\n\nfunction ProjectsOverview() {\n const [viewMode, setViewMode] = useState<ViewMode>(\"card\")\n const { projects } = Route.useLoaderData()\n const { search = \"\" } = Route.useSearch()\n const navigate = Route.useNavigate()\n\n const handleSearch = (value: string) => {\n navigate({\n search: { search: value },\n replace: true,\n })\n }\n\n return (\n <div>\n <div className=\"mx-auto h-full w-full max-w-full p-4 lg:w-3/4 xl:w-2/3 2xl:w-5/8\">\n <div className=\"mx-auto w-full\">\n <ContentHeading className=\"px-4 pt-4\">\n <Trans>Projects</Trans>\n </ContentHeading>\n <ProjectsOverviewNavBar\n viewMode={viewMode}\n setViewMode={setViewMode}\n searchTerm={search}\n onSearch={handleSearch}\n />\n <div className=\"w-full pt-5\">\n {viewMode === \"list\" ? <ProjectListView projects={projects} /> : <ProjectCardView projects={projects} />}\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":";;cAsBW,kBAAC,KAAA,EAAA,UAAE,sBAAA,CAAA"}
@@ -0,0 +1,22 @@
1
+ import { createFileRoute as e, lazyRouteComponent as t } from "@tanstack/react-router";
2
+ import { z as n } from "zod";
3
+ //#region src/client/routes/_auth/projects/index.tsx
4
+ var r = () => import("./projects-MbS1USl2.mjs"), i = () => import("./projects-D1pP0XdA.mjs"), a = () => import("./projects-BuN69cxO.mjs"), o = n.object({ search: n.string().optional() }), s = e("/_auth/projects/")({
5
+ component: t(a, "component"),
6
+ errorComponent: t(i, "errorComponent"),
7
+ notFoundComponent: t(r, "notFoundComponent"),
8
+ validateSearch: o,
9
+ loaderDeps: ({ search: e }) => ({ search: e.search || "" }),
10
+ loader: async ({ context: e, deps: t }) => {
11
+ let n = await e.trpcClient?.project.getAuthProjects.query(), r = n;
12
+ if (t.search && t.search.trim() !== "") {
13
+ let e = t.search.toLowerCase();
14
+ r = n?.filter((t) => t.name?.toLowerCase().includes(e) || t.description?.toLowerCase().includes(e));
15
+ }
16
+ return { projects: r };
17
+ }
18
+ });
19
+ //#endregion
20
+ export { s as t };
21
+
22
+ //# sourceMappingURL=projects-_Dfn6eQT.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"projects-_Dfn6eQT.mjs","names":["createFileRoute","z","searchSchema","object","search","string","optional","Route","component","lazyRouteComponent","$$splitComponentImporter","errorComponent","$$splitErrorComponentImporter","notFoundComponent","$$splitNotFoundComponentImporter","validateSearch","loaderDeps","loader","context","deps","allProjects","trpcClient","project","getAuthProjects","query","projects","trim","searchTermLower","toLowerCase","filter","name","includes","description"],"sources":["../../src/client/routes/_auth/projects/index.tsx"],"sourcesContent":["import { createFileRoute } from \"@tanstack/react-router\"\nimport { useState } from \"react\"\nimport { ProjectsOverviewNavBar, ViewMode } from \"@/client/routes/_auth/projects/-components/ProjectOverviewNavBar\"\nimport { ProjectCardView } from \"@/client/routes/_auth/projects/-components/ProjectCardView\"\nimport { ProjectListView } from \"@/client/routes/_auth/projects/-components/ProjectListView\"\nimport { RouteError } from \"@/client/components/Error/RouteError\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { ContentHeading } from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\n\nimport { z } from \"zod\"\n\nconst searchSchema = z.object({\n search: z.string().optional(),\n})\n\nexport const Route = createFileRoute(\"/_auth/projects/\")({\n component: ProjectsOverview,\n errorComponent: ({ error }) => (\n <RouteError error={error} safeErrorMessage={error instanceof TRPCClientError ? error.message : undefined} />\n ),\n notFoundComponent: () => {\n return <p>Projects not found</p>\n },\n\n validateSearch: searchSchema,\n\n loaderDeps: ({ search }) => ({\n search: search.search || \"\",\n }),\n\n loader: async ({ context, deps }) => {\n const allProjects = await context.trpcClient?.project.getAuthProjects.query()\n\n // Filter projects based on search term\n let projects = allProjects\n if (deps.search && deps.search.trim() !== \"\") {\n const searchTermLower = deps.search.toLowerCase()\n projects = allProjects?.filter(\n (project) =>\n project.name?.toLowerCase().includes(searchTermLower) ||\n project.description?.toLowerCase().includes(searchTermLower)\n )\n }\n\n return {\n projects,\n }\n },\n})\n\nfunction ProjectsOverview() {\n const [viewMode, setViewMode] = useState<ViewMode>(\"card\")\n const { projects } = Route.useLoaderData()\n const { search = \"\" } = Route.useSearch()\n const navigate = Route.useNavigate()\n\n const handleSearch = (value: string) => {\n navigate({\n search: { search: value },\n replace: true,\n })\n }\n\n return (\n <div>\n <div className=\"mx-auto h-full w-full max-w-full p-4 lg:w-3/4 xl:w-2/3 2xl:w-5/8\">\n <div className=\"mx-auto w-full\">\n <ContentHeading className=\"px-4 pt-4\">\n <Trans>Projects</Trans>\n </ContentHeading>\n <ProjectsOverviewNavBar\n viewMode={viewMode}\n setViewMode={setViewMode}\n searchTerm={search}\n onSearch={handleSearch}\n />\n <div className=\"w-full pt-5\">\n {viewMode === \"list\" ? <ProjectListView projects={projects} /> : <ProjectCardView projects={projects} />}\n </div>\n </div>\n </div>\n </div>\n )\n}\n"],"mappings":";;;2IAYME,IAAeD,EAAEE,OAAO,EAC5BC,QAAQH,EAAEI,QAAM,CAAGC,UAAQ,EAC7B,CAAA,EAEaC,IAAQP,EAAgB,mBAAA,CAAoB;CACvDQ,WAASC,EAAAC,GAAA,YAAA;CACTC,gBAAcF,EAAAG,GAAA,iBAAA;CAGdC,mBAAiBJ,EAAAK,GAAA,oBAAA;CAIjBC,gBAAgBb;CAEhBc,aAAa,EAAEZ,iBAAc,EAC3BA,QAAQA,EAAOA,UAAU,IAC3B;CAEAa,QAAQ,OAAO,EAAEC,YAASC,cAAM;EAC9B,IAAMC,IAAc,MAAMF,EAAQG,YAAYC,QAAQC,gBAAgBC,OAAAA,EAGlEC,IAAWL;AACf,MAAID,EAAKf,UAAUe,EAAKf,OAAOsB,MAAI,KAAO,IAAI;GAC5C,IAAMC,IAAkBR,EAAKf,OAAOwB,aAAW;AAC/CH,OAAWL,GAAaS,QACrBP,MACCA,EAAQQ,MAAMF,aAAAA,CAAcG,SAASJ,EAAAA,IACrCL,EAAQU,aAAaJ,aAAAA,CAAcG,SAASJ,EAAAA,CAAAA;;AAIlD,SAAO,EACLF,aACF;;CAEJ,CAAA"}
@@ -0,0 +1,12 @@
1
+ import { createFileRoute as e, lazyRouteComponent as t } from "@tanstack/react-router";
2
+ var n = e("/_auth/projects/$projectId/network/securitygroups/")({
3
+ staticData: {
4
+ section: "network",
5
+ service: "securitygroups"
6
+ },
7
+ component: t(() => import("./securitygroups-KC2qvmH8.mjs"), "component")
8
+ });
9
+ //#endregion
10
+ export { n as t };
11
+
12
+ //# sourceMappingURL=securitygroups-DURjFfYK.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"securitygroups-DURjFfYK.mjs","names":["createFileRoute","Route","staticData","section","service","RouteInfo","component","lazyRouteComponent","$$splitComponentImporter"],"sources":["../../src/client/routes/_auth/projects/$projectId/network/securitygroups/index.tsx"],"sourcesContent":["import { createFileRoute } from \"@tanstack/react-router\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport { SecurityGroups } from \"./-components/SecurityGroupsList\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { ContentHeading } from \"@cloudoperators/juno-ui-components\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/network/securitygroups/\")({\n staticData: { section: \"network\", service: \"securitygroups\" } satisfies RouteInfo,\n component: RouteComponent,\n})\n\nfunction RouteComponent() {\n const { t } = useLingui()\n const { setPageTitle } = Route.useRouteContext()\n setPageTitle(t`Security Groups`)\n return (\n <>\n <ContentHeading>{t`Security Groups`}</ContentHeading>\n <SecurityGroups />\n </>\n )\n}\n"],"mappings":";AAMA,IAAaC,IAAQD,EAAgB,qDAAA,CAAsD;CACzFE,YAAY;EAAEC,SAAS;EAAWC,SAAS;EAAiB;CAC5DE,WAASC,iDAAA,YAAA;CACX,CAAA"}