decap-cms-core 3.8.1 → 3.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,247 @@
1
+ import _styled from "@emotion/styled/base";
2
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
3
+ import PropTypes from 'prop-types';
4
+ import React, { Component } from 'react';
5
+ import ImmutablePropTypes from 'react-immutable-proptypes';
6
+ import { colors, transitions } from 'decap-cms-ui-default';
7
+ import { jsx as ___EmotionJSX } from "@emotion/react";
8
+ const NoteCard = /*#__PURE__*/_styled("div", {
9
+ target: "ee0v20j13",
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"]} */"));
12
+ const NoteHeader = /*#__PURE__*/_styled("div", {
13
+ target: "ee0v20j12",
14
+ label: "NoteHeader"
15
+ })(process.env.NODE_ENV === "production" ? {
16
+ name: "rcj3va",
17
+ styles: "display:flex;justify-content:space-between;align-items:center;margin-bottom:8px"
18
+ } : {
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"]} */",
21
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
+ });
23
+ const NoteAuthor = /*#__PURE__*/_styled("span", {
24
+ target: "ee0v20j11",
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"]} */"));
27
+ const AuthorSection = /*#__PURE__*/_styled("div", {
28
+ target: "ee0v20j10",
29
+ label: "AuthorSection"
30
+ })(process.env.NODE_ENV === "production" ? {
31
+ name: "1yydxi7",
32
+ styles: "display:flex;align-items:center;gap:8px"
33
+ } : {
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"]} */",
36
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
+ });
38
+ const Avatar = /*#__PURE__*/_styled("div", {
39
+ target: "ee0v20j9",
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"]} */"));
42
+ const AvatarImage = /*#__PURE__*/_styled("img", {
43
+ target: "ee0v20j8",
44
+ label: "AvatarImage"
45
+ })(process.env.NODE_ENV === "production" ? {
46
+ name: "4uwt2b",
47
+ styles: "width:100%;height:100%;object-fit:cover"
48
+ } : {
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"]} */",
51
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
52
+ });
53
+ const AvatarInitials = /*#__PURE__*/_styled("span", {
54
+ target: "ee0v20j7",
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"]} */"));
57
+ const NoteTimestamp = /*#__PURE__*/_styled("span", {
58
+ target: "ee0v20j6",
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"]} */"));
61
+ const NoteContent = /*#__PURE__*/_styled("div", {
62
+ target: "ee0v20j5",
63
+ label: "NoteContent"
64
+ })(process.env.NODE_ENV === "production" ? {
65
+ name: "5bhc30",
66
+ styles: "margin-bottom:8px"
67
+ } : {
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"]} */",
70
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
71
+ });
72
+ const NoteText = /*#__PURE__*/_styled("p", {
73
+ target: "ee0v20j4",
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"]} */"));
76
+ const EditableText = /*#__PURE__*/_styled("textarea", {
77
+ target: "ee0v20j3",
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"]} */"));
80
+ const NoteActions = /*#__PURE__*/_styled("div", {
81
+ target: "ee0v20j2",
82
+ label: "NoteActions"
83
+ })(process.env.NODE_ENV === "production" ? {
84
+ name: "197tvr9",
85
+ styles: "display:flex;gap:8px;align-items:center"
86
+ } : {
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"]} */",
89
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
90
+ });
91
+ const ActionButton = /*#__PURE__*/_styled("button", {
92
+ target: "ee0v20j1",
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"]} */"));
95
+ const ResolvedBadge = /*#__PURE__*/_styled("span", {
96
+ target: "ee0v20j0",
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"]} */"));
99
+ class NoteItem extends Component {
100
+ static propTypes = {
101
+ note: ImmutablePropTypes.map.isRequired,
102
+ onUpdate: PropTypes.func.isRequired,
103
+ onDelete: PropTypes.func.isRequired,
104
+ onToggleResolution: PropTypes.func.isRequired,
105
+ user: PropTypes.object,
106
+ t: PropTypes.func.isRequired
107
+ };
108
+ state = {
109
+ isEditing: false,
110
+ editContent: ''
111
+ };
112
+ isCurrentUserAuthor = () => {
113
+ const {
114
+ note,
115
+ user
116
+ } = this.props;
117
+ const currentUserName = user?.login || user?.name || 'Anonymous';
118
+ return note.get('author') === currentUserName;
119
+ };
120
+ getAuthorInitials = author => {
121
+ return author.split(' ').map(name => name.charAt(0)).join('').slice(0, 2);
122
+ };
123
+ formatTimestamp = timestamp => {
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();
135
+ };
136
+ handleEditStart = () => {
137
+ this.setState({
138
+ isEditing: true,
139
+ editContent: this.props.note.get('content')
140
+ });
141
+ };
142
+ handleEditCancel = () => {
143
+ this.setState({
144
+ isEditing: false,
145
+ editContent: ''
146
+ });
147
+ };
148
+ handleEditSave = () => {
149
+ const {
150
+ note,
151
+ onUpdate
152
+ } = this.props;
153
+ const {
154
+ editContent
155
+ } = this.state;
156
+ const trimmedContent = editContent.trim();
157
+ if (trimmedContent && trimmedContent !== note.get('content')) {
158
+ onUpdate(note.get('id'), {
159
+ content: trimmedContent
160
+ });
161
+ }
162
+ this.setState({
163
+ isEditing: false,
164
+ editContent: ''
165
+ });
166
+ };
167
+ handleEditKeyDown = e => {
168
+ if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) {
169
+ e.preventDefault();
170
+ this.handleEditSave();
171
+ } else if (e.key === 'Escape') {
172
+ e.preventDefault();
173
+ this.handleEditCancel();
174
+ }
175
+ };
176
+ handleDelete = () => {
177
+ const {
178
+ note,
179
+ onDelete,
180
+ t
181
+ } = this.props;
182
+ if (window.confirm(t('editor.editorNotesPane.confirmDelete'))) {
183
+ onDelete(note.get('id'));
184
+ }
185
+ };
186
+ handleToggleResolution = () => {
187
+ const {
188
+ note,
189
+ onToggleResolution
190
+ } = this.props;
191
+ onToggleResolution(note.get('id'));
192
+ };
193
+ render() {
194
+ const {
195
+ note,
196
+ t
197
+ } = this.props;
198
+ const {
199
+ isEditing,
200
+ editContent
201
+ } = this.state;
202
+ const resolved = note.get('resolved');
203
+ return ___EmotionJSX(NoteCard, {
204
+ resolved: resolved
205
+ }, ___EmotionJSX(NoteHeader, null, ___EmotionJSX(AuthorSection, null, ___EmotionJSX(Avatar, null, note.get('avatarUrl') ? ___EmotionJSX(AvatarImage, {
206
+ src: note.get('avatarUrl'),
207
+ alt: `${note.get('author')} avatar`,
208
+ onError: e => {
209
+ e.target.style.display = 'none';
210
+ e.target.nextSibling.style.display = 'flex';
211
+ }
212
+ }) : null, ___EmotionJSX(AvatarInitials, {
213
+ style: {
214
+ display: note.get('avatarUrl') ? 'none' : 'flex'
215
+ }
216
+ }, this.getAuthorInitials(note.get('author')))), ___EmotionJSX(NoteAuthor, null, note.get('author'))), ___EmotionJSX("div", {
217
+ style: {
218
+ display: 'flex',
219
+ alignItems: 'center',
220
+ gap: '8px'
221
+ }
222
+ }, resolved && ___EmotionJSX(ResolvedBadge, null, "resolved"), ___EmotionJSX(NoteTimestamp, null, this.formatTimestamp(note.get('timestamp'))))), ___EmotionJSX(NoteContent, null, isEditing ? ___EmotionJSX(EditableText, {
223
+ value: editContent,
224
+ onChange: e => this.setState({
225
+ editContent: e.target.value
226
+ }),
227
+ onKeyDown: this.handleEditKeyDown,
228
+ placeholder: t('editor.editorNotesPane.editPlaceholder'),
229
+ autoFocus: true
230
+ }) : ___EmotionJSX(NoteText, null, note.get('content'))), ___EmotionJSX(NoteActions, null, isEditing ? ___EmotionJSX(React.Fragment, null, ___EmotionJSX(ActionButton, {
231
+ onClick: this.handleEditSave
232
+ }, t('editor.editorNotesPane.save')), ___EmotionJSX(ActionButton, {
233
+ onClick: this.handleEditCancel
234
+ }, t('editor.editorNotesPane.cancel'))) : ___EmotionJSX(React.Fragment, null, !resolved && ___EmotionJSX(ActionButton, {
235
+ onClick: this.handleEditStart,
236
+ disabled: !this.isCurrentUserAuthor()
237
+ }, t('editor.editorNotesPane.edit')), ___EmotionJSX(ActionButton, {
238
+ onClick: this.handleToggleResolution,
239
+ disabled: !this.isCurrentUserAuthor()
240
+ }, resolved ? t('editor.editorNotesPane.unresolve') : t('editor.editorNotesPane.resolve')), ___EmotionJSX(ActionButton, {
241
+ onClick: this.handleDelete,
242
+ danger: true,
243
+ disabled: !this.isCurrentUserAuthor()
244
+ }, t('editor.editorNotesPane.delete')))));
245
+ }
246
+ }
247
+ export default NoteItem;