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