@pierre/diffs 1.3.0-beta.4 → 1.3.0-beta.6

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 (625) hide show
  1. package/README.md +15 -15
  2. package/dist/components/CodeView.d.ts +10 -11
  3. package/dist/components/CodeView.d.ts.map +1 -1
  4. package/dist/components/CodeView.js +14 -14
  5. package/dist/components/CodeView.js.map +1 -1
  6. package/dist/components/File.d.ts +4 -4
  7. package/dist/components/File.d.ts.map +1 -1
  8. package/dist/components/File.js +53 -24
  9. package/dist/components/File.js.map +1 -1
  10. package/dist/components/FileDiff.d.ts +19 -18
  11. package/dist/components/FileDiff.d.ts.map +1 -1
  12. package/dist/components/FileDiff.js +89 -58
  13. package/dist/components/FileDiff.js.map +1 -1
  14. package/dist/components/FileStream.d.ts +0 -1
  15. package/dist/components/FileStream.d.ts.map +1 -1
  16. package/dist/components/FileStream.js +8 -6
  17. package/dist/components/FileStream.js.map +1 -1
  18. package/dist/components/UnresolvedFile.d.ts +1 -2
  19. package/dist/components/UnresolvedFile.d.ts.map +1 -1
  20. package/dist/components/UnresolvedFile.js +3 -3
  21. package/dist/components/UnresolvedFile.js.map +1 -1
  22. package/dist/components/VirtualizedFile.d.ts +5 -2
  23. package/dist/components/VirtualizedFile.d.ts.map +1 -1
  24. package/dist/components/VirtualizedFile.js +97 -35
  25. package/dist/components/VirtualizedFile.js.map +1 -1
  26. package/dist/components/VirtualizedFileDiff.d.ts +8 -4
  27. package/dist/components/VirtualizedFileDiff.d.ts.map +1 -1
  28. package/dist/components/VirtualizedFileDiff.js +91 -30
  29. package/dist/components/VirtualizedFileDiff.js.map +1 -1
  30. package/dist/components/Virtualizer.d.ts +1 -1
  31. package/dist/components/Virtualizer.d.ts.map +1 -1
  32. package/dist/components/Virtualizer.js +23 -24
  33. package/dist/components/Virtualizer.js.map +1 -1
  34. package/dist/components/VirtulizerDevelopment.d.ts.map +1 -1
  35. package/dist/components/web-components.d.ts.map +1 -1
  36. package/dist/components/web-components.js +2 -3
  37. package/dist/components/web-components.js.map +1 -1
  38. package/dist/constants.d.ts +3 -2
  39. package/dist/constants.d.ts.map +1 -1
  40. package/dist/constants.js +3 -2
  41. package/dist/constants.js.map +1 -1
  42. package/dist/editor/command.d.ts +3 -2
  43. package/dist/editor/command.d.ts.map +1 -1
  44. package/dist/editor/command.js +10 -6
  45. package/dist/editor/command.js.map +1 -1
  46. package/dist/editor/editStack.d.ts +7 -1
  47. package/dist/editor/editStack.d.ts.map +1 -1
  48. package/dist/editor/editStack.js +3 -3
  49. package/dist/editor/editStack.js.map +1 -1
  50. package/dist/editor/editor.d.ts +56 -6
  51. package/dist/editor/editor.d.ts.map +1 -1
  52. package/dist/editor/editor.js +758 -397
  53. package/dist/editor/editor.js.map +1 -1
  54. package/dist/editor/editor2.js +3 -3
  55. package/dist/editor/editor2.js.map +1 -1
  56. package/dist/editor/index.d.ts +2 -2
  57. package/dist/editor/index.js +1 -2
  58. package/dist/editor/lineAnnotations.d.ts.map +1 -1
  59. package/dist/editor/lineAnnotations.js +2 -3
  60. package/dist/editor/lineAnnotations.js.map +1 -1
  61. package/dist/editor/marker.d.ts +4 -3
  62. package/dist/editor/marker.d.ts.map +1 -1
  63. package/dist/editor/marker.js +30 -13
  64. package/dist/editor/marker.js.map +1 -1
  65. package/dist/editor/pieceTable.d.ts +10 -3
  66. package/dist/editor/pieceTable.d.ts.map +1 -1
  67. package/dist/editor/pieceTable.js +170 -129
  68. package/dist/editor/pieceTable.js.map +1 -1
  69. package/dist/editor/platform.d.ts +8 -1
  70. package/dist/editor/platform.d.ts.map +1 -1
  71. package/dist/editor/platform.js +16 -5
  72. package/dist/editor/platform.js.map +1 -1
  73. package/dist/editor/searchPanel.d.ts +13 -3
  74. package/dist/editor/searchPanel.d.ts.map +1 -1
  75. package/dist/editor/searchPanel.js +194 -67
  76. package/dist/editor/searchPanel.js.map +1 -1
  77. package/dist/editor/selection.d.ts +41 -4
  78. package/dist/editor/selection.d.ts.map +1 -1
  79. package/dist/editor/selection.js +423 -83
  80. package/dist/editor/selection.js.map +1 -1
  81. package/dist/editor/selectionAction.d.ts +4 -5
  82. package/dist/editor/selectionAction.d.ts.map +1 -1
  83. package/dist/editor/selectionAction.js +14 -64
  84. package/dist/editor/selectionAction.js.map +1 -1
  85. package/dist/editor/sprite.d.ts +2 -2
  86. package/dist/editor/sprite.d.ts.map +1 -1
  87. package/dist/editor/sprite.js +8 -8
  88. package/dist/editor/sprite.js.map +1 -1
  89. package/dist/editor/textDocument.d.ts +5 -4
  90. package/dist/editor/textDocument.d.ts.map +1 -1
  91. package/dist/editor/textDocument.js +26 -15
  92. package/dist/editor/textDocument.js.map +1 -1
  93. package/dist/editor/textMeasure.d.ts +37 -3
  94. package/dist/editor/textMeasure.d.ts.map +1 -1
  95. package/dist/editor/textMeasure.js +85 -10
  96. package/dist/editor/textMeasure.js.map +1 -1
  97. package/dist/editor/tokenzier.d.ts +1 -0
  98. package/dist/editor/tokenzier.d.ts.map +1 -1
  99. package/dist/editor/tokenzier.js +25 -19
  100. package/dist/editor/tokenzier.js.map +1 -1
  101. package/dist/editor/utils.d.ts +2 -1
  102. package/dist/editor/utils.d.ts.map +1 -1
  103. package/dist/editor/utils.js +6 -3
  104. package/dist/editor/utils.js.map +1 -1
  105. package/dist/highlighter/languages/areLanguagesAttached.d.ts.map +1 -1
  106. package/dist/highlighter/languages/areLanguagesAttached.js +1 -2
  107. package/dist/highlighter/languages/areLanguagesAttached.js.map +1 -1
  108. package/dist/highlighter/languages/attachResolvedLanguages.d.ts +0 -2
  109. package/dist/highlighter/languages/attachResolvedLanguages.d.ts.map +1 -1
  110. package/dist/highlighter/languages/attachResolvedLanguages.js +1 -2
  111. package/dist/highlighter/languages/attachResolvedLanguages.js.map +1 -1
  112. package/dist/highlighter/languages/cleanUpResolvedLanguages.d.ts.map +1 -1
  113. package/dist/highlighter/languages/cleanUpResolvedLanguages.js +1 -2
  114. package/dist/highlighter/languages/cleanUpResolvedLanguages.js.map +1 -1
  115. package/dist/highlighter/languages/constants.d.ts +0 -1
  116. package/dist/highlighter/languages/constants.d.ts.map +1 -1
  117. package/dist/highlighter/languages/constants.js +1 -1
  118. package/dist/highlighter/languages/constants.js.map +1 -1
  119. package/dist/highlighter/languages/getResolvedLanguages.d.ts +0 -2
  120. package/dist/highlighter/languages/getResolvedLanguages.d.ts.map +1 -1
  121. package/dist/highlighter/languages/getResolvedLanguages.js +1 -2
  122. package/dist/highlighter/languages/getResolvedLanguages.js.map +1 -1
  123. package/dist/highlighter/languages/getResolvedOrResolveLanguage.d.ts +0 -2
  124. package/dist/highlighter/languages/getResolvedOrResolveLanguage.d.ts.map +1 -1
  125. package/dist/highlighter/languages/getResolvedOrResolveLanguage.js +1 -2
  126. package/dist/highlighter/languages/getResolvedOrResolveLanguage.js.map +1 -1
  127. package/dist/highlighter/languages/hasResolvedLanguages.d.ts.map +1 -1
  128. package/dist/highlighter/languages/hasResolvedLanguages.js +1 -2
  129. package/dist/highlighter/languages/hasResolvedLanguages.js.map +1 -1
  130. package/dist/highlighter/languages/registerCustomLanguage.d.ts +0 -1
  131. package/dist/highlighter/languages/registerCustomLanguage.d.ts.map +1 -1
  132. package/dist/highlighter/languages/registerCustomLanguage.js +1 -2
  133. package/dist/highlighter/languages/registerCustomLanguage.js.map +1 -1
  134. package/dist/highlighter/languages/resolveLanguage.d.ts +0 -2
  135. package/dist/highlighter/languages/resolveLanguage.d.ts.map +1 -1
  136. package/dist/highlighter/languages/resolveLanguage.js +4 -5
  137. package/dist/highlighter/languages/resolveLanguage.js.map +1 -1
  138. package/dist/highlighter/languages/resolveLanguages.d.ts +0 -2
  139. package/dist/highlighter/languages/resolveLanguages.d.ts.map +1 -1
  140. package/dist/highlighter/languages/resolveLanguages.js +1 -2
  141. package/dist/highlighter/languages/resolveLanguages.js.map +1 -1
  142. package/dist/highlighter/shared_highlighter.d.ts.map +1 -1
  143. package/dist/highlighter/shared_highlighter.js +3 -4
  144. package/dist/highlighter/shared_highlighter.js.map +1 -1
  145. package/dist/highlighter/themes/areThemesAttached.d.ts.map +1 -1
  146. package/dist/highlighter/themes/areThemesAttached.js +1 -2
  147. package/dist/highlighter/themes/areThemesAttached.js.map +1 -1
  148. package/dist/highlighter/themes/attachResolvedThemes.d.ts.map +1 -1
  149. package/dist/highlighter/themes/attachResolvedThemes.js +1 -2
  150. package/dist/highlighter/themes/attachResolvedThemes.js.map +1 -1
  151. package/dist/highlighter/themes/cleanUpResolvedThemes.d.ts.map +1 -1
  152. package/dist/highlighter/themes/cleanUpResolvedThemes.js +1 -2
  153. package/dist/highlighter/themes/cleanUpResolvedThemes.js.map +1 -1
  154. package/dist/highlighter/themes/constants.d.ts.map +1 -1
  155. package/dist/highlighter/themes/constants.js +1 -1
  156. package/dist/highlighter/themes/constants.js.map +1 -1
  157. package/dist/highlighter/themes/getResolvedOrResolveTheme.d.ts.map +1 -1
  158. package/dist/highlighter/themes/getResolvedOrResolveTheme.js +1 -2
  159. package/dist/highlighter/themes/getResolvedOrResolveTheme.js.map +1 -1
  160. package/dist/highlighter/themes/getResolvedThemes.d.ts.map +1 -1
  161. package/dist/highlighter/themes/getResolvedThemes.js +1 -2
  162. package/dist/highlighter/themes/getResolvedThemes.js.map +1 -1
  163. package/dist/highlighter/themes/hasResolvedThemes.d.ts.map +1 -1
  164. package/dist/highlighter/themes/hasResolvedThemes.js +1 -2
  165. package/dist/highlighter/themes/hasResolvedThemes.js.map +1 -1
  166. package/dist/highlighter/themes/registerCustomCSSVariableTheme.d.ts.map +1 -1
  167. package/dist/highlighter/themes/registerCustomCSSVariableTheme.js +1 -2
  168. package/dist/highlighter/themes/registerCustomCSSVariableTheme.js.map +1 -1
  169. package/dist/highlighter/themes/registerCustomTheme.d.ts.map +1 -1
  170. package/dist/highlighter/themes/registerCustomTheme.js +1 -2
  171. package/dist/highlighter/themes/registerCustomTheme.js.map +1 -1
  172. package/dist/highlighter/themes/resolveTheme.d.ts.map +1 -1
  173. package/dist/highlighter/themes/resolveTheme.js +1 -2
  174. package/dist/highlighter/themes/resolveTheme.js.map +1 -1
  175. package/dist/highlighter/themes/resolveThemes.d.ts.map +1 -1
  176. package/dist/highlighter/themes/resolveThemes.js +1 -2
  177. package/dist/highlighter/themes/resolveThemes.js.map +1 -1
  178. package/dist/highlighter/themes/themeResolution.d.ts.map +1 -1
  179. package/dist/highlighter/themes/themeResolution.js +1 -2
  180. package/dist/highlighter/themes/themeResolution.js.map +1 -1
  181. package/dist/highlighter/themes/themeResolver.d.ts +2 -2
  182. package/dist/highlighter/themes/themeResolver.d.ts.map +1 -1
  183. package/dist/highlighter/themes/themeResolver.js +1 -2
  184. package/dist/highlighter/themes/themeResolver.js.map +1 -1
  185. package/dist/index.d.ts +10 -10
  186. package/dist/index.js +2 -3
  187. package/dist/managers/InteractionManager.d.ts +7 -0
  188. package/dist/managers/InteractionManager.d.ts.map +1 -1
  189. package/dist/managers/InteractionManager.js +26 -4
  190. package/dist/managers/InteractionManager.js.map +1 -1
  191. package/dist/managers/ResizeManager.d.ts.map +1 -1
  192. package/dist/managers/ResizeManager.js +2 -2
  193. package/dist/managers/ResizeManager.js.map +1 -1
  194. package/dist/managers/ScrollSyncManager.d.ts.map +1 -1
  195. package/dist/managers/ScrollSyncManager.js +1 -1
  196. package/dist/managers/ScrollSyncManager.js.map +1 -1
  197. package/dist/managers/UniversalRenderingManager.d.ts.map +1 -1
  198. package/dist/managers/UniversalRenderingManager.js +2 -2
  199. package/dist/managers/UniversalRenderingManager.js.map +1 -1
  200. package/dist/node_modules/.pnpm/@types_hast@3.0.4/node_modules/@types/hast/index.d.ts +228 -0
  201. package/dist/node_modules/.pnpm/@types_hast@3.0.4/node_modules/@types/hast/index.d.ts.map +1 -0
  202. package/dist/node_modules/.pnpm/@types_unist@3.0.3/node_modules/@types/unist/index.d.ts +84 -0
  203. package/dist/node_modules/.pnpm/@types_unist@3.0.3/node_modules/@types/unist/index.d.ts.map +1 -0
  204. package/dist/react/CodeView.d.ts +1 -1
  205. package/dist/react/CodeView.d.ts.map +1 -1
  206. package/dist/react/CodeView.js +16 -15
  207. package/dist/react/CodeView.js.map +1 -1
  208. package/dist/react/EditorContext.d.ts +0 -1
  209. package/dist/react/EditorContext.d.ts.map +1 -1
  210. package/dist/react/EditorContext.js +2 -5
  211. package/dist/react/EditorContext.js.map +1 -1
  212. package/dist/react/File.d.ts +1 -0
  213. package/dist/react/File.d.ts.map +1 -1
  214. package/dist/react/File.js +4 -6
  215. package/dist/react/File.js.map +1 -1
  216. package/dist/react/FileDiff.d.ts +1 -0
  217. package/dist/react/FileDiff.d.ts.map +1 -1
  218. package/dist/react/FileDiff.js +4 -6
  219. package/dist/react/FileDiff.js.map +1 -1
  220. package/dist/react/MultiFileDiff.d.ts +1 -0
  221. package/dist/react/MultiFileDiff.d.ts.map +1 -1
  222. package/dist/react/MultiFileDiff.js +4 -6
  223. package/dist/react/MultiFileDiff.js.map +1 -1
  224. package/dist/react/PatchDiff.d.ts +1 -0
  225. package/dist/react/PatchDiff.d.ts.map +1 -1
  226. package/dist/react/PatchDiff.js +4 -6
  227. package/dist/react/PatchDiff.js.map +1 -1
  228. package/dist/react/UnresolvedFile.d.ts +2 -1
  229. package/dist/react/UnresolvedFile.d.ts.map +1 -1
  230. package/dist/react/UnresolvedFile.js +4 -6
  231. package/dist/react/UnresolvedFile.js.map +1 -1
  232. package/dist/react/Virtualizer.d.ts.map +1 -1
  233. package/dist/react/Virtualizer.js +2 -5
  234. package/dist/react/Virtualizer.js.map +1 -1
  235. package/dist/react/WorkerPoolContext.d.ts +0 -1
  236. package/dist/react/WorkerPoolContext.d.ts.map +1 -1
  237. package/dist/react/WorkerPoolContext.js +2 -5
  238. package/dist/react/WorkerPoolContext.js.map +1 -1
  239. package/dist/react/constants.d.ts.map +1 -1
  240. package/dist/react/constants.js +1 -1
  241. package/dist/react/constants.js.map +1 -1
  242. package/dist/react/index.d.ts +2 -2
  243. package/dist/react/index.js +1 -2
  244. package/dist/react/jsx.d.ts +0 -2
  245. package/dist/react/jsx.d.ts.map +1 -1
  246. package/dist/react/types.d.ts +2 -0
  247. package/dist/react/types.d.ts.map +1 -1
  248. package/dist/react/utils/renderDiffChildren.d.ts +2 -0
  249. package/dist/react/utils/renderDiffChildren.d.ts.map +1 -1
  250. package/dist/react/utils/renderDiffChildren.js +18 -11
  251. package/dist/react/utils/renderDiffChildren.js.map +1 -1
  252. package/dist/react/utils/renderFileChildren.d.ts +2 -0
  253. package/dist/react/utils/renderFileChildren.d.ts.map +1 -1
  254. package/dist/react/utils/renderFileChildren.js +18 -11
  255. package/dist/react/utils/renderFileChildren.js.map +1 -1
  256. package/dist/react/utils/templateRender.d.ts.map +1 -1
  257. package/dist/react/utils/templateRender.js +1 -2
  258. package/dist/react/utils/templateRender.js.map +1 -1
  259. package/dist/react/utils/useFileDiffInstance.d.ts.map +1 -1
  260. package/dist/react/utils/useFileDiffInstance.js +1 -3
  261. package/dist/react/utils/useFileDiffInstance.js.map +1 -1
  262. package/dist/react/utils/useFileInstance.d.ts.map +1 -1
  263. package/dist/react/utils/useFileInstance.js +1 -2
  264. package/dist/react/utils/useFileInstance.js.map +1 -1
  265. package/dist/react/utils/useStableCallback.d.ts.map +1 -1
  266. package/dist/react/utils/useStableCallback.js +1 -2
  267. package/dist/react/utils/useStableCallback.js.map +1 -1
  268. package/dist/react/utils/useUnresolvedFileInstance.d.ts.map +1 -1
  269. package/dist/react/utils/useUnresolvedFileInstance.js +10 -11
  270. package/dist/react/utils/useUnresolvedFileInstance.js.map +1 -1
  271. package/dist/renderers/DiffHunksRenderer.d.ts +5 -5
  272. package/dist/renderers/DiffHunksRenderer.d.ts.map +1 -1
  273. package/dist/renderers/DiffHunksRenderer.js +73 -20
  274. package/dist/renderers/DiffHunksRenderer.js.map +1 -1
  275. package/dist/renderers/FileRenderer.d.ts +1 -3
  276. package/dist/renderers/FileRenderer.d.ts.map +1 -1
  277. package/dist/renderers/FileRenderer.js +23 -8
  278. package/dist/renderers/FileRenderer.js.map +1 -1
  279. package/dist/renderers/UnresolvedFileHunksRenderer.d.ts +1 -2
  280. package/dist/renderers/UnresolvedFileHunksRenderer.d.ts.map +1 -1
  281. package/dist/renderers/UnresolvedFileHunksRenderer.js +1 -2
  282. package/dist/renderers/UnresolvedFileHunksRenderer.js.map +1 -1
  283. package/dist/shiki-stream/index.js +1 -2
  284. package/dist/shiki-stream/stream.d.ts +0 -1
  285. package/dist/shiki-stream/stream.d.ts.map +1 -1
  286. package/dist/shiki-stream/stream.js +1 -2
  287. package/dist/shiki-stream/stream.js.map +1 -1
  288. package/dist/shiki-stream/tokenizer.d.ts.map +1 -1
  289. package/dist/shiki-stream/tokenizer.js +1 -1
  290. package/dist/shiki-stream/tokenizer.js.map +1 -1
  291. package/dist/shiki-stream/types.d.ts +0 -1
  292. package/dist/shiki-stream/types.d.ts.map +1 -1
  293. package/dist/sprite.d.ts.map +1 -1
  294. package/dist/sprite.js +1 -1
  295. package/dist/ssr/FileDiffReact.d.ts.map +1 -1
  296. package/dist/ssr/FileDiffReact.js +4 -7
  297. package/dist/ssr/FileDiffReact.js.map +1 -1
  298. package/dist/ssr/index.d.ts +2 -2
  299. package/dist/ssr/index.js +1 -2
  300. package/dist/ssr/preloadDiffs.d.ts +1 -1
  301. package/dist/ssr/preloadDiffs.d.ts.map +1 -1
  302. package/dist/ssr/preloadDiffs.js +1 -2
  303. package/dist/ssr/preloadDiffs.js.map +1 -1
  304. package/dist/ssr/preloadFile.d.ts.map +1 -1
  305. package/dist/ssr/preloadFile.js +1 -2
  306. package/dist/ssr/preloadFile.js.map +1 -1
  307. package/dist/ssr/preloadPatchFile.d.ts.map +1 -1
  308. package/dist/ssr/preloadPatchFile.js +2 -3
  309. package/dist/ssr/preloadPatchFile.js.map +1 -1
  310. package/dist/ssr/renderHTML.d.ts +1 -1
  311. package/dist/ssr/renderHTML.d.ts.map +1 -1
  312. package/dist/ssr/renderHTML.js +1 -2
  313. package/dist/ssr/renderHTML.js.map +1 -1
  314. package/dist/string-import.d.ts +4 -0
  315. package/dist/string-import.d.ts.map +1 -1
  316. package/dist/style.js +3 -3
  317. package/dist/style.js.map +1 -1
  318. package/dist/types.d.ts +27 -6
  319. package/dist/types.d.ts.map +1 -1
  320. package/dist/utils/areDiffLineAnnotationsEqual.d.ts.map +1 -1
  321. package/dist/utils/areDiffLineAnnotationsEqual.js +1 -1
  322. package/dist/utils/areDiffLineAnnotationsEqual.js.map +1 -1
  323. package/dist/utils/areDiffRenderOptionsEqual.d.ts.map +1 -1
  324. package/dist/utils/areDiffRenderOptionsEqual.js +1 -2
  325. package/dist/utils/areDiffRenderOptionsEqual.js.map +1 -1
  326. package/dist/utils/areDiffTargetsEqual.d.ts.map +1 -1
  327. package/dist/utils/areDiffTargetsEqual.js +1 -1
  328. package/dist/utils/areDiffTargetsEqual.js.map +1 -1
  329. package/dist/utils/areFileRenderOptionsEqual.d.ts.map +1 -1
  330. package/dist/utils/areFileRenderOptionsEqual.js +1 -2
  331. package/dist/utils/areFileRenderOptionsEqual.js.map +1 -1
  332. package/dist/utils/areFilesEqual.d.ts.map +1 -1
  333. package/dist/utils/areFilesEqual.js +1 -1
  334. package/dist/utils/areFilesEqual.js.map +1 -1
  335. package/dist/utils/areHunkDataEqual.d.ts.map +1 -1
  336. package/dist/utils/areHunkDataEqual.js +1 -1
  337. package/dist/utils/areHunkDataEqual.js.map +1 -1
  338. package/dist/utils/areLineAnnotationsEqual.d.ts.map +1 -1
  339. package/dist/utils/areLineAnnotationsEqual.js +1 -1
  340. package/dist/utils/areLineAnnotationsEqual.js.map +1 -1
  341. package/dist/utils/areManagedSnapshotsEqual.d.ts.map +1 -1
  342. package/dist/utils/areManagedSnapshotsEqual.js +1 -1
  343. package/dist/utils/areManagedSnapshotsEqual.js.map +1 -1
  344. package/dist/utils/areMergeConflictActionsEqual.d.ts.map +1 -1
  345. package/dist/utils/areMergeConflictActionsEqual.js +1 -1
  346. package/dist/utils/areMergeConflictActionsEqual.js.map +1 -1
  347. package/dist/utils/areObjectsEqual.d.ts.map +1 -1
  348. package/dist/utils/areObjectsEqual.js +1 -1
  349. package/dist/utils/areObjectsEqual.js.map +1 -1
  350. package/dist/utils/areOptionsEqual.d.ts +0 -2
  351. package/dist/utils/areOptionsEqual.d.ts.map +1 -1
  352. package/dist/utils/areOptionsEqual.js +1 -2
  353. package/dist/utils/areOptionsEqual.js.map +1 -1
  354. package/dist/utils/arePrePropertiesEqual.d.ts.map +1 -1
  355. package/dist/utils/arePrePropertiesEqual.js +1 -1
  356. package/dist/utils/arePrePropertiesEqual.js.map +1 -1
  357. package/dist/utils/areRenderRangesEqual.d.ts.map +1 -1
  358. package/dist/utils/areRenderRangesEqual.js +1 -1
  359. package/dist/utils/areRenderRangesEqual.js.map +1 -1
  360. package/dist/utils/areSelectionPointsEqual.d.ts.map +1 -1
  361. package/dist/utils/areSelectionPointsEqual.js +1 -1
  362. package/dist/utils/areSelectionPointsEqual.js.map +1 -1
  363. package/dist/utils/areSelectionsEqual.d.ts.map +1 -1
  364. package/dist/utils/areSelectionsEqual.js +1 -1
  365. package/dist/utils/areSelectionsEqual.js.map +1 -1
  366. package/dist/utils/areThemesEqual.d.ts.map +1 -1
  367. package/dist/utils/areThemesEqual.js +1 -1
  368. package/dist/utils/areThemesEqual.js.map +1 -1
  369. package/dist/utils/areVirtualWindowSpecsEqual.d.ts.map +1 -1
  370. package/dist/utils/areVirtualWindowSpecsEqual.js +1 -1
  371. package/dist/utils/areVirtualWindowSpecsEqual.js.map +1 -1
  372. package/dist/utils/areWorkerStatsEqual.d.ts +0 -2
  373. package/dist/utils/areWorkerStatsEqual.d.ts.map +1 -1
  374. package/dist/utils/areWorkerStatsEqual.js +1 -1
  375. package/dist/utils/areWorkerStatsEqual.js.map +1 -1
  376. package/dist/utils/cleanLastNewline.d.ts.map +1 -1
  377. package/dist/utils/cleanLastNewline.js +1 -1
  378. package/dist/utils/cleanLastNewline.js.map +1 -1
  379. package/dist/utils/computeEstimatedDiffHeights.d.ts.map +1 -1
  380. package/dist/utils/computeEstimatedDiffHeights.js +1 -2
  381. package/dist/utils/computeEstimatedDiffHeights.js.map +1 -1
  382. package/dist/utils/computeFileOffsets.d.ts +9 -1
  383. package/dist/utils/computeFileOffsets.d.ts.map +1 -1
  384. package/dist/utils/computeFileOffsets.js +20 -2
  385. package/dist/utils/computeFileOffsets.js.map +1 -1
  386. package/dist/utils/computeVirtualFileMetrics.d.ts.map +1 -1
  387. package/dist/utils/computeVirtualFileMetrics.js +1 -2
  388. package/dist/utils/computeVirtualFileMetrics.js.map +1 -1
  389. package/dist/utils/createAnnotationElement.d.ts +1 -1
  390. package/dist/utils/createAnnotationElement.d.ts.map +1 -1
  391. package/dist/utils/createAnnotationElement.js +1 -2
  392. package/dist/utils/createAnnotationElement.js.map +1 -1
  393. package/dist/utils/createAnnotationWrapperNode.d.ts.map +1 -1
  394. package/dist/utils/createAnnotationWrapperNode.js +1 -1
  395. package/dist/utils/createAnnotationWrapperNode.js.map +1 -1
  396. package/dist/utils/createContentColumn.d.ts +1 -1
  397. package/dist/utils/createContentColumn.d.ts.map +1 -1
  398. package/dist/utils/createContentColumn.js +1 -2
  399. package/dist/utils/createContentColumn.js.map +1 -1
  400. package/dist/utils/createEmptyRowBuffer.d.ts +1 -1
  401. package/dist/utils/createEmptyRowBuffer.d.ts.map +1 -1
  402. package/dist/utils/createEmptyRowBuffer.js +1 -2
  403. package/dist/utils/createEmptyRowBuffer.js.map +1 -1
  404. package/dist/utils/createFileHeaderElement.d.ts +1 -1
  405. package/dist/utils/createFileHeaderElement.d.ts.map +1 -1
  406. package/dist/utils/createFileHeaderElement.js +6 -3
  407. package/dist/utils/createFileHeaderElement.js.map +1 -1
  408. package/dist/utils/createGutterUtilityContentNode.d.ts.map +1 -1
  409. package/dist/utils/createGutterUtilityContentNode.js +1 -1
  410. package/dist/utils/createGutterUtilityContentNode.js.map +1 -1
  411. package/dist/utils/createGutterUtilityElement.d.ts +1 -1
  412. package/dist/utils/createGutterUtilityElement.d.ts.map +1 -1
  413. package/dist/utils/createGutterUtilityElement.js +1 -2
  414. package/dist/utils/createGutterUtilityElement.js.map +1 -1
  415. package/dist/utils/createNoNewlineElement.d.ts +1 -1
  416. package/dist/utils/createNoNewlineElement.d.ts.map +1 -1
  417. package/dist/utils/createNoNewlineElement.js +1 -2
  418. package/dist/utils/createNoNewlineElement.js.map +1 -1
  419. package/dist/utils/createPreElement.d.ts +1 -1
  420. package/dist/utils/createPreElement.d.ts.map +1 -1
  421. package/dist/utils/createPreElement.js +1 -2
  422. package/dist/utils/createPreElement.js.map +1 -1
  423. package/dist/utils/createRowNodes.d.ts.map +1 -1
  424. package/dist/utils/createRowNodes.js +1 -1
  425. package/dist/utils/createRowNodes.js.map +1 -1
  426. package/dist/utils/createSeparator.d.ts +1 -1
  427. package/dist/utils/createSeparator.d.ts.map +1 -1
  428. package/dist/utils/createSeparator.js +1 -2
  429. package/dist/utils/createSeparator.js.map +1 -1
  430. package/dist/utils/createSpanNodeFromToken.d.ts.map +1 -1
  431. package/dist/utils/createSpanNodeFromToken.js +1 -2
  432. package/dist/utils/createSpanNodeFromToken.js.map +1 -1
  433. package/dist/utils/createStyleElement.d.ts +1 -1
  434. package/dist/utils/createStyleElement.d.ts.map +1 -1
  435. package/dist/utils/createStyleElement.js +1 -2
  436. package/dist/utils/createStyleElement.js.map +1 -1
  437. package/dist/utils/createTransformerWithState.d.ts.map +1 -1
  438. package/dist/utils/createTransformerWithState.js +1 -2
  439. package/dist/utils/createTransformerWithState.js.map +1 -1
  440. package/dist/utils/createUnsafeCSSStyleNode.d.ts.map +1 -1
  441. package/dist/utils/createUnsafeCSSStyleNode.js +1 -2
  442. package/dist/utils/createUnsafeCSSStyleNode.js.map +1 -1
  443. package/dist/utils/createWindowFromScrollPosition.d.ts.map +1 -1
  444. package/dist/utils/createWindowFromScrollPosition.js +5 -5
  445. package/dist/utils/createWindowFromScrollPosition.js.map +1 -1
  446. package/dist/utils/cssWrappers.d.ts.map +1 -1
  447. package/dist/utils/cssWrappers.js +2 -3
  448. package/dist/utils/cssWrappers.js.map +1 -1
  449. package/dist/utils/detachString.d.ts.map +1 -1
  450. package/dist/utils/detachString.js +1 -1
  451. package/dist/utils/detachString.js.map +1 -1
  452. package/dist/utils/diffAcceptRejectHunk.d.ts.map +1 -1
  453. package/dist/utils/diffAcceptRejectHunk.js +1 -2
  454. package/dist/utils/diffAcceptRejectHunk.js.map +1 -1
  455. package/dist/utils/formatCSSVariablePrefix.d.ts.map +1 -1
  456. package/dist/utils/formatCSSVariablePrefix.js +1 -1
  457. package/dist/utils/formatCSSVariablePrefix.js.map +1 -1
  458. package/dist/utils/getDiffHunksRendererOptions.d.ts.map +1 -1
  459. package/dist/utils/getDiffHunksRendererOptions.js +1 -1
  460. package/dist/utils/getDiffHunksRendererOptions.js.map +1 -1
  461. package/dist/utils/getFileRendererOptions.d.ts.map +1 -1
  462. package/dist/utils/getFileRendererOptions.js +1 -1
  463. package/dist/utils/getFileRendererOptions.js.map +1 -1
  464. package/dist/utils/getFiletypeFromFileName.d.ts.map +1 -1
  465. package/dist/utils/getFiletypeFromFileName.js +1 -1
  466. package/dist/utils/getFiletypeFromFileName.js.map +1 -1
  467. package/dist/utils/getHighlighterOptions.d.ts.map +1 -1
  468. package/dist/utils/getHighlighterOptions.js +1 -2
  469. package/dist/utils/getHighlighterOptions.js.map +1 -1
  470. package/dist/utils/getHighlighterThemeStyles.d.ts.map +1 -1
  471. package/dist/utils/getHighlighterThemeStyles.js +1 -2
  472. package/dist/utils/getHighlighterThemeStyles.js.map +1 -1
  473. package/dist/utils/getHunkSeparatorSlotName.d.ts.map +1 -1
  474. package/dist/utils/getHunkSeparatorSlotName.js +1 -1
  475. package/dist/utils/getHunkSeparatorSlotName.js.map +1 -1
  476. package/dist/utils/getIconForType.d.ts.map +1 -1
  477. package/dist/utils/getIconForType.js +1 -1
  478. package/dist/utils/getIconForType.js.map +1 -1
  479. package/dist/utils/getLineAnnotationName.d.ts.map +1 -1
  480. package/dist/utils/getLineAnnotationName.js +1 -1
  481. package/dist/utils/getLineAnnotationName.js.map +1 -1
  482. package/dist/utils/getLineEndingType.d.ts.map +1 -1
  483. package/dist/utils/getLineEndingType.js +1 -1
  484. package/dist/utils/getLineEndingType.js.map +1 -1
  485. package/dist/utils/getLineNodes.d.ts +1 -1
  486. package/dist/utils/getLineNodes.d.ts.map +1 -1
  487. package/dist/utils/getLineNodes.js +1 -1
  488. package/dist/utils/getLineNodes.js.map +1 -1
  489. package/dist/utils/getMergeConflictActionSlotName.d.ts.map +1 -1
  490. package/dist/utils/getMergeConflictActionSlotName.js +1 -1
  491. package/dist/utils/getMergeConflictActionSlotName.js.map +1 -1
  492. package/dist/utils/getMergeConflictLineTypes.d.ts.map +1 -1
  493. package/dist/utils/getMergeConflictLineTypes.js +1 -2
  494. package/dist/utils/getMergeConflictLineTypes.js.map +1 -1
  495. package/dist/utils/getOrCreateCodeNode.d.ts.map +1 -1
  496. package/dist/utils/getOrCreateCodeNode.js +1 -1
  497. package/dist/utils/getOrCreateCodeNode.js.map +1 -1
  498. package/dist/utils/getSingularPatch.d.ts.map +1 -1
  499. package/dist/utils/getSingularPatch.js +1 -2
  500. package/dist/utils/getSingularPatch.js.map +1 -1
  501. package/dist/utils/getThemes.d.ts.map +1 -1
  502. package/dist/utils/getThemes.js +1 -2
  503. package/dist/utils/getThemes.js.map +1 -1
  504. package/dist/utils/getTotalLineCountFromHunks.d.ts.map +1 -1
  505. package/dist/utils/getTotalLineCountFromHunks.js +1 -1
  506. package/dist/utils/getTotalLineCountFromHunks.js.map +1 -1
  507. package/dist/utils/hast_utils.d.ts +1 -1
  508. package/dist/utils/hast_utils.d.ts.map +1 -1
  509. package/dist/utils/hast_utils.js +1 -1
  510. package/dist/utils/hast_utils.js.map +1 -1
  511. package/dist/utils/hostTheme.d.ts.map +1 -1
  512. package/dist/utils/hostTheme.js +1 -2
  513. package/dist/utils/hostTheme.js.map +1 -1
  514. package/dist/utils/includesFileAnnotations.d.ts +17 -0
  515. package/dist/utils/includesFileAnnotations.d.ts.map +1 -0
  516. package/dist/utils/includesFileAnnotations.js +19 -0
  517. package/dist/utils/includesFileAnnotations.js.map +1 -0
  518. package/dist/utils/isDefaultRenderRange.d.ts.map +1 -1
  519. package/dist/utils/isDefaultRenderRange.js +1 -1
  520. package/dist/utils/isDefaultRenderRange.js.map +1 -1
  521. package/dist/utils/isDiffPlainText.d.ts.map +1 -1
  522. package/dist/utils/isDiffPlainText.js +1 -2
  523. package/dist/utils/isDiffPlainText.js.map +1 -1
  524. package/dist/utils/isFilePlainText.d.ts.map +1 -1
  525. package/dist/utils/isFilePlainText.js +1 -2
  526. package/dist/utils/isFilePlainText.js.map +1 -1
  527. package/dist/utils/isStyleNode.d.ts.map +1 -1
  528. package/dist/utils/isStyleNode.js +1 -1
  529. package/dist/utils/isStyleNode.js.map +1 -1
  530. package/dist/utils/isWorkerContext.d.ts.map +1 -1
  531. package/dist/utils/isWorkerContext.js +1 -1
  532. package/dist/utils/isWorkerContext.js.map +1 -1
  533. package/dist/utils/iterateOverDiff.d.ts.map +1 -1
  534. package/dist/utils/iterateOverDiff.js +44 -45
  535. package/dist/utils/iterateOverDiff.js.map +1 -1
  536. package/dist/utils/normalizeDiffResolution.d.ts.map +1 -1
  537. package/dist/utils/normalizeDiffResolution.js +1 -1
  538. package/dist/utils/normalizeDiffResolution.js.map +1 -1
  539. package/dist/utils/parseDiffDecorations.d.ts.map +1 -1
  540. package/dist/utils/parseDiffDecorations.js +1 -2
  541. package/dist/utils/parseDiffDecorations.js.map +1 -1
  542. package/dist/utils/parseDiffFromFile.d.ts +0 -1
  543. package/dist/utils/parseDiffFromFile.d.ts.map +1 -1
  544. package/dist/utils/parseDiffFromFile.js +1 -2
  545. package/dist/utils/parseDiffFromFile.js.map +1 -1
  546. package/dist/utils/parseLineType.d.ts.map +1 -1
  547. package/dist/utils/parseLineType.js +1 -1
  548. package/dist/utils/parseLineType.js.map +1 -1
  549. package/dist/utils/parseMergeConflictDiffFromFile.d.ts.map +1 -1
  550. package/dist/utils/parseMergeConflictDiffFromFile.js +5 -5
  551. package/dist/utils/parseMergeConflictDiffFromFile.js.map +1 -1
  552. package/dist/utils/parsePatchFiles.d.ts.map +1 -1
  553. package/dist/utils/parsePatchFiles.js +6 -7
  554. package/dist/utils/parsePatchFiles.js.map +1 -1
  555. package/dist/utils/prefersReducedMotion.d.ts.map +1 -1
  556. package/dist/utils/prefersReducedMotion.js +1 -1
  557. package/dist/utils/prefersReducedMotion.js.map +1 -1
  558. package/dist/utils/prerenderHTMLIfNecessary.d.ts.map +1 -1
  559. package/dist/utils/prerenderHTMLIfNecessary.js +1 -1
  560. package/dist/utils/prerenderHTMLIfNecessary.js.map +1 -1
  561. package/dist/utils/processLine.d.ts +1 -1
  562. package/dist/utils/processLine.d.ts.map +1 -1
  563. package/dist/utils/processLine.js +1 -2
  564. package/dist/utils/processLine.js.map +1 -1
  565. package/dist/utils/renderDiffWithHighlighter.d.ts.map +1 -1
  566. package/dist/utils/renderDiffWithHighlighter.js +8 -7
  567. package/dist/utils/renderDiffWithHighlighter.js.map +1 -1
  568. package/dist/utils/renderFileWithHighlighter.d.ts.map +1 -1
  569. package/dist/utils/renderFileWithHighlighter.js +5 -4
  570. package/dist/utils/renderFileWithHighlighter.js.map +1 -1
  571. package/dist/utils/resolveConflict.d.ts.map +1 -1
  572. package/dist/utils/resolveConflict.js +1 -2
  573. package/dist/utils/resolveConflict.js.map +1 -1
  574. package/dist/utils/resolveRegion.d.ts.map +1 -1
  575. package/dist/utils/resolveRegion.js +1 -1
  576. package/dist/utils/resolveRegion.js.map +1 -1
  577. package/dist/utils/roundToDevicePixel.d.ts.map +1 -1
  578. package/dist/utils/roundToDevicePixel.js +1 -1
  579. package/dist/utils/roundToDevicePixel.js.map +1 -1
  580. package/dist/utils/scrollbarGutter.d.ts.map +1 -1
  581. package/dist/utils/scrollbarGutter.js +1 -2
  582. package/dist/utils/scrollbarGutter.js.map +1 -1
  583. package/dist/utils/setLanguageOverride.d.ts.map +1 -1
  584. package/dist/utils/setLanguageOverride.js +1 -1
  585. package/dist/utils/setLanguageOverride.js.map +1 -1
  586. package/dist/utils/setWrapperNodeProps.d.ts.map +1 -1
  587. package/dist/utils/setWrapperNodeProps.js +1 -1
  588. package/dist/utils/setWrapperNodeProps.js.map +1 -1
  589. package/dist/utils/shouldUseTokenTransformer.d.ts.map +1 -1
  590. package/dist/utils/shouldUseTokenTransformer.js +1 -1
  591. package/dist/utils/shouldUseTokenTransformer.js.map +1 -1
  592. package/dist/utils/splitFileContents.d.ts.map +1 -1
  593. package/dist/utils/splitFileContents.js +1 -2
  594. package/dist/utils/splitFileContents.js.map +1 -1
  595. package/dist/utils/trimPatchContext.d.ts.map +1 -1
  596. package/dist/utils/trimPatchContext.js +1 -2
  597. package/dist/utils/trimPatchContext.js.map +1 -1
  598. package/dist/utils/updateDiffHunks.d.ts +2 -1
  599. package/dist/utils/updateDiffHunks.d.ts.map +1 -1
  600. package/dist/utils/updateDiffHunks.js +22 -3
  601. package/dist/utils/updateDiffHunks.js.map +1 -1
  602. package/dist/utils/virtualDiffLayout.d.ts.map +1 -1
  603. package/dist/utils/virtualDiffLayout.js +1 -2
  604. package/dist/utils/virtualDiffLayout.js.map +1 -1
  605. package/dist/utils/wrapTokenFragments.d.ts +1 -1
  606. package/dist/utils/wrapTokenFragments.d.ts.map +1 -1
  607. package/dist/utils/wrapTokenFragments.js +1 -2
  608. package/dist/utils/wrapTokenFragments.js.map +1 -1
  609. package/dist/worker/WorkerPoolManager.d.ts.map +1 -1
  610. package/dist/worker/WorkerPoolManager.js +5 -5
  611. package/dist/worker/WorkerPoolManager.js.map +1 -1
  612. package/dist/worker/getOrCreateWorkerPoolSingleton.d.ts.map +1 -1
  613. package/dist/worker/getOrCreateWorkerPoolSingleton.js +1 -2
  614. package/dist/worker/getOrCreateWorkerPoolSingleton.js.map +1 -1
  615. package/dist/worker/index.js +1 -2
  616. package/dist/worker/types.d.ts.map +1 -1
  617. package/dist/worker/wasm-B9ZqxnKj.js +8 -0
  618. package/dist/worker/wasm-B9ZqxnKj.js.map +1 -0
  619. package/dist/worker/worker-portable.js +2989 -6577
  620. package/dist/worker/worker-portable.js.map +1 -1
  621. package/dist/worker/worker.js +97 -127
  622. package/dist/worker/worker.js.map +1 -1
  623. package/package.json +14 -21
  624. package/dist/worker/wasm-BaDzIkIn.js +0 -10
  625. package/dist/worker/wasm-BaDzIkIn.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"useFileDiffInstance.d.ts","names":["FileDiffOptions","GetHoveredLineResult","DiffLineAnnotation","FileDiffMetadata","SelectedLineRange","VirtualFileMetrics","UseFileDiffInstanceProps","LAnnotation","UseFileDiffInstanceReturn","HTMLElement","useFileDiffInstance","fileDiff","options","lineAnnotations","selectedLines","prerenderedHTML","metrics","hasGutterRenderUtility","hasCustomHeader","disableWorkerPool","contentEditable"],"sources":["../../../src/react/utils/useFileDiffInstance.d.ts"],"sourcesContent":["import { type FileDiffOptions } from '../../components/FileDiff';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type { DiffLineAnnotation, FileDiffMetadata, SelectedLineRange, VirtualFileMetrics } from '../../types';\ninterface UseFileDiffInstanceProps<LAnnotation> {\n fileDiff: FileDiffMetadata;\n options: FileDiffOptions<LAnnotation> | undefined;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n}\ninterface UseFileDiffInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n}\nexport declare function useFileDiffInstance<LAnnotation>({ fileDiff, options, lineAnnotations, selectedLines, prerenderedHTML, metrics, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool, contentEditable }: UseFileDiffInstanceProps<LAnnotation>): UseFileDiffInstanceReturn;\nexport {};\n//# sourceMappingURL=useFileDiffInstance.d.ts.map"],"mappings":";;;;;UAGUM;YACIH;EADJG,OAAAA,EAEGN,eAFHM,CAEmBC,WAFKA,CAAAA,GAAAA,SAAAA;EACpBJ,eAAAA,EAEOD,kBAFPC,CAE0BI,WAF1BJ,CAAAA,EAAAA,GAAAA,SAAAA;EACeI,aAAAA,EAEVH,iBAFUG,GAAAA,IAAAA,GAAAA,SAAAA;EAAhBP,eAAAA,EAAAA,MAAAA,GAAAA,SAAAA;EAC2BO,OAAAA,CAAAA,EAG1BF,kBAH0BE;EAAnBL,sBAAAA,EAAAA,OAAAA;EACFE,eAAAA,EAAAA,OAAAA;EAELC,iBAAAA,EAAAA,OAAAA;EAAkB,eAAA,EAAA,OAAA;AAAA;AAUhC,UAJUG,yBAAAA,CAIiCD;EAAgBI,GAAAA,CAAAA,IAAAA,EAH7CF,WAG6CE,GAAAA,IAAAA,CAAAA,EAAAA,IAAAA;EAAUC,cAAAA,EAAAA,EAF/CX,oBAE+CW,CAAAA,MAAAA,CAAAA,GAAAA,SAAAA;;AAA0BE,iBAAvEJ,mBAAuEI,CAAAA,WAAAA,CAAAA,CAAAA;EAAAA,QAAAA;EAAAA,OAAAA;EAAAA,eAAAA;EAAAA,aAAAA;EAAAA,eAAAA;EAAAA,OAAAA;EAAAA,sBAAAA;EAAAA,eAAAA;EAAAA,iBAAAA;EAAAA;AAAAA,CAAAA,EAAwHR,wBAAxHQ,CAAiJP,WAAjJO,CAAAA,CAAAA,EAAgKN,yBAAhKM"}
1
+ {"version":3,"file":"useFileDiffInstance.d.ts","names":[],"sources":["../../../src/react/utils/useFileDiffInstance.ts"],"mappings":";;;;;UA2BU,wBAAA;EACR,QAAA,EAAU,gBAAA;EACV,OAAA,EAAS,eAAA,CAAgB,WAAA;EACzB,eAAA,EAAiB,kBAAA,CAAmB,WAAA;EACpC,aAAA,EAAe,iBAAA;EACf,eAAA;EACA,OAAA,GAAU,kBAAA;EACV,sBAAA;EACA,eAAA;EACA,iBAAA;EACA,eAAA;AAAA;AAAA,UAGQ,yBAAA;EACR,GAAA,CAAI,IAAA,EAAM,WAAA;EACV,cAAA,IAAkB,oBAAoB;AAAA;AAAA,iBAGxB,mBAAA;EACd,QAAA;EACA,OAAA;EACA,eAAA;EACA,aAAA;EACA,eAAA;EACA,OAAA;EACA,sBAAA;EACA,eAAA;EACA,iBAAA;EACA;AAAA,GACC,wBAAA,CAAyB,WAAA,IAAe,yBAAA"}
@@ -7,7 +7,6 @@ import { WorkerPoolContext } from "../WorkerPoolContext.js";
7
7
  import { useEditor } from "../EditorContext.js";
