Skip to content

Commit

Permalink
✨ [#4693] Add copy button for Objects API prefill config
Browse files Browse the repository at this point in the history
that allows the user to copy the configuration used by the Form's registration backend
  • Loading branch information
stevenbal authored and sergei-maertens committed Nov 12, 2024
1 parent 50d8129 commit 291b6a7
Show file tree
Hide file tree
Showing 2 changed files with 133 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -626,6 +626,99 @@ export const ConfigurePrefillObjectsAPI = {
},
};

export const ConfigurePrefillObjectsAPIWithCopyButton = {
args: {
registrationBackends: [
{
backend: 'objects_api',
key: 'objects_api_1',
name: 'Example Objects API reg.',
options: {
version: 2,
objectsApiGroup: 1,
objecttype: '2c77babf-a967-4057-9969-0200320d23f1',
objecttypeVersion: 2,
variablesMapping: [
{
variableKey: 'formioComponent',
targetPath: ['path', 'to.the', 'target'],
},
{
variableKey: 'userDefined',
targetPath: ['other', 'path'],
},
],
},
},
{
backend: 'objects_api',
key: 'objects_api_2',
name: 'Other Objects API registration with a long name',
options: {
version: 2,
objectsApiGroup: 1,
objecttype: '209e0341-834d-4060-bd19-a3419d19ed74',
objecttypeVersion: 2,
variablesMapping: [
{
variableKey: 'formioComponent',
targetPath: ['path', 'to.the', 'target'],
},
],
},
},
],
},
play: async ({canvasElement, step}) => {
const canvas = within(canvasElement);

await step('Open configuration modal', async () => {
const userDefinedVarsTab = await canvas.findByRole('tab', {name: 'Gebruikersvariabelen'});
expect(userDefinedVarsTab).toBeVisible();
await userEvent.click(userDefinedVarsTab);

// open modal for configuration
const editIcon = canvas.getByTitle('Prefill instellen');
await userEvent.click(editIcon);
expect(await screen.findByRole('dialog')).toBeVisible();
});

await step('Configure Objects API prefill with copy button', async () => {
window.confirm = () => true;
const modal = within(await screen.findByRole('dialog'));
const pluginDropdown = await screen.findByLabelText('Plugin');
expect(pluginDropdown).toBeVisible();
await userEvent.selectOptions(pluginDropdown, 'Objects API');

const copyButton = await modal.findByRole('button', {
name: 'Copy configuration from registration backend',
});
expect(copyButton).toBeVisible();
await userEvent.click(copyButton);

const modalForm = await screen.findByTestId('modal-form');
expect(modalForm).toBeVisible();
await waitFor(async () => {
expect(modalForm).toHaveFormValues({
'prefillOptions.objectsApiGroup': '1',
'prefillOptions.objecttypeUuid': '2c77babf-a967-4057-9969-0200320d23f1',
'prefillOptions.objecttypeVersion': '2',
});
});

// Wait until the API call to retrieve the prefillAttributes is done
await waitFor(async () => {
const prefillPropertySelect = await screen.findByLabelText(
'Selecteer een attribuut uit het objecttype'
);
expect(prefillPropertySelect).toBeVisible();
expect(prefillPropertySelect.options[1]).toHaveValue(serializeValue(['height']));
expect(prefillPropertySelect.options[2]).toHaveValue(serializeValue(['species']));
});
});
},
};

export const WithValidationErrors = {
args: {
variables: [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {FormattedMessage, useIntl} from 'react-intl';
import useAsync from 'react-use/esm/useAsync';

import {FormContext} from 'components/admin/form_design/Context';
import ButtonContainer from 'components/admin/forms/ButtonContainer';
import Field from 'components/admin/forms/Field';
import Fieldset from 'components/admin/forms/Fieldset';
import FormRow from 'components/admin/forms/FormRow';
Expand Down Expand Up @@ -64,9 +65,11 @@ const ObjectsAPIFields = ({errors}) => {

const {
plugins: {availablePrefillPlugins},
registrationBackends,
} = useContext(FormContext);
const objectsPlugin = availablePrefillPlugins.find(elem => elem.id === PLUGIN_ID);

const backend = registrationBackends.find(elem => elem.backend === 'objects_api');
const {apiGroups} = objectsPlugin.configurationContext;

const {
Expand Down Expand Up @@ -156,6 +159,43 @@ const ObjectsAPIFields = ({errors}) => {
objectTypeFieldName="prefillOptions.objecttypeUuid"
/>
</ErrorBoundary>

{backend ? (
<button
type="button"
className="button"
onClick={e => {
e.preventDefault();
const confirmed = window.confirm(
intl.formatMessage({
description: `Objects API prefill configuration: warning message
when copying the config from registration backend`,
defaultMessage: `Copying the configuration from the registration
backend will clear the existing configuration. Are you sure you want to continue?`,
})
);
if (confirmed) {
setFieldValue('prefillOptions.objectsApiGroup', backend.options.objectsApiGroup);
setFieldValue('prefillOptions.objecttypeUuid', backend.options.objecttype);
setFieldValue(
'prefillOptions.objecttypeVersion',
backend.options.objecttypeVersion
);
}
}}
// admin style overrides...
style={{
marginTop: '2em',
paddingInline: '15px',
paddingBlock: '10px',
}}
>
<FormattedMessage
description="Copy Objects API prefill configuration from registration backend"
defaultMessage="Copy configuration from registration backend"
/>
</button>
) : null}
</Fieldset>

<Fieldset
Expand Down

0 comments on commit 291b6a7

Please sign in to comment.