@canonical/react-ds-app-launchpad 0.9.0-experimental.9 → 0.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.
Files changed (256) hide show
  1. package/dist/esm/ui/DiffChangeMarker/DiffChangeMarker.js +47 -0
  2. package/dist/esm/ui/DiffChangeMarker/DiffChangeMarker.js.map +1 -0
  3. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.js +8 -0
  4. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.js.map +1 -0
  5. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/index.js +4 -0
  6. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/index.js.map +1 -0
  7. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/styles.css +21 -0
  8. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/types.js +2 -0
  9. package/dist/esm/ui/DiffChangeMarker/common/DetailedChangeMarker/types.js.map +1 -0
  10. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.js +11 -0
  11. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.js.map +1 -0
  12. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/index.js +4 -0
  13. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/index.js.map +1 -0
  14. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/styles.css +29 -0
  15. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/types.js +2 -0
  16. package/dist/esm/ui/DiffChangeMarker/common/SimpleChangeMarker/types.js.map +1 -0
  17. package/dist/esm/ui/DiffChangeMarker/common/index.js +3 -0
  18. package/dist/esm/ui/DiffChangeMarker/common/index.js.map +1 -0
  19. package/dist/esm/ui/DiffChangeMarker/icons.js +5 -0
  20. package/dist/esm/ui/DiffChangeMarker/icons.js.map +1 -0
  21. package/dist/esm/ui/DiffChangeMarker/index.js +4 -0
  22. package/dist/esm/ui/DiffChangeMarker/index.js.map +1 -0
  23. package/dist/esm/ui/DiffChangeMarker/styles.css +30 -0
  24. package/dist/esm/ui/DiffChangeMarker/types.js +2 -0
  25. package/dist/esm/ui/DiffChangeMarker/types.js.map +1 -0
  26. package/dist/esm/ui/EditableBlock/EditableBlock.js +5 -3
  27. package/dist/esm/ui/EditableBlock/EditableBlock.js.map +1 -1
  28. package/dist/esm/ui/EditableBlock/styles.css +0 -3
  29. package/dist/esm/ui/FileTree/Provider.js +3 -3
  30. package/dist/esm/ui/FileTree/Provider.js.map +1 -1
  31. package/dist/esm/ui/FileTree/common/Node/Provider.js +3 -1
  32. package/dist/esm/ui/FileTree/common/Node/Provider.js.map +1 -1
  33. package/dist/esm/ui/FileTree/common/Node/styles.css +12 -16
  34. package/dist/esm/ui/FileTree/common/SearchBox/SearchBox.js +1 -1
  35. package/dist/esm/ui/FileTree/common/SearchBox/SearchBox.js.map +1 -1
  36. package/dist/esm/ui/FileTree/common/SearchBox/styles.css +11 -11
  37. package/dist/esm/ui/FileTree/styles.css +16 -4
  38. package/dist/esm/ui/GitDiffViewer/Provider.js +7 -11
  39. package/dist/esm/ui/GitDiffViewer/Provider.js.map +1 -1
  40. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.js +38 -83
  41. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.js.map +1 -1
  42. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/HighlighTheme.css +170 -171
  43. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.js +38 -0
  44. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.js.map +1 -0
  45. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.js +4 -0
  46. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.js.map +1 -0
  47. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/styles.css +15 -0
  48. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.js +3 -0
  49. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.js.map +1 -0
  50. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.js +11 -8
  51. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.js.map +1 -1
  52. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/styles.css +16 -9
  53. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.js +3 -0
  54. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.js.map +1 -0
  55. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/constants.js +2 -0
  56. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/constants.js.map +1 -0
  57. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/index.js +1 -0
  58. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/index.js.map +1 -1
  59. package/dist/esm/ui/GitDiffViewer/common/CodeDiffViewer/styles.css +4 -16
  60. package/dist/esm/ui/GitDiffViewer/common/FileHeader/FileHeader.js +3 -2
  61. package/dist/esm/ui/GitDiffViewer/common/FileHeader/FileHeader.js.map +1 -1
  62. package/dist/esm/ui/GitDiffViewer/common/FileHeader/styles.css +6 -25
  63. package/dist/esm/ui/GitDiffViewer/index.js.map +1 -1
  64. package/dist/esm/ui/GitDiffViewer/styles.css +3 -15
  65. package/dist/esm/ui/GitDiffViewer/utils/highlightDiffHunkLines.js +52 -0
  66. package/dist/esm/ui/GitDiffViewer/utils/highlightDiffHunkLines.js.map +1 -0
  67. package/dist/esm/ui/GitDiffViewer/utils/index.js +1 -0
  68. package/dist/esm/ui/GitDiffViewer/utils/index.js.map +1 -1
  69. package/dist/esm/ui/GitDiffViewer/utils/parseGitDiff.js +27 -4
  70. package/dist/esm/ui/GitDiffViewer/utils/parseGitDiff.js.map +1 -1
  71. package/dist/esm/ui/MarkdownEditor/MarkdownEditor.js +75 -0
  72. package/dist/esm/ui/MarkdownEditor/MarkdownEditor.js.map +1 -0
  73. package/dist/esm/ui/MarkdownEditor/common/Toolbar/Toolbar.js +52 -0
  74. package/dist/esm/ui/MarkdownEditor/common/Toolbar/Toolbar.js.map +1 -0
  75. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/Button.js +19 -0
  76. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/Button.js.map +1 -0
  77. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/index.js +4 -0
  78. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/index.js.map +1 -0
  79. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/styles.css +17 -0
  80. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/types.js +2 -0
  81. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Button/types.js.map +1 -0
  82. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/Group.js +13 -0
  83. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/Group.js.map +1 -0
  84. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/index.js +4 -0
  85. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/index.js.map +1 -0
  86. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/styles.css +7 -0
  87. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/types.js +2 -0
  88. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Group/types.js.map +1 -0
  89. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.js +13 -0
  90. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.js.map +1 -0
  91. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/index.js +4 -0
  92. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/index.js.map +1 -0
  93. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/styles.css +7 -0
  94. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/types.js +2 -0
  95. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/Separator/types.js.map +1 -0
  96. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/index.js +4 -0
  97. package/dist/esm/ui/MarkdownEditor/common/Toolbar/common/index.js.map +1 -0
  98. package/dist/esm/ui/MarkdownEditor/common/Toolbar/index.js +9 -0
  99. package/dist/esm/ui/MarkdownEditor/common/Toolbar/index.js.map +1 -0
  100. package/dist/esm/ui/MarkdownEditor/common/Toolbar/styles.css +16 -0
  101. package/dist/esm/ui/MarkdownEditor/common/Toolbar/types.js +2 -0
  102. package/dist/esm/ui/MarkdownEditor/common/Toolbar/types.js.map +1 -0
  103. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.js +34 -0
  104. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.js.map +1 -0
  105. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/index.js +4 -0
  106. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/index.js.map +1 -0
  107. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/styles.css +42 -0
  108. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/types.js +2 -0
  109. package/dist/esm/ui/MarkdownEditor/common/ViewModeTabs/types.js.map +1 -0
  110. package/dist/esm/ui/MarkdownEditor/common/icons.js +10 -0
  111. package/dist/esm/ui/MarkdownEditor/common/icons.js.map +1 -0
  112. package/dist/esm/ui/MarkdownEditor/common/index.js +4 -0
  113. package/dist/esm/ui/MarkdownEditor/common/index.js.map +1 -0
  114. package/dist/esm/ui/MarkdownEditor/hooks/index.js +2 -0
  115. package/dist/esm/ui/MarkdownEditor/hooks/index.js.map +1 -0
  116. package/dist/esm/ui/MarkdownEditor/hooks/useEditor.js +274 -0
  117. package/dist/esm/ui/MarkdownEditor/hooks/useEditor.js.map +1 -0
  118. package/dist/esm/ui/MarkdownEditor/index.js +4 -0
  119. package/dist/esm/ui/MarkdownEditor/index.js.map +1 -0
  120. package/dist/esm/ui/MarkdownEditor/styles.css +83 -0
  121. package/dist/esm/ui/MarkdownEditor/types.js +2 -0
  122. package/dist/esm/ui/MarkdownEditor/types.js.map +1 -0
  123. package/dist/esm/ui/RelativeTime/utils/formatHumanTime.js +1 -1
  124. package/dist/esm/ui/RelativeTime/utils/formatHumanTime.js.map +1 -1
  125. package/dist/esm/ui/RelativeTime/utils/getOptimalUpdateInterval.js +1 -1
  126. package/dist/esm/ui/RelativeTime/utils/getOptimalUpdateInterval.js.map +1 -1
  127. package/dist/esm/ui/index.js +2 -0
  128. package/dist/esm/ui/index.js.map +1 -1
  129. package/dist/types/ui/DiffChangeMarker/DiffChangeMarker.d.ts +11 -0
  130. package/dist/types/ui/DiffChangeMarker/DiffChangeMarker.d.ts.map +1 -0
  131. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.d.ts +6 -0
  132. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/DetailedChangeMarker.d.ts.map +1 -0
  133. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/index.d.ts +3 -0
  134. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/index.d.ts.map +1 -0
  135. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/types.d.ts +10 -0
  136. package/dist/types/ui/DiffChangeMarker/common/DetailedChangeMarker/types.d.ts.map +1 -0
  137. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.d.ts +6 -0
  138. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/SimpleChangeMarker.d.ts.map +1 -0
  139. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/index.d.ts +3 -0
  140. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/index.d.ts.map +1 -0
  141. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/types.d.ts +9 -0
  142. package/dist/types/ui/DiffChangeMarker/common/SimpleChangeMarker/types.d.ts.map +1 -0
  143. package/dist/types/ui/DiffChangeMarker/common/index.d.ts +3 -0
  144. package/dist/types/ui/DiffChangeMarker/common/index.d.ts.map +1 -0
  145. package/dist/types/ui/DiffChangeMarker/icons.d.ts +4 -0
  146. package/dist/types/ui/DiffChangeMarker/icons.d.ts.map +1 -0
  147. package/dist/types/ui/DiffChangeMarker/index.d.ts +3 -0
  148. package/dist/types/ui/DiffChangeMarker/index.d.ts.map +1 -0
  149. package/dist/types/ui/DiffChangeMarker/types.d.ts +18 -0
  150. package/dist/types/ui/DiffChangeMarker/types.d.ts.map +1 -0
  151. package/dist/types/ui/EditableBlock/EditableBlock.d.ts +1 -1
  152. package/dist/types/ui/EditableBlock/EditableBlock.d.ts.map +1 -1
  153. package/dist/types/ui/EditableBlock/types.d.ts +2 -0
  154. package/dist/types/ui/EditableBlock/types.d.ts.map +1 -1
  155. package/dist/types/ui/FileTree/Provider.d.ts +1 -1
  156. package/dist/types/ui/FileTree/Provider.d.ts.map +1 -1
  157. package/dist/types/ui/FileTree/common/File/File.d.ts.map +1 -1
  158. package/dist/types/ui/FileTree/common/Folder/Folder.d.ts.map +1 -1
  159. package/dist/types/ui/FileTree/common/IndentationBlock/IndentationBlock.d.ts.map +1 -1
  160. package/dist/types/ui/FileTree/common/Node/Provider.d.ts.map +1 -1
  161. package/dist/types/ui/FileTree/common/SearchBox/SearchBox.d.ts +1 -1
  162. package/dist/types/ui/FileTree/common/SearchBox/SearchBox.d.ts.map +1 -1
  163. package/dist/types/ui/FileTree/common/SearchBox/types.d.ts +0 -2
  164. package/dist/types/ui/FileTree/common/SearchBox/types.d.ts.map +1 -1
  165. package/dist/types/ui/FileTree/common/TreeView/TreeView.d.ts.map +1 -1
  166. package/dist/types/ui/FileTree/types.d.ts +5 -1
  167. package/dist/types/ui/FileTree/types.d.ts.map +1 -1
  168. package/dist/types/ui/FileTree/utils/hashNodeName.d.ts.map +1 -1
  169. package/dist/types/ui/GitDiffViewer/Provider.d.ts +1 -1
  170. package/dist/types/ui/GitDiffViewer/Provider.d.ts.map +1 -1
  171. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.d.ts +3 -12
  172. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/CodeDiffViewer.d.ts.map +1 -1
  173. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.d.ts +10 -0
  174. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/AnnotatedDiffLine.d.ts.map +1 -0
  175. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.d.ts +3 -0
  176. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/index.d.ts.map +1 -0
  177. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.d.ts +21 -0
  178. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/AnnotatedDiffLine/types.d.ts.map +1 -0
  179. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.d.ts +1 -1
  180. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.d.ts.map +1 -1
  181. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/types.d.ts +20 -6
  182. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/types.d.ts.map +1 -1
  183. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.d.ts +2 -0
  184. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.d.ts.map +1 -0
  185. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/constants.d.ts +2 -0
  186. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/constants.d.ts.map +1 -0
  187. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/index.d.ts +1 -0
  188. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/index.d.ts.map +1 -1
  189. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/types.d.ts +19 -3
  190. package/dist/types/ui/GitDiffViewer/common/CodeDiffViewer/types.d.ts.map +1 -1
  191. package/dist/types/ui/GitDiffViewer/common/FileHeader/FileHeader.d.ts.map +1 -1
  192. package/dist/types/ui/GitDiffViewer/index.d.ts +6 -2
  193. package/dist/types/ui/GitDiffViewer/index.d.ts.map +1 -1
  194. package/dist/types/ui/GitDiffViewer/types.d.ts +9 -11
  195. package/dist/types/ui/GitDiffViewer/types.d.ts.map +1 -1
  196. package/dist/types/ui/GitDiffViewer/utils/highlightDiffHunkLines.d.ts +4 -0
  197. package/dist/types/ui/GitDiffViewer/utils/highlightDiffHunkLines.d.ts.map +1 -0
  198. package/dist/types/ui/GitDiffViewer/utils/index.d.ts +1 -0
  199. package/dist/types/ui/GitDiffViewer/utils/index.d.ts.map +1 -1
  200. package/dist/types/ui/GitDiffViewer/utils/parseGitDiff.d.ts.map +1 -1
  201. package/dist/types/ui/MarkdownEditor/MarkdownEditor.d.ts +10 -0
  202. package/dist/types/ui/MarkdownEditor/MarkdownEditor.d.ts.map +1 -0
  203. package/dist/types/ui/MarkdownEditor/common/Toolbar/Toolbar.d.ts +8 -0
  204. package/dist/types/ui/MarkdownEditor/common/Toolbar/Toolbar.d.ts.map +1 -0
  205. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/Button.d.ts +9 -0
  206. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/Button.d.ts.map +1 -0
  207. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/index.d.ts +3 -0
  208. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/index.d.ts.map +1 -0
  209. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/types.d.ts +14 -0
  210. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Button/types.d.ts.map +1 -0
  211. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/Group.d.ts +9 -0
  212. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/Group.d.ts.map +1 -0
  213. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/index.d.ts +3 -0
  214. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/index.d.ts.map +1 -0
  215. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/types.d.ts +14 -0
  216. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Group/types.d.ts.map +1 -0
  217. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.d.ts +9 -0
  218. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/Separator.d.ts.map +1 -0
  219. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/index.d.ts +3 -0
  220. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/index.d.ts.map +1 -0
  221. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/types.d.ts +10 -0
  222. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/Separator/types.d.ts.map +1 -0
  223. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/index.d.ts +4 -0
  224. package/dist/types/ui/MarkdownEditor/common/Toolbar/common/index.d.ts.map +1 -0
  225. package/dist/types/ui/MarkdownEditor/common/Toolbar/index.d.ts +4 -0
  226. package/dist/types/ui/MarkdownEditor/common/Toolbar/index.d.ts.map +1 -0
  227. package/dist/types/ui/MarkdownEditor/common/Toolbar/types.d.ts +20 -0
  228. package/dist/types/ui/MarkdownEditor/common/Toolbar/types.d.ts.map +1 -0
  229. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.d.ts +9 -0
  230. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/ViewModeTabs.d.ts.map +1 -0
  231. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/index.d.ts +3 -0
  232. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/index.d.ts.map +1 -0
  233. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/types.d.ts +14 -0
  234. package/dist/types/ui/MarkdownEditor/common/ViewModeTabs/types.d.ts.map +1 -0
  235. package/dist/types/ui/MarkdownEditor/common/icons.d.ts +9 -0
  236. package/dist/types/ui/MarkdownEditor/common/icons.d.ts.map +1 -0
  237. package/dist/types/ui/MarkdownEditor/common/index.d.ts +4 -0
  238. package/dist/types/ui/MarkdownEditor/common/index.d.ts.map +1 -0
  239. package/dist/types/ui/MarkdownEditor/hooks/index.d.ts +2 -0
  240. package/dist/types/ui/MarkdownEditor/hooks/index.d.ts.map +1 -0
  241. package/dist/types/ui/MarkdownEditor/hooks/useEditor.d.ts +40 -0
  242. package/dist/types/ui/MarkdownEditor/hooks/useEditor.d.ts.map +1 -0
  243. package/dist/types/ui/MarkdownEditor/index.d.ts +3 -0
  244. package/dist/types/ui/MarkdownEditor/index.d.ts.map +1 -0
  245. package/dist/types/ui/MarkdownEditor/types.d.ts +47 -0
  246. package/dist/types/ui/MarkdownEditor/types.d.ts.map +1 -0
  247. package/dist/types/ui/RelativeTime/RelativeTime.d.ts.map +1 -1
  248. package/dist/types/ui/RelativeTime/utils/formatHumanTime.d.ts.map +1 -1
  249. package/dist/types/ui/RelativeTime/utils/getOptimalUpdateInterval.d.ts.map +1 -1
  250. package/dist/types/ui/index.d.ts +2 -0
  251. package/dist/types/ui/index.d.ts.map +1 -1
  252. package/package.json +27 -25
  253. package/dist/esm/ui/EditableBlock/EditableBlock.test.js +0 -57
  254. package/dist/esm/ui/EditableBlock/EditableBlock.test.js.map +0 -1
  255. package/dist/types/ui/EditableBlock/EditableBlock.test.d.ts +0 -2
  256. package/dist/types/ui/EditableBlock/EditableBlock.test.d.ts.map +0 -1
