From 5d0dd10a5f99e9b9dd6ad63b5fb4704619be2973 Mon Sep 17 00:00:00 2001 From: Piyush Kumar Date: Fri, 28 Jun 2024 17:32:49 +0530 Subject: [PATCH] fix(web): - Add archive state of managed services when cluster is deleted - refactor name of managed services, managed resource to integrated services and integrated resource --- gql-queries-generator/doc/queries.graphql | 2 + .../$account+/env+/$environment+/_layout.tsx | 36 ++---- .../handle-managed-resource-v2.tsx | 120 ++++++++++-------- .../managed-resources-resource-v2.tsx | 2 +- .../$environment+/managed-resources/route.tsx | 15 ++- .../environments/environment-resources-v2.tsx | 23 +--- .../backend-services-resources-V2.tsx | 84 +++++++++++- .../$account+/managed-services/route.tsx | 12 +- .../_main+/$account+/msvc+/$msv+/_layout.tsx | 4 +- .../handle-managed-resource.tsx | 99 ++++++++------- .../managed-resources-resource-v2.tsx | 2 +- .../msvc+/$msv+/managed-resources/route.tsx | 15 ++- .../$msv+/new-managed-resource/_index.tsx | 12 +- .../msvc+/$msv+/settings+/general/route.tsx | 17 +-- .../$account+/new-managed-service/_index.tsx | 6 +- .../console/routes/_main+/_layout/_layout.tsx | 22 ++-- .../cluster-managed-services-queries.ts | 2 + src/generated/gql/sdl.graphql | 13 +- src/generated/gql/server.ts | 14 +- 19 files changed, 282 insertions(+), 218 deletions(-) diff --git a/gql-queries-generator/doc/queries.graphql b/gql-queries-generator/doc/queries.graphql index f8b32d672..bbfc47a5a 100644 --- a/gql-queries-generator/doc/queries.graphql +++ b/gql-queries-generator/doc/queries.graphql @@ -3135,6 +3135,7 @@ query consoleGetClusterMSv($name: String!) { clusterName creationTime displayName + isArchived id kind lastUpdatedBy { @@ -3206,6 +3207,7 @@ query consoleListClusterMSvs($pagination: CursorPaginationIn, $search: SearchClu accountName apiVersion clusterName + isArchived createdBy { userEmail userId diff --git a/src/apps/console/routes/_main+/$account+/env+/$environment+/_layout.tsx b/src/apps/console/routes/_main+/$account+/env+/$environment+/_layout.tsx index 2e94c38d7..c77fae868 100644 --- a/src/apps/console/routes/_main+/$account+/env+/$environment+/_layout.tsx +++ b/src/apps/console/routes/_main+/$account+/env+/$environment+/_layout.tsx @@ -1,13 +1,9 @@ import { - // BackingServices, + BackingServices, CirclesFour, GearSix, - // Plus, - // Search, File, TreeStructure, - // Check, - // ChevronUpDown, } from '~/console/components/icons'; import { Link, @@ -17,23 +13,15 @@ import { useParams, } from '@remix-run/react'; import { useState } from 'react'; -// import OptionList from '~/components/atoms/option-list'; import { CommonTabs } from '~/console/components/common-navbar-tabs'; import HandleScope from '~/console/page-components/handle-environment'; import { GQLServerHandler } from '~/console/server/gql/saved-queries'; import { parseName } from '~/console/server/r-utils/common'; -import { - // ensureAccountClientSide, - ensureAccountSet, -} from '~/console/server/utils/auth-utils'; +import { ensureAccountSet } from '~/console/server/utils/auth-utils'; import { SubNavDataProvider } from '~/lib/client/hooks/use-create-subnav-action'; -// import useDebounce from '~/lib/client/hooks/use-debounce'; import { IRemixCtx, LoaderResult } from '~/lib/types/common'; -// import { useConsoleApi } from '~/console/server/gql/api-provider'; import { BreadcrumSlash, tabIconSize } from '~/console/utils/commons'; import { IEnvironment } from '~/console/server/gql/queries/environment-queries'; -// import { cn } from '~/components/utils'; -// import useCustomSwr from '~/lib/client/hooks/use-custom-swr'; import { ILoginUrls, ILogins } from '~/console/server/gql/queries/git-queries'; import logger from '~/root/lib/client/helpers/log'; import Breadcrum from '~/console/components/breadcrum'; @@ -103,16 +91,16 @@ const tabs = [ to: '/cs/configs', value: '/cs', }, - // { - // label: ( - // - // - // Managed resources - // - // ), - // to: '/managed-resources', - // value: '/managed-resources', - // }, + { + label: ( + + + Integrated resources + + ), + to: '/managed-resources', + value: '/managed-resources', + }, // { // label: 'Jobs & Crons', // to: '/jc/task', diff --git a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/handle-managed-resource-v2.tsx b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/handle-managed-resource-v2.tsx index 9eeac517f..8d99c0223 100644 --- a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/handle-managed-resource-v2.tsx +++ b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/handle-managed-resource-v2.tsx @@ -1,5 +1,4 @@ /* eslint-disable react/destructuring-assignment */ -import { toast } from 'react-toastify'; import Popup from '~/components/molecule/popup'; import { useReload } from '~/root/lib/client/helpers/reloader'; import useForm, { dummyEvent } from '~/root/lib/client/hooks/use-form'; @@ -13,7 +12,7 @@ import { } from '~/console/server/r-utils/common'; import Select from '~/components/atoms/select'; import { useConsoleApi } from '~/console/server/gql/api-provider'; -import { useOutletContext } from '@remix-run/react'; +import { useOutletContext, useParams } from '@remix-run/react'; import useCustomSwr from '~/root/lib/client/hooks/use-custom-swr'; import { useMapper } from '~/components/utils'; import MultiStep, { useMultiStep } from '~/console/components/multi-step'; @@ -23,6 +22,8 @@ import { ListItem } from '~/console/components/console-list-components'; import { CopyContentToClipboard } from '~/console/components/common-console-components'; import { useEffect, useState } from 'react'; import { IManagedResources } from '~/console/server/gql/queries/managed-resources-queries'; +import { toast } from '~/components/molecule/toast'; +import { ensureAccountClientSide } from '~/console/server/utils/auth-utils'; import { IEnvironmentContext } from '../_layout'; type BaseType = ExtractNodeType; @@ -59,10 +60,10 @@ const Root = (props: IDialog) => { }, validationSchema: Yup.object({ managedServiceName: Yup.string().required( - 'managed service is required' + 'integrated service is required' ), managedResourceName: Yup.string().required( - 'managed resource name is required' + 'integrated resource name is required' ), }), onSubmit: async (val) => { @@ -80,7 +81,9 @@ const Root = (props: IDialog) => { reloadPage(); resetValues(); toast.success( - `managed resource ${isUpdate ? 'updated' : 'imported'} successfully` + `integrated resource ${ + isUpdate ? 'updated' : 'imported' + } successfully` ); setVisible(false); } catch (err) { @@ -145,11 +148,11 @@ const Root = (props: IDialog) => {
[ ...((mresList && mresList.filter((mres) => { @@ -206,7 +209,7 @@ const HandleManagedResourceV2 = (props: IDialog) => { return ( setVisible(v)}> - {isUpdate ? 'Edit External Name' : 'Import Managed Resource'} + {isUpdate ? 'Edit External Name' : 'Import Integrated Resource'} {(!isUpdate || (isUpdate && props.data)) && } @@ -227,6 +230,8 @@ export const ViewSecret = ({ const api = useConsoleApi(); const { environment } = useOutletContext(); const [onYesClick, setOnYesClick] = useState(false); + const params = useParams(); + ensureAccountClientSide(params); const { data, isLoading, error } = useCustomSwr( () => onYesClick @@ -246,6 +251,55 @@ export const ViewSecret = ({ } ); + const dataSecret = () => { + if (isLoading) { + return ; + } + if (error) { + return

Error: {error}

; + } + if (!data?.data) { + return

No secret found

; + } + + return ( + 'Key', + name: 'key', + className: 'min-w-[170px]', + }, + { + render: () => 'Value', + name: 'value', + className: 'flex-1 min-w-[345px] max-w-[345px] w-[345px]', + }, + ], + rows: Object.entries(data.data || {}).map(([key, value]) => { + const v = value as string; + return { + columns: { + key: { + render: () => , + }, + value: { + render: () => ( + + ), + }, + }, + }; + }), + }} + /> + ); + }; + useEffect(() => { if (error) { toast.error(error); @@ -268,51 +322,7 @@ export const ViewSecret = ({

{`Are you sure you want to view the secrets of '${item.syncedOutputSecretRef?.metadata?.name}'?`}

- - {isLoading ? ( - - ) : ( - data && ( - 'Key', - name: 'key', - className: 'min-w-[170px]', - }, - { - render: () => 'Value', - name: 'value', - className: - 'flex-1 min-w-[345px] max-w-[345px] w-[345px]', - }, - ], - rows: Object.entries(data.stringData).map( - ([key, value]) => { - const v = value as string; - return { - columns: { - key: { - render: () => , - }, - value: { - render: () => ( - - ), - }, - }, - }; - } - ), - }} - /> - ) - )} - + {dataSecret()}
diff --git a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/managed-resources-resource-v2.tsx b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/managed-resources-resource-v2.tsx index ec20f2295..7852bdccb 100644 --- a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/managed-resources-resource-v2.tsx +++ b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/managed-resources-resource-v2.tsx @@ -163,7 +163,7 @@ const ListView = ({ items = [], onAction, templates }: IResource) => { className: 'flex-1', }, { - render: () => 'Managed Service', + render: () => 'Integrated Service', name: 'service', className: 'w-[200px]', }, diff --git a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/route.tsx b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/route.tsx index 7aee47738..606ffdfda 100644 --- a/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/route.tsx +++ b/src/apps/console/routes/_main+/$account+/env+/$environment+/managed-resources/route.tsx @@ -12,6 +12,7 @@ import { useState } from 'react'; import { IAccountContext } from '~/console/routes/_main+/$account+/_layout'; import { EmptyManagedResourceImage } from '~/console/components/empty-resource-images'; import { getSearch } from '~/console/server/utils/common'; +import { ensureAccountSet } from '~/console/server/utils/auth-utils'; import Tools from './tools'; import ManagedResourceResourcesV2 from './managed-resources-resource-v2'; import HandleManagedResourceV2 from './handle-managed-resource-v2'; @@ -19,6 +20,8 @@ import HandleManagedResourceV2 from './handle-managed-resource-v2'; export const loader = (ctx: IRemixCtx) => { const { environment } = ctx.params; const promise = pWrapper(async () => { + ensureAccountSet(ctx); + const { data: mData, errors: mErrors } = await GQLServerHandler( ctx.request ).listManagedResources({ @@ -60,11 +63,11 @@ const KlOperatorServices = () => { return ( 0 && (