@krainovsd/markdown-editor 0.0.3 → 0.1.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.
Files changed (231) hide show
  1. package/README.md +21 -1
  2. package/lib/cjs/index-Byjf17iv.js +501 -0
  3. package/lib/cjs/index-Byjf17iv.js.map +1 -0
  4. package/lib/cjs/index-lPo-3QDL.js +1374 -0
  5. package/lib/cjs/index-lPo-3QDL.js.map +1 -0
  6. package/lib/cjs/index.js +15 -0
  7. package/lib/cjs/index.js.map +1 -0
  8. package/lib/esm/extensions/compartments/index.js +8 -0
  9. package/lib/esm/extensions/compartments/index.js.map +1 -0
  10. package/lib/esm/extensions/init-extensions.js +45 -0
  11. package/lib/esm/extensions/init-extensions.js.map +1 -0
  12. package/lib/esm/extensions/keymaps/init-key-map.js +91 -0
  13. package/lib/esm/extensions/keymaps/init-key-map.js.map +1 -0
  14. package/lib/esm/extensions/listeners/get-change-event.js +14 -0
  15. package/lib/esm/extensions/listeners/get-change-event.js.map +1 -0
  16. package/lib/esm/extensions/listeners/get-focus-event.js +16 -0
  17. package/lib/esm/extensions/listeners/get-focus-event.js.map +1 -0
  18. package/lib/esm/extensions/listeners/init-listeners.js +9 -0
  19. package/lib/esm/extensions/listeners/init-listeners.js.map +1 -0
  20. package/lib/esm/extensions/markdown/blockquote/blockquote-constants.js +6 -0
  21. package/lib/esm/extensions/markdown/blockquote/blockquote-constants.js.map +1 -0
  22. package/lib/esm/extensions/markdown/blockquote/blockquote-decoration.js +99 -0
  23. package/lib/esm/extensions/markdown/blockquote/blockquote-decoration.js.map +1 -0
  24. package/lib/esm/extensions/markdown/blockquote/blockquote-widget.js +25 -0
  25. package/lib/esm/extensions/markdown/blockquote/blockquote-widget.js.map +1 -0
  26. package/lib/esm/extensions/markdown/bold/bold-constants.js +5 -0
  27. package/lib/esm/extensions/markdown/bold/bold-constants.js.map +1 -0
  28. package/lib/esm/extensions/markdown/bold/bold-decoration.js +41 -0
  29. package/lib/esm/extensions/markdown/bold/bold-decoration.js.map +1 -0
  30. package/lib/esm/extensions/markdown/code/code-constants.js +6 -0
  31. package/lib/esm/extensions/markdown/code/code-constants.js.map +1 -0
  32. package/lib/esm/extensions/markdown/code/code-decoration.js +109 -0
  33. package/lib/esm/extensions/markdown/code/code-decoration.js.map +1 -0
  34. package/lib/esm/extensions/markdown/code/code-widget.js +83 -0
  35. package/lib/esm/extensions/markdown/code/code-widget.js.map +1 -0
  36. package/lib/esm/extensions/markdown/header/header-constants.js +6 -0
  37. package/lib/esm/extensions/markdown/header/header-constants.js.map +1 -0
  38. package/lib/esm/extensions/markdown/header/header-decoration.js +64 -0
  39. package/lib/esm/extensions/markdown/header/header-decoration.js.map +1 -0
  40. package/lib/esm/extensions/markdown/horizontal/horizontal-constants.js +4 -0
  41. package/lib/esm/extensions/markdown/horizontal/horizontal-constants.js.map +1 -0
  42. package/lib/esm/extensions/markdown/horizontal/horizontal-decoration.js +31 -0
  43. package/lib/esm/extensions/markdown/horizontal/horizontal-decoration.js.map +1 -0
  44. package/lib/esm/extensions/markdown/image/image-constants.js +8 -0
  45. package/lib/esm/extensions/markdown/image/image-constants.js.map +1 -0
  46. package/lib/esm/extensions/markdown/image/image-decoration.js +75 -0
  47. package/lib/esm/extensions/markdown/image/image-decoration.js.map +1 -0
  48. package/lib/esm/extensions/markdown/image/image-widget.js +184 -0
  49. package/lib/esm/extensions/markdown/image/image-widget.js.map +1 -0
  50. package/lib/esm/extensions/markdown/index.js +2 -0
  51. package/lib/esm/extensions/markdown/index.js.map +1 -0
  52. package/lib/esm/extensions/markdown/init-markdown.js +18 -0
  53. package/lib/esm/extensions/markdown/init-markdown.js.map +1 -0
  54. package/lib/esm/extensions/markdown/italic/italic-constants.js +5 -0
  55. package/lib/esm/extensions/markdown/italic/italic-constants.js.map +1 -0
  56. package/lib/esm/extensions/markdown/italic/italic-decoration.js +77 -0
  57. package/lib/esm/extensions/markdown/italic/italic-decoration.js.map +1 -0
  58. package/lib/esm/extensions/markdown/link/auto-link-decoration.js +24 -0
  59. package/lib/esm/extensions/markdown/link/auto-link-decoration.js.map +1 -0
  60. package/lib/esm/extensions/markdown/link/link-constants.js +10 -0
  61. package/lib/esm/extensions/markdown/link/link-constants.js.map +1 -0
  62. package/lib/esm/extensions/markdown/link/link-decoration.js +51 -0
  63. package/lib/esm/extensions/markdown/link/link-decoration.js.map +1 -0
  64. package/lib/esm/extensions/markdown/link/link-label-decoration.js +22 -0
  65. package/lib/esm/extensions/markdown/link/link-label-decoration.js.map +1 -0
  66. package/lib/esm/extensions/markdown/link/link-widget.js +144 -0
  67. package/lib/esm/extensions/markdown/link/link-widget.js.map +1 -0
  68. package/lib/esm/extensions/markdown/list/list-constants.js +7 -0
  69. package/lib/esm/extensions/markdown/list/list-constants.js.map +1 -0
  70. package/lib/esm/extensions/markdown/list/list-decoration.js +38 -0
  71. package/lib/esm/extensions/markdown/list/list-decoration.js.map +1 -0
  72. package/lib/esm/extensions/markdown/list/list-widget.js +33 -0
  73. package/lib/esm/extensions/markdown/list/list-widget.js.map +1 -0
  74. package/lib/esm/extensions/markdown/markdown-decoration.js +105 -0
  75. package/lib/esm/extensions/markdown/markdown-decoration.js.map +1 -0
  76. package/lib/esm/extensions/markdown/markdown-parser.js +6 -0
  77. package/lib/esm/extensions/markdown/markdown-parser.js.map +1 -0
  78. package/lib/esm/extensions/markdown/mention/mention-constants.js +6 -0
  79. package/lib/esm/extensions/markdown/mention/mention-constants.js.map +1 -0
  80. package/lib/esm/extensions/markdown/mention/mention-decoration.js +37 -0
  81. package/lib/esm/extensions/markdown/mention/mention-decoration.js.map +1 -0
  82. package/lib/esm/extensions/markdown/mention/mention-parser.js +25 -0
  83. package/lib/esm/extensions/markdown/mention/mention-parser.js.map +1 -0
  84. package/lib/esm/extensions/markdown/strike-through/strike-through-constants.js +4 -0
  85. package/lib/esm/extensions/markdown/strike-through/strike-through-constants.js.map +1 -0
  86. package/lib/esm/extensions/markdown/strike-through/strike-through-decoration.js +32 -0
  87. package/lib/esm/extensions/markdown/strike-through/strike-through-decoration.js.map +1 -0
  88. package/lib/esm/extensions/markdown/styles.module.scss.js +8 -0
  89. package/lib/esm/extensions/markdown/styles.module.scss.js.map +1 -0
  90. package/lib/esm/extensions/markdown/todo/todo-constants.js +6 -0
  91. package/lib/esm/extensions/markdown/todo/todo-constants.js.map +1 -0
  92. package/lib/esm/extensions/markdown/todo/todo-decoration.js +35 -0
  93. package/lib/esm/extensions/markdown/todo/todo-decoration.js.map +1 -0
  94. package/lib/esm/extensions/markdown/todo/todo-widget.js +51 -0
  95. package/lib/esm/extensions/markdown/todo/todo-widget.js.map +1 -0
  96. package/lib/esm/extensions/settings/init-settings.js +19 -0
  97. package/lib/esm/extensions/settings/init-settings.js.map +1 -0
  98. package/lib/esm/extensions/theme/init-theme.js +15 -0
  99. package/lib/esm/extensions/theme/init-theme.js.map +1 -0
  100. package/lib/esm/extensions/theme/theme-constants.js +17 -0
  101. package/lib/esm/extensions/theme/theme-constants.js.map +1 -0
  102. package/lib/esm/extensions/theme/themes/get-dark-theme.js +40 -0
  103. package/lib/esm/extensions/theme/themes/get-dark-theme.js.map +1 -0
  104. package/lib/esm/extensions/theme/themes/get-highlight-template.js +35 -0
  105. package/lib/esm/extensions/theme/themes/get-highlight-template.js.map +1 -0
  106. package/lib/esm/extensions/theme/themes/get-light-theme.js +40 -0
  107. package/lib/esm/extensions/theme/themes/get-light-theme.js.map +1 -0
  108. package/lib/esm/extensions/theme/themes/get-theme-template.js +69 -0
  109. package/lib/esm/extensions/theme/themes/get-theme-template.js.map +1 -0
  110. package/lib/esm/index.js +1 -1
  111. package/lib/esm/index.js.map +1 -1
  112. package/lib/esm/lib/utils/copy-to-clipboard.js +35 -0
  113. package/lib/esm/lib/utils/copy-to-clipboard.js.map +1 -0
  114. package/lib/esm/lib/utils/get-decoration.js +24 -0
  115. package/lib/esm/lib/utils/get-decoration.js.map +1 -0
  116. package/lib/esm/lib/utils/is-in-range.js +8 -0
  117. package/lib/esm/lib/utils/is-in-range.js.map +1 -0
  118. package/lib/esm/lib/utils/is-range-overlap.js +6 -0
  119. package/lib/esm/lib/utils/is-range-overlap.js.map +1 -0
  120. package/lib/esm/lib/utils/tick.js +22 -0
  121. package/lib/esm/lib/utils/tick.js.map +1 -0
  122. package/lib/esm/module/Editor/Editor.js +91 -0
  123. package/lib/esm/module/Editor/Editor.js.map +1 -0
  124. package/lib/esm/module/Editor/lib/init-editor-provider.js +32 -0
  125. package/lib/esm/module/Editor/lib/init-editor-provider.js.map +1 -0
  126. package/lib/esm/module/Editor/lib/init-editor-state.js +18 -0
  127. package/lib/esm/module/Editor/lib/init-editor-state.js.map +1 -0
  128. package/lib/esm/module/Editor/lib/init-editor.js +27 -0
  129. package/lib/esm/module/Editor/lib/init-editor.js.map +1 -0
  130. package/lib/esm/node_modules/.pnpm/style-inject@0.3.0/node_modules/style-inject/dist/style-inject.es.js +29 -0
  131. package/lib/esm/node_modules/.pnpm/style-inject@0.3.0/node_modules/style-inject/dist/style-inject.es.js.map +1 -0
  132. package/lib/index.d.ts +137 -0
  133. package/package.json +32 -24
  134. package/lib/cjs/bundle.cjs +0 -2
  135. package/lib/cjs/bundle.cjs.map +0 -1
  136. package/tmp/app/helpers/common-test.d.ts +0 -1
  137. package/tmp/app/helpers/full-example.d.ts +0 -1
  138. package/tmp/app/helpers/index.d.ts +0 -5
  139. package/tmp/app/helpers/random-color.d.ts +0 -1
  140. package/tmp/app/helpers/random-string.d.ts +0 -1
  141. package/tmp/app/helpers/stress-test.d.ts +0 -1
  142. package/tmp/app/index.d.ts +0 -1
  143. package/tmp/extensions/compartments/index.d.ts +0 -4
  144. package/tmp/extensions/index.d.ts +0 -8
  145. package/tmp/extensions/init-extensions.d.ts +0 -14
  146. package/tmp/extensions/keymaps/bold-keymap.d.ts +0 -2
  147. package/tmp/extensions/keymaps/index.d.ts +0 -1
  148. package/tmp/extensions/keymaps/init-key-map.d.ts +0 -9
  149. package/tmp/extensions/keymaps/italic-key-map.d.ts +0 -2
  150. package/tmp/extensions/keymaps/line-through-key-map.d.ts +0 -2
  151. package/tmp/extensions/keymaps/underline-key-map.d.ts +0 -2
  152. package/tmp/extensions/listeners/get-change-event.d.ts +0 -6
  153. package/tmp/extensions/listeners/get-focus-event.d.ts +0 -8
  154. package/tmp/extensions/listeners/index.d.ts +0 -3
  155. package/tmp/extensions/listeners/init-listeners.d.ts +0 -4
  156. package/tmp/extensions/markdown/blockquote/blockquote-constants.d.ts +0 -3
  157. package/tmp/extensions/markdown/blockquote/blockquote-decoration.d.ts +0 -2
  158. package/tmp/extensions/markdown/blockquote/blockquote-widget.d.ts +0 -6
  159. package/tmp/extensions/markdown/blockquote/index.d.ts +0 -1
  160. package/tmp/extensions/markdown/bold/bold-constants.d.ts +0 -2
  161. package/tmp/extensions/markdown/bold/bold-decoration.d.ts +0 -2
  162. package/tmp/extensions/markdown/bold/index.d.ts +0 -1
  163. package/tmp/extensions/markdown/code/code-constants.d.ts +0 -3
  164. package/tmp/extensions/markdown/code/code-decoration.d.ts +0 -2
  165. package/tmp/extensions/markdown/code/code-widget.d.ts +0 -13
  166. package/tmp/extensions/markdown/code/index.d.ts +0 -1
  167. package/tmp/extensions/markdown/header/header-constants.d.ts +0 -3
  168. package/tmp/extensions/markdown/header/header-decoration.d.ts +0 -2
  169. package/tmp/extensions/markdown/header/index.d.ts +0 -1
  170. package/tmp/extensions/markdown/horizontal/horizontal-constants.d.ts +0 -1
  171. package/tmp/extensions/markdown/horizontal/horizontal-decoration.d.ts +0 -2
  172. package/tmp/extensions/markdown/horizontal/index.d.ts +0 -1
  173. package/tmp/extensions/markdown/image/image-constants.d.ts +0 -5
  174. package/tmp/extensions/markdown/image/image-decoration.d.ts +0 -2
  175. package/tmp/extensions/markdown/image/image-widget.d.ts +0 -15
  176. package/tmp/extensions/markdown/image/index.d.ts +0 -1
  177. package/tmp/extensions/markdown/index.d.ts +0 -2
  178. package/tmp/extensions/markdown/init-markdown.d.ts +0 -3
  179. package/tmp/extensions/markdown/italic/index.d.ts +0 -1
  180. package/tmp/extensions/markdown/italic/italic-constants.d.ts +0 -2
  181. package/tmp/extensions/markdown/italic/italic-decoration.d.ts +0 -2
  182. package/tmp/extensions/markdown/link/auto-link-decoration.d.ts +0 -2
  183. package/tmp/extensions/markdown/link/index.d.ts +0 -2
  184. package/tmp/extensions/markdown/link/link-constants.d.ts +0 -7
  185. package/tmp/extensions/markdown/link/link-decoration.d.ts +0 -2
  186. package/tmp/extensions/markdown/link/link-label-decoration.d.ts +0 -2
  187. package/tmp/extensions/markdown/link/link-widget.d.ts +0 -17
  188. package/tmp/extensions/markdown/list/index.d.ts +0 -1
  189. package/tmp/extensions/markdown/list/list-constants.d.ts +0 -4
  190. package/tmp/extensions/markdown/list/list-decoration.d.ts +0 -2
  191. package/tmp/extensions/markdown/list/list-widget.d.ts +0 -7
  192. package/tmp/extensions/markdown/markdown-decoration.d.ts +0 -5
  193. package/tmp/extensions/markdown/markdown-types.d.ts +0 -24
  194. package/tmp/extensions/markdown/mention/index.d.ts +0 -1
  195. package/tmp/extensions/markdown/mention/mention-constants.d.ts +0 -3
  196. package/tmp/extensions/markdown/mention/mention-decoration.d.ts +0 -2
  197. package/tmp/extensions/markdown/mention/mention-parser.d.ts +0 -2
  198. package/tmp/extensions/markdown/strike-through/index.d.ts +0 -1
  199. package/tmp/extensions/markdown/strike-through/strike-through-constants.d.ts +0 -1
  200. package/tmp/extensions/markdown/strike-through/strike-through-decoration.d.ts +0 -2
  201. package/tmp/extensions/markdown/todo/index.d.ts +0 -1
  202. package/tmp/extensions/markdown/todo/todo-constants.d.ts +0 -3
  203. package/tmp/extensions/markdown/todo/todo-decoration.d.ts +0 -2
  204. package/tmp/extensions/markdown/todo/todo-widget.d.ts +0 -11
  205. package/tmp/extensions/settings/index.d.ts +0 -1
  206. package/tmp/extensions/settings/init-settings.d.ts +0 -6
  207. package/tmp/extensions/theme/index.d.ts +0 -4
  208. package/tmp/extensions/theme/init-theme.d.ts +0 -3
  209. package/tmp/extensions/theme/theme-constants.d.ts +0 -14
  210. package/tmp/extensions/theme/theme-types.d.ts +0 -36
  211. package/tmp/extensions/theme/themes/get-dark-theme.d.ts +0 -2
  212. package/tmp/extensions/theme/themes/get-highlight-template.d.ts +0 -6
  213. package/tmp/extensions/theme/themes/get-light-theme.d.ts +0 -2
  214. package/tmp/extensions/theme/themes/get-theme-template.d.ts +0 -2
  215. package/tmp/extensions/theme/themes/index.d.ts +0 -2
  216. package/tmp/index.d.ts +0 -3
  217. package/tmp/lib/index.d.ts +0 -1
  218. package/tmp/lib/utils/copy-to-clipboard.d.ts +0 -1
  219. package/tmp/lib/utils/get-decoration.d.ts +0 -26
  220. package/tmp/lib/utils/index.d.ts +0 -5
  221. package/tmp/lib/utils/is-in-range.d.ts +0 -2
  222. package/tmp/lib/utils/is-range-overlap.d.ts +0 -1
  223. package/tmp/lib/utils/tick.d.ts +0 -10
  224. package/tmp/module/Editor/Editor.d.ts +0 -17
  225. package/tmp/module/Editor/Editor.types.d.ts +0 -13
  226. package/tmp/module/Editor/index.d.ts +0 -3
  227. package/tmp/module/Editor/lib/index.d.ts +0 -1
  228. package/tmp/module/Editor/lib/init-editor-provider.d.ts +0 -10
  229. package/tmp/module/Editor/lib/init-editor-state.d.ts +0 -7
  230. package/tmp/module/Editor/lib/init-editor.d.ts +0 -7
  231. package/tmp/module/index.d.ts +0 -1
