@commercetools-frontend-extensions/export-resources-modal 4.6.6 → 4.6.8

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.
@@ -45,6 +45,7 @@ var constants = require('@commercetools-frontend/constants');
45
45
  var sdk = require('@commercetools-frontend/sdk');
46
46
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
47
47
  var l10n = require('@commercetools-frontend/l10n');
48
+ var sortBy = require('lodash/sortBy');
48
49
  var _styled = require('@emotion/styled/base');
49
50
  var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
50
51
  var throttle = require('lodash/throttle');
@@ -79,6 +80,7 @@ var _Set__default = /*#__PURE__*/_interopDefault(_Set);
79
80
  var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
80
81
  var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
81
82
  var moment__default = /*#__PURE__*/_interopDefault(moment);
83
+ var sortBy__default = /*#__PURE__*/_interopDefault(sortBy);
82
84
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
83
85
  var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
84
86
  var throttle__default = /*#__PURE__*/_interopDefault(throttle);
@@ -1077,14 +1079,23 @@ const useConvertFieldDefinitionsForExport = () => {
1077
1079
  })),
1078
1080
  language = _useApplicationContex.language,
1079
1081
  languages = _useApplicationContex.languages;
1082
+ const sortByField = (fields, fieldName) => {
1083
+ if (fieldName) {
1084
+ return sortBy__default["default"](fields, field => {
1085
+ return field[fieldName]?.toLowerCase();
1086
+ });
1087
+ }
1088
+ return fields;
1089
+ };
1080
1090
  const convertFieldDefinitionsForExport = _ref3 => {
1081
1091
  let fieldDefinitions = _ref3.fieldDefinitions,
1082
1092
  fieldPrefix = _ref3.fieldPrefix,
1083
1093
  _ref3$expandAll = _ref3.expandAll,
1084
- expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll;
1094
+ expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll,
1095
+ sortField = _ref3.sortField;
1085
1096
  if (!fieldDefinitions) return [];
1086
1097
  const localizedTypeDefinitions = localizeTypeDefinitionLabels(fieldDefinitions);
1087
- return _mapInstanceProperty__default["default"](localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1098
+ const results = _mapInstanceProperty__default["default"](localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1088
1099
  isExpandable: true,
1089
1100
  isExpanded: expandAll,
1090
1101
  name: transformedType.name,
@@ -1096,7 +1107,7 @@ const useConvertFieldDefinitionsForExport = () => {
1096
1107
  fallbackOrder: languages,
1097
1108
  fallback: transformedType.name
1098
1109
  }),
1099
- fields: transformedType.fields?.map(fieldDefinition => ({
1110
+ fields: sortByField(transformedType.fields?.map(fieldDefinition => ({
1100
1111
  name: getFieldFullName({
1101
1112
  fieldPrefix: fieldPrefix,
1102
1113
  fieldName: fieldDefinition.name
@@ -1109,8 +1120,9 @@ const useConvertFieldDefinitionsForExport = () => {
1109
1120
  fallbackOrder: languages,
1110
1121
  fallback: fieldDefinition.name
1111
1122
  })
1112
- }))
1123
+ })), sortField)
1113
1124
  }));
1125
+ return sortByField(results, sortField);
1114
1126
  };
