decap-cms-core 3.10.0 → 3.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (27) hide show
  1. package/dist/decap-cms-core.js +8 -8
  2. package/dist/decap-cms-core.js.map +1 -1
  3. package/dist/esm/bootstrap.js +2 -2
  4. package/dist/esm/components/App/StatusBar.js +1 -1
  5. package/dist/esm/components/Collection/CollectionControls.js +3 -2
  6. package/dist/esm/components/Collection/ViewStyleControl.js +6 -3
  7. package/dist/esm/components/Editor/EditorControlPane/EditorControl.js +8 -5
  8. package/dist/esm/components/Editor/EditorNotesPane/AddNoteForm.js +5 -5
  9. package/dist/esm/components/Editor/EditorNotesPane/EditorNotesPane.js +75 -15
  10. package/dist/esm/components/Editor/EditorNotesPane/NoteItem.js +21 -24
  11. package/dist/esm/components/Editor/EditorNotesPane/NotesList.js +4 -4
  12. package/dist/esm/components/MediaLibrary/MediaLibraryHeader.js +5 -3
  13. package/dist/esm/components/MediaLibrary/MediaLibraryTop.js +5 -4
  14. package/dist/esm/components/UI/ErrorBoundary.js +2 -2
  15. package/dist/esm/components/UI/SettingsDropdown.js +9 -7
  16. package/package.json +2 -2
  17. package/src/components/Collection/CollectionControls.js +1 -1
  18. package/src/components/Collection/ViewStyleControl.js +3 -1
  19. package/src/components/Editor/EditorControlPane/EditorControl.js +1 -0
  20. package/src/components/MediaLibrary/MediaLibraryHeader.js +2 -2
  21. package/src/components/MediaLibrary/MediaLibraryTop.js +1 -0
  22. package/src/components/UI/SettingsDropdown.js +1 -1
  23. package/dist/esm/components/Collection/Entries/Pagination.js +0 -132
  24. package/dist/esm/lib/entryCache.js +0 -145
  25. package/dist/esm/lib/entryHelpers.js +0 -102
  26. package/dist/esm/lib/immutableHelpers.js +0 -21
  27. package/dist/esm/lib/pagination.js +0 -68
@@ -4,26 +4,52 @@ import PropTypes from 'prop-types';
4
4
  import React, { Component } from 'react';
5
5
  import ImmutablePropTypes from 'react-immutable-proptypes';
6
6
  import { List } from 'immutable';
7
- import { colors } from 'decap-cms-ui-default';
7
+ import { colors, Icon } from 'decap-cms-ui-default';
8
8
  import NotesList from './NotesList';
9
9
  import AddNoteForm from './AddNoteForm';
10
10
  import { jsx as ___EmotionJSX } from "@emotion/react";
