decap-cms-core 3.2.2 → 3.2.4

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.
@@ -203,6 +203,19 @@ function collectionDepth(collection) {
203
203
  }
204
204
  return depth;
205
205
  }
206
+ function collectionRegex(collection) {
207
+ let ruleString = '';
208
+ if (collection.get('path')) {
209
+ ruleString = `${collection.get('folder')}/${collection.get('path')}`.replace(/{{.*}}/gm, '(.*)');
210
+ }
211
+ if ((0, _i18n.hasI18n)(collection)) {
212
+ const {
213
+ defaultLocale
214
+ } = (0, _i18n.getI18nInfo)(collection);
215
+ ruleString += `\\.${defaultLocale}\\..*`;
216
+ }
217
+ return ruleString ? new RegExp(ruleString) : undefined;
218
+ }
206
219
  class Backend {
207
220
  constructor(implementation, {
208
221
  backendName,
@@ -413,7 +426,7 @@ class Backend {
413
426
  if (collection.get('folder') && this.implementation.allEntriesByFolder) {
414
427
  const depth = collectionDepth(collection);
415
428
  const extension = (0, _collections.selectFolderEntryExtension)(collection);
416
- return this.implementation.allEntriesByFolder(collection.get('folder'), extension, depth).then(entries => this.processEntries(entries, collection));
429
+ return this.implementation.allEntriesByFolder(collection.get('folder'), extension, depth, collectionRegex(collection)).then(entries => this.processEntries(entries, collection));
417
430
  }
418
431
  const response = await this.listEntries(collection);
419
432
  const {
@@ -55,8 +55,8 @@ function bootstrap(opts = {}) {
55
55
  /**
56
56
  * Log the version number.
57
57
  */
58
- if (typeof "3.2.2" === 'string') {
59
- console.log(`decap-cms-core ${"3.2.2"}`);
58
+ if (typeof "3.2.4" === 'string') {
59
+ console.log(`decap-cms-core ${"3.2.4"}`);
60
60
  }
61
61
 
62
62
  /**
@@ -26,13 +26,13 @@ const ControlPaneContainer = (0, _styledBase.default)("div", {
26
26
  } : {
27
27
  name: "78woh1",
28
28
  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/core';\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          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"]} */",
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/core';\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"]} */",
30
30
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
31
31
  });
32
32
  const LocaleButton = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault.StyledDropdownButton, {
33
33
  target: "e11hw0lx1",
34
34
  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/core';\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          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"]} */"));
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/core';\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
36
  const LocaleButtonWrapper = (0, _styledBase.default)("div", {
37
37
  target: "e11hw0lx2",
38
38
  label: "LocaleButtonWrapper"
@@ -42,7 +42,7 @@ const LocaleButtonWrapper = (0, _styledBase.default)("div", {
42
42
  } : {
43
43
  name: "k008qs",
44
44
  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/core';\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          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"]} */",
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/core';\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"]} */",
46
46
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
47
47
  });
48
48
  const LocaleRowWrapper = (0, _styledBase.default)("div", {
@@ -54,7 +54,7 @@ const LocaleRowWrapper = (0, _styledBase.default)("div", {
54
54
  } : {
55
55
  name: "k008qs",
56
56
  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/core';\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          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"]} */",
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/core';\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"]} */",
58
58
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
59
59
  });
60
60
  const StyledDropdown = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault.Dropdown, {
@@ -66,7 +66,7 @@ const StyledDropdown = ( /*#__PURE__*/0, _styledBase.default)(_decapCmsUiDefault
66
66
  } : {
67
67
  name: "qq8cu0",
68
68
  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/core';\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          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"]} */",
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/core';\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"]} */",
70
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
71
  });
72
72
  function LocaleDropdown({
@@ -79,7 +79,7 @@ function LocaleDropdown({
79
79
  return (0, _core.jsx)(LocaleButtonWrapper, null, (0, _core.jsx)(LocaleButton, null, dropdownText));
80
80
  }
81
81
  }, locales.map(l => (0, _core.jsx)(_decapCmsUiDefault.DropdownItem, {
82
- css: /*#__PURE__*/(0, _core.css)(_decapCmsUiDefault.text.fieldLabel, 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/core';\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          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"]} */"),
82
+ css: /*#__PURE__*/(0, _core.css)(_decapCmsUiDefault.text.fieldLabel, 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/core';\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"]} */"),
83
83
  key: l,
84
84
  label: l,
85
85
  onClick: () => onLocaleChange(l)
@@ -144,7 +144,7 @@ class ControlPane extends _react.default.Component {
144
144
  locale: sourceLocale,
145
145
  isTranslatable: sourceLocale !== defaultLocale
146
146
  });
147
- this.props.onChange(field, copyValue, undefined, i18n);
147
+ if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);
148
148
  }
149
149
  });
150
150
  });
@@ -54,8 +54,8 @@ function buildIssueTemplate({
54
54
  let version = '';
55
55
  if (typeof DECAP_CMS_VERSION === 'string') {
56
56
  version = `decap-cms@${DECAP_CMS_VERSION}`;
57
- } else if (typeof "3.0.5" === 'string') {
58
- version = `decap-cms-app@${"3.0.5"}`;
57
+ } else if (typeof "3.0.7" === 'string') {
58
+ version = `decap-cms-app@${"3.0.7"}`;
59
59
  }
60
60
  const template = getIssueTemplate({
61
61
  version,
@@ -22,7 +22,6 @@ const notifications = (0, _immer.produce)((state, action) => {
22
22
  state.notifications = [];
23
23
  break;
24
24
  case _notifications.NOTIFICATION_DISMISS:
25
- console.log('dismissed!');
26
25
  state.notifications = state.notifications.filter(n => n.id !== action.id);
27
26
  break;
28
27
  case _notifications.NOTIFICATION_SEND:
package/index.d.ts CHANGED
@@ -412,6 +412,14 @@ declare module 'decap-cms-core' {
412
412
  name: string;
413
413
  label: string;
414
414
  widget: string;
415
+ /**
416
+ * Used if widget === "list" to create a flat array
417
+ */
418
+ field: EditorComponentField;
419
+ /**
420
+ * Used if widget === "list" to create an array of objects
421
+ */
422
+ fields: EditorComponentField[];
415
423
  }
416
424
 
417
425
  export interface EditorComponentOptions {
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "decap-cms-core",
3
3
  "description": "Decap CMS core application, see decap-cms package for the main distribution.",
4
- "version": "3.2.2",
4
+ "version": "3.2.4",
5
5
  "repository": "https://github.com/decaporg/decap-cms/tree/master/packages/decap-cms-core",
6
6
  "bugs": "https://github.com/decaporg/decap-cms/issues",
7
7
  "module": "dist/esm/index.js",
@@ -56,7 +56,6 @@
56
56
  "react-redux": "^7.2.0",
57
57
  "react-router-dom": "^5.2.0",
58
58
  "react-scroll-sync": "^0.9.0",
59
- "react-sortable-hoc": "^2.0.0",
60
59
  "react-split-pane": "^0.1.85",
61
60
  "react-toastify": "^9.1.1",
62
61
  "react-topbar-progress-indicator": "^4.0.0",
@@ -98,5 +97,5 @@
98
97
  "@types/url-join": "^4.0.0",
99
98
  "redux-mock-store": "^1.5.3"
100
99
  },
101
- "gitHead": "2f0f9dbd1654868da59cbdbaa2c9dce1d1bcb2c6"
100
+ "gitHead": "b1eae3bbb1661dfa5e3fc0407f03a2e0d564c14e"
102
101
  }
package/src/backend.ts CHANGED
@@ -46,6 +46,7 @@ import {
46
46
  getI18nDataFiles,
47
47
  getI18nBackup,
48
48
  formatI18nBackup,
49
+ getI18nInfo,
49
50
  } from './lib/i18n';
50
51
 
51
52
  import type AssetProxy from './valueObjects/AssetProxy';
@@ -307,6 +308,24 @@ function collectionDepth(collection: Collection) {
307
308
  return depth;
308
309
  }
309
310
 
311
+ function collectionRegex(collection: Collection): RegExp | undefined {
312
+ let ruleString = '';
313
+
314
+ if (collection.get('path')) {
315
+ ruleString = `${collection.get('folder')}/${collection.get('path')}`.replace(
316
+ /{{.*}}/gm,
317
+ '(.*)',
318
+ );
319
+ }
320
+
321
+ if (hasI18n(collection)) {
322
+ const { defaultLocale } = getI18nInfo(collection) as { defaultLocale: string };
323
+ ruleString += `\\.${defaultLocale}\\..*`;
324
+ }
325
+
326
+ return ruleString ? new RegExp(ruleString) : undefined;
327
+ }
328
+
310
329
  export class Backend {
311
330
  implementation: Implementation;
312
331
  backendName: string;
@@ -552,7 +571,12 @@ export class Backend {
552
571
  const depth = collectionDepth(collection);
553
572
  const extension = selectFolderEntryExtension(collection);
554
573
  return this.implementation
555
- .allEntriesByFolder(collection.get('folder') as string, extension, depth)
574
+ .allEntriesByFolder(
575
+ collection.get('folder') as string,
576
+ extension,
577
+ depth,
578
+ collectionRegex(collection),
579
+ )
556
580
  .then(entries => this.processEntries(entries, collection));
557
581
  }
558
582
 
@@ -144,7 +144,7 @@ export default class ControlPane extends React.Component {
144
144
  locale: sourceLocale,
145
145
  isTranslatable: sourceLocale !== defaultLocale,
146
146
  });
147
- this.props.onChange(field, copyValue, undefined, i18n);
147
+ if (copyValue) this.props.onChange(field, copyValue, undefined, i18n);
148
148
  }
149
149
  });
150
150
  };
package/src/lib/i18n.ts CHANGED
@@ -250,7 +250,11 @@ function mergeValues(
250
250
  return entryValue;
251
251
  }
252
252
 
253
- function mergeSingleFileValue(entryValue: EntryValue, defaultLocale: string, locales: string[]) {
253
+ function mergeSingleFileValue(
254
+ entryValue: EntryValue,
255
+ defaultLocale: string,
256
+ locales: string[],
257
+ ): EntryValue {
254
258
  const data = entryValue.data[defaultLocale] || {};
255
259
  const i18n = locales
256
260
  .filter(l => l !== defaultLocale)
@@ -35,7 +35,6 @@ const notifications = produce((state: NotificationsState, action: NotificationsA
35
35
  state.notifications = [];
36
36
  break;
37
37
  case NOTIFICATION_DISMISS:
38
- console.log('dismissed!');
39
38
  state.notifications = state.notifications.filter(n => n.id !== action.id);
40
39
  break;
41
40
  case NOTIFICATION_SEND: