mirror of
https://github.com/Unleash/unleash.git
synced 2025-02-23 00:22:19 +01:00
1-1307: Show info about flag naming patterns before making mistakes (#4616)
This PR adds info about a project's flag naming pattern to the flag creation form. This way, it's displayed before the user tries to create a flag, so that they have all the necessary information before making mistakes. data:image/s3,"s3://crabby-images/20d6c/20d6ca3dd93aca87a5f2673974b5514cc1c14834" alt="image"
This commit is contained in:
parent
0b8b772ff1
commit
1ffa0b86d9
@ -137,6 +137,7 @@ const CreateFeature = () => {
|
||||
handleCancel={handleCancel}
|
||||
mode="Create"
|
||||
clearErrors={clearErrors}
|
||||
featureNaming={projectInfo.featureNaming}
|
||||
>
|
||||
<CreateButton
|
||||
name="feature toggle"
|
||||
|
@ -21,6 +21,7 @@ import { CREATE_FEATURE } from 'component/providers/AccessProvider/permissions';
|
||||
import { useNavigate } from 'react-router-dom';
|
||||
import React from 'react';
|
||||
import { useAuthPermissions } from 'hooks/api/getters/useAuth/useAuthPermissions';
|
||||
import { FeatureNamingType } from 'interfaces/project';
|
||||
|
||||
interface IFeatureToggleForm {
|
||||
type: string;
|
||||
@ -33,6 +34,7 @@ interface IFeatureToggleForm {
|
||||
setDescription: React.Dispatch<React.SetStateAction<string>>;
|
||||
setProject: React.Dispatch<React.SetStateAction<string>>;
|
||||
setImpressionData: React.Dispatch<React.SetStateAction<boolean>>;
|
||||
featureNaming?: FeatureNamingType;
|
||||
validateToggleName?: () => void;
|
||||
handleSubmit: (e: any) => void;
|
||||
handleCancel: () => void;
|
||||
@ -80,6 +82,11 @@ const StyledTypeDescription = styled('p')(({ theme }) => ({
|
||||
position: 'relative',
|
||||
}));
|
||||
|
||||
const StyledFlagNamingInfo = styled('div')(({ theme }) => ({
|
||||
fontSize: theme.fontSizes.smallBody,
|
||||
color: theme.palette.text.secondary,
|
||||
}));
|
||||
|
||||
const StyledButtonContainer = styled('div')({
|
||||
marginTop: 'auto',
|
||||
display: 'flex',
|
||||
@ -111,6 +118,7 @@ const FeatureForm: React.FC<IFeatureToggleForm> = ({
|
||||
setDescription,
|
||||
setProject,
|
||||
validateToggleName,
|
||||
featureNaming,
|
||||
setImpressionData,
|
||||
impressionData,
|
||||
handleSubmit,
|
||||
@ -128,16 +136,52 @@ const FeatureForm: React.FC<IFeatureToggleForm> = ({
|
||||
return featureTypes.find(toggle => toggle.id === type)?.description;
|
||||
};
|
||||
|
||||
const displayFeatureNamingInfo = Boolean(featureNaming?.pattern);
|
||||
|
||||
return (
|
||||
<StyledForm onSubmit={handleSubmit}>
|
||||
<StyledContainer>
|
||||
<StyledInputDescription>
|
||||
What would you like to call your toggle?
|
||||
</StyledInputDescription>
|
||||
<ConditionallyRender
|
||||
condition={displayFeatureNamingInfo}
|
||||
show={
|
||||
<StyledFlagNamingInfo>
|
||||
<p>
|
||||
This project has feature flag naming patterns
|
||||
enabled.
|
||||
</p>
|
||||
<dl id="feature-naming-pattern-info">
|
||||
<dt>Pattern</dt>
|
||||
<dd>
|
||||
<code>{featureNaming?.pattern}</code>
|
||||
</dd>
|
||||
{Boolean(featureNaming?.example) && (
|
||||
<>
|
||||
<dt>Example</dt>
|
||||
<dd>{featureNaming?.example}</dd>
|
||||
</>
|
||||
)}
|
||||
{Boolean(featureNaming?.description) && (
|
||||
<>
|
||||
<dt>Description</dt>
|
||||
<dd>{featureNaming?.description}</dd>
|
||||
</>
|
||||
)}
|
||||
</dl>
|
||||
</StyledFlagNamingInfo>
|
||||
}
|
||||
/>
|
||||
<StyledInput
|
||||
autoFocus
|
||||
disabled={mode === 'Edit'}
|
||||
label="Name"
|
||||
aria-details={
|
||||
displayFeatureNamingInfo
|
||||
? 'feature-naming-pattern-info'
|
||||
: undefined
|
||||
}
|
||||
id="feature-toggle-name"
|
||||
error={Boolean(errors.name)}
|
||||
errorText={errors.name}
|
||||
|
@ -352,7 +352,7 @@ const ProjectForm: React.FC<IProjectForm> = ({
|
||||
label={'Naming Example'}
|
||||
name="feature flag naming example"
|
||||
type={'text'}
|
||||
aria-describedBy="pattern-additional-description"
|
||||
aria-describedby="pattern-additional-description"
|
||||
value={featureNamingExample || ''}
|
||||
placeholder="dx.feature1.1-135"
|
||||
error={Boolean(errors.namingExample)}
|
||||
@ -367,7 +367,7 @@ const ProjectForm: React.FC<IProjectForm> = ({
|
||||
label={'Naming pattern description'}
|
||||
name="feature flag naming description"
|
||||
type={'text'}
|
||||
aria-describedBy="pattern-additional-description"
|
||||
aria-describedby="pattern-additional-description"
|
||||
placeholder={`<project>.<featureName>.<ticket>
|
||||
|
||||
The flag name should contain the project name, the feature name, and the ticket number, each separated by a dot.`}
|
||||
|
Loading…
Reference in New Issue
Block a user