decap-cms-core 3.5.0 → 3.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/dist/decap-cms-core.js +9 -9
  2. package/dist/decap-cms-core.js.map +1 -1
  3. package/dist/esm/actions/auth.js +22 -37
  4. package/dist/esm/actions/collections.js +9 -17
  5. package/dist/esm/actions/config.js +58 -74
  6. package/dist/esm/actions/deploys.js +10 -17
  7. package/dist/esm/actions/editorialWorkflow.js +87 -101
  8. package/dist/esm/actions/entries.js +161 -211
  9. package/dist/esm/actions/media.js +31 -46
  10. package/dist/esm/actions/mediaLibrary.js +94 -126
  11. package/dist/esm/actions/notifications.js +5 -13
  12. package/dist/esm/actions/search.js +30 -47
  13. package/dist/esm/actions/status.js +13 -23
  14. package/dist/esm/actions/waitUntil.js +4 -11
  15. package/dist/esm/backend.js +132 -148
  16. package/dist/esm/bootstrap.js +37 -44
  17. package/dist/esm/components/App/App.js +82 -89
  18. package/dist/esm/components/App/Header.js +46 -52
  19. package/dist/esm/components/App/NotFoundPage.js +11 -18
  20. package/dist/esm/components/Collection/Collection.js +55 -63
  21. package/dist/esm/components/Collection/CollectionControls.js +15 -22
  22. package/dist/esm/components/Collection/CollectionSearch.js +35 -42
  23. package/dist/esm/components/Collection/CollectionTop.js +23 -30
  24. package/dist/esm/components/Collection/ControlButton.js +10 -16
  25. package/dist/esm/components/Collection/Entries/Entries.js +24 -31
  26. package/dist/esm/components/Collection/Entries/EntriesCollection.js +52 -62
  27. package/dist/esm/components/Collection/Entries/EntriesSearch.js +26 -33
  28. package/dist/esm/components/Collection/Entries/EntryCard.js +38 -45
  29. package/dist/esm/components/Collection/Entries/EntryListing.js +24 -32
  30. package/dist/esm/components/Collection/FilterControl.js +9 -16
  31. package/dist/esm/components/Collection/GroupControl.js +9 -16
  32. package/dist/esm/components/Collection/NestedCollection.js +54 -65
  33. package/dist/esm/components/Collection/Sidebar.js +36 -43
  34. package/dist/esm/components/Collection/SortControl.js +19 -26
  35. package/dist/esm/components/Collection/ViewStyleControl.js +17 -24
  36. package/dist/esm/components/Editor/Editor.js +100 -108
  37. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +105 -112
  38. package/dist/esm/components/Editor/EditorControlPane/EditorControlPane.js +68 -62
  39. package/dist/esm/components/Editor/EditorControlPane/Widget.js +87 -73
  40. package/dist/esm/components/Editor/EditorInterface.js +95 -98
  41. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreview.js +13 -21
  42. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewContent.js +64 -23
  43. package/dist/esm/components/Editor/EditorPreviewPane/EditorPreviewPane.js +94 -78
  44. package/dist/esm/components/Editor/EditorPreviewPane/PreviewHOC.js +9 -16
  45. package/dist/esm/components/Editor/EditorToolbar.js +133 -140
  46. package/dist/esm/components/Editor/withWorkflow.js +15 -22
  47. package/dist/esm/components/EditorWidgets/Unknown/UnknownControl.js +9 -16
  48. package/dist/esm/components/EditorWidgets/Unknown/UnknownPreview.js +9 -16
  49. package/dist/esm/components/EditorWidgets/index.js +4 -7
  50. package/dist/esm/components/MediaLibrary/EmptyMessage.js +12 -19
  51. package/dist/esm/components/MediaLibrary/MediaLibrary.js +55 -62
  52. package/dist/esm/components/MediaLibrary/MediaLibraryButtons.js +28 -35
  53. package/dist/esm/components/MediaLibrary/MediaLibraryCard.js +36 -43
  54. package/dist/esm/components/MediaLibrary/MediaLibraryCardGrid.js +50 -57
  55. package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +16 -23
  56. package/dist/esm/components/MediaLibrary/MediaLibraryModal.js +59 -64
  57. package/dist/esm/components/MediaLibrary/MediaLibrarySearch.js +18 -25
  58. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +39 -46
  59. package/dist/esm/components/UI/DragDrop.js +21 -30
  60. package/dist/esm/components/UI/ErrorBoundary.js +35 -43
  61. package/dist/esm/components/UI/FileUploadButton.js +11 -18
  62. package/dist/esm/components/UI/Modal.js +19 -26
  63. package/dist/esm/components/UI/Notifications.js +21 -28
  64. package/dist/esm/components/UI/SettingsDropdown.js +28 -34
  65. package/dist/esm/components/UI/index.js +6 -60
  66. package/dist/esm/components/Workflow/Workflow.js +52 -61
  67. package/dist/esm/components/Workflow/WorkflowCard.js +45 -51
  68. package/dist/esm/components/Workflow/WorkflowList.js +43 -49
  69. package/dist/esm/constants/collectionTypes.js +2 -8
  70. package/dist/esm/constants/collectionViews.js +2 -8
  71. package/dist/esm/constants/commitProps.js +2 -8
  72. package/dist/esm/constants/configSchema.js +20 -27
  73. package/dist/esm/constants/fieldInference.js +8 -15
  74. package/dist/esm/constants/publishModes.js +6 -11
  75. package/dist/esm/constants/validationErrorTypes.js +1 -7
  76. package/dist/esm/formats/formats.js +32 -41
  77. package/dist/esm/formats/frontmatter.js +18 -30
  78. package/dist/esm/formats/helpers.js +1 -7
  79. package/dist/esm/formats/json.js +1 -7
  80. package/dist/esm/formats/toml.js +11 -18
  81. package/dist/esm/formats/yaml.js +7 -14
  82. package/dist/esm/index.js +5 -12
  83. package/dist/esm/integrations/index.js +8 -16
  84. package/dist/esm/integrations/providers/algolia/implementation.js +14 -22
  85. package/dist/esm/integrations/providers/assetStore/implementation.js +10 -18
  86. package/dist/esm/lib/consoleError.js +1 -7
  87. package/dist/esm/lib/formatters.js +34 -47
  88. package/dist/esm/lib/i18n.js +37 -66
  89. package/dist/esm/lib/phrases.js +4 -11
  90. package/dist/esm/lib/registry.js +40 -75
  91. package/dist/esm/lib/serializeEntryValues.js +11 -18
  92. package/dist/esm/lib/textHelper.js +1 -7
  93. package/dist/esm/lib/urlHelper.js +28 -43
  94. package/dist/esm/mediaLibrary.js +12 -16
  95. package/dist/esm/reducers/auth.js +10 -16
  96. package/dist/esm/reducers/collections.js +70 -102
  97. package/dist/esm/reducers/combinedReducer.js +4 -11
  98. package/dist/esm/reducers/config.js +11 -19
  99. package/dist/esm/reducers/cursors.js +12 -18
  100. package/dist/esm/reducers/deploys.js +8 -15
  101. package/dist/esm/reducers/editorialWorkflow.js +37 -47
  102. package/dist/esm/reducers/entries.js +107 -132
  103. package/dist/esm/reducers/entryDraft.js +64 -72
  104. package/dist/esm/reducers/globalUI.js +5 -11
  105. package/dist/esm/reducers/index.js +43 -64
  106. package/dist/esm/reducers/integrations.js +8 -16
  107. package/dist/esm/reducers/mediaLibrary.js +43 -52
  108. package/dist/esm/reducers/medias.js +11 -18
  109. package/dist/esm/reducers/notifications.js +9 -15
  110. package/dist/esm/reducers/search.js +12 -18
  111. package/dist/esm/reducers/status.js +7 -13
  112. package/dist/esm/redux/index.js +7 -13
  113. package/dist/esm/redux/middleware/waitUntilAction.js +3 -10
  114. package/dist/esm/routing/history.js +7 -15
  115. package/dist/esm/types/diacritics.d.js +0 -1
  116. package/dist/esm/types/global.d.js +1 -5
  117. package/dist/esm/types/immutable.js +1 -5
  118. package/dist/esm/types/redux.js +7 -8
  119. package/dist/esm/types/tomlify-j0.4.d.js +0 -1
  120. package/dist/esm/valueObjects/AssetProxy.js +2 -10
  121. package/dist/esm/valueObjects/EditorComponent.js +5 -12
  122. package/dist/esm/valueObjects/Entry.js +3 -10
  123. package/package.json +3 -2
  124. package/src/components/Collection/Entries/EntriesCollection.js +7 -8
  125. package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +3 -5
  126. package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +8 -8
  127. package/src/components/Collection/NestedCollection.js +2 -2
  128. package/src/components/Collection/__tests__/__snapshots__/NestedCollection.spec.js.snap +68 -0
  129. package/src/components/Editor/EditorControlPane/EditorControl.js +0 -3
  130. package/src/components/Editor/EditorControlPane/EditorControlPane.js +21 -8
  131. package/src/components/Editor/EditorControlPane/Widget.js +22 -1
  132. package/src/components/Editor/EditorInterface.js +6 -1
  133. package/src/components/Editor/EditorPreviewPane/EditorPreviewContent.js +51 -11
  134. package/src/components/Editor/EditorPreviewPane/EditorPreviewPane.js +33 -1
  135. package/dist/esm/actions/editorControl.js +0 -14
  136. package/dist/esm/reducers/editorComponent.js +0 -1
  137. package/dist/esm/reducers/editorControl.js +0 -17
