decap-cms-core 3.3.2 → 3.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +5 -5
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/bootstrap.js +2 -2
- package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +10 -7
- package/dist/esm/components/Editor/EditorControlPane/Widget.js +7 -4
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/dist/esm/constants/configSchema.js +1 -1
- package/index.d.ts +3 -3
- package/package.json +2 -2
- package/src/components/Editor/EditorControlPane/EditorControl.js +3 -0
- package/src/components/Editor/EditorControlPane/Widget.js +4 -1
- package/src/constants/configSchema.js +1 -1
package/dist/esm/bootstrap.js
CHANGED
|
@@ -86,17 +86,17 @@ const ControlContainer = /*#__PURE__*/(0, _base.default)("div", {
|
|
|
86
86
|
} : {
|
|
87
87
|
name: "gpgisz",
|
|
88
88
|
styles: "margin-top:16px;&:first-of-type{margin-top:36px;}",
|
|
89
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAuEmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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  };\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    } = 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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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            />\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
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorControlPane/EditorControl.js"],"names":[],"mappings":"AAuEmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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"]} */",
|
|
90
90
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
91
91
|
});
|
|
92
92
|
const ControlErrorsList = /*#__PURE__*/(0, _base.default)("ul", {
|
|
93
93
|
target: "ec1nk3l1",
|
|
94
94
|
label: "ControlErrorsList"
|
|
95
|
-
})("list-style-type:none;font-size:12px;color:", _decapCmsUiDefault.colors.errorText, ";margin-bottom:5px;text-align:right;text-transform:uppercase;position:relative;font-weight:600;top:20px;" + (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+EmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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  };\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    } = 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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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            />\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"]} */"));
|
|
95
|
+
})("list-style-type:none;font-size:12px;color:", _decapCmsUiDefault.colors.errorText, ";margin-bottom:5px;text-align:right;text-transform:uppercase;position:relative;font-weight:600;top:20px;" + (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+EmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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
96
|
const ControlHint = exports.ControlHint = /*#__PURE__*/(0, _base.default)("p", {
|
|
97
97
|
target: "ec1nk3l0",
|
|
98
98
|
label: "ControlHint"
|
|
99
|
-
})("margin-bottom:0;padding:3px 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":"AA2FmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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  };\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    } = 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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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            />\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"]} */"));
|
|
99
|
+
})("margin-bottom:0;padding:3px 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":"AA2FmC","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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"]} */"));
|
|
100
100
|
function LabelComponent({
|
|
101
101
|
field,
|
|
102
102
|
isActive,
|
|
@@ -169,7 +169,8 @@ class EditorControl extends _react.default.Component {
|
|
|
169
169
|
isHidden,
|
|
170
170
|
isFieldDuplicate,
|
|
171
171
|
isFieldHidden,
|
|
172
|
-
locale
|
|
172
|
+
locale,
|
|
173
|
+
isParentListCollapsed
|
|
173
174
|
} = this.props;
|
|
174
175
|
const widgetName = field.get('widget');
|
|
175
176
|
const widget = (0, _registry.resolveWidget)(widgetName);
|
|
@@ -190,7 +191,7 @@ class EditorControl extends _react.default.Component {
|
|
|
190
191
|
${isHidden && styleStrings.hidden};
|
|
191
192
|
`
|
|
192
193
|
}, widget.globalStyles && (0, _react2.jsx)(_react2.Global, {
|
|
193
|
-
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":"AA0O2D","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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  };\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    } = 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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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            />\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"]} */"))
|
|
194
|
+
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":"AA4O2D","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    background: #ccc;\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 ControlErrorsList = styled.ul`\n  list-style-type: none;\n  font-size: 12px;\n  color: ${colors.errorText};\n  margin-bottom: 5px;\n  text-align: right;\n  text-transform: uppercase;\n  position: relative;\n  font-weight: 600;\n  top: 20px;\n`;\n\nexport const ControlHint = styled.p`\n  margin-bottom: 0;\n  padding: 3px 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      {label} {`${isFieldOptional ? ` (${t('editor.editorControl.field.optional')})` : ''}`}\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            {widget.globalStyles && <Global styles={coreCss`${widget.globalStyles}`} />}\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            <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            <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) => onChange(field, newValue, newMetadata)}\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"]} */"))
|
|
194
195
|
}), errors && (0, _react2.jsx)(ControlErrorsList, null, errors.map(error => error.message && typeof error.message === 'string' && (0, _react2.jsx)("li", {
|
|
195
196
|
key: error.message.trim().replace(/[^a-z0-9]+/gi, '-')
|
|
196
197
|
}, error.message))), (0, _react2.jsx)(LabelComponent, {
|
|
@@ -276,7 +277,8 @@ class EditorControl extends _react.default.Component {
|
|
|
276
277
|
isFieldDuplicate: isFieldDuplicate,
|
|
277
278
|
isFieldHidden: isFieldHidden,
|
|
278
279
|
isLoadingAsset: isLoadingAsset,
|
|
279
|
-
locale: locale
|
|
280
|
+
locale: locale,
|
|
281
|
+
isParentListCollapsed: isParentListCollapsed
|
|
280
282
|
}), fieldHint && (0, _react2.jsx)(ControlHint, {
|
|
281
283
|
active: isSelected || this.state.styleActive,
|
|
282
284
|
error: hasErrors
|
|
@@ -334,7 +336,8 @@ _defineProperty(EditorControl, "propTypes", {
|
|
|
334
336
|
isHidden: _propTypes.default.bool,
|
|
335
337
|
isFieldDuplicate: _propTypes.default.func,
|
|
336
338
|
isFieldHidden: _propTypes.default.func,
|
|
337
|
-
locale: _propTypes.default.string
|
|
339
|
+
locale: _propTypes.default.string,
|
|
340
|
+
isParentListCollapsed: _propTypes.default.bool
|
|
338
341
|
});
|
|
339
342
|
_defineProperty(EditorControl, "defaultProps", {
|
|
340
343
|
parentIds: []
|
|
@@ -200,7 +200,7 @@ class Widget extends _react.Component {
|
|
|
200
200
|
/**
|
|
201
201
|
* Avoid unnecessary rerenders while loading assets.
|
|
202
202
|
*/
|
|
203
|
-
if (this.props.isLoadingAsset) return false;
|
|
203
|
+
if (this.props.isLoadingAsset && nextProps.isLoadingAsset) return false;
|
|
204
204
|
/**
|
|
205
205
|
* Allow widgets to provide their own `shouldComponentUpdate` method.
|
|
206
206
|
*/
|
|
@@ -255,7 +255,8 @@ class Widget extends _react.Component {
|
|
|
255
255
|
isDisabled,
|
|
256
256
|
isFieldDuplicate,
|
|
257
257
|
isFieldHidden,
|
|
258
|
-
locale
|
|
258
|
+
locale,
|
|
259
|
+
isParentListCollapsed
|
|
259
260
|
} = this.props;
|
|
260
261
|
return /*#__PURE__*/_react.default.createElement(controlComponent, {
|
|
261
262
|
entry,
|
|
@@ -306,7 +307,8 @@ class Widget extends _react.Component {
|
|
|
306
307
|
isDisabled,
|
|
307
308
|
isFieldDuplicate,
|
|
308
309
|
isFieldHidden,
|
|
309
|
-
locale
|
|
310
|
+
locale,
|
|
311
|
+
isParentListCollapsed
|
|
310
312
|
});
|
|
311
313
|
}
|
|
312
314
|
}
|
|
@@ -355,5 +357,6 @@ _defineProperty(Widget, "propTypes", {
|
|
|
355
357
|
isDisabled: _propTypes.default.bool,
|
|
356
358
|
isFieldDuplicate: _propTypes.default.func,
|
|
357
359
|
isFieldHidden: _propTypes.default.func,
|
|
358
|
-
locale: _propTypes.default.string
|
|
360
|
+
locale: _propTypes.default.string,
|
|
361
|
+
isParentListCollapsed: _propTypes.default.bool
|
|
359
362
|
});
|
|
@@ -54,8 +54,8 @@ function buildIssueTemplate({
|
|
|
54
54
|
let version = '';
|
|
55
55
|
if (typeof DECAP_CMS_VERSION === 'string') {
|
|
56
56
|
version = `decap-cms@${DECAP_CMS_VERSION}`;
|
|
57
|
-
} else if (typeof "3.1.
|
|
58
|
-
version = `decap-cms-app@${"3.1.
|
|
57
|
+
} else if (typeof "3.1.3" === 'string') {
|
|
58
|
+
version = `decap-cms-app@${"3.1.3"}`;
|
|
59
59
|
}
|
|
60
60
|
const template = getIssueTemplate({
|
|
61
61
|
version,
|
package/index.d.ts
CHANGED
|
@@ -41,7 +41,7 @@ declare module 'decap-cms-core' {
|
|
|
41
41
|
|
|
42
42
|
export type CmsAuthScope = 'repo' | 'public_repo';
|
|
43
43
|
|
|
44
|
-
export type CmsPublishMode = 'simple' | 'editorial_workflow';
|
|
44
|
+
export type CmsPublishMode = 'simple' | 'editorial_workflow' | '';
|
|
45
45
|
|
|
46
46
|
export type CmsSlugEncoding = 'unicode' | 'ascii';
|
|
47
47
|
|
|
@@ -426,12 +426,12 @@ declare module 'decap-cms-core' {
|
|
|
426
426
|
export interface EditorComponentOptions {
|
|
427
427
|
id: string;
|
|
428
428
|
label: string;
|
|
429
|
-
fields
|
|
429
|
+
fields?: EditorComponentField[];
|
|
430
430
|
pattern: RegExp;
|
|
431
431
|
allow_add?: boolean;
|
|
432
432
|
fromBlock: (match: RegExpMatchArray) => any;
|
|
433
433
|
toBlock: (data: any) => string;
|
|
434
|
-
toPreview: (data: any) => string;
|
|
434
|
+
toPreview: (data: any) => string | JSX.Element;
|
|
435
435
|
}
|
|
436
436
|
|
|
437
437
|
export interface PreviewStyleOptions {
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "decap-cms-core",
|
|
3
3
|
"description": "Decap CMS core application, see decap-cms package for the main distribution.",
|
|
4
|
-
"version": "3.3.
|
|
4
|
+
"version": "3.3.3",
|
|
5
5
|
"repository": "https://github.com/decaporg/decap-cms/tree/master/packages/decap-cms-core",
|
|
6
6
|
"bugs": "https://github.com/decaporg/decap-cms/issues",
|
|
7
7
|
"module": "dist/esm/index.js",
|
|
@@ -96,5 +96,5 @@
|
|
|
96
96
|
"@types/url-join": "^4.0.0",
|
|
97
97
|
"redux-mock-store": "^1.5.3"
|
|
98
98
|
},
|
|
99
|
-
"gitHead": "
|
|
99
|
+
"gitHead": "bc2a59cf3f16a9a3208680feec96e8b5ce316804"
|
|
100
100
|
}
|
|
@@ -147,6 +147,7 @@ class EditorControl extends React.Component {
|
|
|
147
147
|
isFieldDuplicate: PropTypes.func,
|
|
148
148
|
isFieldHidden: PropTypes.func,
|
|
149
149
|
locale: PropTypes.string,
|
|
150
|
+
isParentListCollapsed: PropTypes.bool,
|
|
150
151
|
};
|
|
151
152
|
|
|
152
153
|
static defaultProps = {
|
|
@@ -210,6 +211,7 @@ class EditorControl extends React.Component {
|
|
|
210
211
|
isFieldDuplicate,
|
|
211
212
|
isFieldHidden,
|
|
212
213
|
locale,
|
|
214
|
+
isParentListCollapsed,
|
|
213
215
|
} = this.props;
|
|
214
216
|
|
|
215
217
|
const widgetName = field.get('widget');
|
|
@@ -332,6 +334,7 @@ class EditorControl extends React.Component {
|
|
|
332
334
|
isFieldHidden={isFieldHidden}
|
|
333
335
|
isLoadingAsset={isLoadingAsset}
|
|
334
336
|
locale={locale}
|
|
337
|
+
isParentListCollapsed={isParentListCollapsed}
|
|
335
338
|
/>
|
|
336
339
|
{fieldHint && (
|
|
337
340
|
<ControlHint active={isSelected || this.state.styleActive} error={hasErrors}>
|
|
@@ -72,13 +72,14 @@ export default class Widget extends Component {
|
|
|
72
72
|
isFieldDuplicate: PropTypes.func,
|
|
73
73
|
isFieldHidden: PropTypes.func,
|
|
74
74
|
locale: PropTypes.string,
|
|
75
|
+
isParentListCollapsed: PropTypes.bool,
|
|
75
76
|
};
|
|
76
77
|
|
|
77
78
|
shouldComponentUpdate(nextProps) {
|
|
78
79
|
/**
|
|
79
80
|
* Avoid unnecessary rerenders while loading assets.
|
|
80
81
|
*/
|
|
81
|
-
if (this.props.isLoadingAsset) return false;
|
|
82
|
+
if (this.props.isLoadingAsset && nextProps.isLoadingAsset) return false;
|
|
82
83
|
/**
|
|
83
84
|
* Allow widgets to provide their own `shouldComponentUpdate` method.
|
|
84
85
|
*/
|
|
@@ -298,6 +299,7 @@ export default class Widget extends Component {
|
|
|
298
299
|
isFieldDuplicate,
|
|
299
300
|
isFieldHidden,
|
|
300
301
|
locale,
|
|
302
|
+
isParentListCollapsed,
|
|
301
303
|
} = this.props;
|
|
302
304
|
|
|
303
305
|
return React.createElement(controlComponent, {
|
|
@@ -350,6 +352,7 @@ export default class Widget extends Component {
|
|
|
350
352
|
isFieldDuplicate,
|
|
351
353
|
isFieldHidden,
|
|
352
354
|
locale,
|
|
355
|
+
isParentListCollapsed,
|
|
353
356
|
});
|
|
354
357
|
}
|
|
355
358
|
}
|