@@ -0,0 +1,144 @@
1
+ import { WidgetType } from '@codemirror/view';
2
+ import '../../compartments/index.js';
3
+ import '@codemirror/language';
4
+ import '@lezer/highlight';
5
+ import { CLASSES } from '../../theme/theme-constants.js';
6
+ import { tick } from '../../../lib/utils/tick.js';
7
+ import styles from '../styles.module.scss.js';
8
+
9
+ class LinkWidget extends WidgetType {
10
+ text;
11
+ link;
12
+ type;
13
+ view;
14
+ constructor(text, link, type) {
15
+ super();
16
+ this.text = text;
17
+ this.link = link;
18
+ this.type = type;
19
+ }
20
+ /** recursively find the link text node in line */
21
+ getTextNode(line) {
22
+ if (!line)
23
+ return null;
24
+ let textNode = null;
25
+ for (const node of Array.from(line.childNodes)) {
26
+ if (node.nodeType !== 3) {
27
+ const innerNode = this.getTextNode(node);
28
+ if (innerNode) {
29
+ textNode = innerNode;
30
+ break;
31
+ }
32
+ continue;
33
+ }
34
+ const textContent = node.textContent;
35
+ if (textContent && textContent.includes(this.link)) {
36
+ textNode = node;
37
+ break;
38
+ }
39
+ }
40
+ return textNode;
41
+ }
42
+ getMinLength() {
43
+ let startPosition = 0;
44
+ if (this.type === "link")
45
+ startPosition = 3 + this.text.length;
46
+ if (this.type === "auto")
47
+ startPosition = 1;
48
+ const endPosition = startPosition + this.link.length;
49
+ return endPosition;
50
+ }
51
+ /** check that the text node is correct node */
52
+ isCorrectNode(node) {
53
+ if (!node)
54
+ return false;
55
+ const textContent = node.textContent;
56
+ const minLength = this.getMinLength();
57
+ return Boolean(textContent && node.nodeType === 3 && textContent.length >= minLength);
58
+ }
59
+ selectLink(node, selection) {
60
+ const startPosition = node.textContent?.indexOf?.(this.link) || 0;
61
+ const endPosition = startPosition + this.link.length;
62
+ const range = document.createRange();
63
+ range.setStart(node, startPosition);
64
+ range.setEnd(node, endPosition);
65
+ selection.removeAllRanges();
66
+ selection.addRange(range);
67
+ }
68
+ handleClick(event) {
69
+ if (!this.view)
70
+ return;
71
+ /** open the link if has special key or the view is readonly */
72
+ const contentEditable = this.view.contentDOM.getAttribute("contenteditable");
73
+ const isReadonly = !contentEditable || contentEditable === "false";
74
+ if (event.shiftKey || event.ctrlKey || event.altKey || event.metaKey || isReadonly) {
75
+ if (event.type === "mousedown") {
76
+ const target = event.target;
77
+ window.open(target.href, "_blank");
78
+ }
79
+ return;
80
+ }
81
+ event.stopPropagation();
82
+ event.preventDefault();
83
+ const target = event.target;
84
+ const parent = target.parentNode;
85
+ let line = parent;
86
+ /** recursively find line that contains link */
87
+ while (line && !line.classList.contains("cm-line")) {
88
+ line = line.parentNode;
89
+ }
90
+ const editor = this.view.dom.querySelector(".cm-content");
91
+ const selection = window.getSelection();
92
+ if (!selection || !editor || !parent)
93
+ return;
94
+ const range = document.createRange();
95
+ range.selectNode(target);
96
+ range.collapse(true);
97
+ selection.removeAllRanges();
98
+ selection.addRange(range);
99
+ /** trick for correct select the link by click when the view is not focused */
100
+ void tick({ delay: 0 }).then(() => {
101
+ if (selection && selection.anchorNode?.nodeType !== 3) {
102
+ selection.removeAllRanges();
103
+ selection.addRange(range);
104
+ }
105
+ });
106
+ /** wait for the widget to disappear and link will be visible */
107
+ void tick({
108
+ delay: 0,
109
+ maxDeep: 5,
110
+ delayGetter: (deep) => {
111
+ return deep > 1 ? 10 : 5;
112
+ },
113
+ recursiveCondition: () => {
114
+ const textNode = this.getTextNode(line);
115
+ return this.isCorrectNode(textNode);
116
+ },
117
+ })
118
+ .then(() => {
119
+ const textNode = this.getTextNode(line);
120
+ if (this.isCorrectNode(textNode))
121
+ this.selectLink(textNode, selection);
122
+ });
123
+ return false;
124
+ }
125
+ toDOM(view) {
126
+ this.view = view;
127
+ const anchor = document.createElement("a");
128
+ anchor.classList.add(styles.link);
129
+ anchor.classList.add(CLASSES.link);
130
+ anchor.target = "_blank";
131
+ anchor.textContent = this.text;
132
+ anchor.href = this.link;
133
+ anchor.addEventListener("mousedown", this.handleClick.bind(this));
134
+ anchor.addEventListener("click", this.handleClick.bind(this));
135
+ return anchor;
136
+ }
137
+ destroy(dom) {
138
+ dom.removeEventListener("mousedown", this.handleClick.bind(this));
139
+ dom.removeEventListener("click", this.handleClick.bind(this));
140
+ }
141
+ }
142
+
143
+ export { LinkWidget };
144
+ //# sourceMappingURL=link-widget.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"link-widget.js","sources":["../../../../../src/extensions/markdown/link/link-widget.ts"],"sourcesContent":["import { type EditorView, WidgetType } from \"@codemirror/view\";\nimport { CLASSES } from \"@/extensions/theme\";\nimport { utils } from \"@/lib\";\nimport styles from \"../styles.module.scss\";\n\nexport class LinkWidget extends WidgetType {\n view: EditorView | undefined;\n\n constructor(\n private readonly text: string,\n private readonly link: string,\n private readonly type: \"link\" | \"auto\",\n ) {\n super();\n }\n\n /** recursively find the link text node in line */\n getTextNode(line: ChildNode | Node | null | undefined): ChildNode | null {\n if (!line) return null;\n\n let textNode: ChildNode | null = null;\n\n for (const node of Array.from(line.childNodes)) {\n if (node.nodeType !== 3) {\n const innerNode = this.getTextNode(node);\n if (innerNode) {\n textNode = innerNode;\n break;\n }\n\n continue;\n }\n\n const textContent = node.textContent;\n if (textContent && textContent.includes(this.link)) {\n textNode = node;\n break;\n }\n }\n\n return textNode;\n }\n\n getMinLength() {\n let startPosition: number = 0;\n if (this.type === \"link\") startPosition = 3 + this.text.length;\n if (this.type === \"auto\") startPosition = 1;\n const endPosition = startPosition + this.link.length;\n\n return endPosition;\n }\n\n /** check that the text node is correct node */\n isCorrectNode(node: ChildNode | Node | null | undefined): node is ChildNode | Node {\n if (!node) return false;\n\n const textContent = node.textContent;\n const minLength = this.getMinLength();\n\n return Boolean(textContent && node.nodeType === 3 && textContent.length >= minLength);\n }\n\n selectLink(node: ChildNode | Node, selection: Selection) {\n const startPosition = node.textContent?.indexOf?.(this.link) || 0;\n const endPosition = startPosition + this.link.length;\n\n const range = document.createRange();\n range.setStart(node, startPosition);\n range.setEnd(node, endPosition);\n selection.removeAllRanges();\n selection.addRange(range);\n }\n\n handleClick(event: MouseEvent) {\n if (!this.view) return;\n\n /** open the link if has special key or the view is readonly */\n const contentEditable = this.view.contentDOM.getAttribute(\"contenteditable\");\n const isReadonly = !contentEditable || contentEditable === \"false\";\n if (event.shiftKey || event.ctrlKey || event.altKey || event.metaKey || isReadonly) {\n if (event.type === \"mousedown\") {\n const target = event.target as HTMLAnchorElement;\n window.open(target.href, \"_blank\");\n }\n\n return;\n }\n\n event.stopPropagation();\n event.preventDefault();\n const target = event.target as HTMLAnchorElement;\n const parent = target.parentNode;\n let line: HTMLElement | null = parent as HTMLElement | null;\n\n /** recursively find line that contains link */\n while (line && !line.classList.contains(\"cm-line\")) {\n line = line.parentNode as HTMLElement | null;\n }\n\n const editor = this.view.dom.querySelector(\".cm-content\");\n const selection = window.getSelection();\n\n if (!selection || !editor || !parent) return;\n\n const range = document.createRange();\n range.selectNode(target);\n range.collapse(true);\n\n selection.removeAllRanges();\n selection.addRange(range);\n\n /** trick for correct select the link by click when the view is not focused */\n void utils.tick({ delay: 0 }).then(() => {\n if (selection && selection.anchorNode?.nodeType !== 3) {\n selection.removeAllRanges();\n selection.addRange(range);\n }\n });\n\n /** wait for the widget to disappear and link will be visible */\n void utils\n .tick({\n delay: 0,\n maxDeep: 5,\n delayGetter: (deep) => {\n return deep > 1 ? 10 : 5;\n },\n recursiveCondition: () => {\n const textNode = this.getTextNode(line);\n\n return this.isCorrectNode(textNode);\n },\n })\n .then(() => {\n const textNode = this.getTextNode(line);\n\n if (this.isCorrectNode(textNode)) this.selectLink(textNode, selection);\n });\n\n return false;\n }\n\n toDOM(view: EditorView): HTMLElement {\n this.view = view;\n const anchor = document.createElement(\"a\");\n anchor.classList.add(styles.link);\n anchor.classList.add(CLASSES.link);\n\n anchor.target = \"_blank\";\n anchor.textContent = this.text;\n anchor.href = this.link;\n\n anchor.addEventListener(\"mousedown\", this.handleClick.bind(this));\n anchor.addEventListener(\"click\", this.handleClick.bind(this));\n\n return anchor;\n }\n\n destroy(dom: HTMLElement): void {\n dom.removeEventListener(\"mousedown\", this.handleClick.bind(this));\n dom.removeEventListener(\"click\", this.handleClick.bind(this));\n }\n}\n"],"names":["utils.tick","utils\n .tick"],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ const NAME_OF_LIST = "ListMark";
2
+ const NAME_OF_TODO = "Task";
3
+ const LIST_OF_LIST_MARKS = new Set([42, 43, 45]); // * + -
4
+ const CODE_OF_ORDERED_LIST_MARK = 46; // .
5
+
6
+ export { CODE_OF_ORDERED_LIST_MARK, LIST_OF_LIST_MARKS, NAME_OF_LIST, NAME_OF_TODO };
7
+ //# sourceMappingURL=list-constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-constants.js","sources":["../../../../../src/extensions/markdown/list/list-constants.ts"],"sourcesContent":["export const NAME_OF_LIST = \"ListMark\";\nexport const NAME_OF_TODO = \"Task\";\nexport const LIST_OF_LIST_MARKS = new Set([42, 43, 45]); // * + -\nexport const CODE_OF_ORDERED_LIST_MARK = 46; // .\n"],"names":[],"mappings":"AAAO,MAAM,YAAY,GAAG;AACrB,MAAM,YAAY,GAAG;AACf,MAAA,kBAAkB,GAAG,IAAI,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE;AAC3C,MAAA,yBAAyB,GAAG,GAAG;;;;"}
@@ -0,0 +1,38 @@
1
+ import { getHideDecoration, getReplaceDecoration } from '../../../lib/utils/get-decoration.js';
2
+ import { isInRange } from '../../../lib/utils/is-in-range.js';
3
+ import { NAME_OF_LIST, LIST_OF_LIST_MARKS, CODE_OF_ORDERED_LIST_MARK, NAME_OF_TODO } from './list-constants.js';
4
+ import { ListPointWidget } from './list-widget.js';
5
+
6
+ function getListSelectionDecorations({ decorations, node, view, isReadonly, }) {
7
+ if (node.name !== NAME_OF_LIST) {
8
+ return;
9
+ }
10
+ const content = view.state.doc.sliceString(node.from, node.to);
11
+ const lastCodePoint = content.codePointAt(content.length - 1) || 0;
12
+ if (!LIST_OF_LIST_MARKS.has(lastCodePoint) && CODE_OF_ORDERED_LIST_MARK !== lastCodePoint) {
13
+ return;
14
+ }
15
+ const nextSibling = node.node.nextSibling;
16
+ if (nextSibling && nextSibling.name === NAME_OF_TODO) {
17
+ if (isReadonly ||
18
+ !view.hasFocus ||
19
+ !isInRange(view.state.selection.ranges, [node.from, nextSibling.from + 3])) {
20
+ decorations.push(getHideDecoration({ range: [node.from, nextSibling.from] }));
21
+ }
22
+ return;
23
+ }
24
+ if (isReadonly ||
25
+ !view.hasFocus ||
26
+ !isInRange(view.state.selection.ranges, [node.from, node.to])) {
27
+ decorations.push(getReplaceDecoration({
28
+ range: [node.from, node.to],
29
+ widget: new ListPointWidget(content, lastCodePoint),
30
+ }));
31
+ }
32
+ }
33
+ const listDecorationPlugin = {
34
+ selectionDecorations: [getListSelectionDecorations],
35
+ };
36
+
37
+ export { listDecorationPlugin };
38
+ //# sourceMappingURL=list-decoration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-decoration.js","sources":["../../../../../src/extensions/markdown/list/list-decoration.ts"],"sourcesContent":["import { utils } from \"@/lib\";\nimport type { DecorationPlugin, GetSelectionDecorationOptions } from \"../markdown-types\";\nimport {\n CODE_OF_ORDERED_LIST_MARK,\n LIST_OF_LIST_MARKS,\n NAME_OF_LIST,\n NAME_OF_TODO,\n} from \"./list-constants\";\nimport { ListPointWidget } from \"./list-widget\";\n\nfunction getListSelectionDecorations({\n decorations,\n node,\n view,\n isReadonly,\n}: GetSelectionDecorationOptions) {\n if (node.name !== NAME_OF_LIST) {\n return;\n }\n\n const content = view.state.doc.sliceString(node.from, node.to);\n const lastCodePoint = content.codePointAt(content.length - 1) || 0;\n if (!LIST_OF_LIST_MARKS.has(lastCodePoint) && CODE_OF_ORDERED_LIST_MARK !== lastCodePoint) {\n return;\n }\n\n const nextSibling = node.node.nextSibling;\n if (nextSibling && nextSibling.name === NAME_OF_TODO) {\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [node.from, nextSibling.from + 3])\n ) {\n decorations.push(utils.getHideDecoration({ range: [node.from, nextSibling.from] }));\n }\n\n return;\n }\n\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [node.from, node.to])\n ) {\n decorations.push(\n utils.getReplaceDecoration({\n range: [node.from, node.to],\n widget: new ListPointWidget(content, lastCodePoint),\n }),\n );\n }\n}\n\nexport const listDecorationPlugin: DecorationPlugin = {\n selectionDecorations: [getListSelectionDecorations],\n};\n"],"names":["utils.isInRange","utils.getHideDecoration","utils.getReplaceDecoration"],"mappings":";;;;;AAUA,SAAS,2BAA2B,CAAC,EACnC,WAAW,EACX,IAAI,EACJ,IAAI,EACJ,UAAU,GACoB,EAAA;AAC9B,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,EAAE;QAC9B;;AAGF,IAAA,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;AAC9D,IAAA,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC;AAClE,IAAA,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,yBAAyB,KAAK,aAAa,EAAE;QACzF;;AAGF,IAAA,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW;IACzC,IAAI,WAAW,IAAI,WAAW,CAAC,IAAI,KAAK,YAAY,EAAE;AACpD,QAAA,IACE,UAAU;YACV,CAAC,IAAI,CAAC,QAAQ;YACd,CAACA,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAChF;YACA,WAAW,CAAC,IAAI,CAACC,iBAAuB,CAAC,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;;QAGrF;;AAGF,IAAA,IACE,UAAU;QACV,CAAC,IAAI,CAAC,QAAQ;QACd,CAACD,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EACnE;AACA,QAAA,WAAW,CAAC,IAAI,CACdE,oBAA0B,CAAC;YACzB,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;AAC3B,YAAA,MAAM,EAAE,IAAI,eAAe,CAAC,OAAO,EAAE,aAAa,CAAC;AACpD,SAAA,CAAC,CACH;;AAEL;AAEa,MAAA,oBAAoB,GAAqB;IACpD,oBAAoB,EAAE,CAAC,2BAA2B,CAAC;;;;;"}
@@ -0,0 +1,33 @@
1
+ import { WidgetType } from '@codemirror/view';
2
+ import '../../compartments/index.js';
3
+ import '@codemirror/language';
4
+ import '@lezer/highlight';
5
+ import { CLASSES } from '../../theme/theme-constants.js';
6
+ import styles from '../styles.module.scss.js';
7
+ import { LIST_OF_LIST_MARKS, CODE_OF_ORDERED_LIST_MARK } from './list-constants.js';
8
+
9
+ class ListPointWidget extends WidgetType {
10
+ mark;
11
+ lastCodePoint;
12
+ constructor(mark, lastCodePoint) {
13
+ super();
14
+ this.mark = mark;
15
+ this.lastCodePoint = lastCodePoint;
16
+ }
17
+ toDOM() {
18
+ const span = document.createElement("span");
19
+ span.classList.add(styles.list);
20
+ span.textContent = this.mark;
21
+ if (LIST_OF_LIST_MARKS.has(this.lastCodePoint)) {
22
+ span.classList.add(styles.common);
23
+ span.classList.add(CLASSES.listCommon);
24
+ }
25
+ if (CODE_OF_ORDERED_LIST_MARK === this.lastCodePoint) {
26
+ span.classList.add(styles.ordered);
27
+ }
28
+ return span;
29
+ }
30
+ }
31
+
32
+ export { ListPointWidget };
33
+ //# sourceMappingURL=list-widget.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-widget.js","sources":["../../../../../src/extensions/markdown/list/list-widget.ts"],"sourcesContent":["import { WidgetType } from \"@codemirror/view\";\nimport { CLASSES } from \"@/extensions/theme\";\nimport styles from \"../styles.module.scss\";\nimport { CODE_OF_ORDERED_LIST_MARK, LIST_OF_LIST_MARKS } from \"./list-constants\";\n\nexport class ListPointWidget extends WidgetType {\n constructor(\n private readonly mark: string,\n private readonly lastCodePoint: number,\n ) {\n super();\n }\n\n toDOM(): HTMLElement {\n const span = document.createElement(\"span\");\n span.classList.add(styles.list);\n span.textContent = this.mark;\n if (LIST_OF_LIST_MARKS.has(this.lastCodePoint)) {\n span.classList.add(styles.common);\n span.classList.add(CLASSES.listCommon);\n }\n if (CODE_OF_ORDERED_LIST_MARK === this.lastCodePoint) {\n span.classList.add(styles.ordered);\n }\n\n return span;\n }\n}\n"],"names":[],"mappings":";;;;;;;;AAKM,MAAO,eAAgB,SAAQ,UAAU,CAAA;AAE1B,IAAA,IAAA;AACA,IAAA,aAAA;IAFnB,WACmB,CAAA,IAAY,EACZ,aAAqB,EAAA;AAEtC,QAAA,KAAK,EAAE;QAHU,IAAI,CAAA,IAAA,GAAJ,IAAI;QACJ,IAAa,CAAA,aAAA,GAAb,aAAa;;IAKhC,KAAK,GAAA;QACH,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC;QAC3C,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;AAC/B,QAAA,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI;QAC5B,IAAI,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;YAC9C,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC;YACjC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC;;AAExC,QAAA,IAAI,yBAAyB,KAAK,IAAI,CAAC,aAAa,EAAE;YACpD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC;;AAGpC,QAAA,OAAO,IAAI;;AAEd;;;;"}
@@ -0,0 +1,105 @@
1
+ import { syntaxTree } from '@codemirror/language';
2
+ import { ViewPlugin, Decoration } from '@codemirror/view';
3
+ import { blockquoteDecorationPlugin } from './blockquote/blockquote-decoration.js';
4
+ import { boldDecorationPlugin } from './bold/bold-decoration.js';
5
+ import { codeDecorationPlugin } from './code/code-decoration.js';
6
+ import { headerDecorationPlugin } from './header/header-decoration.js';
7
+ import { horizontalDecorationPlugin } from './horizontal/horizontal-decoration.js';
8
+ import { imageDecorationPlugin } from './image/image-decoration.js';
9
+ import { italicDecorationPlugin } from './italic/italic-decoration.js';
10
+ import { linkDecorationPlugin } from './link/link-decoration.js';
11
+ import { autoLinkDecorationPlugin } from './link/auto-link-decoration.js';
12
+ import { listDecorationPlugin } from './list/list-decoration.js';
13
+ import { mentionDecorationPlugin } from './mention/mention-decoration.js';
14
+ import { strikeThroughDecorationPlugin } from './strike-through/strike-through-decoration.js';
15
+ import { todoDecorationPlugin } from './todo/todo-decoration.js';
16
+
17
+ const decorationPlugins = [
18
+ blockquoteDecorationPlugin,
19
+ boldDecorationPlugin,
20
+ codeDecorationPlugin,
21
+ headerDecorationPlugin,
22
+ horizontalDecorationPlugin,
23
+ imageDecorationPlugin,
24
+ italicDecorationPlugin,
25
+ linkDecorationPlugin,
26
+ listDecorationPlugin,
27
+ autoLinkDecorationPlugin,
28
+ mentionDecorationPlugin,
29
+ strikeThroughDecorationPlugin,
30
+ todoDecorationPlugin,
31
+ ];
32
+ let decorationFunctions = [];
33
+ let selectionDecorationFunctions = [];
34
+ for (const plugin of decorationPlugins) {
35
+ if (plugin.decorations)
36
+ decorationFunctions = decorationFunctions.concat(plugin.decorations);
37
+ if (plugin.selectionDecorations)
38
+ selectionDecorationFunctions = selectionDecorationFunctions.concat(plugin.selectionDecorations);
39
+ }
40
+ const SKIP_MARKS = new Set([
41
+ "Document",
42
+ "Paragraph",
43
+ "EmphasisMark",
44
+ "Blockquote",
45
+ "StrikethroughMark",
46
+ "BulletList",
47
+ "OrderedList",
48
+ "ListItem",
49
+ "LinkMark",
50
+ "URL",
51
+ "CodeMark",
52
+ "CodeInfo",
53
+ "CodeText",
54
+ "HeaderMark",
55
+ "TaskMarker",
56
+ ]);
57
+ let markdownDecorations = [];
58
+ function getDecorations(view, isChanged) {
59
+ const decorations = isChanged ? [] : markdownDecorations;
60
+ const selectionDecorations = [];
61
+ const contentEditable = view.contentDOM.getAttribute("contenteditable");
62
+ const isReadonly = !contentEditable || contentEditable === "false";
63
+ for (const { from: fromVisible, to: toVisible } of view.visibleRanges) {
64
+ syntaxTree(view.state).iterate({
65
+ from: fromVisible,
66
+ to: toVisible,
67
+ enter: (node) => {
68
+ if (SKIP_MARKS.has(node.name))
69
+ return;
70
+ /** Decoration by change content */
71
+ if (isChanged) {
72
+ decorationFunctions.forEach((f) => f({ decorations, node, view }));
73
+ }
74
+ /** Decoration by selection content */
75
+ selectionDecorationFunctions.forEach((f) => f({
76
+ decorations: selectionDecorations,
77
+ node,
78
+ view,
79
+ isReadonly,
80
+ }));
81
+ },
82
+ });
83
+ }
84
+ if (isChanged) {
85
+ markdownDecorations = decorations;
86
+ }
87
+ return Decoration.set([...decorations, ...selectionDecorations], true);
88
+ }
89
+ const markdownDecorationPlugin = ViewPlugin.fromClass(class DecorationMarkdown {
90
+ decorations;
91
+ constructor(view) {
92
+ this.decorations = getDecorations(view, true);
93
+ }
94
+ update(update) {
95
+ const isDocumentChanged = update.docChanged ||
96
+ update.viewportChanged ||
97
+ syntaxTree(update.startState) != syntaxTree(update.state);
98
+ this.decorations = getDecorations(update.view, isDocumentChanged);
99
+ }
100
+ }, {
101
+ decorations: (plugin) => plugin.decorations,
102
+ });
103
+
104
+ export { markdownDecorationPlugin };
105
+ //# sourceMappingURL=markdown-decoration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown-decoration.js","sources":["../../../../src/extensions/markdown/markdown-decoration.ts"],"sourcesContent":["import { syntaxTree } from \"@codemirror/language\";\nimport { type Range } from \"@codemirror/state\";\nimport {\n Decoration,\n type DecorationSet,\n type EditorView,\n ViewPlugin,\n type ViewUpdate,\n} from \"@codemirror/view\";\nimport { blockquoteDecorationPlugin } from \"./blockquote\";\nimport { boldDecorationPlugin } from \"./bold\";\nimport { codeDecorationPlugin } from \"./code\";\nimport { headerDecorationPlugin } from \"./header\";\nimport { horizontalDecorationPlugin } from \"./horizontal\";\nimport { imageDecorationPlugin } from \"./image/image-decoration\";\nimport { italicDecorationPlugin } from \"./italic\";\nimport { autoLinkDecorationPlugin, linkDecorationPlugin } from \"./link\";\nimport { listDecorationPlugin } from \"./list\";\nimport type {\n DecorationPlugin,\n GetDecorationFunction,\n GetSelectionDecorationFunction,\n} from \"./markdown-types\";\nimport { mentionDecorationPlugin } from \"./mention/mention-decoration\";\nimport { strikeThroughDecorationPlugin } from \"./strike-through\";\nimport { todoDecorationPlugin } from \"./todo\";\n\nconst decorationPlugins: DecorationPlugin[] = [\n blockquoteDecorationPlugin,\n boldDecorationPlugin,\n codeDecorationPlugin,\n headerDecorationPlugin,\n horizontalDecorationPlugin,\n imageDecorationPlugin,\n italicDecorationPlugin,\n linkDecorationPlugin,\n listDecorationPlugin,\n autoLinkDecorationPlugin,\n mentionDecorationPlugin,\n strikeThroughDecorationPlugin,\n todoDecorationPlugin,\n];\n\nlet decorationFunctions: GetDecorationFunction[] = [];\nlet selectionDecorationFunctions: GetSelectionDecorationFunction[] = [];\n\nfor (const plugin of decorationPlugins) {\n if (plugin.decorations) decorationFunctions = decorationFunctions.concat(plugin.decorations);\n if (plugin.selectionDecorations)\n selectionDecorationFunctions = selectionDecorationFunctions.concat(plugin.selectionDecorations);\n}\n\nconst SKIP_MARKS = new Set([\n \"Document\",\n \"Paragraph\",\n \"EmphasisMark\",\n \"Blockquote\",\n \"StrikethroughMark\",\n \"BulletList\",\n \"OrderedList\",\n \"ListItem\",\n \"LinkMark\",\n \"URL\",\n \"CodeMark\",\n \"CodeInfo\",\n \"CodeText\",\n \"HeaderMark\",\n \"TaskMarker\",\n]);\n\nlet markdownDecorations: Range<Decoration>[] = [];\n\nfunction getDecorations(view: EditorView, isChanged: boolean) {\n const decorations: Range<Decoration>[] = isChanged ? [] : markdownDecorations;\n const selectionDecorations: Range<Decoration>[] = [];\n const contentEditable = view.contentDOM.getAttribute(\"contenteditable\");\n const isReadonly = !contentEditable || contentEditable === \"false\";\n\n for (const { from: fromVisible, to: toVisible } of view.visibleRanges) {\n syntaxTree(view.state).iterate({\n from: fromVisible,\n to: toVisible,\n enter: (node) => {\n if (SKIP_MARKS.has(node.name)) return;\n /** Decoration by change content */\n if (isChanged) {\n decorationFunctions.forEach((f) => f({ decorations, node, view }));\n }\n\n /** Decoration by selection content */\n selectionDecorationFunctions.forEach((f) =>\n f({\n decorations: selectionDecorations,\n node,\n view,\n isReadonly,\n }),\n );\n },\n });\n }\n\n if (isChanged) {\n markdownDecorations = decorations;\n }\n\n return Decoration.set([...decorations, ...selectionDecorations], true);\n}\n\nexport const markdownDecorationPlugin = ViewPlugin.fromClass(\n class DecorationMarkdown {\n decorations: DecorationSet;\n\n constructor(view: EditorView) {\n this.decorations = getDecorations(view, true);\n }\n\n update(update: ViewUpdate) {\n const isDocumentChanged =\n update.docChanged ||\n update.viewportChanged ||\n syntaxTree(update.startState) != syntaxTree(update.state);\n this.decorations = getDecorations(update.view, isDocumentChanged);\n }\n },\n {\n decorations: (plugin) => plugin.decorations,\n },\n);\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { mentionParser } from './mention/mention-parser.js';
2
+
3
+ const markdownParserPlugin = [mentionParser];
4
+
5
+ export { markdownParserPlugin };
6
+ //# sourceMappingURL=markdown-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"markdown-parser.js","sources":["../../../../src/extensions/markdown/markdown-parser.ts"],"sourcesContent":["import type { MarkdownExtension } from \"@lezer/markdown\";\nimport { mentionParser } from \"./mention\";\n\nexport const markdownParserPlugin: MarkdownExtension = [mentionParser];\n"],"names":[],"mappings":";;AAGa,MAAA,oBAAoB,GAAsB,CAAC,aAAa;;;;"}
@@ -0,0 +1,6 @@
1
+ const CODE_OF_START_MENTION = 64; // @
2
+ const CODE_OF_SPACE = 32;
3
+ const NAME_OF_MENTION = "Mention";
4
+
5
+ export { CODE_OF_SPACE, CODE_OF_START_MENTION, NAME_OF_MENTION };
6
+ //# sourceMappingURL=mention-constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mention-constants.js","sources":["../../../../../src/extensions/markdown/mention/mention-constants.ts"],"sourcesContent":["export const CODE_OF_START_MENTION = 64; // @\nexport const CODE_OF_SPACE = 32;\nexport const NAME_OF_MENTION = \"Mention\";\n"],"names":[],"mappings":"AAAa,MAAA,qBAAqB,GAAG,GAAG;AACjC,MAAM,aAAa,GAAG;AACtB,MAAM,eAAe,GAAG;;;;"}
@@ -0,0 +1,37 @@
1
+ import clsx from 'clsx';
2
+ import '@codemirror/view';
3
+ import '../../compartments/index.js';
4
+ import '@codemirror/language';
5
+ import '@lezer/highlight';
6
+ import { CLASSES } from '../../theme/theme-constants.js';
7
+ import { getMarkDecoration, getHideDecoration } from '../../../lib/utils/get-decoration.js';
8
+ import { isInRange } from '../../../lib/utils/is-in-range.js';
9
+ import styles from '../styles.module.scss.js';
10
+ import { NAME_OF_MENTION } from './mention-constants.js';
11
+
12
+ function getMentionDecorations({ decorations, node }) {
13
+ if (node.name !== NAME_OF_MENTION) {
14
+ return;
15
+ }
16
+ decorations.push(getMarkDecoration({
17
+ style: clsx(styles.mention, CLASSES.mention),
18
+ range: [node.from, node.to],
19
+ }));
20
+ }
21
+ function getMentionSelectionDecorations({ decorations, node, view, isReadonly, }) {
22
+ if (node.name !== NAME_OF_MENTION) {
23
+ return;
24
+ }
25
+ if (isReadonly ||
26
+ !view.hasFocus ||
27
+ !isInRange(view.state.selection.ranges, [node.from, node.to])) {
28
+ decorations.push(getHideDecoration({ range: [node.from, node.from + 1] }));
29
+ }
30
+ }
31
+ const mentionDecorationPlugin = {
32
+ decorations: [getMentionDecorations],
33
+ selectionDecorations: [getMentionSelectionDecorations],
34
+ };
35
+
36
+ export { mentionDecorationPlugin };
37
+ //# sourceMappingURL=mention-decoration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mention-decoration.js","sources":["../../../../../src/extensions/markdown/mention/mention-decoration.ts"],"sourcesContent":["import clsx from \"clsx\";\nimport { CLASSES } from \"@/extensions/theme\";\nimport { utils } from \"@/lib\";\nimport type {\n DecorationPlugin,\n GetDecorationOptions,\n GetSelectionDecorationOptions,\n} from \"../markdown-types\";\nimport styles from \"../styles.module.scss\";\nimport { NAME_OF_MENTION } from \"./mention-constants\";\n\nfunction getMentionDecorations({ decorations, node }: GetDecorationOptions) {\n if (node.name !== NAME_OF_MENTION) {\n return;\n }\n\n decorations.push(\n utils.getMarkDecoration({\n style: clsx(styles.mention, CLASSES.mention),\n range: [node.from, node.to],\n }),\n );\n}\n\nfunction getMentionSelectionDecorations({\n decorations,\n node,\n view,\n isReadonly,\n}: GetSelectionDecorationOptions) {\n if (node.name !== NAME_OF_MENTION) {\n return;\n }\n\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [node.from, node.to])\n ) {\n decorations.push(utils.getHideDecoration({ range: [node.from, node.from + 1] }));\n }\n}\n\nexport const mentionDecorationPlugin: DecorationPlugin = {\n decorations: [getMentionDecorations],\n selectionDecorations: [getMentionSelectionDecorations],\n};\n"],"names":["utils.getMarkDecoration","utils.isInRange","utils.getHideDecoration"],"mappings":";;;;;;;;;;;AAWA,SAAS,qBAAqB,CAAC,EAAE,WAAW,EAAE,IAAI,EAAwB,EAAA;AACxE,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,eAAe,EAAE;QACjC;;AAGF,IAAA,WAAW,CAAC,IAAI,CACdA,iBAAuB,CAAC;QACtB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC;QAC5C,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;AAC5B,KAAA,CAAC,CACH;AACH;AAEA,SAAS,8BAA8B,CAAC,EACtC,WAAW,EACX,IAAI,EACJ,IAAI,EACJ,UAAU,GACoB,EAAA;AAC9B,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,eAAe,EAAE;QACjC;;AAGF,IAAA,IACE,UAAU;QACV,CAAC,IAAI,CAAC,QAAQ;QACd,CAACC,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EACnE;QACA,WAAW,CAAC,IAAI,CAACC,iBAAuB,CAAC,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;;AAEpF;AAEa,MAAA,uBAAuB,GAAqB;IACvD,WAAW,EAAE,CAAC,qBAAqB,CAAC;IACpC,oBAAoB,EAAE,CAAC,8BAA8B,CAAC;;;;;"}
@@ -0,0 +1,25 @@
1
+ import { NAME_OF_MENTION, CODE_OF_START_MENTION, CODE_OF_SPACE } from './mention-constants.js';
2
+
3
+ const mentionParser = {
4
+ defineNodes: [{ name: NAME_OF_MENTION }],
5
+ parseInline: [
6
+ {
7
+ name: NAME_OF_MENTION,
8
+ parse(cx, next, pos) {
9
+ if (next != CODE_OF_START_MENTION)
10
+ return -1;
11
+ let end = pos + 1;
12
+ for (let i = pos + 1; i < cx.end; i++) {
13
+ const next = cx.char(i);
14
+ if (next === CODE_OF_SPACE)
15
+ break;
16
+ end++;
17
+ }
18
+ return cx.addElement(cx.elt(NAME_OF_MENTION, pos, end));
19
+ },
20
+ },
21
+ ],
22
+ };
23
+
24
+ export { mentionParser };
25
+ //# sourceMappingURL=mention-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mention-parser.js","sources":["../../../../../src/extensions/markdown/mention/mention-parser.ts"],"sourcesContent":["import type { MarkdownConfig } from \"@lezer/markdown\";\nimport { CODE_OF_SPACE, CODE_OF_START_MENTION, NAME_OF_MENTION } from \"./mention-constants\";\n\nexport const mentionParser: MarkdownConfig = {\n defineNodes: [{ name: NAME_OF_MENTION }],\n parseInline: [\n {\n name: NAME_OF_MENTION,\n parse(cx, next, pos) {\n if (next != CODE_OF_START_MENTION) return -1;\n let end: number = pos + 1;\n for (let i = pos + 1; i < cx.end; i++) {\n const next = cx.char(i);\n if (next === CODE_OF_SPACE) break;\n end++;\n }\n\n return cx.addElement(cx.elt(NAME_OF_MENTION, pos, end));\n },\n },\n ],\n};\n"],"names":[],"mappings":";;AAGa,MAAA,aAAa,GAAmB;AAC3C,IAAA,WAAW,EAAE,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC;AACxC,IAAA,WAAW,EAAE;AACX,QAAA;AACE,YAAA,IAAI,EAAE,eAAe;AACrB,YAAA,KAAK,CAAC,EAAE,EAAE,IAAI,EAAE,GAAG,EAAA;gBACjB,IAAI,IAAI,IAAI,qBAAqB;oBAAE,OAAO,CAAC,CAAC;AAC5C,gBAAA,IAAI,GAAG,GAAW,GAAG,GAAG,CAAC;AACzB,gBAAA,KAAK,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE;oBACrC,MAAM,IAAI,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;oBACvB,IAAI,IAAI,KAAK,aAAa;wBAAE;AAC5B,oBAAA,GAAG,EAAE;;AAGP,gBAAA,OAAO,EAAE,CAAC,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,eAAe,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;aACxD;AACF,SAAA;AACF,KAAA;;;;;"}
@@ -0,0 +1,4 @@
1
+ const NAME_OF_STRIKE_THROUGH = "Strikethrough";
2
+
3
+ export { NAME_OF_STRIKE_THROUGH };
4
+ //# sourceMappingURL=strike-through-constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"strike-through-constants.js","sources":["../../../../../src/extensions/markdown/strike-through/strike-through-constants.ts"],"sourcesContent":["export const NAME_OF_STRIKE_THROUGH = \"Strikethrough\";\n"],"names":[],"mappings":"AAAO,MAAM,sBAAsB,GAAG;;;;"}
@@ -0,0 +1,32 @@
1
+ import { getMarkDecoration, getHideDecoration } from '../../../lib/utils/get-decoration.js';
2
+ import { isInRange } from '../../../lib/utils/is-in-range.js';
3
+ import styles from '../styles.module.scss.js';
4
+ import { NAME_OF_STRIKE_THROUGH } from './strike-through-constants.js';
5
+
6
+ function getStrikeThroughDecorations({ decorations, node }) {
7
+ if (node.name !== NAME_OF_STRIKE_THROUGH) {
8
+ return;
9
+ }
10
+ decorations.push(getMarkDecoration({
11
+ style: styles["strike-through"],
12
+ range: [node.from, node.to],
13
+ }));
14
+ }
15
+ function getStrikeThroughSelectionDecorations({ decorations, node, view, isReadonly, }) {
16
+ if (node.name !== NAME_OF_STRIKE_THROUGH) {
17
+ return;
18
+ }
19
+ if (isReadonly ||
20
+ !view.hasFocus ||
21
+ !isInRange(view.state.selection.ranges, [node.from, node.to])) {
22
+ decorations.push(getHideDecoration({ range: [node.from, node.from + 2] }));
23
+ decorations.push(getHideDecoration({ range: [node.to - 2, node.to] }));
24
+ }
25
+ }
26
+ const strikeThroughDecorationPlugin = {
27
+ decorations: [getStrikeThroughDecorations],
28
+ selectionDecorations: [getStrikeThroughSelectionDecorations],
29
+ };
30
+
31
+ export { strikeThroughDecorationPlugin };
32
+ //# sourceMappingURL=strike-through-decoration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"strike-through-decoration.js","sources":["../../../../../src/extensions/markdown/strike-through/strike-through-decoration.ts"],"sourcesContent":["import { utils } from \"@/lib\";\nimport type {\n DecorationPlugin,\n GetDecorationOptions,\n GetSelectionDecorationOptions,\n} from \"../markdown-types\";\nimport styles from \"../styles.module.scss\";\nimport { NAME_OF_STRIKE_THROUGH } from \"./strike-through-constants\";\n\nfunction getStrikeThroughDecorations({ decorations, node }: GetDecorationOptions) {\n if (node.name !== NAME_OF_STRIKE_THROUGH) {\n return;\n }\n\n decorations.push(\n utils.getMarkDecoration({\n style: styles[\"strike-through\"],\n range: [node.from, node.to],\n }),\n );\n}\n\nfunction getStrikeThroughSelectionDecorations({\n decorations,\n node,\n view,\n isReadonly,\n}: GetSelectionDecorationOptions) {\n if (node.name !== NAME_OF_STRIKE_THROUGH) {\n return;\n }\n\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [node.from, node.to])\n ) {\n decorations.push(utils.getHideDecoration({ range: [node.from, node.from + 2] }));\n decorations.push(utils.getHideDecoration({ range: [node.to - 2, node.to] }));\n }\n}\n\nexport const strikeThroughDecorationPlugin: DecorationPlugin = {\n decorations: [getStrikeThroughDecorations],\n selectionDecorations: [getStrikeThroughSelectionDecorations],\n};\n"],"names":["utils.getMarkDecoration","utils.isInRange","utils.getHideDecoration"],"mappings":";;;;;AASA,SAAS,2BAA2B,CAAC,EAAE,WAAW,EAAE,IAAI,EAAwB,EAAA;AAC9E,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;QACxC;;AAGF,IAAA,WAAW,CAAC,IAAI,CACdA,iBAAuB,CAAC;AACtB,QAAA,KAAK,EAAE,MAAM,CAAC,gBAAgB,CAAC;QAC/B,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC;AAC5B,KAAA,CAAC,CACH;AACH;AAEA,SAAS,oCAAoC,CAAC,EAC5C,WAAW,EACX,IAAI,EACJ,IAAI,EACJ,UAAU,GACoB,EAAA;AAC9B,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,sBAAsB,EAAE;QACxC;;AAGF,IAAA,IACE,UAAU;QACV,CAAC,IAAI,CAAC,QAAQ;QACd,CAACC,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,EACnE;QACA,WAAW,CAAC,IAAI,CAACC,iBAAuB,CAAC,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC;QAChF,WAAW,CAAC,IAAI,CAACA,iBAAuB,CAAC,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;;AAEhF;AAEa,MAAA,6BAA6B,GAAqB;IAC7D,WAAW,EAAE,CAAC,2BAA2B,CAAC;IAC1C,oBAAoB,EAAE,CAAC,oCAAoC,CAAC;;;;;"}
@@ -0,0 +1,8 @@
1
+ import styleInject from '../../node_modules/.pnpm/style-inject@0.3.0/node_modules/style-inject/dist/style-inject.es.js';
2
+
3
+ var css_248z = "._header_XFwV5{font-weight:700}._header_XFwV5._level_1_-KPph{font-size:2rem}._header_XFwV5._level_2_ecHlB{font-size:1.8rem}._header_XFwV5._level_3_SYcVr{font-size:1.6rem}._header_XFwV5._level_4_V3o5m{font-size:1.4rem}._header_XFwV5._level_5_I7eVk{font-size:1.3rem}._header_XFwV5._level_6_A3lbK{font-size:1.2rem}._bold_I8DT-{font-weight:700}._italic_72qBe{font-style:italic}._blockquote_Xq6O4{border-left:3px solid;margin-left:5px}._blockquote__inner_mjT0h{margin-left:1px;padding-left:5px;position:relative}._blockquote__inner_mjT0h:before{border-left:3px solid;content:\"\";height:140%;left:0;position:absolute;top:-3px}._blockquote__inner-deep_s6tNj{margin-left:5px}._strike-through_U64jP{text-decoration:line-through}._list_MHIjT._common_0GdDi{position:relative;visibility:hidden}._list_MHIjT._common_0GdDi:after{border-radius:100%;content:\"\";height:5px;left:0;position:absolute;top:50%;transform:translateY(-50%);visibility:visible;width:5px}._link_7U9wl{text-decoration:none;text-decoration:underline}._link__label_dHGGf{font-size:12px;position:relative;top:-4px}._image_KmBM8{display:inline-flex}._code__line_m3IiO{padding:5px;position:relative}._code__line_m3IiO,._code__single_hbMte{font-family:monospace}._code__button_WwYE-{background-color:transparent;border:none;border-radius:4px;box-shadow:none;cursor:pointer;min-width:30px;outline:none;padding:4px 10px;position:absolute;right:5px;top:5px;transition:all .3s ease;z-index:1}._code__button_WwYE-._pending_fgHgD:before{animation:_loading-btn--fade-in_8z5an .33s ease,_loading-btn--rotation_QaopN .66s linear 0s infinite;border:2px solid hsla(0,0%,100%,.33);border-radius:50%;border-top-color:#000;content:\"\";display:inline-block;height:10.5px;left:50%;position:absolute;top:50%;width:10.5px}._code__button_WwYE-._success_kUPnO:after{animation:_loading-btn--fade-in_8z5an .6s ease;border-color:currentcolor;border-style:solid;border-width:0 0 1px 1px;content:\"\";display:inline-block;height:7px;left:50%;position:absolute;top:50%;transform:translate(-50%,-75%) rotate(-45deg);width:11px}._code__button_WwYE-._fail_cOpap:after,._code__button_WwYE-._fail_cOpap:before{content:\" \";height:13px;left:50%;position:absolute;top:50%;width:1px}._code__button_WwYE-._fail_cOpap:before{transform:translate(-50%,-50%) rotate(45deg)}._code__button_WwYE-._fail_cOpap:after{transform:translate(-50%,-50%) rotate(-45deg)}@keyframes _loading-btn--fade-in_8z5an{0%{opacity:0}to{opacity:1}}@keyframes _loading-btn--rotation_QaopN{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}._code__span_iSCmj{opacity:1;transition:opacity .3s ease}._code__span_iSCmj._hide_uqpax{opacity:0}._horizontal_J1jU-{border-bottom:1px solid;margin:0 5px;position:relative;width:calc(100% - 10px)}._todo_m6MIP{align-items:flex-end;display:inline-flex;height:100%;padding-left:3px;padding-right:3px}._todo_m6MIP>input{margin:0}._todo__checked_kemjy{text-decoration:line-through}._mention_cpzik{font-weight:700}";
4
+ const styles = {"header":"_header_XFwV5","level_1":"_level_1_-KPph","level_2":"_level_2_ecHlB","level_3":"_level_3_SYcVr","level_4":"_level_4_V3o5m","level_5":"_level_5_I7eVk","level_6":"_level_6_A3lbK","bold":"_bold_I8DT-","italic":"_italic_72qBe","blockquote":"_blockquote_Xq6O4","blockquote__inner":"_blockquote__inner_mjT0h","blockquote__inner-deep":"_blockquote__inner-deep_s6tNj","strike-through":"_strike-through_U64jP","list":"_list_MHIjT","common":"_common_0GdDi","link":"_link_7U9wl","link__label":"_link__label_dHGGf","image":"_image_KmBM8","code__line":"_code__line_m3IiO","code__single":"_code__single_hbMte","code__button":"_code__button_WwYE-","pending":"_pending_fgHgD","loading-btn--fade-in":"_loading-btn--fade-in_8z5an","loading-btn--rotation":"_loading-btn--rotation_QaopN","success":"_success_kUPnO","fail":"_fail_cOpap","code__span":"_code__span_iSCmj","hide":"_hide_uqpax","horizontal":"_horizontal_J1jU-","todo":"_todo_m6MIP","todo__checked":"_todo__checked_kemjy","mention":"_mention_cpzik"};
5
+ styleInject(css_248z);
6
+
7
+ export { styles as default };
8
+ //# sourceMappingURL=styles.module.scss.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
@@ -0,0 +1,6 @@
1
+ const NAME_OF_TODO = "Task";
2
+ const NAME_OF_LIST_MARK = "ListMark";
3
+ const LIST_OF_TODO_MARKS = new Set([120, 1093]); // x
4
+
5
+ export { LIST_OF_TODO_MARKS, NAME_OF_LIST_MARK, NAME_OF_TODO };
6
+ //# sourceMappingURL=todo-constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"todo-constants.js","sources":["../../../../../src/extensions/markdown/todo/todo-constants.ts"],"sourcesContent":["export const NAME_OF_TODO = \"Task\";\nexport const NAME_OF_LIST_MARK = \"ListMark\";\nexport const LIST_OF_TODO_MARKS = new Set([120, 1093]); // x\n"],"names":[],"mappings":"AAAO,MAAM,YAAY,GAAG;AACrB,MAAM,iBAAiB,GAAG;AAC1B,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE;;;;"}
@@ -0,0 +1,35 @@
1
+ import { getReplaceDecoration, getMarkDecoration } from '../../../lib/utils/get-decoration.js';
2
+ import { isInRange } from '../../../lib/utils/is-in-range.js';
3
+ import styles from '../styles.module.scss.js';
4
+ import { NAME_OF_TODO, NAME_OF_LIST_MARK, LIST_OF_TODO_MARKS } from './todo-constants.js';
5
+ import { TodoWidget } from './todo-widget.js';
6
+
7
+ function getTodoSelectionDecoration({ decorations, node, view, isReadonly, }) {
8
+ if (node.name !== NAME_OF_TODO)
9
+ return;
10
+ const prevSibling = node.node.prevSibling;
11
+ if (!prevSibling || prevSibling.name !== NAME_OF_LIST_MARK)
12
+ return;
13
+ const isChecked = LIST_OF_TODO_MARKS.has(view.state.doc.sliceString(node.from + 1, node.from + 2).codePointAt(0) || 0);
14
+ if (isReadonly ||
15
+ !view.hasFocus ||
16
+ !isInRange(view.state.selection.ranges, [prevSibling.from, node.from + 3])) {
17
+ decorations.push(getReplaceDecoration({
18
+ range: [node.from, node.from + 3],
19
+ widget: new TodoWidget(isChecked, node.from + 1),
20
+ }));
21
+ }
22
+ if (isChecked) {
23
+ const line = view.lineBlockAt(node.from);
24
+ if (isReadonly ||
25
+ !view.hasFocus ||
26
+ !isInRange(view.state.selection.ranges, [line.from, line.to]))
27
+ decorations.push(getMarkDecoration({ style: styles.todo__checked, range: [node.from + 4, node.to] }));
28
+ }
29
+ }
30
+ const todoDecorationPlugin = {
31
+ selectionDecorations: [getTodoSelectionDecoration],
32
+ };
33
+
34
+ export { todoDecorationPlugin };
35
+ //# sourceMappingURL=todo-decoration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"todo-decoration.js","sources":["../../../../../src/extensions/markdown/todo/todo-decoration.ts"],"sourcesContent":["import { utils } from \"@/lib\";\nimport type { DecorationPlugin, GetSelectionDecorationOptions } from \"../markdown-types\";\nimport styles from \"../styles.module.scss\";\nimport { LIST_OF_TODO_MARKS, NAME_OF_LIST_MARK, NAME_OF_TODO } from \"./todo-constants\";\nimport { TodoWidget } from \"./todo-widget\";\n\nfunction getTodoSelectionDecoration({\n decorations,\n node,\n view,\n isReadonly,\n}: GetSelectionDecorationOptions) {\n if (node.name !== NAME_OF_TODO) return;\n\n const prevSibling = node.node.prevSibling;\n if (!prevSibling || prevSibling.name !== NAME_OF_LIST_MARK) return;\n\n const isChecked = LIST_OF_TODO_MARKS.has(\n view.state.doc.sliceString(node.from + 1, node.from + 2).codePointAt(0) || 0,\n );\n\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [prevSibling.from, node.from + 3])\n ) {\n decorations.push(\n utils.getReplaceDecoration({\n range: [node.from, node.from + 3],\n widget: new TodoWidget(isChecked, node.from + 1),\n }),\n );\n }\n\n if (isChecked) {\n const line = view.lineBlockAt(node.from);\n\n if (\n isReadonly ||\n !view.hasFocus ||\n !utils.isInRange(view.state.selection.ranges, [line.from, line.to])\n )\n decorations.push(\n utils.getMarkDecoration({ style: styles.todo__checked, range: [node.from + 4, node.to] }),\n );\n }\n}\n\nexport const todoDecorationPlugin: DecorationPlugin = {\n selectionDecorations: [getTodoSelectionDecoration],\n};\n"],"names":["utils.isInRange","utils.getReplaceDecoration","utils.getMarkDecoration"],"mappings":";;;;;;AAMA,SAAS,0BAA0B,CAAC,EAClC,WAAW,EACX,IAAI,EACJ,IAAI,EACJ,UAAU,GACoB,EAAA;AAC9B,IAAA,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY;QAAE;AAEhC,IAAA,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW;AACzC,IAAA,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,IAAI,KAAK,iBAAiB;QAAE;AAE5D,IAAA,MAAM,SAAS,GAAG,kBAAkB,CAAC,GAAG,CACtC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAC7E;AAED,IAAA,IACE,UAAU;QACV,CAAC,IAAI,CAAC,QAAQ;QACd,CAACA,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,EAChF;AACA,QAAA,WAAW,CAAC,IAAI,CACdC,oBAA0B,CAAC;YACzB,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;YACjC,MAAM,EAAE,IAAI,UAAU,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;AACjD,SAAA,CAAC,CACH;;IAGH,IAAI,SAAS,EAAE;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC;AAExC,QAAA,IACE,UAAU;YACV,CAAC,IAAI,CAAC,QAAQ;YACd,CAACD,SAAe,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;AAEnE,YAAA,WAAW,CAAC,IAAI,CACdE,iBAAuB,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,CAC1F;;AAEP;AAEa,MAAA,oBAAoB,GAAqB;IACpD,oBAAoB,EAAE,CAAC,0BAA0B,CAAC;;;;;"}