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.
@@ -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: "effeus48",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzBCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY29ubmVjdCB9IGZyb20gJ3JlYWN0LXJlZHV4JztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IGNvbG9ycywgY29sb3JzUmF3LCBjb21wb25lbnRzLCBsZW5ndGhzLCB6SW5kZXggfSBmcm9tICdkZWNhcC1jbXMtdWktZGVmYXVsdCc7XG5cbmltcG9ydCB7IGJvdW5kR2V0QXNzZXQgfSBmcm9tICcuLi8uLi8uLi9hY3Rpb25zL21lZGlhJztcbmltcG9ydCB7IFZJRVdfU1RZTEVfTElTVCwgVklFV19TVFlMRV9HUklEIH0gZnJvbSAnLi4vLi4vLi4vY29uc3RhbnRzL2NvbGxlY3Rpb25WaWV3cyc7XG5pbXBvcnQgeyBzZWxlY3RJc0xvYWRpbmdBc3NldCB9IGZyb20gJy4uLy4uLy4uL3JlZHVjZXJzL21lZGlhcyc7XG5pbXBvcnQgeyBzZWxlY3RFbnRyeUNvbGxlY3Rpb25UaXRsZSB9IGZyb20gJy4uLy4uLy4uL3JlZHVjZXJzL2NvbGxlY3Rpb25zJztcblxuY29uc3QgTGlzdENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgd2lkdGg6ICR7bGVuZ3Rocy50b3BDYXJkV2lkdGh9O1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTBweDtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbmA7XG5cbmNvbnN0IExpc3RDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIG1heC13aWR0aDogMTAwJTtcbiAgcGFkZGluZzogMTZweCAyMHB4O1xuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmZvcmVncm91bmR9O1xuICB9XG5gO1xuXG5jb25zdCBHcmlkQ2FyZCA9IHN0eWxlZC5saWBcbiAgJHtjb21wb25lbnRzLmNhcmR9O1xuICBmbGV4OiAwIDAgMzM1cHg7XG4gIGhlaWdodDogMjQwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIG1hcmdpbi1sZWZ0OiAxMnB4O1xuICBtYXJnaW4tYm90dG9tOiAxNnB4O1xuYDtcblxuY29uc3QgR3JpZENhcmRMaW5rID0gc3R5bGVkKExpbmspYFxuICBkaXNwbGF5OiBibG9jaztcbiAgaGVpZ2h0OiAxMDAlO1xuICBvdXRsaW5lLW9mZnNldDogLTJweDtcblxuICAmLFxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgICBjb2xvcjogJHtjb2xvcnMudGV4dH07XG4gIH1cbmA7XG5cbmNvbnN0IENvbGxlY3Rpb25MYWJlbCA9IHN0eWxlZC5oMmBcbiAgZm9udC1zaXplOiAxMnB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuYDtcblxuY29uc3QgTGlzdENhcmRUaXRsZSA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luLWJvdHRvbTogMDtcbmA7XG5cbmNvbnN0IENhcmRIZWFkaW5nID0gc3R5bGVkLmgyYFxuICBtYXJnaW46IDAgMCAycHg7XG5gO1xuXG5jb25zdCBDYXJkQm9keSA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6IDE2cHggMjBweDtcbiAgaGVpZ2h0OiA5MHB4O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIG1hcmdpbi1ib3R0b206ICR7cHJvcHMgPT4gcHJvcHMuaGFzSW1hZ2UgJiYgMH07XG5cbiAgJjphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHotaW5kZXg6ICR7ekluZGV4LnpJbmRleDF9O1xuICAgIGJvdHRvbTogMDtcbiAgICBsZWZ0OiAtMjAlO1xuICAgIGhlaWdodDogMTQwJTtcbiAgICB3aWR0aDogMTQwJTtcbiAgICBib3gtc2hhZG93OiBpbnNldCAwIC0xNXB4IDI0cHggJHtjb2xvcnNSYXcud2hpdGV9O1xuICB9XG5gO1xuXG5jb25zdCBDYXJkSW1hZ2UgPSBzdHlsZWQuZGl2YFxuICBiYWNrZ3JvdW5kLWltYWdlOiB1cmwoJHtwcm9wcyA9PiBwcm9wcy5zcmN9KTtcbiAgYmFja2dyb3VuZC1wb3NpdGlvbjogY2VudGVyIGNlbnRlcjtcbiAgYmFja2dyb3VuZC1zaXplOiBjb3ZlcjtcbiAgYmFja2dyb3VuZC1yZXBlYXQ6IG5vLXJlcGVhdDtcbiAgaGVpZ2h0OiAxNTBweDtcbmA7XG5cbmZ1bmN0aW9uIEVudHJ5Q2FyZCh7XG4gIHBhdGgsXG4gIHN1bW1hcnksXG4gIGltYWdlLFxuICBpbWFnZUZpZWxkLFxuICBjb2xsZWN0aW9uTGFiZWwsXG4gIHZpZXdTdHlsZSA9IFZJRVdfU1RZTEVfTElTVCxcbiAgZ2V0QXNzZXQsXG59KSB7XG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfTElTVCkge1xuICAgIHJldHVybiAoXG4gICAgICA8TGlzdENhcmQ+XG4gICAgICAgIDxMaXN0Q2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIHtjb2xsZWN0aW9uTGFiZWwgPyA8Q29sbGVjdGlvbkxhYmVsPntjb2xsZWN0aW9uTGFiZWx9PC9Db2xsZWN0aW9uTGFiZWw+IDogbnVsbH1cbiAgICAgICAgICA8TGlzdENhcmRUaXRsZT57c3VtbWFyeX08L0xpc3RDYXJkVGl0bGU+XG4gICAgICAgIDwvTGlzdENhcmRMaW5rPlxuICAgICAgPC9MaXN0Q2FyZD5cbiAgICApO1xuICB9XG5cbiAgaWYgKHZpZXdTdHlsZSA9PT0gVklFV19TVFlMRV9HUklEKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxHcmlkQ2FyZD5cbiAgICAgICAgPEdyaWRDYXJkTGluayB0bz17cGF0aH0+XG4gICAgICAgICAgPENhcmRCb2R5IGhhc0ltYWdlPXtpbWFnZX0+XG4gICAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgICA8Q2FyZEhlYWRpbmc+e3N1bW1hcnl9PC9DYXJkSGVhZGluZz5cbiAgICAgICAgICA8L0NhcmRCb2R5PlxuICAgICAgICAgIHtpbWFnZSA/IDxDYXJkSW1hZ2Ugc3JjPXtnZXRBc3NldChpbWFnZSwgaW1hZ2VGaWVsZCkudG9TdHJpbmcoKX0gLz4gOiBudWxsfVxuICAgICAgICA8L0dyaWRDYXJkTGluaz5cbiAgICAgIDwvR3JpZENhcmQ+XG4gICAgKTtcbiAgfVxufVxuXG5mdW5jdGlvbiBtYXBTdGF0ZVRvUHJvcHMoc3RhdGUsIG93blByb3BzKSB7XG4gIGNvbnN0IHsgZW50cnksIGluZmVycmVkRmllbGRzLCBjb2xsZWN0aW9uIH0gPSBvd25Qcm9wcztcbiAgY29uc3QgZW50cnlEYXRhID0gZW50cnkuZ2V0KCdkYXRhJyk7XG4gIGNvbnN0IHN1bW1hcnkgPSBzZWxlY3RFbnRyeUNvbGxlY3Rpb25UaXRsZShjb2xsZWN0aW9uLCBlbnRyeSk7XG5cbiAgbGV0IGltYWdlID0gZW50cnlEYXRhLmdldChpbmZlcnJlZEZpZWxkcy5pbWFnZUZpZWxkKTtcbiAgaWYgKGltYWdlKSB7XG4gICAgaW1hZ2UgPSBlbmNvZGVVUkkoaW1hZ2UpO1xuICB9XG5cbiAgY29uc3QgaXNMb2FkaW5nQXNzZXQgPSBzZWxlY3RJc0xvYWRpbmdBc3NldChzdGF0ZS5tZWRpYXMpO1xuXG4gIHJldHVybiB7XG4gICAgc3VtbWFyeSxcbiAgICBwYXRoOiBgL2NvbGxlY3Rpb25zLyR7Y29sbGVjdGlvbi5nZXQoJ25hbWUnKX0vZW50cmllcy8ke2VudHJ5LmdldCgnc2x1ZycpfWAsXG4gICAgaW1hZ2UsXG4gICAgaW1hZ2VGb2xkZXI6IGNvbGxlY3Rpb25cbiAgICAgIC5nZXQoJ2ZpZWxkcycpXG4gICAgICA/LmZpbmQoZiA9PiBmLmdldCgnbmFtZScpID09PSBpbmZlcnJlZEZpZWxkcy5pbWFnZUZpZWxkICYmIGYuZ2V0KCd3aWRnZXQnKSA9PT0gJ2ltYWdlJyksXG4gICAgaXNMb2FkaW5nQXNzZXQsXG4gIH07XG59XG5cbmZ1bmN0aW9uIG1hcERpc3BhdGNoVG9Qcm9wcyhkaXNwYXRjaCkge1xuICByZXR1cm4ge1xuICAgIGJvdW5kR2V0QXNzZXQ6IChjb2xsZWN0aW9uLCBlbnRyeSkgPT4gYm91bmRHZXRBc3NldChkaXNwYXRjaCwgY29sbGVjdGlvbiwgZW50cnkpLFxuICB9O1xufVxuXG5mdW5jdGlvbiBtZXJnZVByb3BzKHN0YXRlUHJvcHMsIGRpc3BhdGNoUHJvcHMsIG93blByb3BzKSB7XG4gIHJldHVybiB7XG4gICAgLi4uc3RhdGVQcm9wcyxcbiAgICAuLi5kaXNwYXRjaFByb3BzLFxuICAgIC4uLm93blByb3BzLFxuICAgIGdldEFzc2V0OiBkaXNwYXRjaFByb3BzLmJvdW5kR2V0QXNzZXQob3duUHJvcHMuY29sbGVjdGlvbiwgb3duUHJvcHMuZW50cnkpLFxuICB9O1xufVxuXG5jb25zdCBDb25uZWN0ZWRFbnRyeUNhcmQgPSBjb25uZWN0KG1hcFN0YXRlVG9Qcm9wcywgbWFwRGlzcGF0Y2hUb1Byb3BzLCBtZXJnZVByb3BzKShFbnRyeUNhcmQpO1xuXG5leHBvcnQgZGVmYXVsdCBDb25uZWN0ZWRFbnRyeUNhcmQ7XG4iXX0= */"));
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: "effeus47",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJpQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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: "effeus46",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkIwQiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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: "effeus45",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0NpQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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: "effeus44",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0RpQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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: "effeus43",
34
+ target: "effeus45",
34
35
  label: "ListCardTitle"
