decap-cms-core 3.7.1 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/decap-cms-core.js +17 -17
- package/dist/decap-cms-core.js.map +1 -1
- package/dist/esm/bootstrap.js +2 -2
- package/dist/esm/components/App/App.js +6 -3
- package/dist/esm/components/App/Header.js +38 -14
- package/dist/esm/components/Collection/Entries/Entries.js +14 -5
- package/dist/esm/components/Collection/Entries/EntriesCollection.js +65 -9
- package/dist/esm/components/Collection/Entries/EntryCard.js +84 -28
- package/dist/esm/components/Collection/Entries/EntryListing.js +46 -11
- package/dist/esm/components/UI/ErrorBoundary.js +2 -2
- package/dist/esm/constants/configSchema.js +14 -0
- package/dist/esm/lib/i18n.js +16 -0
- package/index.d.ts +5 -1
- package/package.json +2 -2
- package/src/components/App/App.js +2 -0
- package/src/components/App/Header.js +27 -0
- package/src/components/Collection/Entries/Entries.js +9 -0
- package/src/components/Collection/Entries/EntriesCollection.js +100 -4
- package/src/components/Collection/Entries/EntryCard.js +82 -3
- package/src/components/Collection/Entries/EntryListing.js +65 -5
- package/src/components/Collection/Entries/__tests__/EntriesCollection.spec.js +26 -18
- package/src/components/Collection/Entries/__tests__/__snapshots__/EntriesCollection.spec.js.snap +1 -0
- package/src/constants/configSchema.js +9 -1
- package/src/lib/i18n.ts +21 -0
- package/src/types/redux.ts +5 -1
|
@@ -4,61 +4,99 @@ import React from 'react';
|
|
|
4
4
|
import { connect } from 'react-redux';
|
|
5
5
|
import { Link } from 'react-router-dom';
|
|
6
6
|
import { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';
|
|
7
|
+
import { translate } from 'react-polyglot';
|
|
7
8
|
import { boundGetAsset } from '../../../actions/media';
|
|
8
9
|
import { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';
|
|
9
10
|
import { selectIsLoadingAsset } from '../../../reducers/medias';
|
|
10
11
|
import { selectEntryCollectionTitle } from '../../../reducers/collections';
|
|
11
12
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
12
13
|
const ListCard = /*#__PURE__*/_styled("li", {
|
|
13
|
-
target: "
|
|
14
|
+
target: "effeus410",
|
|
14
15
|
label: "ListCard"
|
|
15
|
-
})(components.card, ";width:", lengths.topCardWidth, ";margin-left:12px;margin-bottom:10px;overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16
|
+
})(components.card, ";width:", lengths.topCardWidth, ";margin-left:12px;margin-bottom:10px;overflow:hidden;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAY0B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
16
17
|
const ListCardLink = /*#__PURE__*/_styled(Link, {
|
|
17
|
-
target: "
|
|
18
|
+
target: "effeus49",
|
|
18
19
|
label: "ListCardLink"
|
|
19
|
-
})("display:block;max-width:100%;padding:16px 20px;&:hover{background-color:", colors.foreground, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
20
|
+
})("display:block;max-width:100%;padding:16px 20px;&:hover{background-color:", colors.foreground, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAoBiC","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
20
21
|
const GridCard = /*#__PURE__*/_styled("li", {
|
|
21
|
-
target: "
|
|
22
|
+
target: "effeus48",
|
|
22
23
|
label: "GridCard"
|
|
23
|
-
})(components.card, ";flex:0 0 335px;height:240px;overflow:hidden;margin-left:12px;margin-bottom:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
24
|
+
})(components.card, ";flex:0 0 335px;height:240px;overflow:hidden;margin-left:12px;margin-bottom:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AA8B0B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
24
25
|
const GridCardLink = /*#__PURE__*/_styled(Link, {
|
|
25
|
-
target: "
|
|
26
|
+
target: "effeus47",
|
|
26
27
|
label: "GridCardLink"
|
|
27
|
-
})("display:block;height:100%;outline-offset:-2px;&,&:hover{background-color:", colors.foreground, ";color:", colors.text, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
28
|
+
})("display:block;height:100%;outline-offset:-2px;&,&:hover{background-color:", colors.foreground, ";color:", colors.text, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAuCiC","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
28
29
|
const CollectionLabel = /*#__PURE__*/_styled("h2", {
|
|
29
|
-
target: "
|
|
30
|
+
target: "effeus46",
|
|
30
31
|
label: "CollectionLabel"
|
|
31
|
-
})("font-size:12px;color:", colors.textLead, ";text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
})("font-size:12px;color:", colors.textLead, ";text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAmDiC","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
32
33
|
const ListCardTitle = /*#__PURE__*/_styled("h2", {
|
|
33
|
-
target: "
|
|
34
|
+
target: "effeus45",
|
|
34
35
|
label: "ListCardTitle"
|
|
35
36
|
})(process.env.NODE_ENV === "production" ? {
|
|
36
|
-
name: "
|
|
37
|
-
styles: "margin-bottom:0"
|
|
37
|
+
name: "rmz9aj",
|
|
38
|
+
styles: "margin-bottom:0;display:flex;justify-content:space-between"
|
|
38
39
|
} : {
|
|
39
|
-
name: "
|
|
40
|
-
styles: "margin-bottom:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
40
|
+
name: "rmz9aj",
|
|
41
|
+
styles: "margin-bottom:0;display:flex;justify-content:space-between/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAyD+B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */",
|
|
41
42
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
42
43
|
});
|
|
43
44
|
const CardHeading = /*#__PURE__*/_styled("h2", {
|
|
44
|
-
target: "
|
|
45
|
+
target: "effeus44",
|
|
45
46
|
label: "CardHeading"
|
|
46
47
|
})(process.env.NODE_ENV === "production" ? {
|
|
47
|
-
name: "
|
|
48
|
-
styles: "margin:0 0 2px"
|
|
48
|
+
name: "1969ag7",
|
|
49
|
+
styles: "margin:0 0 2px;display:flex;justify-content:space-between"
|
|
49
50
|
} : {
|
|
50
|
-
name: "
|
|
51
|
-
styles: "margin:0 0 2px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
51
|
+
name: "1969ag7",
|
|
52
|
+
styles: "margin:0 0 2px;display:flex;justify-content:space-between/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AA+D6B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */",
|
|
52
53
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
53
54
|
});
|
|
54
55
|
const CardBody = /*#__PURE__*/_styled("div", {
|
|
55
|
-
target: "
|
|
56
|
+
target: "effeus43",
|
|
56
57
|
label: "CardBody"
|
|
57
|
-
})("padding:16px 20px;height:90px;position:relative;margin-bottom:", props => props.hasImage && 0, ";&:after{content:'';position:absolute;display:block;z-index:", zIndex.zIndex1, ";bottom:0;left:-20%;height:140%;width:140%;box-shadow:inset 0 -15px 24px ", colorsRaw.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
58
|
+
})("padding:16px 20px;height:90px;position:relative;margin-bottom:", props => props.hasImage && 0, ";&:after{content:'';position:absolute;display:block;z-index:", zIndex.zIndex1, ";bottom:0;left:-20%;height:140%;width:140%;box-shadow:inset 0 -15px 24px ", colorsRaw.white, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAqE2B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
58
59
|
const CardImage = /*#__PURE__*/_styled("div", {
|
|
59
|
-
target: "
|
|
60
|
+
target: "effeus42",
|
|
60
61
|
label: "CardImage"
|
|
61
|
-
})("background-image:url(", props => props.src, ");background-position:center center;background-size:cover;background-repeat:no-repeat;height:150px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
62
|
+
})("background-image:url(", props => props.src, ");background-position:center center;background-size:cover;background-repeat:no-repeat;height:150px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAwF4B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
63
|
+
const TitleIcons = /*#__PURE__*/_styled("div", {
|
|
64
|
+
target: "effeus41",
|
|
65
|
+
label: "TitleIcons"
|
|
66
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
67
|
+
name: "1yydxi7",
|
|
68
|
+
styles: "display:flex;align-items:center;gap:8px"
|
|
69
|
+
} : {
|
|
70
|
+
name: "1yydxi7",
|
|
71
|
+
styles: "display:flex;align-items:center;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAgG6B","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */",
|
|
72
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
73
|
+
});
|
|
74
|
+
const WorkflowBadge = /*#__PURE__*/_styled("span", {
|
|
75
|
+
target: "effeus40",
|
|
76
|
+
label: "WorkflowBadge"
|
|
77
|
+
})("padding:2px 6px;border-radius:3px;font-size:11px;text-transform:uppercase;background-color:", props => {
|
|
78
|
+
switch (props.status) {
|
|
79
|
+
case 'draft':
|
|
80
|
+
return colors.statusDraftBackground;
|
|
81
|
+
case 'pending_review':
|
|
82
|
+
return colors.statusReviewBackground;
|
|
83
|
+
case 'pending_publish':
|
|
84
|
+
return colors.statusReadyBackground;
|
|
85
|
+
default:
|
|
86
|
+
return colors.background;
|
|
87
|
+
}
|
|
88
|
+
}, ";color:", props => {
|
|
89
|
+
switch (props.status) {
|
|
90
|
+
case 'draft':
|
|
91
|
+
return colors.statusDraftText;
|
|
92
|
+
case 'pending_review':
|
|
93
|
+
return colors.statusReviewText;
|
|
94
|
+
case 'pending_publish':
|
|
95
|
+
return colors.statusReadyText;
|
|
96
|
+
default:
|
|
97
|
+
return colors.text;
|
|
98
|
+
}
|
|
99
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Collection/Entries/EntryCard.js"],"names":[],"mappings":"AAsGiC","file":"../../../../../src/components/Collection/Entries/EntryCard.js","sourcesContent":["import React from 'react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { Link } from 'react-router-dom';\nimport { colors, colorsRaw, components, lengths, zIndex } from 'decap-cms-ui-default';\nimport { translate } from 'react-polyglot';\n\nimport { boundGetAsset } from '../../../actions/media';\nimport { VIEW_STYLE_LIST, VIEW_STYLE_GRID } from '../../../constants/collectionViews';\nimport { selectIsLoadingAsset } from '../../../reducers/medias';\nimport { selectEntryCollectionTitle } from '../../../reducers/collections';\n\nconst ListCard = styled.li`\n  ${components.card};\n  width: ${lengths.topCardWidth};\n  margin-left: 12px;\n  margin-bottom: 10px;\n  overflow: hidden;\n`;\n\nconst ListCardLink = styled(Link)`\n  display: block;\n  max-width: 100%;\n  padding: 16px 20px;\n\n  &:hover {\n    background-color: ${colors.foreground};\n  }\n`;\n\nconst GridCard = styled.li`\n  ${components.card};\n  flex: 0 0 335px;\n  height: 240px;\n  overflow: hidden;\n  margin-left: 12px;\n  margin-bottom: 16px;\n`;\n\nconst GridCardLink = styled(Link)`\n  display: block;\n  height: 100%;\n  outline-offset: -2px;\n\n  &,\n  &:hover {\n    background-color: ${colors.foreground};\n    color: ${colors.text};\n  }\n`;\n\nconst CollectionLabel = styled.h2`\n  font-size: 12px;\n  color: ${colors.textLead};\n  text-transform: uppercase;\n`;\n\nconst ListCardTitle = styled.h2`\n  margin-bottom: 0;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardHeading = styled.h2`\n  margin: 0 0 2px;\n  display: flex;\n  justify-content: space-between;\n`;\n\nconst CardBody = styled.div`\n  padding: 16px 20px;\n  height: 90px;\n  position: relative;\n  margin-bottom: ${props => props.hasImage && 0};\n\n  &:after {\n    content: '';\n    position: absolute;\n    display: block;\n    z-index: ${zIndex.zIndex1};\n    bottom: 0;\n    left: -20%;\n    height: 140%;\n    width: 140%;\n    box-shadow: inset 0 -15px 24px ${colorsRaw.white};\n  }\n`;\n\nconst CardImage = styled.div`\n  background-image: url(${props => props.src});\n  background-position: center center;\n  background-size: cover;\n  background-repeat: no-repeat;\n  height: 150px;\n`;\n\nconst TitleIcons = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst WorkflowBadge = styled.span`\n  padding: 2px 6px;\n  border-radius: 3px;\n  font-size: 11px;\n  text-transform: uppercase;\n  background-color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftBackground;\n      case 'pending_review':\n        return colors.statusReviewBackground;\n      case 'pending_publish':\n        return colors.statusReadyBackground;\n      default:\n        return colors.background;\n    }\n  }};\n  color: ${props => {\n    switch (props.status) {\n      case 'draft':\n        return colors.statusDraftText;\n      case 'pending_review':\n        return colors.statusReviewText;\n      case 'pending_publish':\n        return colors.statusReadyText;\n      default:\n        return colors.text;\n    }\n  }};\n`;\n\nfunction EntryCard({\n  path,\n  summary,\n  image,\n  imageField,\n  collectionLabel,\n  viewStyle = VIEW_STYLE_LIST,\n  workflowStatus,\n  getAsset,\n  t,\n}) {\n  function getStatusLabel(status) {\n    switch (status) {\n      case 'pending_review':\n        return t('editor.editorToolbar.inReview');\n      case 'pending_publish':\n        return t('editor.editorToolbar.ready');\n      case 'draft':\n        return t('editor.editorToolbar.draft');\n      default:\n        return status;\n    }\n  }\n\n  if (viewStyle === VIEW_STYLE_LIST) {\n    return (\n      <ListCard>\n        <ListCardLink to={path}>\n          {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n          <ListCardTitle>\n            {summary}\n            <TitleIcons>\n              {workflowStatus && (\n                <WorkflowBadge status={workflowStatus}>\n                  {getStatusLabel(workflowStatus)}\n                </WorkflowBadge>\n              )}\n            </TitleIcons>\n          </ListCardTitle>\n        </ListCardLink>\n      </ListCard>\n    );\n  }\n\n  if (viewStyle === VIEW_STYLE_GRID) {\n    return (\n      <GridCard>\n        <GridCardLink to={path}>\n          <CardBody hasImage={image}>\n            {collectionLabel ? <CollectionLabel>{collectionLabel}</CollectionLabel> : null}\n            <CardHeading>\n              {summary}\n              <TitleIcons>\n                {workflowStatus && (\n                  <WorkflowBadge status={workflowStatus}>\n                    {getStatusLabel(workflowStatus)}\n                  </WorkflowBadge>\n                )}\n              </TitleIcons>\n            </CardHeading>\n          </CardBody>\n          {image ? <CardImage src={getAsset(image, imageField).toString()} /> : null}\n        </GridCardLink>\n      </GridCard>\n    );\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { entry, inferredFields, collection } = ownProps;\n  const entryData = entry.get('data');\n  const summary = selectEntryCollectionTitle(collection, entry);\n\n  let image = entryData.get(inferredFields.imageField);\n  if (image) {\n    image = encodeURI(image);\n  }\n\n  const isLoadingAsset = selectIsLoadingAsset(state.medias);\n\n  return {\n    summary,\n    path: `/collections/${collection.get('name')}/entries/${entry.get('slug')}`,\n    image,\n    imageFolder: collection\n      .get('fields')\n      ?.find(f => f.get('name') === inferredFields.imageField && f.get('widget') === 'image'),\n    isLoadingAsset,\n  };\n}\n\nfunction mapDispatchToProps(dispatch) {\n  return {\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    getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry),\n  };\n}\n\nconst ConnectedEntryCard = connect(\n  mapStateToProps,\n  mapDispatchToProps,\n  mergeProps,\n)(translate()(EntryCard));\n\nexport default ConnectedEntryCard;\n"]} */"));
|
|
62
100
|
function EntryCard({
|
|
63
101
|
path,
|
|
64
102
|
summary,
|
|
@@ -66,19 +104,37 @@ function EntryCard({
|
|
|
66
104
|
imageField,
|
|
67
105
|
collectionLabel,
|
|
68
106
|
viewStyle = VIEW_STYLE_LIST,
|
|
69
|
-
|
|
107
|
+
workflowStatus,
|
|
108
|
+
getAsset,
|
|
109
|
+
t
|
|
70
110
|
}) {
|
|
111
|
+
function getStatusLabel(status) {
|
|
112
|
+
switch (status) {
|
|
113
|
+
case 'pending_review':
|
|
114
|
+
return t('editor.editorToolbar.inReview');
|
|
115
|
+
case 'pending_publish':
|
|
116
|
+
return t('editor.editorToolbar.ready');
|
|
117
|
+
case 'draft':
|
|
118
|
+
return t('editor.editorToolbar.draft');
|
|
119
|
+
default:
|
|
120
|
+
return status;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
71
123
|
if (viewStyle === VIEW_STYLE_LIST) {
|
|
72
124
|
return ___EmotionJSX(ListCard, null, ___EmotionJSX(ListCardLink, {
|
|
73
125
|
to: path
|
|
74
|
-
}, collectionLabel ? ___EmotionJSX(CollectionLabel, null, collectionLabel) : null, ___EmotionJSX(ListCardTitle, null, summary
|
|
126
|
+
}, collectionLabel ? ___EmotionJSX(CollectionLabel, null, collectionLabel) : null, ___EmotionJSX(ListCardTitle, null, summary, ___EmotionJSX(TitleIcons, null, workflowStatus && ___EmotionJSX(WorkflowBadge, {
|
|
127
|
+
status: workflowStatus
|
|
128
|
+
}, getStatusLabel(workflowStatus))))));
|
|
75
129
|
}
|
|
76
130
|
if (viewStyle === VIEW_STYLE_GRID) {
|
|
77
131
|
return ___EmotionJSX(GridCard, null, ___EmotionJSX(GridCardLink, {
|
|
78
132
|
to: path
|
|
79
133
|
}, ___EmotionJSX(CardBody, {
|
|
80
134
|
hasImage: image
|
|
81
|
-
}, collectionLabel ? ___EmotionJSX(CollectionLabel, null, collectionLabel) : null, ___EmotionJSX(CardHeading, null, summary
|
|
135
|
+
}, collectionLabel ? ___EmotionJSX(CollectionLabel, null, collectionLabel) : null, ___EmotionJSX(CardHeading, null, summary, ___EmotionJSX(TitleIcons, null, workflowStatus && ___EmotionJSX(WorkflowBadge, {
|
|
136
|
+
status: workflowStatus
|
|
137
|
+
}, getStatusLabel(workflowStatus))))), image ? ___EmotionJSX(CardImage, {
|
|
82
138
|
src: getAsset(image, imageField).toString()
|
|
83
139
|
}) : null));
|
|
84
140
|
}
|
|
@@ -117,5 +173,5 @@ function mergeProps(stateProps, dispatchProps, ownProps) {
|
|
|
117
173
|
getAsset: dispatchProps.boundGetAsset(ownProps.collection, ownProps.entry)
|
|
118
174
|
};
|
|
119
175
|
}
|
|
120
|
-
const ConnectedEntryCard = connect(mapStateToProps, mapDispatchToProps, mergeProps)(EntryCard);
|
|
176
|
+
const ConnectedEntryCard = connect(mapStateToProps, mapDispatchToProps, mergeProps)(translate()(EntryCard));
|
|
121
177
|
export default ConnectedEntryCard;
|