1115
1127
  return {
1116
1128
  convertFieldDefinitionsForExport
@@ -1333,12 +1345,12 @@ const FieldWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env
1333
1345
  target: "e1judmlm0",
1334
1346
  label: "FieldWrapper"
1335
1347
  })(process.env.NODE_ENV === "production" ? {
1336
- name: "bjn8wh",
1337
- styles: "position:relative"
1348
+ name: "9iujih",
1349
+ styles: "position:relative;display:flex;align-items:center"
1338
1350
  } : {
1339
- name: "bjn8wh",
1340
- styles: "position:relative",
1341
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAkB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport type { FilteredField, FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => JSX.Element\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isForceExpanded?: boolean\n  groupName: string\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isForceExpanded,\n  groupName,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (field.isHidden) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isForceExpanded}\n            field={field}\n            key={`${field.name}.${isForceExpanded}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isForceExpanded) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\n                          if (item && item.fields) {\n                            item.fields.forEach((field, i) => {\n                              const fieldPath = `${path}.fields[${i}]`\n                              if (!field.fields?.length) {\n                                formik.setFieldValue(\n                                  `${fieldPath}.isChecked`,\n                                  checked || field.isRequired,\n                                  // pass `false` to avoid revalidating the form with intermediate values\n                                  false\n                                )\n                              }\n                              updateAllChildFieldsChecked(fieldPath, checked)\n                            })\n                          }\n                        }\n                        if (!field.fields?.length) {\n                          formik.setFieldValue(\n                            `${path}.isChecked`,\n                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields?.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    <Spacings.Inline scale=\"xl\">\n                      <div />\n                      <FieldSection\n                        fields={field.fields}\n                        formik={formik}\n                        parentKeys={[...parentKeys, `fields[${index}]`]}\n                        isAnySiblingChecked={isAnySiblingChecked}\n                        isForceExpanded={isForceExpanded}\n                        groupName={groupName}\n                      />\n                    </Spacings.Inline>\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n"]} */",
1351
+ name: "9iujih",
1352
+ styles: "position:relative;display:flex;align-items:center",
1353
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAkB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport type { FilteredField, FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n  display: flex;\n  align-items: center;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => JSX.Element\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isForceExpanded?: boolean\n  groupName: string\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isForceExpanded,\n  groupName,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (field.isHidden) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isForceExpanded}\n            field={field}\n            key={`${field.name}.${isForceExpanded}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isForceExpanded) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\n                          if (item && item.fields) {\n                            item.fields.forEach((field, i) => {\n                              const fieldPath = `${path}.fields[${i}]`\n                              if (!field.fields?.length) {\n                                formik.setFieldValue(\n                                  `${fieldPath}.isChecked`,\n                                  checked || field.isRequired,\n                                  // pass `false` to avoid revalidating the form with intermediate values\n                                  false\n                                )\n                              }\n                              updateAllChildFieldsChecked(fieldPath, checked)\n                            })\n                          }\n                        }\n                        if (!field.fields?.length) {\n                          formik.setFieldValue(\n                            `${path}.isChecked`,\n                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields?.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    <Spacings.Inline scale=\"xl\">\n                      <div />\n                      <FieldSection\n                        fields={field.fields}\n                        formik={formik}\n                        parentKeys={[...parentKeys, `fields[${index}]`]}\n                        isAnySiblingChecked={isAnySiblingChecked}\n                        isForceExpanded={isForceExpanded}\n                        groupName={groupName}\n                      />\n                    </Spacings.Inline>\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n"]} */",
1342
1354
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
1343
1355
  });
1344
1356
  const CollapsibleFieldWrapper = _ref => {
@@ -45,6 +45,7 @@ var constants = require('@commercetools-frontend/constants');
45
45
  var sdk = require('@commercetools-frontend/sdk');
46
46
  var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
47
47
  var l10n = require('@commercetools-frontend/l10n');
48
+ var sortBy = require('lodash/sortBy');
48
49
  var _styled = require('@emotion/styled/base');
49
50
  var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
50
51
  var throttle = require('lodash/throttle');
@@ -79,6 +80,7 @@ var _Set__default = /*#__PURE__*/_interopDefault(_Set);
79
80
  var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
80
81
  var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
81
82
  var moment__default = /*#__PURE__*/_interopDefault(moment);
83
+ var sortBy__default = /*#__PURE__*/_interopDefault(sortBy);
82
84
  var _styled__default = /*#__PURE__*/_interopDefault(_styled);
83
85
  var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
84
86
  var throttle__default = /*#__PURE__*/_interopDefault(throttle);
@@ -1077,14 +1079,23 @@ const useConvertFieldDefinitionsForExport = () => {
1077
1079
  })),
1078
1080
  language = _useApplicationContex.language,
1079
1081
  languages = _useApplicationContex.languages;
1082
+ const sortByField = (fields, fieldName) => {
1083
+ if (fieldName) {
1084
+ return sortBy__default["default"](fields, field => {
1085
+ return field[fieldName]?.toLowerCase();
1086
+ });
1087
+ }
1088
+ return fields;
1089
+ };
1080
1090
  const convertFieldDefinitionsForExport = _ref3 => {
1081
1091
  let fieldDefinitions = _ref3.fieldDefinitions,
1082
1092
  fieldPrefix = _ref3.fieldPrefix,
1083
1093
  _ref3$expandAll = _ref3.expandAll,
1084
- expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll;
1094
+ expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll,
1095
+ sortField = _ref3.sortField;
1085
1096
  if (!fieldDefinitions) return [];
1086
1097
  const localizedTypeDefinitions = localizeTypeDefinitionLabels(fieldDefinitions);
1087
- return _mapInstanceProperty__default["default"](localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1098
+ const results = _mapInstanceProperty__default["default"](localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1088
1099
  isExpandable: true,
1089
1100
  isExpanded: expandAll,
1090
1101
  name: transformedType.name,
@@ -1096,7 +1107,7 @@ const useConvertFieldDefinitionsForExport = () => {
1096
1107
  fallbackOrder: languages,
1097
1108
  fallback: transformedType.name
1098
1109
  }),
1099
- fields: transformedType.fields?.map(fieldDefinition => ({
1110
+ fields: sortByField(transformedType.fields?.map(fieldDefinition => ({
1100
1111
  name: getFieldFullName({
1101
1112
  fieldPrefix: fieldPrefix,
1102
1113
  fieldName: fieldDefinition.name
@@ -1109,8 +1120,9 @@ const useConvertFieldDefinitionsForExport = () => {
1109
1120
  fallbackOrder: languages,
1110
1121
  fallback: fieldDefinition.name
1111
1122
  })
1112
- }))
1123
+ })), sortField)
1113
1124
  }));
1125
+ return sortByField(results, sortField);
1114
1126
  };
1115
1127
  return {
1116
1128
  convertFieldDefinitionsForExport
@@ -1329,8 +1341,8 @@ const ExportFieldSelectionStamp = _ref => {
1329
1341
  const FieldWrapper = /*#__PURE__*/_styled__default["default"]("div", {
1330
1342
  target: "e1judmlm0"
1331
1343
  } )({
1332
- name: "bjn8wh",
1333
- styles: "position:relative"
1344
+ name: "9iujih",
1345
+ styles: "position:relative;display:flex;align-items:center"
1334
1346
  } );
1335
1347
  const CollapsibleFieldWrapper = _ref => {
1336
1348
  let isForceExpanded = _ref.isForceExpanded,
@@ -41,6 +41,7 @@ import { MC_API_PROXY_TARGETS, DOMAINS } from '@commercetools-frontend/constants
41
41
  import { actions, useAsyncDispatch } from '@commercetools-frontend/sdk';
42
42
  import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
43
43
  import { formatLocalizedString, applyTransformedLocalizedFields } from '@commercetools-frontend/l10n';
44
+ import sortBy from 'lodash/sortBy';
44
45
  import _styled from '@emotion/styled/base';
45
46
  import _includesInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/includes';
46
47
  import throttle from 'lodash/throttle';
@@ -1043,14 +1044,23 @@ const useConvertFieldDefinitionsForExport = () => {
1043
1044
  })),
1044
1045
  language = _useApplicationContex.language,
1045
1046
  languages = _useApplicationContex.languages;
1047
+ const sortByField = (fields, fieldName) => {
1048
+ if (fieldName) {
1049
+ return sortBy(fields, field => {
1050
+ return field[fieldName]?.toLowerCase();
1051
+ });
1052
+ }
1053
+ return fields;
1054
+ };
1046
1055
  const convertFieldDefinitionsForExport = _ref3 => {
1047
1056
  let fieldDefinitions = _ref3.fieldDefinitions,
1048
1057
  fieldPrefix = _ref3.fieldPrefix,
1049
1058
  _ref3$expandAll = _ref3.expandAll,
1050
- expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll;
1059
+ expandAll = _ref3$expandAll === void 0 ? false : _ref3$expandAll,
1060
+ sortField = _ref3.sortField;
1051
1061
  if (!fieldDefinitions) return [];
1052
1062
  const localizedTypeDefinitions = localizeTypeDefinitionLabels(fieldDefinitions);
1053
- return _mapInstanceProperty(localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1063
+ const results = _mapInstanceProperty(localizedTypeDefinitions).call(localizedTypeDefinitions, transformedType => ({
1054
1064
  isExpandable: true,
1055
1065
  isExpanded: expandAll,
1056
1066
  name: transformedType.name,
@@ -1062,7 +1072,7 @@ const useConvertFieldDefinitionsForExport = () => {
1062
1072
  fallbackOrder: languages,
1063
1073
  fallback: transformedType.name
1064
1074
  }),
1065
- fields: transformedType.fields?.map(fieldDefinition => ({
1075
+ fields: sortByField(transformedType.fields?.map(fieldDefinition => ({
1066
1076
  name: getFieldFullName({
1067
1077
  fieldPrefix: fieldPrefix,
1068
1078
  fieldName: fieldDefinition.name
@@ -1075,8 +1085,9 @@ const useConvertFieldDefinitionsForExport = () => {
1075
1085
  fallbackOrder: languages,
1076
1086
  fallback: fieldDefinition.name
1077
1087
  })
1078
- }))
1088
+ })), sortField)
1079
1089
  }));
1090
+ return sortByField(results, sortField);
1080
1091
  };
1081
1092
  return {
1082
1093
  convertFieldDefinitionsForExport
@@ -1299,12 +1310,12 @@ const FieldWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produ
1299
1310
  target: "e1judmlm0",
1300
1311
  label: "FieldWrapper"
1301
1312
  })(process.env.NODE_ENV === "production" ? {
1302
- name: "bjn8wh",
1303
- styles: "position:relative"
1313
+ name: "9iujih",
1314
+ styles: "position:relative;display:flex;align-items:center"
1304
1315
  } : {
1305
- name: "bjn8wh",
1306
- styles: "position:relative",
1307
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAkB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport type { FilteredField, FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => JSX.Element\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isForceExpanded?: boolean\n  groupName: string\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isForceExpanded,\n  groupName,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (field.isHidden) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isForceExpanded}\n            field={field}\n            key={`${field.name}.${isForceExpanded}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isForceExpanded) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\n                          if (item && item.fields) {\n                            item.fields.forEach((field, i) => {\n                              const fieldPath = `${path}.fields[${i}]`\n                              if (!field.fields?.length) {\n                                formik.setFieldValue(\n                                  `${fieldPath}.isChecked`,\n                                  checked || field.isRequired,\n                                  // pass `false` to avoid revalidating the form with intermediate values\n                                  false\n                                )\n                              }\n                              updateAllChildFieldsChecked(fieldPath, checked)\n                            })\n                          }\n                        }\n                        if (!field.fields?.length) {\n                          formik.setFieldValue(\n                            `${path}.isChecked`,\n                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields?.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    <Spacings.Inline scale=\"xl\">\n                      <div />\n                      <FieldSection\n                        fields={field.fields}\n                        formik={formik}\n                        parentKeys={[...parentKeys, `fields[${index}]`]}\n                        isAnySiblingChecked={isAnySiblingChecked}\n                        isForceExpanded={isForceExpanded}\n                        groupName={groupName}\n                      />\n                    </Spacings.Inline>\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n"]} */",
1316
+ name: "9iujih",
1317
+ styles: "position:relative;display:flex;align-items:center",
1318
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["field-section.tsx"],"names":[],"mappings":"AAkB+B","file":"field-section.tsx","sourcesContent":["import { Fragment } from 'react'\nimport {\n  AngleDownIcon,\n  AngleRightIcon,\n  CheckboxInput,\n  CollapsibleMotion,\n  IconButton,\n  Spacings,\n  designTokens,\n} from '@commercetools-frontend/ui-kit'\nimport styled from '@emotion/styled'\nimport type { FormikProps } from 'formik'\nimport get from 'lodash/get'\nimport { useExportFieldSelectionContext } from './export-field-selection-provider'\nimport { StyledExpandableContent } from './field-group-section'\nimport type { FilteredField, FormField, FormValues } from '../../@types'\nimport { areAllFieldsChecked, isAnyFieldChecked } from '../../@utils'\n\nconst FieldWrapper = styled.div`\n  position: relative;\n  display: flex;\n  align-items: center;\n`\n\ntype CollapsibleFieldWrapperProps = {\n  isForceExpanded?: boolean\n  field: FormField\n  children: (props: {\n    isOpen: boolean\n    toggle: () => void\n    registerContentNode: any\n  }) => JSX.Element\n}\nconst CollapsibleFieldWrapper = ({\n  isForceExpanded,\n  field,\n  children,\n}: CollapsibleFieldWrapperProps) => {\n  if (field.isExpandable)\n    return (\n      <CollapsibleMotion\n        isDefaultClosed={isForceExpanded ? false : !field.isExpanded}\n        key={`${isForceExpanded}`}\n      >\n        {({ isOpen, toggle, registerContentNode }) =>\n          children({\n            isOpen,\n            toggle,\n            registerContentNode,\n          })\n        }\n      </CollapsibleMotion>\n    )\n  return children({\n    isOpen: true,\n    toggle: () => {},\n    registerContentNode: () => {},\n  })\n}\n\ntype FieldSectionProps = {\n  fields?: FilteredField[]\n  parentKeys: string[]\n  formik: FormikProps<FormValues>\n  isAnySiblingChecked: boolean\n  isForceExpanded?: boolean\n  groupName: string\n}\n\nexport const FieldSection = ({\n  fields,\n  parentKeys,\n  formik,\n  isAnySiblingChecked,\n  isForceExpanded,\n  groupName,\n}: FieldSectionProps) => {\n  const { updateExpandedGroups } = useExportFieldSelectionContext()\n\n  return (\n    <Spacings.Stack scale=\"s\">\n      {fields?.map((field, index) => {\n        const hasDependents = Boolean(\n          field.dependentGroupNames?.length || field.dependentFieldNames?.length\n        )\n        const isAnyOfTheChildFieldsChecked = isAnyFieldChecked(\n          field.fields || []\n        )\n        const allFieldsChecked = areAllFieldsChecked(field.fields || [])\n        const getIsChecked = () => {\n          const isParent = Boolean(field.fields && field.fields?.length > 0)\n\n          if (isParent) return areAllFieldsChecked(field.fields!)\n\n          return field.isChecked\n        }\n        if (field.isHidden) return null\n        return (\n          <CollapsibleFieldWrapper\n            isForceExpanded={isForceExpanded}\n            field={field}\n            key={`${field.name}.${isForceExpanded}`}\n          >\n            {({ isOpen, toggle, registerContentNode }) => (\n              <Fragment key={`${field.name}-${index}`}>\n                <FieldWrapper>\n                  {field.isExpandable && (\n                    <IconButton\n                      size=\"20\"\n                      style={{\n                        position: 'absolute',\n                        left: `calc(-1 * ${designTokens.spacingXl})`,\n                      }}\n                      onClick={() => {\n                        if (!isForceExpanded) {\n                          updateExpandedGroups(\n                            `${groupName}.${field.name}`,\n                            !isOpen\n                          )\n                        }\n                        toggle()\n                      }}\n                      icon={isOpen ? <AngleDownIcon /> : <AngleRightIcon />}\n                      label=\"\"\n                    />\n                  )}\n                  <Spacings.Inline scale=\"s\" alignItems=\"center\">\n                    <CheckboxInput\n                      isIndeterminate={\n                        field.isExpandable &&\n                        !allFieldsChecked &&\n                        isAnyOfTheChildFieldsChecked\n                      }\n                      isChecked={getIsChecked()}\n                      isReadOnly={hasDependents || field.isRequired}\n                      onChange={(e) => {\n                        const path = `${parentKeys.join('.')}.fields[${index}]`\n                        const checked = e.target.checked\n                        // Update all child fields\n                        const updateAllChildFieldsChecked = (\n                          path: string,\n                          checked: boolean\n                        ) => {\n                          const item = get(formik.values, path) as FormField\n                          if (item && item.fields) {\n                            item.fields.forEach((field, i) => {\n                              const fieldPath = `${path}.fields[${i}]`\n                              if (!field.fields?.length) {\n                                formik.setFieldValue(\n                                  `${fieldPath}.isChecked`,\n                                  checked || field.isRequired,\n                                  // pass `false` to avoid revalidating the form with intermediate values\n                                  false\n                                )\n                              }\n                              updateAllChildFieldsChecked(fieldPath, checked)\n                            })\n                          }\n                        }\n                        if (!field.fields?.length) {\n                          formik.setFieldValue(\n                            `${path}.isChecked`,\n                            checked || field.isRequired,\n                            // pass `false` to avoid revalidating the form with intermediate values\n                            false\n                          )\n                        }\n                        updateAllChildFieldsChecked(path, checked)\n                      }}\n                    >\n                      {field.label}\n                      {(hasDependents || field.isRequired) && ' *'}\n                    </CheckboxInput>\n                  </Spacings.Inline>\n                </FieldWrapper>\n                {field.fields && field.fields?.length > 0 && (\n                  <StyledExpandableContent\n                    ref={registerContentNode}\n                    isOpen={isOpen}\n                  >\n                    <Spacings.Inline scale=\"xl\">\n                      <div />\n                      <FieldSection\n                        fields={field.fields}\n                        formik={formik}\n                        parentKeys={[...parentKeys, `fields[${index}]`]}\n                        isAnySiblingChecked={isAnySiblingChecked}\n                        isForceExpanded={isForceExpanded}\n                        groupName={groupName}\n                      />\n                    </Spacings.Inline>\n                  </StyledExpandableContent>\n                )}\n              </Fragment>\n            )}\n          </CollapsibleFieldWrapper>\n        )\n      })}\n    </Spacings.Stack>\n  )\n}\n"]} */",
1308
1319
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
1309
1320
  });
1310
1321
  const CollapsibleFieldWrapper = _ref => {
@@ -1,8 +1,9 @@
1
1
  import type { Field, FieldDefinition } from "../@types/index.js";
2
2
  export declare const useConvertFieldDefinitionsForExport: () => {
3
- convertFieldDefinitionsForExport: ({ fieldDefinitions, fieldPrefix, expandAll, }: {
3
+ convertFieldDefinitionsForExport: ({ fieldDefinitions, fieldPrefix, expandAll, sortField, }: {
4
4
  fieldDefinitions?: FieldDefinition[] | undefined;
5
5
  fieldPrefix?: string | undefined;
6
6
  expandAll?: boolean | undefined;
7
+ sortField?: string | undefined;
7
8
  }) => Field[];
8
9
  };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-frontend-extensions/export-resources-modal",
3
3
  "description": "Shared export modal for exporting resources",
4
- "version": "4.6.6",
4
+ "version": "4.6.8",
5
5
  "license": "BSD-3-Clause",
6
6
  "publishConfig": {
7
7
  "access": "public"