decap-cms-core 3.3.0 → 3.3.2

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.
@@ -40,7 +40,7 @@ const NodeTitleContainer = /*#__PURE__*/(0, _base.default)("div", {
40
40
  } : {
41
41
  name: "1vcob1d",
42
42
  styles: "display:flex;justify-content:center;align-items:center",
43
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAkBqC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
43
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAkBqC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
44
44
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
45
45
  });
46
46
  const NodeTitle = /*#__PURE__*/(0, _base.default)("div", {
@@ -52,7 +52,7 @@ const NodeTitle = /*#__PURE__*/(0, _base.default)("div", {
52
52
  } : {
53
53
  name: "qamjgr",
54
54
  styles: "margin-right:4px",
55
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAwB4B","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
55
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAwB4B","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
56
56
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
57
57
  });
58
58
  const Caret = /*#__PURE__*/(0, _base.default)("div", {
@@ -64,21 +64,21 @@ const Caret = /*#__PURE__*/(0, _base.default)("div", {
64
64
  } : {
65
65
  name: "1lo1a34",
66
66
  styles: "position:relative;top:2px",
67
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA4BwB","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
67
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA4BwB","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */",
68
68
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
69
69
  });
70
70
  const CaretDown = /*#__PURE__*/(0, _base.default)(Caret, {
71
71
  target: "eh84wlq2",
72
72
  label: "CaretDown"
73
- })(_decapCmsUiDefault.components.caretDown, ";color:currentColor;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAiC+B","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
73
+ })(_decapCmsUiDefault.components.caretDown, ";color:currentColor;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAiC+B","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
74
74
  const CaretRight = /*#__PURE__*/(0, _base.default)(Caret, {
75
75
  target: "eh84wlq1",
76
76
  label: "CaretRight"
77
- })(_decapCmsUiDefault.components.caretRight, ";color:currentColor;left:2px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAsCgC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
77
+ })(_decapCmsUiDefault.components.caretRight, ";color:currentColor;left:2px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AAsCgC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
78
78
  const TreeNavLink = /*#__PURE__*/(0, _base.default)(_reactRouterDom.NavLink, {
79
79
  target: "eh84wlq0",
80
80
  label: "TreeNavLink"
81
- })("display:flex;font-size:14px;font-weight:500;align-items:center;padding:8px;padding-left:", props => props.depth * 20 + 12, "px;border-left:2px solid #fff;", _decapCmsUiDefault.Icon, "{margin-right:8px;flex-shrink:0;}", props => /*#__PURE__*/(0, _react2.css)("&:hover,&:active,&.", props.activeClassName, "{color:", _decapCmsUiDefault.colors.active, ";background-color:", _decapCmsUiDefault.colors.activeBackground, ";border-left-color:#4863c6;};label:TreeNavLink;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA0DgB","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA4CmC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 20 + 12}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 8px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
81
+ })("display:flex;font-size:14px;font-weight:500;align-items:center;padding:8px;padding-left:", props => props.depth * 16 + 18, "px;border-left:2px solid #fff;", _decapCmsUiDefault.Icon, "{margin-right:4px;flex-shrink:0;}", props => /*#__PURE__*/(0, _react2.css)("&:hover,&:active,&.", props.activeClassName, "{color:", _decapCmsUiDefault.colors.active, ";background-color:", _decapCmsUiDefault.colors.activeBackground, ";border-left-color:#4863c6;};label:TreeNavLink;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA0DgB","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Collection/NestedCollection.js"],"names":[],"mappings":"AA4CmC","file":"../../../../src/components/Collection/NestedCollection.js","sourcesContent":["import React from 'react';\nimport { List } from 'immutable';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { connect } from 'react-redux';\nimport { NavLink } from 'react-router-dom';\nimport { dirname, sep } from 'path';\nimport { stringTemplate } from 'decap-cms-lib-widgets';\nimport { Icon, colors, components } from 'decap-cms-ui-default';\nimport PropTypes from 'prop-types';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport { sortBy } from 'lodash';\n\nimport { selectEntries } from '../../reducers/entries';\nimport { selectEntryCollectionTitle } from '../../reducers/collections';\n\nconst { addFileTemplateFields } = stringTemplate;\n\nconst NodeTitleContainer = styled.div`\n  display: flex;\n  justify-content: center;\n  align-items: center;\n`;\n\nconst NodeTitle = styled.div`\n  margin-right: 4px;\n`;\n\nconst Caret = styled.div`\n  position: relative;\n  top: 2px;\n`;\n\nconst CaretDown = styled(Caret)`\n  ${components.caretDown};\n  color: currentColor;\n`;\n\nconst CaretRight = styled(Caret)`\n  ${components.caretRight};\n  color: currentColor;\n  left: 2px;\n`;\n\nconst TreeNavLink = styled(NavLink)`\n  display: flex;\n  font-size: 14px;\n  font-weight: 500;\n  align-items: center;\n  padding: 8px;\n  padding-left: ${props => props.depth * 16 + 18}px;\n  border-left: 2px solid #fff;\n\n  ${Icon} {\n    margin-right: 4px;\n    flex-shrink: 0;\n  }\n\n  ${props => css`\n    &:hover,\n    &:active,\n    &.${props.activeClassName} {\n      color: ${colors.active};\n      background-color: ${colors.activeBackground};\n      border-left-color: #4863c6;\n    }\n  `};\n`;\n\nfunction getNodeTitle(node) {\n  const title = node.isRoot\n    ? node.title\n    : node.children.find(c => !c.isDir && c.title)?.title || node.title;\n  return title;\n}\n\nfunction TreeNode(props) {\n  const { collection, treeData, depth = 0, onToggle } = props;\n  const collectionName = collection.get('name');\n\n  const sortedData = sortBy(treeData, getNodeTitle);\n  return sortedData.map(node => {\n    const leaf = node.children.length <= 1 && !node.children[0]?.isDir && depth > 0;\n    if (leaf) {\n      return null;\n    }\n    let to = `/collections/${collectionName}`;\n    if (depth > 0) {\n      to = `${to}/filter${node.path}`;\n    }\n    const title = getNodeTitle(node);\n\n    const hasChildren = depth === 0 || node.children.some(c => c.children.some(c => c.isDir));\n\n    return (\n      <React.Fragment key={node.path}>\n        <TreeNavLink\n          exact\n          to={to}\n          activeClassName=\"sidebar-active\"\n          onClick={() => onToggle({ node, expanded: !node.expanded })}\n          depth={depth}\n          data-testid={node.path}\n        >\n          <Icon type=\"write\" />\n          <NodeTitleContainer>\n            <NodeTitle>{title}</NodeTitle>\n            {hasChildren && (node.expanded ? <CaretDown /> : <CaretRight />)}\n          </NodeTitleContainer>\n        </TreeNavLink>\n        {node.expanded && (\n          <TreeNode\n            collection={collection}\n            depth={depth + 1}\n            treeData={node.children}\n            onToggle={onToggle}\n          />\n        )}\n      </React.Fragment>\n    );\n  });\n}\n\nTreeNode.propTypes = {\n  collection: ImmutablePropTypes.map.isRequired,\n  depth: PropTypes.number,\n  treeData: PropTypes.array.isRequired,\n  onToggle: PropTypes.func.isRequired,\n};\n\nexport function walk(treeData, callback) {\n  function traverse(children) {\n    for (const child of children) {\n      callback(child);\n      traverse(child.children);\n    }\n  }\n\n  return traverse(treeData);\n}\n\nexport function getTreeData(collection, entries) {\n  const collectionFolder = collection.get('folder');\n  const rootFolder = '/';\n  const entriesObj = entries\n    .toJS()\n    .map(e => ({ ...e, path: e.path.slice(collectionFolder.length) }));\n\n  const dirs = entriesObj.reduce((acc, entry) => {\n    let dir = dirname(entry.path);\n    while (!acc[dir] && dir && dir !== rootFolder) {\n      const parts = dir.split(sep);\n      acc[dir] = parts.pop();\n      dir = parts.length && parts.join(sep);\n    }\n    return acc;\n  }, {});\n\n  if (collection.getIn(['nested', 'summary'])) {\n    collection = collection.set('summary', collection.getIn(['nested', 'summary']));\n  } else {\n    collection = collection.delete('summary');\n  }\n\n  const flatData = [\n    {\n      title: collection.get('label'),\n      path: rootFolder,\n      isDir: true,\n      isRoot: true,\n    },\n    ...Object.entries(dirs).map(([key, value]) => ({\n      title: value,\n      path: key,\n      isDir: true,\n      isRoot: false,\n    })),\n    ...entriesObj.map((e, index) => {\n      let entryMap = entries.get(index);\n      entryMap = entryMap.set(\n        'data',\n        addFileTemplateFields(entryMap.get('path'), entryMap.get('data')),\n      );\n      const title = selectEntryCollectionTitle(collection, entryMap);\n      return {\n        ...e,\n        title,\n        isDir: false,\n        isRoot: false,\n      };\n    }),\n  ];\n\n  const parentsToChildren = flatData.reduce((acc, node) => {\n    const parent = node.path === rootFolder ? '' : dirname(node.path);\n    if (acc[parent]) {\n      acc[parent].push(node);\n    } else {\n      acc[parent] = [node];\n    }\n    return acc;\n  }, {});\n\n  function reducer(acc, value) {\n    const node = value;\n    let children = [];\n    if (parentsToChildren[node.path]) {\n      children = parentsToChildren[node.path].reduce(reducer, []);\n    }\n\n    acc.push({ ...node, children });\n    return acc;\n  }\n\n  const treeData = parentsToChildren[''].reduce(reducer, []);\n\n  return treeData;\n}\n\nexport function updateNode(treeData, node, callback) {\n  let stop = false;\n\n  function updater(nodes) {\n    if (stop) {\n      return nodes;\n    }\n    for (let i = 0; i < nodes.length; i++) {\n      if (nodes[i].path === node.path) {\n        nodes[i] = callback(node);\n        stop = true;\n        return nodes;\n      }\n    }\n    nodes.forEach(node => updater(node.children));\n    return nodes;\n  }\n\n  return updater([...treeData]);\n}\n\nexport class NestedCollection extends React.Component {\n  static propTypes = {\n    collection: ImmutablePropTypes.map.isRequired,\n    entries: ImmutablePropTypes.list.isRequired,\n    filterTerm: PropTypes.string,\n  };\n\n  constructor(props) {\n    super(props);\n    this.state = {\n      treeData: getTreeData(this.props.collection, this.props.entries),\n      selected: null,\n      useFilter: true,\n    };\n  }\n\n  componentDidUpdate(prevProps) {\n    const { collection, entries, filterTerm } = this.props;\n    if (\n      collection !== prevProps.collection ||\n      entries !== prevProps.entries ||\n      filterTerm !== prevProps.filterTerm\n    ) {\n      const expanded = {};\n      walk(this.state.treeData, node => {\n        if (node.expanded) {\n          expanded[node.path] = true;\n        }\n      });\n      const treeData = getTreeData(collection, entries);\n\n      const path = `/${filterTerm}`;\n      walk(treeData, node => {\n        if (expanded[node.path] || (this.state.useFilter && path.startsWith(node.path))) {\n          node.expanded = true;\n        }\n      });\n      this.setState({ treeData });\n    }\n  }\n\n  onToggle = ({ node, expanded }) => {\n    if (!this.state.selected || this.state.selected.path === node.path || expanded) {\n      const treeData = updateNode(this.state.treeData, node, node => ({\n        ...node,\n        expanded,\n      }));\n      this.setState({ treeData, selected: node, useFilter: false });\n    } else {\n      // don't collapse non selected nodes when clicked\n      this.setState({ selected: node, useFilter: false });\n    }\n  };\n\n  render() {\n    const { treeData } = this.state;\n    const { collection } = this.props;\n\n    return <TreeNode collection={collection} treeData={treeData} onToggle={this.onToggle} />;\n  }\n}\n\nfunction mapStateToProps(state, ownProps) {\n  const { collection } = ownProps;\n  const entries = selectEntries(state.entries, collection) || List();\n  return { entries };\n}\n\nexport default connect(mapStateToProps, null)(NestedCollection);\n"]} */"));
82
82
  function getNodeTitle(node) {
83
83
  var _node$children$find;
84
84
  const title = node.isRoot ? node.title : ((_node$children$find = node.children.find(c => !c.isDir && c.title)) === null || _node$children$find === void 0 ? void 0 : _node$children$find.title) || node.title;
@@ -21,32 +21,32 @@ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typ
21
21
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
22
22
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
23
23
  const styles = {
24
- sidebarNavLinkActive: /*#__PURE__*/(0, _react2.css)("color:", _decapCmsUiDefault.colors.active, ";background-color:", _decapCmsUiDefault.colors.activeBackground, ";border-left-color:#4863c6;;label:sidebarNavLinkActive;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjMkIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQ29sbGVjdGlvbi9TaWRlYmFyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgSW1tdXRhYmxlUHJvcFR5cGVzIGZyb20gJ3JlYWN0LWltbXV0YWJsZS1wcm9wdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdHJhbnNsYXRlIH0gZnJvbSAncmVhY3QtcG9seWdsb3QnO1xuaW1wb3J0IHsgTmF2TGluayB9IGZyb20gJ3JlYWN0LXJvdXRlci1kb20nO1xuaW1wb3J0IHsgSWNvbiwgY29tcG9uZW50cywgY29sb3JzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBzZWFyY2hDb2xsZWN0aW9ucyB9IGZyb20gJy4uLy4uL2FjdGlvbnMvY29sbGVjdGlvbnMnO1xuaW1wb3J0IENvbGxlY3Rpb25TZWFyY2ggZnJvbSAnLi9Db2xsZWN0aW9uU2VhcmNoJztcbmltcG9ydCBOZXN0ZWRDb2xsZWN0aW9uIGZyb20gJy4vTmVzdGVkQ29sbGVjdGlvbic7XG5cbmNvbnN0IHN0eWxlcyA9IHtcbiAgc2lkZWJhck5hdkxpbmtBY3RpdmU6IGNzc2BcbiAgICBjb2xvcjogJHtjb2xvcnMuYWN0aXZlfTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5hY3RpdmVCYWNrZ3JvdW5kfTtcbiAgICBib3JkZXItbGVmdC1jb2xvcjogIzQ4NjNjNjtcbiAgYCxcbn07XG5cbmNvbnN0IFNpZGViYXJDb250YWluZXIgPSBzdHlsZWQuYXNpZGVgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgd2lkdGg6IDI1MHB4O1xuICBwYWRkaW5nOiA4cHggMCAxMnB4O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIG1heC1oZWlnaHQ6IGNhbGMoMTAwdmggLSAxMTJweCk7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG5gO1xuXG5jb25zdCBTaWRlYmFySGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgZm9udC1zaXplOiAyM3B4O1xuICBmb250LXdlaWdodDogNjAwO1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDE4cHggMTJweCAxMnB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTZweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDEycHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA4cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */"))
24
+ sidebarNavLinkActive: /*#__PURE__*/(0, _react2.css)("color:", _decapCmsUiDefault.colors.active, ";background-color:", _decapCmsUiDefault.colors.activeBackground, ";border-left-color:#4863c6;;label:sidebarNavLinkActive;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjMkIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvQ29sbGVjdGlvbi9TaWRlYmFyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgSW1tdXRhYmxlUHJvcFR5cGVzIGZyb20gJ3JlYWN0LWltbXV0YWJsZS1wcm9wdHlwZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgdHJhbnNsYXRlIH0gZnJvbSAncmVhY3QtcG9seWdsb3QnO1xuaW1wb3J0IHsgTmF2TGluayB9IGZyb20gJ3JlYWN0LXJvdXRlci1kb20nO1xuaW1wb3J0IHsgSWNvbiwgY29tcG9uZW50cywgY29sb3JzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgeyBzZWFyY2hDb2xsZWN0aW9ucyB9IGZyb20gJy4uLy4uL2FjdGlvbnMvY29sbGVjdGlvbnMnO1xuaW1wb3J0IENvbGxlY3Rpb25TZWFyY2ggZnJvbSAnLi9Db2xsZWN0aW9uU2VhcmNoJztcbmltcG9ydCBOZXN0ZWRDb2xsZWN0aW9uIGZyb20gJy4vTmVzdGVkQ29sbGVjdGlvbic7XG5cbmNvbnN0IHN0eWxlcyA9IHtcbiAgc2lkZWJhck5hdkxpbmtBY3RpdmU6IGNzc2BcbiAgICBjb2xvcjogJHtjb2xvcnMuYWN0aXZlfTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5hY3RpdmVCYWNrZ3JvdW5kfTtcbiAgICBib3JkZXItbGVmdC1jb2xvcjogIzQ4NjNjNjtcbiAgYCxcbn07XG5cbmNvbnN0IFNpZGViYXJDb250YWluZXIgPSBzdHlsZWQuYXNpZGVgXG4gICR7Y29tcG9uZW50cy5jYXJkfTtcbiAgd2lkdGg6IDI1MHB4O1xuICBwYWRkaW5nOiA4cHggMCAxMnB4O1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIG1heC1oZWlnaHQ6IGNhbGMoMTAwdmggLSAxMTJweCk7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG5gO1xuXG5jb25zdCBTaWRlYmFySGVhZGluZyA9IHN0eWxlZC5oMmBcbiAgZm9udC1zaXplOiAyMnB4O1xuICBmb250LXdlaWdodDogNjAwO1xuICBsaW5lLWhlaWdodDogMzdweDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxMHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0TGVhZH07XG5gO1xuXG5jb25zdCBTaWRlYmFyTmF2TGlzdCA9IHN0eWxlZC51bGBcbiAgbWFyZ2luOiAxMnB4IDAgMDtcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgb3ZlcmZsb3c6IGF1dG87XG5gO1xuXG5jb25zdCBTaWRlYmFyTmF2TGluayA9IHN0eWxlZChOYXZMaW5rKWBcbiAgZGlzcGxheTogZmxleDtcbiAgZm9udC1zaXplOiAxNHB4O1xuICBmb250LXdlaWdodDogNTAwO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA4cHggMThweDtcbiAgYm9yZGVyLWxlZnQ6IDJweCBzb2xpZCAjZmZmO1xuICB6LWluZGV4OiAtMTtcblxuICAke0ljb259IHtcbiAgICBtYXJnaW4tcmlnaHQ6IDRweDtcbiAgICBmbGV4LXNocmluazogMDtcbiAgfVxuXG4gICR7cHJvcHMgPT4gY3NzYFxuICAgICY6aG92ZXIsXG4gICAgJjphY3RpdmUsXG4gICAgJi4ke3Byb3BzLmFjdGl2ZUNsYXNzTmFtZX0ge1xuICAgICAgJHtzdHlsZXMuc2lkZWJhck5hdkxpbmtBY3RpdmV9O1xuICAgIH1cbiAgYH07XG5gO1xuXG5leHBvcnQgY2xhc3MgU2lkZWJhciBleHRlbmRzIFJlYWN0LkNvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgY29sbGVjdGlvbnM6IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICBjb2xsZWN0aW9uOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLFxuICAgIGlzU2VhcmNoRW5hYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gICAgc2VhcmNoVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICBmaWx0ZXJUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLmlzUmVxdWlyZWQsXG4gIH07XG5cbiAgcmVuZGVyTGluayA9IChjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSA9PiB7XG4gICAgY29uc3QgY29sbGVjdGlvbk5hbWUgPSBjb2xsZWN0aW9uLmdldCgnbmFtZScpO1xuICAgIGlmIChjb2xsZWN0aW9uLmhhcygnbmVzdGVkJykpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgICA8TmVzdGVkQ29sbGVjdGlvblxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIGZpbHRlclRlcm09e2ZpbHRlclRlcm19XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9saT5cbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiAoXG4gICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgIDxTaWRlYmFyTmF2TGlua1xuICAgICAgICAgIHRvPXtgL2NvbGxlY3Rpb25zLyR7Y29sbGVjdGlvbk5hbWV9YH1cbiAgICAgICAgICBhY3RpdmVDbGFzc05hbWU9XCJzaWRlYmFyLWFjdGl2ZVwiXG4gICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICA+XG4gICAgICAgICAgPEljb24gdHlwZT1cIndyaXRlXCIgLz5cbiAgICAgICAgICB7Y29sbGVjdGlvbi5nZXQoJ2xhYmVsJyl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpbms+XG4gICAgICA8L2xpPlxuICAgICk7XG4gIH07XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IHsgY29sbGVjdGlvbnMsIGNvbGxlY3Rpb24sIGlzU2VhcmNoRW5hYmxlZCwgc2VhcmNoVGVybSwgdCwgZmlsdGVyVGVybSB9ID0gdGhpcy5wcm9wcztcbiAgICByZXR1cm4gKFxuICAgICAgPFNpZGViYXJDb250YWluZXI+XG4gICAgICAgIDxTaWRlYmFySGVhZGluZz57dCgnY29sbGVjdGlvbi5zaWRlYmFyLmNvbGxlY3Rpb25zJyl9PC9TaWRlYmFySGVhZGluZz5cbiAgICAgICAge2lzU2VhcmNoRW5hYmxlZCAmJiAoXG4gICAgICAgICAgPENvbGxlY3Rpb25TZWFyY2hcbiAgICAgICAgICAgIHNlYXJjaFRlcm09e3NlYXJjaFRlcm19XG4gICAgICAgICAgICBjb2xsZWN0aW9ucz17Y29sbGVjdGlvbnN9XG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgb25TdWJtaXQ9eyhxdWVyeSwgY29sbGVjdGlvbikgPT4gc2VhcmNoQ29sbGVjdGlvbnMocXVlcnksIGNvbGxlY3Rpb24pfVxuICAgICAgICAgIC8+XG4gICAgICAgICl9XG4gICAgICAgIDxTaWRlYmFyTmF2TGlzdD5cbiAgICAgICAgICB7Y29sbGVjdGlvbnNcbiAgICAgICAgICAgIC50b0xpc3QoKVxuICAgICAgICAgICAgLmZpbHRlcihjb2xsZWN0aW9uID0+IGNvbGxlY3Rpb24uZ2V0KCdoaWRlJykgIT09IHRydWUpXG4gICAgICAgICAgICAubWFwKGNvbGxlY3Rpb24gPT4gdGhpcy5yZW5kZXJMaW5rKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGlzdD5cbiAgICAgIDwvU2lkZWJhckNvbnRhaW5lcj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IHRyYW5zbGF0ZSgpKFNpZGViYXIpO1xuIl19 */"))
25
25
  };
26
26
  const SidebarContainer = /*#__PURE__*/(0, _base.default)("aside", {
27
27
  target: "e1t18l343",
28
28
  label: "SidebarContainer"
29
- })(_decapCmsUiDefault.components.card, ";width:250px;padding:8px 0 12px;position:fixed;max-height:calc(100vh - 112px);display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnFDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjNweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxOHB4IDEycHggMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaXN0ID0gc3R5bGVkLnVsYFxuICBtYXJnaW46IDE2cHggMCAwO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaW5rID0gc3R5bGVkKE5hdkxpbmspYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6IDE0cHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDhweCAxMnB4O1xuICBib3JkZXItbGVmdDogMnB4IHNvbGlkICNmZmY7XG4gIHotaW5kZXg6IC0xO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgIGZsZXgtc2hyaW5rOiAwO1xuICB9XG5cbiAgJHtwcm9wcyA9PiBjc3NgXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSxcbiAgICAmLiR7cHJvcHMuYWN0aXZlQ2xhc3NOYW1lfSB7XG4gICAgICAke3N0eWxlcy5zaWRlYmFyTmF2TGlua0FjdGl2ZX07XG4gICAgfVxuICBgfTtcbmA7XG5cbmV4cG9ydCBjbGFzcyBTaWRlYmFyIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjb2xsZWN0aW9uczogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAsXG4gICAgaXNTZWFyY2hFbmFibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBzZWFyY2hUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGZpbHRlclRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZW5kZXJMaW5rID0gKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pID0+IHtcbiAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGNvbGxlY3Rpb24uZ2V0KCduYW1lJyk7XG4gICAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICAgIDxOZXN0ZWRDb2xsZWN0aW9uXG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2xpPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIChcbiAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgPFNpZGViYXJOYXZMaW5rXG4gICAgICAgICAgdG89e2AvY29sbGVjdGlvbnMvJHtjb2xsZWN0aW9uTmFtZX1gfVxuICAgICAgICAgIGFjdGl2ZUNsYXNzTmFtZT1cInNpZGViYXItYWN0aXZlXCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8SWNvbiB0eXBlPVwid3JpdGVcIiAvPlxuICAgICAgICAgIHtjb2xsZWN0aW9uLmdldCgnbGFiZWwnKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGluaz5cbiAgICAgIDwvbGk+XG4gICAgKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9ucywgY29sbGVjdGlvbiwgaXNTZWFyY2hFbmFibGVkLCBzZWFyY2hUZXJtLCB0LCBmaWx0ZXJUZXJtIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICA8U2lkZWJhckNvbnRhaW5lcj5cbiAgICAgICAgPFNpZGViYXJIZWFkaW5nPnt0KCdjb2xsZWN0aW9uLnNpZGViYXIuY29sbGVjdGlvbnMnKX08L1NpZGViYXJIZWFkaW5nPlxuICAgICAgICB7aXNTZWFyY2hFbmFibGVkICYmIChcbiAgICAgICAgICA8Q29sbGVjdGlvblNlYXJjaFxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBvblN1Ym1pdD17KHF1ZXJ5LCBjb2xsZWN0aW9uKSA9PiBzZWFyY2hDb2xsZWN0aW9ucyhxdWVyeSwgY29sbGVjdGlvbil9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgPFNpZGViYXJOYXZMaXN0PlxuICAgICAgICAgIHtjb2xsZWN0aW9uc1xuICAgICAgICAgICAgLnRvTGlzdCgpXG4gICAgICAgICAgICAuZmlsdGVyKGNvbGxlY3Rpb24gPT4gY29sbGVjdGlvbi5nZXQoJ2hpZGUnKSAhPT0gdHJ1ZSlcbiAgICAgICAgICAgIC5tYXAoY29sbGVjdGlvbiA9PiB0aGlzLnJlbmRlckxpbmsoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaXN0PlxuICAgICAgPC9TaWRlYmFyQ29udGFpbmVyPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoU2lkZWJhcik7XG4iXX0= */"));
29
+ })(_decapCmsUiDefault.components.card, ";width:250px;padding:8px 0 12px;position:fixed;max-height:calc(100vh - 112px);display:flex;flex-direction:column;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQnFDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMTBweCAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTJweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDE4cHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */"));
30
30
  const SidebarHeading = /*#__PURE__*/(0, _base.default)("h2", {
31
31
  target: "e1t18l342",
32
32
  label: "SidebarHeading"
33
- })("font-size:23px;font-weight:600;padding:0;margin:18px 12px 12px;color:", _decapCmsUiDefault.colors.textLead, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmdDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjNweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxOHB4IDEycHggMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaXN0ID0gc3R5bGVkLnVsYFxuICBtYXJnaW46IDE2cHggMCAwO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaW5rID0gc3R5bGVkKE5hdkxpbmspYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6IDE0cHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDhweCAxMnB4O1xuICBib3JkZXItbGVmdDogMnB4IHNvbGlkICNmZmY7XG4gIHotaW5kZXg6IC0xO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgIGZsZXgtc2hyaW5rOiAwO1xuICB9XG5cbiAgJHtwcm9wcyA9PiBjc3NgXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSxcbiAgICAmLiR7cHJvcHMuYWN0aXZlQ2xhc3NOYW1lfSB7XG4gICAgICAke3N0eWxlcy5zaWRlYmFyTmF2TGlua0FjdGl2ZX07XG4gICAgfVxuICBgfTtcbmA7XG5cbmV4cG9ydCBjbGFzcyBTaWRlYmFyIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjb2xsZWN0aW9uczogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAsXG4gICAgaXNTZWFyY2hFbmFibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBzZWFyY2hUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGZpbHRlclRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZW5kZXJMaW5rID0gKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pID0+IHtcbiAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGNvbGxlY3Rpb24uZ2V0KCduYW1lJyk7XG4gICAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICAgIDxOZXN0ZWRDb2xsZWN0aW9uXG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2xpPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIChcbiAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgPFNpZGViYXJOYXZMaW5rXG4gICAgICAgICAgdG89e2AvY29sbGVjdGlvbnMvJHtjb2xsZWN0aW9uTmFtZX1gfVxuICAgICAgICAgIGFjdGl2ZUNsYXNzTmFtZT1cInNpZGViYXItYWN0aXZlXCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8SWNvbiB0eXBlPVwid3JpdGVcIiAvPlxuICAgICAgICAgIHtjb2xsZWN0aW9uLmdldCgnbGFiZWwnKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGluaz5cbiAgICAgIDwvbGk+XG4gICAgKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9ucywgY29sbGVjdGlvbiwgaXNTZWFyY2hFbmFibGVkLCBzZWFyY2hUZXJtLCB0LCBmaWx0ZXJUZXJtIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICA8U2lkZWJhckNvbnRhaW5lcj5cbiAgICAgICAgPFNpZGViYXJIZWFkaW5nPnt0KCdjb2xsZWN0aW9uLnNpZGViYXIuY29sbGVjdGlvbnMnKX08L1NpZGViYXJIZWFkaW5nPlxuICAgICAgICB7aXNTZWFyY2hFbmFibGVkICYmIChcbiAgICAgICAgICA8Q29sbGVjdGlvblNlYXJjaFxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBvblN1Ym1pdD17KHF1ZXJ5LCBjb2xsZWN0aW9uKSA9PiBzZWFyY2hDb2xsZWN0aW9ucyhxdWVyeSwgY29sbGVjdGlvbil9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgPFNpZGViYXJOYXZMaXN0PlxuICAgICAgICAgIHtjb2xsZWN0aW9uc1xuICAgICAgICAgICAgLnRvTGlzdCgpXG4gICAgICAgICAgICAuZmlsdGVyKGNvbGxlY3Rpb24gPT4gY29sbGVjdGlvbi5nZXQoJ2hpZGUnKSAhPT0gdHJ1ZSlcbiAgICAgICAgICAgIC5tYXAoY29sbGVjdGlvbiA9PiB0aGlzLnJlbmRlckxpbmsoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaXN0PlxuICAgICAgPC9TaWRlYmFyQ29udGFpbmVyPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoU2lkZWJhcik7XG4iXX0= */"));
33
+ })("font-size:22px;font-weight:600;line-height:37px;padding:0;margin:10px 20px;color:", _decapCmsUiDefault.colors.textLead, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQmdDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMTBweCAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTJweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDE4cHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */"));
34
34
  const SidebarNavList = /*#__PURE__*/(0, _base.default)("ul", {
35
35
  target: "e1t18l341",
36
36
  label: "SidebarNavList"
37
37
  })(process.env.NODE_ENV === "production" ? {
38
- name: "nljgb7",
39
- styles: "margin:16px 0 0;list-style:none;overflow:auto"
38
+ name: "14vcqsr",
39
+ styles: "margin:12px 0 0;list-style:none;overflow:auto"
40
40
  } : {
41
- name: "nljgb7",
42
- styles: "margin:16px 0 0;list-style:none;overflow:auto",
43
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1Q2dDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjNweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxOHB4IDEycHggMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaXN0ID0gc3R5bGVkLnVsYFxuICBtYXJnaW46IDE2cHggMCAwO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaW5rID0gc3R5bGVkKE5hdkxpbmspYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6IDE0cHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDhweCAxMnB4O1xuICBib3JkZXItbGVmdDogMnB4IHNvbGlkICNmZmY7XG4gIHotaW5kZXg6IC0xO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgIGZsZXgtc2hyaW5rOiAwO1xuICB9XG5cbiAgJHtwcm9wcyA9PiBjc3NgXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSxcbiAgICAmLiR7cHJvcHMuYWN0aXZlQ2xhc3NOYW1lfSB7XG4gICAgICAke3N0eWxlcy5zaWRlYmFyTmF2TGlua0FjdGl2ZX07XG4gICAgfVxuICBgfTtcbmA7XG5cbmV4cG9ydCBjbGFzcyBTaWRlYmFyIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjb2xsZWN0aW9uczogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAsXG4gICAgaXNTZWFyY2hFbmFibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBzZWFyY2hUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGZpbHRlclRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZW5kZXJMaW5rID0gKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pID0+IHtcbiAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGNvbGxlY3Rpb24uZ2V0KCduYW1lJyk7XG4gICAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICAgIDxOZXN0ZWRDb2xsZWN0aW9uXG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2xpPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIChcbiAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgPFNpZGViYXJOYXZMaW5rXG4gICAgICAgICAgdG89e2AvY29sbGVjdGlvbnMvJHtjb2xsZWN0aW9uTmFtZX1gfVxuICAgICAgICAgIGFjdGl2ZUNsYXNzTmFtZT1cInNpZGViYXItYWN0aXZlXCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8SWNvbiB0eXBlPVwid3JpdGVcIiAvPlxuICAgICAgICAgIHtjb2xsZWN0aW9uLmdldCgnbGFiZWwnKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGluaz5cbiAgICAgIDwvbGk+XG4gICAgKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9ucywgY29sbGVjdGlvbiwgaXNTZWFyY2hFbmFibGVkLCBzZWFyY2hUZXJtLCB0LCBmaWx0ZXJUZXJtIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICA8U2lkZWJhckNvbnRhaW5lcj5cbiAgICAgICAgPFNpZGViYXJIZWFkaW5nPnt0KCdjb2xsZWN0aW9uLnNpZGViYXIuY29sbGVjdGlvbnMnKX08L1NpZGViYXJIZWFkaW5nPlxuICAgICAgICB7aXNTZWFyY2hFbmFibGVkICYmIChcbiAgICAgICAgICA8Q29sbGVjdGlvblNlYXJjaFxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBvblN1Ym1pdD17KHF1ZXJ5LCBjb2xsZWN0aW9uKSA9PiBzZWFyY2hDb2xsZWN0aW9ucyhxdWVyeSwgY29sbGVjdGlvbil9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgPFNpZGViYXJOYXZMaXN0PlxuICAgICAgICAgIHtjb2xsZWN0aW9uc1xuICAgICAgICAgICAgLnRvTGlzdCgpXG4gICAgICAgICAgICAuZmlsdGVyKGNvbGxlY3Rpb24gPT4gY29sbGVjdGlvbi5nZXQoJ2hpZGUnKSAhPT0gdHJ1ZSlcbiAgICAgICAgICAgIC5tYXAoY29sbGVjdGlvbiA9PiB0aGlzLnJlbmRlckxpbmsoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaXN0PlxuICAgICAgPC9TaWRlYmFyQ29udGFpbmVyPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoU2lkZWJhcik7XG4iXX0= */",
41
+ name: "14vcqsr",
42
+ styles: "margin:12px 0 0;list-style:none;overflow:auto",
43
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3Q2dDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMTBweCAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTJweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDE4cHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */",
44
44
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
45
45
  });
46
46
  const SidebarNavLink = /*#__PURE__*/(0, _base.default)(_reactRouterDom.NavLink, {
47
47
  target: "e1t18l340",
48
48
  label: "SidebarNavLink"
49
- })("display:flex;font-size:14px;font-weight:500;align-items:center;padding:8px 12px;border-left:2px solid #fff;z-index:-1;", _decapCmsUiDefault.Icon, "{margin-right:8px;flex-shrink:0;}", props => /*#__PURE__*/(0, _react2.css)("&:hover,&:active,&.", props.activeClassName, "{", styles.sidebarNavLinkActive, ";};label:SidebarNavLink;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyRGdCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjNweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxOHB4IDEycHggMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaXN0ID0gc3R5bGVkLnVsYFxuICBtYXJnaW46IDE2cHggMCAwO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaW5rID0gc3R5bGVkKE5hdkxpbmspYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6IDE0cHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDhweCAxMnB4O1xuICBib3JkZXItbGVmdDogMnB4IHNvbGlkICNmZmY7XG4gIHotaW5kZXg6IC0xO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgIGZsZXgtc2hyaW5rOiAwO1xuICB9XG5cbiAgJHtwcm9wcyA9PiBjc3NgXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSxcbiAgICAmLiR7cHJvcHMuYWN0aXZlQ2xhc3NOYW1lfSB7XG4gICAgICAke3N0eWxlcy5zaWRlYmFyTmF2TGlua0FjdGl2ZX07XG4gICAgfVxuICBgfTtcbmA7XG5cbmV4cG9ydCBjbGFzcyBTaWRlYmFyIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjb2xsZWN0aW9uczogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAsXG4gICAgaXNTZWFyY2hFbmFibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBzZWFyY2hUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGZpbHRlclRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZW5kZXJMaW5rID0gKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pID0+IHtcbiAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGNvbGxlY3Rpb24uZ2V0KCduYW1lJyk7XG4gICAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICAgIDxOZXN0ZWRDb2xsZWN0aW9uXG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2xpPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIChcbiAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgPFNpZGViYXJOYXZMaW5rXG4gICAgICAgICAgdG89e2AvY29sbGVjdGlvbnMvJHtjb2xsZWN0aW9uTmFtZX1gfVxuICAgICAgICAgIGFjdGl2ZUNsYXNzTmFtZT1cInNpZGViYXItYWN0aXZlXCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8SWNvbiB0eXBlPVwid3JpdGVcIiAvPlxuICAgICAgICAgIHtjb2xsZWN0aW9uLmdldCgnbGFiZWwnKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGluaz5cbiAgICAgIDwvbGk+XG4gICAgKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9ucywgY29sbGVjdGlvbiwgaXNTZWFyY2hFbmFibGVkLCBzZWFyY2hUZXJtLCB0LCBmaWx0ZXJUZXJtIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICA8U2lkZWJhckNvbnRhaW5lcj5cbiAgICAgICAgPFNpZGViYXJIZWFkaW5nPnt0KCdjb2xsZWN0aW9uLnNpZGViYXIuY29sbGVjdGlvbnMnKX08L1NpZGViYXJIZWFkaW5nPlxuICAgICAgICB7aXNTZWFyY2hFbmFibGVkICYmIChcbiAgICAgICAgICA8Q29sbGVjdGlvblNlYXJjaFxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBvblN1Ym1pdD17KHF1ZXJ5LCBjb2xsZWN0aW9uKSA9PiBzZWFyY2hDb2xsZWN0aW9ucyhxdWVyeSwgY29sbGVjdGlvbil9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgPFNpZGViYXJOYXZMaXN0PlxuICAgICAgICAgIHtjb2xsZWN0aW9uc1xuICAgICAgICAgICAgLnRvTGlzdCgpXG4gICAgICAgICAgICAuZmlsdGVyKGNvbGxlY3Rpb24gPT4gY29sbGVjdGlvbi5nZXQoJ2hpZGUnKSAhPT0gdHJ1ZSlcbiAgICAgICAgICAgIC5tYXAoY29sbGVjdGlvbiA9PiB0aGlzLnJlbmRlckxpbmsoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaXN0PlxuICAgICAgPC9TaWRlYmFyQ29udGFpbmVyPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoU2lkZWJhcik7XG4iXX0= */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Q3NDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjNweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgcGFkZGluZzogMDtcbiAgbWFyZ2luOiAxOHB4IDEycHggMTJweDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHRMZWFkfTtcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaXN0ID0gc3R5bGVkLnVsYFxuICBtYXJnaW46IDE2cHggMCAwO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICBvdmVyZmxvdzogYXV0bztcbmA7XG5cbmNvbnN0IFNpZGViYXJOYXZMaW5rID0gc3R5bGVkKE5hdkxpbmspYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmb250LXNpemU6IDE0cHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDhweCAxMnB4O1xuICBib3JkZXItbGVmdDogMnB4IHNvbGlkICNmZmY7XG4gIHotaW5kZXg6IC0xO1xuXG4gICR7SWNvbn0ge1xuICAgIG1hcmdpbi1yaWdodDogOHB4O1xuICAgIGZsZXgtc2hyaW5rOiAwO1xuICB9XG5cbiAgJHtwcm9wcyA9PiBjc3NgXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSxcbiAgICAmLiR7cHJvcHMuYWN0aXZlQ2xhc3NOYW1lfSB7XG4gICAgICAke3N0eWxlcy5zaWRlYmFyTmF2TGlua0FjdGl2ZX07XG4gICAgfVxuICBgfTtcbmA7XG5cbmV4cG9ydCBjbGFzcyBTaWRlYmFyIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50IHtcbiAgc3RhdGljIHByb3BUeXBlcyA9IHtcbiAgICBjb2xsZWN0aW9uczogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAsXG4gICAgaXNTZWFyY2hFbmFibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgICBzZWFyY2hUZXJtOiBQcm9wVHlwZXMuc3RyaW5nLFxuICAgIGZpbHRlclRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgfTtcblxuICByZW5kZXJMaW5rID0gKGNvbGxlY3Rpb24sIGZpbHRlclRlcm0pID0+IHtcbiAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IGNvbGxlY3Rpb24uZ2V0KCduYW1lJyk7XG4gICAgaWYgKGNvbGxlY3Rpb24uaGFzKCduZXN0ZWQnKSkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICAgIDxOZXN0ZWRDb2xsZWN0aW9uXG4gICAgICAgICAgICBjb2xsZWN0aW9uPXtjb2xsZWN0aW9ufVxuICAgICAgICAgICAgZmlsdGVyVGVybT17ZmlsdGVyVGVybX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2xpPlxuICAgICAgKTtcbiAgICB9XG4gICAgcmV0dXJuIChcbiAgICAgIDxsaSBrZXk9e2NvbGxlY3Rpb25OYW1lfT5cbiAgICAgICAgPFNpZGViYXJOYXZMaW5rXG4gICAgICAgICAgdG89e2AvY29sbGVjdGlvbnMvJHtjb2xsZWN0aW9uTmFtZX1gfVxuICAgICAgICAgIGFjdGl2ZUNsYXNzTmFtZT1cInNpZGViYXItYWN0aXZlXCJcbiAgICAgICAgICBkYXRhLXRlc3RpZD17Y29sbGVjdGlvbk5hbWV9XG4gICAgICAgID5cbiAgICAgICAgICA8SWNvbiB0eXBlPVwid3JpdGVcIiAvPlxuICAgICAgICAgIHtjb2xsZWN0aW9uLmdldCgnbGFiZWwnKX1cbiAgICAgICAgPC9TaWRlYmFyTmF2TGluaz5cbiAgICAgIDwvbGk+XG4gICAgKTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBjb2xsZWN0aW9ucywgY29sbGVjdGlvbiwgaXNTZWFyY2hFbmFibGVkLCBzZWFyY2hUZXJtLCB0LCBmaWx0ZXJUZXJtIH0gPSB0aGlzLnByb3BzO1xuICAgIHJldHVybiAoXG4gICAgICA8U2lkZWJhckNvbnRhaW5lcj5cbiAgICAgICAgPFNpZGViYXJIZWFkaW5nPnt0KCdjb2xsZWN0aW9uLnNpZGViYXIuY29sbGVjdGlvbnMnKX08L1NpZGViYXJIZWFkaW5nPlxuICAgICAgICB7aXNTZWFyY2hFbmFibGVkICYmIChcbiAgICAgICAgICA8Q29sbGVjdGlvblNlYXJjaFxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGNvbGxlY3Rpb25zPXtjb2xsZWN0aW9uc31cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBvblN1Ym1pdD17KHF1ZXJ5LCBjb2xsZWN0aW9uKSA9PiBzZWFyY2hDb2xsZWN0aW9ucyhxdWVyeSwgY29sbGVjdGlvbil9XG4gICAgICAgICAgLz5cbiAgICAgICAgKX1cbiAgICAgICAgPFNpZGViYXJOYXZMaXN0PlxuICAgICAgICAgIHtjb2xsZWN0aW9uc1xuICAgICAgICAgICAgLnRvTGlzdCgpXG4gICAgICAgICAgICAuZmlsdGVyKGNvbGxlY3Rpb24gPT4gY29sbGVjdGlvbi5nZXQoJ2hpZGUnKSAhPT0gdHJ1ZSlcbiAgICAgICAgICAgIC5tYXAoY29sbGVjdGlvbiA9PiB0aGlzLnJlbmRlckxpbmsoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaXN0PlxuICAgICAgPC9TaWRlYmFyQ29udGFpbmVyPlxuICAgICk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgdHJhbnNsYXRlKCkoU2lkZWJhcik7XG4iXX0= */"));
49
+ })("display:flex;font-size:14px;font-weight:500;align-items:center;padding:8px 18px;border-left:2px solid #fff;z-index:-1;", _decapCmsUiDefault.Icon, "{margin-right:4px;flex-shrink:0;}", props => /*#__PURE__*/(0, _react2.css)("&:hover,&:active,&.", props.activeClassName, "{", styles.sidebarNavLinkActive, ";};label:SidebarNavLink;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0RGdCIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMTBweCAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTJweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDE4cHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4Q3NDIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0NvbGxlY3Rpb24vU2lkZWJhci5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IHRyYW5zbGF0ZSB9IGZyb20gJ3JlYWN0LXBvbHlnbG90JztcbmltcG9ydCB7IE5hdkxpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7IEljb24sIGNvbXBvbmVudHMsIGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IHsgc2VhcmNoQ29sbGVjdGlvbnMgfSBmcm9tICcuLi8uLi9hY3Rpb25zL2NvbGxlY3Rpb25zJztcbmltcG9ydCBDb2xsZWN0aW9uU2VhcmNoIGZyb20gJy4vQ29sbGVjdGlvblNlYXJjaCc7XG5pbXBvcnQgTmVzdGVkQ29sbGVjdGlvbiBmcm9tICcuL05lc3RlZENvbGxlY3Rpb24nO1xuXG5jb25zdCBzdHlsZXMgPSB7XG4gIHNpZGViYXJOYXZMaW5rQWN0aXZlOiBjc3NgXG4gICAgY29sb3I6ICR7Y29sb3JzLmFjdGl2ZX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuYWN0aXZlQmFja2dyb3VuZH07XG4gICAgYm9yZGVyLWxlZnQtY29sb3I6ICM0ODYzYzY7XG4gIGAsXG59O1xuXG5jb25zdCBTaWRlYmFyQ29udGFpbmVyID0gc3R5bGVkLmFzaWRlYFxuICAke2NvbXBvbmVudHMuY2FyZH07XG4gIHdpZHRoOiAyNTBweDtcbiAgcGFkZGluZzogOHB4IDAgMTJweDtcbiAgcG9zaXRpb246IGZpeGVkO1xuICBtYXgtaGVpZ2h0OiBjYWxjKDEwMHZoIC0gMTEycHgpO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuYDtcblxuY29uc3QgU2lkZWJhckhlYWRpbmcgPSBzdHlsZWQuaDJgXG4gIGZvbnQtc2l6ZTogMjJweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgbGluZS1oZWlnaHQ6IDM3cHg7XG4gIHBhZGRpbmc6IDA7XG4gIG1hcmdpbjogMTBweCAyMHB4O1xuICBjb2xvcjogJHtjb2xvcnMudGV4dExlYWR9O1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpc3QgPSBzdHlsZWQudWxgXG4gIG1hcmdpbjogMTJweCAwIDA7XG4gIGxpc3Qtc3R5bGU6IG5vbmU7XG4gIG92ZXJmbG93OiBhdXRvO1xuYDtcblxuY29uc3QgU2lkZWJhck5hdkxpbmsgPSBzdHlsZWQoTmF2TGluaylgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZvbnQtc2l6ZTogMTRweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogOHB4IDE4cHg7XG4gIGJvcmRlci1sZWZ0OiAycHggc29saWQgI2ZmZjtcbiAgei1pbmRleDogLTE7XG5cbiAgJHtJY29ufSB7XG4gICAgbWFyZ2luLXJpZ2h0OiA0cHg7XG4gICAgZmxleC1zaHJpbms6IDA7XG4gIH1cblxuICAke3Byb3BzID0+IGNzc2BcbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlLFxuICAgICYuJHtwcm9wcy5hY3RpdmVDbGFzc05hbWV9IHtcbiAgICAgICR7c3R5bGVzLnNpZGViYXJOYXZMaW5rQWN0aXZlfTtcbiAgICB9XG4gIGB9O1xuYDtcblxuZXhwb3J0IGNsYXNzIFNpZGViYXIgZXh0ZW5kcyBSZWFjdC5Db21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNvbGxlY3Rpb25zOiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcCxcbiAgICBpc1NlYXJjaEVuYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICAgIHNlYXJjaFRlcm06IFByb3BUeXBlcy5zdHJpbmcsXG4gICAgZmlsdGVyVGVybTogUHJvcFR5cGVzLnN0cmluZyxcbiAgICB0OiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICB9O1xuXG4gIHJlbmRlckxpbmsgPSAoY29sbGVjdGlvbiwgZmlsdGVyVGVybSkgPT4ge1xuICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lID0gY29sbGVjdGlvbi5nZXQoJ25hbWUnKTtcbiAgICBpZiAoY29sbGVjdGlvbi5oYXMoJ25lc3RlZCcpKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGkga2V5PXtjb2xsZWN0aW9uTmFtZX0+XG4gICAgICAgICAgPE5lc3RlZENvbGxlY3Rpb25cbiAgICAgICAgICAgIGNvbGxlY3Rpb249e2NvbGxlY3Rpb259XG4gICAgICAgICAgICBmaWx0ZXJUZXJtPXtmaWx0ZXJUZXJtfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9e2NvbGxlY3Rpb25OYW1lfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cbiAgICByZXR1cm4gKFxuICAgICAgPGxpIGtleT17Y29sbGVjdGlvbk5hbWV9PlxuICAgICAgICA8U2lkZWJhck5hdkxpbmtcbiAgICAgICAgICB0bz17YC9jb2xsZWN0aW9ucy8ke2NvbGxlY3Rpb25OYW1lfWB9XG4gICAgICAgICAgYWN0aXZlQ2xhc3NOYW1lPVwic2lkZWJhci1hY3RpdmVcIlxuICAgICAgICAgIGRhdGEtdGVzdGlkPXtjb2xsZWN0aW9uTmFtZX1cbiAgICAgICAgPlxuICAgICAgICAgIDxJY29uIHR5cGU9XCJ3cml0ZVwiIC8+XG4gICAgICAgICAge2NvbGxlY3Rpb24uZ2V0KCdsYWJlbCcpfVxuICAgICAgICA8L1NpZGViYXJOYXZMaW5rPlxuICAgICAgPC9saT5cbiAgICApO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IGNvbGxlY3Rpb25zLCBjb2xsZWN0aW9uLCBpc1NlYXJjaEVuYWJsZWQsIHNlYXJjaFRlcm0sIHQsIGZpbHRlclRlcm0gfSA9IHRoaXMucHJvcHM7XG4gICAgcmV0dXJuIChcbiAgICAgIDxTaWRlYmFyQ29udGFpbmVyPlxuICAgICAgICA8U2lkZWJhckhlYWRpbmc+e3QoJ2NvbGxlY3Rpb24uc2lkZWJhci5jb2xsZWN0aW9ucycpfTwvU2lkZWJhckhlYWRpbmc+XG4gICAgICAgIHtpc1NlYXJjaEVuYWJsZWQgJiYgKFxuICAgICAgICAgIDxDb2xsZWN0aW9uU2VhcmNoXG4gICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgY29sbGVjdGlvbnM9e2NvbGxlY3Rpb25zfVxuICAgICAgICAgICAgY29sbGVjdGlvbj17Y29sbGVjdGlvbn1cbiAgICAgICAgICAgIG9uU3VibWl0PXsocXVlcnksIGNvbGxlY3Rpb24pID0+IHNlYXJjaENvbGxlY3Rpb25zKHF1ZXJ5LCBjb2xsZWN0aW9uKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgICA8U2lkZWJhck5hdkxpc3Q+XG4gICAgICAgICAge2NvbGxlY3Rpb25zXG4gICAgICAgICAgICAudG9MaXN0KClcbiAgICAgICAgICAgIC5maWx0ZXIoY29sbGVjdGlvbiA9PiBjb2xsZWN0aW9uLmdldCgnaGlkZScpICE9PSB0cnVlKVxuICAgICAgICAgICAgLm1hcChjb2xsZWN0aW9uID0+IHRoaXMucmVuZGVyTGluayhjb2xsZWN0aW9uLCBmaWx0ZXJUZXJtKSl9XG4gICAgICAgIDwvU2lkZWJhck5hdkxpc3Q+XG4gICAgICA8L1NpZGViYXJDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCB0cmFuc2xhdGUoKShTaWRlYmFyKTtcbiJdfQ== */"));
50
50
  class Sidebar extends _react.default.Component {
51
51
  constructor(...args) {
52
52
  super(...args);