diff --git a/web/Taskfile.yaml b/web/Taskfile.yaml
index cd33c7618..0b8d8576c 100644
--- a/web/Taskfile.yaml
+++ b/web/Taskfile.yaml
@@ -41,6 +41,10 @@ tasks:
"vision")
URL_SUFFIX="-vision"
;;
+
+ "piyush")
+ URL_SUFFIX="-piyush"
+ ;;
*)
URL_SUFFIX=""
diff --git a/web/src/apps/console/page-components/app-states.tsx b/web/src/apps/console/page-components/app-states.tsx
index ddb844e49..e78443f2f 100644
--- a/web/src/apps/console/page-components/app-states.tsx
+++ b/web/src/apps/console/page-components/app-states.tsx
@@ -6,6 +6,8 @@ import {
AppIn,
Github__Com___Kloudlite___Operator___Apis___Crds___V1__AppContainerIn as AppSpecContainersIn,
} from '~/root/src/generated/gql/server';
+import {useMapper} from "~/components/utils";
+import {parseNodes} from "~/console/server/r-utils/common";
const defaultApp: AppIn = {
metadata: {
@@ -185,6 +187,18 @@ export const useAppState = () => {
});
};
+ type IparseNodes = {
+ edges: Array<{ node: any }>;
+ };
+
+ const getRepoMapper = (resources: IparseNodes | undefined) => {
+ return useMapper(parseNodes(resources), (val) => ({
+ label: val.name,
+ value: val.name,
+ accName: val.accountName
+ }))
+ }
+
return {
resetState,
completePages,
@@ -203,6 +217,7 @@ export const useAppState = () => {
activeContIndex: activeContIndex || 0,
services: app.spec.services || [],
setServices,
+ getRepoMapper,
};
};
diff --git a/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/app+/$app+/settings+/compute/route.tsx b/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/app+/$app+/settings+/compute/route.tsx
index 4811a8f4a..d70303d5e 100644
--- a/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/app+/$app+/settings+/compute/route.tsx
+++ b/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/app+/$app+/settings+/compute/route.tsx
@@ -1,4 +1,4 @@
-import { useEffect } from 'react';
+import { useEffect, useState } from 'react';
import { NumberInput, TextInput } from '~/components/atoms/input';
import Slider from '~/components/atoms/slider';
import { useAppState } from '~/console/page-components/app-states';
@@ -13,6 +13,9 @@ import ExtendedFilledTab from '~/console/components/extended-filled-tab';
import Wrapper from '~/console/components/wrapper';
import { useUnsavedChanges } from '~/root/lib/client/hooks/use-unsaved-changes';
import { Button } from '~/components/atoms/button';
+import useCustomSwr from '~/lib/client/hooks/use-custom-swr';
+import { useConsoleApi } from '~/console/server/gql/api-provider';
+import { parseNodes } from '~/console/server/r-utils/common';
import { plans } from '../../../../new-app/datas';
const valueRender = ({
@@ -37,9 +40,22 @@ const valueRender = ({
};
const SettingCompute = () => {
- const { app, setApp, getContainer, activeContIndex } = useAppState();
+ const { app, setApp, getContainer, activeContIndex, getRepoMapper } =
+ useAppState();
const { setPerformAction, hasChanges, loading } = useUnsavedChanges();
+ const api = useConsoleApi();
+
+ const [accountName, setAccountName] = useState('');
+
+ const {
+ data,
+ isLoading: repoLoading,
+ error: repoLoadingError,
+ } = useCustomSwr('/repos', async () => {
+ return api.listRepo({});
+ });
+
const { values, errors, handleChange, submit, resetValues } = useForm({
initialValues: {
imageUrl: getContainer(0)?.image || '',
@@ -47,6 +63,11 @@ const SettingCompute = () => {
cpuMode: app.metadata?.annotations?.[keyconstants.cpuMode] || 'shared',
memPerCpu: app.metadata?.annotations?.[keyconstants.memPerCpu] || 1,
+ repoName: app.metadata?.annotations?.[keyconstants.repoName] || '',
+ repoImageTag: app.metadata?.annotations?.[keyconstants.imageTag] || '',
+ repoImageUrl: app.metadata?.annotations?.[keyconstants.repoImageUrl] || '',
+ image: app.metadata?.annotations?.[keyconstants.image] || '',
+
cpu: parseValue(
app.spec.containers[activeContIndex]?.resourceCpu?.max,
250
@@ -88,6 +109,10 @@ const SettingCompute = () => {
...(s.metadata?.annotations || {}),
[keyconstants.cpuMode]: val.cpuMode,
[keyconstants.selectedPlan]: val.selectedPlan,
+ [keyconstants.repoName]: val.repoName,
+ [keyconstants.imageTag]: val.repoImageTag,
+ [keyconstants.image]: val.image,
+ [keyconstants.repoImageUrl]: val.repoImageUrl,
},
},
spec: {
@@ -95,7 +120,8 @@ const SettingCompute = () => {
containers: [
{
...(s.spec.containers?.[0] || {}),
- image: val.imageUrl,
+ // image: val.imageUrl,
+ image: val.repoImageUrl == '' ? val.imageUrl : val.repoImageUrl,
name: 'container-0',
resourceCpu:
val.selectionMode === 'quick'
@@ -132,6 +158,25 @@ const SettingCompute = () => {
// );
// }, [values.cpuMode, values.selectedPlan]);
+ // const repository = useMapper(parseNodes(data), (val) => ({
+ // label: val.name,
+ // value: val.name,
+ // accName: val.accountName
+ // }));
+
+ const repos = getRepoMapper(data);
+
+ const {
+ data: digestData,
+ isLoading: digestLoading,
+ error: digestError,
+ } = useCustomSwr(
+ () => `/digests_${values.repoName}`,
+ async () => {
+ return api.listDigest({ repoName: values.repoName });
+ }
+ );
+
useEffect(() => {
submit();
}, [values]);
@@ -166,16 +211,18 @@ const SettingCompute = () => {
}}
>
-
- }
- size="lg"
- value={values.imageUrl}
- onChange={handleChange('imageUrl')}
- error={!!errors.imageUrl}
- message={errors.imageUrl}
- />
+ {!values.repoImageUrl && (
+
+ }
+ size="lg"
+ value={values.imageUrl}
+ onChange={handleChange('imageUrl')}
+ error={!!errors.imageUrl}
+ message={errors.imageUrl}
+ />
+ )}
{/*
@@ -186,6 +233,67 @@ const SettingCompute = () => {
// message={errors.pullSecret}
// onChange={handleChange('pullSecret')}
/> */}
+
+ {values.repoImageUrl && (
+
{/*
diff --git a/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/new-app/app-compute.tsx b/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/new-app/app-compute.tsx
index cf71f78d3..57d220cae 100644
--- a/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/new-app/app-compute.tsx
+++ b/web/src/apps/console/routes/_main+/$account+/$project+/$environment+/new-app/app-compute.tsx
@@ -10,6 +10,11 @@ import { InfoLabel } from '~/console/components/commons';
import { FadeIn, parseValue } from '~/console/page-components/util';
import Select from '~/components/atoms/select';
import ExtendedFilledTab from '~/console/components/extended-filled-tab';
+import { parseNodes } from '~/console/server/r-utils/common';
+import useCustomSwr from '~/lib/client/hooks/use-custom-swr';
+import { useConsoleApi } from '~/console/server/gql/api-provider';
+import { useMapper } from '~/components/utils';
+import { useState } from 'react';
import { plans } from './datas';
const valueRender = ({
@@ -36,6 +41,18 @@ const valueRender = ({
const AppCompute = () => {
const { app, setApp, setPage, markPageAsCompleted, activeContIndex } =
useAppState();
+ const api = useConsoleApi();
+
+ const [accountName, setAccountName] = useState('');
+ const [showImageUrl, setShowImageUrl] = useState(true);
+
+ const {
+ data,
+ isLoading: repoLoading,
+ error: repoLoadingError,
+ } = useCustomSwr('/repos', async () => {
+ return api.listRepo({});
+ });
const { values, errors, handleChange, isLoading, submit } = useForm({
initialValues: {
@@ -49,6 +66,11 @@ const AppCompute = () => {
250
),
+ repoName: app.metadata?.annotations?.[keyconstants.repoName] || '',
+ repoImageTag: app.metadata?.annotations?.[keyconstants.imageTag] || '',
+ repoImageUrl: app.metadata?.annotations?.[keyconstants.repoImageUrl] || '',
+ image: app.metadata?.annotations?.[keyconstants.image] || '',
+
selectedPlan:
app.metadata?.annotations[keyconstants.selectedPlan] || 'shared-1',
selectionMode:
@@ -71,7 +93,7 @@ const AppCompute = () => {
),
},
validationSchema: Yup.object({
- imageUrl: Yup.string().required(),
+ // imageUrl: Yup.string().required(),
pullSecret: Yup.string(),
cpuMode: Yup.string().required(),
selectedPlan: Yup.string().required(),
@@ -88,6 +110,10 @@ const AppCompute = () => {
[keyconstants.memPerCpu]: val.memPerCpu,
[keyconstants.selectionModeKey]: val.selectionMode,
[keyconstants.selectedPlan]: val.selectedPlan,
+ [keyconstants.repoName]: val.repoName,
+ [keyconstants.imageTag]: val.repoImageTag,
+ [keyconstants.image]: val.image,
+ [keyconstants.repoImageUrl]: val.repoImageUrl,
},
},
spec: {
@@ -95,7 +121,7 @@ const AppCompute = () => {
containers: [
{
...(s.spec.containers?.[0] || {}),
- image: val.imageUrl,
+ image: val.image === '' ? val.repoImageUrl : val.imageUrl,
name: 'container-0',
resourceCpu:
val.selectionMode === 'quick'
@@ -126,6 +152,23 @@ const AppCompute = () => {
},
});
+ const repos = useMapper(parseNodes(data), (val) => ({
+ label: val.name,
+ value: val.name,
+ accName: val.accountName,
+ }));
+
+ const {
+ data: digestData,
+ isLoading: digestLoading,
+ error: digestError,
+ } = useCustomSwr(
+ () => `/digests_${values.repoName}`,
+ async () => {
+ return api.listDigest({ repoName: values.repoName });
+ }
+ );
+
return (
{
@@ -145,16 +188,95 @@ const AppCompute = () => {
manipulation and calculations in a system.
-
- }
- size="lg"
- value={values.imageUrl}
- onChange={handleChange('imageUrl')}
- error={!!errors.imageUrl}
- message={errors.imageUrl}
+ {showImageUrl && (
+
+ }
+ size="lg"
+ value={values.image}
+ onChange={(e) => {
+ handleChange('imageUrl')(
+ dummyEvent(e.target.value.toLowerCase())
+ );
+ handleChange('image')(dummyEvent(e.target.value.toLowerCase()));
+ handleChange('repoName')(dummyEvent(''));
+ handleChange('repoImageTag')(dummyEvent(''));
+ }}
+ error={!!errors.imageUrl}
+ message={errors.imageUrl}
+ />
+ )}
+
+