decap-cms-core 3.5.0 → 3.6.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.
Files changed (137) hide show
  1. package/dist/decap-cms-core.js +9 -9
  2. package/dist/decap-cms-core.js.map +1 -1
  3. package/dist/esm/actions/auth.js +22 -37
  4. package/dist/esm/actions/collections.js +9 -17
  5. package/dist/esm/actions/config.js +58 -74
  6. package/dist/esm/actions/deploys.js +10 -17
  7. package/dist/esm/actions/editorialWorkflow.js +87 -101
  8. package/dist/esm/actions/entries.js +161 -211
  9. package/dist/esm/actions/media.js +31 -46
  10. package/dist/esm/actions/mediaLibrary.js +94 -126
  11. package/dist/esm/actions/notifications.js +5 -13
  12. package/dist/esm/actions/search.js +30 -47
  13. package/dist/esm/actions/status.js +13 -23
  14. package/dist/esm/actions/waitUntil.js +4 -11
  15. package/dist/esm/backend.js +132 -148
  16. package/dist/esm/bootstrap.js +37 -44
  17. package/dist/esm/components/App/App.js +82 -89
  18. package/dist/esm/components/App/Header.js +46 -52
  19. package/dist/esm/components/App/NotFoundPage.js +11 -18
  20. package/dist/esm/components/Collection/Collection.js +55 -63
  21. package/dist/esm/components/Collection/CollectionControls.js +15 -22
  22. package/dist/esm/components/Collection/CollectionSearch.js +35 -42
  23. package/dist/esm/components/Collection/CollectionTop.js +23 -30
  24. package/dist/esm/components/Collection/ControlButton.js +10 -16
  25. package/dist/esm/components/Collection/Entries/Entries.js +24 -31
  26. package/dist/esm/components/Collection/Entries/EntriesCollection.js +52 -62
  27. package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
  28. package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
  29. package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
  30. package/dist/esm/components/Collection/FilterControl.js +9 -16
  31. package/dist/esm/components/Collection/GroupControl.js +9 -16
  32. package/dist/esm/components/Collection/NestedCollection.js +54 -65
  33. package/dist/esm/components/Collection/Sidebar.js +36 -43
  34. package/dist/esm/components/Collection/SortControl.js +19 -26
  35. package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
  36. package/dist/esm/components/Editor/Editor.js +100 -108
  37. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
  38. package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
  39. package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
  40. package/dist/esm/components/Editor/EditorInterface.js +95 -98
  41. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
  42. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
  43. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
  44. package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
  45. package/dist/esm/components/Editor/EditorToolbar.js +133 -140
  46. package/dist/esm/components/Editor/withWorkflow.js +15 -22
  47. package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
  48. package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
  49. package/dist/esm/components/EditorWidgets/index.js +4 -7
  50. package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
  51. package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
  52. package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
  53. package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
  54. package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
  55. package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
  56. package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
  57. package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
  58. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
  59. package/dist/esm/components/UI/DragDrop.js +21 -30
  60. package/dist/esm/components/UI/ErrorBoundary.js +35 -43
  61. package/dist/esm/components/UI/FileUploadButton.js +11 -18
  62. package/dist/esm/components/UI/Modal.js +19 -26
  63. package/dist/esm/components/UI/Notifications.js +21 -28
  64. package/dist/esm/components/UI/SettingsDropdown.js +28 -34
  65. package/dist/esm/components/UI/index.js +6 -60
  66. package/dist/esm/components/Workflow/Workflow.js +52 -61
  67. package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
  68. package/dist/esm/components/Workflow/WorkflowList.js +43 -49
  69. package/dist/esm/constants/collectionTypes.js +2 -8
  70. package/dist/esm/constants/collectionViews.js +2 -8
  71. package/dist/esm/constants/commitProps.js +2 -8
  72. package/dist/esm/constants/configSchema.js +20 -27
  73. package/dist/esm/constants/fieldInference.js +8 -15
  74. package/dist/esm/constants/publishModes.js +6 -11
  75. package/dist/esm/constants/validationErrorTypes.js +1 -7
  76. package/dist/esm/formats/formats.js +32 -41
  77. package/dist/esm/formats/frontmatter.js +18 -30
  78. package/dist/esm/formats/helpers.js +1 -7
  79. package/dist/esm/formats/json.js +1 -7
  80. package/dist/esm/formats/toml.js +11 -18
  81. package/dist/esm/formats/yaml.js +7 -14
  82. package/dist/esm/index.js +5 -12
  83. package/dist/esm/integrations/index.js +8 -16
  84. package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
  85. package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
  86. package/dist/esm/lib/consoleError.js +1 -7
  87. package/dist/esm/lib/formatters.js +34 -47
  88. package/dist/esm/lib/i18n.js +37 -66
  89. package/dist/esm/lib/phrases.js +4 -11
  90. package/dist/esm/lib/registry.js +40 -75
  91. package/dist/esm/lib/serializeEntryValues.js +11 -18
  92. package/dist/esm/lib/textHelper.js +1 -7
  93. package/dist/esm/lib/urlHelper.js +28 -43
  94. package/dist/esm/mediaLibrary.js +12 -16
  95. package/dist/esm/reducers/auth.js +10 -16
  96. package/dist/esm/reducers/collections.js +70 -102
  97. package/dist/esm/reducers/combinedReducer.js +4 -11
  98. package/dist/esm/reducers/config.js +11 -19
  99. package/dist/esm/reducers/cursors.js +12 -18
  100. package/dist/esm/reducers/deploys.js +8 -15
  101. package/dist/esm/reducers/editorialWorkflow.js +37 -47
  102. package/dist/esm/reducers/entries.js +107 -132
  103. package/dist/esm/reducers/entryDraft.js +64 -72
  104. package/dist/esm/reducers/globalUI.js +5 -11
  105. package/dist/esm/reducers/index.js +43 -64
  106. package/dist/esm/reducers/integrations.js +8 -16
  107. package/dist/esm/reducers/mediaLibrary.js +43 -52
  108. package/dist/esm/reducers/medias.js +11 -18
  109. package/dist/esm/reducers/notifications.js +9 -15
  110. package/dist/esm/reducers/search.js +12 -18
  111. package/dist/esm/reducers/status.js +7 -13
  112. package/dist/esm/redux/index.js +7 -13
  113. package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
  114. package/dist/esm/routing/history.js +7 -15
  115. package/dist/esm/types/diacritics.d.js +0 -1
  116. package/dist/esm/types/global.d.js +1 -5
  117. package/dist/esm/types/immutable.js +1 -5
  118. package/dist/esm/types/redux.js +7 -8
  119. package/dist/esm/types/tomlify-j0.4.d.js +0 -1
  120. package/dist/esm/valueObjects/AssetProxy.js +2 -10
  121. package/dist/esm/valueObjects/EditorComponent.js +5 -12
  122. package/dist/esm/valueObjects/Entry.js +3 -10
  123. package/package.json +3 -2
  124. package/src/components/Collection/Entries/EntriesCollection.js +7 -8
  125. package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +3 -5
  126. package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +8 -8
  127. package/src/components/Collection/NestedCollection.js +2 -2
  128. package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
  129. package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
  130. package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
  131. package/src/components/Editor/EditorControlPane/Widget.js +22 -1
  132. package/src/components/Editor/EditorInterface.js +6 -1
  133. package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
  134. package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
  135. package/dist/esm/actions/editorControl.js +0 -14
  136. package/dist/esm/reducers/editorComponent.js +0 -1
  137. package/dist/esm/reducers/editorControl.js +0 -17