@@ -1,31 +1,7 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = exports.ControlHint = void 0;
7
- var _base = _interopRequireDefault(require("@emotion/styled/base"));
8
- var _uniqueId2 = _interopRequireDefault(require("lodash/uniqueId"));
9
- var _partial2 = _interopRequireDefault(require("lodash/partial"));
10
- var _react = _interopRequireDefault(require("react"));
11
- var _redux = require("redux");
12
- var _propTypes = _interopRequireDefault(require("prop-types"));
13
- var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
14
- var _reactPolyglot = require("react-polyglot");
15
- var _react2 = require("@emotion/react");
16
- var _reactRedux = require("react-redux");
17
- var _decapCmsUiDefault = require("decap-cms-ui-default");
18
- var _reactMarkdown = _interopRequireDefault(require("react-markdown"));
19
- var _remarkGfm = _interopRequireDefault(require("remark-gfm"));
20
- var _registry = require("../../../lib/registry");
21
- var _entries = require("../../../actions/entries");
22
- var _media = require("../../../actions/media");
23
- var _medias = require("../../../reducers/medias");
24
- var _search = require("../../../actions/search");
25
- var _mediaLibrary = require("../../../actions/mediaLibrary");
26
- var _Widget = _interopRequireDefault(require("./Widget"));
1
+ import _styled from "@emotion/styled/base";
2
+ import _uniqueId from "lodash/uniqueId";
3
+ import _partial from "lodash/partial";
27
4
  const _excluded = ["node"];
28
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
29
5
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
30
6
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
31
7
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
@@ -34,25 +10,45 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
34
10
  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; }
35
11
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
36
12
  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); }
