@commercetools-frontend-extensions/export-resources-modal 3.6.0 → 3.7.0
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.
|
@@ -8,7 +8,7 @@ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/obje
|
|
|
8
8
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
9
9
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
10
10
|
import React, { useContext, createContext } from 'react';
|
|
11
|
-
import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, Grid } from '@commercetools-frontend/ui-kit';
|
|
11
|
+
import { Text, TextInput, Link, Spacings, ExportIcon, SelectField, TextField, CheckboxInput, Card, designTokens, SearchTextInput, Grid } from '@commercetools-frontend/ui-kit';
|
|
12
12
|
import { jsx, jsxs, Fragment } from '@emotion/react/jsx-runtime';
|
|
13
13
|
import '@commercetools-uikit/design-system';
|
|
14
14
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
@@ -38,11 +38,14 @@ import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/ins
|
|
|
38
38
|
import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
|
|
39
39
|
import { useShowNotification } from '@commercetools-frontend/actions-global';
|
|
40
40
|
import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants';
|
|
41
|
+
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
41
42
|
import _styled from '@emotion/styled/base';
|
|
42
43
|
import _everyInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/every';
|
|
43
44
|
import _someInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/some';
|
|
45
|
+
import _trimInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/trim';
|
|
46
|
+
import throttle from 'lodash/throttle';
|
|
47
|
+
import { css } from '@emotion/react';
|
|
44
48
|
import PropTypes from 'prop-types';
|
|
45
|
-
import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
|
|
46
49
|
import { useFormik } from 'formik';
|
|
47
50
|
|
|
48
51
|
function getBold(msg) {
|
|
@@ -196,6 +199,31 @@ var messages = defineMessages({
|
|
|
196
199
|
id: 'ExportResourcesModal.unexpectedError',
|
|
197
200
|
description: 'Generic notification message when starting export process fails',
|
|
198
201
|
defaultMessage: 'An error occurred while starting the export process. Please try again or contact support if the problem persists.'
|
|
202
|
+
},
|
|
203
|
+
searchForFields: {
|
|
204
|
+
id: 'ExportResourcesModal.searchForFields',
|
|
205
|
+
description: 'Placeholder for "Search for fields" search input',
|
|
206
|
+
defaultMessage: 'Search for fields'
|
|
207
|
+
},
|
|
208
|
+
thereAreNoResults: {
|
|
209
|
+
id: 'ExportResourcesModal.thereAreNoResults',
|
|
210
|
+
description: 'No search results message',
|
|
211
|
+
defaultMessage: 'There are no results that match your search.'
|
|
212
|
+
},
|
|
213
|
+
suggestions: {
|
|
214
|
+
id: 'ExportResourcesModal.suggestions',
|
|
215
|
+
description: 'In Export fields selection - Suggestions message',
|
|
216
|
+
defaultMessage: 'Suggestions:'
|
|
217
|
+
},
|
|
218
|
+
checkTheSpelling: {
|
|
219
|
+
id: 'ExportResourcesModal.checkTheSpelling',
|
|
220
|
+
description: 'In Export fields selection - Check the spelling message',
|
|
221
|
+
defaultMessage: 'Check the spelling.'
|
|
222
|
+
},
|
|
223
|
+
searchByEnteringTheExactFieldName: {
|
|
224
|
+
id: 'ExportResourcesModal.searchByEnteringTheExactFieldName',
|
|
225
|
+
description: 'In Export fields selection - Search by entering the exact field name message',
|
|
226
|
+
defaultMessage: 'Try searching by entering the exact field name.'
|
|
199
227
|
}
|
|
200
228
|
});
|
|
201
229
|
|
|
@@ -793,35 +821,62 @@ const ExportFileSettingsStep = () => {
|
|
|
793
821
|
});
|
|
794
822
|
};
|
|
795
823
|
|
|
824
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
825
|
+
var _ref = process.env.NODE_ENV === "production" ? {
|
|
826
|
+
name: "ti75j2",
|
|
827
|
+
styles: "margin:0"
|
|
828
|
+
} : {
|
|
829
|
+
name: "ozey8m-NoSearchResults",
|
|
830
|
+
styles: "margin:0;label:NoSearchResults;",
|
|
831
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vLXNlYXJjaC1yZXN1bHRzLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlZ0IiLCJmaWxlIjoibm8tc2VhcmNoLXJlc3VsdHMuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FyZCwgU3BhY2luZ3MsIFRleHQgfSBmcm9tICdAY29tbWVyY2V0b29scy1mcm9udGVuZC91aS1raXQnXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBtZXNzYWdlcyBmcm9tICcuLi9tZXNzYWdlcydcblxuZXhwb3J0IGNvbnN0IE5vU2VhcmNoUmVzdWx0cyA9ICgpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q2FyZCBpbnNldFNjYWxlPVwieGxcIj5cbiAgICAgIDxTcGFjaW5ncy5TdGFjayBzY2FsZT1cInNcIj5cbiAgICAgICAgPFRleHQuQm9keVxuICAgICAgICAgIGZvbnRXZWlnaHQ9XCJtZWRpdW1cIlxuICAgICAgICAgIGludGxNZXNzYWdlPXttZXNzYWdlcy50aGVyZUFyZU5vUmVzdWx0c31cbiAgICAgICAgLz5cbiAgICAgICAgPFRleHQuQm9keSBpbnRsTWVzc2FnZT17bWVzc2FnZXMuc3VnZ2VzdGlvbnN9IC8+XG4gICAgICA8L1NwYWNpbmdzLlN0YWNrPlxuICAgICAgPHVsXG4gICAgICAgIGNzcz17Y3NzYFxuICAgICAgICAgIG1hcmdpbjogMDtcbiAgICAgICAgYH1cbiAgICAgID5cbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxUZXh0LkJvZHkgaW50bE1lc3NhZ2U9e21lc3NhZ2VzLmNoZWNrVGhlU3BlbGxpbmd9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICAgIDxsaT5cbiAgICAgICAgICA8VGV4dC5Cb2R5IGludGxNZXNzYWdlPXttZXNzYWdlcy5zZWFyY2hCeUVudGVyaW5nVGhlRXhhY3RGaWVsZE5hbWV9IC8+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L3VsPlxuICAgIDwvQ2FyZD5cbiAgKVxufVxuIl19 */",
|
|
832
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
833
|
+
};
|
|
834
|
+
const NoSearchResults = () => {
|
|
835
|
+
return jsxs(Card, {
|
|
836
|
+
insetScale: "xl",
|
|
837
|
+
children: [jsxs(Spacings.Stack, {
|
|
838
|
+
scale: "s",
|
|
839
|
+
children: [jsx(Text.Body, {
|
|
840
|
+
fontWeight: "medium",
|
|
841
|
+
intlMessage: messages.thereAreNoResults
|
|
842
|
+
}), jsx(Text.Body, {
|
|
843
|
+
intlMessage: messages.suggestions
|
|
844
|
+
})]
|
|
845
|
+
}), jsxs("ul", {
|
|
846
|
+
css: _ref,
|
|
847
|
+
children: [jsx("li", {
|
|
848
|
+
children: jsx(Text.Body, {
|
|
849
|
+
intlMessage: messages.checkTheSpelling
|
|
850
|
+
})
|
|
851
|
+
}), jsx("li", {
|
|
852
|
+
children: jsx(Text.Body, {
|
|
853
|
+
intlMessage: messages.searchByEnteringTheExactFieldName
|
|
854
|
+
})
|
|
855
|
+
})]
|
|
856
|
+
})]
|
|
857
|
+
});
|
|
858
|
+
};
|
|
859
|
+
|
|
796
860
|
function ownKeys$2(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
797
|
-
function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var
|
|
798
|
-
const
|
|
861
|
+
function _objectSpread$2(e) { for (var r = 1; r < arguments.length; r++) { var _context22, _context23; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context22 = ownKeys$2(Object(t), !0)).call(_context22, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context23 = ownKeys$2(Object(t))).call(_context23, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
862
|
+
const StyledGroupCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
|
|
799
863
|
target: "e1ocu3bb1"
|
|
800
864
|
} : {
|
|
801
865
|
target: "e1ocu3bb1",
|
|
802
|
-
label: "
|
|
803
|
-
})("height:100%;background-color:#f9f9fb;border-top:", _ref => {
|
|
804
|
-
|
|
805
|
-
return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
|
|
806
|
-
}, ";border-radius:", _ref2 => {
|
|
807
|
-
let isTopRow = _ref2.isTopRow;
|
|
808
|
-
return isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px';
|
|
809
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmBmC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
810
|
-
const StyledCardRight = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
|
|
866
|
+
label: "StyledGroupCard"
|
|
867
|
+
})("border-right:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";background-color:", designTokens.colorNeutral98, ";height:100%;border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledGroupCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA8BO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAsBoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
868
|
+
const StyledFieldsCard = /*#__PURE__*/_styled(Card, process.env.NODE_ENV === "production" ? {
|
|
811
869
|
target: "e1ocu3bb0"
|
|
812
870
|
} : {
|
|
813
871
|
target: "e1ocu3bb0",
|
|
814
|
-
label: "
|
|
815
|
-
})("height:100%;border-left:0;border-top:", _ref3 => {
|
|
816
|
-
let isTopRow = _ref3.isTopRow;
|
|
817
|
-
return isTopRow ? designTokens.borderForCardWhenRaised : 'none';
|
|
818
|
-
}, ";border-radius:", _ref4 => {
|
|
819
|
-
let isTopRow = _ref4.isTopRow;
|
|
820
|
-
return isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px';
|
|
821
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AA2BoC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport styled from '@emotion/styled'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\n\n// TODO: Remove these styled components as it's not a recommended practice to use them. We should align with MC UI Kit/patterns in terms of styling (to be discussed with the UI/UX).\nconst StyledCardLeft = styled(Card)`\n  height: 100%;\n  background-color: #f9f9fb;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '4px 0px 0px 0px' : '0px 0px 0px 4px'};\n`\nconst StyledCardRight = styled(Card)`\n  height: 100%;\n  border-left: 0;\n  border-top: ${({ isTopRow }) =>\n    isTopRow ? designTokens.borderForCardWhenRaised : 'none'};\n  border-radius: ${({ isTopRow }) =>\n    isTopRow ? '0px 4px 0px 0px' : '0px 0px 4px 0px'};\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <Grid\n            gridAutoFlow=\"row\"\n            gridTemplateColumns={`${designTokens.constraint5} auto`}\n          >\n            <Grid.Item>\n              <StyledCardLeft isTopRow insetScale=\"l\">\n                <CheckboxInput\n                  isIndeterminate={\n                    !areAllGeneralFieldsChecked &&\n                    isAtLeastOneGeneralFieldChecked\n                  }\n                  isChecked={areAllGeneralFieldsChecked}\n                  onChange={(e) => {\n                    formik.setFieldValue(\n                      'fields',\n                      formik.values.fields.map((field) => ({\n                        ...field,\n                        isChecked: field.isRequired ? true : e.target.checked,\n                      }))\n                    )\n                  }}\n                >\n                  <FormattedMessage {...messages.allGeneralFields} />\n                </CheckboxInput>\n              </StyledCardLeft>\n            </Grid.Item>\n            <Grid.Item>\n              <StyledCardRight isTopRow insetScale=\"l\">\n                <Spacings.Stack scale=\"s\">\n                  <GeneralFieldsSelection\n                    fields={formik.values.fields}\n                    setFieldValue={formik.setFieldValue}\n                  />\n                </Spacings.Stack>\n              </StyledCardRight>\n            </Grid.Item>\n            {formik.values.customFields?.length > 0 && (\n              <>\n                <Grid.Item>\n                  <StyledCardLeft insetScale=\"l\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        !areAllCustomFieldsChecked &&\n                        isAtLeastOneCustomFieldChecked\n                      }\n                      isChecked={areAllCustomFieldsChecked}\n                      onChange={(e) => {\n                        formik.setFieldValue(\n                          'customFields',\n                          formik.values.customFields.map((customType) => ({\n                            ...customType,\n                            fields: customType.fields.map((field) => ({\n                              ...field,\n                              isChecked: e.target.checked,\n                            })),\n                          }))\n                        )\n                      }}\n                    >\n                      <FormattedMessage {...messages.allCustomFields} />\n                    </CheckboxInput>\n                  </StyledCardLeft>\n                </Grid.Item>\n                <Grid.Item>\n                  <StyledCardRight insetScale=\"l\">\n                    <Spacings.Stack scale=\"s\">\n                      <CheckboxInput\n                        isReadOnly\n                        onChange={() => {}}\n                        isChecked={isAtLeastOneCustomFieldChecked}\n                      >\n                        <FormattedMessage\n                          {...messages.customTypeKeyAndTypeId}\n                        />{' '}\n                        *\n                      </CheckboxInput>\n                      <CustomFieldsSelection\n                        customFields={formik.values.customFields}\n                        setFieldValue={formik.setFieldValue}\n                      />\n                    </Spacings.Stack>\n                  </StyledCardRight>\n                </Grid.Item>\n              </>\n            )}\n          </Grid>\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, setFieldValue }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        setFieldValue(\n          'fields',\n          fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, setFieldValue }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            setFieldValue(\n              'customFields',\n              customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  setFieldValue(\n                    'customFields',\n                    customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
872
|
+
label: "StyledFieldsCard"
|
|
873
|
+
})("border-radius:0;", props => props.showTopBorder && /*#__PURE__*/css("border-top:", designTokens.borderWidth1, " solid ", designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:StyledFieldsCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAuCO","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["export-fields-selection-step.jsx"],"names":[],"mappings":"AAmCqC","file":"export-fields-selection-step.jsx","sourcesContent":["import React from 'react'\nimport { FormattedMessage, useIntl } from 'react-intl'\nimport throttle from 'lodash/throttle'\nimport styled from '@emotion/styled'\nimport { css } from '@emotion/react'\nimport { FormDialog } from '@commercetools-frontend/application-components'\nimport {\n  Card,\n  CheckboxInput,\n  Grid,\n  Link,\n  Spacings,\n  Text,\n  SearchTextInput,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport messages from '../messages'\nimport { useExportResourcesContext } from '../@hooks'\nimport { FIELD_DEFINITIONS_URLS } from '../@constants'\nimport { resourceTypeToDisplayName } from '../@utils'\nimport { NoSearchResults } from './no-search-results'\n\nconst StyledGroupCard = styled(Card)`\n  border-right: ${designTokens.borderWidth1} solid\n    ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral98};\n  height: 100%;\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\nconst StyledFieldsCard = styled(Card)`\n  border-radius: 0;\n  ${(props) =>\n    props.showTopBorder &&\n    css`\n      border-top: ${designTokens.borderWidth1} solid\n        ${designTokens.colorNeutral90};\n    `}\n`\n\nexport const ExportFieldsSelectionStep = () => {\n  const intl = useIntl()\n  const [fieldSearchTerm, setFieldSearchTerm] = React.useState('')\n  const { formik, setCurrentStep, resourceType, onClose } =\n    useExportResourcesContext()\n  const resourceTypePlural = resourceTypeToDisplayName({\n    resourceType: resourceType,\n    isPlural: true,\n  })\n  const areAllGeneralFieldsChecked = React.useMemo(() => {\n    return formik.values.fields.every((field) => field.isChecked)\n  }, [formik.values.fields])\n  const isAtLeastOneGeneralFieldChecked = React.useMemo(() => {\n    return formik.values.fields.some((field) => field.isChecked)\n  }, [formik.values.fields])\n  const allCustomFields = React.useMemo(() => {\n    return formik.values.customFields.flatMap((customType) => customType.fields)\n  }, [formik.values.customFields])\n  const areAllCustomFieldsChecked = React.useMemo(() => {\n    return allCustomFields.every((field) => field.isChecked)\n  }, [allCustomFields])\n  const isAtLeastOneCustomFieldChecked = React.useMemo(() => {\n    return allCustomFields.some((field) => field.isChecked)\n  }, [allCustomFields])\n  const filteredGeneralFields = React.useMemo(() => {\n    return formik.values.fields.filter((field) =>\n      field.label.toLowerCase().includes(fieldSearchTerm.trim().toLowerCase())\n    )\n  }, [formik.values.fields, fieldSearchTerm])\n  const filteredCustomFields = React.useMemo(() => {\n    return formik.values.customFields\n      .map((customType) => ({\n        ...customType,\n        fields: customType.type.label\n          .toLowerCase()\n          .includes(fieldSearchTerm.trim().toLowerCase())\n          ? customType.fields\n          : customType.fields.filter((field) =>\n              field.label\n                .toLowerCase()\n                .includes(fieldSearchTerm.trim().toLowerCase())\n            ),\n      }))\n      .filter((customType) => customType.fields.length > 0)\n  }, [formik.values.customFields, fieldSearchTerm])\n  const onSearchChange = React.useCallback(\n    (event) => {\n      setFieldSearchTerm(event.target.value)\n    },\n    [setFieldSearchTerm]\n  )\n  const hasResults =\n    filteredGeneralFields.length > 0 || filteredCustomFields.length > 0\n\n  const onSearchChangeThrottled = React.useMemo(\n    () => throttle(onSearchChange, 300),\n    [onSearchChange]\n  )\n\n  const onSearchReset = () => {\n    setFieldSearchTerm('')\n  }\n\n  return (\n    <FormDialog\n      isOpen\n      title={intl.formatMessage(messages.modalTitle, {\n        resourceType: resourceTypePlural,\n      })}\n      labelPrimary={intl.formatMessage(messages.startExport)}\n      onPrimaryButtonClick={formik.submitForm}\n      isPrimaryButtonDisabled={!formik.isValid}\n      labelSecondary={intl.formatMessage(messages.back)}\n      onSecondaryButtonClick={() => setCurrentStep(1)}\n      onClose={onClose}\n      size={16}\n    >\n      <Spacings.Stack scale=\"xl\">\n        <Spacings.Stack scale=\"m\">\n          <Spacings.Inline justifyContent=\"space-between\">\n            <Text.Body intlMessage={messages.selectFieldsToExport} />\n            <Link\n              isExternal\n              tone=\"secondary\"\n              intlMessage={messages.fieldDefinitions}\n              to={FIELD_DEFINITIONS_URLS[resourceType]}\n            />\n          </Spacings.Inline>\n          <SearchTextInput\n            placeholder={intl.formatMessage(messages.searchForFields)}\n            value={fieldSearchTerm}\n            onChange={onSearchChangeThrottled}\n            onReset={onSearchReset}\n          />\n          {!hasResults && <NoSearchResults />}\n          {hasResults && (\n            <Card insetScale=\"none\">\n              <Grid\n                gridAutoFlow=\"row\"\n                gridTemplateColumns={`${designTokens.constraint5} auto`}\n              >\n                {filteredGeneralFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard type=\"flat\" insetScale=\"l\">\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllGeneralFieldsChecked &&\n                            isAtLeastOneGeneralFieldChecked\n                          }\n                          isChecked={areAllGeneralFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'fields',\n                              formik.values.fields.map((field) => ({\n                                ...field,\n                                isChecked: field.isRequired\n                                  ? true\n                                  : e.target.checked,\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allGeneralFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard type=\"flat\" insetScale=\"l\">\n                        <Spacings.Stack scale=\"s\">\n                          <GeneralFieldsSelection\n                            fields={filteredGeneralFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n                {filteredCustomFields.length > 0 && (\n                  <>\n                    <Grid.Item>\n                      <StyledGroupCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <CheckboxInput\n                          isIndeterminate={\n                            !areAllCustomFieldsChecked &&\n                            isAtLeastOneCustomFieldChecked\n                          }\n                          isChecked={areAllCustomFieldsChecked}\n                          onChange={(e) => {\n                            formik.setFieldValue(\n                              'customFields',\n                              formik.values.customFields.map((customType) => ({\n                                ...customType,\n                                fields: customType.fields.map((field) => ({\n                                  ...field,\n                                  isChecked: e.target.checked,\n                                })),\n                              }))\n                            )\n                          }}\n                        >\n                          <FormattedMessage {...messages.allCustomFields} />\n                        </CheckboxInput>\n                      </StyledGroupCard>\n                    </Grid.Item>\n                    <Grid.Item>\n                      <StyledFieldsCard\n                        type=\"flat\"\n                        insetScale=\"l\"\n                        showTopBorder={filteredGeneralFields.length > 0}\n                      >\n                        <Spacings.Stack scale=\"s\">\n                          <CheckboxInput\n                            isReadOnly\n                            onChange={() => {}}\n                            isChecked={isAtLeastOneCustomFieldChecked}\n                          >\n                            <FormattedMessage\n                              {...messages.customTypeKeyAndTypeId}\n                            />{' '}\n                            *\n                          </CheckboxInput>\n                          <CustomFieldsSelection\n                            customFields={filteredCustomFields}\n                            formik={formik}\n                          />\n                        </Spacings.Stack>\n                      </StyledFieldsCard>\n                    </Grid.Item>\n                  </>\n                )}\n              </Grid>\n            </Card>\n          )}\n        </Spacings.Stack>\n      </Spacings.Stack>\n    </FormDialog>\n  )\n}\n\nconst GeneralFieldsSelection = ({ fields, formik }) => {\n  return fields.map((field) => (\n    <CheckboxInput\n      key={field.name}\n      isChecked={field.isChecked}\n      isReadOnly={field.isRequired}\n      onChange={(e) => {\n        formik.setFieldValue(\n          'fields',\n          formik.values.fields.map((_field) =>\n            field.name === _field.name\n              ? { ..._field, isChecked: e.target.checked }\n              : _field\n          )\n        )\n      }}\n    >\n      {field.label} {field.isRequired && '*'}\n    </CheckboxInput>\n  ))\n}\n\nconst CustomFieldsSelection = ({ customFields, formik }) => {\n  return customFields.map((customType) => {\n    const areAllFieldsChecked = customType.fields.every(\n      (field) => field.isChecked\n    )\n    const isAtLeastOneFieldChecked = customType.fields.some(\n      (field) => field.isChecked\n    )\n\n    return (\n      <Spacings.Stack key={customType.type.key} scale=\"s\">\n        <CheckboxInput\n          isIndeterminate={!areAllFieldsChecked && isAtLeastOneFieldChecked}\n          isChecked={areAllFieldsChecked}\n          onChange={(e) => {\n            formik.setFieldValue(\n              'customFields',\n              formik.values.customFields.map((_customType) =>\n                _customType.type.key === customType.type.key\n                  ? {\n                      ..._customType,\n                      fields: _customType.fields.map((field) => ({\n                        ...field,\n                        isChecked: e.target.checked,\n                      })),\n                    }\n                  : _customType\n              )\n            )\n          }}\n        >\n          <Text.Body>{customType.type.label}</Text.Body>\n        </CheckboxInput>\n        <Spacings.Inline scale=\"l\">\n          <div />\n          <Spacings.Stack scale=\"s\">\n            {customType.fields.map((field) => (\n              <CheckboxInput\n                key={field.name}\n                isChecked={field.isChecked}\n                onChange={(e) => {\n                  formik.setFieldValue(\n                    'customFields',\n                    formik.values.customFields.map((_customType) =>\n                      _customType.type.key === customType.type.key\n                        ? {\n                            ..._customType,\n                            fields: _customType.fields.map((_field) =>\n                              _field.name === field.name\n                                ? {\n                                    ..._field,\n                                    isChecked: e.target.checked,\n                                  }\n                                : _field\n                            ),\n                          }\n                        : _customType\n                    )\n                  )\n                }}\n              >\n                <Text.Body>{field.label}</Text.Body>\n              </CheckboxInput>\n            ))}\n          </Spacings.Stack>\n        </Spacings.Inline>\n      </Spacings.Stack>\n    )\n  })\n}\n"]} */"));
|
|
822
874
|
const ExportFieldsSelectionStep = () => {
|
|
823
|
-
var _formik$values$custom;
|
|
824
875
|
const intl = useIntl();
|
|
876
|
+
const _React$useState = React.useState(''),
|
|
877
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
878
|
+
fieldSearchTerm = _React$useState2[0],
|
|
879
|
+
setFieldSearchTerm = _React$useState2[1];
|
|
825
880
|
const _useExportResourcesCo = useExportResourcesContext(),
|
|
826
881
|
formik = _useExportResourcesCo.formik,
|
|
827
882
|
setCurrentStep = _useExportResourcesCo.setCurrentStep,
|
|
@@ -849,6 +904,33 @@ const ExportFieldsSelectionStep = () => {
|
|
|
849
904
|
const isAtLeastOneCustomFieldChecked = React.useMemo(() => {
|
|
850
905
|
return _someInstanceProperty(allCustomFields).call(allCustomFields, field => field.isChecked);
|
|
851
906
|
}, [allCustomFields]);
|
|
907
|
+
const filteredGeneralFields = React.useMemo(() => {
|
|
908
|
+
var _context4;
|
|
909
|
+
return _filterInstanceProperty(_context4 = _valuesInstanceProperty(formik).fields).call(_context4, field => {
|
|
910
|
+
var _context5;
|
|
911
|
+
return _includesInstanceProperty(_context5 = field.label.toLowerCase()).call(_context5, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
|
|
912
|
+
});
|
|
913
|
+
}, [_valuesInstanceProperty(formik).fields, fieldSearchTerm]);
|
|
914
|
+
const filteredCustomFields = React.useMemo(() => {
|
|
915
|
+
var _context6, _context7;
|
|
916
|
+
return _filterInstanceProperty(_context6 = _mapInstanceProperty(_context7 = _valuesInstanceProperty(formik).customFields).call(_context7, customType => {
|
|
917
|
+
var _context8, _context9;
|
|
918
|
+
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
919
|
+
fields: _includesInstanceProperty(_context8 = customType.type.label.toLowerCase()).call(_context8, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase()) ? customType.fields : _filterInstanceProperty(_context9 = customType.fields).call(_context9, field => {
|
|
920
|
+
var _context10;
|
|
921
|
+
return _includesInstanceProperty(_context10 = field.label.toLowerCase()).call(_context10, _trimInstanceProperty(fieldSearchTerm).call(fieldSearchTerm).toLowerCase());
|
|
922
|
+
})
|
|
923
|
+
});
|
|
924
|
+
})).call(_context6, customType => customType.fields.length > 0);
|
|
925
|
+
}, [_valuesInstanceProperty(formik).customFields, fieldSearchTerm]);
|
|
926
|
+
const onSearchChange = React.useCallback(event => {
|
|
927
|
+
setFieldSearchTerm(event.target.value);
|
|
928
|
+
}, [setFieldSearchTerm]);
|
|
929
|
+
const hasResults = filteredGeneralFields.length > 0 || filteredCustomFields.length > 0;
|
|
930
|
+
const onSearchChangeThrottled = React.useMemo(() => throttle(onSearchChange, 300), [onSearchChange]);
|
|
931
|
+
const onSearchReset = () => {
|
|
932
|
+
setFieldSearchTerm('');
|
|
933
|
+
};
|
|
852
934
|
return jsx(FormDialog, {
|
|
853
935
|
isOpen: true,
|
|
854
936
|
title: intl.formatMessage(messages.modalTitle, {
|
|
@@ -875,112 +957,128 @@ const ExportFieldsSelectionStep = () => {
|
|
|
875
957
|
intlMessage: messages.fieldDefinitions,
|
|
876
958
|
to: FIELD_DEFINITIONS_URLS[resourceType]
|
|
877
959
|
})]
|
|
878
|
-
}),
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
899
|
-
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
|
|
904
|
-
fields: _valuesInstanceProperty(formik).fields,
|
|
905
|
-
setFieldValue: formik.setFieldValue
|
|
960
|
+
}), jsx(SearchTextInput, {
|
|
961
|
+
placeholder: intl.formatMessage(messages.searchForFields),
|
|
962
|
+
value: fieldSearchTerm,
|
|
963
|
+
onChange: onSearchChangeThrottled,
|
|
964
|
+
onReset: onSearchReset
|
|
965
|
+
}), !hasResults && jsx(NoSearchResults, {}), hasResults && jsx(Card, {
|
|
966
|
+
insetScale: "none",
|
|
967
|
+
children: jsxs(Grid, {
|
|
968
|
+
gridAutoFlow: "row",
|
|
969
|
+
gridTemplateColumns: "".concat(designTokens.constraint5, " auto"),
|
|
970
|
+
children: [filteredGeneralFields.length > 0 && jsxs(Fragment, {
|
|
971
|
+
children: [jsx(Grid.Item, {
|
|
972
|
+
children: jsx(StyledGroupCard, {
|
|
973
|
+
type: "flat",
|
|
974
|
+
insetScale: "l",
|
|
975
|
+
children: jsx(CheckboxInput, {
|
|
976
|
+
isIndeterminate: !areAllGeneralFieldsChecked && isAtLeastOneGeneralFieldChecked,
|
|
977
|
+
isChecked: areAllGeneralFieldsChecked,
|
|
978
|
+
onChange: e => {
|
|
979
|
+
var _context11;
|
|
980
|
+
formik.setFieldValue('fields', _mapInstanceProperty(_context11 = _valuesInstanceProperty(formik).fields).call(_context11, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
981
|
+
isChecked: field.isRequired ? true : e.target.checked
|
|
982
|
+
})));
|
|
983
|
+
},
|
|
984
|
+
children: jsx(FormattedMessage, _objectSpread$2({}, messages.allGeneralFields))
|
|
985
|
+
})
|
|
906
986
|
})
|
|
907
|
-
})
|
|
908
|
-
|
|
909
|
-
|
|
910
|
-
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
|
|
918
|
-
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
987
|
+
}), jsx(Grid.Item, {
|
|
988
|
+
children: jsx(StyledFieldsCard, {
|
|
989
|
+
type: "flat",
|
|
990
|
+
insetScale: "l",
|
|
991
|
+
children: jsx(Spacings.Stack, {
|
|
992
|
+
scale: "s",
|
|
993
|
+
children: jsx(GeneralFieldsSelection, {
|
|
994
|
+
fields: filteredGeneralFields,
|
|
995
|
+
formik: formik
|
|
996
|
+
})
|
|
997
|
+
})
|
|
998
|
+
})
|
|
999
|
+
})]
|
|
1000
|
+
}), filteredCustomFields.length > 0 && jsxs(Fragment, {
|
|
1001
|
+
children: [jsx(Grid.Item, {
|
|
1002
|
+
children: jsx(StyledGroupCard, {
|
|
1003
|
+
type: "flat",
|
|
1004
|
+
insetScale: "l",
|
|
1005
|
+
showTopBorder: filteredGeneralFields.length > 0,
|
|
1006
|
+
children: jsx(CheckboxInput, {
|
|
1007
|
+
isIndeterminate: !areAllCustomFieldsChecked && isAtLeastOneCustomFieldChecked,
|
|
1008
|
+
isChecked: areAllCustomFieldsChecked,
|
|
1009
|
+
onChange: e => {
|
|
1010
|
+
var _context12;
|
|
1011
|
+
formik.setFieldValue('customFields', _mapInstanceProperty(_context12 = _valuesInstanceProperty(formik).customFields).call(_context12, customType => {
|
|
1012
|
+
var _context13;
|
|
1013
|
+
return _objectSpread$2(_objectSpread$2({}, customType), {}, {
|
|
1014
|
+
fields: _mapInstanceProperty(_context13 = customType.fields).call(_context13, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
1015
|
+
isChecked: e.target.checked
|
|
1016
|
+
}))
|
|
1017
|
+
});
|
|
1018
|
+
}));
|
|
1019
|
+
},
|
|
1020
|
+
children: jsx(FormattedMessage, _objectSpread$2({}, messages.allCustomFields))
|
|
1021
|
+
})
|
|
928
1022
|
})
|
|
929
|
-
})
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
1023
|
+
}), jsx(Grid.Item, {
|
|
1024
|
+
children: jsx(StyledFieldsCard, {
|
|
1025
|
+
type: "flat",
|
|
1026
|
+
insetScale: "l",
|
|
1027
|
+
showTopBorder: filteredGeneralFields.length > 0,
|
|
1028
|
+
children: jsxs(Spacings.Stack, {
|
|
1029
|
+
scale: "s",
|
|
1030
|
+
children: [jsxs(CheckboxInput, {
|
|
1031
|
+
isReadOnly: true,
|
|
1032
|
+
onChange: () => {},
|
|
1033
|
+
isChecked: isAtLeastOneCustomFieldChecked,
|
|
1034
|
+
children: [jsx(FormattedMessage, _objectSpread$2({}, messages.customTypeKeyAndTypeId)), ' ', "*"]
|
|
1035
|
+
}), jsx(CustomFieldsSelection, {
|
|
1036
|
+
customFields: filteredCustomFields,
|
|
1037
|
+
formik: formik
|
|
1038
|
+
})]
|
|
1039
|
+
})
|
|
944
1040
|
})
|
|
945
|
-
})
|
|
1041
|
+
})]
|
|
946
1042
|
})]
|
|
947
|
-
})
|
|
1043
|
+
})
|
|
948
1044
|
})]
|
|
949
1045
|
})
|
|
950
1046
|
})
|
|
951
1047
|
});
|
|
952
1048
|
};
|
|
953
|
-
const GeneralFieldsSelection =
|
|
954
|
-
let fields =
|
|
955
|
-
|
|
1049
|
+
const GeneralFieldsSelection = _ref => {
|
|
1050
|
+
let fields = _ref.fields,
|
|
1051
|
+
formik = _ref.formik;
|
|
956
1052
|
return _mapInstanceProperty(fields).call(fields, field => jsxs(CheckboxInput, {
|
|
957
1053
|
isChecked: field.isChecked,
|
|
958
1054
|
isReadOnly: field.isRequired,
|
|
959
1055
|
onChange: e => {
|
|
960
|
-
|
|
1056
|
+
var _context14;
|
|
1057
|
+
formik.setFieldValue('fields', _mapInstanceProperty(_context14 = _valuesInstanceProperty(formik).fields).call(_context14, _field => field.name === _field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
961
1058
|
isChecked: e.target.checked
|
|
962
1059
|
}) : _field));
|
|
963
1060
|
},
|
|
964
1061
|
children: [field.label, " ", field.isRequired && '*']
|
|
965
1062
|
}, field.name));
|
|
966
1063
|
};
|
|
967
|
-
const CustomFieldsSelection =
|
|
968
|
-
let customFields =
|
|
969
|
-
|
|
1064
|
+
const CustomFieldsSelection = _ref2 => {
|
|
1065
|
+
let customFields = _ref2.customFields,
|
|
1066
|
+
formik = _ref2.formik;
|
|
970
1067
|
return _mapInstanceProperty(customFields).call(customFields, customType => {
|
|
971
|
-
var
|
|
972
|
-
const areAllFieldsChecked = _everyInstanceProperty(
|
|
973
|
-
const isAtLeastOneFieldChecked = _someInstanceProperty(
|
|
1068
|
+
var _context15, _context16, _context19;
|
|
1069
|
+
const areAllFieldsChecked = _everyInstanceProperty(_context15 = customType.fields).call(_context15, field => field.isChecked);
|
|
1070
|
+
const isAtLeastOneFieldChecked = _someInstanceProperty(_context16 = customType.fields).call(_context16, field => field.isChecked);
|
|
974
1071
|
return jsxs(Spacings.Stack, {
|
|
975
1072
|
scale: "s",
|
|
976
1073
|
children: [jsx(CheckboxInput, {
|
|
977
1074
|
isIndeterminate: !areAllFieldsChecked && isAtLeastOneFieldChecked,
|
|
978
1075
|
isChecked: areAllFieldsChecked,
|
|
979
1076
|
onChange: e => {
|
|
980
|
-
|
|
981
|
-
|
|
1077
|
+
var _context17;
|
|
1078
|
+
formik.setFieldValue('customFields', _mapInstanceProperty(_context17 = _valuesInstanceProperty(formik).customFields).call(_context17, _customType => {
|
|
1079
|
+
var _context18;
|
|
982
1080
|
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
983
|
-
fields: _mapInstanceProperty(
|
|
1081
|
+
fields: _mapInstanceProperty(_context18 = _customType.fields).call(_context18, field => _objectSpread$2(_objectSpread$2({}, field), {}, {
|
|
984
1082
|
isChecked: e.target.checked
|
|
985
1083
|
}))
|
|
986
1084
|
}) : _customType;
|
|
@@ -993,13 +1091,14 @@ const CustomFieldsSelection = _ref6 => {
|
|
|
993
1091
|
scale: "l",
|
|
994
1092
|
children: [jsx("div", {}), jsx(Spacings.Stack, {
|
|
995
1093
|
scale: "s",
|
|
996
|
-
children: _mapInstanceProperty(
|
|
1094
|
+
children: _mapInstanceProperty(_context19 = customType.fields).call(_context19, field => jsx(CheckboxInput, {
|
|
997
1095
|
isChecked: field.isChecked,
|
|
998
1096
|
onChange: e => {
|
|
999
|
-
|
|
1000
|
-
|
|
1097
|
+
var _context20;
|
|
1098
|
+
formik.setFieldValue('customFields', _mapInstanceProperty(_context20 = _valuesInstanceProperty(formik).customFields).call(_context20, _customType => {
|
|
1099
|
+
var _context21;
|
|
1001
1100
|
return _customType.type.key === customType.type.key ? _objectSpread$2(_objectSpread$2({}, _customType), {}, {
|
|
1002
|
-
fields: _mapInstanceProperty(
|
|
1101
|
+
fields: _mapInstanceProperty(_context21 = _customType.fields).call(_context21, _field => _field.name === field.name ? _objectSpread$2(_objectSpread$2({}, _field), {}, {
|
|
1003
1102
|
isChecked: e.target.checked
|
|
1004
1103
|
}) : _field)
|
|
1005
1104
|
}) : _customType;
|