@@ -1,23 +1,17 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _react = _interopRequireDefault(require("react"));
9
- var _propTypes = _interopRequireDefault(require("prop-types"));
10
- var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
11
- var _react2 = require("@emotion/react");
12
- var _decapCmsUiDefault = require("decap-cms-ui-default");
13
- var _EditorControl = _interopRequireDefault(require("./EditorControl"));
14
- var _i18n = require("../../../lib/i18n");
15
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
1
+ import _styled from "@emotion/styled/base";
16
2
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
3
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
18
4
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
19
5
  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)."; }
20
- const ControlPaneContainer = /*#__PURE__*/(0, _base.default)("div", {
6
+ import React from 'react';
7
+ import PropTypes from 'prop-types';
8
+ import ImmutablePropTypes from 'react-immutable-proptypes';
9
+ import { css } from '@emotion/react';
10
+ import { buttons, colors, Dropdown, DropdownItem, StyledDropdownButton, text } from 'decap-cms-ui-default';
11
+ import EditorControl from './EditorControl';
12
+ import { getI18nInfo, getLocaleDataPath, hasI18n, isFieldDuplicate, isFieldHidden, isFieldTranslatable } from '../../../lib/i18n';
13
+ import { jsx as ___EmotionJSX } from "@emotion/react";
14
+ const ControlPaneContainer = /*#__PURE__*/_styled("div", {
21
15
  target: "e11hw0lx4",
22
16
  label: "ControlPaneContainer"
23
17
  })(process.env.NODE_ENV === "production" ? {
@@ -26,14 +20,14 @@ const ControlPaneContainer = /*#__PURE__*/(0, _base.default)("div", {
26
20
  } : {
27
21
  name: "1n0x6o4",
28
22
  styles: "max-width:800px;margin:0 auto;padding-bottom:16px;font-size:16px",
29
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAwBuC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
23
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAwBuC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
30
24
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
25
  });
32
- const LocaleButton = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.StyledDropdownButton, {
26
+ const LocaleButton = /*#__PURE__*/_styled(StyledDropdownButton, {
33
27
  target: "e11hw0lx3",
34
28
  label: "LocaleButton"
35
- })(_decapCmsUiDefault.buttons.button, ";", _decapCmsUiDefault.buttons.medium, ";color:", _decapCmsUiDefault.colors.controlLabel, ";background:", _decapCmsUiDefault.colors.textFieldBorder, ";height:100%;&:after{top:11px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA+BiD","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */"));
36
- const LocaleButtonWrapper = /*#__PURE__*/(0, _base.default)("div", {
29
+ })(buttons.button, ";", buttons.medium, ";color:", colors.controlLabel, ";background:", colors.textFieldBorder, ";height:100%;&:after{top:11px;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA+BiD","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */"));
30
+ const LocaleButtonWrapper = /*#__PURE__*/_styled("div", {
37
31
  target: "e11hw0lx2",
38
32
  label: "LocaleButtonWrapper"
39
33
  })(process.env.NODE_ENV === "production" ? {
@@ -42,10 +36,10 @@ const LocaleButtonWrapper = /*#__PURE__*/(0, _base.default)("div", {
42
36
  } : {
43
37
  name: "zjik7",
44
38
  styles: "display:flex",
45
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA2CsC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
39
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA2CsC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
46
40
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
41
  });
48
- const LocaleRowWrapper = /*#__PURE__*/(0, _base.default)("div", {
42
+ const LocaleRowWrapper = /*#__PURE__*/_styled("div", {
49
43
  target: "e11hw0lx1",
50
44
  label: "LocaleRowWrapper"
51
45
  })(process.env.NODE_ENV === "production" ? {
@@ -54,10 +48,10 @@ const LocaleRowWrapper = /*#__PURE__*/(0, _base.default)("div", {
54
48
  } : {
55
49
  name: "zjik7",
56
50
  styles: "display:flex",
57
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA+CmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
51
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AA+CmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
58
52
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
53
  });
60
- const StyledDropdown = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.Dropdown, {
54
+ const StyledDropdown = /*#__PURE__*/_styled(Dropdown, {
61
55
  target: "e11hw0lx0",
62
56
  label: "StyledDropdown"
63
57
  })(process.env.NODE_ENV === "production" ? {
@@ -66,7 +60,7 @@ const StyledDropdown = /*#__PURE__*/(0, _base.default)(_decapCmsUiDefault.Dropdo
66
60
  } : {
67
61
  name: "1hfmrg2",
68
62
  styles: "width:max-content;margin-top:20px;margin-bottom:20px;margin-right:20px",
69
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAmDuC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
63
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAmDuC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */",
70
64
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
65
  });
72
66
  function LocaleDropdown({
@@ -74,12 +68,12 @@ function LocaleDropdown({
74
68
  dropdownText,
75
69
  onLocaleChange
76
70
  }) {
77
- return (0, _react2.jsx)(StyledDropdown, {
71
+ return ___EmotionJSX(StyledDropdown, {
78
72
  renderButton: () => {
79
- return (0, _react2.jsx)(LocaleButtonWrapper, null, (0, _react2.jsx)(LocaleButton, null, dropdownText));
73
+ return ___EmotionJSX(LocaleButtonWrapper, null, ___EmotionJSX(LocaleButton, null, dropdownText));
80
74
  }
81
- }, locales.map(l => (0, _react2.jsx)(_decapCmsUiDefault.DropdownItem, {
82
- css: /*#__PURE__*/(0, _react2.css)(_decapCmsUiDefault.text.fieldLabel, ";;label:LocaleDropdown;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAuEkB","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  componentValidate = {};\n\n  controlRef(field, wrappedControl) {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n\n    this.componentValidate[name] =\n      wrappedControl.innerWrappedControl?.validate || wrappedControl.validate;\n  }\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      this.componentValidate[field.get('name')]();\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                processControlRef={this.controlRef.bind(this)}\n                controlRef={this.controlRef}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */")),
75
+ }, locales.map(l => ___EmotionJSX(DropdownItem, {
76
+ css: /*#__PURE__*/css(text.fieldLabel, ";;label:LocaleDropdown;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js"],"names":[],"mappings":"AAuEkB","file":"../../../../../src/components/Editor/EditorControlPane/EditorControlPane.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport {\n  buttons,\n  colors,\n  Dropdown,\n  DropdownItem,\n  StyledDropdownButton,\n  text,\n} from 'decap-cms-ui-default';\n\nimport EditorControl from './EditorControl';\nimport {\n  getI18nInfo,\n  getLocaleDataPath,\n  hasI18n,\n  isFieldDuplicate,\n  isFieldHidden,\n  isFieldTranslatable,\n} from '../../../lib/i18n';\n\nconst ControlPaneContainer = styled.div`\n  max-width: 800px;\n  margin: 0 auto;\n  padding-bottom: 16px;\n  font-size: 16px;\n`;\n\nconst LocaleButton = styled(StyledDropdownButton)`\n  ${buttons.button};\n  ${buttons.medium};\n  color: ${colors.controlLabel};\n  background: ${colors.textFieldBorder};\n  height: 100%;\n\n  &:after {\n    top: 11px;\n  }\n`;\n\nconst LocaleButtonWrapper = styled.div`\n  display: flex;\n`;\n\nconst LocaleRowWrapper = styled.div`\n  display: flex;\n`;\n\nconst StyledDropdown = styled(Dropdown)`\n  width: max-content;\n  margin-top: 20px;\n  margin-bottom: 20px;\n  margin-right: 20px;\n`;\n\nfunction LocaleDropdown({ locales, dropdownText, onLocaleChange }) {\n  return (\n    <StyledDropdown\n      renderButton={() => {\n        return (\n          <LocaleButtonWrapper>\n            <LocaleButton>{dropdownText}</LocaleButton>\n          </LocaleButtonWrapper>\n        );\n      }}\n    >\n      {locales.map(l => (\n        <DropdownItem\n          css={css`\n            ${text.fieldLabel}\n          `}\n          key={l}\n          label={l}\n          onClick={() => onLocaleChange(l)}\n        />\n      ))}\n    </StyledDropdown>\n  );\n}\n\nfunction getFieldValue({ field, entry, isTranslatable, locale }) {\n  if (field.get('meta')) {\n    return entry.getIn(['meta', field.get('name')]);\n  }\n\n  if (isTranslatable) {\n    const dataPath = getLocaleDataPath(locale);\n    return entry.getIn([...dataPath, field.get('name')]);\n  }\n\n  return entry.getIn(['data', field.get('name')]);\n}\n\nexport default class ControlPane extends React.Component {\n  state = {\n    selectedLocale: this.props.locale,\n  };\n\n  childRefs = {};\n\n  controlRef = (field, wrappedControl) => {\n    if (!wrappedControl) return;\n    const name = field.get('name');\n    this.childRefs[name] = wrappedControl;\n  };\n\n  getControlRef = field => wrappedControl => {\n    this.controlRef(field, wrappedControl);\n  };\n\n  handleLocaleChange = val => {\n    this.setState({ selectedLocale: val });\n    this.props.onLocaleChange(val);\n  };\n\n  copyFromOtherLocale =\n    ({ targetLocale, t }) =>\n    sourceLocale => {\n      if (\n        !window.confirm(\n          t('editor.editorControlPane.i18n.copyFromLocaleConfirm', {\n            locale: sourceLocale.toUpperCase(),\n          }),\n        )\n      ) {\n        return;\n      }\n      const { entry, collection } = this.props;\n      const { locales, defaultLocale } = getI18nInfo(collection);\n\n      const locale = this.state.selectedLocale;\n      const i18n = locales && {\n        currentLocale: locale,\n        locales,\n        defaultLocale,\n      };\n\n      this.props.fields.forEach(field => {\n        if (isFieldTranslatable(field, targetLocale, sourceLocale)) {\n          const copyValue = getFieldValue({\n            field,\n            entry,\n            locale: sourceLocale,\n            isTranslatable: sourceLocale !== defaultLocale,\n          });\n          if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);\n        }\n      });\n    };\n\n  validate = async () => {\n    this.props.fields.forEach(field => {\n      if (field.get('widget') === 'hidden') return;\n      const control = this.childRefs[field.get('name')];\n      const validateFn = control?.innerWrappedControl?.validate ?? control?.validate;\n      if (validateFn) {\n        validateFn();\n      }\n    });\n  };\n\n  switchToDefaultLocale = () => {\n    if (hasI18n(this.props.collection)) {\n      const { defaultLocale } = getI18nInfo(this.props.collection);\n      return new Promise(resolve => this.setState({ selectedLocale: defaultLocale }, resolve));\n    } else {\n      return Promise.resolve();\n    }\n  };\n\n  focus(path) {\n    const [fieldName, ...remainingPath] = path.split('.');\n    const control = this.childRefs[fieldName];\n    if (control?.focus) {\n      control.focus(remainingPath.join('.'));\n    }\n  }\n\n  render() {\n    const { collection, entry, fields, fieldsMetaData, fieldsErrors, onChange, onValidate, t } =\n      this.props;\n\n    if (!collection || !fields) {\n      return null;\n    }\n\n    if (entry.size === 0 || entry.get('partial') === true) {\n      return null;\n    }\n\n    const { locales, defaultLocale } = getI18nInfo(collection);\n    const locale = this.state.selectedLocale;\n    const i18n = locales && {\n      currentLocale: locale,\n      locales,\n      defaultLocale,\n    };\n\n    return (\n      <ControlPaneContainer>\n        {locales && (\n          <LocaleRowWrapper>\n            <LocaleDropdown\n              locales={locales}\n              dropdownText={t('editor.editorControlPane.i18n.writingInLocale', {\n                locale: locale.toUpperCase(),\n              })}\n              onLocaleChange={this.handleLocaleChange}\n            />\n            <LocaleDropdown\n              locales={locales.filter(l => l !== locale)}\n              dropdownText={t('editor.editorControlPane.i18n.copyFromLocale')}\n              onLocaleChange={this.copyFromOtherLocale({ targetLocale: locale, t })}\n            />\n          </LocaleRowWrapper>\n        )}\n        {fields\n          .filter(f => f.get('widget') !== 'hidden')\n          .map((field, i) => {\n            const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);\n            const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);\n            const isHidden = isFieldHidden(field, locale, defaultLocale);\n            const key = i18n ? `${locale}_${i}` : i;\n\n            return (\n              <EditorControl\n                key={key}\n                field={field}\n                value={getFieldValue({\n                  field,\n                  entry,\n                  locale,\n                  isTranslatable,\n                })}\n                fieldsMetaData={fieldsMetaData}\n                fieldsErrors={fieldsErrors}\n                onChange={(field, newValue, newMetadata) => {\n                  onChange(field, newValue, newMetadata, i18n);\n                }}\n                onValidate={onValidate}\n                controlRef={this.getControlRef(field)}\n                entry={entry}\n                collection={collection}\n                isDisabled={isDuplicate}\n                isHidden={isHidden}\n                isFieldDuplicate={field => isFieldDuplicate(field, locale, defaultLocale)}\n                isFieldHidden={field => isFieldHidden(field, locale, defaultLocale)}\n                locale={locale}\n              />\n            );\n          })}\n      </ControlPaneContainer>\n    );\n  }\n}\n\nControlPane.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  entry: ImmutablePropTypes.map.isRequired,\n  fields: ImmutablePropTypes.list.isRequired,\n  fieldsMetaData: ImmutablePropTypes.map.isRequired,\n  fieldsErrors: ImmutablePropTypes.map.isRequired,\n  onChange: PropTypes.func.isRequired,\n  onValidate: PropTypes.func.isRequired,\n  locale: PropTypes.string,\n};\n"]} */")),
83
77
  key: l,
84
78
  label: l,
85
79
  onClick: () => onLocaleChange(l)
@@ -95,18 +89,26 @@ function getFieldValue({
95
89
  return entry.getIn(['meta', field.get('name')]);
96
90
  }
97
91
  if (isTranslatable) {
98
- const dataPath = (0, _i18n.getLocaleDataPath)(locale);
92
+ const dataPath = getLocaleDataPath(locale);
99
93
  return entry.getIn([...dataPath, field.get('name')]);
100
94
  }
101
95
  return entry.getIn(['data', field.get('name')]);
102
96
  }
103
- class ControlPane extends _react.default.Component {
97
+ export default class ControlPane extends React.Component {
104
98
  constructor(...args) {
105
99
  super(...args);
106
100
  _defineProperty(this, "state", {
107
101
  selectedLocale: this.props.locale
108
102
  });
109
- _defineProperty(this, "componentValidate", {});
103
+ _defineProperty(this, "childRefs", {});
104
+ _defineProperty(this, "controlRef", (field, wrappedControl) => {
105
+ if (!wrappedControl) return;
106
+ const name = field.get('name');
107
+ this.childRefs[name] = wrappedControl;
108
+ });
109
+ _defineProperty(this, "getControlRef", field => wrappedControl => {
110
+ this.controlRef(field, wrappedControl);
111
+ });
110
112
  _defineProperty(this, "handleLocaleChange", val => {
111
113
  this.setState({
112
114
  selectedLocale: val
@@ -129,7 +131,7 @@ class ControlPane extends _react.default.Component {
129
131
  const {
130
132
  locales,
131
133
  defaultLocale
132
- } = (0, _i18n.getI18nInfo)(collection);
134
+ } = getI18nInfo(collection);
133
135
  const locale = this.state.selectedLocale;
134
136
  const i18n = locales && {
135
137
  currentLocale: locale,
@@ -137,7 +139,7 @@ class ControlPane extends _react.default.Component {
137
139
  defaultLocale
138
140
  };
139
141
  this.props.fields.forEach(field => {
140
- if ((0, _i18n.isFieldTranslatable)(field, targetLocale, sourceLocale)) {
142
+ if (isFieldTranslatable(field, targetLocale, sourceLocale)) {
141
143
  const copyValue = getFieldValue({
142
144
  field,
143
145
  entry,
@@ -150,15 +152,20 @@ class ControlPane extends _react.default.Component {
150
152
  });
151
153
  _defineProperty(this, "validate", async () => {
152
154
  this.props.fields.forEach(field => {
155
+ var _control$innerWrapped, _control$innerWrapped2;
153
156
  if (field.get('widget') === 'hidden') return;
154
- this.componentValidate[field.get('name')]();
157
+ const control = this.childRefs[field.get('name')];
158
+ const validateFn = (_control$innerWrapped = control === null || control === void 0 ? void 0 : (_control$innerWrapped2 = control.innerWrappedControl) === null || _control$innerWrapped2 === void 0 ? void 0 : _control$innerWrapped2.validate) !== null && _control$innerWrapped !== void 0 ? _control$innerWrapped : control === null || control === void 0 ? void 0 : control.validate;
159
+ if (validateFn) {
160
+ validateFn();
161
+ }
155
162
  });
156
163
  });
157
164
  _defineProperty(this, "switchToDefaultLocale", () => {
158
- if ((0, _i18n.hasI18n)(this.props.collection)) {
165
+ if (hasI18n(this.props.collection)) {
159
166
  const {
160
167
  defaultLocale
161
- } = (0, _i18n.getI18nInfo)(this.props.collection);
168
+ } = getI18nInfo(this.props.collection);
162
169
  return new Promise(resolve => this.setState({
163
170
  selectedLocale: defaultLocale
164
171
  }, resolve));
@@ -167,11 +174,12 @@ class ControlPane extends _react.default.Component {
167
174
  }
168
175
  });
169
176
  }
170
- controlRef(field, wrappedControl) {
171
- var _wrappedControl$inner;
172
- if (!wrappedControl) return;
173
- const name = field.get('name');
174
- this.componentValidate[name] = ((_wrappedControl$inner = wrappedControl.innerWrappedControl) === null || _wrappedControl$inner === void 0 ? void 0 : _wrappedControl$inner.validate) || wrappedControl.validate;
177
+ focus(path) {
178
+ const [fieldName, ...remainingPath] = path.split('.');
179
+ const control = this.childRefs[fieldName];
180
+ if (control !== null && control !== void 0 && control.focus) {
181
+ control.focus(remainingPath.join('.'));
182
+ }
175
183
  }
176
184
  render() {
177
185
  const {
@@ -193,20 +201,20 @@ class ControlPane extends _react.default.Component {
193
201
  const {
194
202
  locales,
195
203
  defaultLocale
196
- } = (0, _i18n.getI18nInfo)(collection);
204
+ } = getI18nInfo(collection);
197
205
  const locale = this.state.selectedLocale;
198
206
  const i18n = locales && {
199
207
  currentLocale: locale,
200
208
  locales,
201
209
  defaultLocale
202
210
  };
203
- return (0, _react2.jsx)(ControlPaneContainer, null, locales && (0, _react2.jsx)(LocaleRowWrapper, null, (0, _react2.jsx)(LocaleDropdown, {
211
+ return ___EmotionJSX(ControlPaneContainer, null, locales && ___EmotionJSX(LocaleRowWrapper, null, ___EmotionJSX(LocaleDropdown, {
204
212
  locales: locales,
205
213
  dropdownText: t('editor.editorControlPane.i18n.writingInLocale', {
206
214
  locale: locale.toUpperCase()
207
215
  }),
208
216
  onLocaleChange: this.handleLocaleChange
209
- }), (0, _react2.jsx)(LocaleDropdown, {
217
+ }), ___EmotionJSX(LocaleDropdown, {
210
218
  locales: locales.filter(l => l !== locale),
211
219
  dropdownText: t('editor.editorControlPane.i18n.copyFromLocale'),
212
220
  onLocaleChange: this.copyFromOtherLocale({
@@ -214,11 +222,11 @@ class ControlPane extends _react.default.Component {
214
222
  t
215
223
  })
216
224
  })), fields.filter(f => f.get('widget') !== 'hidden').map((field, i) => {
217
- const isTranslatable = (0, _i18n.isFieldTranslatable)(field, locale, defaultLocale);
218
- const isDuplicate = (0, _i18n.isFieldDuplicate)(field, locale, defaultLocale);
219
- const isHidden = (0, _i18n.isFieldHidden)(field, locale, defaultLocale);
225
+ const isTranslatable = isFieldTranslatable(field, locale, defaultLocale);
226
+ const isDuplicate = isFieldDuplicate(field, locale, defaultLocale);
227
+ const isHidden = isFieldHidden(field, locale, defaultLocale);
220
228
  const key = i18n ? `${locale}_${i}` : i;
221
- return (0, _react2.jsx)(_EditorControl.default, {
229
+ return ___EmotionJSX(EditorControl, {
222
230
  key: key,
223
231
  field: field,
224
232
  value: getFieldValue({
@@ -233,27 +241,25 @@ class ControlPane extends _react.default.Component {
233
241
  onChange(field, newValue, newMetadata, i18n);
234
242
  },
235
243
  onValidate: onValidate,
236
- processControlRef: this.controlRef.bind(this),
237
- controlRef: this.controlRef,
244
+ controlRef: this.getControlRef(field),
238
245
  entry: entry,
239
246
  collection: collection,
240
247
  isDisabled: isDuplicate,
241
248
  isHidden: isHidden,
242
- isFieldDuplicate: field => (0, _i18n.isFieldDuplicate)(field, locale, defaultLocale),
243
- isFieldHidden: field => (0, _i18n.isFieldHidden)(field, locale, defaultLocale),
249
+ isFieldDuplicate: field => isFieldDuplicate(field, locale, defaultLocale),
250
+ isFieldHidden: field => isFieldHidden(field, locale, defaultLocale),
244
251
  locale: locale
245
252
  });
246
253
  }));
247
254
  }
248
255
  }
249
- exports.default = ControlPane;
250
256
  ControlPane.propTypes = {
251
- collection: _reactImmutableProptypes.default.map.isRequired,
252
- entry: _reactImmutableProptypes.default.map.isRequired,
253
- fields: _reactImmutableProptypes.default.list.isRequired,
254
- fieldsMetaData: _reactImmutableProptypes.default.map.isRequired,
255
- fieldsErrors: _reactImmutableProptypes.default.map.isRequired,
256
- onChange: _propTypes.default.func.isRequired,
257
- onValidate: _propTypes.default.func.isRequired,
258
- locale: _propTypes.default.string
257
+ collection: ImmutablePropTypes.map.isRequired,
258
+ entry: ImmutablePropTypes.map.isRequired,
259
+ fields: ImmutablePropTypes.list.isRequired,
260
+ fieldsMetaData: ImmutablePropTypes.map.isRequired,
261
+ fieldsErrors: ImmutablePropTypes.map.isRequired,
262
+ onChange: PropTypes.func.isRequired,
263
+ onValidate: PropTypes.func.isRequired,
264
+ locale: PropTypes.string
259
265
  };