35
36
  })(process.env.NODE_ENV === "production" ? {
36
- name: "1ykowef",
37
- styles: "margin-bottom:0"
37
+ name: "rmz9aj",
38
+ styles: "margin-bottom:0;display:flex;justify-content:space-between"
38
39
  } : {
39
- name: "1ykowef",
40
- styles: "margin-bottom:0/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0QrQiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */",
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: "effeus42",
45
+ target: "effeus44",
45
46
  label: "CardHeading"
46
47
  })(process.env.NODE_ENV === "production" ? {
47
- name: "m483k0",
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: "m483k0",
51
- styles: "margin:0 0 2px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEQ2QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */",
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: "effeus41",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0UyQiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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: "effeus40",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vRW50cmllcy9FbnRyeUNhcmQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUY0QiIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9Db2xsZWN0aW9uL0VudHJpZXMvRW50cnlDYXJkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNvbm5lY3QgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgeyBMaW5rIH0gZnJvbSAncmVhY3Qtcm91dGVyLWRvbSc7XG5pbXBvcnQgeyBjb2xvcnMsIGNvbG9yc1JhdywgY29tcG9uZW50cywgbGVuZ3RocywgekluZGV4IH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBib3VuZEdldEFzc2V0IH0gZnJvbSAnLi4vLi4vLi4vYWN0aW9ucy9tZWRpYSc7XG5pbXBvcnQgeyBWSUVXX1NUWUxFX0xJU1QsIFZJRVdfU1RZTEVfR1JJRCB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cy9jb2xsZWN0aW9uVmlld3MnO1xuaW1wb3J0IHsgc2VsZWN0SXNMb2FkaW5nQXNzZXQgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9tZWRpYXMnO1xuaW1wb3J0IHsgc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUgfSBmcm9tICcuLi8uLi8uLi9yZWR1Y2Vycy9jb2xsZWN0aW9ucyc7XG5cbmNvbnN0IExpc3RDYXJkID0gc3R5bGVkLmxpYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAke2xlbmd0aHMudG9wQ2FyZFdpZHRofTtcbiAgbWFyZ2luLWxlZnQ6IDEycHg7XG4gIG1hcmdpbi1ib3R0b206IDEwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBMaXN0Q2FyZExpbmsgPSBzdHlsZWQoTGluaylgXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHBhZGRpbmc6IDE2cHggMjBweDtcblxuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5mb3JlZ3JvdW5kfTtcbiAgfVxuYDtcblxuY29uc3QgR3JpZENhcmQgPSBzdHlsZWQubGlgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgZmxleDogMCAwIDMzNXB4O1xuICBoZWlnaHQ6IDI0MHB4O1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBtYXJnaW4tbGVmdDogMTJweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XG5cbmNvbnN0IEdyaWRDYXJkTGluayA9IHN0eWxlZChMaW5rKWBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGhlaWdodDogMTAwJTtcbiAgb3V0bGluZS1vZmZzZXQ6IC0ycHg7XG5cbiAgJixcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuZm9yZWdyb3VuZH07XG4gICAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuICB9XG5gO1xuXG5jb25zdCBDb2xsZWN0aW9uTGFiZWwgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbiAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbmA7XG5cbmNvbnN0IExpc3RDYXJkVGl0bGUgPSBzdHlsZWQuaDJgXG4gIG1hcmdpbi1ib3R0b206IDA7XG5gO1xuXG5jb25zdCBDYXJkSGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgbWFyZ2luOiAwIDAgMnB4O1xuYDtcblxuY29uc3QgQ2FyZEJvZHkgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4IDIwcHg7XG4gIGhlaWdodDogOTBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tYm90dG9tOiAke3Byb3BzID0+IHByb3BzLmhhc0ltYWdlICYmIDB9O1xuXG4gICY6YWZ0ZXIge1xuICAgIGNvbnRlbnQ6ICcnO1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBkaXNwbGF5OiBibG9jaztcbiAgICB6LWluZGV4OiAke3pJbmRleC56SW5kZXgxfTtcbiAgICBib3R0b206IDA7XG4gICAgbGVmdDogLTIwJTtcbiAgICBoZWlnaHQ6IDE0MCU7XG4gICAgd2lkdGg6IDE0MCU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAtMTVweCAyNHB4ICR7Y29sb3JzUmF3LndoaXRlfTtcbiAgfVxuYDtcblxuY29uc3QgQ2FyZEltYWdlID0gc3R5bGVkLmRpdmBcbiAgYmFja2dyb3VuZC1pbWFnZTogdXJsKCR7cHJvcHMgPT4gcHJvcHMuc3JjfSk7XG4gIGJhY2tncm91bmQtcG9zaXRpb246IGNlbnRlciBjZW50ZXI7XG4gIGJhY2tncm91bmQtc2l6ZTogY292ZXI7XG4gIGJhY2tncm91bmQtcmVwZWF0OiBuby1yZXBlYXQ7XG4gIGhlaWdodDogMTUwcHg7XG5gO1xuXG5mdW5jdGlvbiBFbnRyeUNhcmQoe1xuICBwYXRoLFxuICBzdW1tYXJ5LFxuICBpbWFnZSxcbiAgaW1hZ2VGaWVsZCxcbiAgY29sbGVjdGlvbkxhYmVsLFxuICB2aWV3U3R5bGUgPSBWSUVXX1NUWUxFX0xJU1QsXG4gIGdldEFzc2V0LFxufSkge1xuICBpZiAodmlld1N0eWxlID09PSBWSUVXX1NUWUxFX0xJU1QpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPExpc3RDYXJkPlxuICAgICAgICA8TGlzdENhcmRMaW5rIHRvPXtwYXRofT5cbiAgICAgICAgICB7Y29sbGVjdGlvbkxhYmVsID8gPENvbGxlY3Rpb25MYWJlbD57Y29sbGVjdGlvbkxhYmVsfTwvQ29sbGVjdGlvbkxhYmVsPiA6IG51bGx9XG4gICAgICAgICAgPExpc3RDYXJkVGl0bGU+e3N1bW1hcnl9PC9MaXN0Q2FyZFRpdGxlPlxuICAgICAgICA8L0xpc3RDYXJkTGluaz5cbiAgICAgIDwvTGlzdENhcmQ+XG4gICAgKTtcbiAgfVxuXG4gIGlmICh2aWV3U3R5bGUgPT09IFZJRVdfU1RZTEVfR1JJRCkge1xuICAgIHJldHVybiAoXG4gICAgICA8R3JpZENhcmQ+XG4gICAgICAgIDxHcmlkQ2FyZExpbmsgdG89e3BhdGh9PlxuICAgICAgICAgIDxDYXJkQm9keSBoYXNJbWFnZT17aW1hZ2V9PlxuICAgICAgICAgICAge2NvbGxlY3Rpb25MYWJlbCA/IDxDb2xsZWN0aW9uTGFiZWw+e2NvbGxlY3Rpb25MYWJlbH08L0NvbGxlY3Rpb25MYWJlbD4gOiBudWxsfVxuICAgICAgICAgICAgPENhcmRIZWFkaW5nPntzdW1tYXJ5fTwvQ2FyZEhlYWRpbmc+XG4gICAgICAgICAgPC9DYXJkQm9keT5cbiAgICAgICAgICB7aW1hZ2UgPyA8Q2FyZEltYWdlIHNyYz17Z2V0QXNzZXQoaW1hZ2UsIGltYWdlRmllbGQpLnRvU3RyaW5nKCl9IC8+IDogbnVsbH1cbiAgICAgICAgPC9HcmlkQ2FyZExpbms+XG4gICAgICA8L0dyaWRDYXJkPlxuICAgICk7XG4gIH1cbn1cblxuZnVuY3Rpb24gbWFwU3RhdGVUb1Byb3BzKHN0YXRlLCBvd25Qcm9wcykge1xuICBjb25zdCB7IGVudHJ5LCBpbmZlcnJlZEZpZWxkcywgY29sbGVjdGlvbiB9ID0gb3duUHJvcHM7XG4gIGNvbnN0IGVudHJ5RGF0YSA9IGVudHJ5LmdldCgnZGF0YScpO1xuICBjb25zdCBzdW1tYXJ5ID0gc2VsZWN0RW50cnlDb2xsZWN0aW9uVGl0bGUoY29sbGVjdGlvbiwgZW50cnkpO1xuXG4gIGxldCBpbWFnZSA9IGVudHJ5RGF0YS5nZXQoaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCk7XG4gIGlmIChpbWFnZSkge1xuICAgIGltYWdlID0gZW5jb2RlVVJJKGltYWdlKTtcbiAgfVxuXG4gIGNvbnN0IGlzTG9hZGluZ0Fzc2V0ID0gc2VsZWN0SXNMb2FkaW5nQXNzZXQoc3RhdGUubWVkaWFzKTtcblxuICByZXR1cm4ge1xuICAgIHN1bW1hcnksXG4gICAgcGF0aDogYC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb24uZ2V0KCduYW1lJyl9L2VudHJpZXMvJHtlbnRyeS5nZXQoJ3NsdWcnKX1gLFxuICAgIGltYWdlLFxuICAgIGltYWdlRm9sZGVyOiBjb2xsZWN0aW9uXG4gICAgICAuZ2V0KCdmaWVsZHMnKVxuICAgICAgPy5maW5kKGYgPT4gZi5nZXQoJ25hbWUnKSA9PT0gaW5mZXJyZWRGaWVsZHMuaW1hZ2VGaWVsZCAmJiBmLmdldCgnd2lkZ2V0JykgPT09ICdpbWFnZScpLFxuICAgIGlzTG9hZGluZ0Fzc2V0LFxuICB9O1xufVxuXG5mdW5jdGlvbiBtYXBEaXNwYXRjaFRvUHJvcHMoZGlzcGF0Y2gpIHtcbiAgcmV0dXJuIHtcbiAgICBib3VuZEdldEFzc2V0OiAoY29sbGVjdGlvbiwgZW50cnkpID0+IGJvdW5kR2V0QXNzZXQoZGlzcGF0Y2gsIGNvbGxlY3Rpb24sIGVudHJ5KSxcbiAgfTtcbn1cblxuZnVuY3Rpb24gbWVyZ2VQcm9wcyhzdGF0ZVByb3BzLCBkaXNwYXRjaFByb3BzLCBvd25Qcm9wcykge1xuICByZXR1cm4ge1xuICAgIC4uLnN0YXRlUHJvcHMsXG4gICAgLi4uZGlzcGF0Y2hQcm9wcyxcbiAgICAuLi5vd25Qcm9wcyxcbiAgICBnZXRBc3NldDogZGlzcGF0Y2hQcm9wcy5ib3VuZEdldEFzc2V0KG93blByb3BzLmNvbGxlY3Rpb24sIG93blByb3BzLmVudHJ5KSxcbiAgfTtcbn1cblxuY29uc3QgQ29ubmVjdGVkRW50cnlDYXJkID0gY29ubmVjdChtYXBTdGF0ZVRvUHJvcHMsIG1hcERpc3BhdGNoVG9Qcm9wcywgbWVyZ2VQcm9wcykoRW50cnlDYXJkKTtcblxuZXhwb3J0IGRlZmF1bHQgQ29ubmVjdGVkRW50cnlDYXJkO1xuIl19 */"));
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
- getAsset
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)), image ? ___EmotionJSX(CardImage, {
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;