@beyondwork/docx-react-component 1.0.29 → 1.0.31

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 (383) hide show
  1. package/package.json +65 -96
  2. package/src/README.md +85 -0
  3. package/src/api/README.md +26 -0
  4. package/src/api/public-types.ts +1952 -0
  5. package/src/api/session-state.ts +62 -0
  6. package/src/compare/diff-engine.ts +623 -0
  7. package/src/compare/export-redlines.ts +280 -0
  8. package/src/compare/index.ts +25 -0
  9. package/src/compare/snapshot.ts +97 -0
  10. package/src/component-inventory.md +99 -0
  11. package/src/core/README.md +10 -0
  12. package/src/core/commands/README.md +3 -0
  13. package/{dist/chunk-TJBP2K4T.js → src/core/commands/formatting-commands.ts} +536 -196
  14. package/src/core/commands/image-commands.ts +373 -0
  15. package/src/core/commands/index.ts +1879 -0
  16. package/src/core/commands/list-commands.ts +565 -0
  17. package/src/core/commands/paragraph-layout-commands.ts +339 -0
  18. package/src/core/commands/review-commands.ts +108 -0
  19. package/{dist/core/commands/section-layout-commands.cjs → src/core/commands/section-layout-commands.ts} +340 -137
  20. package/src/core/commands/structural-helpers.ts +309 -0
  21. package/{dist/core/commands/style-commands.cjs → src/core/commands/style-commands.ts} +113 -65
  22. package/src/core/commands/table-structure-commands.ts +854 -0
  23. package/{dist/chunk-UZXBISGO.js → src/core/commands/text-commands.ts} +142 -86
  24. package/src/core/schema/README.md +3 -0
  25. package/src/core/schema/text-schema.ts +516 -0
  26. package/src/core/search/search-text.ts +357 -0
  27. package/src/core/selection/README.md +3 -0
  28. package/src/core/selection/mapping.ts +289 -0
  29. package/src/core/selection/review-anchors.ts +183 -0
  30. package/src/core/state/README.md +3 -0
  31. package/src/core/state/editor-state.ts +892 -0
  32. package/src/core/state/text-transaction.ts +869 -0
  33. package/src/formats/xlsx/io/parse-shared-strings.ts +41 -0
  34. package/src/formats/xlsx/io/parse-sheet.ts +459 -0
  35. package/src/formats/xlsx/io/parse-styles.ts +59 -0
  36. package/src/formats/xlsx/io/parse-workbook.ts +75 -0
  37. package/src/formats/xlsx/io/serialize-shared-strings.ts +72 -0
  38. package/src/formats/xlsx/io/serialize-sheet.ts +333 -0
  39. package/src/formats/xlsx/io/serialize-styles.ts +98 -0
  40. package/src/formats/xlsx/io/serialize-workbook.ts +429 -0
  41. package/src/formats/xlsx/io/xlsx-session.ts +314 -0
  42. package/src/formats/xlsx/model/cell.ts +189 -0
  43. package/src/formats/xlsx/model/sheet.ts +326 -0
  44. package/src/formats/xlsx/model/styles.ts +118 -0
  45. package/src/formats/xlsx/model/workbook.ts +453 -0
  46. package/src/formats/xlsx/runtime/cell-commands.ts +567 -0
  47. package/src/formats/xlsx/runtime/sheet-commands.ts +206 -0
  48. package/src/formats/xlsx/runtime/workbook-runtime.ts +177 -0
  49. package/src/formats/xlsx/runtime/workbook-transaction.ts +822 -0
  50. package/src/index.ts +142 -0
  51. package/src/io/README.md +10 -0
  52. package/src/io/docx-session.ts +3175 -0
  53. package/src/io/export/README.md +3 -0
  54. package/src/io/export/export-session.ts +220 -0
  55. package/src/io/export/minimal-docx.ts +115 -0
  56. package/src/io/export/reattach-preserved-parts.ts +54 -0
  57. package/src/io/export/serialize-comments.ts +947 -0
  58. package/src/io/export/serialize-footnotes.ts +394 -0
  59. package/src/io/export/serialize-headers-footers.ts +368 -0
  60. package/src/io/export/serialize-main-document.ts +1342 -0
  61. package/src/io/export/serialize-numbering.ts +218 -0
  62. package/src/io/export/serialize-revisions.ts +389 -0
  63. package/src/io/export/serialize-runtime-revisions.ts +463 -0
  64. package/src/io/export/serialize-tables.ts +174 -0
  65. package/src/io/export/split-review-boundaries.ts +356 -0
  66. package/src/io/export/split-story-blocks-for-runtime-revisions.ts +252 -0
  67. package/src/io/export/table-properties-xml.ts +318 -0
  68. package/src/io/normalize/README.md +3 -0
  69. package/src/io/normalize/normalize-text.ts +670 -0
  70. package/src/io/ooxml/README.md +3 -0
  71. package/src/io/ooxml/highlight-colors.ts +39 -0
  72. package/src/io/ooxml/numbering-sentinels.ts +44 -0
  73. package/src/io/ooxml/parse-comments.ts +852 -0
  74. package/src/io/ooxml/parse-complex-content.ts +287 -0
  75. package/src/io/ooxml/parse-fields.ts +834 -0
  76. package/src/io/ooxml/parse-footnotes.ts +952 -0
  77. package/src/io/ooxml/parse-headers-footers.ts +1212 -0
  78. package/src/io/ooxml/parse-inline-media.ts +461 -0
  79. package/src/io/ooxml/parse-main-document.ts +2947 -0
  80. package/src/io/ooxml/parse-numbering.ts +747 -0
  81. package/src/io/ooxml/parse-revisions.ts +1045 -0
  82. package/src/io/ooxml/parse-settings.ts +184 -0
  83. package/src/io/ooxml/parse-shapes.ts +296 -0
  84. package/src/io/ooxml/parse-styles.ts +639 -0
  85. package/src/io/ooxml/parse-tables.ts +627 -0
  86. package/src/io/ooxml/parse-theme.ts +346 -0
  87. package/src/io/ooxml/part-manifest.ts +136 -0
  88. package/src/io/ooxml/revision-boundaries.ts +475 -0
  89. package/src/io/ooxml/workflow-payload.ts +544 -0
  90. package/src/io/opc/README.md +3 -0
  91. package/src/io/opc/corrupt-package.ts +166 -0
  92. package/src/io/opc/docx-package.ts +74 -0
  93. package/src/io/opc/package-reader.ts +325 -0
  94. package/src/io/opc/package-writer.ts +273 -0
  95. package/src/io/source-package-provenance.ts +241 -0
  96. package/{dist/chunk-RMH72RZI.js → src/legal/bookmarks.ts} +130 -44
  97. package/src/legal/cross-references.ts +414 -0
  98. package/src/legal/defined-terms.ts +203 -0
  99. package/src/legal/index.ts +32 -0
  100. package/src/legal/signature-blocks.ts +259 -0
  101. package/src/model/README.md +3 -0
  102. package/src/model/canonical-document.ts +2722 -0
  103. package/src/model/cds-1.0.0.ts +212 -0
  104. package/src/model/snapshot.ts +760 -0
  105. package/src/preservation/README.md +3 -0
  106. package/src/preservation/markup-compatibility.ts +48 -0
  107. package/src/preservation/opaque-fragment-store.ts +89 -0
  108. package/src/preservation/opaque-region.ts +233 -0
  109. package/src/preservation/package-preservation.ts +113 -0
  110. package/src/preservation/preserved-part-manifest.ts +56 -0
  111. package/src/preservation/relationship-retention.ts +57 -0
  112. package/src/preservation/store.ts +255 -0
  113. package/src/review/README.md +16 -0
  114. package/src/review/store/README.md +3 -0
  115. package/src/review/store/comment-anchors.ts +70 -0
  116. package/src/review/store/comment-remapping.ts +154 -0
  117. package/src/review/store/comment-store.ts +349 -0
  118. package/src/review/store/comment-thread.ts +109 -0
  119. package/src/review/store/revision-actions.ts +423 -0
  120. package/src/review/store/revision-store.ts +323 -0
  121. package/src/review/store/revision-types.ts +182 -0
  122. package/src/review/store/runtime-comment-store.ts +43 -0
  123. package/src/runtime/README.md +3 -0
  124. package/src/runtime/ai-action-policy.ts +764 -0
  125. package/src/runtime/context-analytics.ts +824 -0
  126. package/src/runtime/document-layout.ts +332 -0
  127. package/src/runtime/document-locations.ts +521 -0
  128. package/src/runtime/document-navigation.ts +616 -0
  129. package/src/runtime/document-outline.ts +440 -0
  130. package/src/runtime/document-runtime.ts +4055 -0
  131. package/src/runtime/document-search.ts +145 -0
  132. package/src/runtime/event-refresh-hints.ts +137 -0
  133. package/src/runtime/numbering-prefix.ts +244 -0
  134. package/src/runtime/page-layout-estimation.ts +305 -0
  135. package/src/runtime/read-only-diagnostics-runtime.ts +241 -0
  136. package/src/runtime/resolved-numbering-geometry.ts +293 -0
  137. package/src/runtime/review-runtime.ts +44 -0
  138. package/src/runtime/revision-runtime.ts +107 -0
  139. package/src/runtime/session-capabilities.ts +192 -0
  140. package/src/runtime/story-context.ts +164 -0
  141. package/src/runtime/story-targeting.ts +162 -0
  142. package/src/runtime/suggestions-snapshot.ts +137 -0
  143. package/src/runtime/surface-projection.ts +1553 -0
  144. package/src/runtime/table-commands.ts +173 -0
  145. package/src/runtime/table-schema.ts +309 -0
  146. package/src/runtime/table-style-resolver.ts +409 -0
  147. package/src/runtime/view-state.ts +493 -0
  148. package/src/runtime/virtualized-rendering.ts +258 -0
  149. package/src/runtime/workflow-markup.ts +393 -0
  150. package/src/ui/README.md +30 -0
  151. package/src/ui/WordReviewEditor.tsx +5268 -0
  152. package/src/ui/browser-export.ts +52 -0
  153. package/src/ui/comments/README.md +3 -0
  154. package/src/ui/compatibility/README.md +3 -0
  155. package/src/ui/editor-command-bag.ts +127 -0
  156. package/src/ui/editor-runtime-boundary.ts +1558 -0
  157. package/src/ui/editor-shell-view.tsx +144 -0
  158. package/src/ui/editor-surface/README.md +3 -0
  159. package/src/ui/editor-surface-controller.tsx +66 -0
  160. package/src/ui/headless/comment-decoration-model.ts +124 -0
  161. package/src/ui/headless/preserve-editor-selection.ts +5 -0
  162. package/src/ui/headless/revision-decoration-model.ts +128 -0
  163. package/src/ui/headless/selection-helpers.ts +54 -0
  164. package/src/ui/headless/selection-tool-context.ts +19 -0
  165. package/src/ui/headless/selection-tool-resolver.ts +752 -0
  166. package/src/ui/headless/selection-tool-types.ts +129 -0
  167. package/src/ui/headless/selection-toolbar-model.ts +11 -0
  168. package/src/ui/headless/use-editor-keyboard.ts +103 -0
  169. package/src/ui/review/README.md +3 -0
  170. package/src/ui/runtime-shortcut-dispatch.ts +365 -0
  171. package/src/ui/runtime-snapshot-selectors.ts +197 -0
  172. package/src/ui/shared/revision-filters.ts +31 -0
  173. package/src/ui/status/README.md +3 -0
  174. package/src/ui/theme/README.md +3 -0
  175. package/src/ui/toolbar/README.md +3 -0
  176. package/src/ui/workflow-surface-blocked-rails.ts +94 -0
  177. package/src/ui-tailwind/chrome/chrome-preset-model.ts +107 -0
  178. package/src/ui-tailwind/chrome/chrome-preset-toolbar.tsx +15 -0
  179. package/src/ui-tailwind/chrome/responsive-chrome.ts +46 -0
  180. package/src/ui-tailwind/chrome/review-queue-bar.tsx +97 -0
  181. package/src/ui-tailwind/chrome/tw-alert-banner.tsx +64 -0
  182. package/src/ui-tailwind/chrome/tw-context-analytics-summary.tsx +122 -0
  183. package/src/ui-tailwind/chrome/tw-image-context-toolbar.tsx +121 -0
  184. package/src/ui-tailwind/chrome/tw-layout-panel.tsx +114 -0
  185. package/src/ui-tailwind/chrome/tw-object-context-toolbar.tsx +30 -0
  186. package/src/ui-tailwind/chrome/tw-page-ruler.tsx +365 -0
  187. package/src/ui-tailwind/chrome/tw-selection-tool-blocked.tsx +23 -0
  188. package/src/ui-tailwind/chrome/tw-selection-tool-comment.tsx +35 -0
  189. package/src/ui-tailwind/chrome/tw-selection-tool-formatting.tsx +37 -0
  190. package/src/ui-tailwind/chrome/tw-selection-tool-host.tsx +303 -0
  191. package/src/ui-tailwind/chrome/tw-selection-tool-structure.tsx +116 -0
  192. package/src/ui-tailwind/chrome/tw-selection-tool-suggestion.tsx +29 -0
  193. package/src/ui-tailwind/chrome/tw-selection-tool-workflow.tsx +27 -0
  194. package/src/ui-tailwind/chrome/tw-selection-toolbar.tsx +186 -0
  195. package/src/ui-tailwind/chrome/tw-suggestion-card.tsx +139 -0
  196. package/src/ui-tailwind/chrome/tw-table-context-toolbar.tsx +250 -0
  197. package/src/ui-tailwind/chrome/tw-unsaved-modal.tsx +58 -0
  198. package/src/ui-tailwind/chrome/use-before-unload.ts +20 -0
  199. package/src/ui-tailwind/editor-surface/perf-probe.ts +179 -0
  200. package/src/ui-tailwind/editor-surface/pm-command-bridge.ts +189 -0
  201. package/src/ui-tailwind/editor-surface/pm-contextual-ui.ts +31 -0
  202. package/src/ui-tailwind/editor-surface/pm-decorations.ts +411 -0
  203. package/src/ui-tailwind/editor-surface/pm-position-map.ts +123 -0
  204. package/src/ui-tailwind/editor-surface/pm-schema.ts +927 -0
  205. package/src/ui-tailwind/editor-surface/pm-state-from-snapshot.ts +567 -0
  206. package/src/ui-tailwind/editor-surface/search-plugin.ts +168 -0
  207. package/src/ui-tailwind/editor-surface/surface-build-keys.ts +63 -0
  208. package/src/ui-tailwind/editor-surface/tw-caret.tsx +12 -0
  209. package/src/ui-tailwind/editor-surface/tw-editor-surface.tsx +150 -0
  210. package/src/ui-tailwind/editor-surface/tw-inline-token.tsx +129 -0
  211. package/src/ui-tailwind/editor-surface/tw-opaque-block.tsx +58 -0
  212. package/src/ui-tailwind/editor-surface/tw-paragraph-block.tsx +151 -0
  213. package/src/ui-tailwind/editor-surface/tw-prosemirror-surface.tsx +1047 -0
  214. package/src/ui-tailwind/editor-surface/tw-segment-view.tsx +111 -0
  215. package/src/ui-tailwind/editor-surface/tw-table-node-view.tsx +503 -0
  216. package/src/ui-tailwind/index.ts +62 -0
  217. package/src/ui-tailwind/page-chrome-model.ts +27 -0
  218. package/src/ui-tailwind/review/tw-comment-sidebar.tsx +406 -0
  219. package/src/ui-tailwind/review/tw-health-panel.tsx +149 -0
  220. package/src/ui-tailwind/review/tw-review-rail.tsx +130 -0
  221. package/src/ui-tailwind/review/tw-revision-sidebar.tsx +164 -0
  222. package/src/ui-tailwind/status/tw-status-bar.tsx +65 -0
  223. package/{dist → src}/ui-tailwind/theme/editor-theme.css +58 -40
  224. package/src/ui-tailwind/toolbar/toolbar-layout.ts +47 -0
  225. package/src/ui-tailwind/toolbar/tw-toolbar-icon-button.tsx +52 -0
  226. package/src/ui-tailwind/toolbar/tw-toolbar.tsx +1478 -0
  227. package/src/ui-tailwind/tw-review-workspace.tsx +1587 -0
  228. package/src/validation/README.md +3 -0
  229. package/src/validation/compatibility-engine.ts +878 -0
  230. package/src/validation/compatibility-report.ts +161 -0
  231. package/src/validation/diagnostics.ts +204 -0
  232. package/src/validation/docx-comment-proof.ts +720 -0
  233. package/src/validation/import-diagnostics.ts +128 -0
  234. package/src/validation/low-priority-word-surfaces.ts +373 -0
  235. package/dist/canonical-document-BLEbzL2J.d.cts +0 -844
  236. package/dist/canonical-document-BLEbzL2J.d.ts +0 -844
  237. package/dist/chunk-2FJS5GZM.js +0 -763
  238. package/dist/chunk-2FJS5GZM.js.map +0 -1
  239. package/dist/chunk-2OQBZS3F.js +0 -446
  240. package/dist/chunk-2OQBZS3F.js.map +0 -1
  241. package/dist/chunk-2S7W4KFO.js +0 -127
  242. package/dist/chunk-2S7W4KFO.js.map +0 -1
  243. package/dist/chunk-2TG72QSW.js +0 -3874
  244. package/dist/chunk-2TG72QSW.js.map +0 -1
  245. package/dist/chunk-36QNIZBO.js +0 -532
  246. package/dist/chunk-36QNIZBO.js.map +0 -1
  247. package/dist/chunk-4AQOYAW4.js +0 -3069
  248. package/dist/chunk-4AQOYAW4.js.map +0 -1
  249. package/dist/chunk-4D5EWJ3P.js +0 -77
  250. package/dist/chunk-4D5EWJ3P.js.map +0 -1
  251. package/dist/chunk-5FN54NDH.js +0 -2257
  252. package/dist/chunk-5FN54NDH.js.map +0 -1
  253. package/dist/chunk-BOYGQYRQ.js +0 -7306
  254. package/dist/chunk-BOYGQYRQ.js.map +0 -1
  255. package/dist/chunk-CN3XMECL.js +0 -212
  256. package/dist/chunk-CN3XMECL.js.map +0 -1
  257. package/dist/chunk-EBI3BX6U.js +0 -164
  258. package/dist/chunk-EBI3BX6U.js.map +0 -1
  259. package/dist/chunk-EILUG3VB.js +0 -1275
  260. package/dist/chunk-EILUG3VB.js.map +0 -1
  261. package/dist/chunk-FUDY333O.js +0 -70
  262. package/dist/chunk-FUDY333O.js.map +0 -1
  263. package/dist/chunk-GBVOWFIK.js +0 -1237
  264. package/dist/chunk-GBVOWFIK.js.map +0 -1
  265. package/dist/chunk-H4TQ3H3Y.js +0 -262
  266. package/dist/chunk-H4TQ3H3Y.js.map +0 -1
  267. package/dist/chunk-JGB3IXZO.js +0 -189
  268. package/dist/chunk-JGB3IXZO.js.map +0 -1
  269. package/dist/chunk-KD2QRQPY.js +0 -4342
  270. package/dist/chunk-KD2QRQPY.js.map +0 -1
  271. package/dist/chunk-KLMXQVYK.js +0 -369
  272. package/dist/chunk-KLMXQVYK.js.map +0 -1
  273. package/dist/chunk-KZUG5KFQ.js +0 -214
  274. package/dist/chunk-KZUG5KFQ.js.map +0 -1
  275. package/dist/chunk-QDAQ4CJU.js +0 -345
  276. package/dist/chunk-QDAQ4CJU.js.map +0 -1
  277. package/dist/chunk-RMH72RZI.js.map +0 -1
  278. package/dist/chunk-SWKWQZXM.js +0 -117
  279. package/dist/chunk-SWKWQZXM.js.map +0 -1
  280. package/dist/chunk-TJBP2K4T.js.map +0 -1
  281. package/dist/chunk-TLCEAQDQ.js +0 -542
  282. package/dist/chunk-TLCEAQDQ.js.map +0 -1
  283. package/dist/chunk-UZXBISGO.js.map +0 -1
  284. package/dist/chunk-WGBAKP3Q.js +0 -3220
  285. package/dist/chunk-WGBAKP3Q.js.map +0 -1
  286. package/dist/compare/index.cjs +0 -5475
  287. package/dist/compare/index.cjs.map +0 -1
  288. package/dist/compare/index.d.cts +0 -114
  289. package/dist/compare/index.d.ts +0 -114
  290. package/dist/compare/index.js +0 -731
  291. package/dist/compare/index.js.map +0 -1
  292. package/dist/core/commands/formatting-commands.cjs +0 -828
  293. package/dist/core/commands/formatting-commands.cjs.map +0 -1
  294. package/dist/core/commands/formatting-commands.d.cts +0 -63
  295. package/dist/core/commands/formatting-commands.d.ts +0 -63
  296. package/dist/core/commands/formatting-commands.js +0 -37
  297. package/dist/core/commands/formatting-commands.js.map +0 -1
  298. package/dist/core/commands/image-commands.cjs +0 -2023
  299. package/dist/core/commands/image-commands.cjs.map +0 -1
  300. package/dist/core/commands/image-commands.d.cts +0 -58
  301. package/dist/core/commands/image-commands.d.ts +0 -58
  302. package/dist/core/commands/image-commands.js +0 -18
  303. package/dist/core/commands/image-commands.js.map +0 -1
  304. package/dist/core/commands/section-layout-commands.cjs.map +0 -1
  305. package/dist/core/commands/section-layout-commands.d.cts +0 -62
  306. package/dist/core/commands/section-layout-commands.d.ts +0 -62
  307. package/dist/core/commands/section-layout-commands.js +0 -21
  308. package/dist/core/commands/section-layout-commands.js.map +0 -1
  309. package/dist/core/commands/style-commands.cjs.map +0 -1
  310. package/dist/core/commands/style-commands.d.cts +0 -13
  311. package/dist/core/commands/style-commands.d.ts +0 -13
  312. package/dist/core/commands/style-commands.js +0 -9
  313. package/dist/core/commands/style-commands.js.map +0 -1
  314. package/dist/core/commands/table-structure-commands.cjs +0 -1883
  315. package/dist/core/commands/table-structure-commands.cjs.map +0 -1
  316. package/dist/core/commands/table-structure-commands.d.cts +0 -59
  317. package/dist/core/commands/table-structure-commands.d.ts +0 -59
  318. package/dist/core/commands/table-structure-commands.js +0 -12
  319. package/dist/core/commands/table-structure-commands.js.map +0 -1
  320. package/dist/core/commands/text-commands.cjs +0 -2391
  321. package/dist/core/commands/text-commands.cjs.map +0 -1
  322. package/dist/core/commands/text-commands.d.cts +0 -24
  323. package/dist/core/commands/text-commands.d.ts +0 -24
  324. package/dist/core/commands/text-commands.js +0 -28
  325. package/dist/core/commands/text-commands.js.map +0 -1
  326. package/dist/core/selection/mapping.cjs +0 -200
  327. package/dist/core/selection/mapping.cjs.map +0 -1
  328. package/dist/core/selection/mapping.d.cts +0 -2
  329. package/dist/core/selection/mapping.d.ts +0 -2
  330. package/dist/core/selection/mapping.js +0 -31
  331. package/dist/core/selection/mapping.js.map +0 -1
  332. package/dist/core/state/editor-state.cjs +0 -2278
  333. package/dist/core/state/editor-state.cjs.map +0 -1
  334. package/dist/core/state/editor-state.d.cts +0 -2
  335. package/dist/core/state/editor-state.d.ts +0 -2
  336. package/dist/core/state/editor-state.js +0 -26
  337. package/dist/core/state/editor-state.js.map +0 -1
  338. package/dist/index.cjs +0 -38553
  339. package/dist/index.cjs.map +0 -1
  340. package/dist/index.d.cts +0 -15
  341. package/dist/index.d.ts +0 -15
  342. package/dist/index.js +0 -7856
  343. package/dist/index.js.map +0 -1
  344. package/dist/io/docx-session.cjs +0 -16236
  345. package/dist/io/docx-session.cjs.map +0 -1
  346. package/dist/io/docx-session.d.cts +0 -21
  347. package/dist/io/docx-session.d.ts +0 -21
  348. package/dist/io/docx-session.js +0 -18
  349. package/dist/io/docx-session.js.map +0 -1
  350. package/dist/legal/index.cjs +0 -3900
  351. package/dist/legal/index.cjs.map +0 -1
  352. package/dist/legal/index.d.cts +0 -86
  353. package/dist/legal/index.d.ts +0 -86
  354. package/dist/legal/index.js +0 -616
  355. package/dist/legal/index.js.map +0 -1
  356. package/dist/public-types-7ZL_94cz.d.ts +0 -1573
  357. package/dist/public-types-CeMaDueh.d.cts +0 -1573
  358. package/dist/public-types.cjs +0 -19
  359. package/dist/public-types.cjs.map +0 -1
  360. package/dist/public-types.d.cts +0 -2
  361. package/dist/public-types.d.ts +0 -2
  362. package/dist/public-types.js +0 -1
  363. package/dist/public-types.js.map +0 -1
  364. package/dist/runtime/document-runtime.cjs +0 -11140
  365. package/dist/runtime/document-runtime.cjs.map +0 -1
  366. package/dist/runtime/document-runtime.d.cts +0 -231
  367. package/dist/runtime/document-runtime.d.ts +0 -231
  368. package/dist/runtime/document-runtime.js +0 -21
  369. package/dist/runtime/document-runtime.js.map +0 -1
  370. package/dist/structural-helpers-CilgOVhh.d.cts +0 -10
  371. package/dist/structural-helpers-q0Gd-eBN.d.ts +0 -10
  372. package/dist/ui-tailwind/editor-surface/search-plugin.cjs +0 -313
  373. package/dist/ui-tailwind/editor-surface/search-plugin.cjs.map +0 -1
  374. package/dist/ui-tailwind/editor-surface/search-plugin.d.cts +0 -67
  375. package/dist/ui-tailwind/editor-surface/search-plugin.d.ts +0 -67
  376. package/dist/ui-tailwind/editor-surface/search-plugin.js +0 -23
  377. package/dist/ui-tailwind/editor-surface/search-plugin.js.map +0 -1
  378. package/dist/ui-tailwind/index.cjs +0 -4833
  379. package/dist/ui-tailwind/index.cjs.map +0 -1
  380. package/dist/ui-tailwind/index.d.cts +0 -617
  381. package/dist/ui-tailwind/index.d.ts +0 -617
  382. package/dist/ui-tailwind/index.js +0 -575
  383. package/dist/ui-tailwind/index.js.map +0 -1