8
8
  import { useVirtualizer } from "../Virtualizer.js";
9
9
  import { useCallback, useContext, useEffect, useLayoutEffect, useRef } from "react";
10
-
11
10
  //#region src/react/utils/useFileDiffInstance.ts
12
11
  const useIsometricEffect = typeof window === "undefined" ? useEffect : useLayoutEffect;
13
12
  function useFileDiffInstance({ fileDiff, options, lineAnnotations, selectedLines, prerenderedHTML, metrics, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool, contentEditable }) {
@@ -97,12 +96,11 @@ function mergeFileDiffOptions({ options, controlledSelection, contentEditable, h
97
96
  enableGutterUtility: false,
98
97
  enableLineSelection: false,
99
98
  expandUnchanged: true,
100
- diffStyle: "split",
101
99
  lineHoverHighlight: "disabled"
102
100
  };
103
101
  return merged;
104
102
  }
105
-
106
103
  //#endregion
107
104
  export { useFileDiffInstance };
105
+
108
106
  //# sourceMappingURL=useFileDiffInstance.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useFileDiffInstance.js","names":["merged: FileDiffOptions<LAnnotation>"],"sources":["../../../src/react/utils/useFileDiffInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n} from 'react';\n\nimport { FileDiff, type FileDiffOptions } from '../../components/FileDiff';\nimport { VirtualizedFileDiff } from '../../components/VirtualizedFileDiff';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n DiffLineAnnotation,\n FileDiffMetadata,\n SelectedLineRange,\n VirtualFileMetrics,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport { noopRender } from '../constants';\nimport { useEditor } from '../EditorContext';\nimport { useVirtualizer } from '../Virtualizer';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseFileDiffInstanceProps<LAnnotation> {\n fileDiff: FileDiffMetadata;\n options: FileDiffOptions<LAnnotation> | undefined;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n}\n\ninterface UseFileDiffInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n}\n\nexport function useFileDiffInstance<LAnnotation>({\n fileDiff,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n metrics,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n contentEditable,\n}: UseFileDiffInstanceProps<LAnnotation>): UseFileDiffInstanceReturn {\n const simpleVirtualizer = useVirtualizer();\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const editor = useEditor<LAnnotation>();\n const instanceRef = useRef<\n FileDiff<LAnnotation> | VirtualizedFileDiff<LAnnotation> | null\n >(null);\n const ref = useStableCallback((fileContainer: HTMLElement | null) => {\n if (fileContainer != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'useFileDiffInstance: An instance should not already exist when a node is created'\n );\n }\n if (simpleVirtualizer != null) {\n instanceRef.current = new VirtualizedFileDiff(\n mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n simpleVirtualizer,\n metrics,\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n } else {\n instanceRef.current = new FileDiff(\n mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n }\n void instanceRef.current.hydrate({\n fileDiff,\n fileContainer,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error(\n 'useFileDiffInstance: A FileDiff instance should exist when unmounting'\n );\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n const { current: instance } = instanceRef;\n if (instance == null) return;\n const newOptions = mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n });\n const forceRender = !areOptionsEqual(instance.options, newOptions);\n instance.setOptions(newOptions);\n void instance.render({\n forceRender,\n fileDiff,\n lineAnnotations,\n });\n if (selectedLines !== undefined) {\n instance.setSelectedLines(selectedLines);\n }\n });\n\n useIsometricEffect(() => {\n if (contentEditable && instanceRef.current != null) {\n if (editor === undefined) {\n throw new Error('FileDiff: Editor is not attached');\n }\n return editor.edit(instanceRef.current);\n }\n return undefined;\n }, [contentEditable, editor]);\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'diff'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n\n return { ref, getHoveredLine };\n}\n\ninterface MergeFileDiffOptionsProps<LAnnotation> {\n controlledSelection: boolean;\n contentEditable: boolean;\n hasEditor: boolean;\n hasCustomHeader: boolean;\n hasGutterRenderUtility: boolean;\n options: FileDiffOptions<LAnnotation> | undefined;\n}\n\nfunction mergeFileDiffOptions<LAnnotation>({\n options,\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor,\n hasGutterRenderUtility,\n}: MergeFileDiffOptionsProps<LAnnotation>):\n | FileDiffOptions<LAnnotation>\n | undefined {\n const needsEditorOptions = contentEditable && hasEditor;\n const needsReactOverrides =\n controlledSelection || hasGutterRenderUtility || hasCustomHeader;\n\n if (!needsReactOverrides && !needsEditorOptions) {\n return options;\n }\n\n let merged: FileDiffOptions<LAnnotation> = { ...options };\n\n if (needsReactOverrides) {\n merged = {\n ...merged,\n controlledSelection,\n renderCustomHeader: hasCustomHeader\n ? noopRender\n : options?.renderCustomHeader,\n renderGutterUtility: hasGutterRenderUtility\n ? noopRender\n : options?.renderGutterUtility,\n };\n }\n\n if (needsEditorOptions) {\n merged = {\n ...merged,\n useTokenTransformer: true,\n enableGutterUtility: false,\n enableLineSelection: false,\n expandUnchanged: true,\n diffStyle: 'split',\n lineHoverHighlight: 'disabled',\n };\n }\n\n return merged;\n}\n"],"mappings":";;;;;;;;;;;AAwBA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAoB9C,SAAgB,oBAAiC,EAC/C,UACA,SACA,iBACA,eACA,iBACA,SACA,wBACA,iBACA,mBACA,mBACmE;CACnE,MAAM,oBAAoB,gBAAgB;CAC1C,MAAM,sBAAsB,kBAAkB;CAC9C,MAAM,cAAc,WAAW,kBAAkB;CACjD,MAAM,SAAS,WAAwB;CACvC,MAAM,cAAc,OAElB,KAAK;CACP,MAAM,MAAM,mBAAmB,kBAAsC;AACnE,MAAI,iBAAiB,MAAM;AACzB,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MACR,mFACD;AAEH,OAAI,qBAAqB,KACvB,aAAY,UAAU,IAAI,oBACxB,qBAAqB;IACnB;IACA;IACA;IACA,WAAW,WAAW;IACtB;IACA;IACD,CAAC,EACF,mBACA,SACA,CAAC,oBAAoB,cAAc,QACnC,KACD;OAED,aAAY,UAAU,IAAI,SACxB,qBAAqB;IACnB;IACA;IACA;IACA,WAAW,WAAW;IACtB;IACA;IACD,CAAC,EACF,CAAC,oBAAoB,cAAc,QACnC,KACD;AAEH,GAAK,YAAY,QAAQ,QAAQ;IAC/B;IACA;IACA;IACA;IACD,CAAC;SACG;AACL,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MACR,wEACD;AAEH,eAAY,QAAQ,SAAS;AAC7B,eAAY,UAAU;;GAExB;AAEF,0BAAyB;EACvB,MAAM,EAAE,SAAS,aAAa;AAC9B,MAAI,YAAY,KAAM;EACtB,MAAM,aAAa,qBAAqB;GACtC;GACA;GACA;GACA,WAAW,WAAW;GACtB;GACA;GACD,CAAC;EACF,MAAM,cAAc,CAAC,gBAAgB,SAAS,SAAS,WAAW;AAClE,WAAS,WAAW,WAAW;AAC/B,EAAK,SAAS,OAAO;GACnB;GACA;GACA;GACD,CAAC;AACF,MAAI,kBAAkB,OACpB,UAAS,iBAAiB,cAAc;GAE1C;AAEF,0BAAyB;AACvB,MAAI,mBAAmB,YAAY,WAAW,MAAM;AAClD,OAAI,WAAW,OACb,OAAM,IAAI,MAAM,mCAAmC;AAErD,UAAO,OAAO,KAAK,YAAY,QAAQ;;IAGxC,CAAC,iBAAiB,OAAO,CAAC;AAQ7B,QAAO;EAAE;EAAK,gBANS,kBAEN;AACf,UAAO,YAAY,SAAS,gBAAgB;KAC3C,EAAE,CAAC;EAEwB;;AAYhC,SAAS,qBAAkC,EACzC,SACA,qBACA,iBACA,iBACA,WACA,0BAGY;CACZ,MAAM,qBAAqB,mBAAmB;CAC9C,MAAM,sBACJ,uBAAuB,0BAA0B;AAEnD,KAAI,CAAC,uBAAuB,CAAC,mBAC3B,QAAO;CAGT,IAAIA,SAAuC,EAAE,GAAG,SAAS;AAEzD,KAAI,oBACF,UAAS;EACP,GAAG;EACH;EACA,oBAAoB,kBAChB,aACA,SAAS;EACb,qBAAqB,yBACjB,aACA,SAAS;EACd;AAGH,KAAI,mBACF,UAAS;EACP,GAAG;EACH,qBAAqB;EACrB,qBAAqB;EACrB,qBAAqB;EACrB,iBAAiB;EACjB,WAAW;EACX,oBAAoB;EACrB;AAGH,QAAO"}
1
+ {"version":3,"file":"useFileDiffInstance.js","names":[],"sources":["../../../src/react/utils/useFileDiffInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n} from 'react';\n\nimport { FileDiff, type FileDiffOptions } from '../../components/FileDiff';\nimport { VirtualizedFileDiff } from '../../components/VirtualizedFileDiff';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n DiffLineAnnotation,\n FileDiffMetadata,\n SelectedLineRange,\n VirtualFileMetrics,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport { noopRender } from '../constants';\nimport { useEditor } from '../EditorContext';\nimport { useVirtualizer } from '../Virtualizer';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseFileDiffInstanceProps<LAnnotation> {\n fileDiff: FileDiffMetadata;\n options: FileDiffOptions<LAnnotation> | undefined;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n}\n\ninterface UseFileDiffInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n}\n\nexport function useFileDiffInstance<LAnnotation>({\n fileDiff,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n metrics,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n contentEditable,\n}: UseFileDiffInstanceProps<LAnnotation>): UseFileDiffInstanceReturn {\n const simpleVirtualizer = useVirtualizer();\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const editor = useEditor<LAnnotation>();\n const instanceRef = useRef<\n FileDiff<LAnnotation> | VirtualizedFileDiff<LAnnotation> | null\n >(null);\n const ref = useStableCallback((fileContainer: HTMLElement | null) => {\n if (fileContainer != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'useFileDiffInstance: An instance should not already exist when a node is created'\n );\n }\n if (simpleVirtualizer != null) {\n instanceRef.current = new VirtualizedFileDiff(\n mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n simpleVirtualizer,\n metrics,\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n } else {\n instanceRef.current = new FileDiff(\n mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n }\n void instanceRef.current.hydrate({\n fileDiff,\n fileContainer,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error(\n 'useFileDiffInstance: A FileDiff instance should exist when unmounting'\n );\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n const { current: instance } = instanceRef;\n if (instance == null) return;\n const newOptions = mergeFileDiffOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n });\n const forceRender = !areOptionsEqual(instance.options, newOptions);\n instance.setOptions(newOptions);\n void instance.render({\n forceRender,\n fileDiff,\n lineAnnotations,\n });\n if (selectedLines !== undefined) {\n instance.setSelectedLines(selectedLines);\n }\n });\n\n useIsometricEffect(() => {\n if (contentEditable && instanceRef.current != null) {\n if (editor === undefined) {\n throw new Error('FileDiff: Editor is not attached');\n }\n return editor.edit(instanceRef.current);\n }\n return undefined;\n }, [contentEditable, editor]);\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'diff'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n\n return { ref, getHoveredLine };\n}\n\ninterface MergeFileDiffOptionsProps<LAnnotation> {\n controlledSelection: boolean;\n contentEditable: boolean;\n hasEditor: boolean;\n hasCustomHeader: boolean;\n hasGutterRenderUtility: boolean;\n options: FileDiffOptions<LAnnotation> | undefined;\n}\n\nfunction mergeFileDiffOptions<LAnnotation>({\n options,\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor,\n hasGutterRenderUtility,\n}: MergeFileDiffOptionsProps<LAnnotation>):\n | FileDiffOptions<LAnnotation>\n | undefined {\n const needsEditorOptions = contentEditable && hasEditor;\n const needsReactOverrides =\n controlledSelection || hasGutterRenderUtility || hasCustomHeader;\n\n if (!needsReactOverrides && !needsEditorOptions) {\n return options;\n }\n\n let merged: FileDiffOptions<LAnnotation> = { ...options };\n\n if (needsReactOverrides) {\n merged = {\n ...merged,\n controlledSelection,\n renderCustomHeader: hasCustomHeader\n ? noopRender\n : options?.renderCustomHeader,\n renderGutterUtility: hasGutterRenderUtility\n ? noopRender\n : options?.renderGutterUtility,\n };\n }\n\n if (needsEditorOptions) {\n merged = {\n ...merged,\n useTokenTransformer: true,\n enableGutterUtility: false,\n enableLineSelection: false,\n expandUnchanged: true,\n lineHoverHighlight: 'disabled',\n };\n }\n\n return merged;\n}\n"],"mappings":";;;;;;;;;;AAwBA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAoB9C,SAAgB,oBAAiC,EAC/C,UACA,SACA,iBACA,eACA,iBACA,SACA,wBACA,iBACA,mBACA,mBACmE;CACnE,MAAM,oBAAoB,eAAe;CACzC,MAAM,sBAAsB,kBAAkB,KAAA;CAC9C,MAAM,cAAc,WAAW,iBAAiB;CAChD,MAAM,SAAS,UAAuB;CACtC,MAAM,cAAc,OAElB,IAAI;CACN,MAAM,MAAM,mBAAmB,kBAAsC;EACnE,IAAI,iBAAiB,MAAM;GACzB,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MACR,kFACF;GAEF,IAAI,qBAAqB,MACvB,YAAY,UAAU,IAAI,oBACxB,qBAAqB;IACnB;IACA;IACA;IACA,WAAW,WAAW,KAAA;IACtB;IACA;GACF,CAAC,GACD,mBACA,SACA,CAAC,oBAAoB,cAAc,KAAA,GACnC,IACF;QAEA,YAAY,UAAU,IAAI,SACxB,qBAAqB;IACnB;IACA;IACA;IACA,WAAW,WAAW,KAAA;IACtB;IACA;GACF,CAAC,GACD,CAAC,oBAAoB,cAAc,KAAA,GACnC,IACF;GAEF,YAAiB,QAAQ,QAAQ;IAC/B;IACA;IACA;IACA;GACF,CAAC;EACH,OAAO;GACL,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MACR,uEACF;GAEF,YAAY,QAAQ,QAAQ;GAC5B,YAAY,UAAU;EACxB;CACF,CAAC;CAED,yBAAyB;EACvB,MAAM,EAAE,SAAS,aAAa;EAC9B,IAAI,YAAY,MAAM;EACtB,MAAM,aAAa,qBAAqB;GACtC;GACA;GACA;GACA,WAAW,WAAW,KAAA;GACtB;GACA;EACF,CAAC;EACD,MAAM,cAAc,CAAC,gBAAgB,SAAS,SAAS,UAAU;EACjE,SAAS,WAAW,UAAU;EAC9B,SAAc,OAAO;GACnB;GACA;GACA;EACF,CAAC;EACD,IAAI,kBAAkB,KAAA,GACpB,SAAS,iBAAiB,aAAa;CAE3C,CAAC;CAED,yBAAyB;EACvB,IAAI,mBAAmB,YAAY,WAAW,MAAM;GAClD,IAAI,WAAW,KAAA,GACb,MAAM,IAAI,MAAM,kCAAkC;GAEpD,OAAO,OAAO,KAAK,YAAY,OAAO;EACxC;CAEF,GAAG,CAAC,iBAAiB,MAAM,CAAC;CAQ5B,OAAO;EAAE;EAAK,gBANS,kBAEN;GACf,OAAO,YAAY,SAAS,eAAe;EAC7C,GAAG,CAAC,CAEuB;CAAE;AAC/B;AAWA,SAAS,qBAAkC,EACzC,SACA,qBACA,iBACA,iBACA,WACA,0BAGY;CACZ,MAAM,qBAAqB,mBAAmB;CAC9C,MAAM,sBACJ,uBAAuB,0BAA0B;CAEnD,IAAI,CAAC,uBAAuB,CAAC,oBAC3B,OAAO;CAGT,IAAI,SAAuC,EAAE,GAAG,QAAQ;CAExD,IAAI,qBACF,SAAS;EACP,GAAG;EACH;EACA,oBAAoB,kBAChB,aACA,SAAS;EACb,qBAAqB,yBACjB,aACA,SAAS;CACf;CAGF,IAAI,oBACF,SAAS;EACP,GAAG;EACH,qBAAqB;EACrB,qBAAqB;EACrB,qBAAqB;EACrB,iBAAiB;EACjB,oBAAoB;CACtB;CAGF,OAAO;AACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"useFileInstance.d.ts","names":["FileOptions","GetHoveredLineResult","FileContents","LineAnnotation","SelectedLineRange","VirtualFileMetrics","UseFileInstanceProps","LAnnotation","UseFileInstanceReturn","HTMLElement","useFileInstance","file","options","lineAnnotations","selectedLines","prerenderedHTML","metrics","hasGutterRenderUtility","hasCustomHeader","disableWorkerPool","contentEditable"],"sources":["../../../src/react/utils/useFileInstance.d.ts"],"sourcesContent":["import { type FileOptions } from '../../components/File';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type { FileContents, LineAnnotation, SelectedLineRange, VirtualFileMetrics } from '../../types';\ninterface UseFileInstanceProps<LAnnotation> {\n file: FileContents;\n options: FileOptions<LAnnotation> | undefined;\n lineAnnotations: LineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n onChange?: (file: FileContents, lineAnnotations?: LineAnnotation<LAnnotation>[]) => void;\n}\ninterface UseFileInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'file'> | undefined;\n}\nexport declare function useFileInstance<LAnnotation>({ file, options, lineAnnotations, selectedLines, prerenderedHTML, metrics, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool, contentEditable }: UseFileInstanceProps<LAnnotation>): UseFileInstanceReturn;\nexport {};\n//# sourceMappingURL=useFileInstance.d.ts.map"],"mappings":";;;;;UAGUM;QACAJ;EADAI,OAAAA,EAEGN,WAFHM,CAEeC,WAFKA,CAAAA,GAAAA,SAAAA;EACpBL,eAAAA,EAEWC,cAFXD,CAE0BK,WAF1BL,CAAAA,EAAAA,GAAAA,SAAAA;EACeK,aAAAA,EAENH,iBAFMG,GAAAA,IAAAA,GAAAA,SAAAA;EAAZP,eAAAA,EAAAA,MAAAA,GAAAA,SAAAA;EACuBO,OAAAA,CAAAA,EAGtBF,kBAHsBE;EAAfJ,sBAAAA,EAAAA,OAAAA;EACFC,eAAAA,EAAAA,OAAAA;EAELC,iBAAAA,EAAAA,OAAAA;EAKQH,eAAAA,EAAAA,OAAAA;EAA+CK,QAAAA,CAAAA,EAAAA,CAAAA,IAAAA,EAA/CL,YAA+CK,EAAAA,eAAAA,CAAAA,EAAfJ,cAAeI,CAAAA,WAAAA,CAAAA,EAAAA,EAAAA,GAAAA,IAAAA;;UAE3DC,qBAAAA,CAF0D;EAE1DA,GAAAA,CAAAA,IAAAA,EACIC,WADJD,GAAqB,IAAA,CAAA,EAAA,IAAA;EAIPE,cAAAA,EAAAA,EAFFT,oBAEiBM,CAAAA,MAAA,CAAA,GAAA,SAAA;;AAAsBK,iBAArCF,eAAqCE,CAAAA,WAAAA,CAAAA,CAAAA;EAAAA,IAAAA;EAAAA,OAAAA;EAAAA,eAAAA;EAAAA,aAAAA;EAAAA,eAAAA;EAAAA,OAAAA;EAAAA,sBAAAA;EAAAA,eAAAA;EAAAA,iBAAAA;EAAAA;AAAAA,CAAAA,EAAkJN,oBAAlJM,CAAuKL,WAAvKK,CAAAA,CAAAA,EAAsLJ,qBAAtLI"}
1
+ {"version":3,"file":"useFileInstance.d.ts","names":[],"sources":["../../../src/react/utils/useFileInstance.ts"],"mappings":";;;;;UA2BU,oBAAA;EACR,IAAA,EAAM,YAAA;EACN,OAAA,EAAS,WAAA,CAAY,WAAA;EACrB,eAAA,EAAiB,cAAA,CAAe,WAAA;EAChC,aAAA,EAAe,iBAAA;EACf,eAAA;EACA,OAAA,GAAU,kBAAA;EACV,sBAAA;EACA,eAAA;EACA,iBAAA;EACA,eAAA;EACA,QAAA,IACE,IAAA,EAAM,YAAA,EACN,eAAA,GAAkB,cAAA,CAAe,WAAA;AAAA;AAAA,UAI3B,qBAAA;EACR,GAAA,CAAI,IAAA,EAAM,WAAA;EACV,cAAA,IAAkB,oBAAoB;AAAA;AAAA,iBAGxB,eAAA;EACd,IAAA;EACA,OAAA;EACA,eAAA;EACA,aAAA;EACA,eAAA;EACA,OAAA;EACA,sBAAA;EACA,eAAA;EACA,iBAAA;EACA;AAAA,GACC,oBAAA,CAAqB,WAAA,IAAe,qBAAA"}
@@ -7,7 +7,6 @@ import { WorkerPoolContext } from "../WorkerPoolContext.js";
7
7
  import { useEditor } from "../EditorContext.js";
8
8
  import { useVirtualizer } from "../Virtualizer.js";
9
9
  import { useCallback, useContext, useEffect, useLayoutEffect, useRef } from "react";
10
-
11
10
  //#region src/react/utils/useFileInstance.ts
12
11
  const useIsometricEffect = typeof window === "undefined" ? useEffect : useLayoutEffect;
13
12
  function useFileInstance({ file, options, lineAnnotations, selectedLines, prerenderedHTML, metrics, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool, contentEditable }) {
@@ -99,7 +98,7 @@ function mergeFileOptions({ options, controlledSelection, contentEditable, hasCu
99
98
  };
100
99
  return merged;
101
100
  }
102
-
103
101
  //#endregion
104
102
  export { useFileInstance };
103
+
105
104
  //# sourceMappingURL=useFileInstance.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useFileInstance.js","names":["merged: FileOptions<LAnnotation>"],"sources":["../../../src/react/utils/useFileInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n} from 'react';\n\nimport { File, type FileOptions } from '../../components/File';\nimport { VirtualizedFile } from '../../components/VirtualizedFile';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n FileContents,\n LineAnnotation,\n SelectedLineRange,\n VirtualFileMetrics,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport { noopRender } from '../constants';\nimport { useEditor } from '../EditorContext';\nimport { useVirtualizer } from '../Virtualizer';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseFileInstanceProps<LAnnotation> {\n file: FileContents;\n options: FileOptions<LAnnotation> | undefined;\n lineAnnotations: LineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n onChange?: (\n file: FileContents,\n lineAnnotations?: LineAnnotation<LAnnotation>[]\n ) => void;\n}\n\ninterface UseFileInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'file'> | undefined;\n}\n\nexport function useFileInstance<LAnnotation>({\n file,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n metrics,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n contentEditable,\n}: UseFileInstanceProps<LAnnotation>): UseFileInstanceReturn {\n const simpleVirtualizer = useVirtualizer();\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const editor = useEditor<LAnnotation>();\n const instanceRef = useRef<\n File<LAnnotation> | VirtualizedFile<LAnnotation> | null\n >(null);\n const ref = useStableCallback((node: HTMLElement | null) => {\n if (node != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'File: An instance should not already exist when a node is created'\n );\n }\n if (simpleVirtualizer != null) {\n instanceRef.current = new VirtualizedFile(\n mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n simpleVirtualizer,\n metrics,\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n } else {\n instanceRef.current = new File(\n mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n }\n void instanceRef.current.hydrate({\n file,\n fileContainer: node,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error('File: A File instance should exist when unmounting');\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n if (instanceRef.current == null) return;\n const newOptions = mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n });\n const forceRender = !areOptionsEqual(\n instanceRef.current.options,\n newOptions\n );\n instanceRef.current.setOptions(newOptions);\n void instanceRef.current.render({ file, lineAnnotations, forceRender });\n if (selectedLines !== undefined) {\n instanceRef.current.setSelectedLines(selectedLines);\n }\n });\n\n useIsometricEffect(() => {\n if (contentEditable && instanceRef.current != null) {\n if (editor === undefined) {\n throw new Error('File: Editor is not attached');\n }\n return editor.edit(instanceRef.current);\n }\n return undefined;\n }, [contentEditable, editor]);\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'file'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n return { ref, getHoveredLine };\n}\n\ninterface MergeFileOptionsProps<LAnnotation> {\n options: FileOptions<LAnnotation> | undefined;\n controlledSelection: boolean;\n contentEditable: boolean;\n hasEditor: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n}\n\nfunction mergeFileOptions<LAnnotation>({\n options,\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor,\n hasGutterRenderUtility,\n}: MergeFileOptionsProps<LAnnotation>): FileOptions<LAnnotation> | undefined {\n const needsEditorOptions = contentEditable && hasEditor;\n const needsReactOverrides =\n controlledSelection || hasGutterRenderUtility || hasCustomHeader;\n\n if (!needsReactOverrides && !needsEditorOptions) {\n return options;\n }\n\n let merged: FileOptions<LAnnotation> = { ...options };\n\n if (needsReactOverrides) {\n merged = {\n ...merged,\n controlledSelection,\n renderCustomHeader: hasCustomHeader\n ? noopRender\n : options?.renderCustomHeader,\n renderGutterUtility: hasGutterRenderUtility\n ? noopRender\n : options?.renderGutterUtility,\n };\n }\n\n if (needsEditorOptions) {\n merged = {\n ...merged,\n useTokenTransformer: true,\n enableGutterUtility: false,\n enableLineSelection: false,\n lineHoverHighlight: 'disabled',\n };\n }\n\n return merged;\n}\n"],"mappings":";;;;;;;;;;;AAwBA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAwB9C,SAAgB,gBAA6B,EAC3C,MACA,SACA,iBACA,eACA,iBACA,SACA,wBACA,iBACA,mBACA,mBAC2D;CAC3D,MAAM,oBAAoB,gBAAgB;CAC1C,MAAM,sBAAsB,kBAAkB;CAC9C,MAAM,cAAc,WAAW,kBAAkB;CACjD,MAAM,SAAS,WAAwB;CACvC,MAAM,cAAc,OAElB,KAAK;CACP,MAAM,MAAM,mBAAmB,SAA6B;AAC1D,MAAI,QAAQ,MAAM;AAChB,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MACR,oEACD;AAEH,OAAI,qBAAqB,KACvB,aAAY,UAAU,IAAI,gBACxB,iBAAiB;IACf;IACA;IACA;IACA,WAAW,WAAW;IACtB;IACA;IACD,CAAC,EACF,mBACA,SACA,CAAC,oBAAoB,cAAc,QACnC,KACD;OAED,aAAY,UAAU,IAAI,KACxB,iBAAiB;IACf;IACA;IACA;IACA,WAAW,WAAW;IACtB;IACA;IACD,CAAC,EACF,CAAC,oBAAoB,cAAc,QACnC,KACD;AAEH,GAAK,YAAY,QAAQ,QAAQ;IAC/B;IACA,eAAe;IACf;IACA;IACD,CAAC;SACG;AACL,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MAAM,qDAAqD;AAEvE,eAAY,QAAQ,SAAS;AAC7B,eAAY,UAAU;;GAExB;AAEF,0BAAyB;AACvB,MAAI,YAAY,WAAW,KAAM;EACjC,MAAM,aAAa,iBAAiB;GAClC;GACA;GACA;GACA,WAAW,WAAW;GACtB;GACA;GACD,CAAC;EACF,MAAM,cAAc,CAAC,gBACnB,YAAY,QAAQ,SACpB,WACD;AACD,cAAY,QAAQ,WAAW,WAAW;AAC1C,EAAK,YAAY,QAAQ,OAAO;GAAE;GAAM;GAAiB;GAAa,CAAC;AACvE,MAAI,kBAAkB,OACpB,aAAY,QAAQ,iBAAiB,cAAc;GAErD;AAEF,0BAAyB;AACvB,MAAI,mBAAmB,YAAY,WAAW,MAAM;AAClD,OAAI,WAAW,OACb,OAAM,IAAI,MAAM,+BAA+B;AAEjD,UAAO,OAAO,KAAK,YAAY,QAAQ;;IAGxC,CAAC,iBAAiB,OAAO,CAAC;AAO7B,QAAO;EAAE;EAAK,gBALS,kBAEN;AACf,UAAO,YAAY,SAAS,gBAAgB;KAC3C,EAAE,CAAC;EACwB;;AAYhC,SAAS,iBAA8B,EACrC,SACA,qBACA,iBACA,iBACA,WACA,0BAC2E;CAC3E,MAAM,qBAAqB,mBAAmB;CAC9C,MAAM,sBACJ,uBAAuB,0BAA0B;AAEnD,KAAI,CAAC,uBAAuB,CAAC,mBAC3B,QAAO;CAGT,IAAIA,SAAmC,EAAE,GAAG,SAAS;AAErD,KAAI,oBACF,UAAS;EACP,GAAG;EACH;EACA,oBAAoB,kBAChB,aACA,SAAS;EACb,qBAAqB,yBACjB,aACA,SAAS;EACd;AAGH,KAAI,mBACF,UAAS;EACP,GAAG;EACH,qBAAqB;EACrB,qBAAqB;EACrB,qBAAqB;EACrB,oBAAoB;EACrB;AAGH,QAAO"}
1
+ {"version":3,"file":"useFileInstance.js","names":[],"sources":["../../../src/react/utils/useFileInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n} from 'react';\n\nimport { File, type FileOptions } from '../../components/File';\nimport { VirtualizedFile } from '../../components/VirtualizedFile';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n FileContents,\n LineAnnotation,\n SelectedLineRange,\n VirtualFileMetrics,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport { noopRender } from '../constants';\nimport { useEditor } from '../EditorContext';\nimport { useVirtualizer } from '../Virtualizer';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseFileInstanceProps<LAnnotation> {\n file: FileContents;\n options: FileOptions<LAnnotation> | undefined;\n lineAnnotations: LineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n metrics?: VirtualFileMetrics;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n contentEditable: boolean;\n onChange?: (\n file: FileContents,\n lineAnnotations?: LineAnnotation<LAnnotation>[]\n ) => void;\n}\n\ninterface UseFileInstanceReturn {\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'file'> | undefined;\n}\n\nexport function useFileInstance<LAnnotation>({\n file,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n metrics,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n contentEditable,\n}: UseFileInstanceProps<LAnnotation>): UseFileInstanceReturn {\n const simpleVirtualizer = useVirtualizer();\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const editor = useEditor<LAnnotation>();\n const instanceRef = useRef<\n File<LAnnotation> | VirtualizedFile<LAnnotation> | null\n >(null);\n const ref = useStableCallback((node: HTMLElement | null) => {\n if (node != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'File: An instance should not already exist when a node is created'\n );\n }\n if (simpleVirtualizer != null) {\n instanceRef.current = new VirtualizedFile(\n mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n simpleVirtualizer,\n metrics,\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n } else {\n instanceRef.current = new File(\n mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n }\n void instanceRef.current.hydrate({\n file,\n fileContainer: node,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error('File: A File instance should exist when unmounting');\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n if (instanceRef.current == null) return;\n const newOptions = mergeFileOptions({\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor: editor !== undefined,\n hasGutterRenderUtility,\n options,\n });\n const forceRender = !areOptionsEqual(\n instanceRef.current.options,\n newOptions\n );\n instanceRef.current.setOptions(newOptions);\n void instanceRef.current.render({ file, lineAnnotations, forceRender });\n if (selectedLines !== undefined) {\n instanceRef.current.setSelectedLines(selectedLines);\n }\n });\n\n useIsometricEffect(() => {\n if (contentEditable && instanceRef.current != null) {\n if (editor === undefined) {\n throw new Error('File: Editor is not attached');\n }\n return editor.edit(instanceRef.current);\n }\n return undefined;\n }, [contentEditable, editor]);\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'file'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n return { ref, getHoveredLine };\n}\n\ninterface MergeFileOptionsProps<LAnnotation> {\n options: FileOptions<LAnnotation> | undefined;\n controlledSelection: boolean;\n contentEditable: boolean;\n hasEditor: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n}\n\nfunction mergeFileOptions<LAnnotation>({\n options,\n controlledSelection,\n contentEditable,\n hasCustomHeader,\n hasEditor,\n hasGutterRenderUtility,\n}: MergeFileOptionsProps<LAnnotation>): FileOptions<LAnnotation> | undefined {\n const needsEditorOptions = contentEditable && hasEditor;\n const needsReactOverrides =\n controlledSelection || hasGutterRenderUtility || hasCustomHeader;\n\n if (!needsReactOverrides && !needsEditorOptions) {\n return options;\n }\n\n let merged: FileOptions<LAnnotation> = { ...options };\n\n if (needsReactOverrides) {\n merged = {\n ...merged,\n controlledSelection,\n renderCustomHeader: hasCustomHeader\n ? noopRender\n : options?.renderCustomHeader,\n renderGutterUtility: hasGutterRenderUtility\n ? noopRender\n : options?.renderGutterUtility,\n };\n }\n\n if (needsEditorOptions) {\n merged = {\n ...merged,\n useTokenTransformer: true,\n enableGutterUtility: false,\n enableLineSelection: false,\n lineHoverHighlight: 'disabled',\n };\n }\n\n return merged;\n}\n"],"mappings":";;;;;;;;;;AAwBA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAwB9C,SAAgB,gBAA6B,EAC3C,MACA,SACA,iBACA,eACA,iBACA,SACA,wBACA,iBACA,mBACA,mBAC2D;CAC3D,MAAM,oBAAoB,eAAe;CACzC,MAAM,sBAAsB,kBAAkB,KAAA;CAC9C,MAAM,cAAc,WAAW,iBAAiB;CAChD,MAAM,SAAS,UAAuB;CACtC,MAAM,cAAc,OAElB,IAAI;CACN,MAAM,MAAM,mBAAmB,SAA6B;EAC1D,IAAI,QAAQ,MAAM;GAChB,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MACR,mEACF;GAEF,IAAI,qBAAqB,MACvB,YAAY,UAAU,IAAI,gBACxB,iBAAiB;IACf;IACA;IACA;IACA,WAAW,WAAW,KAAA;IACtB;IACA;GACF,CAAC,GACD,mBACA,SACA,CAAC,oBAAoB,cAAc,KAAA,GACnC,IACF;QAEA,YAAY,UAAU,IAAI,KACxB,iBAAiB;IACf;IACA;IACA;IACA,WAAW,WAAW,KAAA;IACtB;IACA;GACF,CAAC,GACD,CAAC,oBAAoB,cAAc,KAAA,GACnC,IACF;GAEF,YAAiB,QAAQ,QAAQ;IAC/B;IACA,eAAe;IACf;IACA;GACF,CAAC;EACH,OAAO;GACL,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MAAM,oDAAoD;GAEtE,YAAY,QAAQ,QAAQ;GAC5B,YAAY,UAAU;EACxB;CACF,CAAC;CAED,yBAAyB;EACvB,IAAI,YAAY,WAAW,MAAM;EACjC,MAAM,aAAa,iBAAiB;GAClC;GACA;GACA;GACA,WAAW,WAAW,KAAA;GACtB;GACA;EACF,CAAC;EACD,MAAM,cAAc,CAAC,gBACnB,YAAY,QAAQ,SACpB,UACF;EACA,YAAY,QAAQ,WAAW,UAAU;EACzC,YAAiB,QAAQ,OAAO;GAAE;GAAM;GAAiB;EAAY,CAAC;EACtE,IAAI,kBAAkB,KAAA,GACpB,YAAY,QAAQ,iBAAiB,aAAa;CAEtD,CAAC;CAED,yBAAyB;EACvB,IAAI,mBAAmB,YAAY,WAAW,MAAM;GAClD,IAAI,WAAW,KAAA,GACb,MAAM,IAAI,MAAM,8BAA8B;GAEhD,OAAO,OAAO,KAAK,YAAY,OAAO;EACxC;CAEF,GAAG,CAAC,iBAAiB,MAAM,CAAC;CAO5B,OAAO;EAAE;EAAK,gBALS,kBAEN;GACf,OAAO,YAAY,SAAS,eAAe;EAC7C,GAAG,CAAC,CACuB;CAAE;AAC/B;AAWA,SAAS,iBAA8B,EACrC,SACA,qBACA,iBACA,iBACA,WACA,0BAC2E;CAC3E,MAAM,qBAAqB,mBAAmB;CAC9C,MAAM,sBACJ,uBAAuB,0BAA0B;CAEnD,IAAI,CAAC,uBAAuB,CAAC,oBAC3B,OAAO;CAGT,IAAI,SAAmC,EAAE,GAAG,QAAQ;CAEpD,IAAI,qBACF,SAAS;EACP,GAAG;EACH;EACA,oBAAoB,kBAChB,aACA,SAAS;EACb,qBAAqB,yBACjB,aACA,SAAS;CACf;CAGF,IAAI,oBACF,SAAS;EACP,GAAG;EACH,qBAAqB;EACrB,qBAAqB;EACrB,qBAAqB;EACrB,oBAAoB;CACtB;CAGF,OAAO;AACT"}
@@ -1 +1 @@
1
- {"version":3,"file":"useStableCallback.d.ts","names":["useStableCallback","T"],"sources":["../../../src/react/utils/useStableCallback.d.ts"],"sourcesContent":["export declare function useStableCallback<T extends (...args: any[]) => any>(callback: T): T;\n//# sourceMappingURL=useStableCallback.d.ts.map"],"mappings":";iBAAwBA,+DAA+DC,IAAIA"}
1
+ {"version":3,"file":"useStableCallback.d.ts","names":[],"sources":["../../../src/react/utils/useStableCallback.ts"],"mappings":";iBAGgB,iBAAA,eAAgC,IAAA,iBAC9C,QAAA,EAAU,CAAA,GACT,CAAC"}
@@ -1,5 +1,4 @@
1
1
  import { useCallback, useInsertionEffect, useRef } from "react";
2
-
3
2
  //#region src/react/utils/useStableCallback.ts
4
3
  function useStableCallback(callback) {
5
4
  const callbackRef = useRef(callback);
@@ -8,7 +7,7 @@ function useStableCallback(callback) {
8
7
  return callbackRef.current(...args);
9
8
  }, []);
10
9
  }
11
-
12
10
  //#endregion
13
11
  export { useStableCallback };
12
+
14
13
  //# sourceMappingURL=useStableCallback.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useStableCallback.js","names":[],"sources":["../../../src/react/utils/useStableCallback.ts"],"sourcesContent":["import { useCallback, useInsertionEffect, useRef } from 'react';\n\n// oxlint-disable-next-line typescript/no-explicit-any\nexport function useStableCallback<T extends (...args: any[]) => any>(\n callback: T\n): T {\n const callbackRef = useRef(callback);\n useInsertionEffect(() => void (callbackRef.current = callback));\n return useCallback((...args: Parameters<T>): ReturnType<T> => {\n // oxlint-disable-next-line typescript/no-unsafe-return\n return callbackRef.current(...args);\n }, []) as T;\n}\n"],"mappings":";;;AAGA,SAAgB,kBACd,UACG;CACH,MAAM,cAAc,OAAO,SAAS;AACpC,0BAAyB,MAAM,YAAY,UAAU,UAAU;AAC/D,QAAO,aAAa,GAAG,SAAuC;AAE5D,SAAO,YAAY,QAAQ,GAAG,KAAK;IAClC,EAAE,CAAC"}
1
+ {"version":3,"file":"useStableCallback.js","names":[],"sources":["../../../src/react/utils/useStableCallback.ts"],"sourcesContent":["import { useCallback, useInsertionEffect, useRef } from 'react';\n\n// oxlint-disable-next-line typescript/no-explicit-any\nexport function useStableCallback<T extends (...args: any[]) => any>(\n callback: T\n): T {\n const callbackRef = useRef(callback);\n useInsertionEffect(() => void (callbackRef.current = callback));\n return useCallback((...args: Parameters<T>): ReturnType<T> => {\n // oxlint-disable-next-line typescript/no-unsafe-return\n return callbackRef.current(...args);\n }, []) as T;\n}\n"],"mappings":";;AAGA,SAAgB,kBACd,UACG;CACH,MAAM,cAAc,OAAO,QAAQ;CACnC,yBAAyB,MAAM,YAAY,UAAU,SAAS;CAC9D,OAAO,aAAa,GAAG,SAAuC;EAE5D,OAAO,YAAY,QAAQ,GAAG,IAAI;CACpC,GAAG,CAAC,CAAC;AACP"}
@@ -1 +1 @@
1
- {"version":3,"file":"useUnresolvedFileInstance.d.ts","names":["UnresolvedFile","GetHoveredLineResult","DiffLineAnnotation","FileContents","FileDiffMetadata","MergeConflictMarkerRow","SelectedLineRange","MergeConflictDiffAction","UnresolvedFileReactOptions","UseUnresolvedFileInstanceProps","LAnnotation","UseUnresolvedFileInstanceReturn","HTMLElement","useUnresolvedFileInstance","file","options","lineAnnotations","selectedLines","prerenderedHTML","hasConflictUtility","hasGutterRenderUtility","hasCustomHeader","disableWorkerPool"],"sources":["../../../src/react/utils/useUnresolvedFileInstance.d.ts"],"sourcesContent":["import { UnresolvedFile } from '../../components/UnresolvedFile';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type { DiffLineAnnotation, FileContents, FileDiffMetadata, MergeConflictMarkerRow, SelectedLineRange } from '../../types';\nimport { type MergeConflictDiffAction } from '../../utils/parseMergeConflictDiffFromFile';\nimport type { UnresolvedFileReactOptions } from '../UnresolvedFile';\ninterface UseUnresolvedFileInstanceProps<LAnnotation> {\n file: FileContents;\n options?: UnresolvedFileReactOptions<LAnnotation>;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n hasConflictUtility: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n}\ninterface UseUnresolvedFileInstanceReturn<LAnnotation> {\n fileDiff: FileDiffMetadata;\n actions: (MergeConflictDiffAction | undefined)[];\n markerRows: MergeConflictMarkerRow[];\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n getInstance(): UnresolvedFile<LAnnotation> | undefined;\n}\nexport declare function useUnresolvedFileInstance<LAnnotation>({ file, options, lineAnnotations, selectedLines, prerenderedHTML, hasConflictUtility, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool }: UseUnresolvedFileInstanceProps<LAnnotation>): UseUnresolvedFileInstanceReturn<LAnnotation>;\nexport {};\n//# sourceMappingURL=useUnresolvedFileInstance.d.ts.map"],"mappings":";;;;;;;UAKUS;QACAN;EADAM,OAAAA,CAAAA,EAEID,0BAF0B,CAECE,WAFDA,CAAAA;EAC9BP,eAAAA,EAEWD,kBAFXC,CAE8BO,WAF9BP,CAAAA,EAAAA,GAAAA,SAAAA;EAC+BO,aAAAA,EAEtBJ,iBAFsBI,GAAAA,IAAAA,GAAAA,SAAAA;EAA3BF,eAAAA,EAAAA,MAAAA,GAAAA,SAAAA;EAC0BE,kBAAAA,EAAAA,OAAAA;EAAnBR,sBAAAA,EAAAA,OAAAA;EACFI,eAAAA,EAAAA,OAAAA;EAAiB,iBAAA,EAAA,OAAA;AAAA;UAO1BK,+BACIP,CAAAA,WAAAA,CAAAA,CAAAA;EACAG,QAAAA,EADAH,gBACAG;EACEF,OAAAA,EAAAA,CADFE,uBACEF,GAAAA,SAAAA,CAAAA,EAAAA;EACFO,UAAAA,EADEP,sBACFO,EAAAA;EACQX,GAAAA,CAAAA,IAAAA,EADRW,WACQX,GAAAA,IAAAA,CAAAA,EAAAA,IAAAA;EACYS,cAAAA,EAAAA,EADZT,oBACYS,CAAAA,MAAAA,CAAAA,GAAAA,SAAAA;EAAfV,WAAAA,EAAAA,EAAAA,cAAAA,CAAeU,WAAfV,CAAAA,GAAAA,SAAAA;;AAEKa,iBAAAA,yBAAyBH,CAAAA,WAAA,CAAA,CAAA;EAAA,IAAA;EAAA,OAAA;EAAA,eAAA;EAAA,aAAA;EAAA,eAAA;EAAA,kBAAA;EAAA,sBAAA;EAAA,eAAA;EAAA;AAAA,CAAA,EAAkKD,8BAAlK,CAAiMC,WAAjM,CAAA,CAAA,EAAgNC,+BAAhN,CAAgPD,WAAhP,CAAA"}
1
+ {"version":3,"file":"useUnresolvedFileInstance.d.ts","names":[],"sources":["../../../src/react/utils/useUnresolvedFileInstance.ts"],"mappings":";;;;;;;UAoCU,8BAAA;EACR,IAAA,EAAM,YAAA;EACN,OAAA,GAAU,0BAAA,CAA2B,WAAA;EACrC,eAAA,EAAiB,kBAAA,CAAmB,WAAA;EACpC,aAAA,EAAe,iBAAA;EACf,eAAA;EACA,kBAAA;EACA,sBAAA;EACA,eAAA;EACA,iBAAA;AAAA;AAAA,UAGQ,+BAAA;EACR,QAAA,EAAU,gBAAA;EACV,OAAA,GAAU,uBAAA;EACV,UAAA,EAAY,sBAAA;EACZ,GAAA,CAAI,IAAA,EAAM,WAAA;EACV,cAAA,IAAkB,oBAAA;EAClB,WAAA,IAAe,cAAA,CAAe,WAAA;AAAA;AAAA,iBAGhB,yBAAA;EACd,IAAA;EACA,OAAA;EACA,eAAA;EACA,aAAA;EACA,eAAA;EACA,kBAAA;EACA,sBAAA;EACA,eAAA;EACA;AAAA,GACC,8BAAA,CAA+B,WAAA,IAAe,+BAAA,CAAgC,WAAA"}
@@ -5,26 +5,25 @@ import { noopRender } from "../constants.js";
5
5
  import { useStableCallback } from "./useStableCallback.js";
6
6
  import { WorkerPoolContext } from "../WorkerPoolContext.js";
7
7
  import { useCallback, useContext, useEffect, useLayoutEffect, useRef, useState } from "react";
8
-
9
8
  //#region src/react/utils/useUnresolvedFileInstance.ts
10
9
  const useIsometricEffect = typeof window === "undefined" ? useEffect : useLayoutEffect;
11
10
  function useUnresolvedFileInstance({ file, options, lineAnnotations, selectedLines, prerenderedHTML, hasConflictUtility, hasGutterRenderUtility, hasCustomHeader, disableWorkerPool }) {
12
11
  const [{ fileDiff, actions, markerRows }, setState] = useState(() => {
13
- const { fileDiff: fileDiff$1, actions: actions$1, markerRows: markerRows$1 } = parseMergeConflictDiffFromFile(file, options?.maxContextLines);
12
+ const { fileDiff, actions, markerRows } = parseMergeConflictDiffFromFile(file, options?.maxContextLines);
14
13
  return {
15
- fileDiff: fileDiff$1,
16
- actions: actions$1,
17
- markerRows: markerRows$1
14
+ fileDiff,
15
+ actions,
16
+ markerRows
18
17
  };
19
18
  });
20
19
  const onMergeConflictAction = useStableCallback((payload, instance) => {
21
20
  setState((prevState) => {
22
- const { fileDiff: fileDiff$1, actions: actions$1, markerRows: markerRows$1 } = instance.resolveConflict(payload.conflict.conflictIndex, payload.resolution, prevState.fileDiff) ?? {};
23
- if (fileDiff$1 == null || actions$1 == null || markerRows$1 == null) return prevState;
21
+ const { fileDiff, actions, markerRows } = instance.resolveConflict(payload.conflict.conflictIndex, payload.resolution, prevState.fileDiff) ?? {};
22
+ if (fileDiff == null || actions == null || markerRows == null) return prevState;
24
23
  else return {
25
- fileDiff: fileDiff$1,
26
- actions: actions$1,
27
- markerRows: markerRows$1
24
+ fileDiff,
25
+ actions,
26
+ markerRows
28
27
  };
29
28
  });
30
29
  });
@@ -102,7 +101,7 @@ function mergeUnresolvedOptions({ options, controlledSelection, onMergeConflictA
102
101
  renderGutterUtility: hasGutterRenderUtility ? noopRender : void 0
103
102
  };
104
103
  }
105
-
106
104
  //#endregion
107
105
  export { useUnresolvedFileInstance };
106
+
108
107
  //# sourceMappingURL=useUnresolvedFileInstance.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useUnresolvedFileInstance.js","names":["fileDiff","actions","markerRows","UnresolvedFileClass"],"sources":["../../../src/react/utils/useUnresolvedFileInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\n\nimport {\n UnresolvedFile,\n UnresolvedFile as UnresolvedFileClass,\n type UnresolvedFileOptions,\n} from '../../components/UnresolvedFile';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n DiffLineAnnotation,\n FileContents,\n FileDiffMetadata,\n MergeConflictActionPayload,\n MergeConflictMarkerRow,\n SelectedLineRange,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport {\n type MergeConflictDiffAction,\n parseMergeConflictDiffFromFile,\n} from '../../utils/parseMergeConflictDiffFromFile';\nimport { noopRender } from '../constants';\nimport type { UnresolvedFileReactOptions } from '../UnresolvedFile';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseUnresolvedFileInstanceProps<LAnnotation> {\n file: FileContents;\n options?: UnresolvedFileReactOptions<LAnnotation>;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n hasConflictUtility: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n}\n\ninterface UseUnresolvedFileInstanceReturn<LAnnotation> {\n fileDiff: FileDiffMetadata;\n actions: (MergeConflictDiffAction | undefined)[];\n markerRows: MergeConflictMarkerRow[];\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n getInstance(): UnresolvedFile<LAnnotation> | undefined;\n}\n\nexport function useUnresolvedFileInstance<LAnnotation>({\n file,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n hasConflictUtility,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n}: UseUnresolvedFileInstanceProps<LAnnotation>): UseUnresolvedFileInstanceReturn<LAnnotation> {\n const [{ fileDiff, actions, markerRows }, setState] = useState(() => {\n const { fileDiff, actions, markerRows } = parseMergeConflictDiffFromFile(\n file,\n options?.maxContextLines\n );\n return { fileDiff, actions, markerRows };\n });\n // UnresolvedFile is intentionally uncontrolled in React. Keep an internal\n // source-of-truth file so sequential conflict actions apply to the latest\n // resolved contents rather than the initial prop value.\n const onMergeConflictAction = useStableCallback(\n (\n payload: MergeConflictActionPayload,\n instance: UnresolvedFile<LAnnotation>\n ) => {\n setState((prevState) => {\n const { fileDiff, actions, markerRows } =\n instance.resolveConflict(\n payload.conflict.conflictIndex,\n payload.resolution,\n prevState.fileDiff\n ) ?? {};\n if (fileDiff == null || actions == null || markerRows == null) {\n return prevState;\n } else {\n return { fileDiff, actions, markerRows };\n }\n });\n }\n );\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const instanceRef = useRef<UnresolvedFileClass<LAnnotation> | null>(null);\n const ref = useStableCallback((fileContainer: HTMLElement | null) => {\n if (fileContainer != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'useUnresolvedFileInstance: An instance should not already exist when a node is created'\n );\n }\n instanceRef.current = new UnresolvedFileClass(\n mergeUnresolvedOptions({\n controlledSelection,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n onMergeConflictAction,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n void instanceRef.current.hydrate({\n fileDiff,\n actions,\n markerRows,\n fileContainer,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error(\n 'useUnresolvedFileInstance: A UnresolvedFile instance should exist when unmounting'\n );\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n if (instanceRef.current == null) return;\n const instance = instanceRef.current;\n const newOptions = mergeUnresolvedOptions({\n controlledSelection,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n onMergeConflictAction,\n options,\n });\n const forceRender = !areOptionsEqual(instance.options, newOptions);\n instance.setOptions(newOptions);\n void instance.render({\n fileDiff,\n actions,\n markerRows,\n lineAnnotations,\n forceRender,\n });\n if (selectedLines !== undefined) {\n instance.setSelectedLines(selectedLines);\n }\n });\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'diff'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n\n const getInstance = useCallback(() => {\n return instanceRef.current ?? undefined;\n }, []);\n\n return { ref, getHoveredLine, fileDiff, actions, markerRows, getInstance };\n}\n\ninterface MergeUnresolvedOptionsProps<LAnnotation> {\n options: UnresolvedFileReactOptions<LAnnotation> | undefined;\n controlledSelection: boolean;\n onMergeConflictAction: UnresolvedFileOptions<LAnnotation>['onMergeConflictAction'];\n hasConflictUtility: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n}\n\nfunction mergeUnresolvedOptions<LAnnotation>({\n options,\n controlledSelection,\n onMergeConflictAction,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n}: MergeUnresolvedOptionsProps<LAnnotation>): UnresolvedFileOptions<LAnnotation> {\n return {\n ...options,\n controlledSelection,\n onMergeConflictAction,\n hunkSeparators:\n options?.hunkSeparators === 'custom'\n ? noopRender\n : options?.hunkSeparators,\n // Add a placeholder type for the custom render\n mergeConflictActionsType:\n hasConflictUtility || options?.mergeConflictActionsType === 'custom'\n ? noopRender\n : options?.mergeConflictActionsType,\n renderCustomHeader: hasCustomHeader ? noopRender : undefined,\n renderGutterUtility: hasGutterRenderUtility ? noopRender : undefined,\n };\n}\n"],"mappings":";;;;;;;;;AAiCA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAuB9C,SAAgB,0BAAuC,EACrD,MACA,SACA,iBACA,eACA,iBACA,oBACA,wBACA,iBACA,qBAC4F;CAC5F,MAAM,CAAC,EAAE,UAAU,SAAS,cAAc,YAAY,eAAe;EACnE,MAAM,EAAE,sBAAU,oBAAS,6BAAe,+BACxC,MACA,SAAS,gBACV;AACD,SAAO;GAAE;GAAU;GAAS;GAAY;GACxC;CAIF,MAAM,wBAAwB,mBAE1B,SACA,aACG;AACH,YAAU,cAAc;GACtB,MAAM,EAAE,sBAAU,oBAAS,6BACzB,SAAS,gBACP,QAAQ,SAAS,eACjB,QAAQ,YACR,UAAU,SACX,IAAI,EAAE;AACT,OAAIA,cAAY,QAAQC,aAAW,QAAQC,gBAAc,KACvD,QAAO;OAEP,QAAO;IAAE;IAAU;IAAS;IAAY;IAE1C;GAEL;CACD,MAAM,sBAAsB,kBAAkB;CAC9C,MAAM,cAAc,WAAW,kBAAkB;CACjD,MAAM,cAAc,OAAgD,KAAK;CACzE,MAAM,MAAM,mBAAmB,kBAAsC;AACnE,MAAI,iBAAiB,MAAM;AACzB,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MACR,yFACD;AAEH,eAAY,UAAU,IAAIC,eACxB,uBAAuB;IACrB;IACA;IACA;IACA;IACA;IACA;IACD,CAAC,EACF,CAAC,oBAAoB,cAAc,QACnC,KACD;AACD,GAAK,YAAY,QAAQ,QAAQ;IAC/B;IACA;IACA;IACA;IACA;IACA;IACD,CAAC;SACG;AACL,OAAI,YAAY,WAAW,KACzB,OAAM,IAAI,MACR,oFACD;AAEH,eAAY,QAAQ,SAAS;AAC7B,eAAY,UAAU;;GAExB;AAEF,0BAAyB;AACvB,MAAI,YAAY,WAAW,KAAM;EACjC,MAAM,WAAW,YAAY;EAC7B,MAAM,aAAa,uBAAuB;GACxC;GACA;GACA;GACA;GACA;GACA;GACD,CAAC;EACF,MAAM,cAAc,CAAC,gBAAgB,SAAS,SAAS,WAAW;AAClE,WAAS,WAAW,WAAW;AAC/B,EAAK,SAAS,OAAO;GACnB;GACA;GACA;GACA;GACA;GACD,CAAC;AACF,MAAI,kBAAkB,OACpB,UAAS,iBAAiB,cAAc;GAE1C;AAYF,QAAO;EAAE;EAAK,gBAVS,kBAEN;AACf,UAAO,YAAY,SAAS,gBAAgB;KAC3C,EAAE,CAAC;EAMwB;EAAU;EAAS;EAAY,aAJzC,kBAAkB;AACpC,UAAO,YAAY,WAAW;KAC7B,EAAE,CAAC;EAEoE;;AAY5E,SAAS,uBAAoC,EAC3C,SACA,qBACA,uBACA,oBACA,iBACA,0BAC+E;AAC/E,QAAO;EACL,GAAG;EACH;EACA;EACA,gBACE,SAAS,mBAAmB,WACxB,aACA,SAAS;EAEf,0BACE,sBAAsB,SAAS,6BAA6B,WACxD,aACA,SAAS;EACf,oBAAoB,kBAAkB,aAAa;EACnD,qBAAqB,yBAAyB,aAAa;EAC5D"}
1
+ {"version":3,"file":"useUnresolvedFileInstance.js","names":["UnresolvedFileClass"],"sources":["../../../src/react/utils/useUnresolvedFileInstance.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react';\n\nimport {\n UnresolvedFile,\n UnresolvedFile as UnresolvedFileClass,\n type UnresolvedFileOptions,\n} from '../../components/UnresolvedFile';\nimport type { GetHoveredLineResult } from '../../managers/InteractionManager';\nimport type {\n DiffLineAnnotation,\n FileContents,\n FileDiffMetadata,\n MergeConflictActionPayload,\n MergeConflictMarkerRow,\n SelectedLineRange,\n} from '../../types';\nimport { areOptionsEqual } from '../../utils/areOptionsEqual';\nimport {\n type MergeConflictDiffAction,\n parseMergeConflictDiffFromFile,\n} from '../../utils/parseMergeConflictDiffFromFile';\nimport { noopRender } from '../constants';\nimport type { UnresolvedFileReactOptions } from '../UnresolvedFile';\nimport { WorkerPoolContext } from '../WorkerPoolContext';\nimport { useStableCallback } from './useStableCallback';\n\nconst useIsometricEffect =\n typeof window === 'undefined' ? useEffect : useLayoutEffect;\n\ninterface UseUnresolvedFileInstanceProps<LAnnotation> {\n file: FileContents;\n options?: UnresolvedFileReactOptions<LAnnotation>;\n lineAnnotations: DiffLineAnnotation<LAnnotation>[] | undefined;\n selectedLines: SelectedLineRange | null | undefined;\n prerenderedHTML: string | undefined;\n hasConflictUtility: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n disableWorkerPool: boolean;\n}\n\ninterface UseUnresolvedFileInstanceReturn<LAnnotation> {\n fileDiff: FileDiffMetadata;\n actions: (MergeConflictDiffAction | undefined)[];\n markerRows: MergeConflictMarkerRow[];\n ref(node: HTMLElement | null): void;\n getHoveredLine(): GetHoveredLineResult<'diff'> | undefined;\n getInstance(): UnresolvedFile<LAnnotation> | undefined;\n}\n\nexport function useUnresolvedFileInstance<LAnnotation>({\n file,\n options,\n lineAnnotations,\n selectedLines,\n prerenderedHTML,\n hasConflictUtility,\n hasGutterRenderUtility,\n hasCustomHeader,\n disableWorkerPool,\n}: UseUnresolvedFileInstanceProps<LAnnotation>): UseUnresolvedFileInstanceReturn<LAnnotation> {\n const [{ fileDiff, actions, markerRows }, setState] = useState(() => {\n const { fileDiff, actions, markerRows } = parseMergeConflictDiffFromFile(\n file,\n options?.maxContextLines\n );\n return { fileDiff, actions, markerRows };\n });\n // UnresolvedFile is intentionally uncontrolled in React. Keep an internal\n // source-of-truth file so sequential conflict actions apply to the latest\n // resolved contents rather than the initial prop value.\n const onMergeConflictAction = useStableCallback(\n (\n payload: MergeConflictActionPayload,\n instance: UnresolvedFile<LAnnotation>\n ) => {\n setState((prevState) => {\n const { fileDiff, actions, markerRows } =\n instance.resolveConflict(\n payload.conflict.conflictIndex,\n payload.resolution,\n prevState.fileDiff\n ) ?? {};\n if (fileDiff == null || actions == null || markerRows == null) {\n return prevState;\n } else {\n return { fileDiff, actions, markerRows };\n }\n });\n }\n );\n const controlledSelection = selectedLines !== undefined;\n const poolManager = useContext(WorkerPoolContext);\n const instanceRef = useRef<UnresolvedFileClass<LAnnotation> | null>(null);\n const ref = useStableCallback((fileContainer: HTMLElement | null) => {\n if (fileContainer != null) {\n if (instanceRef.current != null) {\n throw new Error(\n 'useUnresolvedFileInstance: An instance should not already exist when a node is created'\n );\n }\n instanceRef.current = new UnresolvedFileClass(\n mergeUnresolvedOptions({\n controlledSelection,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n onMergeConflictAction,\n options,\n }),\n !disableWorkerPool ? poolManager : undefined,\n true\n );\n void instanceRef.current.hydrate({\n fileDiff,\n actions,\n markerRows,\n fileContainer,\n lineAnnotations,\n prerenderedHTML,\n });\n } else {\n if (instanceRef.current == null) {\n throw new Error(\n 'useUnresolvedFileInstance: A UnresolvedFile instance should exist when unmounting'\n );\n }\n instanceRef.current.cleanUp();\n instanceRef.current = null;\n }\n });\n\n useIsometricEffect(() => {\n if (instanceRef.current == null) return;\n const instance = instanceRef.current;\n const newOptions = mergeUnresolvedOptions({\n controlledSelection,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n onMergeConflictAction,\n options,\n });\n const forceRender = !areOptionsEqual(instance.options, newOptions);\n instance.setOptions(newOptions);\n void instance.render({\n fileDiff,\n actions,\n markerRows,\n lineAnnotations,\n forceRender,\n });\n if (selectedLines !== undefined) {\n instance.setSelectedLines(selectedLines);\n }\n });\n\n const getHoveredLine = useCallback(():\n | GetHoveredLineResult<'diff'>\n | undefined => {\n return instanceRef.current?.getHoveredLine();\n }, []);\n\n const getInstance = useCallback(() => {\n return instanceRef.current ?? undefined;\n }, []);\n\n return { ref, getHoveredLine, fileDiff, actions, markerRows, getInstance };\n}\n\ninterface MergeUnresolvedOptionsProps<LAnnotation> {\n options: UnresolvedFileReactOptions<LAnnotation> | undefined;\n controlledSelection: boolean;\n onMergeConflictAction: UnresolvedFileOptions<LAnnotation>['onMergeConflictAction'];\n hasConflictUtility: boolean;\n hasGutterRenderUtility: boolean;\n hasCustomHeader: boolean;\n}\n\nfunction mergeUnresolvedOptions<LAnnotation>({\n options,\n controlledSelection,\n onMergeConflictAction,\n hasConflictUtility,\n hasCustomHeader,\n hasGutterRenderUtility,\n}: MergeUnresolvedOptionsProps<LAnnotation>): UnresolvedFileOptions<LAnnotation> {\n return {\n ...options,\n controlledSelection,\n onMergeConflictAction,\n hunkSeparators:\n options?.hunkSeparators === 'custom'\n ? noopRender\n : options?.hunkSeparators,\n // Add a placeholder type for the custom render\n mergeConflictActionsType:\n hasConflictUtility || options?.mergeConflictActionsType === 'custom'\n ? noopRender\n : options?.mergeConflictActionsType,\n renderCustomHeader: hasCustomHeader ? noopRender : undefined,\n renderGutterUtility: hasGutterRenderUtility ? noopRender : undefined,\n };\n}\n"],"mappings":";;;;;;;;AAiCA,MAAM,qBACJ,OAAO,WAAW,cAAc,YAAY;AAuB9C,SAAgB,0BAAuC,EACrD,MACA,SACA,iBACA,eACA,iBACA,oBACA,wBACA,iBACA,qBAC4F;CAC5F,MAAM,CAAC,EAAE,UAAU,SAAS,cAAc,YAAY,eAAe;EACnE,MAAM,EAAE,UAAU,SAAS,eAAe,+BACxC,MACA,SAAS,eACX;EACA,OAAO;GAAE;GAAU;GAAS;EAAW;CACzC,CAAC;CAID,MAAM,wBAAwB,mBAE1B,SACA,aACG;EACH,UAAU,cAAc;GACtB,MAAM,EAAE,UAAU,SAAS,eACzB,SAAS,gBACP,QAAQ,SAAS,eACjB,QAAQ,YACR,UAAU,QACZ,KAAK,CAAC;GACR,IAAI,YAAY,QAAQ,WAAW,QAAQ,cAAc,MACvD,OAAO;QAEP,OAAO;IAAE;IAAU;IAAS;GAAW;EAE3C,CAAC;CACH,CACF;CACA,MAAM,sBAAsB,kBAAkB,KAAA;CAC9C,MAAM,cAAc,WAAW,iBAAiB;CAChD,MAAM,cAAc,OAAgD,IAAI;CACxE,MAAM,MAAM,mBAAmB,kBAAsC;EACnE,IAAI,iBAAiB,MAAM;GACzB,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MACR,wFACF;GAEF,YAAY,UAAU,IAAIA,eACxB,uBAAuB;IACrB;IACA;IACA;IACA;IACA;IACA;GACF,CAAC,GACD,CAAC,oBAAoB,cAAc,KAAA,GACnC,IACF;GACA,YAAiB,QAAQ,QAAQ;IAC/B;IACA;IACA;IACA;IACA;IACA;GACF,CAAC;EACH,OAAO;GACL,IAAI,YAAY,WAAW,MACzB,MAAM,IAAI,MACR,mFACF;GAEF,YAAY,QAAQ,QAAQ;GAC5B,YAAY,UAAU;EACxB;CACF,CAAC;CAED,yBAAyB;EACvB,IAAI,YAAY,WAAW,MAAM;EACjC,MAAM,WAAW,YAAY;EAC7B,MAAM,aAAa,uBAAuB;GACxC;GACA;GACA;GACA;GACA;GACA;EACF,CAAC;EACD,MAAM,cAAc,CAAC,gBAAgB,SAAS,SAAS,UAAU;EACjE,SAAS,WAAW,UAAU;EAC9B,SAAc,OAAO;GACnB;GACA;GACA;GACA;GACA;EACF,CAAC;EACD,IAAI,kBAAkB,KAAA,GACpB,SAAS,iBAAiB,aAAa;CAE3C,CAAC;CAYD,OAAO;EAAE;EAAK,gBAVS,kBAEN;GACf,OAAO,YAAY,SAAS,eAAe;EAC7C,GAAG,CAAC,CAMuB;EAAG;EAAU;EAAS;EAAY,aAJzC,kBAAkB;GACpC,OAAO,YAAY,WAAW,KAAA;EAChC,GAAG,CAAC,CAEmE;CAAE;AAC3E;AAWA,SAAS,uBAAoC,EAC3C,SACA,qBACA,uBACA,oBACA,iBACA,0BAC+E;CAC/E,OAAO;EACL,GAAG;EACH;EACA;EACA,gBACE,SAAS,mBAAmB,WACxB,aACA,SAAS;EAEf,0BACE,sBAAsB,SAAS,6BAA6B,WACxD,aACA,SAAS;EACf,oBAAoB,kBAAkB,aAAa,KAAA;EACnD,qBAAqB,yBAAyB,aAAa,KAAA;CAC7D;AACF"}
@@ -1,8 +1,7 @@
1
- import { AnnotationSpan, BaseDiffOptions, BaseDiffOptionsWithDefaults, CustomPreProperties, DiffLineAnnotation, DiffsHighlighter, DiffsTextDocument, ExpansionDirections, FileDiffMetadata, FileHeaderRenderMode, HighlightedToken, HunkData, HunkExpansionRegion, LineTypes, RenderDiffOptions, RenderRange, ThemedDiffResult } from "../types.js";
1
+ import { Element, ElementContent, Properties } from "../node_modules/.pnpm/@types_hast@3.0.4/node_modules/@types/hast/index.js";
2
+ import { BaseDiffOptions, BaseDiffOptionsWithDefaults, CustomPreProperties, DiffLineAnnotation, DiffsHighlighter, DiffsTextDocument, ExpansionDirections, FileDiffMetadata, FileHeaderRenderMode, HighlightedToken, HunkData, HunkExpansionRegion, LineTypes, RenderDiffOptions, RenderRange, ThemedDiffResult } from "../types.js";
2
3
  import { WorkerPoolManager } from "../worker/WorkerPoolManager.js";
3
- import "../worker/index.js";
4
4
  import { DiffLineMetadata } from "../utils/iterateOverDiff.js";
5
- import { Element, ElementContent, Properties } from "hast";
6
5
 
7
6
  //#region src/renderers/DiffHunksRenderer.d.ts
8
7
  interface DiffHunksRendererOptions extends BaseDiffOptions {
@@ -93,7 +92,7 @@ declare class DiffHunksRenderer<LAnnotation = undefined> {
93
92
  getExpandedHunk(hunkIndex: number): HunkExpansionRegion;
94
93
  getExpandedHunksMap(): Map<number, HunkExpansionRegion>;
95
94
  setLineAnnotations(lineAnnotations: DiffLineAnnotation<LAnnotation>[]): void;
96
- updateRenderCache(dirtyLines: Map<number, Array<HighlightedToken>>, themeType: 'dark' | 'light'): void;
95
+ updateRenderCache(dirtyLines: Map<number, Array<HighlightedToken>>, themeType: 'dark' | 'light', skipDiffRecompute?: boolean): void;
97
96
  applyDocumentChange(textDocument: DiffsTextDocument): void;
98
97
  protected getUnifiedLineDecoration({
99
98
  lineType
@@ -102,7 +101,7 @@ declare class DiffHunksRenderer<LAnnotation = undefined> {
102
101
  side,
103
102
  type
104
103
  }: SplitLineDecorationProps): LineDecoration;
105
- protected createAnnotationElement(span: AnnotationSpan): Element;
104
+ private createAnnotationElement;
106
105
  protected getUnifiedInjectedRowsForLine?: (ctx: RenderedLineContext) => UnifiedInjectedRowPlacement | undefined;
107
106
  protected getSplitInjectedRowsForLine?: (ctx: RenderedLineContext) => SplitInjectedRowPlacement | undefined;
108
107
  protected getOptionsWithDefaults(): DiffHunksRendererOptionsWithDefaults;
@@ -124,6 +123,7 @@ declare class DiffHunksRenderer<LAnnotation = undefined> {
124
123
  renderFullAST(result: HunksRenderResult, children?: ElementContent[]): Element;
125
124
  renderFullHTML(result: HunksRenderResult, tempChildren?: ElementContent[]): string;
126
125
  renderPartialHTML(children: ElementContent[], columnType?: 'unified' | 'deletions' | 'additions'): string;
126
+ private pushFileLevelAnnotations;
127
127
  private getAnnotations;
128
128
  private renderHeader;
129
129
  }
@@ -1 +1 @@
1
- {"version":3,"file":"DiffHunksRenderer.d.ts","names":["ElementContent","Element","HASTElement","Properties","AnnotationSpan","BaseDiffOptions","BaseDiffOptionsWithDefaults","CustomPreProperties","DiffLineAnnotation","DiffsHighlighter","DiffsTextDocument","ExpansionDirections","FileDiffMetadata","FileHeaderRenderMode","HighlightedToken","HunkData","HunkExpansionRegion","LineTypes","RenderDiffOptions","RenderRange","ThemedDiffResult","DiffLineMetadata","WorkerPoolManager","DiffHunksRendererOptions","DiffHunksRendererOptionsWithDefaults","Omit","UnifiedLineDecorationProps","SplitLineDecorationProps","LineDecoration","RenderedLineContext","InjectedRow","SplitInjectedRow","UnifiedInjectedRowPlacement","SplitInjectedRowPlacement","HunksRenderResult","DiffHunksRenderer","LAnnotation","Partial","Map","Array","lineType","side","type","Promise"],"sources":["../../src/renderers/DiffHunksRenderer.d.ts"],"sourcesContent":["import type { ElementContent, Element as HASTElement, Properties } from 'hast';\nimport type { AnnotationSpan, BaseDiffOptions, BaseDiffOptionsWithDefaults, CustomPreProperties, DiffLineAnnotation, DiffsHighlighter, DiffsTextDocument, ExpansionDirections, FileDiffMetadata, FileHeaderRenderMode, HighlightedToken, HunkData, HunkExpansionRegion, LineTypes, RenderDiffOptions, RenderRange, ThemedDiffResult } from '../types';\nimport type { DiffLineMetadata } from '../utils/iterateOverDiff';\nimport type { WorkerPoolManager } from '../worker';\nexport interface DiffHunksRendererOptions extends BaseDiffOptions {\n headerRenderMode?: FileHeaderRenderMode;\n}\nexport interface DiffHunksRendererOptionsWithDefaults extends Omit<BaseDiffOptionsWithDefaults, 'themeType'> {\n headerRenderMode: FileHeaderRenderMode;\n}\nexport interface UnifiedLineDecorationProps {\n type: 'context' | 'context-expanded' | 'change';\n lineType: LineTypes;\n additionLineIndex: number | undefined;\n deletionLineIndex: number | undefined;\n}\nexport interface SplitLineDecorationProps {\n side: 'deletions' | 'additions';\n type: 'context' | 'context-expanded' | 'change';\n lineIndex: number | undefined;\n}\nexport interface LineDecoration {\n gutterLineType: LineTypes;\n gutterProperties?: Properties;\n contentProperties?: Properties;\n}\nexport interface RenderedLineContext {\n type: 'context' | 'context-expanded' | 'change';\n hunkIndex: number;\n lineIndex: number;\n unifiedLineIndex: number;\n splitLineIndex: number;\n deletionLine?: DiffLineMetadata;\n additionLine?: DiffLineMetadata;\n}\nexport interface InjectedRow {\n content: HASTElement;\n gutter: HASTElement;\n}\nexport interface SplitInjectedRow {\n deletion: InjectedRow | undefined;\n addition: InjectedRow | undefined;\n}\nexport interface UnifiedInjectedRowPlacement {\n before?: InjectedRow[];\n after?: InjectedRow[];\n}\nexport interface SplitInjectedRowPlacement {\n before?: SplitInjectedRow[];\n after?: SplitInjectedRow[];\n}\nexport interface HunksRenderResult {\n unifiedGutterAST: ElementContent[] | undefined;\n unifiedContentAST: ElementContent[] | undefined;\n deletionsGutterAST: ElementContent[] | undefined;\n deletionsContentAST: ElementContent[] | undefined;\n additionsGutterAST: ElementContent[] | undefined;\n additionsContentAST: ElementContent[] | undefined;\n hunkData: HunkData[];\n css: string;\n preNode: HASTElement;\n headerElement: HASTElement | undefined;\n totalLines: number;\n themeStyles: string;\n baseThemeType: 'light' | 'dark' | undefined;\n rowCount: number;\n bufferBefore: number;\n bufferAfter: number;\n}\nexport declare class DiffHunksRenderer<LAnnotation = undefined> {\n options: DiffHunksRendererOptions;\n private onRenderUpdate?;\n private workerManager?;\n readonly __id: string;\n private highlighter;\n private diff;\n private expandedHunks;\n private deletionAnnotations;\n private additionAnnotations;\n private computedLang;\n private renderCache;\n constructor(options?: DiffHunksRendererOptions, onRenderUpdate?: (() => unknown) | undefined, workerManager?: WorkerPoolManager | undefined);\n cleanUp(): void;\n recycle(): void;\n getRenderDiff(): FileDiffMetadata | undefined;\n clearRenderCache(): void;\n setOptions(options: DiffHunksRendererOptions): void;\n mergeOptions(options: Partial<DiffHunksRendererOptions>): void;\n expandHunk(index: number, direction: ExpansionDirections, expansionLineCount?: number): void;\n getExpandedHunk(hunkIndex: number): HunkExpansionRegion;\n getExpandedHunksMap(): Map<number, HunkExpansionRegion>;\n setLineAnnotations(lineAnnotations: DiffLineAnnotation<LAnnotation>[]): void;\n updateRenderCache(dirtyLines: Map<number, Array<HighlightedToken>>, themeType: 'dark' | 'light'): void;\n applyDocumentChange(textDocument: DiffsTextDocument): void;\n protected getUnifiedLineDecoration({ lineType }: UnifiedLineDecorationProps): LineDecoration;\n protected getSplitLineDecoration({ side, type }: SplitLineDecorationProps): LineDecoration;\n protected createAnnotationElement(span: AnnotationSpan): HASTElement;\n protected getUnifiedInjectedRowsForLine?: (ctx: RenderedLineContext) => UnifiedInjectedRowPlacement | undefined;\n protected getSplitInjectedRowsForLine?: (ctx: RenderedLineContext) => SplitInjectedRowPlacement | undefined;\n protected getOptionsWithDefaults(): DiffHunksRendererOptionsWithDefaults;\n initializeHighlighter(): Promise<DiffsHighlighter>;\n hydrate(diff: FileDiffMetadata | undefined): void;\n private getRenderOptions;\n renderDiff(diff?: FileDiffMetadata | undefined, renderRange?: RenderRange): HunksRenderResult | undefined;\n asyncRender(diff: FileDiffMetadata, renderRange?: RenderRange): Promise<HunksRenderResult>;\n protected createPreElement(split: boolean, totalLines: number, customProperties?: CustomPreProperties): HASTElement;\n private asyncHighlight;\n private renderDiffWithHighlighter;\n onHighlightSuccess(diff: FileDiffMetadata, result: ThemedDiffResult, options: RenderDiffOptions, highlighted?: boolean): void;\n private getMatchingWorkerResultCache;\n private hasHighlightedRenderCache;\n onHighlightError(error: unknown): void;\n private getTokenizeMaxLength;\n private processDiffResult;\n renderCodeAST(type: 'unified' | 'deletions' | 'additions', result: HunksRenderResult): ElementContent[] | undefined;\n renderFullAST(result: HunksRenderResult, children?: ElementContent[]): HASTElement;\n renderFullHTML(result: HunksRenderResult, tempChildren?: ElementContent[]): string;\n renderPartialHTML(children: ElementContent[], columnType?: 'unified' | 'deletions' | 'additions'): string;\n private getAnnotations;\n private renderHeader;\n}\n//# sourceMappingURL=DiffHunksRenderer.d.ts.map"],"mappings":"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"}
1
+ {"version":3,"file":"DiffHunksRenderer.d.ts","names":[],"sources":["../../src/renderers/DiffHunksRenderer.ts"],"mappings":"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"}
@@ -1,4 +1,5 @@
1
- import { DEFAULT_COLLAPSED_CONTEXT_THRESHOLD, DEFAULT_EXPANDED_REGION, DEFAULT_RENDER_RANGE, DEFAULT_THEMES, DEFAULT_TOKENIZE_MAX_LENGTH } from "../constants.js";
1
+ import { DEFAULT_EXPANDED_REGION, DEFAULT_RENDER_RANGE, DEFAULT_THEMES, DEFAULT_TOKENIZE_MAX_LENGTH } from "../constants.js";
2
+ import { getFileAnnotations, shouldRenderFileAnnotations } from "../utils/includesFileAnnotations.js";
2
3
  import { createGutterGap, createGutterItem, createGutterWrapper, createHastElement } from "../utils/hast_utils.js";
3
4
  import { areLanguagesAttached } from "../highlighter/languages/areLanguagesAttached.js";
4
5
  import { getHighlighterIfLoaded, getSharedHighlighter } from "../highlighter/shared_highlighter.js";
@@ -26,12 +27,14 @@ import { isDefaultRenderRange } from "../utils/isDefaultRenderRange.js";
26
27
  import { isDiffPlainText } from "../utils/isDiffPlainText.js";
27
28
  import { renderDiffWithHighlighter } from "../utils/renderDiffWithHighlighter.js";
28
29
  import { splitFileContents } from "../utils/splitFileContents.js";
29
- import { recomputeDiffHunks, updateDiffHunks } from "../utils/updateDiffHunks.js";
30
+ import { recomputeDiffHunks, recomputeEmptyDocumentDiff, updateDiffHunks } from "../utils/updateDiffHunks.js";
30
31
  import { toHtml } from "hast-util-to-html";
31
-
32
32
  //#region src/renderers/DiffHunksRenderer.ts
33
33
  let instanceId = -1;
34
34
  var DiffHunksRenderer = class {
35
+ options;
36
+ onRenderUpdate;
37
+ workerManager;
35
38
  __id = `diff-hunks-renderer:${++instanceId}`;
36
39
  highlighter;
37
40
  diff;
@@ -108,7 +111,7 @@ var DiffHunksRenderer = class {
108
111
  arr.push(annotation);
109
112
  }
110
113
  }
111
- updateRenderCache(dirtyLines, themeType) {
114
+ updateRenderCache(dirtyLines, themeType, skipDiffRecompute = false) {
112
115
  if (this.renderCache == null) return;
113
116
  const { result, diff } = this.renderCache;
114
117
  if (result == null) return;
@@ -161,7 +164,7 @@ var DiffHunksRenderer = class {
161
164
  })
162
165
  };
163
166
  }
164
- if (changedAdditionLines.length > 0) Object.assign(diff, updateDiffHunks(diff, changedAdditionLines, this.options.parseDiffOptions));
167
+ if (!skipDiffRecompute && changedAdditionLines.length > 0) Object.assign(diff, updateDiffHunks(diff, changedAdditionLines, this.options.parseDiffOptions));
165
168
  result.baseThemeType = themeType;
166
169
  this.renderCache.isDirty = true;
167
170
  }
@@ -175,7 +178,10 @@ var DiffHunksRenderer = class {
175
178
  const prevLen = additionHastLines.length;
176
179
  if (newLength < prevLen) additionHastLines.length = newLength;
177
180
  for (let i = prevLen; i < newLength; i++) additionHastLines[i] ??= createPlainAdditionLineElement(i, textDocument);
178
- if (!diff.isPartial) Object.assign(diff, recomputeDiffHunks(diff, this.options.parseDiffOptions));
181
+ if (!diff.isPartial) if (newLength === 0) {
182
+ Object.assign(diff, recomputeEmptyDocumentDiff(diff, this.options.parseDiffOptions));
183
+ additionHastLines[0] = createPlainAdditionLineElement(0, textDocument);
184
+ } else Object.assign(diff, recomputeDiffHunks(diff, this.options.parseDiffOptions));
179
185
  this.renderCache.isDirty = true;
180
186
  }
181
187
  getUnifiedLineDecoration({ lineType }) {
@@ -191,11 +197,11 @@ var DiffHunksRenderer = class {
191
197
  contentProperties: { "data-line-type": lineType }
192
198
  };
193
199
  }
194
- createAnnotationElement(span) {
200
+ createAnnotationElement = (span) => {
195
201
  return createAnnotationElement(span);
196
- }
202
+ };
197
203
  getOptionsWithDefaults() {
198
- const { diffIndicators = "bars", diffStyle = "split", disableBackground = false, disableFileHeader = false, disableLineNumbers = false, disableVirtualizationBuffers = false, collapsed = false, expandUnchanged = false, collapsedContextThreshold = DEFAULT_COLLAPSED_CONTEXT_THRESHOLD, expansionLineCount = 100, hunkSeparators = "line-info", lineDiffType = "word-alt", maxLineDiffLength = 1e3, overflow = "scroll", stickyHeader = false, theme = DEFAULT_THEMES, headerRenderMode = "default", tokenizeMaxLineLength = 1e3, tokenizeMaxLength = DEFAULT_TOKENIZE_MAX_LENGTH, useTokenTransformer = false, useCSSClasses = false } = this.options;
204
+ const { diffIndicators = "bars", diffStyle = "split", disableBackground = false, disableFileHeader = false, disableLineNumbers = false, disableVirtualizationBuffers = false, collapsed = false, expandUnchanged = false, collapsedContextThreshold = 1, expansionLineCount = 100, hunkSeparators = "line-info", lineDiffType = "word-alt", maxLineDiffLength = 1e3, overflow = "scroll", stickyHeader = false, theme = DEFAULT_THEMES, headerRenderMode = "default", tokenizeMaxLineLength = 1e3, tokenizeMaxLength = DEFAULT_TOKENIZE_MAX_LENGTH, useTokenTransformer = false, useCSSClasses = false } = this.options;
199
205
  return {
200
206
  diffIndicators,
201
207
  diffStyle,
@@ -312,18 +318,18 @@ var DiffHunksRenderer = class {
312
318
  const hasLangs = this.highlighter != null && areLanguagesAttached(this.computedLang);
313
319
  const canHighlight = !forcePlainText && hasLangs;
314
320
  if (this.highlighter != null && hasThemes && (forceHighlight || forcePlainText || !this.renderCache.highlighted && canHighlight || this.renderCache.result == null)) {
315
- const { result, options: options$1 } = this.renderDiffWithHighlighter(diff, this.highlighter, forcePlainText || !hasLangs);
321
+ const { result, options } = this.renderDiffWithHighlighter(diff, this.highlighter, forcePlainText || !hasLangs);
316
322
  this.renderCache = {
317
323
  diff,
318
- options: options$1,
324
+ options,
319
325
  highlighted: canHighlight,
320
326
  result,
321
327
  renderRange: void 0
322
328
  };
323
329
  }
324
- if (!hasThemes || !forcePlainText && !hasLangs) this.asyncHighlight(diff).then(({ result, options: options$1 }) => {
330
+ if (!hasThemes || !forcePlainText && !hasLangs) this.asyncHighlight(diff).then(({ result, options }) => {
325
331
  if (this.renderCache != null) this.renderCache.highlighted = false;
326
- this.onHighlightSuccess(diff, result, options$1, !forcePlainText);
332
+ this.onHighlightSuccess(diff, result, options, !forcePlainText);
327
333
  });
328
334
  }
329
335
  return this.renderCache.result != null ? this.processDiffResult(this.renderCache.diff, renderRange, this.renderCache.result) : void 0;
@@ -390,7 +396,7 @@ var DiffHunksRenderer = class {
390
396
  console.error(error);
391
397
  }
392
398
  getTokenizeMaxLength() {
393
- return this.options.tokenizeMaxLength ?? DEFAULT_TOKENIZE_MAX_LENGTH;
399
+ return this.options.tokenizeMaxLength ?? 1e5;
394
400
  }
395
401
  processDiffResult(fileDiff, renderRange, { code, themeStyles, baseThemeType }) {
396
402
  const { diffStyle, disableFileHeader, expandUnchanged, expansionLineCount, collapsedContextThreshold, hunkSeparators } = this.getOptionsWithDefaults();
@@ -469,6 +475,7 @@ var DiffHunksRenderer = class {
469
475
  pushSeparator("additions", props, context);
470
476
  }
471
477
  }
478
+ this.pushFileLevelAnnotations(fileDiff, diffStyle, renderRange, context);
472
479
  iterateOverDiff({
473
480
  diff: fileDiff,
474
481
  diffStyle,
@@ -739,6 +746,48 @@ var DiffHunksRenderer = class {
739
746
  }
740
747
  }));
741
748
  }
749
+ pushFileLevelAnnotations(fileDiff, diffStyle, renderRange, context) {
750
+ if (!shouldRenderFileAnnotations(renderRange)) return;
751
+ const deletionAnnotationNames = fileDiff.type !== "new" ? getAnnotationNames(getFileAnnotations(this.deletionAnnotations)) : [];
752
+ const additionAnnotationNames = fileDiff.type !== "deleted" ? getAnnotationNames(getFileAnnotations(this.additionAnnotations)) : [];
753
+ if (deletionAnnotationNames.length === 0 && additionAnnotationNames.length === 0) return;
754
+ const hunkIndex = -1;
755
+ const lineIndex = -1;
756
+ const { createAnnotationElement } = this;
757
+ if (diffStyle === "unified") {
758
+ pushLineWithAnnotation({
759
+ diffStyle,
760
+ type: "context",
761
+ unifiedSpan: {
762
+ type: "annotation",
763
+ hunkIndex,
764
+ lineIndex,
765
+ annotations: deletionAnnotationNames.concat(additionAnnotationNames)
766
+ },
767
+ createAnnotationElement,
768
+ context
769
+ });
770
+ return;
771
+ }
772
+ pushLineWithAnnotation({
773
+ diffStyle,
774
+ type: "context",
775
+ deletionSpan: {
776
+ type: "annotation",
777
+ hunkIndex,
778
+ lineIndex,
779
+ annotations: deletionAnnotationNames
780
+ },
781
+ additionSpan: {
782
+ type: "annotation",
783
+ hunkIndex,
784
+ lineIndex,
785
+ annotations: additionAnnotationNames
786
+ },
787
+ createAnnotationElement,
788
+ context
789
+ });
790
+ }
742
791
  getAnnotations(type, deletionLineNumber, additionLineNumber, hunkIndex, lineIndex) {
743
792
  const deletionSpan = {
744
793
  type: "annotation",
@@ -773,8 +822,12 @@ var DiffHunksRenderer = class {
773
822
  });
774
823
  }
775
824
  };
825
+ function getAnnotationNames(annotations) {
826
+ return annotations?.map((annotation) => getLineAnnotationName(annotation)) ?? [];
827
+ }
828
+ const EN_PLURAL_RULES = new Intl.PluralRules("en-US");
776
829
  function getModifiedLinesString(lines) {
777
- return `${lines} unmodified line${lines > 1 ? "s" : ""}`;
830
+ return `${lines} unmodified line${EN_PLURAL_RULES.select(lines) === "one" ? "" : "s"}`;
778
831
  }
779
832
  function pushUnifiedInjectedRows(rows, context) {
780
833
  for (const row of rows) {
@@ -803,14 +856,14 @@ function pushSplitInjectedRows(rows, context, pendingSplitContext) {
803
856
  context.incrementRowCount(1);
804
857
  }
805
858
  }
806
- function pushLineWithAnnotation({ diffStyle, type, deletionLine, additionLine, unifiedSpan, deletionSpan, additionSpan, createAnnotationElement: createAnnotationElement$1, context }) {
859
+ function pushLineWithAnnotation({ diffStyle, type, deletionLine, additionLine, unifiedSpan, deletionSpan, additionSpan, createAnnotationElement, context }) {
807
860
  let hasAnnotationRow = false;
808
861
  if (diffStyle === "unified") {
809
862
  if (additionLine != null) context.unifiedContentAST.push(additionLine);
810
863
  else if (deletionLine != null) context.unifiedContentAST.push(deletionLine);
811
864
  if (unifiedSpan != null) {
812
865
  const lineType = type === "change" ? deletionLine != null ? "change-deletion" : "change-addition" : type;
813
- context.unifiedContentAST.push(createAnnotationElement$1(unifiedSpan));
866
+ context.unifiedContentAST.push(createAnnotationElement(unifiedSpan));
814
867
  context.pushToGutter("unified", createGutterGap(lineType, "annotation", 1));
815
868
  hasAnnotationRow = true;
816
869
  }
@@ -819,13 +872,13 @@ function pushLineWithAnnotation({ diffStyle, type, deletionLine, additionLine, u
819
872
  if (additionLine != null) context.additionsContentAST.push(additionLine);
820
873
  if (deletionSpan != null) {
821
874
  const lineType = type === "change" ? deletionLine != null ? "change-deletion" : "context" : type;
822
- context.deletionsContentAST.push(createAnnotationElement$1(deletionSpan));
875
+ context.deletionsContentAST.push(createAnnotationElement(deletionSpan));
823
876
  context.pushToGutter("deletions", createGutterGap(lineType, "annotation", 1));
824
877
  hasAnnotationRow = true;
825
878
  }
826
879
  if (additionSpan != null) {
827
880
  const lineType = type === "change" ? additionLine != null ? "change-addition" : "context" : type;
828
- context.additionsContentAST.push(createAnnotationElement$1(additionSpan));
881
+ context.additionsContentAST.push(createAnnotationElement(additionSpan));
829
882
  context.pushToGutter("additions", createGutterGap(lineType, "annotation", 1));
830
883
  hasAnnotationRow = true;
831
884
  }
@@ -943,7 +996,7 @@ function applyLineTextWithNewline(line, lineText) {
943
996
  function isDiffMassive(diff, tokenizeMaxLength) {
944
997
  return Math.max(diff.additionLines.length, diff.deletionLines.length) > tokenizeMaxLength;
945
998
  }
946
-
947
999
  //#endregion
948
1000
  export { DiffHunksRenderer };
1001
+
949
1002
  //# sourceMappingURL=DiffHunksRenderer.js.map