mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-25 00:07:47 +01:00
feat: store playground settings in local storage (#4012)
This commit is contained in:
parent
211d445c4d
commit
2e4f55707d
@ -0,0 +1,64 @@
|
||||
import { screen } from '@testing-library/react';
|
||||
import { render } from 'utils/testRenderer';
|
||||
import { UIProviderContainer } from '../../providers/UIProvider/UIProviderContainer';
|
||||
import AdvancedPlayground from './AdvancedPlayground';
|
||||
import { createLocalStorage } from 'utils/createLocalStorage';
|
||||
|
||||
const testComponent = (
|
||||
<UIProviderContainer>
|
||||
<AdvancedPlayground
|
||||
FormComponent={props => (
|
||||
<div>
|
||||
<div data-id="projects">
|
||||
{JSON.stringify(props.projects)}
|
||||
</div>
|
||||
<div data-id="environments">
|
||||
{JSON.stringify(props.environments)}
|
||||
</div>
|
||||
<div data-id="context">{JSON.stringify(props.context)}</div>
|
||||
</div>
|
||||
)}
|
||||
/>
|
||||
</UIProviderContainer>
|
||||
);
|
||||
|
||||
afterEach(() => {
|
||||
const { setValue } = createLocalStorage('AdvancedPlayground:v1', {});
|
||||
setValue({});
|
||||
});
|
||||
|
||||
test('should fetch initial form data from local storage', async () => {
|
||||
const { setValue } = createLocalStorage('AdvancedPlayground:v1', {});
|
||||
setValue({
|
||||
projects: ['projectA', 'projectB'],
|
||||
environments: ['development', 'production'],
|
||||
context: { userId: '1' },
|
||||
});
|
||||
|
||||
render(testComponent);
|
||||
|
||||
expect(screen.getByText('Unleash playground')).toBeInTheDocument();
|
||||
expect(screen.getByText('["projectA","projectB"]')).toBeInTheDocument();
|
||||
expect(
|
||||
screen.getByText('["development","production"]')
|
||||
).toBeInTheDocument();
|
||||
expect(screen.getByText('{"userId":"1"}')).toBeInTheDocument();
|
||||
});
|
||||
|
||||
test('should fetch initial form data from url', async () => {
|
||||
const { setValue } = createLocalStorage('AdvancedPlayground:v1', {});
|
||||
setValue({
|
||||
projects: ['projectA', 'projectB'],
|
||||
environments: ['development', 'production'],
|
||||
context: { userId: '1' },
|
||||
});
|
||||
|
||||
render(testComponent, {
|
||||
route: '/playground?context=customContext&environments=customEnv&projects=urlProject&sort=name',
|
||||
});
|
||||
|
||||
expect(screen.getByText('Unleash playground')).toBeInTheDocument();
|
||||
expect(screen.getByText('["urlProject"]')).toBeInTheDocument();
|
||||
expect(screen.getByText('["customEnv"]')).toBeInTheDocument();
|
||||
expect(screen.getByText('"customContext"')).toBeInTheDocument();
|
||||
});
|
@ -1,6 +1,6 @@
|
||||
import { FormEventHandler, useEffect, useState, VFC } from 'react';
|
||||
import { useSearchParams } from 'react-router-dom';
|
||||
import { Box, Paper, useMediaQuery, useTheme } from '@mui/material';
|
||||
import { Box, Paper, useTheme } from '@mui/material';
|
||||
import { PageContent } from 'component/common/PageContent/PageContent';
|
||||
import { PageHeader } from 'component/common/PageHeader/PageHeader';
|
||||
import useToast from 'hooks/useToast';
|
||||
@ -20,28 +20,48 @@ import { PlaygroundGuidancePopper } from './PlaygroundGuidancePopper/PlaygroundG
|
||||
import Loader from '../../common/Loader/Loader';
|
||||
import { AdvancedPlaygroundResultsTable } from './AdvancedPlaygroundResultsTable/AdvancedPlaygroundResultsTable';
|
||||
import { AdvancedPlaygroundResponseSchema } from 'openapi';
|
||||
import { createLocalStorage } from 'utils/createLocalStorage';
|
||||
|
||||
export const AdvancedPlayground: VFC<{
|
||||
FormComponent?: typeof PlaygroundForm;
|
||||
}> = ({ FormComponent = PlaygroundForm }) => {
|
||||
const defaultSettings: {
|
||||
projects: string[];
|
||||
environments: string[];
|
||||
context?: string;
|
||||
} = { projects: [], environments: [] };
|
||||
const { value, setValue } = createLocalStorage(
|
||||
'AdvancedPlayground:v1',
|
||||
defaultSettings
|
||||
);
|
||||
|
||||
export const AdvancedPlayground: VFC<{}> = () => {
|
||||
const { environments: availableEnvironments } = useEnvironments();
|
||||
const theme = useTheme();
|
||||
const matches = true;
|
||||
|
||||
const [environments, setEnvironments] = useState<string[]>([]);
|
||||
const [projects, setProjects] = useState<string[]>([]);
|
||||
const [context, setContext] = useState<string>();
|
||||
const [environments, setEnvironments] = useState<string[]>(
|
||||
value.environments
|
||||
);
|
||||
const [projects, setProjects] = useState<string[]>(value.projects);
|
||||
const [context, setContext] = useState<string | undefined>(value.context);
|
||||
const [results, setResults] = useState<
|
||||
AdvancedPlaygroundResponseSchema | undefined
|
||||
>();
|
||||
const { setToastData } = useToast();
|
||||
const [searchParams, setSearchParams] = useSearchParams();
|
||||
const searchParamsLength = Array.from(searchParams.entries()).length;
|
||||
const { evaluateAdvancedPlayground, loading } = usePlaygroundApi();
|
||||
|
||||
useEffect(() => {
|
||||
setEnvironments([resolveDefaultEnvironment(availableEnvironments)]);
|
||||
if (environments.length === 0) {
|
||||
setEnvironments([resolveDefaultEnvironment(availableEnvironments)]);
|
||||
}
|
||||
}, [availableEnvironments]);
|
||||
|
||||
useEffect(() => {
|
||||
loadInitialValuesFromUrl();
|
||||
if (searchParamsLength > 0) {
|
||||
loadInitialValuesFromUrl();
|
||||
}
|
||||
}, []);
|
||||
|
||||
const loadInitialValuesFromUrl = () => {
|
||||
@ -129,12 +149,14 @@ export const AdvancedPlayground: VFC<{}> = () => {
|
||||
const onSubmit: FormEventHandler<HTMLFormElement> = async event => {
|
||||
event.preventDefault();
|
||||
|
||||
await evaluatePlaygroundContext(
|
||||
environments,
|
||||
projects,
|
||||
context,
|
||||
setURLParameters
|
||||
);
|
||||
await evaluatePlaygroundContext(environments, projects, context, () => {
|
||||
setURLParameters();
|
||||
setValue({
|
||||
environments,
|
||||
projects,
|
||||
context,
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
const setURLParameters = () => {
|
||||
@ -201,7 +223,7 @@ export const AdvancedPlayground: VFC<{}> = () => {
|
||||
top: 0,
|
||||
}}
|
||||
>
|
||||
<PlaygroundForm
|
||||
<FormComponent
|
||||
onSubmit={onSubmit}
|
||||
context={context}
|
||||
setContext={setContext}
|
||||
|
@ -21,7 +21,7 @@ const irrelevantDetails = {
|
||||
projectId: 'projectA',
|
||||
};
|
||||
|
||||
test('should render environment table', async () => {
|
||||
test('should render environment diff table', async () => {
|
||||
render(
|
||||
<UIProviderContainer>
|
||||
<PlaygroundEnvironmentDiffTable
|
||||
|
Loading…
Reference in New Issue
Block a user