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
@@ -8,7 +8,7 @@ import { jsx as ___EmotionJSX } from "@emotion/react";
8
8
  const NoteCard = /*#__PURE__*/_styled("div", {
9
9
  target: "ee0v20j13",
10
10
  label: "NoteCard"
11
- })("background-color:", props => props.resolved ? colors.inputBackground : 'white', ";border:1px solid ", props => props.resolved ? colors.textFieldBorder : colors.textFieldBorder, ";border-radius:4px;margin-bottom:8px;padding:12px;transition:all ", transitions.main, ";opacity:", props => props.resolved ? 0.7 : 1, ";&:hover{border-color:", colors.active, ";box-shadow:0 2px 4px rgba(0, 0, 0, 0.1);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAM2B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
11
+ })("background-color:", props => props.resolved ? colors.inputBackground : 'white', ";border:1px solid ", props => props.resolved ? colors.textFieldBorder : colors.textFieldBorder, ";border-radius:4px;margin-bottom:8px;padding:12px 18px;transition:all ", transitions.main, ";opacity:", props => props.resolved ? 0.7 : 1, ";&:hover{border-color:", colors.active, ";box-shadow:0 2px 4px rgba(0, 0, 0, 0.1);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAM2B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
12
12
  const NoteHeader = /*#__PURE__*/_styled("div", {
13
13
  target: "ee0v20j12",
14
14
  label: "NoteHeader"
@@ -17,13 +17,13 @@ const NoteHeader = /*#__PURE__*/_styled("div", {
17
17
  styles: "display:flex;justify-content:space-between;align-items:center;margin-bottom:8px"
18
18
  } : {
19
19
  name: "rcj3va",
20
- styles: "display:flex;justify-content:space-between;align-items:center;margin-bottom:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAqB6B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
20
+ styles: "display:flex;justify-content:space-between;align-items:center;margin-bottom:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAqB6B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
21
21
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
22
  });
23
23
  const NoteAuthor = /*#__PURE__*/_styled("span", {
24
24
  target: "ee0v20j11",
25
25
  label: "NoteAuthor"
26
- })("font-size:12px;color:", colors.controlLabel, ";font-weight:500;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA4B8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
26
+ })("font-size:12px;color:", colors.controlLabel, ";font-weight:500;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA4B8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
27
27
  const AuthorSection = /*#__PURE__*/_styled("div", {
28
28
  target: "ee0v20j10",
29
29
  label: "AuthorSection"
@@ -32,13 +32,13 @@ const AuthorSection = /*#__PURE__*/_styled("div", {
32
32
  styles: "display:flex;align-items:center;gap:8px"
33
33
  } : {
34
34
  name: "1yydxi7",
35
- styles: "display:flex;align-items:center;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAkCgC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
35
+ styles: "display:flex;align-items:center;gap:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAkCgC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
36
36
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
37
  });
38
38
  const Avatar = /*#__PURE__*/_styled("div", {
39
39
  target: "ee0v20j9",
40
40
  label: "Avatar"
41
- })("width:24px;height:24px;border-radius:50%;overflow:hidden;background-color:", colors.inputBackground, ";display:flex;align-items:center;justify-content:center;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAwCyB","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
41
+ })("width:24px;height:24px;border-radius:50%;overflow:hidden;background-color:", colors.inputBackground, ";display:flex;align-items:center;justify-content:center;flex-shrink:0;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAwCyB","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
42
42
  const AvatarImage = /*#__PURE__*/_styled("img", {
43
43
  target: "ee0v20j8",
44
44
  label: "AvatarImage"
@@ -47,17 +47,17 @@ const AvatarImage = /*#__PURE__*/_styled("img", {
47
47
  styles: "width:100%;height:100%;object-fit:cover"
48
48
  } : {
49
49
  name: "4uwt2b",
50
- styles: "width:100%;height:100%;object-fit:cover/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAoD8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
50
+ styles: "width:100%;height:100%;object-fit:cover/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAoD8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
51
51
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
52
  });
53
53
  const AvatarInitials = /*#__PURE__*/_styled("span", {
54
54
  target: "ee0v20j7",
55
55
  label: "AvatarInitials"
56
- })("font-size:10px;font-weight:600;color:", colors.controlLabel, ";text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA0DkC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
56
+ })("font-size:10px;font-weight:600;color:", colors.controlLabel, ";text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA0DkC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
57
57
  const NoteTimestamp = /*#__PURE__*/_styled("span", {
58
58
  target: "ee0v20j6",
59
59
  label: "NoteTimestamp"
60
- })("font-size:11px;color:", colors.controlLabel, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAiEiC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
60
+ })("font-size:11px;color:", colors.controlLabel, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAiEiC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
61
61
  const NoteContent = /*#__PURE__*/_styled("div", {
62
62
  target: "ee0v20j5",
63
63
  label: "NoteContent"
@@ -66,17 +66,17 @@ const NoteContent = /*#__PURE__*/_styled("div", {
66
66
  styles: "margin-bottom:8px"
67
67
  } : {
68
68
  name: "5bhc30",
69
- styles: "margin-bottom:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAsE8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
69
+ styles: "margin-bottom:8px/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAsE8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
70
70
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
71
  });
72
72
  const NoteText = /*#__PURE__*/_styled("p", {
73
73
  target: "ee0v20j4",
74
74
  label: "NoteText"
75
- })("margin:0;font-size:14px;line-height:1.4;color:", colors.text, ";white-space:pre-wrap;word-wrap:break-word;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA0EyB","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
75
+ })("margin:0;font-size:14px;line-height:1.4;color:", colors.text, ";white-space:pre-wrap;word-wrap:break-word;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA0EyB","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
76
76
  const EditableText = /*#__PURE__*/_styled("textarea", {
77
77
  target: "ee0v20j3",
78
78
  label: "EditableText"
79
- })("width:100%;min-height:60px;padding:8px;border:1px solid ", colors.active, ";border-radius:3px;font-size:14px;font-family:inherit;line-height:1.4;resize:vertical;outline:none;&:focus{border-color:", colors.active, ";box-shadow:0 0 0 2px rgba(70, 151, 218, 0.1);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAmFoC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
79
+ })("width:100%;min-height:60px;padding:8px;border:1px solid ", colors.active, ";border-radius:3px;font-size:14px;font-family:inherit;line-height:1.4;resize:vertical;outline:none;&:focus{border-color:", colors.active, ";box-shadow:0 0 0 2px rgba(70, 151, 218, 0.1);}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAmFoC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
80
80
  const NoteActions = /*#__PURE__*/_styled("div", {
81
81
  target: "ee0v20j2",
82
82
  label: "NoteActions"
@@ -85,17 +85,17 @@ const NoteActions = /*#__PURE__*/_styled("div", {
85
85
  styles: "display:flex;gap:8px;align-items:center"
86
86
  } : {
87
87
  name: "197tvr9",
88
- styles: "display:flex;gap:8px;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAqG8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
88
+ styles: "display:flex;gap:8px;align-items:center/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAqG8B","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */",
89
89
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
90
  });
91
91
  const ActionButton = /*#__PURE__*/_styled("button", {
92
92
  target: "ee0v20j1",
93
93
  label: "ActionButton"
94
- })("background:none;border:none;color:", colors.controlLabel, ";font-size:12px;cursor:pointer;padding:4px 8px;border-radius:3px;transition:all ", transitions.main, ";&:hover{background-color:", colors.inputBackground, ";color:", props => props.danger ? colors.errorText : colors.active, ";}&:disabled{opacity:0.5;cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA2GkC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
94
+ })("background:none;border:none;color:", colors.controlLabel, ";font-size:12px;cursor:pointer;padding:4px 8px;border-radius:3px;transition:all ", transitions.main, ";&:hover{background-color:", colors.inputBackground, ";color:", props => props.danger ? colors.errorText : colors.active, ";}&:disabled{opacity:0.5;cursor:not-allowed;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AA2GkC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
95
95
  const ResolvedBadge = /*#__PURE__*/_styled("span", {
96
96
  target: "ee0v20j0",
97
97
  label: "ResolvedBadge"
98
- })("background-color:", colors.successText, ";color:white;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:500;text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAgIiC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    const now = new Date();\n    const diffMs = now - date;\n    const diffMins = Math.floor(diffMs / 60000);\n    const diffHours = Math.floor(diffMs / 3600000);\n    const diffDays = Math.floor(diffMs / 86400000);\n\n    if (diffMins < 1) return 'just now';\n    if (diffMins < 60) return `${diffMins}m ago`;\n    if (diffHours < 24) return `${diffHours}h ago`;\n    if (diffDays < 7) return `${diffDays}d ago`;\n\n    return date.toLocaleDateString();\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
98
+ })("background-color:", colors.successText, ";color:white;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:500;text-transform:uppercase;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/components/Editor/EditorNotesPane/NoteItem.js"],"names":[],"mappings":"AAgIiC","file":"../../../../../src/components/Editor/EditorNotesPane/NoteItem.js","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { Component } from 'react';\nimport ImmutablePropTypes from 'react-immutable-proptypes';\nimport styled from '@emotion/styled';\nimport { colors, transitions } from 'decap-cms-ui-default';\n\nconst NoteCard = styled.div`\n  background-color: ${props => (props.resolved ? colors.inputBackground : 'white')};\n  border: 1px solid ${props => (props.resolved ? colors.textFieldBorder : colors.textFieldBorder)};\n  border-radius: 4px;\n  margin-bottom: 8px;\n  padding: 12px 18px;\n  transition: all ${transitions.main};\n  opacity: ${props => (props.resolved ? 0.7 : 1)};\n\n  &:hover {\n    border-color: ${colors.active};\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n  }\n`;\n\nconst NoteHeader = styled.div`\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  margin-bottom: 8px;\n`;\n\nconst NoteAuthor = styled.span`\n  font-size: 12px;\n  color: ${colors.controlLabel};\n  font-weight: 500;\n`;\n\nconst AuthorSection = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n`;\n\nconst Avatar = styled.div`\n  width: 24px;\n  height: 24px;\n  border-radius: 50%;\n  overflow: hidden;\n  background-color: ${colors.inputBackground};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  flex-shrink: 0;\n`;\n\nconst AvatarImage = styled.img`\n  width: 100%;\n  height: 100%;\n  object-fit: cover;\n`;\n\nconst AvatarInitials = styled.span`\n  font-size: 10px;\n  font-weight: 600;\n  color: ${colors.controlLabel};\n  text-transform: uppercase;\n`;\n\nconst NoteTimestamp = styled.span`\n  font-size: 11px;\n  color: ${colors.controlLabel};\n`;\n\nconst NoteContent = styled.div`\n  margin-bottom: 8px;\n`;\n\nconst NoteText = styled.p`\n  margin: 0;\n  font-size: 14px;\n  line-height: 1.4;\n  color: ${colors.text};\n  white-space: pre-wrap;\n  word-wrap: break-word;\n`;\n\nconst EditableText = styled.textarea`\n  width: 100%;\n  min-height: 60px;\n  padding: 8px;\n  border: 1px solid ${colors.active};\n  border-radius: 3px;\n  font-size: 14px;\n  font-family: inherit;\n  line-height: 1.4;\n  resize: vertical;\n  outline: none;\n\n  &:focus {\n    border-color: ${colors.active};\n    box-shadow: 0 0 0 2px rgba(70, 151, 218, 0.1);\n  }\n`;\n\nconst NoteActions = styled.div`\n  display: flex;\n  gap: 8px;\n  align-items: center;\n`;\n\nconst ActionButton = styled.button`\n  background: none;\n  border: none;\n  color: ${colors.controlLabel};\n  font-size: 12px;\n  cursor: pointer;\n  padding: 4px 8px;\n  border-radius: 3px;\n  transition: all ${transitions.main};\n\n  &:hover {\n    background-color: ${colors.inputBackground};\n    color: ${props => (props.danger ? colors.errorText : colors.active)};\n  }\n\n  &:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n  }\n`;\n\nconst ResolvedBadge = styled.span`\n  background-color: ${colors.successText};\n  color: white;\n  font-size: 10px;\n  padding: 2px 6px;\n  border-radius: 10px;\n  font-weight: 500;\n  text-transform: uppercase;\n`;\n\nclass NoteItem extends Component {\n  static propTypes = {\n    note: ImmutablePropTypes.map.isRequired,\n    onUpdate: PropTypes.func.isRequired,\n    onDelete: PropTypes.func.isRequired,\n    onToggleResolution: PropTypes.func.isRequired,\n    user: PropTypes.object,\n    t: PropTypes.func.isRequired,\n  };\n\n  state = {\n    isEditing: false,\n    editContent: '',\n  };\n\n  isCurrentUserAuthor = () => {\n    const { note, user } = this.props;\n    const currentUserName = user?.login || user?.name || 'Anonymous';\n    return note.get('author') === currentUserName;\n  };\n\n  getAuthorInitials = author => {\n    return author\n      .split(' ')\n      .map(name => name.charAt(0))\n      .join('')\n      .slice(0, 2);\n  };\n\n  formatTimestamp = timestamp => {\n    const date = new Date(timestamp);\n    return date.toLocaleString(undefined, {\n      year: 'numeric',\n      month: 'numeric',\n      day: 'numeric',\n      hour: 'numeric',\n      minute: 'numeric',\n    });\n  };\n\n  handleEditStart = () => {\n    this.setState({\n      isEditing: true,\n      editContent: this.props.note.get('content'),\n    });\n  };\n\n  handleEditCancel = () => {\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditSave = () => {\n    const { note, onUpdate } = this.props;\n    const { editContent } = this.state;\n    const trimmedContent = editContent.trim();\n\n    if (trimmedContent && trimmedContent !== note.get('content')) {\n      onUpdate(note.get('id'), { content: trimmedContent });\n    }\n\n    this.setState({\n      isEditing: false,\n      editContent: '',\n    });\n  };\n\n  handleEditKeyDown = e => {\n    if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {\n      e.preventDefault();\n      this.handleEditSave();\n    } else if (e.key === 'Escape') {\n      e.preventDefault();\n      this.handleEditCancel();\n    }\n  };\n\n  handleDelete = () => {\n    const { note, onDelete, t } = this.props;\n    if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {\n      onDelete(note.get('id'));\n    }\n  };\n\n  handleToggleResolution = () => {\n    const { note, onToggleResolution } = this.props;\n    onToggleResolution(note.get('id'));\n  };\n  render() {\n    const { note, t } = this.props;\n    const { isEditing, editContent } = this.state;\n    const resolved = note.get('resolved');\n\n    return (\n      <NoteCard resolved={resolved}>\n        <NoteHeader>\n          <AuthorSection>\n            <Avatar>\n              {note.get('avatarUrl') ? (\n                <AvatarImage\n                  src={note.get('avatarUrl')}\n                  alt={`${note.get('author')} avatar`}\n                  onError={e => {\n                    e.target.style.display = 'none';\n                    e.target.nextSibling.style.display = 'flex';\n                  }}\n                />\n              ) : null}\n              <AvatarInitials style={{ display: note.get('avatarUrl') ? 'none' : 'flex' }}>\n                {this.getAuthorInitials(note.get('author'))}\n              </AvatarInitials>\n            </Avatar>\n            <NoteAuthor>{note.get('author')}</NoteAuthor>\n          </AuthorSection>\n          <div style={{ display: 'flex', alignItems: 'center', gap: '8px' }}>\n            {resolved && <ResolvedBadge>resolved</ResolvedBadge>}\n            <NoteTimestamp>{this.formatTimestamp(note.get('timestamp'))}</NoteTimestamp>\n          </div>\n        </NoteHeader>\n\n        <NoteContent>\n          {isEditing ? (\n            <EditableText\n              value={editContent}\n              onChange={e => this.setState({ editContent: e.target.value })}\n              onKeyDown={this.handleEditKeyDown}\n              placeholder={t('editor.editorNotesPane.editPlaceholder')}\n              autoFocus\n            />\n          ) : (\n            <NoteText>{note.get('content')}</NoteText>\n          )}\n        </NoteContent>\n\n        <NoteActions>\n          {isEditing ? (\n            <>\n              <ActionButton onClick={this.handleEditSave}>\n                {t('editor.editorNotesPane.save')}\n              </ActionButton>\n              <ActionButton onClick={this.handleEditCancel}>\n                {t('editor.editorNotesPane.cancel')}\n              </ActionButton>\n            </>\n          ) : (\n            <>\n              {!resolved && (\n                <ActionButton onClick={this.handleEditStart} disabled={!this.isCurrentUserAuthor()}>\n                  {t('editor.editorNotesPane.edit')}\n                </ActionButton>\n              )}\n              <ActionButton\n                onClick={this.handleToggleResolution}\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {resolved\n                  ? t('editor.editorNotesPane.unresolve')\n                  : t('editor.editorNotesPane.resolve')}\n              </ActionButton>\n              <ActionButton\n                onClick={this.handleDelete}\n                danger\n                disabled={!this.isCurrentUserAuthor()}\n              >\n                {t('editor.editorNotesPane.delete')}\n              </ActionButton>\n            </>\n          )}\n        </NoteActions>\n      </NoteCard>\n    );\n  }\n}\n\nexport default NoteItem;\n"]} */"));
99
99
  class NoteItem extends Component {
100
100
  static propTypes = {
101
101
  note: ImmutablePropTypes.map.isRequired,
@@ -122,16 +122,13 @@ class NoteItem extends Component {
122
122
  };
123
123
  formatTimestamp = timestamp => {
124
124
  const date = new Date(timestamp);
125
- const now = new Date();
126
- const diffMs = now - date;
127
- const diffMins = Math.floor(diffMs / 60000);
128
- const diffHours = Math.floor(diffMs / 3600000);
129
- const diffDays = Math.floor(diffMs / 86400000);
130
- if (diffMins < 1) return 'just now';
131
- if (diffMins < 60) return `${diffMins}m ago`;
132
- if (diffHours < 24) return `${diffHours}h ago`;
133
- if (diffDays < 7) return `${diffDays}d ago`;
134
- return date.toLocaleDateString();
125
+ return date.toLocaleString(undefined, {
126
+ year: 'numeric',
127
+ month: 'numeric',
128
+ day: 'numeric',
129
+ hour: 'numeric',
130
+ minute: 'numeric'
131
+ });
135
132
  };
136
133
  handleEditStart = () => {
137
134
  this.setState({