decap-cms-core 3.2.2 → 3.2.3
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.
- package/dist/decap-cms-core.js +3 -3
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/backend.js +16 -1
- package/dist/esm/bootstrap.js +2 -2
- package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +7 -7
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/index.d.ts +8 -0
- package/package.json +2 -2
- package/src/backend.ts +28 -1
- package/src/components/Editor/EditorControlPane/EditorControlPane.js +1 -1
- package/src/lib/i18n.ts +5 -1
package/dist/esm/backend.js
CHANGED
|
@@ -203,6 +203,21 @@ function collectionDepth(collection) {
|
|
|
203
203
|
}
|
|
204
204
|
return depth;
|
|
205
205
|
}
|
|
206
|
+
function collectionRegex(collection) {
|
|
207
|
+
console.log('collection', collection.toJS());
|
|
208
|
+
let ruleString = '';
|
|
209
|
+
if (collection.get('path')) {
|
|
210
|
+
ruleString = `${collection.get('folder')}/${collection.get('path')}`.replace(/{{.*}}/gm, '(.*)');
|
|
211
|
+
}
|
|
212
|
+
if ((0, _i18n.hasI18n)(collection)) {
|
|
213
|
+
const {
|
|
214
|
+
defaultLocale
|
|
215
|
+
} = (0, _i18n.getI18nInfo)(collection);
|
|
216
|
+
ruleString += `\\.${defaultLocale}\\..*`;
|
|
217
|
+
}
|
|
218
|
+
console.log('ruleString', ruleString);
|
|
219
|
+
return ruleString ? new RegExp(ruleString) : undefined;
|
|
220
|
+
}
|
|
206
221
|
class Backend {
|
|
207
222
|
constructor(implementation, {
|
|
208
223
|
backendName,
|
|
@@ -413,7 +428,7 @@ class Backend {
|
|
|
413
428
|
if (collection.get('folder') && this.implementation.allEntriesByFolder) {
|
|
414
429
|
const depth = collectionDepth(collection);
|
|
415
430
|
const extension = (0, _collections.selectFolderEntryExtension)(collection);
|
|
416
|
-
return this.implementation.allEntriesByFolder(collection.get('folder'), extension, depth).then(entries => this.processEntries(entries, collection));
|
|
431
|
+
return this.implementation.allEntriesByFolder(collection.get('folder'), extension, depth, collectionRegex(collection)).then(entries => this.processEntries(entries, collection));
|
|
417
432
|
}
|
|
418
433
|
const response = await this.listEntries(collection);
|
|
419
434
|
const {
|
package/dist/esm/bootstrap.js
CHANGED
|
@@ -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.
|
|
58
|
-
version = `decap-cms-app@${"3.0.
|
|
57
|
+
} else if (typeof "3.0.6" === 'string') {
|
|
58
|
+
version = `decap-cms-app@${"3.0.6"}`;
|
|
59
59
|
}
|
|
60
60
|
const template = getIssueTemplate({
|
|
61
61
|
version,
|
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.
|
|
4
|
+
"version": "3.2.3",
|
|
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",
|
|
@@ -98,5 +98,5 @@
|
|
|
98
98
|
"@types/url-join": "^4.0.0",
|
|
99
99
|
"redux-mock-store": "^1.5.3"
|
|
100
100
|
},
|
|
101
|
-
"gitHead": "
|
|
101
|
+
"gitHead": "45447cef915f2e6edfaf55ad402535c687f95f37"
|
|
102
102
|
}
|
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,27 @@ function collectionDepth(collection: Collection) {
|
|
|
307
308
|
return depth;
|
|
308
309
|
}
|
|
309
310
|
|
|
311
|
+
function collectionRegex(collection: Collection): RegExp | undefined {
|
|
312
|
+
console.log('collection', collection.toJS());
|
|
313
|
+
let ruleString = '';
|
|
314
|
+
|
|
315
|
+
if (collection.get('path')) {
|
|
316
|
+
ruleString = `${collection.get('folder')}/${collection.get('path')}`.replace(
|
|
317
|
+
/{{.*}}/gm,
|
|
318
|
+
'(.*)',
|
|
319
|
+
);
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
if (hasI18n(collection)) {
|
|
323
|
+
const { defaultLocale } = getI18nInfo(collection) as { defaultLocale: string };
|
|
324
|
+
ruleString += `\\.${defaultLocale}\\..*`;
|
|
325
|
+
}
|
|
326
|
+
|
|
327
|
+
console.log('ruleString', ruleString);
|
|
328
|
+
|
|
329
|
+
return ruleString ? new RegExp(ruleString) : undefined;
|
|
330
|
+
}
|
|
331
|
+
|
|
310
332
|
export class Backend {
|
|
311
333
|
implementation: Implementation;
|
|
312
334
|
backendName: string;
|
|
@@ -552,7 +574,12 @@ export class Backend {
|
|
|
552
574
|
const depth = collectionDepth(collection);
|
|
553
575
|
const extension = selectFolderEntryExtension(collection);
|
|
554
576
|
return this.implementation
|
|
555
|
-
.allEntriesByFolder(
|
|
577
|
+
.allEntriesByFolder(
|
|
578
|
+
collection.get('folder') as string,
|
|
579
|
+
extension,
|
|
580
|
+
depth,
|
|
581
|
+
collectionRegex(collection),
|
|
582
|
+
)
|
|
556
583
|
.then(entries => this.processEntries(entries, collection));
|
|
557
584
|
}
|
|
558
585
|
|
|
@@ -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(
|
|
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)
|