From 404046190620d8c1fae68715815adf69e4a5cc76 Mon Sep 17 00:00:00 2001 From: Cristhian Castaneda Date: Tue, 10 Dec 2024 10:37:23 -0600 Subject: [PATCH] refactor(kubernetes): convert find artifacts from resource stage to react (#10157) --- packages/kubernetes/src/kubernetes.module.ts | 2 - .../FindArtifactsFromResourceConfig.tsx | 35 ++++++++++++++++++ .../FindArtifactsFromResourceStageForm.tsx | 37 +++++++++++++++++++ ...dArtifactsFromResourceConfig.controller.ts | 28 -------------- .../findArtifactsFromResourceConfig.html | 10 ----- .../findArtifactsFromResourceStage.ts | 36 +++++++----------- .../kubernetes/src/pipelines/stages/index.ts | 1 + 7 files changed, 86 insertions(+), 63 deletions(-) create mode 100644 packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceConfig.tsx create mode 100644 packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceStageForm.tsx delete mode 100644 packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.controller.ts delete mode 100644 packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.html diff --git a/packages/kubernetes/src/kubernetes.module.ts b/packages/kubernetes/src/kubernetes.module.ts index e9c436f5110..11b19a50951 100644 --- a/packages/kubernetes/src/kubernetes.module.ts +++ b/packages/kubernetes/src/kubernetes.module.ts @@ -31,7 +31,6 @@ import { KUBERNETES_MANIFEST_CONDITION } from './manifest/status/condition.compo import { KUBERNETES_MANIFEST_STATUS } from './manifest/status/status.component'; import { ManifestWizard } from './manifest/wizard/ManifestWizard'; import './pipelines/stages'; -import { KUBERNETES_FIND_ARTIFACTS_FROM_RESOURCE_STAGE } from './pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceStage'; import { KUBERNETES_DISABLE_MANIFEST_STAGE } from './pipelines/stages/traffic/disableManifest.stage'; import { KUBERNETES_ENABLE_MANIFEST_STAGE } from './pipelines/stages/traffic/enableManifest.stage'; import { KUBERNETES_UNDO_ROLLOUT_MANIFEST_STAGE } from './pipelines/stages/undoRolloutManifest/undoRolloutManifestStage'; @@ -73,7 +72,6 @@ const requires = [ KUBERNETES_LOAD_BALANCER_TRANSFORMER, KUBERNETES_SECURITY_GROUP_TRANSFORMER, KUBERNETES_UNDO_ROLLOUT_MANIFEST_STAGE, - KUBERNETES_FIND_ARTIFACTS_FROM_RESOURCE_STAGE, KUBERNETES_MANIFEST_SELECTOR, KUBERNETES_MANIFEST_LABELS, KUBERNETES_MANIFEST_EVENTS, diff --git a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceConfig.tsx b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceConfig.tsx new file mode 100644 index 00000000000..c8bc415e043 --- /dev/null +++ b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceConfig.tsx @@ -0,0 +1,35 @@ +import { defaults } from 'lodash'; +import { useEffect } from 'react'; +import React from 'react'; + +import type { IFormikStageConfigInjectedProps, IStageConfigProps } from '@spinnaker/core'; +import { FormikStageConfig } from '@spinnaker/core'; + +import { FindArtifactsFromResourceStageForm } from './FindArtifactsFromResourceStageForm'; + +export function FindArtifactsFromResourceConfig({ + application, + pipeline, + stage, + updateStage, + stageFieldUpdated, +}: IStageConfigProps) { + useEffect(() => { + defaults(stage, { + app: application.name, + cloudProvider: 'kubernetes', + }); + }, []); + + return ( + ( + + )} + /> + ); +} diff --git a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceStageForm.tsx b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceStageForm.tsx new file mode 100644 index 00000000000..9b4ad7f6e90 --- /dev/null +++ b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/FindArtifactsFromResourceStageForm.tsx @@ -0,0 +1,37 @@ +import React from 'react'; + +import type { IFormikStageConfigInjectedProps } from '@spinnaker/core'; + +import type { IManifestSelector } from '../../../manifest/selector/IManifestSelector'; +import { SelectorMode } from '../../../manifest/selector/IManifestSelector'; +import { ManifestSelector } from '../../../manifest/selector/ManifestSelector'; + +interface IFindArtifactsFromResourceStageConfigFormProps { + stageFieldUpdated: () => void; +} + +export function FindArtifactsFromResourceStageForm({ + application, + formik, + stageFieldUpdated, +}: IFindArtifactsFromResourceStageConfigFormProps & IFormikStageConfigInjectedProps) { + const stage = formik.values; + + const onManifestSelectorChange = () => { + stageFieldUpdated(); + }; + + return ( +
+

Manifest

+
+ +
+ ); +} diff --git a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.controller.ts b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.controller.ts deleted file mode 100644 index 6deb15b95de..00000000000 --- a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.controller.ts +++ /dev/null @@ -1,28 +0,0 @@ -import type { IController, IScope } from 'angular'; - -import type { Application } from '@spinnaker/core'; - -import type { IManifestSelector } from '../../../manifest/selector/IManifestSelector'; - -export class KubernetesV2FindArtifactsFromResourceConfigCtrl implements IController { - public application: Application; - - public static $inject = ['$scope']; - constructor(private $scope: IScope) { - this.application = this.$scope.$parent.application; - if (this.$scope.stage.isNew) { - const defaultSelection: IManifestSelector = { - location: '', - account: '', - manifestName: '', - app: this.application.name, - }; - Object.assign(this.$scope.stage, defaultSelection); - this.$scope.stage.cloudProvider = 'kubernetes'; - } - } - - public handleManifestSelectorChange = (): void => { - this.$scope.$applyAsync(); - }; -} diff --git a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.html b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.html deleted file mode 100644 index f9db76a02ac..00000000000 --- a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceConfig.html +++ /dev/null @@ -1,10 +0,0 @@ -
-

Manifest

-
- -
diff --git a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceStage.ts b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceStage.ts index 33a371b05a2..b51acf73dbb 100644 --- a/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceStage.ts +++ b/packages/kubernetes/src/pipelines/stages/findArtifactsFromResource/findArtifactsFromResourceStage.ts @@ -1,28 +1,18 @@ -import { module } from 'angular'; - import { ExecutionArtifactTab, ExecutionDetailsTasks, Registry } from '@spinnaker/core'; -import { KubernetesV2FindArtifactsFromResourceConfigCtrl } from './findArtifactsFromResourceConfig.controller'; -import { KUBERNETES_MANIFEST_SELECTOR } from '../../../manifest/selector/selector.component'; +import { FindArtifactsFromResourceConfig } from './FindArtifactsFromResourceConfig'; import { manifestSelectorValidators } from '../validators/manifestSelectorValidators'; -export const KUBERNETES_FIND_ARTIFACTS_FROM_RESOURCE_STAGE = - 'spinnaker.kubernetes.v2.pipeline.stage.findArtifactsFromResource'; - const STAGE_NAME = 'Find Artifacts From Resource (Manifest)'; -module(KUBERNETES_FIND_ARTIFACTS_FROM_RESOURCE_STAGE, [KUBERNETES_MANIFEST_SELECTOR]) - .config(() => { - Registry.pipeline.registerStage({ - label: STAGE_NAME, - description: 'Finds artifacts from a Kubernetes resource.', - key: 'findArtifactsFromResource', - cloudProvider: 'kubernetes', - templateUrl: require('./findArtifactsFromResourceConfig.html'), - controller: 'KubernetesV2FindArtifactsFromResourceConfigCtrl', - controllerAs: 'ctrl', - executionDetailsSections: [ExecutionDetailsTasks, ExecutionArtifactTab], - producesArtifacts: true, - validators: manifestSelectorValidators(STAGE_NAME), - }); - }) - .controller('KubernetesV2FindArtifactsFromResourceConfigCtrl', KubernetesV2FindArtifactsFromResourceConfigCtrl); +const STAGE_KEY = 'findArtifactsFromResource'; + +Registry.pipeline.registerStage({ + label: STAGE_NAME, + description: 'Finds artifacts from a Kubernetes resource.', + key: STAGE_KEY, + cloudProvider: 'kubernetes', + component: FindArtifactsFromResourceConfig, + executionDetailsSections: [ExecutionDetailsTasks, ExecutionArtifactTab], + producesArtifacts: true, + validators: manifestSelectorValidators(STAGE_NAME), +}); diff --git a/packages/kubernetes/src/pipelines/stages/index.ts b/packages/kubernetes/src/pipelines/stages/index.ts index e5a9696ce2c..fd647fcefb1 100644 --- a/packages/kubernetes/src/pipelines/stages/index.ts +++ b/packages/kubernetes/src/pipelines/stages/index.ts @@ -1,5 +1,6 @@ export * from './deleteManifest/deleteManifestStage'; export * from './deployManifest/deployManifestStage'; +export * from './findArtifactsFromResource/findArtifactsFromResourceStage'; export * from './patchManifest/patchManifestStage'; export * from './rolloutRestartManifest/rolloutRestartManifestStage'; export * from './runJob/runJobStage';