@devtron-labs/devtron-fe-common-lib 1.2.4-beta-3 → 1.2.4-beta-4
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/dist/{@code-editor-DT9fzrvW.js → @code-editor-Dl49eEEU.js} +5407 -5763
- package/dist/{@common-rjsf-DJXsw-P3.js → @common-rjsf-D7zjI7cT.js} +1 -1
- package/dist/Common/Common.service.d.ts +2 -1
- package/dist/Common/Constants.d.ts +0 -1
- package/dist/Common/CustomTagSelector/ResizableTagTextArea.d.ts +1 -1
- package/dist/Common/CustomTagSelector/Types.d.ts +14 -19
- package/dist/Common/Helper.d.ts +2 -3
- package/dist/Common/Types.d.ts +50 -59
- package/dist/Pages/Applications/DevtronApps/Details/CDPipeline/types.d.ts +1 -2
- package/dist/Shared/Components/FeatureDescription/FeatureDescriptionModal.d.ts +1 -1
- package/dist/Shared/Components/FeatureDescription/FeatureTitleWithInfo.d.ts +1 -1
- package/dist/Shared/Components/FeatureDescription/types.d.ts +34 -6
- package/dist/Shared/Components/SelectPicker/type.d.ts +4 -5
- package/dist/Shared/Components/index.d.ts +0 -1
- package/dist/Shared/Helpers.d.ts +4 -3
- package/dist/Shared/Services/app.types.d.ts +2 -1
- package/dist/Shared/constants.d.ts +7 -0
- package/dist/Shared/types.d.ts +17 -23
- package/dist/assets/@code-editor.css +1 -1
- package/dist/index.js +352 -351
- package/package.json +2 -2
- package/dist/Shared/Components/DynamicDataTable/DynamicDataTable.d.ts +0 -2
- package/dist/Shared/Components/DynamicDataTable/DynamicDataTableHeader.d.ts +0 -2
- package/dist/Shared/Components/DynamicDataTable/DynamicDataTableRow.d.ts +0 -2
- package/dist/Shared/Components/DynamicDataTable/index.d.ts +0 -2
- package/dist/Shared/Components/DynamicDataTable/types.d.ts +0 -165
- package/dist/Shared/Components/DynamicDataTable/utils.d.ts +0 -5
- package/dist/Shared/Components/SelectTextArea/SelectTextArea.d.ts +0 -2
- package/dist/Shared/Components/SelectTextArea/index.d.ts +0 -2
- package/dist/Shared/Components/SelectTextArea/types.d.ts +0 -12
- package/dist/assets/ic-clear-square.e60de021.svg +0 -1
- /package/dist/assets/{ic-arrow-square-out.1be837ac.svg → ic-arrow-square-out.3d1a0d41.svg} +0 -0
@@ -2,7 +2,7 @@ import { j as n, J as A } from "./@vendor-RU8AW1bK.js";
|
|
2
2
|
import E, { forwardRef as $ } from "react";
|
3
3
|
import L, { getDefaultRegistry as k } from "@rjsf/core";
|
4
4
|
import D from "@rjsf/validator-ajv8";
|
5
|
-
import { T as y, c as H, a as J, d as w } from "./@code-editor-
|
5
|
+
import { T as y, c as H, a as J, d as w } from "./@code-editor-Dl49eEEU.js";
|
6
6
|
import M, { components as O } from "react-select";
|
7
7
|
import { getUiOptions as B, getTemplate as I, getSubmitButtonOptions as U, ADDITIONAL_PROPERTY_FLAG as P, errorId as W, englishStringTranslator as V, TranslatableString as q, titleId as K, canExpand as Y, deepEquals as z } from "@rjsf/utils";
|
8
8
|
import { ReactComponent as G } from "./assets/ic-chevron-down.fc70d7a7.svg";
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { RuntimeParamsAPIResponseType, RuntimeParamsListItemType } from '../Shared/types';
|
2
|
-
import { TeamList, ResponseType, DeploymentNodeType, CDMaterialServiceEnum, CDMaterialServiceQueryParams, CDMaterialResponseType, CDMaterialFilterQuery, EnvironmentListHelmResponse } from './Types';
|
2
|
+
import { TeamList, ResponseType, DeploymentNodeType, CDMaterialServiceEnum, CDMaterialServiceQueryParams, CDMaterialResponseType, CDMaterialFilterQuery, EnvironmentListHelmResponse, UserApprovalMetadataType } from './Types';
|
3
3
|
import { ApiResourceType } from '../Pages';
|
4
4
|
export declare const getTeamListMin: () => Promise<TeamList>;
|
5
5
|
interface UserRole extends ResponseType {
|
@@ -15,6 +15,7 @@ export declare const SourceTypeMap: {
|
|
15
15
|
};
|
16
16
|
export declare function getUserRole(appName?: string): Promise<UserRole>;
|
17
17
|
export declare function setImageTags(request: any, pipelineId: number, artifactId: number): Promise<ResponseType<any>>;
|
18
|
+
export declare const sanitizeUserApprovalMetadata: (userApprovalMetadata: UserApprovalMetadataType) => UserApprovalMetadataType;
|
18
19
|
export declare const parseRuntimeParams: (response: RuntimeParamsAPIResponseType) => RuntimeParamsListItemType[];
|
19
20
|
export declare const processCDMaterialServiceResponse: (cdMaterialsResult: any, stage: DeploymentNodeType, offset: number, filter: CDMaterialFilterQuery, disableDefaultSelection?: boolean) => CDMaterialResponseType;
|
20
21
|
export declare const genericCDMaterialsService: (serviceType: CDMaterialServiceEnum, cdMaterialID: number, stage: DeploymentNodeType, signal: AbortSignal, queryParams?: CDMaterialServiceQueryParams) => Promise<CDMaterialResponseType>;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ResizableTagTextAreaProps } from './Types';
|
2
|
-
export declare const ResizableTagTextArea: ({
|
2
|
+
export declare const ResizableTagTextArea: ({ className, minHeight, maxHeight, value, onChange, onBlur, onFocus, placeholder, tabIndex, refVar, dependentRef, dataTestId, handleKeyDown, disabled, disableOnBlurResizeToMinHeight, }: ResizableTagTextAreaProps) => JSX.Element;
|
@@ -1,20 +1,9 @@
|
|
1
|
-
import { DetailedHTMLProps, MutableRefObject, TextareaHTMLAttributes } from 'react';
|
2
1
|
import { KEY_VALUE } from '../Constants';
|
3
2
|
import { OptionType } from '../Types';
|
4
3
|
export interface SuggestedTagOptionType extends OptionType {
|
5
4
|
description: string;
|
6
5
|
propagate: boolean;
|
7
6
|
}
|
8
|
-
export declare enum DeploymentPolicy {
|
9
|
-
ALLOW = "allow",
|
10
|
-
BLOCK = "block",
|
11
|
-
BLOCK_PROD = "block-prod",
|
12
|
-
BLOCK_NON_PROD = "block-non-prod"
|
13
|
-
}
|
14
|
-
export interface VariableValueConstraintTypes {
|
15
|
-
choices?: string[];
|
16
|
-
blockCustomValue?: boolean;
|
17
|
-
}
|
18
7
|
export interface TagType {
|
19
8
|
id?: number;
|
20
9
|
key: string;
|
@@ -26,8 +15,6 @@ export interface TagType {
|
|
26
15
|
isInvalidValue?: boolean;
|
27
16
|
isSuggested?: boolean;
|
28
17
|
isPropagateDisabled?: boolean;
|
29
|
-
deploymentPolicy?: DeploymentPolicy;
|
30
|
-
valueConstraint?: VariableValueConstraintTypes;
|
31
18
|
}
|
32
19
|
export interface TagErrorType {
|
33
20
|
isValid: boolean;
|
@@ -61,16 +48,24 @@ export interface TagLabelValueSelectorType {
|
|
61
48
|
tagInputType?: KEY_VALUE;
|
62
49
|
placeholder?: string;
|
63
50
|
tabIndex?: number;
|
64
|
-
refVar?: MutableRefObject<HTMLTextAreaElement>;
|
65
|
-
dependentRef?: MutableRefObject<HTMLTextAreaElement>;
|
51
|
+
refVar?: React.MutableRefObject<HTMLTextAreaElement>;
|
52
|
+
dependentRef?: React.MutableRefObject<HTMLTextAreaElement>;
|
66
53
|
noBackDrop?: boolean;
|
67
54
|
}
|
68
|
-
export interface ResizableTagTextAreaProps
|
55
|
+
export interface ResizableTagTextAreaProps {
|
56
|
+
className?: string;
|
69
57
|
minHeight?: number;
|
70
58
|
maxHeight?: number;
|
71
|
-
value
|
72
|
-
|
73
|
-
|
59
|
+
value?: string;
|
60
|
+
onChange?: (e: any) => void;
|
61
|
+
onBlur?: (e: any) => void;
|
62
|
+
onFocus?: (e: any) => void;
|
63
|
+
placeholder?: string;
|
64
|
+
tabIndex?: number;
|
65
|
+
refVar?: React.MutableRefObject<HTMLTextAreaElement>;
|
66
|
+
dependentRef?: React.MutableRefObject<HTMLTextAreaElement>;
|
74
67
|
dataTestId?: string;
|
68
|
+
handleKeyDown?: any;
|
69
|
+
disabled?: boolean;
|
75
70
|
disableOnBlurResizeToMinHeight?: boolean;
|
76
71
|
}
|
package/dist/Common/Helper.d.ts
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { default as React, SyntheticEvent } from 'react';
|
2
2
|
import { JSONPathOptions } from 'jsonpath-plus';
|
3
|
-
import { AsyncOptions,
|
3
|
+
import { AsyncOptions, UseSearchString } from './Types';
|
4
4
|
import { scrollableInterface } from '../Shared';
|
5
5
|
export declare function showError(serverError: any, showToastOnUnknownError?: boolean, hideAccessError?: boolean): void;
|
6
6
|
interface ConditionalWrapper<T> {
|
@@ -9,7 +9,7 @@ interface ConditionalWrapper<T> {
|
|
9
9
|
children: T;
|
10
10
|
}
|
11
11
|
export declare const ConditionalWrap: React.FC<ConditionalWrapper<any>>;
|
12
|
-
export declare function sortCallback(key: string, a: any, b: any, isCaseSensitive?: boolean):
|
12
|
+
export declare function sortCallback(key: string, a: any, b: any, isCaseSensitive?: boolean): 1 | -1 | 0;
|
13
13
|
export declare const stopPropagation: (event: any) => void;
|
14
14
|
export declare const preventDefault: (event: SyntheticEvent) => void;
|
15
15
|
export declare function useThrottledEffect(callback: any, delay: any, deps?: any[]): void;
|
@@ -133,5 +133,4 @@ export declare const getSanitizedIframe: (iframeString: string) => string;
|
|
133
133
|
* This method adds default attributes to iframe - title, loading ="lazy", width="100%", height="100%"
|
134
134
|
*/
|
135
135
|
export declare const getIframeWithDefaultAttributes: (iframeString: string, defaultName?: string) => string;
|
136
|
-
export declare const getStageTitle: (stageType: DeploymentNodeType) => string;
|
137
136
|
export {};
|
package/dist/Common/Types.d.ts
CHANGED
@@ -1,9 +1,8 @@
|
|
1
1
|
import { default as React, ReactNode, CSSProperties, ReactElement, MutableRefObject } from 'react';
|
2
2
|
import { TippyProps } from '@tippyjs/react';
|
3
|
-
import { Placement } from 'tippy.js';
|
4
3
|
import { UserGroupDTO } from '../Pages/GlobalConfigurations';
|
5
4
|
import { ImageComment, ReleaseTag } from './ImageTags.Types';
|
6
|
-
import { MandatoryPluginBaseStateType,
|
5
|
+
import { MandatoryPluginBaseStateType, RegistryType, RuntimeParamsListItemType, Severity } from '../Shared';
|
7
6
|
import { ACTION_STATE, DEPLOYMENT_WINDOW_TYPE, DockerConfigOverrideType, SortingOrder, TaskErrorObj } from '.';
|
8
7
|
/**
|
9
8
|
* Generic response type object with support for overriding the result type
|
@@ -74,7 +73,7 @@ export interface TippyCustomizedProps extends Pick<TippyProps, 'appendTo'> {
|
|
74
73
|
noHeadingBorder?: boolean;
|
75
74
|
infoTextHeading?: string;
|
76
75
|
hideHeading?: boolean;
|
77
|
-
placement?:
|
76
|
+
placement?: TippyProps['placement'];
|
78
77
|
className?: string;
|
79
78
|
Icon?: React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
|
80
79
|
iconPath?: string;
|
@@ -274,21 +273,6 @@ export declare enum ManualApprovalType {
|
|
274
273
|
any = "ANY",
|
275
274
|
notConfigured = "NOT_CONFIGURED"
|
276
275
|
}
|
277
|
-
export interface UserGroupApproverType {
|
278
|
-
email: string;
|
279
|
-
hasAccess: boolean;
|
280
|
-
}
|
281
|
-
export interface ImageApprovalPolicyUserGroupDataType {
|
282
|
-
dataStore: Record<string, UserGroupApproverType>;
|
283
|
-
requiredCount: number;
|
284
|
-
emails: string[];
|
285
|
-
}
|
286
|
-
export interface ImageApprovalPolicyType {
|
287
|
-
isPolicyConfigured: boolean;
|
288
|
-
specificUsersData: ImageApprovalPolicyUserGroupDataType;
|
289
|
-
userGroupData: Record<string, ImageApprovalPolicyUserGroupDataType>;
|
290
|
-
validGroups: string[];
|
291
|
-
}
|
292
276
|
export type ImageApprovalUsersInfoDTO = Record<string, Pick<UserGroupDTO, 'identifier' | 'name'>[]>;
|
293
277
|
export interface UserApprovalConfigType {
|
294
278
|
type: ManualApprovalType;
|
@@ -301,13 +285,6 @@ export interface UserApprovalConfigType {
|
|
301
285
|
requiredCount: number;
|
302
286
|
})[];
|
303
287
|
}
|
304
|
-
export type UserApprovalConfigPayloadType = ({
|
305
|
-
type: ManualApprovalType.any;
|
306
|
-
} & Pick<UserApprovalConfigType, 'requiredCount'>) | ({
|
307
|
-
type: ManualApprovalType.specific;
|
308
|
-
} & Pick<UserApprovalConfigType, 'userGroups' | 'specificUsers'>) | {
|
309
|
-
type: ManualApprovalType.notConfigured;
|
310
|
-
};
|
311
288
|
interface ApprovalUserDataType {
|
312
289
|
dataId: number;
|
313
290
|
userActionTime: string;
|
@@ -317,12 +294,45 @@ interface ApprovalUserDataType {
|
|
317
294
|
userResponse: number;
|
318
295
|
userGroups?: Pick<UserGroupDTO, 'identifier' | 'name'>[];
|
319
296
|
}
|
297
|
+
export interface UserApprovalInfo {
|
298
|
+
requiredCount: number;
|
299
|
+
currentCount: number;
|
300
|
+
approverList: {
|
301
|
+
hasApproved: boolean;
|
302
|
+
canApprove: boolean;
|
303
|
+
identifier: string;
|
304
|
+
}[];
|
305
|
+
}
|
306
|
+
export declare enum ApprovalConfigDataKindType {
|
307
|
+
configMap = "configuration/config-map",
|
308
|
+
configSecret = "configuration/config-secret",
|
309
|
+
deploymentTemplate = "configuration/deployment-template",
|
310
|
+
deploymentTrigger = "approval/deployment"
|
311
|
+
}
|
312
|
+
export interface ApprovalConfigDataType extends Pick<UserApprovalInfo, 'currentCount' | 'requiredCount'> {
|
313
|
+
kind: ApprovalConfigDataKindType | null;
|
314
|
+
anyUserApprovedInfo: UserApprovalInfo;
|
315
|
+
specificUsersApprovedInfo: UserApprovalInfo;
|
316
|
+
userGroupsApprovedInfo: Pick<UserApprovalInfo, 'currentCount' | 'requiredCount'> & {
|
317
|
+
userGroups: (UserApprovalInfo & {
|
318
|
+
groupIdentifier: UserGroupDTO['identifier'];
|
319
|
+
groupName: UserGroupDTO['name'];
|
320
|
+
})[];
|
321
|
+
};
|
322
|
+
}
|
323
|
+
export declare enum ApprovalRuntimeStateType {
|
324
|
+
init = 0,
|
325
|
+
requested = 1,
|
326
|
+
approved = 2,
|
327
|
+
consumed = 3
|
328
|
+
}
|
320
329
|
export interface UserApprovalMetadataType {
|
321
330
|
approvalRequestId: number;
|
322
|
-
approvalRuntimeState:
|
323
|
-
approvedUsersData: ApprovalUserDataType[];
|
331
|
+
approvalRuntimeState: ApprovalRuntimeStateType;
|
324
332
|
requestedUserData: ApprovalUserDataType;
|
325
|
-
|
333
|
+
hasCurrentUserApproved: boolean;
|
334
|
+
canCurrentUserApprove: boolean;
|
335
|
+
approvalConfigData: ApprovalConfigDataType;
|
326
336
|
}
|
327
337
|
export declare enum FilterStates {
|
328
338
|
ALLOWED = 0,
|
@@ -379,7 +389,6 @@ export interface CDMaterialListModalServiceUtilProps {
|
|
379
389
|
artifactId?: number;
|
380
390
|
artifactStatus?: string;
|
381
391
|
disableDefaultSelection?: boolean;
|
382
|
-
userApprovalConfig?: UserApprovalConfigType;
|
383
392
|
}
|
384
393
|
export interface CDMaterialType {
|
385
394
|
index: number;
|
@@ -432,10 +441,6 @@ export interface CDMaterialType {
|
|
432
441
|
* Would currently only be received in case of release
|
433
442
|
*/
|
434
443
|
appWorkflowId: number;
|
435
|
-
/**
|
436
|
-
* Denotes trigger blocking due to mandatory tags, (might be used for plugins and other features in future)
|
437
|
-
*/
|
438
|
-
deploymentBlockedState?: PolicyBlockInfo;
|
439
444
|
}
|
440
445
|
export declare enum CDMaterialServiceEnum {
|
441
446
|
ROLLBACK = "rollback",
|
@@ -472,14 +477,6 @@ export interface DownstreamNodesEnvironmentsType {
|
|
472
477
|
environmentId: number;
|
473
478
|
environmentName: string;
|
474
479
|
}
|
475
|
-
export declare enum TriggerBlockType {
|
476
|
-
MANDATORY_TAG = "mandatory-tags",
|
477
|
-
MANDATORY_PLUGIN = "mandatory-plugins"
|
478
|
-
}
|
479
|
-
export interface TriggerBlockedInfo {
|
480
|
-
blockedBy: TriggerBlockType;
|
481
|
-
blockedReason?: string;
|
482
|
-
}
|
483
480
|
export interface CommonNodeAttr extends Pick<MandatoryPluginBaseStateType, 'isTriggerBlocked' | 'pluginBlockState'> {
|
484
481
|
connectingCiPipelineId?: number;
|
485
482
|
parents: string | number[] | string[];
|
@@ -527,8 +524,7 @@ export interface CommonNodeAttr extends Pick<MandatoryPluginBaseStateType, 'isTr
|
|
527
524
|
primaryBranchAfterRegex?: string;
|
528
525
|
storageConfigured?: boolean;
|
529
526
|
deploymentAppDeleteRequest?: boolean;
|
530
|
-
|
531
|
-
userApprovalConfig?: UserApprovalConfigType;
|
527
|
+
approvalConfigData: ApprovalConfigDataType;
|
532
528
|
requestedUserId?: number;
|
533
529
|
showPluginWarning: boolean;
|
534
530
|
helmPackageName?: string;
|
@@ -542,7 +538,6 @@ export interface CommonNodeAttr extends Pick<MandatoryPluginBaseStateType, 'isTr
|
|
542
538
|
downstreamEnvironments?: DownstreamNodesEnvironmentsType[];
|
543
539
|
cipipelineId?: number;
|
544
540
|
isDeploymentBlocked?: boolean;
|
545
|
-
triggerBlockedInfo?: TriggerBlockedInfo;
|
546
541
|
}
|
547
542
|
export declare enum DeploymentAppTypes {
|
548
543
|
HELM = "helm",
|
@@ -586,14 +581,17 @@ export interface FilterConditionsListType {
|
|
586
581
|
description: string;
|
587
582
|
conditions: FilterConditionsInfo[];
|
588
583
|
}
|
584
|
+
export interface DeploymentApprovalInfoType {
|
585
|
+
eligibleApprovers: {
|
586
|
+
specificUsers: Pick<UserApprovalInfo, 'approverList'>;
|
587
|
+
anyUsers: Pick<UserApprovalInfo, 'approverList'>;
|
588
|
+
userGroups: (Pick<ApprovalConfigDataType['userGroupsApprovedInfo']['userGroups'][number], 'groupIdentifier' | 'groupName'> & Pick<UserApprovalInfo, 'approverList'>)[];
|
589
|
+
};
|
590
|
+
approvalConfigData: ApprovalConfigDataType;
|
591
|
+
}
|
589
592
|
export interface CDMaterialsApprovalInfo {
|
590
|
-
approvalUsers: string[];
|
591
|
-
userApprovalConfig: UserApprovalConfigType;
|
592
593
|
canApproverDeploy: boolean;
|
593
|
-
|
594
|
-
* Only available incase of approvals do'nt use in cd materials or any other flow since approvalUsers are not present there
|
595
|
-
*/
|
596
|
-
imageApprovalPolicyDetails: ImageApprovalPolicyType;
|
594
|
+
deploymentApprovalInfo: DeploymentApprovalInfoType;
|
597
595
|
}
|
598
596
|
export interface CDMaterialsMetaInfo {
|
599
597
|
tagsEditable: boolean;
|
@@ -606,7 +604,6 @@ export interface CDMaterialsMetaInfo {
|
|
606
604
|
*/
|
607
605
|
requestedUserId: number;
|
608
606
|
runtimeParams: RuntimeParamsListItemType[];
|
609
|
-
deploymentBlockedState?: PolicyBlockInfo;
|
610
607
|
}
|
611
608
|
export interface ImagePromotionMaterialInfo {
|
612
609
|
isApprovalPendingForPromotion: boolean;
|
@@ -673,7 +670,6 @@ export interface AppEnvironment {
|
|
673
670
|
appStatus?: string;
|
674
671
|
deploymentAppDeleteRequest?: boolean;
|
675
672
|
isVirtualEnvironment?: boolean;
|
676
|
-
isProtected?: boolean;
|
677
673
|
pipelineId?: number;
|
678
674
|
latestCdWorkflowRunnerId?: number;
|
679
675
|
commits?: string[];
|
@@ -689,7 +685,6 @@ export interface CDStage {
|
|
689
685
|
name: string;
|
690
686
|
triggerType: 'AUTOMATIC' | 'MANUAL';
|
691
687
|
config: string;
|
692
|
-
triggerBlockedInfo?: TriggerBlockedInfo;
|
693
688
|
}
|
694
689
|
export interface CDStageConfigMapSecretNames {
|
695
690
|
configMaps: any[];
|
@@ -701,7 +696,6 @@ export interface PrePostDeployStageType extends MandatoryPluginBaseStateType {
|
|
701
696
|
triggerType: string;
|
702
697
|
name: string;
|
703
698
|
status: string;
|
704
|
-
triggerBlockedInfo?: TriggerBlockedInfo;
|
705
699
|
}
|
706
700
|
export interface CdPipeline {
|
707
701
|
id: number;
|
@@ -726,7 +720,6 @@ export interface CdPipeline {
|
|
726
720
|
parentPipelineType?: string;
|
727
721
|
deploymentAppDeleteRequest?: boolean;
|
728
722
|
deploymentAppCreated?: boolean;
|
729
|
-
userApprovalConfig?: UserApprovalConfigType;
|
730
723
|
isVirtualEnvironment?: boolean;
|
731
724
|
deploymentAppType: DeploymentAppTypes;
|
732
725
|
helmPackageName?: string;
|
@@ -735,8 +728,7 @@ export interface CdPipeline {
|
|
735
728
|
isProdEnv?: boolean;
|
736
729
|
isGitOpsRepoNotConfigured?: boolean;
|
737
730
|
isDeploymentBlocked?: boolean;
|
738
|
-
|
739
|
-
triggerBlockedInfo?: TriggerBlockedInfo;
|
731
|
+
approvalConfigData: ApprovalConfigDataType;
|
740
732
|
}
|
741
733
|
export interface ExternalCiConfig {
|
742
734
|
id: number;
|
@@ -838,12 +830,11 @@ export interface Point {
|
|
838
830
|
export interface EdgeNodeType {
|
839
831
|
height: number;
|
840
832
|
width: number;
|
841
|
-
userApprovalConfig?: UserApprovalConfigType;
|
842
833
|
type?: any;
|
843
834
|
id?: number | string;
|
844
835
|
}
|
845
836
|
export interface EdgeEndNodeType extends EdgeNodeType {
|
846
|
-
|
837
|
+
approvalConfigData: ApprovalConfigDataType;
|
847
838
|
}
|
848
839
|
/**
|
849
840
|
* Search params for sorting configuration
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { BuildStageType, FormType } from '../../../../../Common/CIPipeline.Types';
|
2
|
-
import { DeploymentAppTypes
|
2
|
+
import { DeploymentAppTypes } from '../../../../../Common/Types';
|
3
3
|
import { DeploymentStrategy } from '../../../../../Shared/Components';
|
4
4
|
import { EnvListMinDTO } from '../../../../../Shared/types';
|
5
5
|
interface ConfigSecretType {
|
@@ -53,7 +53,6 @@ export interface CDFormType {
|
|
53
53
|
secrets: ConfigSecretType[];
|
54
54
|
};
|
55
55
|
requiredApprovals: string;
|
56
|
-
userApprovalConfig?: UserApprovalConfigType;
|
57
56
|
isClusterCdActive: boolean;
|
58
57
|
deploymentAppCreated: boolean;
|
59
58
|
clusterId: string;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { FeatureDescriptionModalProps } from './types';
|
2
|
-
export declare const FeatureDescriptionModal: ({ title, renderDescriptionContent, closeModalText, docLink, closeModal, imageVariant, SVGImage, imageStyles, }: FeatureDescriptionModalProps) => JSX.Element;
|
2
|
+
export declare const FeatureDescriptionModal: ({ title, renderDescriptionContent, closeModalText, docLink, closeModal, imageVariant, SVGImage, imageStyles, tabsConfig, }: FeatureDescriptionModalProps) => JSX.Element;
|
@@ -1,3 +1,3 @@
|
|
1
1
|
import { DescriptorProps } from './types';
|
2
|
-
declare const FeatureTitleWithInfo: ({ additionalContainerClasses, breadCrumbs, children, iconClassName, title, renderDescriptionContent, closeModalText, docLink, SVGImage, showInfoIconTippy, docLinkText, dataTestId, additionalContent, showInfoIcon, }: DescriptorProps) => JSX.Element;
|
2
|
+
declare const FeatureTitleWithInfo: ({ additionalContainerClasses, breadCrumbs, children, iconClassName, title, renderDescriptionContent, closeModalText, docLink, SVGImage, showInfoIconTippy, docLinkText, dataTestId, additionalContent, showInfoIcon, tabsConfig, }: DescriptorProps) => JSX.Element;
|
3
3
|
export default FeatureTitleWithInfo;
|
@@ -1,17 +1,44 @@
|
|
1
1
|
import { default as React, ReactNode } from 'react';
|
2
2
|
import { ImageType } from '../../../Common';
|
3
3
|
import { Breadcrumb } from '../../../Common/BreadCrumb/Types';
|
4
|
-
|
5
|
-
title: string;
|
4
|
+
interface BaseFeatureDescriptionModalProps {
|
6
5
|
renderDescriptionContent?: () => ReactNode;
|
7
|
-
closeModalText?: string;
|
8
6
|
docLink?: string;
|
9
|
-
closeModal?: () => void;
|
10
7
|
imageVariant?: ImageType;
|
11
8
|
SVGImage?: React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
|
12
9
|
imageStyles?: React.CSSProperties;
|
13
10
|
}
|
14
|
-
|
11
|
+
type FeatureDescriptionModalWithTabsConfig = {
|
12
|
+
/**
|
13
|
+
* If provided, tabs are shown and have higher precedence over normal modal
|
14
|
+
*/
|
15
|
+
tabsConfig: ({
|
16
|
+
/**
|
17
|
+
* Unique id of the tab
|
18
|
+
*/
|
19
|
+
id: string;
|
20
|
+
/**
|
21
|
+
* Title for the tab
|
22
|
+
*/
|
23
|
+
title: string;
|
24
|
+
} & BaseFeatureDescriptionModalProps)[];
|
25
|
+
} & {
|
26
|
+
renderDescriptionContent?: never;
|
27
|
+
docLink?: never;
|
28
|
+
imageVariant?: never;
|
29
|
+
SVGImage?: never;
|
30
|
+
imageStyles?: never;
|
31
|
+
};
|
32
|
+
export type FeatureDescriptionModalProps = {
|
33
|
+
title: string;
|
34
|
+
closeModalText?: string;
|
35
|
+
closeModal?: () => void;
|
36
|
+
} & ((BaseFeatureDescriptionModalProps & {
|
37
|
+
tabsConfig?: never;
|
38
|
+
}) | FeatureDescriptionModalWithTabsConfig);
|
39
|
+
export type DescriptorProps = ((Omit<FeatureDescriptionModalProps, 'tabsConfig'> & {
|
40
|
+
tabsConfig?: never;
|
41
|
+
}) | (Pick<FeatureDescriptionModalProps, 'title' | 'closeModalText' | 'closeModal'> & FeatureDescriptionModalWithTabsConfig)) & {
|
15
42
|
breadCrumbs?: Breadcrumb[];
|
16
43
|
additionalContainerClasses?: string;
|
17
44
|
iconClassName?: string;
|
@@ -26,4 +53,5 @@ export interface DescriptorProps extends FeatureDescriptionModalProps {
|
|
26
53
|
* @default false
|
27
54
|
*/
|
28
55
|
showInfoIcon?: boolean;
|
29
|
-
}
|
56
|
+
};
|
57
|
+
export {};
|
@@ -24,10 +24,6 @@ export interface SelectPickerOptionType<OptionValue = string | number> extends O
|
|
24
24
|
tooltipProps?: Omit<TooltipProps, 'alwaysShowTippyOnHover' | 'showOnTruncate' | 'shortcutKeyCombo'> | (Omit<TooltipProps, 'alwaysShowTippyOnHover' | 'showOnTruncate' | 'content'> & Required<Pick<TooltipProps, 'shortcutKeyCombo'>>);
|
25
25
|
}
|
26
26
|
type SelectProps<OptionValue, IsMulti extends boolean> = ReactSelectProps<SelectPickerOptionType<OptionValue>, IsMulti, GroupBase<SelectPickerOptionType<OptionValue>>>;
|
27
|
-
export declare enum SelectPickerVariantType {
|
28
|
-
DEFAULT = "default",
|
29
|
-
BORDER_LESS = "border-less"
|
30
|
-
}
|
31
27
|
declare module 'react-select/base' {
|
32
28
|
interface Props<Option, IsMulti extends boolean, Group extends GroupBase<Option>> {
|
33
29
|
/**
|
@@ -59,9 +55,12 @@ declare module 'react-select/base' {
|
|
59
55
|
* @default 'true'
|
60
56
|
*/
|
61
57
|
showSelectedOptionIcon?: boolean;
|
62
|
-
variant?: SelectPickerVariantType;
|
63
58
|
}
|
64
59
|
}
|
60
|
+
export declare enum SelectPickerVariantType {
|
61
|
+
DEFAULT = "default",
|
62
|
+
BORDER_LESS = "border-less"
|
63
|
+
}
|
65
64
|
export type SelectPickerProps<OptionValue = number | string, IsMulti extends boolean = false> = Pick<SelectProps<OptionValue, IsMulti>, 'name' | 'classNamePrefix' | 'options' | 'value' | 'onChange' | 'isSearchable' | 'isClearable' | 'hideSelectedOptions' | 'controlShouldRenderValue' | 'closeMenuOnSelect' | 'isDisabled' | 'isLoading' | 'required' | 'isOptionDisabled' | 'placeholder' | 'menuPosition' | 'getOptionLabel' | 'getOptionValue' | 'isOptionSelected' | 'menuIsOpen' | 'onMenuOpen' | 'onMenuClose' | 'autoFocus' | 'onBlur' | 'onKeyDown' | 'formatOptionLabel' | 'onInputChange' | 'inputValue'> & Partial<Pick<SelectProps<OptionValue, IsMulti>, 'renderMenuListFooter' | 'shouldRenderCustomOptions' | 'renderCustomOptions' | 'icon' | 'showSelectedOptionIcon'>> & Required<Pick<SelectProps<OptionValue, IsMulti>, 'inputId'>> & Partial<Pick<CreatableProps<SelectPickerOptionType<OptionValue>, IsMulti, GroupBase<SelectPickerOptionType<OptionValue>>>, 'onCreateOption'>> & {
|
66
65
|
/**
|
67
66
|
* Error message for the select
|
package/dist/Shared/Helpers.d.ts
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
import { ReactElement } from 'react';
|
2
2
|
import { Pair } from 'yaml';
|
3
3
|
import { MaterialHistoryType } from '@Shared/Services/app.types';
|
4
|
-
import { MaterialInfo, SortingOrder, UserApprovalConfigType } from '../Common';
|
4
|
+
import { MaterialInfo, SortingOrder, UserApprovalConfigType, ApprovalConfigDataType, UserApprovalInfo } from '../Common';
|
5
5
|
import { GitTriggers, IntersectionChangeHandler, IntersectionOptions, PreventOutsideFocusProps, WebhookEventNameType } from './types';
|
6
6
|
import { AggregatedNodes, DeploymentStatusDetailsBreakdownDataType, DeploymentStatusDetailsType, PodMetadatum } from './Components';
|
7
7
|
interface HighlightSearchTextProps {
|
@@ -40,12 +40,13 @@ export declare const decode: (data: any, isEncoded?: boolean) => {};
|
|
40
40
|
export declare const isTimeStringAvailable: (time: string) => boolean;
|
41
41
|
export declare const getTimeDifference: (startTime: string, endTime: string) => string;
|
42
42
|
export declare const getFileNameFromHeaders: (headers: Headers) => string;
|
43
|
-
export declare const
|
43
|
+
export declare const sanitizeUserApprovalList: (approverList: UserApprovalInfo["approverList"]) => UserApprovalInfo["approverList"];
|
44
|
+
export declare const sanitizeApprovalConfigData: (approvalConfigData: ApprovalConfigDataType | null) => ApprovalConfigDataType;
|
44
45
|
/**
|
45
46
|
* Manual approval is considered configured only if the type is not notConfigured
|
46
47
|
*/
|
47
48
|
export declare const getIsManualApprovalConfigured: (userApprovalConfig?: Pick<UserApprovalConfigType, "type">) => boolean;
|
48
|
-
export declare const
|
49
|
+
export declare const getIsApprovalPolicyConfigured: (approvalConfigData: ApprovalConfigDataType) => boolean;
|
49
50
|
/**
|
50
51
|
* @description - Function to open a new tab with the given url
|
51
52
|
* @param url - url to be opened in new tab
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { ReleaseTag } from '../../Common';
|
1
|
+
import { ReleaseTag, UserApprovalMetadataType } from '../../Common';
|
2
2
|
interface WebhookDataType {
|
3
3
|
id: number;
|
4
4
|
eventActionType: string;
|
@@ -132,6 +132,7 @@ export interface DraftMetadataDTO {
|
|
132
132
|
commentsCount: number;
|
133
133
|
dataEncrypted: boolean;
|
134
134
|
isAppAdmin: boolean;
|
135
|
+
userApprovalMetadata: UserApprovalMetadataType;
|
135
136
|
}
|
136
137
|
export declare enum CMSecretExternalType {
|
137
138
|
Internal = "",
|
@@ -417,4 +417,11 @@ export declare const ALL_RESOURCE_KIND_FILTER = "all";
|
|
417
417
|
export declare const OPEN_NEW_TICKET = "https://enterprise.devtron.ai/portal/en/newticket";
|
418
418
|
export declare const VIEW_ALL_TICKETS = "https://enterprise.devtron.ai/portal/en/myarea";
|
419
419
|
export declare const RAISE_ISSUE = "https://github.com/devtron-labs/devtron/issues/new/choose";
|
420
|
+
export declare const TARGET_IDS: {
|
421
|
+
WORKFLOW_EDITOR_CONTAINER: string;
|
422
|
+
};
|
423
|
+
/**
|
424
|
+
* Env ID to get the data for base configuration
|
425
|
+
*/
|
426
|
+
export declare const BASE_CONFIGURATION_ENV_ID = -1;
|
420
427
|
export declare const DEVTRON_BASE_MAIN_ID = "devtron-base-main-identifier";
|
package/dist/Shared/types.d.ts
CHANGED
@@ -1,7 +1,8 @@
|
|
1
1
|
import { Dayjs } from 'dayjs';
|
2
|
-
import {
|
2
|
+
import { ApprovalConfigDataType } from '../Common/Types';
|
3
|
+
import { OptionType, CommonNodeAttr, ResponseType, VulnerabilityType, DeploymentAppTypes, ServerErrors, SortingParams } from '../Common';
|
3
4
|
import { KeyValueListType } from './Components';
|
4
|
-
import { EnvironmentTypeEnum, PatchOperationType } from './constants';
|
5
|
+
import { BASE_CONFIGURATION_ENV_ID, EnvironmentTypeEnum, PatchOperationType } from './constants';
|
5
6
|
export declare enum EnvType {
|
6
7
|
CHART = "helm_charts",
|
7
8
|
APPLICATION = "apps"
|
@@ -186,7 +187,7 @@ export interface AppDetails {
|
|
186
187
|
clusterName?: string;
|
187
188
|
dockerRegistryId?: string;
|
188
189
|
deploymentAppDeleteRequest?: boolean;
|
189
|
-
|
190
|
+
approvalConfigData?: ApprovalConfigDataType;
|
190
191
|
isVirtualEnvironment?: boolean;
|
191
192
|
imageTag?: string;
|
192
193
|
helmPackageName?: string;
|
@@ -246,7 +247,7 @@ export interface WorkflowType {
|
|
246
247
|
showTippy?: boolean;
|
247
248
|
appId?: number;
|
248
249
|
isSelected?: boolean;
|
249
|
-
approvalConfiguredIdsMap?: Record<number,
|
250
|
+
approvalConfiguredIdsMap?: Record<number, ApprovalConfigDataType>;
|
250
251
|
imageReleaseTags: string[];
|
251
252
|
appReleaseTags?: string[];
|
252
253
|
tagsEditable?: boolean;
|
@@ -403,7 +404,8 @@ export interface SeverityCount {
|
|
403
404
|
export declare enum PolicyKindType {
|
404
405
|
lockConfiguration = "lock-configuration",
|
405
406
|
imagePromotion = "image-promotion",
|
406
|
-
plugins = "plugin"
|
407
|
+
plugins = "plugin",
|
408
|
+
approval = "approval"
|
407
409
|
}
|
408
410
|
export interface LastExecutionResultType {
|
409
411
|
lastExecution: string;
|
@@ -735,26 +737,18 @@ export interface DynamicTabType extends CommonTabArgsType {
|
|
735
737
|
*/
|
736
738
|
lastActiveTabId: string | null;
|
737
739
|
}
|
740
|
+
export interface ResourceApprovalPolicyConfigDTO {
|
741
|
+
appId: number;
|
742
|
+
envId: number;
|
743
|
+
approvalConfigurations: ApprovalConfigDataType[];
|
744
|
+
}
|
745
|
+
export interface ResourceApprovalPolicyConfigType extends Omit<ResourceApprovalPolicyConfigDTO, 'state' | 'approvalConfigurations'> {
|
746
|
+
isApprovalApplicable: boolean;
|
747
|
+
approvalConfigurationMap: Record<ApprovalConfigDataType['kind'], ApprovalConfigDataType>;
|
748
|
+
}
|
749
|
+
export type ResourceIdToResourceApprovalPolicyConfigMapType = Record<ResourceApprovalPolicyConfigType['envId'] | typeof BASE_CONFIGURATION_ENV_ID, Pick<ResourceApprovalPolicyConfigType, 'isApprovalApplicable' | 'approvalConfigurationMap'>>;
|
738
750
|
export interface PreventOutsideFocusProps {
|
739
751
|
identifier: string;
|
740
752
|
preventFocus: boolean;
|
741
753
|
}
|
742
|
-
export interface PolicyBlockInfo {
|
743
|
-
isBlocked: boolean;
|
744
|
-
blockedBy: TriggerBlockType;
|
745
|
-
reason: string;
|
746
|
-
}
|
747
|
-
export interface PipelineStageBlockInfo {
|
748
|
-
node: PolicyBlockInfo;
|
749
|
-
pre: PolicyBlockInfo;
|
750
|
-
post: PolicyBlockInfo;
|
751
|
-
}
|
752
|
-
export interface PolicyConsequencesDTO {
|
753
|
-
cd: PipelineStageBlockInfo;
|
754
|
-
ci: PipelineStageBlockInfo;
|
755
|
-
}
|
756
|
-
export interface GetPolicyConsequencesProps {
|
757
|
-
appId: number;
|
758
|
-
envId: number;
|
759
|
-
}
|
760
754
|
export {};
|