@@ -2,28 +2,31 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { useGitDiffViewer } from "../../../../hooks/index.js";
3
3
  import "./styles.css";
4
4
  const componentCssClassName = "ds diff-line";
5
+ const firstHunkLineCssClassName = "is-first-hunk";
5
6
  /**
6
7
  * Displays a single line of a diff as a table row with line numbers.
7
8
  *
8
9
  * @returns {React.ReactElement} - Rendered DiffLine
9
10
  */
10
- const DiffLine = ({ id, className, style, ...props }) => {
11
- const { wrapLines, addCommentEnabled, toggleAddCommentLocation } = useGitDiffViewer();
12
- const gutterIsInteractive = addCommentEnabled;
11
+ const DiffLine = ({ id, className, style, onLineClick, ...props }) => {
12
+ const { wrapLines } = useGitDiffViewer();
13
13
  const typeClass = `diff-line-${props.type}`;
14
- const lineNumber = props.type !== "hunk" ? Number(props.lineNum2 || props.lineNum1) : 0;
14
+ const isInteractive = Boolean(onLineClick);
15
15
  return (_jsxs("tr", { id: id, style: style, className: [
16
16
  componentCssClassName,
17
17
  typeClass,
18
- gutterIsInteractive ? "interactive" : "",
18
+ isInteractive && "interactive",
19
19
  className,
20
+ props.type === "hunk" &&
21
+ props.hunkIndex === 0 &&
22
+ firstHunkLineCssClassName,
20
23
  ]
21
24
  .filter(Boolean)
22
- .join(" "), children: [_jsx("td", { className: `diff-gutter ${wrapLines ? "wrap" : ""} ${props.type}`, tabIndex: gutterIsInteractive && props.type !== "hunk" ? 0 : undefined, onClick: () => toggleAddCommentLocation(lineNumber), onKeyUp: (e) => {
25
+ .join(" "), children: [_jsx("td", { className: `diff-gutter ${wrapLines ? "wrap" : ""} ${props.type}`, tabIndex: isInteractive && props.type !== "hunk" ? 0 : undefined, onClick: onLineClick, onKeyUp: (e) => {
23
26
  if (e.key === "Enter") {
24
- toggleAddCommentLocation(lineNumber);
27
+ onLineClick?.();
25
28
  }
26
- }, onKeyDown: undefined, children: props.type === "hunk" ? ("\u00A0") : (_jsxs("div", { className: "diff-line-numbers", children: [_jsx("span", { className: "line-num", children: props.lineNum1 ?? "+" }), _jsx("span", { className: "line-num", children: props.lineNum2 ?? "-" })] })) }), _jsx("td", { className: `diff-content ${wrapLines ? "wrap" : ""}`, children: props.type === "hunk" ? (_jsx("pre", { children: props.hunkHeader })) : (_jsx("pre", {
29
+ }, onKeyDown: undefined, children: props.type === "hunk" ? ("\u00A0") : (_jsxs("div", { className: "diff-line-numbers", children: [isInteractive && (_jsx("span", { className: "comment-icon", children: _jsxs("svg", { width: 16, height: 16, viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsx("use", { href: "#comment-icon" }), _jsx("title", { children: "Comment" })] }) })), _jsx("span", { className: "line-num", children: props.type === "add" ? "+" : props.removeLineNumber }), _jsx("span", { className: "line-num", children: props.type === "remove" ? "-" : props.addLineNumber })] })) }), _jsx("td", { className: `diff-content ${wrapLines ? "wrap" : ""}`, children: props.type === "hunk" ? (_jsx("pre", { children: props.hunkHeader })) : (_jsx("pre", {
27
30
  // biome-ignore lint/security/noDangerouslySetInnerHtml: syntax highlighting requires adding generated HTML
28
31
  dangerouslySetInnerHTML: {
29
32
  __html: props.content ? props.content : "\u00A0",
@@ -1 +1 @@
1
- {"version":3,"file":"DiffLine.js","sourceRoot":"","sources":["../../../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,cAAc,CAAC;AAE7C;;;;GAIG;AACH,MAAM,QAAQ,GAAG,CAAC,EAChB,EAAE,EACF,SAAS,EACT,KAAK,EACL,GAAG,KAAK,EACM,EAAsB,EAAE;IACtC,MAAM,EAAE,SAAS,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,GAC9D,gBAAgB,EAAE,CAAC;IACrB,MAAM,mBAAmB,GAAG,iBAAiB,CAAC;IAC9C,MAAM,SAAS,GAAG,aAAa,KAAK,CAAC,IAAI,EAAE,CAAC;IAE5C,MAAM,UAAU,GACd,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEvE,OAAO,CACL,cACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE;YACT,qBAAqB;YACrB,SAAS;YACT,mBAAmB,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;YACxC,SAAS;SACV;aACE,MAAM,CAAC,OAAO,CAAC;aACf,IAAI,CAAC,GAAG,CAAC,aAEZ,aACE,SAAS,EAAE,eAAe,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,IAAI,EAAE,EACjE,QAAQ,EAAE,mBAAmB,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EACtE,OAAO,EAAE,GAAG,EAAE,CAAC,wBAAwB,CAAC,UAAU,CAAC,EACnD,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;oBACb,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;wBACtB,wBAAwB,CAAC,UAAU,CAAC,CAAC;oBACvC,CAAC;gBACH,CAAC,EACD,SAAS,EAAE,SAAS,YAEnB,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CACvB,QAAQ,CACT,CAAC,CAAC,CAAC,CACF,eAAK,SAAS,EAAC,mBAAmB,aAChC,eAAM,SAAS,EAAC,UAAU,YAAE,KAAK,CAAC,QAAQ,IAAI,GAAG,GAAQ,EACzD,eAAM,SAAS,EAAC,UAAU,YAAE,KAAK,CAAC,QAAQ,IAAI,GAAG,GAAQ,IACrD,CACP,GACE,EACL,aAAI,SAAS,EAAE,gBAAgB,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,YACrD,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CACvB,wBAAM,KAAK,CAAC,UAAU,GAAO,CAC9B,CAAC,CAAC,CAAC,CACF;oBACE,2GAA2G;oBAC3G,uBAAuB,EAAE;wBACvB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;qBACjD,GACD,CACH,GACE,IACF,CACN,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
1
+ {"version":3,"file":"DiffLine.js","sourceRoot":"","sources":["../../../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/common/DiffLine/DiffLine.tsx"],"names":[],"mappings":";AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,cAAc,CAAC;AAC7C,MAAM,yBAAyB,GAAG,eAAe,CAAC;AAElD;;;;GAIG;AACH,MAAM,QAAQ,GAAG,CAAC,EAChB,EAAE,EACF,SAAS,EACT,KAAK,EACL,WAAW,EACX,GAAG,KAAK,EACM,EAAsB,EAAE;IACtC,MAAM,EAAE,SAAS,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACzC,MAAM,SAAS,GAAG,aAAa,KAAK,CAAC,IAAI,EAAE,CAAC;IAC5C,MAAM,aAAa,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAE3C,OAAO,CACL,cACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE;YACT,qBAAqB;YACrB,SAAS;YACT,aAAa,IAAI,aAAa;YAC9B,SAAS;YACT,KAAK,CAAC,IAAI,KAAK,MAAM;gBACnB,KAAK,CAAC,SAAS,KAAK,CAAC;gBACrB,yBAAyB;SAC5B;aACE,MAAM,CAAC,OAAO,CAAC;aACf,IAAI,CAAC,GAAG,CAAC,aAEZ,aACE,SAAS,EAAE,eAAe,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,IAAI,EAAE,EACjE,QAAQ,EAAE,aAAa,IAAI,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAChE,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;oBACb,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;wBACtB,WAAW,EAAE,EAAE,CAAC;oBAClB,CAAC;gBACH,CAAC,EACD,SAAS,EAAE,SAAS,YAEnB,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CACvB,QAAQ,CACT,CAAC,CAAC,CAAC,CACF,eAAK,SAAS,EAAC,mBAAmB,aAC/B,aAAa,IAAI,CAChB,eAAM,SAAS,EAAC,cAAc,YAC5B,eACE,KAAK,EAAE,EAAE,EACT,MAAM,EAAE,EAAE,EACV,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,4BAA4B,aAElC,cAAK,IAAI,EAAC,eAAe,GAAG,EAC5B,sCAAsB,IAClB,GACD,CACR,EACD,eAAM,SAAS,EAAC,UAAU,YACvB,KAAK,CAAC,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,GAC/C,EACP,eAAM,SAAS,EAAC,UAAU,YACvB,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,GAC/C,IACH,CACP,GACE,EACL,aAAI,SAAS,EAAE,gBAAgB,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,YACrD,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,CACvB,wBAAM,KAAK,CAAC,UAAU,GAAO,CAC9B,CAAC,CAAC,CAAC,CACF;oBACE,2GAA2G;oBAC3G,uBAAuB,EAAE;wBACvB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ;qBACjD,GACD,CACH,GACE,IACF,CACN,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,QAAQ,CAAC"}
@@ -34,7 +34,13 @@
34
34
  background-color: var(--git-diff-viewer-hunk-header-background);
35
35
  color: var(--git-diff-viewer-hunk-header-color);
36
36
  user-select: none;
37
- border-bottom: 1px solid var(--git-diff-viewer-border-color-tinted);
37
+ border-color: var(--git-diff-viewer-border-color-tinted);
38
+ border-style: solid;
39
+ border-width: 1px 0;
40
+
41
+ &.is-first-hunk {
42
+ border-top-width: 0px;
43
+ }
38
44
 
39
45
  td.diff-gutter {
40
46
  background-color: var(--git-diff-viewer-hunk-header-background);
@@ -66,6 +72,7 @@
66
72
  display: inline-block;
67
73
  width: calc(var(--git-diff-viewer-gutter-width) / 2 - 4px);
68
74
  text-align: center;
75
+ color: var(--git-diff-viewer-code-line-number-default-color);
69
76
  }
70
77
  }
71
78
 
@@ -85,25 +92,25 @@
85
92
  font-family: var(--font-family-mono);
86
93
  }
87
94
  }
95
+
88
96
  &.interactive {
89
97
  --icon-opacity: 0;
98
+
90
99
  &:not(.diff-line-hunk) {
91
100
  .diff-gutter {
92
101
  cursor: pointer;
93
- .diff-line-numbers::before {
94
- content: var(--comment-icon);
95
- display: inline-block;
96
- width: var(--comment-icon-width);
102
+ .comment-icon {
97
103
  opacity: var(--icon-opacity);
98
104
  padding: 0 4px;
105
+ display: flex;
106
+ align-items: center;
107
+ justify-content: center;
99
108
  }
100
109
  }
101
110
 
102
- &:has(.diff-gutter:hover),
103
- &:has(.diff-gutter:focus) {
111
+ &:hover,
112
+ &:focus-within {
104
113
  filter: brightness(0.9);
105
- }
106
- &:has(.diff-gutter:hover) {
107
114
  --icon-opacity: 1;
108
115
  }
109
116
  }
@@ -0,0 +1,3 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ export const CommentIcon = (_jsxs("svg", { xmlns: "http://www.w3.org/2000/svg", width: 16, height: 16, fill: "none", id: "comment-icon", children: [_jsx("path", { fill: "currentColor", d: "M12 2a3 3 0 0 1 3 3v5a3.002 3.002 0 0 1-2 2.829V16l-4.5-3H4a3 3 0 0 1-3-3V5a3 3 0 0 1 3-3h8Zm0 1.5H4a1.5 1.5 0 0 0-1.493 1.356L2.5 5v5a1.5 1.5 0 0 0 1.356 1.493L4 11.5h4.954l2.546 1.696.001-1.428 1-.353c.548-.194.935-.69.992-1.269L13.5 10V5a1.5 1.5 0 0 0-1.356-1.493L12 3.5ZM7.976 8.25v1.5H4.994v-1.5h2.982Zm3.005-3v1.5H4.994v-1.5h5.987Z" }), _jsx("title", { children: "Comment" })] }));
3
+ //# sourceMappingURL=icons.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.js","sourceRoot":"","sources":["../../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/common/icons.tsx"],"names":[],"mappings":";AAAA,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,eACE,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAE,EAAE,EACT,MAAM,EAAE,EAAE,EACV,IAAI,EAAC,MAAM,EACX,EAAE,EAAC,cAAc,aAEjB,eACE,IAAI,EAAC,cAAc,EACnB,CAAC,EAAC,mVAAmV,GACrV,EACF,sCAAsB,IAClB,CACP,CAAC"}
@@ -0,0 +1,2 @@
1
+ export const tableWidthCSSVar = "--table-width";
2
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/constants.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,gBAAgB,GAAG,eAAe,CAAC"}
@@ -1,4 +1,5 @@
1
1
  /* @canonical/generator-canonical-ds 0.0.1 */
2
2
  export { default as CodeDiffViewer } from "./CodeDiffViewer.js";
3
+ export * from "./constants.js";
3
4
  export * from "./types.js";
4
5
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/index.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAChE,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/ui/GitDiffViewer/common/CodeDiffViewer/index.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAChE,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC"}
@@ -2,10 +2,8 @@
2
2
 
3
3
  .ds.code-diff-viewer {
4
4
  font-size: 13px;
5
- .diff-table {
6
- --comment-icon: url('data:image/svg+xml,<svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M12 2C12.7956 2 13.5587 2.31607 14.1213 2.87868C14.6839 3.44129 15 4.20435 15 5V10C15 10.6204 14.8076 11.2256 14.4495 11.7323C14.0913 12.2389 13.5849 12.622 13 12.829V16L8.5 13H4C3.20435 13 2.44129 12.6839 1.87868 12.1213C1.31607 11.5587 1 10.7956 1 10V5C1 4.20435 1.31607 3.44129 1.87868 2.87868C2.44129 2.31607 3.20435 2 4 2H12ZM12 3.5H4C3.62712 3.50002 3.26761 3.63892 2.99158 3.88962C2.71555 4.14032 2.5428 4.48484 2.507 4.856L2.5 5V10C2.50002 10.3729 2.63892 10.7324 2.88962 11.0084C3.14032 11.2844 3.48484 11.4572 3.856 11.493L4 11.5H8.954L11.5 13.196L11.501 11.768L12.501 11.415C13.049 11.221 13.436 10.725 13.493 10.146L13.5 10V5C13.5 4.62712 13.3611 4.26761 13.1104 3.99158C12.8597 3.71555 12.5152 3.5428 12.144 3.507L12 3.5ZM7.976 8.25V9.75H4.994V8.25H7.976ZM10.981 5.25V6.75H4.994V5.25H10.981Z" fill="currentColor"/></svg>');
7
- --comment-icon-width: 16px;
8
5
 
6
+ .diff-table {
9
7
  /* updated dynamically on window resize */
10
8
  --table-width: 300px;
11
9
 
@@ -21,19 +19,9 @@
21
19
  margin-left: -1px;
22
20
  margin-right: -1px;
23
21
  }
22
+ }
24
23
 
25
- .line-decoration {
26
- display: flex;
27
- position: sticky;
28
- left: 0;
29
- width: var(--table-width);
30
- .container {
31
- width: 100%;
32
- border: 1px solid var(--git-diff-viewer-border-color-tinted);
33
- border-width: 1px 0;
34
- border-radius: 1px;
35
- padding: 0;
36
- }
37
- }
24
+ > .svg-refs {
25
+ display: none;
38
26
  }
39
27
  }
@@ -1,7 +1,8 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { useCallback } from "react";
3
3
  import { useGitDiffViewer } from "../../hooks/index.js";
4
4
  import "./styles.css";
5
+ import { DiffChangeMarker } from "../../../index.js";
5
6
  const componentCssClassName = "ds file-header";
6
7
  /**
7
8
  * Displays the file name and change count for a diff.
@@ -28,7 +29,7 @@ const FileHeader = ({ id, children, className, style, hideCollapse = false, show
28
29
  return { additions, deletions };
29
30
  }, [diff]);
30
31
  const changesCount = calculateChangeCount();
31
- return (_jsxs("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), ...props, children: [_jsxs("div", { className: "left-content", children: [leftContent, shouldRenderCollapse && (_jsx("button", { className: `collapse-button ${isCollapsed ? "collapsed" : ""}`, onClick: () => onCollapseToggle(!isCollapsed), "aria-label": "Collapse file", type: "button", children: _jsxs("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsx("title", { children: "Collapse" }), _jsx("path", { d: "M11.811 8.124L5.62399 1.937L4.56299 2.997L9.68999 8.124L4.56299 13.25L5.62399 14.311L11.811 8.124Z", fill: "currentColor" })] }) })), _jsx("h5", { className: "file-name", children: diff.newPath })] }), _jsxs("div", { className: "right-content", children: [showChangeCount && (_jsx("div", { className: "change-count", children: diff.fileChangeState === "modified" ? (_jsxs(_Fragment, { children: [_jsxs("span", { className: "deletions", children: ["-", changesCount.deletions] }), _jsxs("span", { className: "insertions", children: ["+", changesCount.additions] })] })) : diff.fileChangeState === "added" ? (_jsx("span", { className: "insertions", children: "Added" })) : diff.fileChangeState === "deleted" ? (_jsx("span", { className: "deletions", children: "Removed" })) : (_jsx(_Fragment, {})) })), rightContent] }), children] }));
32
+ return (_jsxs("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), ...props, children: [_jsxs("div", { className: "left-content", children: [leftContent, shouldRenderCollapse && (_jsx("button", { className: `collapse-button ${isCollapsed ? "collapsed" : ""}`, onClick: () => onCollapseToggle(!isCollapsed), "aria-label": "Collapse file", type: "button", children: _jsxs("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsx("title", { children: "Collapse" }), _jsx("path", { d: "M11.811 8.124L5.62399 1.937L4.56299 2.997L9.68999 8.124L4.56299 13.25L5.62399 14.311L11.811 8.124Z", fill: "currentColor" })] }) })), _jsx("h5", { className: "file-name", children: diff.newPath })] }), _jsxs("div", { className: "right-content", children: [showChangeCount && (_jsx("div", { className: "change-count", children: diff.fileChangeState === "modified" ? (_jsx(DiffChangeMarker, { additions: changesCount.additions, deletions: changesCount.deletions, markerStyle: "detailed" })) : (diff.fileChangeState !== "none" && (_jsx(DiffChangeMarker, { type: diff.fileChangeState, markerStyle: "detailed" }))) })), rightContent] }), children] }));
32
33
  };
33
34
  FileHeader.displayName = "GitDiffViewer.FileHeader";
34
35
  export default FileHeader;
@@ -1 +1 @@
1
- {"version":3,"file":"FileHeader.js","sourceRoot":"","sources":["../../../../../../src/ui/GitDiffViewer/common/FileHeader/FileHeader.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,cAAc,CAAC;AAGtB,MAAM,qBAAqB,GAAG,gBAAgB,CAAC;AAE/C;;;;;GAKG;AACH,MAAM,UAAU,GAAG,CAAC,EAClB,EAAE,EACF,QAAQ,EACR,SAAS,EACT,KAAK,EACL,YAAY,GAAG,KAAK,EACpB,eAAe,EACf,WAAW,EACX,YAAY,EACZ,GAAG,KAAK,EACQ,EAAsB,EAAE;IACxC,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,IAAI,EAAE,GAAG,gBAAgB,EAAE,CAAC;IACnE,MAAM,oBAAoB,GAAG,CAAC,YAAY,IAAI,WAAW,KAAK,SAAS,CAAC;IAExE,MAAM,oBAAoB,GAAG,WAAW,CAAC,GAAG,EAAE;QAC5C,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YAC9B,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBAC9B,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE,CAAC;oBACxB,SAAS,EAAE,CAAC;gBACd,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAClC,SAAS,EAAE,CAAC;gBACd,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC;IAClC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IACX,MAAM,YAAY,GAAG,oBAAoB,EAAE,CAAC;IAC5C,OAAO,CACL,eACE,EAAE,EAAE,EAAE,EACN,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,CAAC,qBAAqB,EAAE,SAAS,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KACnE,KAAK,aAET,eAAK,SAAS,EAAC,cAAc,aAC1B,WAAW,EACX,oBAAoB,IAAI,CACvB,iBACE,SAAS,EAAE,mBAAmB,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,EAAE,EAC9D,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,CAAC,WAAW,CAAC,gBAClC,eAAe,EAC1B,IAAI,EAAC,QAAQ,YAEb,eACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,MAAM,EACX,KAAK,EAAC,4BAA4B,aAElC,uCAAuB,EACvB,eACE,CAAC,EAAC,oGAAoG,EACtG,IAAI,EAAC,cAAc,GACnB,IACE,GACC,CACV,EACA,aAAI,SAAS,EAAC,WAAW,YAAE,IAAI,CAAC,OAAO,GAAM,IAC1C,EACN,eAAK,SAAS,EAAC,eAAe,aAC3B,eAAe,IAAI,CAClB,cAAK,SAAS,EAAC,cAAc,YAC1B,IAAI,CAAC,eAAe,KAAK,UAAU,CAAC,CAAC,CAAC,CACrC,8BACE,gBAAM,SAAS,EAAC,WAAW,kBAAG,YAAY,CAAC,SAAS,IAAQ,EAC5D,gBAAM,SAAS,EAAC,YAAY,kBAAG,YAAY,CAAC,SAAS,IAAQ,IAC5D,CACJ,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,KAAK,OAAO,CAAC,CAAC,CAAC,CACrC,eAAM,SAAS,EAAC,YAAY,sBAAa,CAC1C,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,KAAK,SAAS,CAAC,CAAC,CAAC,CACvC,eAAM,SAAS,EAAC,WAAW,wBAAe,CAC3C,CAAC,CAAC,CAAC,CACF,mBAAK,CACN,GACG,CACP,EACA,YAAY,IACT,EACL,QAAQ,IACL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,UAAU,CAAC,WAAW,GAAG,0BAA0B,CAAC;AAEpD,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"FileHeader.js","sourceRoot":"","sources":["../../../../../../src/ui/GitDiffViewer/common/FileHeader/FileHeader.tsx"],"names":[],"mappings":"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"}
@@ -42,33 +42,14 @@
42
42
  background-color: var(--git-diff-file-header-button-focus-background);
43
43
  }
44
44
 
45
- &.collapsed {
45
+ > svg {
46
46
  transform: rotate(90deg);
47
+ transition: transform 0.15s ease-out;
47
48
  }
48
- }
49
- }
50
-
51
- & > .right-content {
52
- & > .change-count {
53
- font-size: 12px;
54
- font-weight: 550;
55
- line-height: 16px;
56
- display: flex;
57
- align-items: center;
58
-
59
- & > .insertions,
60
- & > .deletions {
61
- padding: 0 4px;
62
- display: flex;
63
- align-items: center;
64
- }
65
- & > .insertions {
66
- background-color: var(--git-diff-file-header-insertion-background);
67
- color: var(--git-diff-file-header-insertion-color);
68
- }
69
- & > .deletions {
70
- background-color: var(--git-diff-file-header-deletion-background);
71
- color: var(--git-diff-file-header-deletion-color);
49
+ &.collapsed {
50
+ > svg {
51
+ transform: rotate(0deg);
52
+ }
72
53
  }
73
54
  }
74
55
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/ui/GitDiffViewer/index.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,cAAc,kBAAkB,CAAC;AAEjC,cAAc,kBAAkB,CAAC;AAEjC,OAAO,QAAQ,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAG/D,MAAM,CAAC,MAAM,aAAa,GAAG,QAAkC,CAAC;AAChE,aAAa,CAAC,UAAU,GAAG,UAAU,CAAC;AACtC,aAAa,CAAC,cAAc,GAAG,cAAc,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/ui/GitDiffViewer/index.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,cAAc,kBAAkB,CAAC;AAEjC,cAAc,kBAAkB,CAAC;AAEjC,OAAO,QAAQ,MAAM,eAAe,CAAC;AACrC,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/D,MAAM,CAAC,MAAM,aAAa,GAAG,QAG5B,CAAC;AACF,aAAa,CAAC,UAAU,GAAG,UAAU,CAAC;AACtC,aAAa,CAAC,cAAc,GAAG,cAAc,CAAC"}
@@ -1,18 +1,17 @@
1
1
  /* GitDiffViewer.css */
2
2
  .ds.git-diff-viewer {
3
3
  --git-diff-viewer-code-default-background: #f7f7f7;
4
- --git-diff-viewer-code-default-color: #636363;
4
+ --git-diff-viewer-code-default-color: #000000;
5
+ --git-diff-viewer-code-line-number-default-color: #707070;
5
6
  --git-diff-viewer-code-insertion-background: #dff1e2;
6
- --git-diff-viewer-code-insertion-color: #8cd297;
7
7
  --git-diff-viewer-code-deletion-background: #f8e8ea;
8
- --git-diff-viewer-code-deletion-color: #fba1aa;
9
8
 
10
9
  --git-diff-viewer-border-color: rgba(0, 0, 0, 0.2);
11
10
  --git-diff-viewer-border-color-tinted: rgba(0, 0, 0, 0.1);
12
11
 
13
12
  --git-diff-viewer-gutter-width: 7.5em;
14
13
  --git-diff-viewer-hunk-header-background: #ffffff;
15
- --git-diff-viewer-hunk-header-color: rgba(0, 0, 0, 0.6);
14
+ --git-diff-viewer-hunk-header-color: #707070;
16
15
 
17
16
  --git-diff-file-header-horizontal-padding: 1em;
18
17
  --git-diff-file-header-vertical-padding: 0.4em;
@@ -23,16 +22,5 @@
23
22
  --git-diff-file-header-button-hover-background: rgba(0, 0, 0, 0.1);
24
23
  --git-diff-file-header-button-focus-background: rgba(0, 0, 0, 0.1);
25
24
 
26
- --git-diff-file-header-insertion-background: rgba(10, 189, 37, 0.1);
27
- --git-diff-file-header-insertion-color: var(
28
- --git-diff-viewer-code-insertion-color,
29
- #8cd297
30
- );
31
- --git-diff-file-header-deletion-background: rgba(255, 102, 120, 0.1);
32
- --git-diff-file-header-deletion-color: var(
33
- --git-diff-viewer-code-deletion-color,
34
- #fba1aa
35
- );
36
-
37
25
  border: 1px solid var(--git-diff-viewer-border-color);
38
26
  }
@@ -0,0 +1,52 @@
1
+ import hljs from "highlight.js";
2
+ function highlight(code, fileExtension) {
3
+ const formattedFileExtension = fileExtension?.toLowerCase();
4
+ if (!formattedFileExtension) {
5
+ return hljs.highlightAuto(code).value;
6
+ }
7
+ const languages = hljs.listLanguages();
8
+ for (const language of languages) {
9
+ const languageDefinition = hljs.getLanguage(language);
10
+ if (language.toLowerCase() === formattedFileExtension ||
11
+ languageDefinition?.aliases?.some((alias) => alias.toLowerCase() === formattedFileExtension)) {
12
+ return hljs.highlight(code, { language }).value;
13
+ }
14
+ }
15
+ // Fall back to auto-detection if no match found
16
+ return hljs.highlightAuto(code).value;
17
+ }
18
+ function highlightDiffHunkLines(filePath, hunkLines) {
19
+ const fileExtension = filePath.split(".").pop();
20
+ const hunkContentAddedVersion = hunkLines
21
+ .filter((line) => line.type === "add" || line.type === "context")
22
+ .map((line) => line.content)
23
+ .join("\n");
24
+ const hunkContentDeletedVersion = hunkLines
25
+ .filter((line) => line.type === "remove" || line.type === "context")
26
+ .map((line) => line.content)
27
+ .join("\n");
28
+ const highlightedHunkAddedVersion = highlight(hunkContentAddedVersion, fileExtension).split("\n");
29
+ const highlightedHunkDeletedVersion = highlight(hunkContentDeletedVersion, fileExtension).split("\n");
30
+ const highlightedLines = [];
31
+ let addedOffset = 0;
32
+ let removedOffset = 0;
33
+ for (let i = 0; i < hunkLines.length; i++) {
34
+ const line = hunkLines[i];
35
+ switch (line.type) {
36
+ case "context":
37
+ highlightedLines.push(highlightedHunkDeletedVersion[i - addedOffset]);
38
+ break;
39
+ case "remove":
40
+ highlightedLines.push(highlightedHunkDeletedVersion[i - addedOffset]);
41
+ removedOffset++;
42
+ break;
43
+ case "add":
44
+ highlightedLines.push(highlightedHunkAddedVersion[i - removedOffset]);
45
+ addedOffset++;
46
+ break;
47
+ }
48
+ }
49
+ return highlightedLines;
50
+ }
51
+ export default highlightDiffHunkLines;
52
+ //# sourceMappingURL=highlightDiffHunkLines.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"highlightDiffHunkLines.js","sourceRoot":"","sources":["../../../../../src/ui/GitDiffViewer/utils/highlightDiffHunkLines.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,3 @@
1
1
  export { default as parseGitDiff } from "./parseGitDiff.js";
2
+ export { default as highlightDiffHunkLines } from "./highlightDiffHunkLines.js";
2
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/GitDiffViewer/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,mBAAmB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/ui/GitDiffViewer/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC5D,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,6BAA6B,CAAC"}
@@ -3,12 +3,14 @@ function parseGitDiff(diffText) {
3
3
  const files = [];
4
4
  let currentFile = null;
5
5
  let currentHunk = null;
6
+ let currentDiffStart = 0;
6
7
  // Regular expressions to match file and hunk headers
7
8
  const fileRegex = /^diff --git a\/(.+) b\/(.+)$/;
8
9
  const hunkRegex = /^@@ -(\d+),?(\d*) \+(\d+),?(\d*) @@/;
9
10
  const oldFileRegex = /^--- (.+)$/;
10
11
  const newFileRegex = /^\+\+\+ (.+)$/;
11
12
  for (const line of lines) {
13
+ currentDiffStart++;
12
14
  const fileMatch = line.match(fileRegex);
13
15
  if (fileMatch) {
14
16
  // New file diff start
@@ -42,13 +44,33 @@ function parseGitDiff(diffText) {
42
44
  }
43
45
  const hunkMatch = line.match(hunkRegex);
44
46
  if (hunkMatch && currentFile) {
47
+ const hunkPositions = [
48
+ Number.parseInt(hunkMatch[1]),
49
+ hunkMatch[2] ? Number.parseInt(hunkMatch[2]) : 1,
50
+ Number.parseInt(hunkMatch[3]),
51
+ hunkMatch[4] ? Number.parseInt(hunkMatch[4]) : 1,
52
+ ];
53
+ const oldPos = {
54
+ start: hunkPositions[0],
55
+ end: hunkPositions[0] + hunkPositions[1],
56
+ };
57
+ const newPos = {
58
+ start: hunkPositions[2],
59
+ end: hunkPositions[2] + hunkPositions[3],
60
+ };
61
+ const diffPos = {
62
+ // +1 because the first line is the hunk header
63
+ start: currentDiffStart + 1,
64
+ end: currentDiffStart + 1,
65
+ };
45
66
  // New hunk start
46
67
  currentHunk = {
47
68
  header: line,
48
- oldStart: Number.parseInt(hunkMatch[1], 10),
49
- oldLines: hunkMatch[2] ? Number.parseInt(hunkMatch[2], 10) : 1,
50
- newStart: Number.parseInt(hunkMatch[3], 10),
51
- newLines: hunkMatch[4] ? Number.parseInt(hunkMatch[4], 10) : 1,
69
+ positions: {
70
+ old: oldPos,
71
+ new: newPos,
72
+ diff: diffPos,
73
+ },
52
74
  lines: [],
53
75
  };
54
76
  currentFile.hunks.push(currentHunk);
@@ -63,6 +85,7 @@ function parseGitDiff(diffText) {
63
85
  : "context";
64
86
  const content = line.slice(1); // Remove the leading +, - or space
65
87
  currentHunk.lines.push({ type, content });
88
+ currentHunk.positions.diff.end++;
66
89
  }
67
90
  }
68
91
  if (currentFile)
@@ -1 +1 @@
1
- {"version":3,"file":"parseGitDiff.js","sourceRoot":"","sources":["../../../../../src/ui/GitDiffViewer/utils/parseGitDiff.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"parseGitDiff.js","sourceRoot":"","sources":["../../../../../src/ui/GitDiffViewer/utils/parseGitDiff.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,75 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import hljs from "highlight.js";
3
+ import { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef, useState, } from "react";
4
+ import ReactMarkdown from "react-markdown";
5
+ import rehypeSanitize from "rehype-sanitize";
6
+ import remarkGfm from "remark-gfm";
7
+ import "../GitDiffViewer/common/CodeDiffViewer/HighlighTheme.css";
8
+ import { Toolbar, ViewModeTabs, icons, } from "./common/index.js";
9
+ import { useEditor } from "./hooks/index.js";
10
+ import "./styles.css";
11
+ ("react-markdown");
12
+ const componentCssClassName = "ds markdown-editor";
13
+ const borderCssClassName = "bordered";
14
+ /**
15
+ * A dual-mode Markdown editor for writing and previewing Markdown content.
16
+ */
17
+ const MarkdownEditor = forwardRef(({ id, className, style, textareaStyle, previewStyle, defaultValue, placeholder, hideToolbar = false, hidePreview = false, previewSwitchMode = "tab", borderless = false, editMode: controlledEditMode, onEditModeChange: controlledOnEditModeChange, emptyInputMessage = "No content", toolbarBarLabelMessage = "Markdown Editor", ToolbarTextFormattingGroupLabelMessage = "Text Formatting", ToolbarToolsGroupLabelMessage = "Tools", ToolbarTitleButtonLabelMessage = "Title", ToolbarBoldButtonLabelMessage = "Bold", ToolbarItalicButtonLabelMessage = "Italic", ToolbarQuoteButtonLabelMessage = "Quote", ToolbarCodeButtonLabelMessage = "Code", ToolbarLinkButtonLabelMessage = "Link", ToolbarUnorderedListButtonLabelMessage = "Unordered List", ToolbarOrderedListButtonLabelMessage = "Ordered List", ...textareaProps }, ref) => {
18
+ const textareaRef = useRef(null);
19
+ const previewRef = useRef(null);
20
+ const [internalEditMode, setInternalEditMode] = useState("write");
21
+ const [shouldFocusTextarea, setShouldFocusTextarea] = useState(false);
22
+ const { toolbar } = useEditor(textareaRef);
23
+ const editMode = useMemo(() => {
24
+ return controlledEditMode ?? internalEditMode;
25
+ }, [controlledEditMode, internalEditMode]);
26
+ const handleEditModeChange = useCallback((newEditMode, eventType) => {
27
+ if (controlledOnEditModeChange) {
28
+ controlledOnEditModeChange(newEditMode);
29
+ }
30
+ else {
31
+ setInternalEditMode(newEditMode);
32
+ }
33
+ // Set flag to focus textarea when switching to write mode after click
34
+ if (eventType === "click" && newEditMode === "write") {
35
+ setShouldFocusTextarea(true);
36
+ }
37
+ }, [controlledOnEditModeChange]);
38
+ useImperativeHandle(ref, () => textareaRef.current);
39
+ // Focus textarea when edit mode changes to "write"
40
+ useEffect(() => {
41
+ if (editMode === "write" && shouldFocusTextarea) {
42
+ // Use a small timeout to ensure DOM has updated
43
+ const focusTimeout = setTimeout(() => {
44
+ if (textareaRef.current) {
45
+ textareaRef.current.focus();
46
+ }
47
+ setShouldFocusTextarea(false);
48
+ }, 10);
49
+ return () => clearTimeout(focusTimeout);
50
+ }
51
+ }, [editMode, shouldFocusTextarea]);
52
+ useEffect(() => {
53
+ if (previewRef.current && editMode === "preview") {
54
+ for (const codeBlock of Array.from(previewRef.current.querySelectorAll("pre code"))) {
55
+ if (!codeBlock.dataset.highlighted) {
56
+ hljs.highlightElement(codeBlock);
57
+ }
58
+ }
59
+ }
60
+ }, [editMode]);
61
+ return (_jsxs("div", { id: id, style: style, className: [
62
+ componentCssClassName,
63
+ className,
64
+ !borderless && borderCssClassName,
65
+ ]
66
+ .filter(Boolean)
67
+ .join(" "), children: [_jsxs("div", { className: "top-bar", children: [!hidePreview && previewSwitchMode === "tab" && (_jsx(ViewModeTabs, { editMode: editMode, onEditModeChange: handleEditModeChange })), !hideToolbar && toolbar && (_jsxs(Toolbar, { label: toolbarBarLabelMessage, children: [_jsxs(Toolbar.Group, { label: ToolbarTextFormattingGroupLabelMessage, children: [_jsx(Toolbar.Button, { label: ToolbarTitleButtonLabelMessage, onClick: toolbar.title.handler, shortcut: toolbar.title.shortcut, children: icons.ToolbarTitle }), _jsx(Toolbar.Button, { label: ToolbarBoldButtonLabelMessage, onClick: toolbar.bold.handler, shortcut: toolbar.bold.shortcut, children: icons.ToolbarBold }), _jsx(Toolbar.Button, { label: ToolbarItalicButtonLabelMessage, onClick: toolbar.italic.handler, shortcut: toolbar.italic.shortcut, children: icons.ToolbarItalic })] }), _jsx(Toolbar.Separator, {}), _jsxs(Toolbar.Group, { label: ToolbarToolsGroupLabelMessage, children: [_jsx(Toolbar.Button, { label: ToolbarQuoteButtonLabelMessage, onClick: toolbar.quote.handler, shortcut: toolbar.quote.shortcut, children: icons.ToolbarQuote }), _jsx(Toolbar.Button, { label: ToolbarCodeButtonLabelMessage, onClick: toolbar.code.handler, shortcut: toolbar.code.shortcut, children: icons.ToolbarCode }), _jsx(Toolbar.Button, { label: ToolbarLinkButtonLabelMessage, onClick: toolbar.link.handler, shortcut: toolbar.link.shortcut, children: icons.ToolbarLink }), _jsx(Toolbar.Button, { label: ToolbarUnorderedListButtonLabelMessage, onClick: toolbar.uList.handler, shortcut: toolbar.uList.shortcut, children: icons.ToolbarUnorderedList }), _jsx(Toolbar.Button, { label: ToolbarOrderedListButtonLabelMessage, onClick: toolbar.oList.handler, shortcut: toolbar.oList.shortcut, children: icons.ToolbarOrderedList })] })] })), !hidePreview && previewSwitchMode === "checkbox" && (_jsxs("div", { className: "preview-switch", children: [_jsx("input", { type: "checkbox", id: `${id}-preview-switch`, checked: editMode === "preview", onChange: (e) => {
68
+ handleEditModeChange(e.target.checked ? "preview" : "write", "click");
69
+ } }), _jsx("label", { htmlFor: `${id}-preview-switch`, children: "Preview" })] }))] }), _jsx("textarea", { defaultValue: defaultValue, placeholder: placeholder, className: "editor-content", ref: textareaRef, hidden: editMode !== "write", style: textareaStyle, ...textareaProps }), editMode === "preview" && (_jsx("div", { className: "editor-content", style: previewStyle, ref: previewRef, children: _jsx(ReactMarkdown, { rehypePlugins: [rehypeSanitize], remarkPlugins: [remarkGfm], components: {
70
+ h1: ({ children }) => _jsx("h3", { children: children }),
71
+ h2: ({ children }) => _jsx("h3", { children: children }),
72
+ }, children: textareaRef.current?.value || defaultValue || emptyInputMessage }) }))] }));
73
+ });
74
+ export default MarkdownEditor;
75
+ //# sourceMappingURL=MarkdownEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarkdownEditor.js","sourceRoot":"","sources":["../../../../src/ui/MarkdownEditor/MarkdownEditor.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,52 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useRef } from "react";
3
+ import { ToolbarButton, ToolbarGroup, ToolbarSeparator, } from "./common/index.js";
4
+ import "./styles.css";
5
+ const componentCssClassName = "ds toolbar";
6
+ /**
7
+ * A horizontal container that groups related controls in a toolbar.
8
+ */
9
+ const Toolbar = (({ id, children, className, style, label }) => {
10
+ const toolbarRef = useRef(null);
11
+ // biome-ignore lint/correctness/useExhaustiveDependencies: We want to reapply tabindex when children change
12
+ useEffect(() => {
13
+ if (!toolbarRef.current)
14
+ return;
15
+ const buttons = Array.from(toolbarRef.current.querySelectorAll("button"));
16
+ for (const button of buttons) {
17
+ button.setAttribute("tabindex", "-1");
18
+ }
19
+ const firstNode = buttons[0];
20
+ if (firstNode)
21
+ firstNode.setAttribute("tabindex", "0");
22
+ }, [children]);
23
+ const handleKeyDown = (event) => {
24
+ if (!toolbarRef.current)
25
+ return;
26
+ const target = event.target;
27
+ if (target.tagName !== "BUTTON")
28
+ return;
29
+ if (event.key === "ArrowLeft" || event.key === "ArrowRight") {
30
+ event.preventDefault();
31
+ const buttons = Array.from(toolbarRef.current.querySelectorAll("button") ?? []);
32
+ const direction = event.key === "ArrowLeft" ? -1 : 1;
33
+ const currentIndex = buttons.indexOf(target);
34
+ let nextIndex = currentIndex + direction;
35
+ if (nextIndex < 0)
36
+ nextIndex = buttons.length - 1;
37
+ if (nextIndex >= buttons.length)
38
+ nextIndex = 0;
39
+ const currentButton = buttons[currentIndex];
40
+ const nextButton = buttons[nextIndex];
41
+ currentButton.setAttribute("tabindex", "-1");
42
+ nextButton.setAttribute("tabindex", "0");
43
+ nextButton.focus();
44
+ }
45
+ };
46
+ return (_jsx("div", { id: id, style: style, className: [componentCssClassName, className].filter(Boolean).join(" "), "aria-label": label, role: "toolbar", "aria-orientation": "horizontal", ref: toolbarRef, onKeyDown: handleKeyDown, children: children }));
47
+ });
48
+ Toolbar.Group = ToolbarGroup;
49
+ Toolbar.Button = ToolbarButton;
50
+ Toolbar.Separator = ToolbarSeparator;
51
+ export default Toolbar;
52
+ //# sourceMappingURL=Toolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Toolbar.js","sourceRoot":"","sources":["../../../../../../src/ui/MarkdownEditor/common/Toolbar/Toolbar.tsx"],"names":[],"mappings":"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"}