11
11
  const NotesContainer = /*#__PURE__*/_styled("div", {
12
- target: "e1fzfvs07",
12
+ target: "e1fzfvs010",
13
13
  label: "NotesContainer"
14
- })("height:100%;display:flex;flex-direction:column;background-color:", colors.background, ";border-left:1px solid ", colors.textFieldBorder, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVVpQyIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9FZGl0b3IvRWRpdG9yTm90ZXNQYW5lL0VkaXRvck5vdGVzUGFuZS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgQ29tcG9uZW50IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEltbXV0YWJsZVByb3BUeXBlcyBmcm9tICdyZWFjdC1pbW11dGFibGUtcHJvcHR5cGVzJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IExpc3QgfSBmcm9tICdpbW11dGFibGUnO1xuaW1wb3J0IHsgY29sb3JzIH0gZnJvbSAnZGVjYXAtY21zLXVpLWRlZmF1bHQnO1xuXG5pbXBvcnQgTm90ZXNMaXN0IGZyb20gJy4vTm90ZXNMaXN0JztcbmltcG9ydCBBZGROb3RlRm9ybSBmcm9tICcuL0FkZE5vdGVGb3JtJztcblxuY29uc3QgTm90ZXNDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBoZWlnaHQ6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGJhY2tncm91bmQtY29sb3I6ICR7Y29sb3JzLmJhY2tncm91bmR9O1xuICBib3JkZXItbGVmdDogMXB4IHNvbGlkICR7Y29sb3JzLnRleHRGaWVsZEJvcmRlcn07XG5gO1xuXG5jb25zdCBOb3Rlc0hlYWRlciA9IHN0eWxlZC5kaXZgXG4gIHBhZGRpbmc6IDE2cHg7XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5pbnB1dEJhY2tncm91bmR9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1pbi1oZWlnaHQ6IDYwcHg7XG5gO1xuXG5jb25zdCBOb3Rlc1RpdGxlID0gc3R5bGVkLmgzYFxuICBtYXJnaW46IDA7XG4gIGZvbnQtc2l6ZTogMTZweDtcbiAgZm9udC13ZWlnaHQ6IDYwMDtcbiAgY29sb3I6ICR7Y29sb3JzLnRleHR9O1xuYDtcblxuY29uc3QgTm90ZXNDb3VudCA9IHN0eWxlZC5zcGFuYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICBjb2xvcjogd2hpdGU7XG4gIGJvcmRlci1yYWRpdXM6IDEycHg7XG4gIHBhZGRpbmc6IDJweCA4cHg7XG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgZm9udC13ZWlnaHQ6IDUwMDtcbmA7XG5cbmNvbnN0IE5vdGVzQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIG92ZXJmbG93OiBoaWRkZW47XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlID0gc3R5bGVkLmRpdmBcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDQwcHggMjBweDtcbiAgY29sb3I6ICR7Y29sb3JzLmNvbnRyb2xMYWJlbH07XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEVtcHR5U3RhdGVJY29uID0gc3R5bGVkLmRpdmBcbiAgZm9udC1zaXplOiA0OHB4O1xuICBtYXJnaW4tYm90dG9tOiAxNnB4O1xuICBvcGFjaXR5OiAwLjU7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlVGV4dCA9IHN0eWxlZC5wYFxuICBmb250LXNpemU6IDE0cHg7XG4gIG1hcmdpbjogMDtcbiAgbGluZS1oZWlnaHQ6IDEuNDtcbmA7XG5cbmNsYXNzIEVkaXRvck5vdGVzUGFuZSBleHRlbmRzIENvbXBvbmVudCB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgbm90ZXM6IEltbXV0YWJsZVByb3BUeXBlcy5saXN0LFxuICAgIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuICAgIGVudHJ5OiBJbW11dGFibGVQcm9wVHlwZXMubWFwLmlzUmVxdWlyZWQsXG4gICAgY29sbGVjdGlvbjogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIHVzZXI6IFByb3BUeXBlcy5vYmplY3QsXG4gICAgdDogUHJvcFR5cGVzLmZ1bmMsXG4gIH07XG5cbiAgc3RhdGljIGRlZmF1bHRQcm9wcyA9IHtcbiAgICBub3RlczogTGlzdCgpLFxuICAgIHQ6IGtleSA9PiBrZXksIC8vIEZhbGxiYWNrIHRyYW5zbGF0aW9uIGZ1bmN0aW9uXG4gIH07XG5cbiAgaGFuZGxlQWRkTm90ZSA9IGNvbnRlbnQgPT4ge1xuICAgIGNvbnN0IHsgb25DaGFuZ2UsIHVzZXIgfSA9IHRoaXMucHJvcHM7XG4gICAgY29uc3QgbmV3Tm90ZSA9IHtcbiAgICAgIGNvbnRlbnQ6IGNvbnRlbnQudHJpbSgpLFxuICAgICAgYXV0aG9yOiB1c2VyPy5sb2dpbiB8fCB1c2VyPy5uYW1lIHx8ICdBbm9ueW1vdXMnLFxuICAgICAgcmVzb2x2ZWQ6IGZhbHNlLFxuICAgIH07XG5cbiAgICBvbkNoYW5nZSgnQUREX05PVEUnLCBuZXdOb3RlKTtcbiAgfTtcblxuICBoYW5kbGVVcGRhdGVOb3RlID0gKG5vdGVJZCwgdXBkYXRlcykgPT4ge1xuICAgIGNvbnN0IHsgb25DaGFuZ2UgfSA9IHRoaXMucHJvcHM7XG4gICAgb25DaGFuZ2UoJ1VQREFURV9OT1RFJywgeyBpZDogbm90ZUlkLCB1cGRhdGVzIH0pO1xuICB9O1xuXG4gIGhhbmRsZURlbGV0ZU5vdGUgPSBub3RlSWQgPT4ge1xuICAgIGNvbnN0IHsgb25DaGFuZ2UgfSA9IHRoaXMucHJvcHM7XG4gICAgb25DaGFuZ2UoJ0RFTEVURV9OT1RFJywgeyBpZDogbm90ZUlkIH0pO1xuICB9O1xuXG4gIGhhbmRsZVRvZ2dsZU5vdGVSZXNvbHV0aW9uID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG5vdGVzIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5vdGVzTGlzdCA9IG5vdGVzICYmIG5vdGVzLnNpemUgIT09IHVuZGVmaW5lZCA/IG5vdGVzIDogTGlzdChub3RlcyB8fCBbXSk7XG4gICAgY29uc3Qgbm90ZSA9IG5vdGVzTGlzdC5maW5kKG4gPT4gbi5nZXQoJ2lkJykgPT09IG5vdGVJZCk7XG4gICAgY29uc3QgY3VycmVudFJlc29sdmVkID0gbm90ZSA/IG5vdGUuZ2V0KCdyZXNvbHZlZCcpIDogZmFsc2U7XG5cbiAgICB0aGlzLmhhbmRsZVVwZGF0ZU5vdGUobm90ZUlkLCB7IHJlc29sdmVkOiAhY3VycmVudFJlc29sdmVkIH0pO1xuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICBjb25zdCB7IG5vdGVzLCB0IH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5vdGVzTGlzdCA9IG5vdGVzICYmIG5vdGVzLnNpemUgIT09IHVuZGVmaW5lZCA/IG5vdGVzIDogTGlzdChub3RlcyB8fCBbXSk7XG4gICAgY29uc3Qgbm90ZXNDb3VudCA9IG5vdGVzTGlzdC5zaXplO1xuICAgIGNvbnN0IHVucmVzb2x2ZWRDb3VudCA9IG5vdGVzTGlzdC5maWx0ZXIobm90ZSA9PiAhbm90ZS5nZXQoJ3Jlc29sdmVkJykpLnNpemU7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPE5vdGVzQ29udGFpbmVyPlxuICAgICAgICA8Tm90ZXNIZWFkZXI+XG4gICAgICAgICAgPE5vdGVzVGl0bGU+e3QoJ2VkaXRvci5lZGl0b3JOb3Rlc1BhbmUudGl0bGUnKX08L05vdGVzVGl0bGU+XG4gICAgICAgICAge25vdGVzQ291bnQgPiAwICYmIChcbiAgICAgICAgICAgIDxOb3Rlc0NvdW50Pnt1bnJlc29sdmVkQ291bnQgPiAwID8gdW5yZXNvbHZlZENvdW50IDogbm90ZXNDb3VudH08L05vdGVzQ291bnQ+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9Ob3Rlc0hlYWRlcj5cblxuICAgICAgICA8Tm90ZXNDb250ZW50PlxuICAgICAgICAgIHtub3Rlc0NvdW50ID09PSAwID8gKFxuICAgICAgICAgICAgPEVtcHR5U3RhdGU+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlSWNvbj7wn5OdPC9FbXB0eVN0YXRlSWNvbj5cbiAgICAgICAgICAgICAgPEVtcHR5U3RhdGVUZXh0Pnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLmVtcHR5U3RhdGUnKX08L0VtcHR5U3RhdGVUZXh0PlxuICAgICAgICAgICAgPC9FbXB0eVN0YXRlPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICA8Tm90ZXNMaXN0XG4gICAgICAgICAgICAgIG5vdGVzPXtub3Rlc0xpc3R9XG4gICAgICAgICAgICAgIG9uVXBkYXRlPXt0aGlzLmhhbmRsZVVwZGF0ZU5vdGV9XG4gICAgICAgICAgICAgIG9uRGVsZXRlPXt0aGlzLmhhbmRsZURlbGV0ZU5vdGV9XG4gICAgICAgICAgICAgIG9uVG9nZ2xlUmVzb2x1dGlvbj17dGhpcy5oYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbn1cbiAgICAgICAgICAgICAgdXNlcj17dGhpcy5wcm9wcy51c2VyfVxuICAgICAgICAgICAgICB0PXt0fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuXG4gICAgICAgICAgPEFkZE5vdGVGb3JtIG9uQWRkPXt0aGlzLmhhbmRsZUFkZE5vdGV9IHQ9e3R9IC8+XG4gICAgICAgIDwvTm90ZXNDb250ZW50PlxuICAgICAgPC9Ob3Rlc0NvbnRhaW5lcj5cbiAgICApO1xuICB9XG59XG5cbmV4cG9ydCBkZWZhdWx0IEVkaXRvck5vdGVzUGFuZTtcbiJdfQ== */"));
14
+ })("height:100%;display:flex;flex-direction:column;background-color:", colors.background, ";border-left:1px solid ", colors.textFieldBorder, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAUiC","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
15
15
  const NotesHeader = /*#__PURE__*/_styled("div", {
16
- target: "e1fzfvs06",
16
+ target: "e1fzfvs09",
17
17
  label: "NotesHeader"
18
- })("padding:16px;border-bottom:1px solid ", colors.textFieldBorder, ";background-color:", colors.inputBackground, ";display:flex;justify-content:space-between;align-items:center;min-height:60px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCOEIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */"));
18
+ })("padding:16px 24px;border-bottom:1px solid ", colors.textFieldBorder, ";background-color:", colors.inputBackground, ";display:flex;align-items:center;min-height:60px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAkB8B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
19
+ const NotesTitleGroup = /*#__PURE__*/_styled("div", {
20
+ target: "e1fzfvs08",
21
+ label: "NotesTitleGroup"
22
+ })(process.env.NODE_ENV === "production" ? {
23
+ name: "1yydxi7",
24
+ styles: "display:flex;align-items:center;gap:8px"
25
+ } : {
26
+ name: "1yydxi7",
27
+ styles: "display:flex;align-items:center;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AA2BkC","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */",
28
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
29
+ });
19
30
  const NotesTitle = /*#__PURE__*/_styled("h3", {
20
- target: "e1fzfvs05",
31
+ target: "e1fzfvs07",
21
32
  label: "NotesTitle"
22
- })("margin:0;font-size:16px;font-weight:600;color:", colors.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCNEIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */"));
33
+ })("margin:0;font-size:16px;font-weight:600;color:", colors.text, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAiC4B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
23
34
  const NotesCount = /*#__PURE__*/_styled("span", {
24
- target: "e1fzfvs04",
35
+ target: "e1fzfvs06",
25
36
  label: "NotesCount"
26
- })("background-color:", colors.controlLabel, ";color:white;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:500;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DOEIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */"));
37
+ })("background-color:", colors.controlLabel, ";color:white;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:500;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAwC8B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
38
+ const SourceLink = /*#__PURE__*/_styled("a", {
39
+ target: "e1fzfvs05",
40
+ label: "SourceLink"
41
+ })("color:", colors.controlLabel, ";text-decoration:none;font-size:14px;display:flex;align-items:center;gap:6px;&:hover{color:", colors.text, ";text-decoration:underline;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAiD2B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
42
+ const SourceIcon = /*#__PURE__*/_styled(Icon, {
43
+ target: "e1fzfvs04",
44
+ label: "SourceIcon"
45
+ })(process.env.NODE_ENV === "production" ? {
46
+ name: "40intd",
47
+ styles: "width:16px;height:16px;color:currentColor"
48
+ } : {
49
+ name: "40intd",
50
+ styles: "width:16px;height:16px;color:currentColor/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AA+D+B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */",
51
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
+ });
27
53
  const NotesContent = /*#__PURE__*/_styled("div", {
28
54
  target: "e1fzfvs03",
29
55
  label: "NotesContent"
@@ -32,13 +58,13 @@ const NotesContent = /*#__PURE__*/_styled("div", {
32
58
  styles: "flex:1;display:flex;flex-direction:column;overflow:hidden"
33
59
  } : {
34
60
  name: "xt6tct",
35
- styles: "flex:1;display:flex;flex-direction:column;overflow:hidden/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDK0IiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */",
61
+ styles: "flex:1;display:flex;flex-direction:column;overflow:hidden/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAqE+B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */",
36
62
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
63
  });
38
64
  const EmptyState = /*#__PURE__*/_styled("div", {
39
65
  target: "e1fzfvs02",
40
66
  label: "EmptyState"
41
- })("flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;color:", colors.controlLabel, ";text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1ENkIiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */"));
67
+ })("flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;color:", colors.controlLabel, ";text-align:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AA4E6B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */"));
42
68
  const EmptyStateIcon = /*#__PURE__*/_styled("div", {
43
69
  target: "e1fzfvs01",
44
70
  label: "EmptyStateIcon"
@@ -47,7 +73,7 @@ const EmptyStateIcon = /*#__PURE__*/_styled("div", {
47
73
  styles: "font-size:48px;margin-bottom:16px;opacity:0.5"
48
74
  } : {
49
75
  name: "wv8os8",
50
- styles: "font-size:48px;margin-bottom:16px;opacity:0.5/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThEaUMiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */",
76
+ styles: "font-size:48px;margin-bottom:16px;opacity:0.5/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AAuFiC","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */",
51
77
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
78
  });
53
79
  const EmptyStateText = /*#__PURE__*/_styled("p", {
@@ -58,7 +84,7 @@ const EmptyStateText = /*#__PURE__*/_styled("p", {
58
84
  styles: "font-size:14px;margin:0;line-height:1.4"
59
85
  } : {
60
86
  name: "ggbbmu",
61
- styles: "font-size:14px;margin:0;line-height:1.4/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0VkaXRvci9FZGl0b3JOb3Rlc1BhbmUvRWRpdG9yTm90ZXNQYW5lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW9FK0IiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRWRpdG9yL0VkaXRvck5vdGVzUGFuZS9FZGl0b3JOb3Rlc1BhbmUuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBJbW11dGFibGVQcm9wVHlwZXMgZnJvbSAncmVhY3QtaW1tdXRhYmxlLXByb3B0eXBlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnaW1tdXRhYmxlJztcbmltcG9ydCB7IGNvbG9ycyB9IGZyb20gJ2RlY2FwLWNtcy11aS1kZWZhdWx0JztcblxuaW1wb3J0IE5vdGVzTGlzdCBmcm9tICcuL05vdGVzTGlzdCc7XG5pbXBvcnQgQWRkTm90ZUZvcm0gZnJvbSAnLi9BZGROb3RlRm9ybSc7XG5cbmNvbnN0IE5vdGVzQ29udGFpbmVyID0gc3R5bGVkLmRpdmBcbiAgaGVpZ2h0OiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2NvbG9ycy5iYWNrZ3JvdW5kfTtcbiAgYm9yZGVyLWxlZnQ6IDFweCBzb2xpZCAke2NvbG9ycy50ZXh0RmllbGRCb3JkZXJ9O1xuYDtcblxuY29uc3QgTm90ZXNIZWFkZXIgPSBzdHlsZWQuZGl2YFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtjb2xvcnMudGV4dEZpZWxkQm9yZGVyfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuaW5wdXRCYWNrZ3JvdW5kfTtcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiA2MHB4O1xuYDtcblxuY29uc3QgTm90ZXNUaXRsZSA9IHN0eWxlZC5oM2BcbiAgbWFyZ2luOiAwO1xuICBmb250LXNpemU6IDE2cHg7XG4gIGZvbnQtd2VpZ2h0OiA2MDA7XG4gIGNvbG9yOiAke2NvbG9ycy50ZXh0fTtcbmA7XG5cbmNvbnN0IE5vdGVzQ291bnQgPSBzdHlsZWQuc3BhbmBcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtjb2xvcnMuY29udHJvbExhYmVsfTtcbiAgY29sb3I6IHdoaXRlO1xuICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBmb250LXNpemU6IDEycHg7XG4gIGZvbnQtd2VpZ2h0OiA1MDA7XG5gO1xuXG5jb25zdCBOb3Rlc0NvbnRlbnQgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAxO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZSA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiA0MHB4IDIwcHg7XG4gIGNvbG9yOiAke2NvbG9ycy5jb250cm9sTGFiZWx9O1xuICB0ZXh0LWFsaWduOiBjZW50ZXI7XG5gO1xuXG5jb25zdCBFbXB0eVN0YXRlSWNvbiA9IHN0eWxlZC5kaXZgXG4gIGZvbnQtc2l6ZTogNDhweDtcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgb3BhY2l0eTogMC41O1xuYDtcblxuY29uc3QgRW1wdHlTdGF0ZVRleHQgPSBzdHlsZWQucGBcbiAgZm9udC1zaXplOiAxNHB4O1xuICBtYXJnaW46IDA7XG4gIGxpbmUtaGVpZ2h0OiAxLjQ7XG5gO1xuXG5jbGFzcyBFZGl0b3JOb3Rlc1BhbmUgZXh0ZW5kcyBDb21wb25lbnQge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG5vdGVzOiBJbW11dGFibGVQcm9wVHlwZXMubGlzdCxcbiAgICBvbkNoYW5nZTogUHJvcFR5cGVzLmZ1bmMuaXNSZXF1aXJlZCxcbiAgICBlbnRyeTogSW1tdXRhYmxlUHJvcFR5cGVzLm1hcC5pc1JlcXVpcmVkLFxuICAgIGNvbGxlY3Rpb246IEltbXV0YWJsZVByb3BUeXBlcy5tYXAuaXNSZXF1aXJlZCxcbiAgICB1c2VyOiBQcm9wVHlwZXMub2JqZWN0LFxuICAgIHQ6IFByb3BUeXBlcy5mdW5jLFxuICB9O1xuXG4gIHN0YXRpYyBkZWZhdWx0UHJvcHMgPSB7XG4gICAgbm90ZXM6IExpc3QoKSxcbiAgICB0OiBrZXkgPT4ga2V5LCAvLyBGYWxsYmFjayB0cmFuc2xhdGlvbiBmdW5jdGlvblxuICB9O1xuXG4gIGhhbmRsZUFkZE5vdGUgPSBjb250ZW50ID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlLCB1c2VyIH0gPSB0aGlzLnByb3BzO1xuICAgIGNvbnN0IG5ld05vdGUgPSB7XG4gICAgICBjb250ZW50OiBjb250ZW50LnRyaW0oKSxcbiAgICAgIGF1dGhvcjogdXNlcj8ubG9naW4gfHwgdXNlcj8ubmFtZSB8fCAnQW5vbnltb3VzJyxcbiAgICAgIHJlc29sdmVkOiBmYWxzZSxcbiAgICB9O1xuXG4gICAgb25DaGFuZ2UoJ0FERF9OT1RFJywgbmV3Tm90ZSk7XG4gIH07XG5cbiAgaGFuZGxlVXBkYXRlTm90ZSA9IChub3RlSWQsIHVwZGF0ZXMpID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdVUERBVEVfTk9URScsIHsgaWQ6IG5vdGVJZCwgdXBkYXRlcyB9KTtcbiAgfTtcblxuICBoYW5kbGVEZWxldGVOb3RlID0gbm90ZUlkID0+IHtcbiAgICBjb25zdCB7IG9uQ2hhbmdlIH0gPSB0aGlzLnByb3BzO1xuICAgIG9uQ2hhbmdlKCdERUxFVEVfTk9URScsIHsgaWQ6IG5vdGVJZCB9KTtcbiAgfTtcblxuICBoYW5kbGVUb2dnbGVOb3RlUmVzb2x1dGlvbiA9IG5vdGVJZCA9PiB7XG4gICAgY29uc3QgeyBub3RlcyB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGUgPSBub3Rlc0xpc3QuZmluZChuID0+IG4uZ2V0KCdpZCcpID09PSBub3RlSWQpO1xuICAgIGNvbnN0IGN1cnJlbnRSZXNvbHZlZCA9IG5vdGUgPyBub3RlLmdldCgncmVzb2x2ZWQnKSA6IGZhbHNlO1xuXG4gICAgdGhpcy5oYW5kbGVVcGRhdGVOb3RlKG5vdGVJZCwgeyByZXNvbHZlZDogIWN1cnJlbnRSZXNvbHZlZCB9KTtcbiAgfTtcblxuICByZW5kZXIoKSB7XG4gICAgY29uc3QgeyBub3RlcywgdCB9ID0gdGhpcy5wcm9wcztcbiAgICBjb25zdCBub3Rlc0xpc3QgPSBub3RlcyAmJiBub3Rlcy5zaXplICE9PSB1bmRlZmluZWQgPyBub3RlcyA6IExpc3Qobm90ZXMgfHwgW10pO1xuICAgIGNvbnN0IG5vdGVzQ291bnQgPSBub3Rlc0xpc3Quc2l6ZTtcbiAgICBjb25zdCB1bnJlc29sdmVkQ291bnQgPSBub3Rlc0xpc3QuZmlsdGVyKG5vdGUgPT4gIW5vdGUuZ2V0KCdyZXNvbHZlZCcpKS5zaXplO1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxOb3Rlc0NvbnRhaW5lcj5cbiAgICAgICAgPE5vdGVzSGVhZGVyPlxuICAgICAgICAgIDxOb3Rlc1RpdGxlPnt0KCdlZGl0b3IuZWRpdG9yTm90ZXNQYW5lLnRpdGxlJyl9PC9Ob3Rlc1RpdGxlPlxuICAgICAgICAgIHtub3Rlc0NvdW50ID4gMCAmJiAoXG4gICAgICAgICAgICA8Tm90ZXNDb3VudD57dW5yZXNvbHZlZENvdW50ID4gMCA/IHVucmVzb2x2ZWRDb3VudCA6IG5vdGVzQ291bnR9PC9Ob3Rlc0NvdW50PlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTm90ZXNIZWFkZXI+XG5cbiAgICAgICAgPE5vdGVzQ29udGVudD5cbiAgICAgICAgICB7bm90ZXNDb3VudCA9PT0gMCA/IChcbiAgICAgICAgICAgIDxFbXB0eVN0YXRlPlxuICAgICAgICAgICAgICA8RW1wdHlTdGF0ZUljb24+8J+TnTwvRW1wdHlTdGF0ZUljb24+XG4gICAgICAgICAgICAgIDxFbXB0eVN0YXRlVGV4dD57dCgnZWRpdG9yLmVkaXRvck5vdGVzUGFuZS5lbXB0eVN0YXRlJyl9PC9FbXB0eVN0YXRlVGV4dD5cbiAgICAgICAgICAgIDwvRW1wdHlTdGF0ZT5cbiAgICAgICAgICApIDogKFxuICAgICAgICAgICAgPE5vdGVzTGlzdFxuICAgICAgICAgICAgICBub3Rlcz17bm90ZXNMaXN0fVxuICAgICAgICAgICAgICBvblVwZGF0ZT17dGhpcy5oYW5kbGVVcGRhdGVOb3RlfVxuICAgICAgICAgICAgICBvbkRlbGV0ZT17dGhpcy5oYW5kbGVEZWxldGVOb3RlfVxuICAgICAgICAgICAgICBvblRvZ2dsZVJlc29sdXRpb249e3RoaXMuaGFuZGxlVG9nZ2xlTm90ZVJlc29sdXRpb259XG4gICAgICAgICAgICAgIHVzZXI9e3RoaXMucHJvcHMudXNlcn1cbiAgICAgICAgICAgICAgdD17dH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cblxuICAgICAgICAgIDxBZGROb3RlRm9ybSBvbkFkZD17dGhpcy5oYW5kbGVBZGROb3RlfSB0PXt0fSAvPlxuICAgICAgICA8L05vdGVzQ29udGVudD5cbiAgICAgIDwvTm90ZXNDb250YWluZXI+XG4gICAgKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBFZGl0b3JOb3Rlc1BhbmU7XG4iXX0= */",
87
+ styles: "font-size:14px;margin:0;line-height:1.4/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js"],"names":[],"mappings":"AA6F+B","file":"../../../../../src/components/Editor/EditorNotesPane/EditorNotesPane.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { List } from 'immutable';\nimport { colors, Icon } from 'decap-cms-ui-default';\n\nimport NotesList from './NotesList';\nimport AddNoteForm from './AddNoteForm';\n\nconst NotesContainer = styled.div`\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  background-color: ${colors.background};\n  border-left: 1px solid ${colors.textFieldBorder};\n`;\n\nconst NotesHeader = styled.div`\n  padding: 16px 24px;\n  border-bottom: 1px solid ${colors.textFieldBorder};\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  min-height: 60px;\n`;\n\nconst NotesTitleGroup = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst NotesTitle = styled.h3`\n  margin: 0;\n  font-size: 16px;\n  font-weight: 600;\n  color: ${colors.text};\n`;\n\nconst NotesCount = styled.span`\n  background-color: ${colors.controlLabel};\n  color: white;\n  border-radius: 12px;\n  padding: 2px 8px;\n  font-size: 12px;\n  font-weight: 500;\n`;\n\nconst SourceLink = styled.a`\n  color: ${colors.controlLabel};\n  text-decoration: none;\n  font-size: 14px;\n  display: flex;\n  align-items: center;\n  gap: 6px;\n\n  &:hover {\n    color: ${colors.text};\n    text-decoration: underline;\n  }\n`;\n\nconst SourceIcon = styled(Icon)`\n  width: 16px;\n  height: 16px;\n  color: currentColor;\n`;\n\nconst NotesContent = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  overflow: hidden;\n`;\n\nconst EmptyState = styled.div`\n  flex: 1;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  padding: 40px 20px;\n  color: ${colors.controlLabel};\n  text-align: center;\n`;\n\nconst EmptyStateIcon = styled.div`\n  font-size: 48px;\n  margin-bottom: 16px;\n  opacity: 0.5;\n`;\n\nconst EmptyStateText = styled.p`\n  font-size: 14px;\n  margin: 0;\n  line-height: 1.4;\n`;\n\nclass EditorNotesPane extends Component {\n  static propTypes = {\n    notes: ImmutablePropTypes.list,\n    onChange: PropTypes.func.isRequired,\n    entry: ImmutablePropTypes.map.isRequired,\n    collection: ImmutablePropTypes.map.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func,\n    sourceUrl: PropTypes.string, // Link to the GitHub issue or source\n  };\n\n  static defaultProps = {\n    notes: List(),\n    t: key => key, // Fallback translation function\n  };\n\n  handleAddNote = content => {\n    const { onChange, user } = this.props;\n    const newNote = {\n      content: content.trim(),\n      author: user?.login || user?.name || 'Anonymous',\n      resolved: false,\n    };\n\n    onChange('ADD_NOTE', newNote);\n  };\n\n  handleUpdateNote = (noteId, updates) => {\n    const { onChange } = this.props;\n    onChange('UPDATE_NOTE', { id: noteId, updates });\n  };\n\n  handleDeleteNote = noteId => {\n    const { onChange } = this.props;\n    onChange('DELETE_NOTE', { id: noteId });\n  };\n\n  handleToggleNoteResolution = noteId => {\n    const { notes } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const note = notesList.find(n => n.get('id') === noteId);\n    const currentResolved = note ? note.get('resolved') : false;\n\n    this.handleUpdateNote(noteId, { resolved: !currentResolved });\n  };\n  // Helper method to get the appropriate link text and icon type based on the source\n  getSourceInfo = url => {\n    // Check if URL is from GitHub\n    if (url.includes('github.com')) {\n      return {\n        text: 'View in GitHub',\n        iconType: 'github', // Using GitHub icon type\n      };\n    }\n\n    // TODO: Add support for other Git providers\n    // Example for future contributors:\n    // if (url.includes('gitlab.com')) {\n    //   return { text: 'View in GitLab', iconType: 'gitlab' };\n    // }\n    // if (url.includes('bitbucket.org')) {\n    //   return { text: 'View in Bitbucket', iconType: 'bitbucket' };\n    // }\n\n    // Default fallback\n    return {\n      text: 'View source',\n      iconType: 'link',\n    };\n  };\n\n  render() {\n    const { notes, t } = this.props;\n    const notesList = notes && notes.size !== undefined ? notes : List(notes || []);\n    const notesCount = notesList.size;\n    const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;\n\n    const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;\n    const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;\n\n    return (\n      <NotesContainer>\n        <NotesHeader>\n          <NotesTitleGroup>\n            <NotesTitle>{t('editor.editorNotesPane.title')}</NotesTitle>\n            {notesCount > 0 && (\n              <NotesCount>{unresolvedCount > 0 ? unresolvedCount : notesCount}</NotesCount>\n            )}\n            {sourceInfo && (\n              <SourceLink href={sourceUrl} target=\"_blank\" rel=\"noopener noreferrer\">\n                <span>{sourceInfo.text}</span>\n                <SourceIcon type={sourceInfo.iconType} />\n              </SourceLink>\n            )}\n          </NotesTitleGroup>\n        </NotesHeader>\n\n        <NotesContent>\n          {notesCount === 0 ? (\n            <EmptyState>\n              <EmptyStateIcon>📝</EmptyStateIcon>\n              <EmptyStateText>{t('editor.editorNotesPane.emptyState')}</EmptyStateText>\n            </EmptyState>\n          ) : (\n            <NotesList\n              notes={notesList}\n              onUpdate={this.handleUpdateNote}\n              onDelete={this.handleDeleteNote}\n              onToggleResolution={this.handleToggleNoteResolution}\n              user={this.props.user}\n              t={t}\n            />\n          )}\n\n          <AddNoteForm onAdd={this.handleAddNote} t={t} />\n        </NotesContent>\n      </NotesContainer>\n    );\n  }\n}\n\nexport default EditorNotesPane;\n"]} */",
62
88
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
63
89
  });
64
90
  class EditorNotesPane extends Component {
@@ -68,7 +94,8 @@ class EditorNotesPane extends Component {
68
94
  entry: ImmutablePropTypes.map.isRequired,
69
95
  collection: ImmutablePropTypes.map.isRequired,
70
96
  user: PropTypes.object,
71
- t: PropTypes.func
97
+ t: PropTypes.func,
98
+ sourceUrl: PropTypes.string // Link to the GitHub issue or source
72
99
  };
73
100
  static defaultProps = {
74
101
  notes: List(),
@@ -114,6 +141,31 @@ class EditorNotesPane extends Component {
114
141
  resolved: !currentResolved
115
142
  });
116
143
  };
144
+ // Helper method to get the appropriate link text and icon type based on the source
145
+ getSourceInfo = url => {
146
+ // Check if URL is from GitHub
147
+ if (url.includes('github.com')) {
148
+ return {
149
+ text: 'View in GitHub',
150
+ iconType: 'github' // Using GitHub icon type
151
+ };
152
+ }
153
+
154
+ // TODO: Add support for other Git providers
155
+ // Example for future contributors:
156
+ // if (url.includes('gitlab.com')) {
157
+ // return { text: 'View in GitLab', iconType: 'gitlab' };
158
+ // }
159
+ // if (url.includes('bitbucket.org')) {
160
+ // return { text: 'View in Bitbucket', iconType: 'bitbucket' };
161
+ // }
162
+
163
+ // Default fallback
164
+ return {
165
+ text: 'View source',
166
+ iconType: 'link'
167
+ };
168
+ };
117
169
  render() {
118
170
  const {
119
171
  notes,
@@ -122,7 +174,15 @@ class EditorNotesPane extends Component {
122
174
  const notesList = notes && notes.size !== undefined ? notes : List(notes || []);
123
175
  const notesCount = notesList.size;
124
176
  const unresolvedCount = notesList.filter(note => !note.get('resolved')).size;
125
- return ___EmotionJSX(NotesContainer, null, ___EmotionJSX(NotesHeader, null, ___EmotionJSX(NotesTitle, null, t('editor.editorNotesPane.title')), notesCount > 0 && ___EmotionJSX(NotesCount, null, unresolvedCount > 0 ? unresolvedCount : notesCount)), ___EmotionJSX(NotesContent, null, notesCount === 0 ? ___EmotionJSX(EmptyState, null, ___EmotionJSX(EmptyStateIcon, null, "\uD83D\uDCDD"), ___EmotionJSX(EmptyStateText, null, t('editor.editorNotesPane.emptyState'))) : ___EmotionJSX(NotesList, {
177
+ const sourceUrl = notesCount > 0 ? notesList.first()?.get('issueUrl') : null;
178
+ const sourceInfo = sourceUrl ? this.getSourceInfo(sourceUrl) : null;
179
+ return ___EmotionJSX(NotesContainer, null, ___EmotionJSX(NotesHeader, null, ___EmotionJSX(NotesTitleGroup, null, ___EmotionJSX(NotesTitle, null, t('editor.editorNotesPane.title')), notesCount > 0 && ___EmotionJSX(NotesCount, null, unresolvedCount > 0 ? unresolvedCount : notesCount), sourceInfo && ___EmotionJSX(SourceLink, {
180
+ href: sourceUrl,
181
+ target: "_blank",
182
+ rel: "noopener noreferrer"
183
+ }, ___EmotionJSX("span", null, sourceInfo.text), ___EmotionJSX(SourceIcon, {
184
+ type: sourceInfo.iconType
185
+ })))), ___EmotionJSX(NotesContent, null, notesCount === 0 ? ___EmotionJSX(EmptyState, null, ___EmotionJSX(EmptyStateIcon, null, "\uD83D\uDCDD"), ___EmotionJSX(EmptyStateText, null, t('editor.editorNotesPane.emptyState'))) : ___EmotionJSX(NotesList, {
126
186
  notes: notesList,
127
187
  onUpdate: this.handleUpdateNote,
128
188
  onDelete: this.handleDeleteNote,