37
- 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)."; } /**
13
+ 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)."; }
14
+ import React from 'react';
15
+ import { bindActionCreators } from 'redux';
16
+ import PropTypes from 'prop-types';
17
+ import ImmutablePropTypes from 'react-immutable-proptypes';
18
+ import { translate } from 'react-polyglot';
19
+ import { ClassNames, Global, css as coreCss } from '@emotion/react';
20
+ import { connect } from 'react-redux';
21
+ import { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';
22
+ import ReactMarkdown from 'react-markdown';
23
+ import gfm from 'remark-gfm';
24
+ import { resolveWidget, getEditorComponents } from '../../../lib/registry';
25
+ import { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';
26
+ import { addAsset, boundGetAsset } from '../../../actions/media';
27
+ import { selectIsLoadingAsset } from '../../../reducers/medias';
28
+ import { query, clearSearch } from '../../../actions/search';
29
+ import { openMediaLibrary, removeInsertedMedia, clearMediaControl, removeMediaControl, persistMedia } from '../../../actions/mediaLibrary';
30
+ import Widget from './Widget';
31
+
32
+ /**
38
33
  * This is a necessary bridge as we are still passing classnames to widgets
39
34
  * for styling. Once that changes we can stop storing raw style strings like
40
35
  * this.
41
36
  */
37
+ import { jsx as ___EmotionJSX } from "@emotion/react";
42
38
  const styleStrings = {
43
39
  widget: `
44
40
  display: block;
45
41
  width: 100%;
46
- padding: ${_decapCmsUiDefault.lengths.inputPadding};
42
+ padding: ${lengths.inputPadding};
47
43
  margin: 0;
48
- border: ${_decapCmsUiDefault.borders.textField};
49
- border-radius: ${_decapCmsUiDefault.lengths.borderRadius};
44
+ border: ${borders.textField};
45
+ border-radius: ${lengths.borderRadius};
50
46
  border-top-left-radius: 0;
51
47
  outline: 0;
52
48
  box-shadow: none;
53
- background-color: ${_decapCmsUiDefault.colors.inputBackground};
49
+ background-color: ${colors.inputBackground};
54
50
  color: #444a57;
55
- transition: border-color ${_decapCmsUiDefault.transitions.main};
51
+ transition: border-color ${transitions.main};
56
52
  position: relative;
57
53
  font-size: 15px;
58
54
  line-height: 1.5;
@@ -63,10 +59,10 @@ const styleStrings = {
63
59
  }
64
60
  `,
65
61
  widgetActive: `
66
- border-color: ${_decapCmsUiDefault.colors.active};
62
+ border-color: ${colors.active};
67
63
  `,
68
64
  widgetError: `
69
- border-color: ${_decapCmsUiDefault.colors.errorText};
65
+ border-color: ${colors.errorText};
70
66
  `,
71
67
  disabled: `
72
68
  pointer-events: none;
@@ -76,7 +72,7 @@ const styleStrings = {
76
72
  visibility: hidden;
77
73
  `
78
74
  };
79
- const ControlContainer = /*#__PURE__*/(0, _base.default)("div", {
75
+ const ControlContainer = /*#__PURE__*/_styled("div", {
80
76
  target: "ec1nk3l3",
81
77
  label: "ControlContainer"
82
78
  })(process.env.NODE_ENV === "production" ? {
@@ -85,10 +81,10 @@ const ControlContainer = /*#__PURE__*/(0, _base.default)("div", {
85
81
  } : {
86
82
  name: "gpgisz",
87
83
  styles: "margin-top:16px;&:first-of-type{margin-top:36px;}",
88
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAsEmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    processControlRef: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      processControlRef,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              ref={processControlRef && partial(processControlRef, field)}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */",
84
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAsEmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */",
89
85
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
86
  });
91
- const ControlTopbar = /*#__PURE__*/(0, _base.default)("div", {
87
+ const ControlTopbar = /*#__PURE__*/_styled("div", {
92
88
  target: "ec1nk3l2",
93
89
  label: "ControlTopbar"
94
90
  })(process.env.NODE_ENV === "production" ? {
@@ -97,17 +93,17 @@ const ControlTopbar = /*#__PURE__*/(0, _base.default)("div", {
97
93
  } : {
98
94
  name: "hvtmtt",
99
95
  styles: "display:flex;justify-content:space-between;gap:20px;align-items:end",
100
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AA8EgC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    processControlRef: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      processControlRef,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              ref={processControlRef && partial(processControlRef, field)}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */",
96
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AA8EgC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */",
101
97
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
102
98
  });
103
- const ControlErrorsList = /*#__PURE__*/(0, _base.default)("ul", {
99
+ const ControlErrorsList = /*#__PURE__*/_styled("ul", {
104
100
  target: "ec1nk3l1",
105
101
  label: "ControlErrorsList"
106
- })("list-style-type:none;font-size:12px;color:", _decapCmsUiDefault.colors.errorText, ";text-align:right;text-transform:uppercase;font-weight:600;margin:0;padding:2px 0 3px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAoFmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    processControlRef: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      processControlRef,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              ref={processControlRef && partial(processControlRef, field)}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"));
107
- const ControlHint = exports.ControlHint = /*#__PURE__*/(0, _base.default)("p", {
102
+ })("list-style-type:none;font-size:12px;color:", colors.errorText, ";text-align:right;text-transform:uppercase;font-weight:600;margin:0;padding:2px 0 3px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAoFmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"));
103
+ export const ControlHint = /*#__PURE__*/_styled("p", {
108
104
  target: "ec1nk3l0",
109
105
  label: "ControlHint"
110
- })("margin-bottom:0;padding:6px 0 0;font-size:12px;color:", props => props.error ? _decapCmsUiDefault.colors.errorText : props.active ? _decapCmsUiDefault.colors.active : _decapCmsUiDefault.colors.controlLabel, ";transition:color ", _decapCmsUiDefault.transitions.main, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AA+FmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    processControlRef: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      processControlRef,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              ref={processControlRef && partial(processControlRef, field)}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"));
106
+ })("margin-bottom:0;padding:6px 0 0;font-size:12px;color:", props => props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel, ";transition:color ", transitions.main, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AA+FmC","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"));
111
107
  function LabelComponent({
112
108
  field,
113
109
  isActive,
@@ -117,20 +113,20 @@ function LabelComponent({
117
113
  t
118
114
  }) {
119
115
  const label = `${field.get('label', field.get('name'))}`;
120
- const labelComponent = (0, _react2.jsx)(_decapCmsUiDefault.FieldLabel, {
116
+ const labelComponent = ___EmotionJSX(FieldLabel, {
121
117
  isActive: isActive,
122
118
  hasErrors: hasErrors,
123
119
  htmlFor: uniqueFieldId
124
- }, isFieldOptional ? (0, _react2.jsx)(_react.default.Fragment, null, label, (0, _react2.jsx)("span", null, ` (${t('editor.editorControl.field.optional')})`)) : label);
120
+ }, isFieldOptional ? ___EmotionJSX(React.Fragment, null, label, ___EmotionJSX("span", null, ` (${t('editor.editorControl.field.optional')})`)) : label);
125
121
  return labelComponent;
126
122
  }
127
- class EditorControl extends _react.default.Component {
123
+ class EditorControl extends React.Component {
128
124
  constructor(...args) {
129
125
  super(...args);
130
126
  _defineProperty(this, "state", {
131
127
  activeLabel: false
132
128
  });
133
- _defineProperty(this, "uniqueFieldId", (0, _uniqueId2.default)(`${this.props.field.get('name')}-field-`));
129
+ _defineProperty(this, "uniqueFieldId", _uniqueId(`${this.props.field.get('name')}-field-`));
134
130
  _defineProperty(this, "isAncestorOfFieldError", () => {
135
131
  const {
136
132
  fieldsErrors
@@ -160,7 +156,6 @@ class EditorControl extends _react.default.Component {
160
156
  removeInsertedMedia,
161
157
  persistMedia,
162
158
  onValidate,
163
- processControlRef,
164
159
  controlRef,
165
160
  query,
166
161
  queryHits,
@@ -184,7 +179,7 @@ class EditorControl extends _react.default.Component {
184
179
  isParentListCollapsed
185
180
  } = this.props;
186
181
  const widgetName = field.get('widget');
187
- const widget = (0, _registry.resolveWidget)(widgetName);
182
+ const widget = resolveWidget(widgetName);
188
183
  const fieldName = field.get('name');
189
184
  const fieldHint = field.get('hint');
190
185
  const isFieldOptional = field.get('required') === false;
@@ -193,26 +188,26 @@ class EditorControl extends _react.default.Component {
193
188
  const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);
194
189
  const childErrors = this.isAncestorOfFieldError();
195
190
  const hasErrors = !!errors || childErrors;
196
- return (0, _react2.jsx)(_react2.ClassNames, null, ({
191
+ return ___EmotionJSX(ClassNames, null, ({
197
192
  css,
198
193
  cx
199
- }) => (0, _react2.jsx)(ControlContainer, {
194
+ }) => ___EmotionJSX(ControlContainer, {
200
195
  className: className,
201
196
  css: css`
202
197
  ${isHidden && styleStrings.hidden};
203
198
  `
204
- }, (0, _react2.jsx)(ControlTopbar, null, widget.globalStyles && (0, _react2.jsx)(_react2.Global, {
205
- styles: /*#__PURE__*/(0, _react2.css)(widget.globalStyles, ";;label:EditorControl;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAwP6D","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    processControlRef: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      processControlRef,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              ref={processControlRef && partial(processControlRef, field)}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"))
206
- }), (0, _react2.jsx)(LabelComponent, {
199
+ }, ___EmotionJSX(ControlTopbar, null, widget.globalStyles && ___EmotionJSX(Global, {
200
+ styles: /*#__PURE__*/coreCss(widget.globalStyles, ";;label:EditorControl;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAsP6D","file":"../../../../../src/components/Editor/EditorControlPane/EditorControl.js","sourcesContent":["import React from 'react';\nimport { bindActionCreators } from 'redux';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { translate } from 'react-polyglot';\nimport { ClassNames, Global, css as coreCss } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { partial, uniqueId } from 'lodash';\nimport { connect } from 'react-redux';\nimport { FieldLabel, colors, transitions, lengths, borders } from 'decap-cms-ui-default';\nimport ReactMarkdown from 'react-markdown';\nimport gfm from 'remark-gfm';\n\nimport { resolveWidget, getEditorComponents } from '../../../lib/registry';\nimport { clearFieldErrors, tryLoadEntry, validateMetaField } from '../../../actions/entries';\nimport { addAsset, boundGetAsset } from '../../../actions/media';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { query, clearSearch } from '../../../actions/search';\nimport {\n  openMediaLibrary,\n  removeInsertedMedia,\n  clearMediaControl,\n  removeMediaControl,\n  persistMedia,\n} from '../../../actions/mediaLibrary';\nimport Widget from './Widget';\n\n/**\n * This is a necessary bridge as we are still passing classnames to widgets\n * for styling. Once that changes we can stop storing raw style strings like\n * this.\n */\nconst styleStrings = {\n  widget: `\n    display: block;\n    width: 100%;\n    padding: ${lengths.inputPadding};\n    margin: 0;\n    border: ${borders.textField};\n    border-radius: ${lengths.borderRadius};\n    border-top-left-radius: 0;\n    outline: 0;\n    box-shadow: none;\n    background-color: ${colors.inputBackground};\n    color: #444a57;\n    transition: border-color ${transitions.main};\n    position: relative;\n    font-size: 15px;\n    line-height: 1.5;\n\n    select& {\n      text-indent: 14px;\n      height: 58px;\n    }\n  `,\n  widgetActive: `\n    border-color: ${colors.active};\n  `,\n  widgetError: `\n    border-color: ${colors.errorText};\n  `,\n  disabled: `\n    pointer-events: none;\n    opacity: 0.5;\n  `,\n  hidden: `\n    visibility: hidden;\n  `,\n};\n\nconst ControlContainer = styled.div`\n  margin-top: 16px;\n\n  &:first-of-type {\n    margin-top: 36px;\n  }\n`;\n\nconst ControlTopbar = styled.div`\n  display: flex;\n  justify-content: space-between;\n  gap: 20px;\n  align-items: end;\n`;\nconst ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  text-align: right;\n  text-transform: uppercase;\n  font-weight: 600;\n  margin: 0;\n  padding: 2px 0 3px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 6px 0 0;\n  font-size: 12px;\n  color: ${props =>\n    props.error ? colors.errorText : props.active ? colors.active : colors.controlLabel};\n  transition: color ${transitions.main};\n`;\n\nfunction LabelComponent({ field, isActive, hasErrors, uniqueFieldId, isFieldOptional, t }) {\n  const label = `${field.get('label', field.get('name'))}`;\n  const labelComponent = (\n    <FieldLabel isActive={isActive} hasErrors={hasErrors} htmlFor={uniqueFieldId}>\n      {isFieldOptional ? (\n        <>\n          {label}\n          <span>{` (${t('editor.editorControl.field.optional')})`}</span>\n        </>\n      ) : (\n        label\n      )}\n    </FieldLabel>\n  );\n\n  return labelComponent;\n}\n\nclass EditorControl extends React.Component {\n  static propTypes = {\n    value: PropTypes.oneOfType([\n      PropTypes.node,\n      PropTypes.object,\n      PropTypes.string,\n      PropTypes.bool,\n    ]),\n    field: ImmutablePropTypes.map.isRequired,\n    fieldsMetaData: ImmutablePropTypes.map,\n    fieldsErrors: ImmutablePropTypes.map,\n    mediaPaths: ImmutablePropTypes.map.isRequired,\n    boundGetAsset: PropTypes.func.isRequired,\n    onChange: PropTypes.func.isRequired,\n    openMediaLibrary: PropTypes.func.isRequired,\n    addAsset: PropTypes.func.isRequired,\n    removeInsertedMedia: PropTypes.func.isRequired,\n    persistMedia: PropTypes.func.isRequired,\n    onValidate: PropTypes.func,\n    controlRef: PropTypes.func,\n    query: PropTypes.func.isRequired,\n    queryHits: PropTypes.object,\n    isFetching: PropTypes.bool,\n    clearSearch: PropTypes.func.isRequired,\n    clearFieldErrors: PropTypes.func.isRequired,\n    loadEntry: PropTypes.func.isRequired,\n    t: PropTypes.func.isRequired,\n    isEditorComponent: PropTypes.bool,\n    isNewEditorComponent: PropTypes.bool,\n    parentIds: PropTypes.arrayOf(PropTypes.string),\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    isDisabled: PropTypes.bool,\n    isHidden: PropTypes.bool,\n    isFieldDuplicate: PropTypes.func,\n    isFieldHidden: PropTypes.func,\n    locale: PropTypes.string,\n    isParentListCollapsed: PropTypes.bool,\n  };\n\n  static defaultProps = {\n    parentIds: [],\n  };\n\n  state = {\n    activeLabel: false,\n  };\n\n  uniqueFieldId = uniqueId(`${this.props.field.get('name')}-field-`);\n\n  isAncestorOfFieldError = () => {\n    const { fieldsErrors } = this.props;\n\n    if (fieldsErrors && fieldsErrors.size > 0) {\n      return Object.values(fieldsErrors.toJS()).some(arr =>\n        arr.some(err => err.parentIds && err.parentIds.includes(this.uniqueFieldId)),\n      );\n    }\n    return false;\n  };\n\n  render() {\n    const {\n      value,\n      entry,\n      collection,\n      config,\n      field,\n      fieldsMetaData,\n      fieldsErrors,\n      mediaPaths,\n      boundGetAsset,\n      onChange,\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      addAsset,\n      removeInsertedMedia,\n      persistMedia,\n      onValidate,\n      controlRef,\n      query,\n      queryHits,\n      isFetching,\n      clearSearch,\n      clearFieldErrors,\n      loadEntry,\n      className,\n      isSelected,\n      isEditorComponent,\n      isNewEditorComponent,\n      parentIds,\n      t,\n      validateMetaField,\n      isLoadingAsset,\n      isDisabled,\n      isHidden,\n      isFieldDuplicate,\n      isFieldHidden,\n      locale,\n      isParentListCollapsed,\n    } = this.props;\n\n    const widgetName = field.get('widget');\n    const widget = resolveWidget(widgetName);\n    const fieldName = field.get('name');\n    const fieldHint = field.get('hint');\n    const isFieldOptional = field.get('required') === false;\n    const onValidateObject = onValidate;\n    const metadata = fieldsMetaData && fieldsMetaData.get(fieldName);\n    const errors = fieldsErrors && fieldsErrors.get(this.uniqueFieldId);\n    const childErrors = this.isAncestorOfFieldError();\n    const hasErrors = !!errors || childErrors;\n\n    return (\n      <ClassNames>\n        {({ css, cx }) => (\n          <ControlContainer\n            className={className}\n            css={css`\n              ${isHidden && styleStrings.hidden};\n            `}\n          >\n            <ControlTopbar>\n              {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\n              <LabelComponent\n                field={field}\n                isActive={isSelected || this.state.styleActive}\n                hasErrors={hasErrors}\n                uniqueFieldId={this.uniqueFieldId}\n                isFieldOptional={isFieldOptional}\n                t={t}\n              />\n              {errors && (\n                <ControlErrorsList>\n                  {errors.map(\n                    error =>\n                      error.message &&\n                      typeof error.message === 'string' && (\n                        <li key={error.message.trim().replace(/[^a-z0-9]+/gi, '-')}>\n                          {error.message}\n                        </li>\n                      ),\n                  )}\n                </ControlErrorsList>\n              )}\n            </ControlTopbar>\n            <Widget\n              classNameWrapper={cx(\n                css`\n                  ${styleStrings.widget};\n                `,\n                {\n                  [css`\n                    ${styleStrings.widgetActive};\n                  `]: isSelected || this.state.styleActive,\n                },\n                {\n                  [css`\n                    ${styleStrings.widgetError};\n                  `]: hasErrors,\n                },\n                {\n                  [css`\n                    ${styleStrings.disabled}\n                  `]: isDisabled,\n                },\n              )}\n              classNameWidget={css`\n                ${styleStrings.widget};\n              `}\n              classNameWidgetActive={css`\n                ${styleStrings.widgetActive};\n              `}\n              classNameLabel={css`\n                ${styleStrings.label};\n              `}\n              classNameLabelActive={css`\n                ${styleStrings.labelActive};\n              `}\n              controlComponent={widget.control}\n              entry={entry}\n              collection={collection}\n              config={config}\n              field={field}\n              uniqueFieldId={this.uniqueFieldId}\n              value={value}\n              mediaPaths={mediaPaths}\n              metadata={metadata}\n              onChange={(newValue, newMetadata) => {\n                onChange(field, newValue, newMetadata);\n                clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля\n              }}\n              onValidate={onValidate && partial(onValidate, this.uniqueFieldId)}\n              onOpenMediaLibrary={openMediaLibrary}\n              onClearMediaControl={clearMediaControl}\n              onRemoveMediaControl={removeMediaControl}\n              onRemoveInsertedMedia={removeInsertedMedia}\n              onPersistMedia={persistMedia}\n              onAddAsset={addAsset}\n              getAsset={boundGetAsset}\n              hasActiveStyle={isSelected || this.state.styleActive}\n              setActiveStyle={() => this.setState({ styleActive: true })}\n              setInactiveStyle={() => this.setState({ styleActive: false })}\n              resolveWidget={resolveWidget}\n              widget={widget}\n              getEditorComponents={getEditorComponents}\n              controlRef={controlRef}\n              editorControl={ConnectedEditorControl}\n              query={query}\n              loadEntry={loadEntry}\n              queryHits={queryHits[this.uniqueFieldId] || []}\n              clearSearch={clearSearch}\n              clearFieldErrors={clearFieldErrors}\n              isFetching={isFetching}\n              fieldsErrors={fieldsErrors}\n              onValidateObject={onValidateObject}\n              isEditorComponent={isEditorComponent}\n              isNewEditorComponent={isNewEditorComponent}\n              parentIds={parentIds}\n              t={t}\n              validateMetaField={validateMetaField}\n              isDisabled={isDisabled}\n              isFieldDuplicate={isFieldDuplicate}\n              isFieldHidden={isFieldHidden}\n              isLoadingAsset={isLoadingAsset}\n              locale={locale}\n              isParentListCollapsed={isParentListCollapsed}\n            />\n            {fieldHint && (\n              <ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>\n                <ReactMarkdown\n                  remarkPlugins={[gfm]}\n                  allowedElements={['a', 'strong', 'em', 'del']}\n                  unwrapDisallowed={true}\n                  components={{\n                    // eslint-disable-next-line no-unused-vars\n                    a: ({ node, ...props }) => (\n                      <a\n                        {...props}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        style={{ color: 'inherit' }}\n                      />\n                    ),\n                  }}\n                >\n                  {fieldHint}\n                </ReactMarkdown>\n              </ControlHint>\n            )}\n          </ControlContainer>\n        )}\n      </ClassNames>\n    );\n  }\n}\n\nfunction mapStateToProps(state) {\n  const { collections, entryDraft } = state;\n  const entry = entryDraft.get('entry');\n  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  async function loadEntry(collectionName, slug) {\n    const targetCollection = collections.get(collectionName);\n    if (targetCollection) {\n      const loadedEntry = await tryLoadEntry(state, targetCollection, slug);\n      return loadedEntry;\n    } else {\n      throw new Error(`Can't find collection '${collectionName}'`);\n    }\n  }\n\n  return {\n    mediaPaths: state.mediaLibrary.get('controlMedia'),\n    isFetching: state.search.isFetching,\n    queryHits: state.search.queryHits,\n    config: state.config,\n    entry,\n    collection,\n    isLoadingAsset,\n    loadEntry,\n    validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t),\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  const creators = bindActionCreators(\n    {\n      openMediaLibrary,\n      clearMediaControl,\n      removeMediaControl,\n      removeInsertedMedia,\n      persistMedia,\n      addAsset,\n      query,\n      clearSearch,\n      clearFieldErrors,\n    },\n    dispatch,\n  );\n  return {\n    ...creators,\n    boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry),\n  };\n}\n\nfunction mergeProps(stateProps, dispatchProps, ownProps) {\n  return {\n    ...stateProps,\n    ...dispatchProps,\n    ...ownProps,\n    boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry),\n  };\n}\n\nconst ConnectedEditorControl = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EditorControl));\n\nexport default ConnectedEditorControl;\n"]} */"))
201
+ }), ___EmotionJSX(LabelComponent, {
207
202
  field: field,
208
203
  isActive: isSelected || this.state.styleActive,
209
204
  hasErrors: hasErrors,
210
205
  uniqueFieldId: this.uniqueFieldId,
211
206
  isFieldOptional: isFieldOptional,
212
207
  t: t
213
- }), errors && (0, _react2.jsx)(ControlErrorsList, null, errors.map(error => error.message && typeof error.message === 'string' && (0, _react2.jsx)("li", {
208
+ }), errors && ___EmotionJSX(ControlErrorsList, null, errors.map(error => error.message && typeof error.message === 'string' && ___EmotionJSX("li", {
214
209
  key: error.message.trim().replace(/[^a-z0-9]+/gi, '-')
215
- }, error.message)))), (0, _react2.jsx)(_Widget.default, {
210
+ }, error.message)))), ___EmotionJSX(Widget, {
216
211
  classNameWrapper: cx(css`
217
212
  ${styleStrings.widget};
218
213
  `, {
@@ -253,7 +248,7 @@ class EditorControl extends _react.default.Component {
253
248
  onChange(field, newValue, newMetadata);
254
249
  clearFieldErrors(this.uniqueFieldId); // Видаляємо помилки лише для цього поля
255
250
  },
256
- onValidate: onValidate && (0, _partial2.default)(onValidate, this.uniqueFieldId),
251
+ onValidate: onValidate && _partial(onValidate, this.uniqueFieldId),
257
252
  onOpenMediaLibrary: openMediaLibrary,
258
253
  onClearMediaControl: clearMediaControl,
259
254
  onRemoveMediaControl: removeMediaControl,
@@ -268,10 +263,9 @@ class EditorControl extends _react.default.Component {
268
263
  setInactiveStyle: () => this.setState({
269
264
  styleActive: false
270
265
  }),
271
- resolveWidget: _registry.resolveWidget,
266
+ resolveWidget: resolveWidget,
272
267
  widget: widget,
273
- getEditorComponents: _registry.getEditorComponents,
274
- ref: processControlRef && (0, _partial2.default)(processControlRef, field),
268
+ getEditorComponents: getEditorComponents,
275
269
  controlRef: controlRef,
276
270
  editorControl: ConnectedEditorControl,
277
271
  query: query,
@@ -293,11 +287,11 @@ class EditorControl extends _react.default.Component {
293
287
  isLoadingAsset: isLoadingAsset,
294
288
  locale: locale,
295
289
  isParentListCollapsed: isParentListCollapsed
296
- }), fieldHint && (0, _react2.jsx)(ControlHint, {
290
+ }), fieldHint && ___EmotionJSX(ControlHint, {
297
291
  active: isSelected || this.state.styleActive,
298
292
  error: hasErrors
299
- }, (0, _react2.jsx)(_reactMarkdown.default, {
300
- remarkPlugins: [_remarkGfm.default],
293
+ }, ___EmotionJSX(ReactMarkdown, {
294
+ remarkPlugins: [gfm],
301
295
  allowedElements: ['a', 'strong', 'em', 'del'],
302
296
  unwrapDisallowed: true,
303
297
  components: {
@@ -307,7 +301,7 @@ class EditorControl extends _react.default.Component {
307
301
  node
308
302
  } = _ref,
309
303
  props = _objectWithoutProperties(_ref, _excluded);
310
- return (0, _react2.jsx)("a", _extends({}, props, {
304
+ return ___EmotionJSX("a", _extends({}, props, {
311
305
  target: "_blank",
312
306
  rel: "noopener noreferrer",
313
307
  style: {
@@ -320,38 +314,37 @@ class EditorControl extends _react.default.Component {
320
314
  }
321
315
  }
322
316
  _defineProperty(EditorControl, "propTypes", {
323
- value: _propTypes.default.oneOfType([_propTypes.default.node, _propTypes.default.object, _propTypes.default.string, _propTypes.default.bool]),
324
- field: _reactImmutableProptypes.default.map.isRequired,
325
- fieldsMetaData: _reactImmutableProptypes.default.map,
326
- fieldsErrors: _reactImmutableProptypes.default.map,
327
- mediaPaths: _reactImmutableProptypes.default.map.isRequired,
328
- boundGetAsset: _propTypes.default.func.isRequired,
329
- onChange: _propTypes.default.func.isRequired,
330
- openMediaLibrary: _propTypes.default.func.isRequired,
331
- addAsset: _propTypes.default.func.isRequired,
332
- removeInsertedMedia: _propTypes.default.func.isRequired,
333
- persistMedia: _propTypes.default.func.isRequired,
334
- onValidate: _propTypes.default.func,
335
- processControlRef: _propTypes.default.func,
336
- controlRef: _propTypes.default.func,
337
- query: _propTypes.default.func.isRequired,
338
- queryHits: _propTypes.default.object,
339
- isFetching: _propTypes.default.bool,
340
- clearSearch: _propTypes.default.func.isRequired,
341
- clearFieldErrors: _propTypes.default.func.isRequired,
342
- loadEntry: _propTypes.default.func.isRequired,
343
- t: _propTypes.default.func.isRequired,
344
- isEditorComponent: _propTypes.default.bool,
345
- isNewEditorComponent: _propTypes.default.bool,
346
- parentIds: _propTypes.default.arrayOf(_propTypes.default.string),
347
- entry: _reactImmutableProptypes.default.map.isRequired,
348
- collection: _reactImmutableProptypes.default.map.isRequired,
349
- isDisabled: _propTypes.default.bool,
350
- isHidden: _propTypes.default.bool,
351
- isFieldDuplicate: _propTypes.default.func,
352
- isFieldHidden: _propTypes.default.func,
353
- locale: _propTypes.default.string,
354
- isParentListCollapsed: _propTypes.default.bool
317
+ value: PropTypes.oneOfType([PropTypes.node, PropTypes.object, PropTypes.string, PropTypes.bool]),
318
+ field: ImmutablePropTypes.map.isRequired,
319
+ fieldsMetaData: ImmutablePropTypes.map,
320
+ fieldsErrors: ImmutablePropTypes.map,
321
+ mediaPaths: ImmutablePropTypes.map.isRequired,
322
+ boundGetAsset: PropTypes.func.isRequired,
323
+ onChange: PropTypes.func.isRequired,
324
+ openMediaLibrary: PropTypes.func.isRequired,
325
+ addAsset: PropTypes.func.isRequired,
326
+ removeInsertedMedia: PropTypes.func.isRequired,
327
+ persistMedia: PropTypes.func.isRequired,
328
+ onValidate: PropTypes.func,
329
+ controlRef: PropTypes.func,
330
+ query: PropTypes.func.isRequired,
331
+ queryHits: PropTypes.object,
332
+ isFetching: PropTypes.bool,
333
+ clearSearch: PropTypes.func.isRequired,
334
+ clearFieldErrors: PropTypes.func.isRequired,
335
+ loadEntry: PropTypes.func.isRequired,
336
+ t: PropTypes.func.isRequired,
337
+ isEditorComponent: PropTypes.bool,
338
+ isNewEditorComponent: PropTypes.bool,
339
+ parentIds: PropTypes.arrayOf(PropTypes.string),
340
+ entry: ImmutablePropTypes.map.isRequired,
341
+ collection: ImmutablePropTypes.map.isRequired,
342
+ isDisabled: PropTypes.bool,
343
+ isHidden: PropTypes.bool,
344
+ isFieldDuplicate: PropTypes.func,
345
+ isFieldHidden: PropTypes.func,
346
+ locale: PropTypes.string,
347
+ isParentListCollapsed: PropTypes.bool
355
348
  });
356
349
  _defineProperty(EditorControl, "defaultProps", {
357
350
  parentIds: []
@@ -363,11 +356,11 @@ function mapStateToProps(state) {
363
356
  } = state;
364
357
  const entry = entryDraft.get('entry');
365
358
  const collection = collections.get(entryDraft.getIn(['entry', 'collection']));
366
- const isLoadingAsset = (0, _medias.selectIsLoadingAsset)(state.medias);
359
+ const isLoadingAsset = selectIsLoadingAsset(state.medias);
367
360
  async function loadEntry(collectionName, slug) {
368
361
  const targetCollection = collections.get(collectionName);
369
362
  if (targetCollection) {
370
- const loadedEntry = await (0, _entries.tryLoadEntry)(state, targetCollection, slug);
363
+ const loadedEntry = await tryLoadEntry(state, targetCollection, slug);
371
364
  return loadedEntry;
372
365
  } else {
373
366
  throw new Error(`Can't find collection '${collectionName}'`);
@@ -382,23 +375,23 @@ function mapStateToProps(state) {
382
375
  collection,
383
376
  isLoadingAsset,
384
377
  loadEntry,
385
- validateMetaField: (field, value, t) => (0, _entries.validateMetaField)(state, collection, field, value, t)
378
+ validateMetaField: (field, value, t) => validateMetaField(state, collection, field, value, t)
386
379
  };
387
380
  }
388
381
  function mapDispatchToProps(dispatch) {
389
- const creators = (0, _redux.bindActionCreators)({
390
- openMediaLibrary: _mediaLibrary.openMediaLibrary,
391
- clearMediaControl: _mediaLibrary.clearMediaControl,
392
- removeMediaControl: _mediaLibrary.removeMediaControl,
393
- removeInsertedMedia: _mediaLibrary.removeInsertedMedia,
394
- persistMedia: _mediaLibrary.persistMedia,
395
- addAsset: _media.addAsset,
396
- query: _search.query,
397
- clearSearch: _search.clearSearch,
398
- clearFieldErrors: _entries.clearFieldErrors
382
+ const creators = bindActionCreators({
383
+ openMediaLibrary,
384
+ clearMediaControl,
385
+ removeMediaControl,
386
+ removeInsertedMedia,
387
+ persistMedia,
388
+ addAsset,
389
+ query,
390
+ clearSearch,
391
+ clearFieldErrors
399
392
  }, dispatch);
400
393
  return _objectSpread(_objectSpread({}, creators), {}, {
401
- boundGetAsset: (collection, entry) => (0, _media.boundGetAsset)(dispatch, collection, entry)
394
+ boundGetAsset: (collection, entry) => boundGetAsset(dispatch, collection, entry)
402
395
  });
403
396
  }
404
397
  function mergeProps(stateProps, dispatchProps, ownProps) {
@@ -406,5 +399,5 @@ function mergeProps(stateProps, dispatchProps, ownProps) {
406
399
  boundGetAsset: dispatchProps.boundGetAsset(stateProps.collection, stateProps.entry)
407
400
  });
408
401
  }
409
- const ConnectedEditorControl = (0, _reactRedux.connect)(mapStateToProps, mapDispatchToProps, mergeProps)((0, _reactPolyglot.translate)()(EditorControl));
410
- var _default = exports.default = ConnectedEditorControl;
402
+ const ConnectedEditorControl = connect(mapStateToProps, mapDispatchToProps, mergeProps)(translate()(EditorControl));
403
+ export default ConnectedEditorControl;