@cobaltcore-dev/aurora 0.6.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +160 -20
- package/dist/client/AuroraApp.d.ts +38 -0
- package/dist/client/{ContentHeader-kx1Th5Sq.mjs → ContentHeader-DqsGNvtD.mjs} +17 -17
- package/dist/client/{ContentHeader-kx1Th5Sq.mjs.map → ContentHeader-DqsGNvtD.mjs.map} +1 -1
- package/dist/client/{DeleteFlavorModal-C3cb7YiJ.mjs → DeleteFlavorModal-C3m7bQJu.mjs} +163 -163
- package/dist/client/{DeleteFlavorModal-C3cb7YiJ.mjs.map → DeleteFlavorModal-C3m7bQJu.mjs.map} +1 -1
- package/dist/client/{EditSecurityGroupModal-CpP54WIK.mjs → EditSecurityGroupModal-DKusxfta.mjs} +18 -18
- package/dist/client/{EditSecurityGroupModal-CpP54WIK.mjs.map → EditSecurityGroupModal-DKusxfta.mjs.map} +1 -1
- package/dist/client/{FiltersInput-DxcyR6Bp.mjs → FiltersInput-GzR4D0q6.mjs} +21 -21
- package/dist/client/{FiltersInput-DxcyR6Bp.mjs.map → FiltersInput-GzR4D0q6.mjs.map} +1 -1
- package/dist/client/{FloatingIpActionModals-BP8RWHbu.mjs → FloatingIpActionModals-CRvROJ3H.mjs} +51 -51
- package/dist/client/{FloatingIpActionModals-BP8RWHbu.mjs.map → FloatingIpActionModals-CRvROJ3H.mjs.map} +1 -1
- package/dist/client/{ImageToastNotifications-TZ3EfQg-.mjs → ImageToastNotifications-BuDXpTkl.mjs} +344 -344
- package/dist/client/{ImageToastNotifications-TZ3EfQg-.mjs.map → ImageToastNotifications-BuDXpTkl.mjs.map} +1 -1
- package/dist/client/{RouteError-QSV7qOoJ.mjs → RouteError-DVAiT0mT.mjs} +2 -2
- package/dist/client/{RouteError-QSV7qOoJ.mjs.map → RouteError-DVAiT0mT.mjs.map} +1 -1
- package/dist/client/{SortInput-CYv2_Pur.mjs → SortInput-VK7IYqQv.mjs} +6 -6
- package/dist/client/{SortInput-CYv2_Pur.mjs.map → SortInput-VK7IYqQv.mjs.map} +1 -1
- package/dist/client/_auth-DXJkv9QO.mjs.map +1 -1
- package/dist/client/{_flavorId-C2x43-6S.mjs → _flavorId-B9Vqkraj.mjs} +8 -8
- package/dist/client/{_flavorId-C2x43-6S.mjs.map → _flavorId-B9Vqkraj.mjs.map} +1 -1
- package/dist/client/{_flavorId-CR8ZUI-P.mjs → _flavorId-CFpNGz52.mjs} +62 -62
- package/dist/client/{_flavorId-CR8ZUI-P.mjs.map → _flavorId-CFpNGz52.mjs.map} +1 -1
- package/dist/client/{_floatingIpId-BCk41_Lb.mjs → _floatingIpId-B5GMSLeQ.mjs} +2 -2
- package/dist/client/{_floatingIpId-BCk41_Lb.mjs.map → _floatingIpId-B5GMSLeQ.mjs.map} +1 -1
- package/dist/client/{_floatingIpId-BGrOAmPT.mjs → _floatingIpId-C2-BeRmF.mjs} +27 -27
- package/dist/client/{_floatingIpId-BGrOAmPT.mjs.map → _floatingIpId-C2-BeRmF.mjs.map} +1 -1
- package/dist/client/_imageId-9NZytfNs.mjs +534 -0
- package/dist/client/{_imageId-CvfD832b.mjs.map → _imageId-9NZytfNs.mjs.map} +1 -1
- package/dist/client/_pcaId-BwTvJJgh.mjs +479 -0
- package/dist/client/_pcaId-BwTvJJgh.mjs.map +1 -0
- package/dist/client/{_pcaId-DOHycvCf.mjs → _pcaId-DUHQd0rB.mjs} +2 -2
- package/dist/client/{_pcaId-DOHycvCf.mjs.map → _pcaId-DUHQd0rB.mjs.map} +1 -1
- package/dist/client/{_projectId-DOgwFiqD.mjs → _projectId-B_2sZKk-.mjs} +2 -2
- package/dist/client/{_projectId-DOgwFiqD.mjs.map → _projectId-B_2sZKk-.mjs.map} +1 -1
- package/dist/client/{_projectId-MxcHrXW4.mjs → _projectId-CLgClx24.mjs} +3 -3
- package/dist/client/{_projectId-MxcHrXW4.mjs.map → _projectId-CLgClx24.mjs.map} +1 -1
- package/dist/client/_projectId-cW9aQ4Ag.mjs +271 -0
- package/dist/client/_projectId-cW9aQ4Ag.mjs.map +1 -0
- package/dist/client/{_securityGroupId-KKw4RPdH.mjs → _securityGroupId-DYxmXUOP.mjs} +319 -319
- package/dist/client/{_securityGroupId-KKw4RPdH.mjs.map → _securityGroupId-DYxmXUOP.mjs.map} +1 -1
- package/dist/client/{_securityGroupId-CJJanWiY.mjs → _securityGroupId-fhK1CuZh.mjs} +2 -2
- package/dist/client/{_securityGroupId-CJJanWiY.mjs.map → _securityGroupId-fhK1CuZh.mjs.map} +1 -1
- package/dist/client/{_storageType-DYjo-6ej.mjs → _storageType-2_fau4B5.mjs} +698 -698
- package/dist/client/{_storageType-DYjo-6ej.mjs.map → _storageType-2_fau4B5.mjs.map} +1 -1
- package/dist/client/{_storageType-4wSxI__0.mjs → _storageType-dRTFMKG3.mjs} +2 -2
- package/dist/client/{_storageType-4wSxI__0.mjs.map → _storageType-dRTFMKG3.mjs.map} +1 -1
- package/dist/client/{about-Bo9vxGHy.mjs → about-Nsxkyh9U.mjs} +2 -2
- package/dist/client/{about-Bo9vxGHy.mjs.map → about-Nsxkyh9U.mjs.map} +1 -1
- package/dist/client/{build-DeJcDjPi.mjs → build-BdRRmNf5.mjs} +3290 -3274
- package/dist/client/{build-DeJcDjPi.mjs.map → build-BdRRmNf5.mjs.map} +1 -1
- package/dist/client/{constants-BmcGYeR-.mjs → constants-J5nm9hbP.mjs} +15 -15
- package/dist/client/{constants-BmcGYeR-.mjs.map → constants-J5nm9hbP.mjs.map} +1 -1
- package/dist/client/{flavors-BxFVqgnb.mjs → flavors-_P7R-CeT.mjs} +2 -2
- package/dist/client/{flavors-BxFVqgnb.mjs.map → flavors-_P7R-CeT.mjs.map} +1 -1
- package/dist/client/{flavors-CfdgjsZY.mjs → flavors-m1qDHzeS.mjs} +238 -221
- package/dist/client/flavors-m1qDHzeS.mjs.map +1 -0
- package/dist/client/{floatingips-ByRb82wS.mjs → floatingips-Dq4DXQYb.mjs} +90 -90
- package/dist/client/{floatingips-ByRb82wS.mjs.map → floatingips-Dq4DXQYb.mjs.map} +1 -1
- package/dist/client/{images-CenluYV8.mjs → images-CpM-T_jM.mjs} +2 -2
- package/dist/client/{images-CenluYV8.mjs.map → images-CpM-T_jM.mjs.map} +1 -1
- package/dist/client/images-DHmVgQAh2.mjs +1890 -0
- package/dist/client/images-DHmVgQAh2.mjs.map +1 -0
- package/dist/client/{images-C_dX7nY6.mjs → images-Dbjo4yKn.mjs} +2 -2
- package/dist/client/{images-C_dX7nY6.mjs.map → images-Dbjo4yKn.mjs.map} +1 -1
- package/dist/client/index.d.ts +1 -1
- package/dist/client/index.js +390 -356
- package/dist/client/index.js.map +1 -1
- package/dist/client/{objects-gxSjvbvF.mjs → objects-DKWp9RtR.mjs} +2 -2
- package/dist/client/{objects-gxSjvbvF.mjs.map → objects-DKWp9RtR.mjs.map} +1 -1
- package/dist/client/{objects-BJM6YeuF.mjs → objects-DaCuy_CB.mjs} +1156 -1156
- package/dist/client/{objects-BJM6YeuF.mjs.map → objects-DaCuy_CB.mjs.map} +1 -1
- package/dist/client/{pca-Bl8NmoVZ.mjs → pca-C8zWTSSt.mjs} +2 -2
- package/dist/client/{pca-Bl8NmoVZ.mjs.map → pca-C8zWTSSt.mjs.map} +1 -1
- package/dist/client/pca-CK5-j7Kk.mjs +202 -0
- package/dist/client/pca-CK5-j7Kk.mjs.map +1 -0
- package/dist/client/{projects-pe2_dCnV.mjs → projects-CHYn7L5e.mjs} +2 -2
- package/dist/client/{projects-pe2_dCnV.mjs.map → projects-CHYn7L5e.mjs.map} +1 -1
- package/dist/client/{projects-D2iewAzu.mjs → projects-CeLhtLvf.mjs} +2 -2
- package/dist/client/{projects-D2iewAzu.mjs.map → projects-CeLhtLvf.mjs.map} +1 -1
- package/dist/client/{projects-CgclWI16.mjs → projects-ClViaUuv.mjs} +11 -11
- package/dist/client/{projects-CgclWI16.mjs.map → projects-ClViaUuv.mjs.map} +1 -1
- package/dist/client/{_projectId-BDSWnMGj.mjs → routeInfo-DlDJZnpg.mjs} +34 -8
- package/dist/client/routeInfo-DlDJZnpg.mjs.map +1 -0
- package/dist/client/{securitygroups-DahZkVYQ.mjs → securitygroups-CNFLu9zS.mjs} +112 -112
- package/dist/client/{securitygroups-DahZkVYQ.mjs.map → securitygroups-CNFLu9zS.mjs.map} +1 -1
- package/dist/client/{useListWithFiltering-DaYcu5AB.mjs → useListWithFiltering-v2A0-SZb.mjs} +9 -9
- package/dist/client/{useListWithFiltering-DaYcu5AB.mjs.map → useListWithFiltering-v2A0-SZb.mjs.map} +1 -1
- package/dist/server/index.d.ts +576 -2
- package/dist/server/index.js +59 -217
- package/package.json +4 -5
- package/dist/client/_imageId-CvfD832b.mjs +0 -534
- package/dist/client/_pcaId-BxBt5DXi.mjs +0 -459
- package/dist/client/_pcaId-BxBt5DXi.mjs.map +0 -1
- package/dist/client/_projectId-BDSWnMGj.mjs.map +0 -1
- package/dist/client/_projectId-DS4nR59B.mjs +0 -299
- package/dist/client/_projectId-DS4nR59B.mjs.map +0 -1
- package/dist/client/flavors-CfdgjsZY.mjs.map +0 -1
- package/dist/client/images-CKqIXUq52.mjs +0 -1873
- package/dist/client/images-CKqIXUq52.mjs.map +0 -1
- package/dist/client/pca-RSiWpJs9.mjs +0 -182
- package/dist/client/pca-RSiWpJs9.mjs.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flavors-m1qDHzeS.mjs","names":["DataGrid","DataGridHeadCell","DataGridRow","DataGridCell","ContentHeading","PopupMenu","PopupMenuOptions","PopupMenuItem","Spinner","Stack","Pagination","DeleteFlavorModal","useEffect","useState","EditSpecModal","ManageAccessModal","useParams","useNavigate","FlavorListContainer","flavors","isLoading","client","project","onFlavorDeleted","canDeleteFlavor","canMangageAccess","canManageSpecs","canListSpecs","currentPage","totalPages","onPageChange","useLingui","navigate","deleteModalOpen","setDeleteModalOpen","specModalOpen","setSpecModalOpen","accessModalOpen","setAccessModalOpen","selectedFlavor","setSelectedFlavor","inputPage","setInputPage","toString","projectId","from","openDeleteModal","flavor","openSpecModal","openAccessModal","closeDeleteModal","handleDeleteSuccess","name","updateCurrentPage","newPage","div","data-testid","colSpan","distribution","alignment","variant","length","columns","className","p","minContentColumns","map","id","onClick","to","params","flavorId","vcpus","ram","disk","swap","t","e","stopPropagation","label","disabled","pages","onPressPrevious","Math","max","onPressNext","min","onSelectChange","selectedPage","onInputChange","newInputPage","undefined","String","onKeyDown","key","parseInt","isNaN","isOpen","onClose","onSuccess","canEdit","validateField","field","value","t","undefined","idStr","String","trim","idRegex","test","msg","nameStr","length","vcpus","Number","isNaN","ram","disk","swap","rxtx","str","ephemeral","cleanFlavorData","flavor","result","name","isValidValue","isValidNumber","id","description","rxtx_factor","Boolean","React","useState","Modal","Form","FormRow","FormSection","TextInput","Message","Spinner","Stack","Checkbox","validateField","cleanFlavorData","useErrorTranslation","CreateFlavorModal","client","isOpen","onClose","project","onSuccess","useLingui","translateError","newFlavor","setNewFlavor","errors","setErrors","isLoading","setIsLoading","generalError","setGeneralError","handleInputChange","e","name","value","type","checked","target","prev","newState","handleNumericInputChange","handleBlur","error","handleSubmit","preventDefault","newErrors","requiredFields","forEach","key","optionalFields","undefined","Object","keys","length","t","flavorData","compute","createFlavor","mutate","project_id","flavor","handleClose","errorMessage","message","dismissError","onCancel","size","title","open","onConfirm","cancelButtonLabel","confirmButtonLabel","distribution","alignment","variant","onDismiss","text","id","label","onChange","onBlur","errortext","required","description","String","vcpus","Number","ram","disk","swap","defaultValue","rxtx_factor","helptext","use","Suspense","useState","useRef","startTransition","useEffect","useCallback","ErrorBoundary","useSearch","useNavigate","TRPCClientError","Message","Button","Stack","Spinner","DataGridToolbar","SearchInput","SortInput","FlavorListContainer","CreateFlavorModal","PAGE_SIZE","createFlavorsPromise","client","project","sortBy","sortDirection","searchTerm","compute","getFlavorsByProjectId","query","project_id","then","res","listError","undefined","catch","err","data","code","flavors","privateFlavorError","message","createPermissionsPromise","canUser","permission","canCreate","canDelete","canManageAccess","canCreateSpecs","canDeleteSpecs","canListSpecs","canManageSpecs","FlavorsContent","flavorsPromise","permissionsPromise","onFlavorDeleted","onFlavorCreated","setSearchTerm","sortSettings","handleSortChange","createModalOpen","setCreateModalOpen","currentPage","onPageChange","useLingui","permissions","localSearchTerm","setLocalSearchTerm","debounceTimer","clearTimeout","current","p","totalPages","Math","max","ceil","length","safePage","min","paginatedFlavors","slice","isOpen","onClose","onSuccess","className","text","t","variant","distribution","alignment","gap","options","onSortByChange","v","onSortDirectionChange","dir","label","onClick","placeholder","data-testid","value","onInput","e","currentTarget","window","setTimeout","onSearch","onClear","isLoading","canDeleteFlavor","canMangageAccess","Flavors","navigate","searchParams","strict","setSortSettings","search","page","success","setSuccess","setFlavorsPromise","refetchFlavors","handleFlavorDeleted","flavorName","timestamp","Date","now","handleFlavorCreated","newSortSettings","settings","toString","prev","replace","handleSearchChange","term","searchValue","handlePageChange","div","onDismiss","dismissible","fallbackRender","error","Error","fallback","direction","size","useLingui","Flavors","ContentHeader","Route","RouteComponent","t","projectId","useParams","trpcClient","useRouteContext","component"],"sources":["../../src/client/routes/_auth/projects/$projectId/compute/-components/Flavors/-components/FlavorListContainer.tsx","../../src/client/routes/_auth/projects/$projectId/compute/-components/Flavors/-components/flavorValidation.ts","../../src/client/routes/_auth/projects/$projectId/compute/-components/Flavors/-components/CreateFlavorModal.tsx","../../src/client/routes/_auth/projects/$projectId/compute/-components/Flavors/List.tsx","../../src/client/routes/_auth/projects/$projectId/compute/flavors/index.tsx?tsr-split=component"],"sourcesContent":["import { Flavor } from \"@/server/Compute/types/flavor\"\nimport {\n DataGrid,\n DataGridHeadCell,\n DataGridRow,\n DataGridCell,\n ContentHeading,\n PopupMenu,\n PopupMenuOptions,\n PopupMenuItem,\n Spinner,\n Stack,\n Pagination,\n} from \"@cloudoperators/juno-ui-components\"\nimport { Trans } from \"@lingui/react/macro\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport { DeleteFlavorModal } from \"./DeleteFlavorModal\"\nimport { useEffect, useState } from \"react\"\nimport { TrpcClient } from \"@/client/trpcClient\"\nimport { EditSpecModal } from \"./EditSpecModal\"\nimport { ManageAccessModal } from \"./ManageAccessModal\"\nimport { useParams, useNavigate } from \"@tanstack/react-router\"\n\ninterface FlavorListContainerProps {\n flavors?: Flavor[]\n isLoading: boolean\n client: TrpcClient\n project: string\n onFlavorDeleted?: (flavorName: string) => void\n canDeleteFlavor?: boolean\n canMangageAccess?: boolean\n canManageSpecs?: boolean\n canListSpecs?: boolean\n currentPage?: number\n totalPages?: number\n onPageChange?: (page: number) => void\n}\n\nexport const FlavorListContainer = ({\n flavors,\n isLoading,\n client,\n project,\n onFlavorDeleted,\n canDeleteFlavor,\n canMangageAccess,\n canManageSpecs,\n canListSpecs,\n currentPage = 1,\n totalPages = 1,\n onPageChange,\n}: FlavorListContainerProps) => {\n const { t } = useLingui()\n const navigate = useNavigate()\n const [deleteModalOpen, setDeleteModalOpen] = useState(false)\n const [specModalOpen, setSpecModalOpen] = useState(false)\n const [accessModalOpen, setAccessModalOpen] = useState(false)\n const [selectedFlavor, setSelectedFlavor] = useState<Flavor | null>(null)\n const [inputPage, setInputPage] = useState<string>(currentPage.toString())\n\n useEffect(() => {\n setInputPage(currentPage.toString())\n }, [currentPage])\n\n const { projectId } = useParams({\n from: \"/_auth/projects/$projectId/compute/flavors/\",\n })\n\n const openDeleteModal = (flavor: Flavor) => {\n setSelectedFlavor(flavor)\n setDeleteModalOpen(true)\n }\n\n const openSpecModal = (flavor: Flavor) => {\n setSelectedFlavor(flavor)\n setSpecModalOpen(true)\n }\n\n const openAccessModal = (flavor: Flavor) => {\n setSelectedFlavor(flavor)\n setAccessModalOpen(true)\n }\n\n const closeDeleteModal = () => {\n setDeleteModalOpen(false)\n setSelectedFlavor(null)\n }\n\n const handleDeleteSuccess = () => {\n if (selectedFlavor && onFlavorDeleted) {\n onFlavorDeleted(selectedFlavor.name || \"\")\n }\n closeDeleteModal()\n }\n\n const updateCurrentPage = (newPage: number) => {\n if (newPage >= 1 && newPage <= totalPages) {\n onPageChange?.(newPage)\n setInputPage(newPage.toString())\n }\n }\n\n if (isLoading) {\n return (\n <div data-testid=\"loading\">\n <div data-testid=\"loading\">\n <DataGridRow>\n <DataGridCell colSpan={3}>\n <Stack distribution=\"center\" alignment=\"center\">\n <Spinner variant=\"primary\" />\n <Trans>Loading...</Trans>\n </Stack>\n </DataGridCell>\n </DataGridRow>\n </div>\n </div>\n )\n }\n\n if (!flavors || flavors.length === 0) {\n return (\n <DataGrid columns={7} className=\"flavors\" data-testid=\"no-flavors\">\n <DataGridRow>\n <DataGridCell colSpan={7}>\n <ContentHeading>\n <Trans>No flavors found</Trans>\n </ContentHeading>\n <p>\n <Trans>\n There are no flavors available for this project with the current filters applied. Try adjusting your\n filter criteria or create a new flavor.\n </Trans>\n </p>\n </DataGridCell>\n </DataGridRow>\n </DataGrid>\n )\n }\n\n return (\n <>\n <DataGrid columns={7} minContentColumns={[6]} className=\"flavors\" data-testid=\"flavors-table\">\n <DataGridRow>\n <DataGridHeadCell>\n <Trans>Name</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell>\n <Trans>vCPU</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell>\n <Trans>RAM (MiB)</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell>\n <Trans>Root Disk (GiB)</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell>\n <Trans>Swap (MiB)</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell>\n <Trans>Access Type</Trans>\n </DataGridHeadCell>\n <DataGridHeadCell></DataGridHeadCell>\n </DataGridRow>\n\n {flavors.map((flavor) => (\n <DataGridRow\n key={flavor.id}\n data-testid={`flavor-row-${flavor.id}`}\n onClick={() =>\n navigate({\n to: \"/projects/$projectId/compute/flavors/$flavorId\",\n params: { projectId, flavorId: flavor.id },\n })\n }\n >\n <DataGridCell>{flavor.name || flavor.id}</DataGridCell>\n <DataGridCell>{flavor.vcpus || \"–\"}</DataGridCell>\n <DataGridCell>{flavor.ram || \"–\"}</DataGridCell>\n <DataGridCell>{flavor.disk || \"–\"}</DataGridCell>\n <DataGridCell>{flavor.swap || \"–\"}</DataGridCell>\n <DataGridCell>{flavor[\"os-flavor-access:is_public\"] === false ? t`Private` : t`Public`}</DataGridCell>\n <DataGridCell onClick={(e) => e.stopPropagation()}>\n <PopupMenu>\n <PopupMenuOptions>\n <PopupMenuItem\n label={t`Details`}\n onClick={() =>\n navigate({\n to: \"/projects/$projectId/compute/flavors/$flavorId\",\n params: { projectId, flavorId: flavor.id },\n })\n }\n />\n {(canManageSpecs || canListSpecs) && (\n <PopupMenuItem\n label={canManageSpecs ? t`Edit Metadata` : t`Metadata`}\n onClick={() => openSpecModal(flavor)}\n />\n )}\n {canMangageAccess && (\n <PopupMenuItem\n label={t`Manage Access`}\n onClick={() => openAccessModal(flavor)}\n disabled={flavor[\"os-flavor-access:is_public\"] !== false}\n />\n )}\n {canDeleteFlavor && (\n <PopupMenuItem label={t`Delete Flavor`} onClick={() => openDeleteModal(flavor)} />\n )}\n </PopupMenuOptions>\n </PopupMenu>\n </DataGridCell>\n </DataGridRow>\n ))}\n </DataGrid>\n {totalPages > 1 && (\n <div className=\"flex justify-center py-4\">\n <Pagination\n variant=\"input\"\n currentPage={currentPage}\n pages={totalPages}\n onPressPrevious={() => updateCurrentPage(Math.max(currentPage - 1, 1))}\n onPressNext={() => updateCurrentPage(Math.min(currentPage + 1, totalPages))}\n onSelectChange={(selectedPage: number) => {\n updateCurrentPage(selectedPage)\n }}\n onInputChange={(newInputPage?: number) => {\n setInputPage(newInputPage === undefined ? \"\" : String(newInputPage))\n }}\n onKeyDown={(e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === \"Enter\" && inputPage !== \"\") {\n const newPage = parseInt(inputPage, 10)\n if (!isNaN(newPage) && newPage >= 1 && newPage <= totalPages) {\n updateCurrentPage(newPage)\n }\n }\n }}\n />\n </div>\n )}\n <DeleteFlavorModal\n client={client}\n isOpen={deleteModalOpen}\n onClose={closeDeleteModal}\n project={project}\n flavor={selectedFlavor}\n onSuccess={handleDeleteSuccess}\n />\n <EditSpecModal\n client={client}\n isOpen={specModalOpen}\n onClose={() => setSpecModalOpen(false)}\n project={project}\n flavor={selectedFlavor}\n canEdit={canManageSpecs}\n />\n\n <ManageAccessModal\n client={client}\n isOpen={accessModalOpen}\n onClose={() => setAccessModalOpen(false)}\n project={project}\n flavor={selectedFlavor}\n />\n </>\n )\n}\n","import { msg } from \"@lingui/core/macro\"\nimport { MessageDescriptor } from \"@lingui/core\"\nimport { Flavor } from \"@/server/Compute/types/flavor\"\n\nexport const validateField = (\n field: FlavorFormField,\n value: string | number | boolean | null | undefined,\n t: (descriptor: MessageDescriptor) => string\n): string | undefined => {\n switch (field) {\n case \"id\":\n if (!value) return undefined\n {\n const idStr = String(value).trim()\n const idRegex = /^[a-zA-Z0-9.\\-_]*$/\n return idRegex.test(idStr)\n ? undefined\n : t(msg`ID must only contain alphanumeric characters, hyphens, underscores, and dots.`)\n }\n\n case \"name\": {\n const nameStr = String(value || \"\").trim()\n return nameStr.length >= 2 && nameStr.length <= 50 ? undefined : t(msg`Name must be 2-50 characters long.`)\n }\n\n case \"vcpus\": {\n const vcpus = Number(value)\n return !isNaN(vcpus) && vcpus >= 1 ? undefined : t(msg`VCPUs must be an integer ≥ 1.`)\n }\n\n case \"ram\": {\n const ram = Number(value)\n return !isNaN(ram) && ram >= 128 ? undefined : t(msg`RAM must be an integer ≥ 128 MB.`)\n }\n\n case \"disk\": {\n const disk = Number(value)\n return !isNaN(disk) && disk >= 0 ? undefined : t(msg`Root Disk must be an integer ≥ 0.`)\n }\n\n case \"swap\":\n if (value === \"\" || value === undefined || value === null) return undefined\n {\n const swap = Number(value)\n return !isNaN(swap) && swap >= 0 ? undefined : t(msg`Swap Disk must be an integer ≥ 0.`)\n }\n\n case \"rxtx_factor\": {\n const rxtx = Number(value)\n return !isNaN(rxtx) && rxtx >= 1 ? undefined : t(msg`RX/TX Factor must be an integer ≥ 1.`)\n }\n\n case \"description\":\n if (!value) return undefined\n {\n const str = String(value)\n return str.length < 65535 ? undefined : t(msg`Description must be less than 65535 characters.`)\n }\n\n case \"OS-FLV-EXT-DATA:ephemeral\": {\n const ephemeral = Number(value)\n return !isNaN(ephemeral) && ephemeral >= 0 ? undefined : t(msg`Ephemeral Disk must be an integer ≥ 0.`)\n }\n\n case \"os-flavor-access:is_public\": {\n if (value === undefined || value === null) {\n return undefined\n }\n if (typeof value === \"boolean\") {\n return undefined\n }\n if (typeof value === \"string\" && (value === \"true\" || value === \"false\")) {\n return undefined\n }\n return t(msg`Invalid value for public flavor setting.`)\n }\n\n default:\n return undefined\n }\n}\n\nexport type FlavorFormField =\n | \"id\"\n | \"name\"\n | \"vcpus\"\n | \"ram\"\n | \"disk\"\n | \"swap\"\n | \"description\"\n | \"rxtx_factor\"\n | \"OS-FLV-EXT-DATA:ephemeral\"\n | \"os-flavor-access:is_public\"\n\nexport interface FieldErrors {\n id?: string\n name?: string\n vcpus?: string\n ram?: string\n disk?: string\n swap?: string\n rxtx_factor?: string\n description?: string\n \"OS-FLV-EXT-DATA:ephemeral\"?: string\n \"os-flavor-access:is_public\"?: string\n}\n\nexport const cleanFlavorData = (flavor: Partial<Flavor>) => {\n const result: {\n name: string\n vcpus: number\n ram: number\n disk: number\n \"OS-FLV-EXT-DATA:ephemeral\"?: number\n id?: string\n swap?: number\n rxtx_factor?: number\n description?: string\n \"os-flavor-access:is_public\"?: boolean\n } = {\n name: String(flavor.name),\n vcpus: Number(flavor.vcpus),\n ram: Number(flavor.ram),\n disk: Number(flavor.disk),\n }\n\n const isValidValue = (value: string | undefined | null) => {\n return value !== undefined && value !== null && value !== \"\" && String(value).trim() !== \"\"\n }\n\n const isValidNumber = (value: string | number | undefined | null) => {\n return value !== undefined && value !== null && value !== \"\" && String(value).trim() !== \"\" && !isNaN(Number(value))\n }\n\n if (isValidValue(flavor.id)) {\n result.id = String(flavor.id).trim()\n }\n\n if (isValidValue(flavor.description)) {\n result.description = String(flavor.description).trim()\n }\n\n if (isValidNumber(flavor.swap)) {\n result.swap = Number(flavor.swap)\n }\n\n if (isValidNumber(flavor.rxtx_factor)) {\n result.rxtx_factor = Number(flavor.rxtx_factor)\n }\n\n if (isValidNumber(flavor[\"OS-FLV-EXT-DATA:ephemeral\"])) {\n result[\"OS-FLV-EXT-DATA:ephemeral\"] = Number(flavor[\"OS-FLV-EXT-DATA:ephemeral\"])\n }\n\n if (flavor[\"os-flavor-access:is_public\"] !== undefined) {\n result[\"os-flavor-access:is_public\"] = Boolean(flavor[\"os-flavor-access:is_public\"])\n }\n\n return result\n}\n","import React, { useState } from \"react\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport { TrpcClient } from \"@/client/trpcClient\"\nimport {\n Modal,\n Form,\n FormRow,\n FormSection,\n TextInput,\n Message,\n Spinner,\n Stack,\n Checkbox,\n} from \"@cloudoperators/juno-ui-components\"\nimport { Flavor } from \"@/server/Compute/types/flavor\"\nimport { validateField, FlavorFormField, FieldErrors } from \"./flavorValidation\"\nimport { cleanFlavorData } from \"./flavorValidation\"\nimport { useErrorTranslation } from \"@/client/utils/useErrorTranslation\"\n\ninterface CreateFlavorModalProps {\n client: TrpcClient\n isOpen: boolean\n onClose: () => void\n project: string\n onSuccess: (name: string) => void\n}\n\nexport const CreateFlavorModal: React.FC<CreateFlavorModalProps> = ({\n client,\n isOpen,\n onClose,\n project,\n onSuccess,\n}) => {\n const { t } = useLingui()\n const { translateError } = useErrorTranslation()\n const [newFlavor, setNewFlavor] = useState<Partial<Flavor>>({\n \"os-flavor-access:is_public\": true,\n })\n const [errors, setErrors] = useState<FieldErrors>({})\n const [isLoading, setIsLoading] = useState(false)\n const [generalError, setGeneralError] = useState<string | null>(null)\n\n const handleInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const { name, value, type, checked } = e.target\n\n setNewFlavor((prev) => {\n const newState = {\n ...prev,\n [name]: type === \"checkbox\" ? checked : value,\n }\n\n return newState\n })\n if (generalError) setGeneralError(null)\n }\n\n const handleNumericInputChange = (name: FlavorFormField, value: number | undefined) => {\n setNewFlavor((prev) => ({\n ...prev,\n [name]: value,\n }))\n if (generalError) setGeneralError(null)\n }\n\n const handleBlur = (e: React.FocusEvent<HTMLInputElement>) => {\n const { name, value } = e.target\n const error = validateField(name as FlavorFormField, value, t)\n setErrors((prev) => ({\n ...prev,\n [name]: error,\n }))\n }\n\n const handleSubmit = async (e: React.FormEvent) => {\n e.preventDefault()\n setGeneralError(null)\n\n const newErrors: FieldErrors = {}\n\n const requiredFields: FlavorFormField[] = [\"name\", \"vcpus\", \"ram\", \"disk\"]\n requiredFields.forEach((key) => {\n const error = validateField(key, newFlavor[key], t)\n if (error) {\n newErrors[key] = error\n }\n })\n\n const optionalFields: FlavorFormField[] = [\n \"id\",\n \"swap\",\n \"OS-FLV-EXT-DATA:ephemeral\",\n \"rxtx_factor\",\n \"description\",\n \"os-flavor-access:is_public\",\n ]\n optionalFields.forEach((key) => {\n const value = newFlavor[key]\n\n if (value !== undefined && value !== \"\" && value !== null) {\n const error = validateField(key, value, t)\n if (error) {\n newErrors[key] = error\n }\n }\n })\n\n if (Object.keys(newErrors).length > 0) {\n setErrors(newErrors)\n setGeneralError(t`Please fix the validation errors below.`)\n return\n }\n\n try {\n setIsLoading(true)\n\n const flavorData = cleanFlavorData(newFlavor)\n\n await client.compute.createFlavor.mutate({\n project_id: project,\n flavor: flavorData,\n })\n\n onSuccess(flavorData.name)\n handleClose()\n } catch (error) {\n const errorMessage = (error as Error)?.message\n ? translateError((error as Error).message)\n : t`Failed to create flavor. Please try again.`\n setGeneralError(errorMessage)\n } finally {\n setIsLoading(false)\n }\n }\n\n const handleClose = () => {\n setNewFlavor({\n \"os-flavor-access:is_public\": true,\n })\n setErrors({})\n setGeneralError(null)\n onClose()\n }\n\n const dismissError = () => {\n setGeneralError(null)\n }\n\n return (\n <Modal\n onCancel={handleClose}\n size=\"large\"\n title={t`Create Flavor`}\n open={isOpen}\n onConfirm={handleSubmit}\n cancelButtonLabel={t`Cancel`}\n confirmButtonLabel={t`Create New Flavor`}\n >\n {isLoading && (\n <Stack distribution=\"center\" alignment=\"center\">\n <Spinner variant=\"primary\" />\n </Stack>\n )}\n {!isLoading && (\n <Form>\n {generalError && (\n <FormRow>\n <Message onDismiss={dismissError} text={generalError} variant=\"error\" />\n </FormRow>\n )}\n\n <FormSection>\n <FormRow>\n <TextInput\n id=\"id\"\n name=\"id\"\n label={t`Flavor ID`}\n value={newFlavor.id || \"\"}\n onChange={handleInputChange}\n onBlur={handleBlur}\n errortext={errors.id}\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"name\"\n name=\"name\"\n label={t`Flavor Name`}\n value={newFlavor.name || \"\"}\n onChange={handleInputChange}\n onBlur={handleBlur}\n errortext={errors.name}\n required\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"description\"\n name=\"description\"\n label={t`Description`}\n value={newFlavor.description || \"\"}\n onChange={handleInputChange}\n onBlur={handleBlur}\n errortext={errors.description}\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"vcpus\"\n name=\"vcpus\"\n label={t`VCPUs`}\n value={String(newFlavor.vcpus || \"\")}\n onChange={(e) => handleNumericInputChange(\"vcpus\", Number(e.target.value))}\n onBlur={handleBlur}\n errortext={errors.vcpus}\n type=\"number\"\n required\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"ram\"\n name=\"ram\"\n label={t`RAM (MiB)`}\n value={String(newFlavor.ram || \"\")}\n onChange={(e) => handleNumericInputChange(\"ram\", Number(e.target.value))}\n onBlur={handleBlur}\n errortext={errors.ram}\n type=\"number\"\n required\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"disk\"\n name=\"disk\"\n label={t`Disk (GiB)`}\n value={String(newFlavor.disk || \"\")}\n onChange={(e) => handleNumericInputChange(\"disk\", Number(e.target.value))}\n onBlur={handleBlur}\n errortext={errors.disk}\n type=\"number\"\n required\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"OS-FLV-EXT-DATA:ephemeral\"\n name=\"OS-FLV-EXT-DATA:ephemeral\"\n label={t`Ephemeral Disk (GiB)`}\n value={String(newFlavor[\"OS-FLV-EXT-DATA:ephemeral\"] || \"\")}\n onChange={(e) => handleNumericInputChange(\"OS-FLV-EXT-DATA:ephemeral\", Number(e.target.value))}\n onBlur={handleBlur}\n errortext={errors[\"OS-FLV-EXT-DATA:ephemeral\"]}\n type=\"number\"\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"swap\"\n name=\"swap\"\n label={t`Swap (MiB)`}\n value={String(newFlavor.swap || \"\")}\n onChange={(e) => handleNumericInputChange(\"swap\", e.target.value ? Number(e.target.value) : undefined)}\n onBlur={handleBlur}\n errortext={errors.swap}\n type=\"number\"\n />\n </FormRow>\n <FormRow>\n <TextInput\n id=\"rxtx_factor\"\n name=\"rxtx_factor\"\n label={t`RX/TX Factor`}\n defaultValue={1}\n value={String(newFlavor.rxtx_factor || \"\")}\n onChange={(e) => handleNumericInputChange(\"rxtx_factor\", Number(e.target.value))}\n onBlur={handleBlur}\n errortext={errors.rxtx_factor}\n type=\"number\"\n />\n </FormRow>\n <FormRow>\n <Checkbox\n name=\"os-flavor-access:is_public\"\n label={t`Public Flavor`}\n helptext={t`If checked, this flavor will be available to all tenants. If unchecked, access must be explicitly granted to specific tenants.`}\n checked={!!newFlavor[\"os-flavor-access:is_public\"]}\n onChange={handleInputChange}\n />\n </FormRow>\n </FormSection>\n </Form>\n )}\n </Modal>\n )\n}\n","import { use, Suspense, useState, useRef, startTransition, useEffect, useCallback } from \"react\"\nimport { ErrorBoundary } from \"react-error-boundary\"\nimport { Trans, useLingui } from \"@lingui/react/macro\"\nimport { useSearch, useNavigate } from \"@tanstack/react-router\"\nimport { TrpcClient } from \"@/client/trpcClient\"\nimport { Flavor } from \"@/server/Compute/types/flavor\"\nimport { TRPCClientError } from \"@trpc/client\"\nimport { Message, Button, Stack, Spinner, DataGridToolbar, SearchInput } from \"@cloudoperators/juno-ui-components\"\nimport { SortInput } from \"@/client/components/ListToolbar/SortInput\"\nimport { SortSettings } from \"@/client/components/ListToolbar/types\"\nimport { FlavorListContainer } from \"./-components/FlavorListContainer\"\nimport { CreateFlavorModal } from \"./-components/CreateFlavorModal\"\nimport type { FlavorsSearchParams } from \"@/client/routes/_auth/projects/$projectId/compute/flavors\"\n\nconst PAGE_SIZE = 50\n\ninterface FlavorsProps {\n client: TrpcClient\n project: string\n}\n\ntype RequiredSortSettings = {\n options: SortSettings[\"options\"]\n sortBy: string\n sortDirection: \"asc\" | \"desc\"\n}\n\nconst createFlavorsPromise = (\n client: TrpcClient,\n project: string,\n sortBy: string,\n sortDirection: string,\n searchTerm: string\n) => {\n return client.compute.getFlavorsByProjectId\n .query({ project_id: project, sortBy, sortDirection, searchTerm })\n .then((res) => ({ ...res, listError: undefined as string | undefined }))\n .catch((err: unknown) => {\n if (err instanceof TRPCClientError && err.data?.code === \"FORBIDDEN\") {\n return { flavors: [] as Flavor[], privateFlavorError: undefined, listError: err.message }\n }\n throw err\n })\n}\n\nconst createPermissionsPromise = (client: TrpcClient, project: string) => {\n return client.compute.canUser\n .query({\n project_id: project,\n permission: [\n \"flavors:create\",\n \"flavors:delete\",\n \"flavors:list_projects\",\n \"flavor_specs:create\",\n \"flavor_specs:delete\",\n \"flavor_specs:list\",\n ],\n })\n .then(([canCreate, canDelete, canManageAccess, canCreateSpecs, canDeleteSpecs, canListSpecs]) => ({\n canCreate,\n canDelete,\n canManageAccess,\n canManageSpecs: canCreateSpecs || canDeleteSpecs,\n canListSpecs,\n }))\n}\n\nfunction FlavorsContent({\n flavorsPromise,\n permissionsPromise,\n client,\n project,\n onFlavorDeleted,\n onFlavorCreated,\n searchTerm,\n setSearchTerm,\n sortSettings,\n handleSortChange,\n createModalOpen,\n setCreateModalOpen,\n currentPage,\n onPageChange,\n}: {\n flavorsPromise: Promise<{ flavors: Flavor[]; privateFlavorError?: string; listError?: string }>\n permissionsPromise: Promise<{\n canCreate: boolean\n canDelete: boolean\n canManageAccess: boolean\n canManageSpecs: boolean\n canListSpecs: boolean\n }>\n client: TrpcClient\n project: string\n onFlavorDeleted: (name: string) => void\n onFlavorCreated: (name: string) => void\n searchTerm: string\n setSearchTerm: (term: string) => void\n sortSettings: SortSettings\n handleSortChange: (settings: SortSettings) => void\n createModalOpen: boolean\n setCreateModalOpen: (open: boolean) => void\n currentPage: number\n onPageChange: (page: number) => void\n}) {\n const { t } = useLingui()\n const { flavors, privateFlavorError, listError } = use(flavorsPromise)\n const permissions = use(permissionsPromise)\n const [localSearchTerm, setLocalSearchTerm] = useState(searchTerm)\n const debounceTimer = useRef<number | undefined>(undefined)\n\n useEffect(() => () => clearTimeout(debounceTimer.current), [])\n\n if (listError) {\n return <p>{listError}</p>\n }\n\n const totalPages = Math.max(1, Math.ceil(flavors.length / PAGE_SIZE))\n const safePage = Math.min(currentPage, totalPages)\n const paginatedFlavors = flavors.slice((safePage - 1) * PAGE_SIZE, safePage * PAGE_SIZE)\n\n useEffect(() => {\n if (currentPage > totalPages) onPageChange(1)\n }, [totalPages, currentPage, onPageChange])\n\n return (\n <>\n <CreateFlavorModal\n client={client}\n isOpen={createModalOpen}\n project={project}\n onClose={() => setCreateModalOpen(false)}\n onSuccess={onFlavorCreated}\n />\n\n {privateFlavorError && (\n <Message\n className=\"mb-4\"\n text={t`Private flavors could not be loaded. You may be seeing an incomplete list.`}\n variant=\"warning\"\n />\n )}\n\n {/* Zone 1 — sort + create action, no background */}\n <Stack distribution=\"end\" alignment=\"center\" gap=\"2\" className=\"pb-2\">\n <Stack gap=\"0.5\">\n <SortInput\n options={sortSettings.options}\n sortBy={sortSettings.sortBy}\n sortDirection={sortSettings.sortDirection ?? \"asc\"}\n onSortByChange={(v) =>\n handleSortChange({ ...sortSettings, sortBy: v, sortDirection: sortSettings.sortDirection })\n }\n onSortDirectionChange={(dir) => handleSortChange({ ...sortSettings, sortDirection: dir })}\n />\n </Stack>\n {permissions.canCreate && (\n <Button variant=\"primary\" label={t`Create Flavor`} onClick={() => setCreateModalOpen(true)} />\n )}\n </Stack>\n\n {/* Zone 2 — search bar */}\n <DataGridToolbar>\n <Stack distribution=\"end\" alignment=\"center\">\n <SearchInput\n placeholder={t`Search flavors...`}\n data-testid=\"searchbar\"\n value={localSearchTerm}\n onInput={(e: React.FormEvent<HTMLInputElement>) => {\n const v = e.currentTarget.value\n setLocalSearchTerm(v)\n clearTimeout(debounceTimer.current)\n debounceTimer.current = window.setTimeout(() => setSearchTerm(v), 500)\n }}\n onSearch={(v) => {\n clearTimeout(debounceTimer.current)\n setSearchTerm(typeof v === \"string\" ? v : \"\")\n }}\n onClear={() => {\n clearTimeout(debounceTimer.current)\n setLocalSearchTerm(\"\")\n setSearchTerm(\"\")\n }}\n />\n </Stack>\n </DataGridToolbar>\n\n <FlavorListContainer\n flavors={paginatedFlavors}\n isLoading={false}\n client={client}\n project={project}\n onFlavorDeleted={onFlavorDeleted}\n canDeleteFlavor={permissions.canDelete}\n canMangageAccess={permissions.canManageAccess}\n canManageSpecs={permissions.canManageSpecs}\n canListSpecs={permissions.canListSpecs}\n currentPage={safePage}\n totalPages={totalPages}\n onPageChange={onPageChange}\n />\n </>\n )\n}\nexport const Flavors = ({ client, project }: FlavorsProps) => {\n const { t } = useLingui()\n const navigate = useNavigate()\n const searchParams = useSearch({ strict: false }) as FlavorsSearchParams\n\n const [sortSettings, setSortSettings] = useState<RequiredSortSettings>({\n options: [\n { label: t`Name`, value: \"name\" },\n { label: t`VCPUs`, value: \"vcpus\" },\n { label: t`RAM`, value: \"ram\" },\n { label: t`Root Disk`, value: \"disk\" },\n { label: t`Swap`, value: \"swap\" },\n ],\n sortBy: searchParams.sortBy || \"name\",\n sortDirection: searchParams.sortDirection || \"asc\",\n })\n\n const [searchTerm, setSearchTerm] = useState(searchParams.search || \"\")\n const currentPage = searchParams.page ?? 1\n const [success, setSuccess] = useState<{ message: string; timestamp: number } | undefined>()\n const [createModalOpen, setCreateModalOpen] = useState(false)\n\n const [flavorsPromise, setFlavorsPromise] = useState(() =>\n createFlavorsPromise(client, project, sortSettings.sortBy, sortSettings.sortDirection, searchTerm)\n )\n const [permissionsPromise] = useState(() => createPermissionsPromise(client, project))\n\n const refetchFlavors = () => {\n startTransition(() => {\n setFlavorsPromise(\n createFlavorsPromise(client, project, sortSettings.sortBy, sortSettings.sortDirection, searchTerm)\n )\n })\n }\n\n const handleFlavorDeleted = (flavorName: string) => {\n setSuccess({\n message: t`Flavor \"${flavorName}\" has been successfully deleted.`,\n timestamp: Date.now(),\n })\n setTimeout(() => setSuccess(undefined), 5000)\n refetchFlavors()\n }\n\n const handleFlavorCreated = (flavorName: string) => {\n setSuccess({\n message: t`Flavor \"${flavorName}\" has been successfully created.`,\n timestamp: Date.now(),\n })\n setTimeout(() => setSuccess(undefined), 5000)\n refetchFlavors()\n }\n\n const handleSortChange = (newSortSettings: SortSettings) => {\n const settings: RequiredSortSettings = {\n options: newSortSettings.options,\n sortBy: newSortSettings.sortBy?.toString() || \"name\",\n sortDirection: newSortSettings.sortDirection || \"asc\",\n }\n\n setSortSettings(settings)\n navigate({\n search: ((prev: FlavorsSearchParams) => ({\n ...prev,\n sortBy: settings.sortBy,\n sortDirection: settings.sortDirection,\n page: undefined,\n })) as unknown as true,\n replace: true,\n })\n startTransition(() => {\n setFlavorsPromise(createFlavorsPromise(client, project, settings.sortBy, settings.sortDirection, searchTerm))\n })\n }\n\n const handleSearchChange = (term: string | number | string[] | undefined) => {\n const searchValue = typeof term === \"string\" ? term : \"\"\n setSearchTerm(searchValue)\n\n navigate({\n search: ((prev: FlavorsSearchParams) => ({\n ...prev,\n search: searchValue || undefined,\n page: undefined,\n })) as unknown as true,\n replace: true,\n })\n startTransition(() => {\n setFlavorsPromise(\n createFlavorsPromise(client, project, sortSettings.sortBy, sortSettings.sortDirection, searchValue)\n )\n })\n }\n\n const handlePageChange = useCallback(\n (page: number) => {\n navigate({\n search: ((prev: FlavorsSearchParams) => ({\n ...prev,\n page: page === 1 ? undefined : page,\n })) as unknown as true,\n })\n },\n [navigate]\n )\n\n return (\n <div className=\"relative\">\n {success && (\n <Message\n className=\"absolute -top-14 right-0 left-0 z-50\"\n text={success.message}\n variant=\"info\"\n onDismiss={() => setSuccess(undefined)}\n dismissible\n />\n )}\n\n <ErrorBoundary\n fallbackRender={({ error }) => (\n <Message variant=\"error\" text={error instanceof Error ? error.message : t`An unexpected error occurred.`} />\n )}\n >\n <Suspense\n fallback={\n <Stack className=\"fixed inset-0\" distribution=\"center\" alignment=\"center\" direction=\"vertical\">\n <Spinner variant=\"primary\" size=\"large\" className=\"mb-2\" />\n <Trans>Loading Flavors...</Trans>\n </Stack>\n }\n >\n <FlavorsContent\n flavorsPromise={flavorsPromise}\n permissionsPromise={permissionsPromise}\n client={client}\n project={project}\n onFlavorDeleted={handleFlavorDeleted}\n onFlavorCreated={handleFlavorCreated}\n searchTerm={searchTerm}\n setSearchTerm={handleSearchChange}\n sortSettings={sortSettings}\n handleSortChange={handleSortChange}\n createModalOpen={createModalOpen}\n setCreateModalOpen={setCreateModalOpen}\n currentPage={currentPage}\n onPageChange={handlePageChange}\n />\n </Suspense>\n </ErrorBoundary>\n </div>\n )\n}\n","import { createFileRoute } from \"@tanstack/react-router\"\nimport { t } from \"@lingui/core/macro\"\nimport { useLingui } from \"@lingui/react/macro\"\nimport { Flavors } from \"../-components/Flavors/List\"\nimport type { RouteInfo } from \"@/client/routes/routeInfo\"\nimport { ContentHeader } from \"@/client/components/ContentHeader/ContentHeader\"\n\nexport const Route = createFileRoute(\"/_auth/projects/$projectId/compute/flavors/\")({\n staticData: {\n section: \"compute\",\n service: \"flavors\",\n sectionCrumb: { labelKey: \"Compute\" },\n crumb: { labelKey: \"Flavors\" },\n } satisfies RouteInfo,\n head: () => ({ meta: [{ title: t`Flavors` }] }),\n component: RouteComponent,\n})\n\nfunction RouteComponent() {\n const { t } = useLingui()\n const { projectId } = Route.useParams()\n const { trpcClient } = Route.useRouteContext()\n return (\n <>\n <ContentHeader title={t`Flavors`} projectId={projectId} />\n <Flavors project={projectId} client={trpcClient!} />\n </>\n )\n}\n"],"mappings":"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"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { D as e, G as t, H as n, J as r, L as i, N as a, Q as o, U as s, Y as c, _ as l, ct as u, et as d, k as f, l as p, m, ot as h, p as g, v as _, x as v } from "./build-BdRRmNf5.mjs";
|
|
2
2
|
import { r as y } from "./trpcClient-BzPUgiM2.mjs";
|
|
3
3
|
import { t as b } from "./useModal-DCs1OJh7.mjs";
|
|
4
4
|
import { t as x } from "./useProjectId-DBc5lpoU.mjs";
|
|
5
5
|
import "./hooks-dSArr2Ca.mjs";
|
|
6
|
-
import { t as S } from "./FloatingIpActionModals-
|
|
7
|
-
import { n as C, t as w } from "./useListWithFiltering-
|
|
6
|
+
import { t as S } from "./FloatingIpActionModals-CRvROJ3H.mjs";
|
|
7
|
+
import { n as C, t as w } from "./useListWithFiltering-v2A0-SZb.mjs";
|
|
8
8
|
import { t as T } from "./buildFilterParams-DoZzMKX9.mjs";
|
|
9
9
|
import { m as E, r as D, s as O } from "./md-CYTrL5dq.mjs";
|
|
10
10
|
import { Fragment as k, jsx as A, jsxs as j } from "react/jsx-runtime";
|
|
@@ -46,91 +46,91 @@ var z = {
|
|
|
46
46
|
I._({ id: "7NC3vm" }),
|
|
47
47
|
I._({ id: "Nu4oKW" }),
|
|
48
48
|
""
|
|
49
|
-
], V = ({ floatingIp:
|
|
50
|
-
let { i18n:
|
|
51
|
-
|
|
49
|
+
], V = ({ floatingIp: n }) => {
|
|
50
|
+
let { i18n: r, _: i } = P(), o = M(), s = x(), c = () => {
|
|
51
|
+
o({
|
|
52
52
|
to: "/projects/$projectId/network/floatingips/$floatingIpId",
|
|
53
53
|
params: {
|
|
54
|
-
projectId:
|
|
55
|
-
floatingIpId:
|
|
54
|
+
projectId: s,
|
|
55
|
+
floatingIpId: n.id
|
|
56
56
|
}
|
|
57
57
|
});
|
|
58
58
|
};
|
|
59
|
-
return /*#__PURE__*/ j(
|
|
60
|
-
"data-testid": `floating-ip-row-${
|
|
61
|
-
onClick:
|
|
59
|
+
return /*#__PURE__*/ j(a, {
|
|
60
|
+
"data-testid": `floating-ip-row-${n.id}`,
|
|
61
|
+
onClick: c,
|
|
62
62
|
children: [
|
|
63
|
-
/*#__PURE__*/ A(
|
|
63
|
+
/*#__PURE__*/ A(t, { children: /*#__PURE__*/ j("div", {
|
|
64
64
|
className: "flex items-center gap-2",
|
|
65
|
-
children: [z[
|
|
65
|
+
children: [z[n.status].icon, z[n.status].text]
|
|
66
66
|
}) }),
|
|
67
|
-
/*#__PURE__*/ A(
|
|
68
|
-
/*#__PURE__*/ A(
|
|
69
|
-
/*#__PURE__*/ A(
|
|
70
|
-
/*#__PURE__*/ A(
|
|
71
|
-
/*#__PURE__*/ A(
|
|
67
|
+
/*#__PURE__*/ A(t, { children: n.floating_ip_address }),
|
|
68
|
+
/*#__PURE__*/ A(t, { children: n.fixed_ip_address || "—" }),
|
|
69
|
+
/*#__PURE__*/ A(t, { children: n.floating_network_id }),
|
|
70
|
+
/*#__PURE__*/ A(t, { children: n.description || "—" }),
|
|
71
|
+
/*#__PURE__*/ A(t, {
|
|
72
72
|
onClick: (e) => e.stopPropagation(),
|
|
73
73
|
className: "items-end pr-0",
|
|
74
74
|
children: /*#__PURE__*/ A(S, {
|
|
75
|
-
floatingIp:
|
|
76
|
-
children: ({ toggleEditModal:
|
|
77
|
-
/*#__PURE__*/ A(
|
|
78
|
-
label:
|
|
79
|
-
onClick:
|
|
75
|
+
floatingIp: n,
|
|
76
|
+
children: ({ toggleEditModal: t, toggleAttachModal: n, toggleDetachModal: i, toggleReleaseModal: a }) => /*#__PURE__*/ A(e, { children: /*#__PURE__*/ j(h, { children: [
|
|
77
|
+
/*#__PURE__*/ A(f, {
|
|
78
|
+
label: r._({ id: "rdUucN" }),
|
|
79
|
+
onClick: c
|
|
80
80
|
}),
|
|
81
|
-
/*#__PURE__*/ A(
|
|
82
|
-
label:
|
|
83
|
-
onClick:
|
|
81
|
+
/*#__PURE__*/ A(f, {
|
|
82
|
+
label: r._({ id: "n22YIM" }),
|
|
83
|
+
onClick: t
|
|
84
84
|
}),
|
|
85
|
-
/*#__PURE__*/ A(
|
|
86
|
-
label:
|
|
85
|
+
/*#__PURE__*/ A(f, {
|
|
86
|
+
label: r._({ id: "igVDFt" }),
|
|
87
87
|
onClick: n
|
|
88
88
|
}),
|
|
89
|
-
/*#__PURE__*/ A(
|
|
90
|
-
label:
|
|
91
|
-
onClick:
|
|
89
|
+
/*#__PURE__*/ A(f, {
|
|
90
|
+
label: r._({ id: "FOcBn3" }),
|
|
91
|
+
onClick: i
|
|
92
92
|
}),
|
|
93
|
-
/*#__PURE__*/ A(
|
|
94
|
-
label:
|
|
93
|
+
/*#__PURE__*/ A(f, {
|
|
94
|
+
label: r._({ id: "H+a5j6" }),
|
|
95
95
|
onClick: a
|
|
96
96
|
})
|
|
97
97
|
] }) })
|
|
98
98
|
})
|
|
99
99
|
})
|
|
100
100
|
]
|
|
101
|
-
},
|
|
102
|
-
}, H = ({ floatingIps: e, isLoading: r, isError:
|
|
103
|
-
let { i18n:
|
|
104
|
-
return r ? /*#__PURE__*/ j(
|
|
101
|
+
}, n.id);
|
|
102
|
+
}, H = ({ floatingIps: e, isLoading: r, isError: s, error: l }) => {
|
|
103
|
+
let { i18n: u, _: f } = P(), p = B();
|
|
104
|
+
return r ? /*#__PURE__*/ j(c, {
|
|
105
105
|
className: "py-8",
|
|
106
106
|
distribution: "center",
|
|
107
107
|
alignment: "center",
|
|
108
108
|
direction: "vertical",
|
|
109
|
-
children: [/*#__PURE__*/ A(
|
|
109
|
+
children: [/*#__PURE__*/ A(n, {
|
|
110
110
|
variant: "primary",
|
|
111
111
|
size: "large",
|
|
112
112
|
className: "mb-2"
|
|
113
113
|
}), /*#__PURE__*/ A(N, { id: "Z3FXyt" })]
|
|
114
|
-
}) :
|
|
114
|
+
}) : s ? /*#__PURE__*/ A(c, {
|
|
115
115
|
className: "py-8",
|
|
116
116
|
distribution: "center",
|
|
117
117
|
alignment: "center",
|
|
118
118
|
direction: "vertical",
|
|
119
|
-
children:
|
|
120
|
-
}) : e.length === 0 ? /*#__PURE__*/ A(
|
|
121
|
-
columns:
|
|
119
|
+
children: l?.message ?? u._({ id: "+Nx1wc" })
|
|
120
|
+
}) : e.length === 0 ? /*#__PURE__*/ A(d, {
|
|
121
|
+
columns: p.length,
|
|
122
122
|
className: "floating-ips",
|
|
123
123
|
"data-testid": "no-floating-ips",
|
|
124
|
-
children: /*#__PURE__*/ A(
|
|
125
|
-
colSpan:
|
|
126
|
-
children: [/*#__PURE__*/ A(
|
|
124
|
+
children: /*#__PURE__*/ A(a, { children: /*#__PURE__*/ j(t, {
|
|
125
|
+
colSpan: p.length,
|
|
126
|
+
children: [/*#__PURE__*/ A(o, { children: /*#__PURE__*/ A(N, { id: "WCLyHI" }) }), /*#__PURE__*/ A("p", { children: /*#__PURE__*/ A(N, { id: "0eY8Mz" }) })]
|
|
127
127
|
}) })
|
|
128
|
-
}) : /*#__PURE__*/ j(
|
|
129
|
-
columns:
|
|
130
|
-
children: [/*#__PURE__*/ A(
|
|
128
|
+
}) : /*#__PURE__*/ j(d, {
|
|
129
|
+
columns: p.length,
|
|
130
|
+
children: [/*#__PURE__*/ A(a, { children: p.map((e) => /*#__PURE__*/ A(i, { children: e }, e)) }), e.map((e) => /*#__PURE__*/ A(V, { floatingIp: e }, e.id))]
|
|
131
131
|
});
|
|
132
|
-
}, U = /^(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}$/, W = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|(([0-9a-fA-F]{1,4}:){1,7}:)|(([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4})|(([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2})|(([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3})|(([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4})|(([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5})|([0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6}))|(:((:[0-9a-fA-F]{1,4}){1,7}|:))|(::([fF]{4}(:0{1,4})?:)?((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|(([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})))$/, G = (e) => U.test(e) || W.test(e), K = /^([a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\.)*[a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?$/, q = ({ open:
|
|
133
|
-
let { i18n: i, _: a } = P(),
|
|
132
|
+
}, U = /^(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}$/, W = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|(([0-9a-fA-F]{1,4}:){1,7}:)|(([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4})|(([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2})|(([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3})|(([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4})|(([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5})|([0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6}))|(:((:[0-9a-fA-F]{1,4}){1,7}|:))|(::([fF]{4}(:0{1,4})?:)?((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|(([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})))$/, G = (e) => U.test(e) || W.test(e), K = /^([a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\.)*[a-zA-Z0-9]([a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?$/, q = ({ open: e, onClose: t }) => {
|
|
133
|
+
let { i18n: i, _: a } = P(), o = x(), c = y.useUtils(), { isPending: l, ...d } = y.network.floatingIp.create.useMutation({ onSettled: () => c.network.floatingIp.list.invalidate() }), { data: f = [], isLoading: h, error: b } = y.network.floatingIp.listExternalNetworks.useQuery({ project_id: o }), { data: S = [], isLoading: C, error: w } = y.network.floatingIp.listDnsDomains.useQuery({ project_id: o }), { data: T = [], isLoading: E, error: D } = y.network.floatingIp.listAvailablePorts.useQuery({ project_id: o }), O = L({
|
|
134
134
|
defaultValues: {
|
|
135
135
|
floating_network_id: "",
|
|
136
136
|
dns_domain: "",
|
|
@@ -150,9 +150,9 @@ var z = {
|
|
|
150
150
|
fixed_ip_address: F.string()
|
|
151
151
|
}) },
|
|
152
152
|
onSubmit: async ({ value: e }) => {
|
|
153
|
-
|
|
154
|
-
project_id:
|
|
155
|
-
tenant_id:
|
|
153
|
+
l || (await d.mutateAsync({
|
|
154
|
+
project_id: o,
|
|
155
|
+
tenant_id: o,
|
|
156
156
|
floating_network_id: e.floating_network_id,
|
|
157
157
|
...e.dns_domain && { dns_domain: e.dns_domain },
|
|
158
158
|
...e.dns_name && { dns_name: e.dns_name },
|
|
@@ -163,43 +163,43 @@ var z = {
|
|
|
163
163
|
}), k());
|
|
164
164
|
}
|
|
165
165
|
}), k = () => {
|
|
166
|
-
|
|
167
|
-
}, M = R(O.store, (e) => e.values.port_id), I = R(O.store, (e) => e.values.floating_network_id), z = T.find((e) => e.id === M)?.fixed_ips ?? [], B = (b?.message || w?.message || D?.message) ??
|
|
168
|
-
return /*#__PURE__*/ j(
|
|
169
|
-
open:
|
|
166
|
+
l || (O.reset(), d.reset(), t());
|
|
167
|
+
}, M = R(O.store, (e) => e.values.port_id), I = R(O.store, (e) => e.values.floating_network_id), z = T.find((e) => e.id === M)?.fixed_ips ?? [], B = (b?.message || w?.message || D?.message) ?? d.error?.message ?? null;
|
|
168
|
+
return /*#__PURE__*/ j(u, {
|
|
169
|
+
open: e,
|
|
170
170
|
size: "large",
|
|
171
171
|
title: i._({ id: "h99+4y" }),
|
|
172
172
|
onCancel: k,
|
|
173
173
|
cancelButtonLabel: i._({ id: "dEgA5A" }),
|
|
174
174
|
confirmButtonLabel: i._({ id: "9X8lAk" }),
|
|
175
175
|
onConfirm: O.handleSubmit,
|
|
176
|
-
disableConfirmButton:
|
|
176
|
+
disableConfirmButton: l || !I,
|
|
177
177
|
children: [
|
|
178
|
-
B && /*#__PURE__*/ A(
|
|
178
|
+
B && /*#__PURE__*/ A(r, {
|
|
179
179
|
dismissible: !1,
|
|
180
180
|
variant: "error",
|
|
181
181
|
className: "mb-4",
|
|
182
182
|
children: B
|
|
183
183
|
}),
|
|
184
|
-
|
|
184
|
+
l && /*#__PURE__*/ j("div", {
|
|
185
185
|
className: "mb-4 flex items-center justify-center gap-2",
|
|
186
|
-
children: [/*#__PURE__*/ A(
|
|
186
|
+
children: [/*#__PURE__*/ A(n, { variant: "primary" }), /*#__PURE__*/ A("span", {
|
|
187
187
|
className: "text-theme-high text-sm",
|
|
188
188
|
children: /*#__PURE__*/ A(N, { id: "HuA8iQ" })
|
|
189
189
|
})]
|
|
190
190
|
}),
|
|
191
|
-
!
|
|
191
|
+
!l && /*#__PURE__*/ j(v, {
|
|
192
192
|
className: "mb-0",
|
|
193
193
|
id: "allocate-floating-ip-form",
|
|
194
194
|
onSubmit: (e) => {
|
|
195
195
|
e.preventDefault(), O.handleSubmit();
|
|
196
196
|
},
|
|
197
197
|
children: [
|
|
198
|
-
/*#__PURE__*/ A(
|
|
198
|
+
/*#__PURE__*/ A(g, {
|
|
199
199
|
className: "mb-4",
|
|
200
200
|
children: /*#__PURE__*/ A(O.Field, {
|
|
201
201
|
name: "floating_network_id",
|
|
202
|
-
children: (e) => /*#__PURE__*/ A(
|
|
202
|
+
children: (e) => /*#__PURE__*/ A(_, {
|
|
203
203
|
id: e.name,
|
|
204
204
|
name: e.name,
|
|
205
205
|
value: e.state.value,
|
|
@@ -207,41 +207,41 @@ var z = {
|
|
|
207
207
|
label: i._({ id: "kA2lMP" }),
|
|
208
208
|
helptext: i._({ id: "BoIAP6" }),
|
|
209
209
|
placeholder: i._({ id: "T6Gm5y" }),
|
|
210
|
-
disabled:
|
|
210
|
+
disabled: l || h,
|
|
211
211
|
required: !0,
|
|
212
|
-
loading:
|
|
213
|
-
children:
|
|
212
|
+
loading: h,
|
|
213
|
+
children: f.map(({ id: e, name: t }) => /*#__PURE__*/ A(p, {
|
|
214
214
|
value: e,
|
|
215
215
|
label: t ? `${t} (${e})` : e
|
|
216
216
|
}, e))
|
|
217
217
|
})
|
|
218
218
|
})
|
|
219
219
|
}),
|
|
220
|
-
/*#__PURE__*/ A(
|
|
220
|
+
/*#__PURE__*/ A(g, {
|
|
221
221
|
className: "mb-4",
|
|
222
222
|
children: /*#__PURE__*/ A(O.Field, {
|
|
223
223
|
name: "dns_domain",
|
|
224
|
-
children: (e) => /*#__PURE__*/ A(
|
|
224
|
+
children: (e) => /*#__PURE__*/ A(_, {
|
|
225
225
|
id: e.name,
|
|
226
226
|
name: e.name,
|
|
227
227
|
value: e.state.value,
|
|
228
228
|
onChange: (t) => e.handleChange(typeof t == "string" ? t : ""),
|
|
229
229
|
label: i._({ id: "WlpcJv" }),
|
|
230
230
|
helptext: i._({ id: "1ojTVo" }),
|
|
231
|
-
disabled:
|
|
231
|
+
disabled: l || C,
|
|
232
232
|
loading: C,
|
|
233
|
-
children: S.map(({ id: e, name: t }) => /*#__PURE__*/ A(
|
|
233
|
+
children: S.map(({ id: e, name: t }) => /*#__PURE__*/ A(p, {
|
|
234
234
|
value: t,
|
|
235
235
|
label: t
|
|
236
236
|
}, e))
|
|
237
237
|
})
|
|
238
238
|
})
|
|
239
239
|
}),
|
|
240
|
-
/*#__PURE__*/ A(
|
|
240
|
+
/*#__PURE__*/ A(g, {
|
|
241
241
|
className: "mb-4",
|
|
242
242
|
children: /*#__PURE__*/ A(O.Field, {
|
|
243
243
|
name: "dns_name",
|
|
244
|
-
children: (e) => /*#__PURE__*/ A(
|
|
244
|
+
children: (e) => /*#__PURE__*/ A(m, {
|
|
245
245
|
id: e.name,
|
|
246
246
|
name: e.name,
|
|
247
247
|
value: e.state.value,
|
|
@@ -251,15 +251,15 @@ var z = {
|
|
|
251
251
|
placeholder: i._({ id: "SLEH7X" }),
|
|
252
252
|
helptext: i._({ id: "Tx4Ym+" }),
|
|
253
253
|
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
254
|
-
disabled:
|
|
254
|
+
disabled: l
|
|
255
255
|
})
|
|
256
256
|
})
|
|
257
257
|
}),
|
|
258
|
-
/*#__PURE__*/ A(
|
|
258
|
+
/*#__PURE__*/ A(g, {
|
|
259
259
|
className: "mb-4",
|
|
260
260
|
children: /*#__PURE__*/ A(O.Field, {
|
|
261
261
|
name: "description",
|
|
262
|
-
children: (e) => /*#__PURE__*/ A(
|
|
262
|
+
children: (e) => /*#__PURE__*/ A(s, {
|
|
263
263
|
id: e.name,
|
|
264
264
|
name: e.name,
|
|
265
265
|
value: e.state.value,
|
|
@@ -267,15 +267,15 @@ var z = {
|
|
|
267
267
|
onChange: (t) => e.handleChange(t.target.value),
|
|
268
268
|
placeholder: i._({ id: "Nu4oKW" }),
|
|
269
269
|
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
270
|
-
disabled:
|
|
270
|
+
disabled: l
|
|
271
271
|
})
|
|
272
272
|
})
|
|
273
273
|
}),
|
|
274
|
-
/*#__PURE__*/ A(
|
|
274
|
+
/*#__PURE__*/ A(g, {
|
|
275
275
|
className: "mb-4",
|
|
276
276
|
children: /*#__PURE__*/ A(O.Field, {
|
|
277
277
|
name: "floating_ip_address",
|
|
278
|
-
children: (e) => /*#__PURE__*/ A(
|
|
278
|
+
children: (e) => /*#__PURE__*/ A(m, {
|
|
279
279
|
id: e.name,
|
|
280
280
|
name: e.name,
|
|
281
281
|
value: e.state.value,
|
|
@@ -285,15 +285,15 @@ var z = {
|
|
|
285
285
|
placeholder: i._({ id: "5/wyf8" }),
|
|
286
286
|
helptext: i._({ id: "PAKSdy" }),
|
|
287
287
|
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
288
|
-
disabled:
|
|
288
|
+
disabled: l
|
|
289
289
|
})
|
|
290
290
|
})
|
|
291
291
|
}),
|
|
292
|
-
/*#__PURE__*/ A(
|
|
292
|
+
/*#__PURE__*/ A(g, {
|
|
293
293
|
className: "mb-4",
|
|
294
294
|
children: /*#__PURE__*/ A(O.Field, {
|
|
295
295
|
name: "port_id",
|
|
296
|
-
children: (e) => /*#__PURE__*/ A(
|
|
296
|
+
children: (e) => /*#__PURE__*/ A(_, {
|
|
297
297
|
id: e.name,
|
|
298
298
|
name: e.name,
|
|
299
299
|
value: e.state.value,
|
|
@@ -306,18 +306,18 @@ var z = {
|
|
|
306
306
|
label: i._({ id: "eks7oA" }),
|
|
307
307
|
placeholder: i._({ id: "UztfYZ" }),
|
|
308
308
|
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
309
|
-
disabled:
|
|
309
|
+
disabled: l || E,
|
|
310
310
|
loading: E,
|
|
311
|
-
children: T.map((e) => /*#__PURE__*/ A(
|
|
311
|
+
children: T.map((e) => /*#__PURE__*/ A(p, {
|
|
312
312
|
value: e.id,
|
|
313
313
|
label: e.name ? `${e.name} (${e.id})` : e.id
|
|
314
314
|
}, e.id))
|
|
315
315
|
})
|
|
316
316
|
})
|
|
317
317
|
}),
|
|
318
|
-
/*#__PURE__*/ A(
|
|
318
|
+
/*#__PURE__*/ A(g, { children: /*#__PURE__*/ A(O.Field, {
|
|
319
319
|
name: "fixed_ip_address",
|
|
320
|
-
children: (e) => /*#__PURE__*/ A(
|
|
320
|
+
children: (e) => /*#__PURE__*/ A(_, {
|
|
321
321
|
id: e.name,
|
|
322
322
|
name: e.name,
|
|
323
323
|
value: e.state.value,
|
|
@@ -327,8 +327,8 @@ var z = {
|
|
|
327
327
|
placeholder: i._({ id: "i41Xuw" }),
|
|
328
328
|
helptext: i._({ id: "PtjzS+" }),
|
|
329
329
|
errortext: e.state.meta.errors.map((e) => e?.message).join(", "),
|
|
330
|
-
disabled:
|
|
331
|
-
children: z.map(({ ip_address: e }) => /*#__PURE__*/ A(
|
|
330
|
+
disabled: l || z.length === 0,
|
|
331
|
+
children: z.map(({ ip_address: e }) => /*#__PURE__*/ A(p, {
|
|
332
332
|
value: e,
|
|
333
333
|
label: e
|
|
334
334
|
}, e))
|
|
@@ -426,9 +426,9 @@ var z = {
|
|
|
426
426
|
//#region src/client/routes/_auth/projects/$projectId/network/floatingips/index.tsx?tsr-split=component
|
|
427
427
|
function Z() {
|
|
428
428
|
let { i18n: e, _: t } = P();
|
|
429
|
-
return /*#__PURE__*/ j(k, { children: [/*#__PURE__*/ A(
|
|
429
|
+
return /*#__PURE__*/ j(k, { children: [/*#__PURE__*/ A(o, { children: e._({ id: "u77/s4" }) }), /*#__PURE__*/ A(X, {})] });
|
|
430
430
|
}
|
|
431
431
|
//#endregion
|
|
432
432
|
export { Z as component };
|
|
433
433
|
|
|
434
|
-
//# sourceMappingURL=floatingips-
|
|
434
|
+
//# sourceMappingURL=floatingips-Dq4DXQYb.mjs.map
|