@@ -1,575 +0,0 @@
1
- import {
2
- TwAlertBanner,
3
- TwCommentSidebar,
4
- TwHealthPanel,
5
- TwReviewRail,
6
- TwReviewWorkspace,
7
- TwRevisionSidebar,
8
- TwSelectionToolbar,
9
- TwStatusBar,
10
- TwToolbar,
11
- TwToolbarIconButton,
12
- createCommentDecorationModel,
13
- createRevisionDecorationModel,
14
- createSelectionSnapshot,
15
- deriveCapabilities,
16
- getCommentHighlightClass,
17
- getCommentRangeState,
18
- getRevisionHighlightClass,
19
- getRevisionRangeState,
20
- selectionTouchesRange,
21
- shouldHideInCleanMode
22
- } from "../chunk-2TG72QSW.js";
23
- import "../chunk-GBVOWFIK.js";
24
- import "../chunk-KLMXQVYK.js";
25
- import "../chunk-EILUG3VB.js";
26
- import "../chunk-SWKWQZXM.js";
27
- import "../chunk-5FN54NDH.js";
28
- import "../chunk-EBI3BX6U.js";
29
-
30
- // src/ui-tailwind/editor-surface/tw-editor-surface.tsx
31
- import { useMemo } from "react";
32
-
33
- // src/ui/headless/use-editor-keyboard.ts
34
- function createEditorKeyboardHandler(context, callbacks) {
35
- return function handleKeyDown(event) {
36
- const { selection, storySize, canEdit } = context;
37
- if (event.key === "ArrowLeft") {
38
- event.preventDefault();
39
- moveSelection(selection.anchor, selection.head - 1, event.shiftKey, storySize, callbacks);
40
- return;
41
- }
42
- if (event.key === "ArrowRight") {
43
- event.preventDefault();
44
- moveSelection(selection.anchor, selection.head + 1, event.shiftKey, storySize, callbacks);
45
- return;
46
- }
47
- if (event.key === "Home") {
48
- event.preventDefault();
49
- moveSelection(selection.anchor, 0, event.shiftKey, storySize, callbacks);
50
- return;
51
- }
52
- if (event.key === "End") {
53
- event.preventDefault();
54
- moveSelection(selection.anchor, storySize, event.shiftKey, storySize, callbacks);
55
- return;
56
- }
57
- if (!canEdit || event.metaKey || event.ctrlKey || event.altKey) {
58
- return;
59
- }
60
- switch (event.key) {
61
- case "Backspace":
62
- event.preventDefault();
63
- callbacks.onDeleteBackward?.();
64
- return;
65
- case "Delete":
66
- event.preventDefault();
67
- callbacks.onDeleteForward?.();
68
- return;
69
- case "Tab":
70
- event.preventDefault();
71
- if (event.shiftKey) {
72
- callbacks.onOutdentTab?.();
73
- } else {
74
- callbacks.onInsertTab?.();
75
- }
76
- return;
77
- case "Enter":
78
- event.preventDefault();
79
- if (event.shiftKey) {
80
- callbacks.onInsertHardBreak?.();
81
- } else {
82
- callbacks.onSplitParagraph?.();
83
- }
84
- return;
85
- default:
86
- if (event.key.length === 1) {
87
- event.preventDefault();
88
- callbacks.onInsertText?.(event.key);
89
- }
90
- }
91
- };
92
- }
93
- function moveSelection(anchor, nextHead, extend, storySize, callbacks) {
94
- const clampedHead = Math.max(0, Math.min(storySize, nextHead));
95
- callbacks.onSelectionChange?.(
96
- createSelectionSnapshot(extend ? anchor : clampedHead, clampedHead)
97
- );
98
- }
99
-
100
- // src/ui-tailwind/editor-surface/tw-opaque-block.tsx
101
- import { jsx, jsxs } from "react/jsx-runtime";
102
- var focusRingClass = "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent focus-visible:ring-offset-2 focus-visible:ring-offset-canvas";
103
- function TwOpaqueBlock(props) {
104
- const { block, selection, workflowTargeted } = props;
105
- const selected = selectionTouchesRange(selection, block.from, block.to);
106
- return /* @__PURE__ */ jsxs("div", { className: "group relative", children: [
107
- /* @__PURE__ */ jsx("div", { className: "absolute -left-10 top-1 flex flex-col items-end gap-0 select-none w-8 text-right", children: /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-0.5", children: [
108
- /* @__PURE__ */ jsx("span", { className: "text-[10px] text-tertiary/60 font-medium", children: "Lock" }),
109
- /* @__PURE__ */ jsx("span", { className: "inline-block h-1 w-1 rounded-full", style: { backgroundColor: "var(--color-comment)" } })
110
- ] }) }),
111
- /* @__PURE__ */ jsxs(
112
- "button",
113
- {
114
- type: "button",
115
- tabIndex: -1,
116
- onMouseDown: (e) => {
117
- e.preventDefault();
118
- props.onSelectionChange?.(createSelectionSnapshot(block.from, block.to));
119
- },
120
- className: [
121
- "w-full text-left border-l-2 border-dashed border-warning/30 pl-4 py-2 rounded-r bg-warning-soft/20",
122
- "cursor-pointer transition-colors",
123
- selected ? "ring-1 ring-accent/30 bg-warning-soft/40" : "hover:bg-warning-soft/30",
124
- focusRingClass
125
- ].join(" "),
126
- children: [
127
- /* @__PURE__ */ jsxs("div", { className: "flex items-center gap-1.5 text-xs text-tertiary mb-1", children: [
128
- /* @__PURE__ */ jsx("span", { children: "\u{1F512}" }),
129
- /* @__PURE__ */ jsx("span", { children: block.label }),
130
- /* @__PURE__ */ jsx("span", { className: "inline-flex items-center px-1.5 py-0.5 rounded-full text-[10px] font-semibold text-comment bg-warning-soft", children: "preserve-only" }),
131
- workflowTargeted && /* @__PURE__ */ jsx("span", { className: "inline-flex items-center px-1.5 py-0.5 rounded-full text-[10px] font-semibold text-amber-700 bg-amber-100", children: "workflow-targeted" })
132
- ] }),
133
- /* @__PURE__ */ jsx("p", { className: "text-sm text-secondary", children: block.detail })
134
- ]
135
- }
136
- )
137
- ] });
138
- }
139
-
140
- // src/ui-tailwind/editor-surface/tw-caret.tsx
141
- import { jsx as jsx2 } from "react/jsx-runtime";
142
- function renderTwCaret(selection, position) {
143
- return selection.isCollapsed && selection.anchor === position ? /* @__PURE__ */ jsx2(
144
- "span",
145
- {
146
- "aria-hidden": "true",
147
- className: "inline-block w-0.5 h-[1.2em] bg-accent rounded-full align-middle animate-wre-blink"
148
- }
149
- ) : null;
150
- }
151
-
152
- // src/ui-tailwind/editor-surface/tw-inline-token.tsx
153
- import { Fragment, jsx as jsx3, jsxs as jsxs2 } from "react/jsx-runtime";
154
- var focusRingClass2 = "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent focus-visible:ring-offset-2 focus-visible:ring-offset-canvas";
155
- function TwInlineToken(props) {
156
- const { segment, selection } = props;
157
- const selected = selectionTouchesRange(selection, segment.from, segment.to);
158
- const commentClass = getCommentHighlightClass(
159
- props.commentDecorations,
160
- segment.from,
161
- segment.to,
162
- props.markupDisplay
163
- );
164
- const showSymbols = props.markupDisplay !== "clean";
165
- if (segment.kind === "tab") {
166
- return /* @__PURE__ */ jsxs2(
167
- "button",
168
- {
169
- type: "button",
170
- tabIndex: -1,
171
- onMouseDown: (e) => {
172
- e.preventDefault();
173
- props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));
174
- },
175
- className: `inline-flex items-center border-none bg-transparent cursor-text ${commentClass} ${selected ? "bg-surface-hover" : ""} ${focusRingClass2} ${showSymbols ? "mx-0.5 text-tertiary/50" : "w-8"}`,
176
- title: "Tab character",
177
- children: [
178
- renderTwCaret(selection, segment.from),
179
- showSymbols ? /* @__PURE__ */ jsx3("span", { className: "text-xs", children: "\u2192" }) : /* @__PURE__ */ jsx3("span", { className: "w-8" }),
180
- renderTwCaret(selection, segment.to)
181
- ]
182
- }
183
- );
184
- }
185
- if (segment.kind === "hard_break") {
186
- return /* @__PURE__ */ jsxs2(Fragment, { children: [
187
- /* @__PURE__ */ jsxs2(
188
- "button",
189
- {
190
- type: "button",
191
- tabIndex: -1,
192
- onMouseDown: (e) => {
193
- e.preventDefault();
194
- props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));
195
- },
196
- className: `inline-flex items-center border-none bg-transparent cursor-text ${commentClass} ${selected ? "bg-surface-hover" : ""} ${focusRingClass2} ${showSymbols ? "mx-0.5 text-tertiary/40" : ""}`,
197
- title: "Line break",
198
- children: [
199
- renderTwCaret(selection, segment.from),
200
- showSymbols ? /* @__PURE__ */ jsx3("span", { className: "text-xs", children: "\u21B5" }) : null,
201
- renderTwCaret(selection, segment.to)
202
- ]
203
- }
204
- ),
205
- /* @__PURE__ */ jsx3("br", {})
206
- ] });
207
- }
208
- if (segment.kind === "image") {
209
- const isMissing = segment.state === "missing";
210
- return /* @__PURE__ */ jsxs2(
211
- "button",
212
- {
213
- type: "button",
214
- tabIndex: -1,
215
- onMouseDown: (e) => {
216
- e.preventDefault();
217
- props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));
218
- },
219
- className: `inline-flex items-center gap-1 mx-0.5 px-1.5 py-0.5 rounded text-xs border-none cursor-pointer ${commentClass} ${isMissing ? "text-danger bg-delete-soft" : "text-secondary bg-surface"} ${selected ? "ring-1 ring-accent/30" : ""} ${focusRingClass2}`,
220
- title: segment.detail ?? segment.altText ?? "Inline image",
221
- children: [
222
- renderTwCaret(selection, segment.from),
223
- /* @__PURE__ */ jsx3("span", { children: "\u{1F4F7}" }),
224
- segment.altText ?? (isMissing ? "Missing image" : "Image"),
225
- renderTwCaret(selection, segment.to)
226
- ]
227
- }
228
- );
229
- }
230
- if (segment.kind === "opaque_inline") {
231
- if (segment.presentation === "quiet-marker") {
232
- return /* @__PURE__ */ jsx3(
233
- "span",
234
- {
235
- "aria-label": segment.label,
236
- title: segment.detail,
237
- className: "inline-block h-0 w-0 overflow-hidden align-baseline",
238
- "data-inline-presentation": "quiet-marker"
239
- }
240
- );
241
- }
242
- return /* @__PURE__ */ jsxs2(
243
- "button",
244
- {
245
- type: "button",
246
- tabIndex: -1,
247
- onMouseDown: (e) => {
248
- e.preventDefault();
249
- props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));
250
- },
251
- className: `inline-flex items-center gap-1 mx-0.5 px-1.5 py-0.5 rounded text-xs text-comment bg-warning-soft border-none cursor-pointer ${commentClass} ${selected ? "ring-1 ring-accent/30" : ""} ${focusRingClass2}`,
252
- title: segment.detail,
253
- children: [
254
- renderTwCaret(selection, segment.from),
255
- /* @__PURE__ */ jsx3("span", { children: "\u{1F512}" }),
256
- segment.label,
257
- renderTwCaret(selection, segment.to)
258
- ]
259
- }
260
- );
261
- }
262
- return null;
263
- }
264
-
265
- // src/ui-tailwind/editor-surface/tw-segment-view.tsx
266
- import { Fragment as Fragment2, jsx as jsx4, jsxs as jsxs3 } from "react/jsx-runtime";
267
- function TwSegmentView(props) {
268
- const { segment, selection, markupDisplay } = props;
269
- if (segment.kind === "tab" || segment.kind === "hard_break" || segment.kind === "image" || segment.kind === "opaque_inline") {
270
- return /* @__PURE__ */ jsx4(
271
- TwInlineToken,
272
- {
273
- segment,
274
- selection,
275
- markupDisplay,
276
- commentDecorations: props.commentDecorations,
277
- onSelectionChange: props.onSelectionChange
278
- }
279
- );
280
- }
281
- if (segment.kind !== "text") {
282
- return null;
283
- }
284
- const characters = Array.from(segment.text);
285
- return /* @__PURE__ */ jsx4(Fragment2, { children: characters.map((character, index) => {
286
- const from = segment.from + index;
287
- const to = from + 1;
288
- const isSelected = selectionTouchesRange(selection, from, to);
289
- if (shouldHideInCleanMode(props.revisionDecorations, from, to) && markupDisplay === "clean") {
290
- return null;
291
- }
292
- const commentClass = getCommentHighlightClass(props.commentDecorations, from, to, markupDisplay);
293
- const revisionClass = getRevisionHighlightClass(props.revisionDecorations, from, to, markupDisplay);
294
- const commentState = getCommentRangeState(props.commentDecorations, from, to);
295
- const overlappingComment = commentState.overlapping[0];
296
- let markClasses = "";
297
- if (segment.marks) {
298
- if (segment.marks.includes("bold")) markClasses += "font-bold ";
299
- if (segment.marks.includes("italic")) markClasses += "italic ";
300
- if (segment.marks.includes("underline")) markClasses += "underline ";
301
- if (segment.marks.includes("strikethrough")) markClasses += "line-through ";
302
- }
303
- const hyperlinkClass = segment.hyperlinkHref ? "text-accent underline decoration-1 underline-offset-2 " : "";
304
- return /* @__PURE__ */ jsxs3(
305
- "button",
306
- {
307
- type: "button",
308
- tabIndex: -1,
309
- onMouseDown: (event) => {
310
- event.preventDefault();
311
- props.onSelectionChange?.(createSelectionSnapshot(to));
312
- if (overlappingComment) {
313
- props.onCommentActivated?.(overlappingComment.commentId);
314
- }
315
- },
316
- "data-comment-id": overlappingComment?.commentId,
317
- className: [
318
- "relative inline border-none bg-transparent cursor-text whitespace-pre p-0 m-0",
319
- "text-[15px] text-primary leading-normal",
320
- commentClass,
321
- revisionClass,
322
- markClasses,
323
- hyperlinkClass,
324
- isSelected ? "bg-surface-hover rounded-[3px]" : ""
325
- ].filter(Boolean).join(" "),
326
- children: [
327
- character,
328
- selection.isCollapsed && selection.anchor === from ? /* @__PURE__ */ jsx4("span", { "aria-hidden": "true", className: "absolute left-0 top-[0.1em] w-0.5 h-[1em] bg-accent rounded-full animate-wre-blink pointer-events-none" }) : null
329
- ]
330
- },
331
- `${segment.segmentId}-${from}`
332
- );
333
- }) });
334
- }
335
-
336
- // src/ui-tailwind/editor-surface/tw-paragraph-block.tsx
337
- import { Fragment as Fragment3, jsx as jsx5, jsxs as jsxs4 } from "react/jsx-runtime";
338
- function TwParagraphBlock(props) {
339
- const { block, selection, markupDisplay } = props;
340
- const headingLevel = inferHeadingLevel(block.styleId);
341
- const hasComment = getCommentRangeState(props.commentDecorations, block.from, block.to).hasComments;
342
- const hasChange = getRevisionRangeState(props.revisionDecorations, block.from, block.to).hasChanges;
343
- let marginClass = "";
344
- if (markupDisplay === "simple" && (hasComment || hasChange)) {
345
- if (hasComment && hasChange) marginClass = "border-l-2 border-l-comment/50 pl-3 ";
346
- else if (hasComment) marginClass = "border-l-2 border-l-comment/40 pl-3 ";
347
- else marginClass = "border-l-2 border-l-insert/40 pl-3 ";
348
- }
349
- const dots = [];
350
- if (markupDisplay === "clean" && hasComment) {
351
- dots.push("var(--color-comment)");
352
- } else if (markupDisplay !== "simple") {
353
- if (hasComment) dots.push("var(--color-comment)");
354
- if (hasChange) dots.push("var(--color-insert)");
355
- }
356
- const segmentElements = /* @__PURE__ */ jsxs4(Fragment3, { children: [
357
- /* @__PURE__ */ jsx5(
358
- CaretButton,
359
- {
360
- position: block.from,
361
- selection,
362
- onSelectionChange: props.onSelectionChange
363
- }
364
- ),
365
- block.segments.length > 0 ? block.segments.map((segment) => /* @__PURE__ */ jsx5(
366
- TwSegmentView,
367
- {
368
- segment,
369
- selection,
370
- markupDisplay,
371
- commentDecorations: props.commentDecorations,
372
- revisionDecorations: props.revisionDecorations,
373
- onSelectionChange: props.onSelectionChange,
374
- onCommentActivated: props.onCommentActivated,
375
- onRevisionActivated: props.onRevisionActivated
376
- },
377
- segment.segmentId
378
- )) : /* @__PURE__ */ jsx5("span", { className: "text-secondary italic", children: "Empty paragraph" }),
379
- /* @__PURE__ */ jsx5(
380
- CaretButton,
381
- {
382
- position: block.to,
383
- selection,
384
- onSelectionChange: props.onSelectionChange
385
- }
386
- )
387
- ] });
388
- return /* @__PURE__ */ jsxs4("div", { className: "group relative", children: [
389
- /* @__PURE__ */ jsx5(
390
- BlockHint,
391
- {
392
- label: headingLevel ? `H${headingLevel}` : "P",
393
- dots: dots.length > 0 ? dots : void 0
394
- }
395
- ),
396
- headingLevel ? /* @__PURE__ */ jsx5("div", { className: `${marginClass}transition-colors`, children: /* @__PURE__ */ jsx5(HeadingElement, { level: headingLevel, children: segmentElements }) }) : /* @__PURE__ */ jsx5("p", { className: `text-base leading-[1.75] text-primary ${marginClass}transition-colors`, children: segmentElements })
397
- ] });
398
- }
399
- function CaretButton(props) {
400
- const isActive = props.selection.isCollapsed && props.selection.anchor === props.position;
401
- return /* @__PURE__ */ jsx5(
402
- "button",
403
- {
404
- type: "button",
405
- tabIndex: -1,
406
- onMouseDown: (e) => {
407
- e.preventDefault();
408
- props.onSelectionChange?.(createSelectionSnapshot(props.position));
409
- },
410
- "aria-label": `Set caret at ${props.position}`,
411
- className: `p-0 m-0 border-none bg-transparent cursor-text inline-flex items-center ${isActive ? "min-w-[2px] h-[22px]" : "w-0 h-0 overflow-hidden"}`,
412
- children: renderTwCaret(props.selection, props.position)
413
- }
414
- );
415
- }
416
- function BlockHint(props) {
417
- return /* @__PURE__ */ jsx5("div", { className: "absolute -left-10 top-1 flex flex-col items-end gap-0 select-none w-8 text-right", children: /* @__PURE__ */ jsxs4("div", { className: "flex items-center gap-0.5", children: [
418
- /* @__PURE__ */ jsx5("span", { className: "text-[10px] text-tertiary/60 font-medium", children: props.label }),
419
- props.dots?.map((color, i) => /* @__PURE__ */ jsx5(
420
- "span",
421
- {
422
- className: "inline-block h-1 w-1 rounded-full",
423
- style: { backgroundColor: color }
424
- },
425
- i
426
- ))
427
- ] }) });
428
- }
429
- function HeadingElement(props) {
430
- switch (props.level) {
431
- case 1:
432
- return /* @__PURE__ */ jsx5("h2", { className: "text-2xl font-medium text-primary leading-tight", children: props.children });
433
- case 2:
434
- return /* @__PURE__ */ jsx5("h3", { className: "text-xl font-medium text-primary leading-snug", children: props.children });
435
- case 3:
436
- return /* @__PURE__ */ jsx5("h4", { className: "text-lg font-medium text-primary leading-snug", children: props.children });
437
- }
438
- }
439
- function inferHeadingLevel(styleId) {
440
- if (!styleId) return null;
441
- const lower = styleId.toLowerCase();
442
- if (lower === "heading1") return 1;
443
- if (lower === "heading2") return 2;
444
- if (lower === "heading3") return 3;
445
- return null;
446
- }
447
-
448
- // src/ui-tailwind/editor-surface/tw-editor-surface.tsx
449
- import { jsx as jsx6, jsxs as jsxs5 } from "react/jsx-runtime";
450
- function TwEditorSurface(props) {
451
- const { currentUser, markupDisplay, onBlur, onFocus, snapshot } = props;
452
- const surface = snapshot.surface;
453
- const canEdit = Boolean(
454
- surface && snapshot.isReady && !snapshot.readOnly && !snapshot.fatalError
455
- );
456
- const commentDecorations = useMemo(
457
- () => createCommentDecorationModel(snapshot.comments),
458
- [snapshot.comments]
459
- );
460
- const showTrackedChanges = props.showTrackedChanges !== false;
461
- const revisionDecorations = useMemo(
462
- () => showTrackedChanges ? createRevisionDecorationModel(snapshot.trackedChanges, props.activeRevisionId) : void 0,
463
- [snapshot.trackedChanges, props.activeRevisionId, showTrackedChanges]
464
- );
465
- const handleKeyDown = useMemo(() => {
466
- if (!surface) return void 0;
467
- return createEditorKeyboardHandler(
468
- {
469
- selection: snapshot.selection,
470
- storySize: surface.storySize,
471
- canEdit
472
- },
473
- {
474
- onSelectionChange: props.onSelectionChange,
475
- onInsertText: props.onInsertText,
476
- onDeleteBackward: props.onDeleteBackward,
477
- onDeleteForward: props.onDeleteForward,
478
- onInsertTab: props.onInsertTab,
479
- onInsertHardBreak: props.onInsertHardBreak,
480
- onSplitParagraph: props.onSplitParagraph
481
- }
482
- );
483
- }, [surface, snapshot.selection, canEdit, props]);
484
- const fontClass = markupDisplay === "clean" ? "font-[family-name:var(--font-legal-sans)]" : "font-[family-name:var(--font-legal-serif)]";
485
- return /* @__PURE__ */ jsx6("section", { "aria-label": "Document canvas", className: "min-w-0", children: /* @__PURE__ */ jsxs5(
486
- "div",
487
- {
488
- "aria-label": "Document surface",
489
- "aria-multiline": "true",
490
- role: "textbox",
491
- tabIndex: 0,
492
- onFocus,
493
- onBlur,
494
- onKeyDown: handleKeyDown,
495
- className: `bg-transparent border-none px-12 py-10 outline-offset-1 ${fontClass}`,
496
- children: [
497
- /* @__PURE__ */ jsxs5("div", { className: "flex justify-between gap-4 items-start mb-5", children: [
498
- /* @__PURE__ */ jsxs5("div", { children: [
499
- /* @__PURE__ */ jsx6("h1", { className: "font-[family-name:var(--font-legal-serif)] text-2xl leading-tight text-primary", children: snapshot.sourceLabel ?? "Document draft" }),
500
- /* @__PURE__ */ jsxs5("p", { className: "text-xs text-secondary mt-2", children: [
501
- snapshot.sessionId,
502
- " \xB7 ",
503
- snapshot.documentStats.storyLength,
504
- " chars"
505
- ] })
506
- ] }),
507
- /* @__PURE__ */ jsxs5("span", { className: "text-xs text-secondary whitespace-nowrap", children: [
508
- "Reviewer ",
509
- currentUser.displayName
510
- ] })
511
- ] }),
512
- /* @__PURE__ */ jsxs5("div", { className: "space-y-4 pl-10 relative", children: [
513
- surface ? surface.blocks.map(
514
- (block) => block.kind === "paragraph" ? /* @__PURE__ */ jsx6(
515
- TwParagraphBlock,
516
- {
517
- block,
518
- selection: snapshot.selection,
519
- markupDisplay,
520
- commentDecorations,
521
- revisionDecorations,
522
- onSelectionChange: props.onSelectionChange,
523
- onCommentActivated: props.onCommentActivated,
524
- onRevisionActivated: props.onRevisionActivated
525
- },
526
- block.blockId
527
- ) : block.kind === "opaque_block" ? /* @__PURE__ */ jsx6(
528
- TwOpaqueBlock,
529
- {
530
- block,
531
- selection: snapshot.selection,
532
- onSelectionChange: props.onSelectionChange
533
- },
534
- block.blockId
535
- ) : null
536
- ) : /* @__PURE__ */ jsx6("p", { className: "text-sm text-secondary leading-relaxed", children: "Loading the review surface. Compatibility cues and edit actions appear here once the runtime snapshot is ready." }),
537
- snapshot.fatalError ? /* @__PURE__ */ jsxs5("p", { className: "text-sm text-danger", children: [
538
- "Fatal runtime error: ",
539
- snapshot.fatalError.message
540
- ] }) : null
541
- ] })
542
- ]
543
- }
544
- ) });
545
- }
546
- export {
547
- TwAlertBanner,
548
- TwCommentSidebar,
549
- TwEditorSurface,
550
- TwHealthPanel,
551
- TwInlineToken,
552
- TwOpaqueBlock,
553
- TwParagraphBlock,
554
- TwReviewRail,
555
- TwReviewWorkspace,
556
- TwRevisionSidebar,
557
- TwSegmentView,
558
- TwSelectionToolbar,
559
- TwStatusBar,
560
- TwToolbar,
561
- TwToolbarIconButton,
562
- createCommentDecorationModel,
563
- createEditorKeyboardHandler,
564
- createRevisionDecorationModel,
565
- createSelectionSnapshot,
566
- deriveCapabilities,
567
- getCommentHighlightClass,
568
- getCommentRangeState,
569
- getRevisionHighlightClass,
570
- getRevisionRangeState,
571
- renderTwCaret,
572
- selectionTouchesRange,
573
- shouldHideInCleanMode
574
- };
575
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/ui-tailwind/editor-surface/tw-editor-surface.tsx","../../src/ui/headless/use-editor-keyboard.ts","../../src/ui-tailwind/editor-surface/tw-opaque-block.tsx","../../src/ui-tailwind/editor-surface/tw-caret.tsx","../../src/ui-tailwind/editor-surface/tw-inline-token.tsx","../../src/ui-tailwind/editor-surface/tw-segment-view.tsx","../../src/ui-tailwind/editor-surface/tw-paragraph-block.tsx"],"sourcesContent":["import React, { type FocusEventHandler, useMemo } from \"react\";\n\nimport type {\n EditorUser,\n RuntimeRenderSnapshot,\n SelectionSnapshot,\n} from \"../../api/public-types\";\nimport {\n createCommentDecorationModel,\n type MarkupDisplay,\n} from \"../../ui/headless/comment-decoration-model\";\nimport { createRevisionDecorationModel } from \"../../ui/headless/revision-decoration-model\";\nimport { createEditorKeyboardHandler } from \"../../ui/headless/use-editor-keyboard\";\nimport { TwOpaqueBlock } from \"./tw-opaque-block\";\nimport { TwParagraphBlock } from \"./tw-paragraph-block\";\n\nexport interface TwEditorSurfaceProps {\n currentUser: EditorUser;\n snapshot: RuntimeRenderSnapshot;\n reviewMode: \"editing\" | \"review\";\n markupDisplay: MarkupDisplay;\n activeRevisionId?: string;\n /** When false, revision decorations are suppressed in the document surface. */\n showTrackedChanges?: boolean;\n onFocus: FocusEventHandler<HTMLDivElement>;\n onBlur: FocusEventHandler<HTMLDivElement>;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n onInsertText?: (text: string) => void;\n onDeleteBackward?: () => void;\n onDeleteForward?: () => void;\n onInsertTab?: () => void;\n onInsertHardBreak?: () => void;\n onSplitParagraph?: () => void;\n onCommentActivated?: (commentId: string) => void;\n onRevisionActivated?: (revisionId: string) => void;\n}\n\nexport function TwEditorSurface(props: TwEditorSurfaceProps) {\n const { currentUser, markupDisplay, onBlur, onFocus, snapshot } = props;\n const surface = snapshot.surface;\n\n const canEdit = Boolean(\n surface && snapshot.isReady && !snapshot.readOnly && !snapshot.fatalError,\n );\n\n const commentDecorations = useMemo(\n () => createCommentDecorationModel(snapshot.comments),\n [snapshot.comments],\n );\n\n const showTrackedChanges = props.showTrackedChanges !== false;\n const revisionDecorations = useMemo(\n () => showTrackedChanges\n ? createRevisionDecorationModel(snapshot.trackedChanges, props.activeRevisionId)\n : undefined,\n [snapshot.trackedChanges, props.activeRevisionId, showTrackedChanges],\n );\n\n const handleKeyDown = useMemo(() => {\n if (!surface) return undefined;\n return createEditorKeyboardHandler(\n {\n selection: snapshot.selection,\n storySize: surface.storySize,\n canEdit,\n },\n {\n onSelectionChange: props.onSelectionChange,\n onInsertText: props.onInsertText,\n onDeleteBackward: props.onDeleteBackward,\n onDeleteForward: props.onDeleteForward,\n onInsertTab: props.onInsertTab,\n onInsertHardBreak: props.onInsertHardBreak,\n onSplitParagraph: props.onSplitParagraph,\n },\n );\n }, [surface, snapshot.selection, canEdit, props]);\n\n const fontClass = markupDisplay === \"clean\"\n ? \"font-[family-name:var(--font-legal-sans)]\"\n : \"font-[family-name:var(--font-legal-serif)]\";\n\n return (\n <section aria-label=\"Document canvas\" className=\"min-w-0\">\n <div\n aria-label=\"Document surface\"\n aria-multiline=\"true\"\n role=\"textbox\"\n tabIndex={0}\n onFocus={onFocus}\n onBlur={onBlur}\n onKeyDown={handleKeyDown}\n className={`bg-transparent border-none px-12 py-10 outline-offset-1 ${fontClass}`}\n >\n {/* Document header */}\n <div className=\"flex justify-between gap-4 items-start mb-5\">\n <div>\n <h1 className=\"font-[family-name:var(--font-legal-serif)] text-2xl leading-tight text-primary\">\n {snapshot.sourceLabel ?? \"Document draft\"}\n </h1>\n <p className=\"text-xs text-secondary mt-2\">\n {snapshot.sessionId} · {snapshot.documentStats.storyLength} chars\n </p>\n </div>\n <span className=\"text-xs text-secondary whitespace-nowrap\">\n Reviewer {currentUser.displayName}\n </span>\n </div>\n\n {/* Document blocks */}\n <div className=\"space-y-4 pl-10 relative\">\n {surface ? (\n surface.blocks.map((block) =>\n block.kind === \"paragraph\" ? (\n <TwParagraphBlock\n key={block.blockId}\n block={block}\n selection={snapshot.selection}\n markupDisplay={markupDisplay}\n commentDecorations={commentDecorations}\n revisionDecorations={revisionDecorations}\n onSelectionChange={props.onSelectionChange}\n onCommentActivated={props.onCommentActivated}\n onRevisionActivated={props.onRevisionActivated}\n />\n ) : block.kind === \"opaque_block\" ? (\n <TwOpaqueBlock\n key={block.blockId}\n block={block}\n selection={snapshot.selection}\n onSelectionChange={props.onSelectionChange}\n />\n ) : null,\n )\n ) : (\n <p className=\"text-sm text-secondary leading-relaxed\">\n Loading the review surface. Compatibility cues and edit actions appear here once\n the runtime snapshot is ready.\n </p>\n )}\n {snapshot.fatalError ? (\n <p className=\"text-sm text-danger\">\n Fatal runtime error: {snapshot.fatalError.message}\n </p>\n ) : null}\n </div>\n </div>\n </section>\n );\n}\n","import type { KeyboardEvent } from \"react\";\n\nimport type { SelectionSnapshot } from \"../../api/public-types\";\nimport { createSelectionSnapshot } from \"./selection-helpers\";\n\nexport interface EditorKeyboardCallbacks {\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n onInsertText?: (text: string) => void;\n onDeleteBackward?: () => void;\n onDeleteForward?: () => void;\n onInsertTab?: () => void;\n onOutdentTab?: () => void;\n onInsertHardBreak?: () => void;\n onSplitParagraph?: () => void;\n}\n\nexport interface EditorKeyboardContext {\n selection: SelectionSnapshot;\n storySize: number;\n canEdit: boolean;\n}\n\nexport function createEditorKeyboardHandler(\n context: EditorKeyboardContext,\n callbacks: EditorKeyboardCallbacks,\n): (event: KeyboardEvent<HTMLDivElement>) => void {\n return function handleKeyDown(event: KeyboardEvent<HTMLDivElement>): void {\n const { selection, storySize, canEdit } = context;\n\n if (event.key === \"ArrowLeft\") {\n event.preventDefault();\n moveSelection(selection.anchor, selection.head - 1, event.shiftKey, storySize, callbacks);\n return;\n }\n\n if (event.key === \"ArrowRight\") {\n event.preventDefault();\n moveSelection(selection.anchor, selection.head + 1, event.shiftKey, storySize, callbacks);\n return;\n }\n\n if (event.key === \"Home\") {\n event.preventDefault();\n moveSelection(selection.anchor, 0, event.shiftKey, storySize, callbacks);\n return;\n }\n\n if (event.key === \"End\") {\n event.preventDefault();\n moveSelection(selection.anchor, storySize, event.shiftKey, storySize, callbacks);\n return;\n }\n\n if (!canEdit || event.metaKey || event.ctrlKey || event.altKey) {\n return;\n }\n\n switch (event.key) {\n case \"Backspace\":\n event.preventDefault();\n callbacks.onDeleteBackward?.();\n return;\n case \"Delete\":\n event.preventDefault();\n callbacks.onDeleteForward?.();\n return;\n case \"Tab\":\n event.preventDefault();\n if (event.shiftKey) {\n callbacks.onOutdentTab?.();\n } else {\n callbacks.onInsertTab?.();\n }\n return;\n case \"Enter\":\n event.preventDefault();\n if (event.shiftKey) {\n callbacks.onInsertHardBreak?.();\n } else {\n callbacks.onSplitParagraph?.();\n }\n return;\n default:\n if (event.key.length === 1) {\n event.preventDefault();\n callbacks.onInsertText?.(event.key);\n }\n }\n };\n}\n\nfunction moveSelection(\n anchor: number,\n nextHead: number,\n extend: boolean,\n storySize: number,\n callbacks: EditorKeyboardCallbacks,\n): void {\n const clampedHead = Math.max(0, Math.min(storySize, nextHead));\n callbacks.onSelectionChange?.(\n createSelectionSnapshot(extend ? anchor : clampedHead, clampedHead),\n );\n}\n","import React from \"react\";\n\nimport type { SelectionSnapshot, SurfaceBlockSnapshot } from \"../../api/public-types\";\nimport { selectionTouchesRange, createSelectionSnapshot } from \"../../ui/headless/selection-helpers\";\n\nexport interface TwOpaqueBlockProps {\n block: Extract<SurfaceBlockSnapshot, { kind: \"opaque_block\" }>;\n selection: SelectionSnapshot;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n workflowTargeted?: boolean;\n}\n\nconst focusRingClass =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent focus-visible:ring-offset-2 focus-visible:ring-offset-canvas\";\n\nexport function TwOpaqueBlock(props: TwOpaqueBlockProps) {\n const { block, selection, workflowTargeted } = props;\n const selected = selectionTouchesRange(selection, block.from, block.to);\n\n return (\n <div className=\"group relative\">\n <div className=\"absolute -left-10 top-1 flex flex-col items-end gap-0 select-none w-8 text-right\">\n <div className=\"flex items-center gap-0.5\">\n <span className=\"text-[10px] text-tertiary/60 font-medium\">Lock</span>\n <span className=\"inline-block h-1 w-1 rounded-full\" style={{ backgroundColor: \"var(--color-comment)\" }} />\n </div>\n </div>\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(block.from, block.to));\n }}\n className={[\n \"w-full text-left border-l-2 border-dashed border-warning/30 pl-4 py-2 rounded-r bg-warning-soft/20\",\n \"cursor-pointer transition-colors\",\n selected ? \"ring-1 ring-accent/30 bg-warning-soft/40\" : \"hover:bg-warning-soft/30\",\n focusRingClass,\n ].join(\" \")}\n >\n <div className=\"flex items-center gap-1.5 text-xs text-tertiary mb-1\">\n <span>🔒</span>\n <span>{block.label}</span>\n <span className=\"inline-flex items-center px-1.5 py-0.5 rounded-full text-[10px] font-semibold text-comment bg-warning-soft\">\n preserve-only\n </span>\n {workflowTargeted && (\n <span className=\"inline-flex items-center px-1.5 py-0.5 rounded-full text-[10px] font-semibold text-amber-700 bg-amber-100\">\n workflow-targeted\n </span>\n )}\n </div>\n <p className=\"text-sm text-secondary\">{block.detail}</p>\n </button>\n </div>\n );\n}\n","import React from \"react\";\n\nimport type { SelectionSnapshot } from \"../../api/public-types\";\n\nexport function renderTwCaret(selection: SelectionSnapshot, position: number) {\n return selection.isCollapsed && selection.anchor === position ? (\n <span\n aria-hidden=\"true\"\n className=\"inline-block w-0.5 h-[1.2em] bg-accent rounded-full align-middle animate-wre-blink\"\n />\n ) : null;\n}\n","import React from \"react\";\n\nimport type { SelectionSnapshot, SurfaceInlineSegment } from \"../../api/public-types\";\nimport type { CommentDecorationModel } from \"../../ui/headless/comment-decoration-model\";\nimport { getCommentHighlightClass, type MarkupDisplay } from \"../../ui/headless/comment-decoration-model\";\nimport { createSelectionSnapshot, selectionTouchesRange } from \"../../ui/headless/selection-helpers\";\nimport { renderTwCaret } from \"./tw-caret\";\n\nexport interface TwInlineTokenProps {\n segment: SurfaceInlineSegment;\n selection: SelectionSnapshot;\n markupDisplay: MarkupDisplay;\n commentDecorations?: CommentDecorationModel;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n}\n\nconst focusRingClass =\n \"focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-accent focus-visible:ring-offset-2 focus-visible:ring-offset-canvas\";\n\nexport function TwInlineToken(props: TwInlineTokenProps) {\n const { segment, selection } = props;\n const selected = selectionTouchesRange(selection, segment.from, segment.to);\n const commentClass = getCommentHighlightClass(\n props.commentDecorations,\n segment.from,\n segment.to,\n props.markupDisplay,\n );\n\n const showSymbols = props.markupDisplay !== \"clean\";\n\n if (segment.kind === \"tab\") {\n return (\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));\n }}\n className={`inline-flex items-center border-none bg-transparent cursor-text ${commentClass} ${selected ? \"bg-surface-hover\" : \"\"} ${focusRingClass} ${showSymbols ? \"mx-0.5 text-tertiary/50\" : \"w-8\"}`}\n title=\"Tab character\"\n >\n {renderTwCaret(selection, segment.from)}\n {showSymbols ? <span className=\"text-xs\">→</span> : <span className=\"w-8\" />}\n {renderTwCaret(selection, segment.to)}\n </button>\n );\n }\n\n if (segment.kind === \"hard_break\") {\n return (\n <>\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));\n }}\n className={`inline-flex items-center border-none bg-transparent cursor-text ${commentClass} ${selected ? \"bg-surface-hover\" : \"\"} ${focusRingClass} ${showSymbols ? \"mx-0.5 text-tertiary/40\" : \"\"}`}\n title=\"Line break\"\n >\n {renderTwCaret(selection, segment.from)}\n {showSymbols ? <span className=\"text-xs\">↵</span> : null}\n {renderTwCaret(selection, segment.to)}\n </button>\n <br />\n </>\n );\n }\n\n if (segment.kind === \"image\") {\n const isMissing = segment.state === \"missing\";\n return (\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));\n }}\n className={`inline-flex items-center gap-1 mx-0.5 px-1.5 py-0.5 rounded text-xs border-none cursor-pointer ${commentClass} ${\n isMissing ? \"text-danger bg-delete-soft\" : \"text-secondary bg-surface\"\n } ${selected ? \"ring-1 ring-accent/30\" : \"\"} ${focusRingClass}`}\n title={segment.detail ?? segment.altText ?? \"Inline image\"}\n >\n {renderTwCaret(selection, segment.from)}\n <span>📷</span>\n {segment.altText ?? (isMissing ? \"Missing image\" : \"Image\")}\n {renderTwCaret(selection, segment.to)}\n </button>\n );\n }\n\n // opaque_inline\n if (segment.kind === \"opaque_inline\") {\n if (segment.presentation === \"quiet-marker\") {\n return (\n <span\n aria-label={segment.label}\n title={segment.detail}\n className=\"inline-block h-0 w-0 overflow-hidden align-baseline\"\n data-inline-presentation=\"quiet-marker\"\n />\n );\n }\n\n return (\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(segment.from, segment.to));\n }}\n className={`inline-flex items-center gap-1 mx-0.5 px-1.5 py-0.5 rounded text-xs text-comment bg-warning-soft border-none cursor-pointer ${commentClass} ${selected ? \"ring-1 ring-accent/30\" : \"\"} ${focusRingClass}`}\n title={segment.detail}\n >\n {renderTwCaret(selection, segment.from)}\n <span>🔒</span>\n {segment.label}\n {renderTwCaret(selection, segment.to)}\n </button>\n );\n }\n\n return null;\n}\n","import React from \"react\";\n\nimport type { SelectionSnapshot, SurfaceInlineSegment } from \"../../api/public-types\";\nimport type { CommentDecorationModel } from \"../../ui/headless/comment-decoration-model\";\nimport { getCommentHighlightClass, getCommentRangeState, type MarkupDisplay } from \"../../ui/headless/comment-decoration-model\";\nimport type { RevisionDecorationModel } from \"../../ui/headless/revision-decoration-model\";\nimport { getRevisionHighlightClass, shouldHideInCleanMode } from \"../../ui/headless/revision-decoration-model\";\nimport { createSelectionSnapshot, selectionTouchesRange } from \"../../ui/headless/selection-helpers\";\nimport { TwInlineToken } from \"./tw-inline-token\";\n\nexport interface TwSegmentViewProps {\n segment: SurfaceInlineSegment;\n selection: SelectionSnapshot;\n markupDisplay: MarkupDisplay;\n commentDecorations?: CommentDecorationModel;\n revisionDecorations?: RevisionDecorationModel;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n onCommentActivated?: (commentId: string) => void;\n onRevisionActivated?: (revisionId: string) => void;\n}\n\nexport function TwSegmentView(props: TwSegmentViewProps) {\n const { segment, selection, markupDisplay } = props;\n\n // Non-text segments delegate to TwInlineToken\n if (segment.kind === \"tab\" || segment.kind === \"hard_break\" || segment.kind === \"image\" || segment.kind === \"opaque_inline\") {\n return (\n <TwInlineToken\n segment={segment}\n selection={selection}\n markupDisplay={markupDisplay}\n commentDecorations={props.commentDecorations}\n onSelectionChange={props.onSelectionChange}\n />\n );\n }\n\n if (segment.kind !== \"text\") {\n return null;\n }\n\n // Text segment: render character-by-character for click-to-position editing\n const characters = Array.from(segment.text);\n\n return (\n <>\n {characters.map((character, index) => {\n const from = segment.from + index;\n const to = from + 1;\n const isSelected = selectionTouchesRange(selection, from, to);\n\n // Hide deletions in clean mode\n if (shouldHideInCleanMode(props.revisionDecorations, from, to) && markupDisplay === \"clean\") {\n return null;\n }\n\n const commentClass = getCommentHighlightClass(props.commentDecorations, from, to, markupDisplay);\n const revisionClass = getRevisionHighlightClass(props.revisionDecorations, from, to, markupDisplay);\n\n // Check if clicking this char should activate a comment or revision\n const commentState = getCommentRangeState(props.commentDecorations, from, to);\n const overlappingComment = commentState.overlapping[0];\n\n // Build mark classes\n let markClasses = \"\";\n if (segment.marks) {\n if (segment.marks.includes(\"bold\")) markClasses += \"font-bold \";\n if (segment.marks.includes(\"italic\")) markClasses += \"italic \";\n if (segment.marks.includes(\"underline\")) markClasses += \"underline \";\n if (segment.marks.includes(\"strikethrough\")) markClasses += \"line-through \";\n }\n\n const hyperlinkClass = segment.hyperlinkHref\n ? \"text-accent underline decoration-1 underline-offset-2 \"\n : \"\";\n\n return (\n <button\n key={`${segment.segmentId}-${from}`}\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(event) => {\n event.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(to));\n\n // Activate comment/revision on click if decorated\n if (overlappingComment) {\n props.onCommentActivated?.(overlappingComment.commentId);\n }\n }}\n data-comment-id={overlappingComment?.commentId}\n className={[\n \"relative inline border-none bg-transparent cursor-text whitespace-pre p-0 m-0\",\n \"text-[15px] text-primary leading-normal\",\n commentClass,\n revisionClass,\n markClasses,\n hyperlinkClass,\n isSelected ? \"bg-surface-hover rounded-[3px]\" : \"\",\n ].filter(Boolean).join(\" \")}\n >\n {character}\n {selection.isCollapsed && selection.anchor === from ? (\n <span aria-hidden=\"true\" className=\"absolute left-0 top-[0.1em] w-0.5 h-[1em] bg-accent rounded-full animate-wre-blink pointer-events-none\" />\n ) : null}\n </button>\n );\n })}\n </>\n );\n}\n","import React from \"react\";\n\nimport type { SelectionSnapshot, SurfaceBlockSnapshot, SurfaceInlineSegment } from \"../../api/public-types\";\nimport type { CommentDecorationModel } from \"../../ui/headless/comment-decoration-model\";\nimport { getCommentRangeState, type MarkupDisplay } from \"../../ui/headless/comment-decoration-model\";\nimport type { RevisionDecorationModel } from \"../../ui/headless/revision-decoration-model\";\nimport { getRevisionRangeState } from \"../../ui/headless/revision-decoration-model\";\nimport { createSelectionSnapshot } from \"../../ui/headless/selection-helpers\";\nimport { renderTwCaret } from \"./tw-caret\";\nimport { TwSegmentView } from \"./tw-segment-view\";\n\nexport interface TwParagraphBlockProps {\n block: Extract<SurfaceBlockSnapshot, { kind: \"paragraph\" }>;\n selection: SelectionSnapshot;\n markupDisplay: MarkupDisplay;\n commentDecorations?: CommentDecorationModel;\n revisionDecorations?: RevisionDecorationModel;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n onCommentActivated?: (commentId: string) => void;\n onRevisionActivated?: (revisionId: string) => void;\n}\n\nexport function TwParagraphBlock(props: TwParagraphBlockProps) {\n const { block, selection, markupDisplay } = props;\n const headingLevel = inferHeadingLevel(block.styleId);\n const hasComment = getCommentRangeState(props.commentDecorations, block.from, block.to).hasComments;\n const hasChange = getRevisionRangeState(props.revisionDecorations, block.from, block.to).hasChanges;\n\n // Margin indicator per mode\n let marginClass = \"\";\n if (markupDisplay === \"simple\" && (hasComment || hasChange)) {\n if (hasComment && hasChange) marginClass = \"border-l-2 border-l-comment/50 pl-3 \";\n else if (hasComment) marginClass = \"border-l-2 border-l-comment/40 pl-3 \";\n else marginClass = \"border-l-2 border-l-insert/40 pl-3 \";\n }\n\n // Dot markers for gutter\n const dots: string[] = [];\n if (markupDisplay === \"clean\" && hasComment) {\n dots.push(\"var(--color-comment)\");\n } else if (markupDisplay !== \"simple\") {\n if (hasComment) dots.push(\"var(--color-comment)\");\n if (hasChange) dots.push(\"var(--color-insert)\");\n }\n\n const segmentElements = (\n <>\n <CaretButton\n position={block.from}\n selection={selection}\n onSelectionChange={props.onSelectionChange}\n />\n {block.segments.length > 0 ? (\n block.segments.map((segment) => (\n <TwSegmentView\n key={segment.segmentId}\n segment={segment}\n selection={selection}\n markupDisplay={markupDisplay}\n commentDecorations={props.commentDecorations}\n revisionDecorations={props.revisionDecorations}\n onSelectionChange={props.onSelectionChange}\n onCommentActivated={props.onCommentActivated}\n onRevisionActivated={props.onRevisionActivated}\n />\n ))\n ) : (\n <span className=\"text-secondary italic\">Empty paragraph</span>\n )}\n <CaretButton\n position={block.to}\n selection={selection}\n onSelectionChange={props.onSelectionChange}\n />\n </>\n );\n\n return (\n <div className=\"group relative\">\n <BlockHint\n label={headingLevel ? `H${headingLevel}` : \"P\"}\n dots={dots.length > 0 ? dots : undefined}\n />\n {headingLevel ? (\n <div className={`${marginClass}transition-colors`}>\n <HeadingElement level={headingLevel}>{segmentElements}</HeadingElement>\n </div>\n ) : (\n <p className={`text-base leading-[1.75] text-primary ${marginClass}transition-colors`}>\n {segmentElements}\n </p>\n )}\n </div>\n );\n}\n\nfunction CaretButton(props: {\n position: number;\n selection: SelectionSnapshot;\n onSelectionChange?: (selection: SelectionSnapshot) => void;\n}) {\n const isActive = props.selection.isCollapsed && props.selection.anchor === props.position;\n return (\n <button\n type=\"button\"\n tabIndex={-1}\n onMouseDown={(e) => {\n e.preventDefault();\n props.onSelectionChange?.(createSelectionSnapshot(props.position));\n }}\n aria-label={`Set caret at ${props.position}`}\n className={`p-0 m-0 border-none bg-transparent cursor-text inline-flex items-center ${isActive ? \"min-w-[2px] h-[22px]\" : \"w-0 h-0 overflow-hidden\"}`}\n >\n {renderTwCaret(props.selection, props.position)}\n </button>\n );\n}\n\nfunction BlockHint(props: { label: string; dots?: string[] }) {\n return (\n <div className=\"absolute -left-10 top-1 flex flex-col items-end gap-0 select-none w-8 text-right\">\n <div className=\"flex items-center gap-0.5\">\n <span className=\"text-[10px] text-tertiary/60 font-medium\">{props.label}</span>\n {props.dots?.map((color, i) => (\n <span\n key={i}\n className=\"inline-block h-1 w-1 rounded-full\"\n style={{ backgroundColor: color }}\n />\n ))}\n </div>\n </div>\n );\n}\n\nfunction HeadingElement(props: { level: 1 | 2 | 3; children: React.ReactNode }) {\n switch (props.level) {\n case 1: return <h2 className=\"text-2xl font-medium text-primary leading-tight\">{props.children}</h2>;\n case 2: return <h3 className=\"text-xl font-medium text-primary leading-snug\">{props.children}</h3>;\n case 3: return <h4 className=\"text-lg font-medium text-primary leading-snug\">{props.children}</h4>;\n }\n}\n\nfunction inferHeadingLevel(styleId?: string): 1 | 2 | 3 | null {\n if (!styleId) return null;\n const lower = styleId.toLowerCase();\n if (lower === \"heading1\") return 1;\n if (lower === \"heading2\") return 2;\n if (lower === \"heading3\") return 3;\n return null;\n}\n"],"mappings":"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","names":["jsx","jsx","jsxs","focusRingClass","Fragment","jsx","jsxs","Fragment","jsx","jsxs","jsx","jsxs"]}