@modusoperandi/licit 0.1.4 → 0.1.8

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 (692) hide show
  1. package/.babelrc +54 -54
  2. package/.dockerignore +4 -4
  3. package/.eslintignore +3 -3
  4. package/.eslintrc.js +80 -80
  5. package/.flowconfig +37 -37
  6. package/.github/workflows/build.yml +35 -29
  7. package/.github/workflows/lint.yml +30 -30
  8. package/.prettierignore +5 -5
  9. package/.prettierrc +4 -4
  10. package/.stylelintignore +1 -1
  11. package/.stylelintrc.json +13 -13
  12. package/.travis.yml +18 -18
  13. package/CODEOWNERS +40 -40
  14. package/LICENSE +22 -22
  15. package/README.md +286 -284
  16. package/build_collab_server.py +7 -7
  17. package/build_customstyle_server.py +7 -7
  18. package/build_image_server.py +7 -7
  19. package/dist/BlockquoteInsertNewLineCommand.js.flow +55 -55
  20. package/dist/BlockquoteNodeSpec.js.flow +30 -30
  21. package/dist/BlockquoteToggleCommand.js.flow +34 -34
  22. package/dist/BookmarkNodeSpec.js.flow +39 -39
  23. package/dist/BulletListNodeSpec.js.flow +61 -61
  24. package/dist/CZIProseMirror.js.flow +90 -90
  25. package/dist/CodeBlockCommand.js.flow +43 -43
  26. package/dist/CodeBlockNodeSpec.js.flow +24 -24
  27. package/dist/CodeMarkSpec.js.flow +14 -14
  28. package/dist/ContentPlaceholderPlugin.js.flow +187 -187
  29. package/dist/CursorPlaceholderPlugin.js.flow +115 -115
  30. package/dist/DocLayoutCommand.js.flow +94 -94
  31. package/dist/DocNodeSpec.js.flow +64 -64
  32. package/dist/EMMarkSpec.js.flow +14 -14
  33. package/dist/EditorCommands.js.flow +128 -128
  34. package/dist/EditorKeyMap.js.flow +187 -187
  35. package/dist/EditorMarks.js.flow +71 -71
  36. package/dist/EditorNodes.js.flow +60 -60
  37. package/dist/EditorPageLayoutPlugin.js.flow +67 -67
  38. package/dist/EditorPlugins.js.flow +8 -8
  39. package/dist/EditorSchema.js.flow +12 -12
  40. package/dist/EditorState.js.flow +7 -7
  41. package/dist/FontSizeCommand.js +0 -8
  42. package/dist/FontSizeCommand.js.flow +57 -73
  43. package/dist/FontSizeMarkSpec.js.flow +49 -49
  44. package/dist/FontTypeCommand.js +0 -8
  45. package/dist/FontTypeCommand.js.flow +100 -116
  46. package/dist/FontTypeMarkSpec.js.flow +80 -80
  47. package/dist/HTMLMutator.js.flow +59 -59
  48. package/dist/HardBreakNodeSpec.js.flow +15 -15
  49. package/dist/HeadingCommand.js.flow +51 -51
  50. package/dist/HeadingNodeSpec.js.flow +54 -54
  51. package/dist/HistoryRedoCommand.js.flow +20 -20
  52. package/dist/HistoryUndoCommand.js.flow +20 -20
  53. package/dist/HorizontalRuleCommand.js.flow +49 -49
  54. package/dist/HorizontalRuleNodeSpec.js.flow +39 -39
  55. package/dist/ImageFromURLCommand.js.flow +14 -14
  56. package/dist/ImageNodeSpec.js.flow +90 -90
  57. package/dist/ImageSourceCommand.js.flow +117 -117
  58. package/dist/ImageUploadCommand.js.flow +36 -36
  59. package/dist/ImageUploadPlaceholderPlugin.js.flow +192 -192
  60. package/dist/IndentCommand.js +0 -9
  61. package/dist/IndentCommand.js.flow +41 -54
  62. package/dist/LinkMarkSpec.js.flow +32 -32
  63. package/dist/LinkSetURLCommand.js.flow +103 -103
  64. package/dist/LinkTooltipPlugin.js.flow +203 -203
  65. package/dist/ListItemInsertNewLineCommand.js.flow +55 -55
  66. package/dist/ListItemMergeCommand.js.flow +177 -177
  67. package/dist/ListItemNodeSpec.js.flow +51 -51
  68. package/dist/ListSplitCommand.js.flow +32 -32
  69. package/dist/ListToggleCommand.js +3 -45
  70. package/dist/ListToggleCommand.js.flow +77 -117
  71. package/dist/MarkNames.js +2 -4
  72. package/dist/MarkNames.js.flow +18 -19
  73. package/dist/MarkToggleCommand.js +3 -114
  74. package/dist/MarkToggleCommand.js.flow +66 -168
  75. package/dist/MarksClearCommand.js +1 -18
  76. package/dist/MarksClearCommand.js.flow +42 -55
  77. package/dist/MathEditCommand.js.flow +110 -110
  78. package/dist/MathNodeSpec.js.flow +46 -46
  79. package/dist/NodeNames.js.flow +23 -23
  80. package/dist/OrderedListNodeSpec.js.flow +132 -132
  81. package/dist/ParagraphNodeSpec.js +6 -115
  82. package/dist/ParagraphNodeSpec.js.flow +160 -250
  83. package/dist/ParagraphSpacingCommand.js.flow +121 -121
  84. package/dist/PrintCommand.js.flow +31 -31
  85. package/dist/SelectionPlaceholderPlugin.js.flow +131 -131
  86. package/dist/SpacerMarkSpec.js.flow +47 -47
  87. package/dist/StrikeMarkSpec.js.flow +21 -21
  88. package/dist/StrongMarkSpec.js.flow +25 -25
  89. package/dist/StyleView.js.flow +19 -19
  90. package/dist/TableBackgroundColorCommand.js.flow +75 -75
  91. package/dist/TableBorderColorCommand.js.flow +75 -75
  92. package/dist/TableCellColorCommand.js.flow +71 -71
  93. package/dist/TableCellMenuPlugin.js.flow +125 -125
  94. package/dist/TableInsertCommand.js.flow +112 -112
  95. package/dist/TableMergeCellsCommand.js.flow +90 -90
  96. package/dist/TableNodesSpecs.js.flow +78 -78
  97. package/dist/TablePlugins.js.flow +14 -14
  98. package/dist/TableResizePlugin.js.flow +631 -631
  99. package/dist/TextAlignCommand.js +0 -8
  100. package/dist/TextAlignCommand.js.flow +122 -138
  101. package/dist/TextColorCommand.js +0 -16
  102. package/dist/TextColorCommand.js.flow +87 -112
  103. package/dist/TextColorMarkSpec.js.flow +35 -35
  104. package/dist/TextHighlightCommand.js +0 -12
  105. package/dist/TextHighlightCommand.js.flow +91 -110
  106. package/dist/TextHighlightMarkSpec.js.flow +38 -38
  107. package/dist/TextInsertTabSpaceCommand.js +2 -5
  108. package/dist/TextInsertTabSpaceCommand.js.flow +83 -85
  109. package/dist/TextLineSpacingCommand.js.flow +157 -157
  110. package/dist/TextNoWrapMarkSpec.js.flow +14 -14
  111. package/dist/TextNodeSpec.js.flow +7 -7
  112. package/dist/TextSelectionMarkSpec.js.flow +24 -24
  113. package/dist/TextSubMarkSpec.js.flow +20 -20
  114. package/dist/TextSuperMarkSpec.js.flow +20 -20
  115. package/dist/TextUnderlineMarkSpec.js.flow +27 -27
  116. package/dist/Types.js +2 -121
  117. package/dist/Types.js.flow +75 -155
  118. package/dist/WebFontLoader.js.flow +22 -22
  119. package/dist/applyMark.js +3 -4
  120. package/dist/applyMark.js.flow +61 -64
  121. package/dist/blockQuoteInputRule.js.flow +36 -36
  122. package/dist/bom.xml +89 -89
  123. package/dist/browser.js.flow +7 -7
  124. package/dist/buildEditorPlugins.js +1 -3
  125. package/dist/buildEditorPlugins.js.flow +51 -53
  126. package/dist/buildInputRules.js.flow +81 -81
  127. package/dist/clearMarks.js +2 -5
  128. package/dist/clearMarks.js.flow +128 -132
  129. package/dist/client/CollabConnector.js +7 -7
  130. package/dist/client/CollabConnector.js.flow +71 -75
  131. package/dist/client/EditorConnection.js.flow +307 -307
  132. package/dist/client/Licit.js +197 -117
  133. package/dist/client/Licit.js.flow +562 -495
  134. package/dist/client/Licit.test.js +3 -57
  135. package/dist/client/Licit.test.js.flow +65 -120
  136. package/dist/client/Reporter.js.flow +37 -37
  137. package/dist/client/SimpleConnector.js.flow +53 -53
  138. package/dist/client/http.js.flow +66 -66
  139. package/dist/client/licit.css +12 -12
  140. package/dist/client/throttle.js.flow +27 -27
  141. package/dist/compareNumber.js.flow +11 -11
  142. package/dist/consolidateListNodes.js +27 -27
  143. package/dist/consolidateListNodes.js.flow +281 -281
  144. package/dist/convertFromDOMElement.js.flow +36 -36
  145. package/dist/convertFromHTML.js.flow +19 -19
  146. package/dist/convertFromJSON.js.flow +78 -78
  147. package/dist/convertToCSSPTValue.js.flow +22 -22
  148. package/dist/convertToJSON.js.flow +7 -7
  149. package/dist/createCommand.js.flow +40 -40
  150. package/dist/createEditorKeyMap.js.flow +94 -94
  151. package/dist/createEmptyEditorState.js.flow +41 -41
  152. package/dist/createTableResizingPlugin.js.flow +86 -86
  153. package/dist/findActionableCell.js.flow +74 -74
  154. package/dist/findActiveMark.js.flow +32 -32
  155. package/dist/findNodesWithSameMark.js.flow +89 -89
  156. package/dist/hyphenize.js.flow +17 -17
  157. package/dist/index.js +0 -14
  158. package/dist/index.js.flow +10 -11
  159. package/dist/insertTable.js.flow +56 -56
  160. package/dist/isBulletListNode.js.flow +9 -9
  161. package/dist/isEditorStateEmpty.js.flow +32 -32
  162. package/dist/isInsideListItem.js.flow +13 -13
  163. package/dist/isListNode.js.flow +13 -13
  164. package/dist/isNodeSelectionForNodeType.js.flow +15 -15
  165. package/dist/isOrderedListNode.js.flow +9 -9
  166. package/dist/isTableNode.js.flow +15 -15
  167. package/dist/isTextStyleMarkCommandEnabled.js.flow +49 -49
  168. package/dist/joinDown.js.flow +27 -27
  169. package/dist/joinListNode.js.flow +55 -55
  170. package/dist/joinUp.js.flow +39 -39
  171. package/dist/keymaps.js.flow +185 -185
  172. package/dist/lookUpElement.js.flow +14 -14
  173. package/dist/nodeAt.js.flow +12 -12
  174. package/dist/noop.js.flow +5 -5
  175. package/dist/normalizeHTML.js.flow +78 -78
  176. package/dist/patchAnchorElements.js.flow +38 -38
  177. package/dist/patchBreakElements.js.flow +22 -22
  178. package/dist/patchElementInlineStyles.js.flow +92 -92
  179. package/dist/patchListElements.js.flow +276 -276
  180. package/dist/patchMathElements.js.flow +60 -60
  181. package/dist/patchParagraphElements.js.flow +20 -20
  182. package/dist/patchStyleElements.js.flow +194 -194
  183. package/dist/patchTableElements.js.flow +89 -89
  184. package/dist/rebaseDocWithSteps.js.flow +42 -42
  185. package/dist/sanitizeURL.js.flow +13 -13
  186. package/dist/splitListItem.js.flow +191 -191
  187. package/dist/styles.css +19 -21
  188. package/dist/styles0.css +29 -30
  189. package/dist/toClosestFontPtSize.js.flow +22 -22
  190. package/dist/toSafeHTMLDocument.js.flow +9 -9
  191. package/dist/toggleBlockquote.js.flow +91 -91
  192. package/dist/toggleCodeBlock.js.flow +102 -102
  193. package/dist/toggleHeading.js.flow +113 -113
  194. package/dist/toggleList.js.flow +450 -450
  195. package/dist/transformAndPreserveTextSelection.js.flow +151 -151
  196. package/dist/ui/AlertInfo.js +1 -1
  197. package/dist/ui/AlertInfo.js.flow +64 -64
  198. package/dist/ui/BookmarkNodeView.js.flow +66 -66
  199. package/dist/ui/ColorEditor.js.flow +101 -101
  200. package/dist/ui/CommandButton.js.flow +68 -68
  201. package/dist/ui/CommandMenu.js.flow +75 -75
  202. package/dist/ui/CommandMenuButton.js.flow +131 -131
  203. package/dist/ui/CustomButton.js.flow +33 -33
  204. package/dist/ui/CustomEditorView.js.flow +28 -28
  205. package/dist/ui/CustomMenu.js.flow +17 -17
  206. package/dist/ui/CustomMenuItem.js.flow +36 -36
  207. package/dist/ui/CustomNodeView.js +6 -1
  208. package/dist/ui/CustomNodeView.js.flow +200 -196
  209. package/dist/ui/CustomRadioButton.js.flow +65 -65
  210. package/dist/ui/DocLayoutEditor.js.flow +146 -146
  211. package/dist/ui/Editor.js.flow +291 -291
  212. package/dist/ui/EditorFrameset.js.flow +81 -81
  213. package/dist/ui/EditorToolbar.js.flow +211 -211
  214. package/dist/ui/EditorToolbarConfig.js +0 -6
  215. package/dist/ui/EditorToolbarConfig.js.flow +172 -178
  216. package/dist/ui/FontSizeCommandMenuButton.js.flow +66 -66
  217. package/dist/ui/FontTypeCommandMenuButton.js.flow +49 -49
  218. package/dist/ui/Frag.js.flow +13 -13
  219. package/dist/ui/Icon.js.flow +89 -89
  220. package/dist/ui/ImageAlignEditor.js.flow +60 -60
  221. package/dist/ui/ImageInlineEditor.js.flow +67 -67
  222. package/dist/ui/ImageNodeView.js +1 -10
  223. package/dist/ui/ImageNodeView.js.flow +404 -414
  224. package/dist/ui/ImageResizeBox.js.flow +219 -219
  225. package/dist/ui/ImageURLEditor.js.flow +119 -119
  226. package/dist/ui/ImageUploadEditor.js.flow +117 -117
  227. package/dist/ui/KeyCodes.js.flow +12 -12
  228. package/dist/ui/LinkTooltip.js.flow +85 -85
  229. package/dist/ui/LinkURLEditor.js.flow +111 -111
  230. package/dist/ui/ListItemNodeView.js.flow +98 -98
  231. package/dist/ui/ListTypeButton.js.flow +131 -131
  232. package/dist/ui/ListTypeCommandButton.js +1 -1
  233. package/dist/ui/ListTypeCommandButton.js.flow +85 -86
  234. package/dist/ui/ListTypeMenu.js.flow +70 -70
  235. package/dist/ui/LoadingIndicator.js.flow +20 -20
  236. package/dist/ui/MathEditor.js.flow +78 -78
  237. package/dist/ui/MathInlineEditor.js.flow +102 -102
  238. package/dist/ui/MathNodeView.js.flow +175 -175
  239. package/dist/ui/PasteMenu.js.flow +57 -57
  240. package/dist/ui/PointerSurface.js.flow +141 -141
  241. package/dist/ui/PopUp.js.flow +77 -77
  242. package/dist/ui/PopUpManager.js.flow +213 -213
  243. package/dist/ui/PopUpPosition.js +0 -0
  244. package/dist/ui/PopUpPosition.js.flow +104 -104
  245. package/dist/ui/ResizeObserver.js.flow +106 -106
  246. package/dist/ui/RichTextEditor.js.flow +133 -133
  247. package/dist/ui/SelectionObserver.js.flow +134 -134
  248. package/dist/ui/TableCellMenu.js.flow +38 -38
  249. package/dist/ui/TableGridSizeEditor.js.flow +184 -184
  250. package/dist/ui/TableNodeView.js.flow +22 -22
  251. package/dist/ui/TooltipSurface.js.flow +76 -76
  252. package/dist/ui/bindScrollHandler.js.flow +46 -46
  253. package/dist/ui/canUseCSSFont.js.flow +43 -43
  254. package/dist/ui/clamp.js.flow +11 -11
  255. package/dist/ui/createPopUp.js.flow +205 -205
  256. package/dist/ui/czi-animations.css +15 -15
  257. package/dist/ui/czi-body-layout-editor.css +16 -16
  258. package/dist/ui/czi-bookmark-view.css +10 -10
  259. package/dist/ui/czi-color-editor.css +56 -56
  260. package/dist/ui/czi-cursor-placeholder.css +36 -36
  261. package/dist/ui/czi-custom-button.css +93 -93
  262. package/dist/ui/czi-custom-menu-button.css +18 -18
  263. package/dist/ui/czi-custom-menu-item.css +30 -30
  264. package/dist/ui/czi-custom-menu.css +8 -8
  265. package/dist/ui/czi-custom-radio-button.css +80 -80
  266. package/dist/ui/czi-custom-scrollbar.css +21 -21
  267. package/dist/ui/czi-editor-frameset.css +81 -81
  268. package/dist/ui/czi-editor-toolbar.css +122 -122
  269. package/dist/ui/czi-editor.css +220 -221
  270. package/dist/ui/czi-form.css +104 -104
  271. package/dist/ui/czi-frag.css +3 -3
  272. package/dist/ui/czi-heading.css +40 -40
  273. package/dist/ui/czi-icon.css +72 -72
  274. package/dist/ui/czi-image-resize-box.css +165 -165
  275. package/dist/ui/czi-image-upload-editor.css +57 -57
  276. package/dist/ui/czi-image-upload-placeholder.css +50 -50
  277. package/dist/ui/czi-image-url-editor.css +38 -38
  278. package/dist/ui/czi-image-view.css +125 -125
  279. package/dist/ui/czi-indent.css +137 -137
  280. package/dist/ui/czi-inline-editor.css +20 -20
  281. package/dist/ui/czi-link-tooltip.css +71 -71
  282. package/dist/ui/czi-list.css +410 -410
  283. package/dist/ui/czi-loading-indicator.css +111 -111
  284. package/dist/ui/czi-math-view.css +62 -62
  285. package/dist/ui/czi-pop-up.css +32 -32
  286. package/dist/ui/czi-selection-placeholder.css +24 -24
  287. package/dist/ui/czi-table-cell-menu.css +14 -14
  288. package/dist/ui/czi-table-grid-size-editor.css +37 -37
  289. package/dist/ui/czi-table.css +86 -86
  290. package/dist/ui/czi-tooltip-surface.css +45 -45
  291. package/dist/ui/czi-vars.css +46 -46
  292. package/dist/ui/findActiveFontSize.js.flow +58 -58
  293. package/dist/ui/findActiveFontType.js.flow +38 -38
  294. package/dist/ui/fonts.css +471 -471
  295. package/dist/ui/handleEditorDrop.js.flow +28 -28
  296. package/dist/ui/handleEditorKeyDown.js.flow +39 -39
  297. package/dist/ui/handleEditorPaste.js.flow +33 -33
  298. package/dist/ui/htmlElementToRect.js.flow +18 -18
  299. package/dist/ui/icon-font.css +10 -10
  300. package/dist/ui/injectStyleSheet.js.flow +42 -42
  301. package/dist/ui/isElementFullyVisible.js.flow +23 -23
  302. package/dist/ui/isOffline.js.flow +8 -8
  303. package/dist/ui/isReactClass.js.flow +12 -12
  304. package/dist/ui/listType.css +21 -21
  305. package/dist/ui/mathquill-editor/MathQuillEditor.js.flow +159 -159
  306. package/dist/ui/mathquill-editor/MathQuillEditorSymbols.js.flow +483 -483
  307. package/dist/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js.flow +48 -48
  308. package/dist/ui/mathquill-editor/czi-mathquill-editor-symbols-panel.css +39 -39
  309. package/dist/ui/mathquill-editor/czi-mathquill-editor.css +50 -50
  310. package/dist/ui/mathquill-editor/mathquill-import-kludge.js.flow +24 -24
  311. package/dist/ui/preventEventDefault.js.flow +5 -5
  312. package/dist/ui/rects.js.flow +47 -47
  313. package/dist/ui/renderLaTeXAsHTML.js.flow +46 -46
  314. package/dist/ui/resolveImage.js.flow +123 -123
  315. package/dist/ui/toCSSColor.js.flow +51 -51
  316. package/dist/ui/toCSSLineSpacing.js.flow +82 -82
  317. package/dist/ui/toHexColor.js.flow +26 -26
  318. package/dist/ui/uuid.js.flow +9 -9
  319. package/dist/updateIndentLevel.js +1 -47
  320. package/dist/updateIndentLevel.js.flow +211 -260
  321. package/dist/uuid.js.flow +9 -9
  322. package/flow-typed/@modusoperandilicit-customstyles.js +5 -0
  323. package/flow-typed/@modusoperandilicit-doc-attrs-step.js +5 -5
  324. package/flow-typed/@molicit-citation.js +5 -5
  325. package/flow-typed/create-emotion.js +5 -5
  326. package/flow-typed/docs-editor.js +3 -3
  327. package/flow-typed/draft-convert.js +3 -3
  328. package/flow-typed/draft-js.js +3 -3
  329. package/flow-typed/flatted.js +5 -5
  330. package/flow-typed/jquery.js +5 -5
  331. package/flow-typed/katex.js +6 -6
  332. package/flow-typed/mathquill.js +5 -5
  333. package/flow-typed/prosemirror-collab.js +5 -5
  334. package/flow-typed/prosemirror-commands.js +5 -5
  335. package/flow-typed/prosemirror-dev-tools.js +5 -5
  336. package/flow-typed/prosemirror-dropcursor.js +5 -5
  337. package/flow-typed/prosemirror-gapcursor.js +5 -5
  338. package/flow-typed/prosemirror-history.js +5 -5
  339. package/flow-typed/prosemirror-inputrules.js +5 -5
  340. package/flow-typed/prosemirror-keymap.js +5 -5
  341. package/flow-typed/prosemirror-model.js +5 -5
  342. package/flow-typed/prosemirror-state.js +5 -5
  343. package/flow-typed/prosemirror-tables.js +5 -5
  344. package/flow-typed/prosemirror-transform.js +5 -5
  345. package/flow-typed/prosemirror-utils.js +5 -5
  346. package/flow-typed/prosemirror-view.js +5 -5
  347. package/flow-typed/resize-observer-polyfill.js +5 -5
  348. package/flow-typed/uuid.js +5 -5
  349. package/jest.setup.js +5 -5
  350. package/licit/client/CustomLicitRuntime.js +95 -200
  351. package/licit/client/CustomStyleRuntime.js +136 -0
  352. package/licit/client/index.js +366 -365
  353. package/licit/index.html +11 -11
  354. package/licit/server/collab/instance.js +221 -221
  355. package/licit/server/collab/route.js +69 -69
  356. package/licit/server/collab/server.js +297 -296
  357. package/licit/server/collab/start.js +13 -13
  358. package/licit/server/customstyles/start.js +184 -184
  359. package/licit/server/image/start.js +58 -58
  360. package/lint.sh +4 -4
  361. package/package.json +165 -165
  362. package/run_collab_server.py +21 -21
  363. package/run_customstyle_server.py +20 -20
  364. package/run_image_server.py +20 -20
  365. package/run_web_server.py +25 -25
  366. package/scripts/build_bin.js +10 -10
  367. package/scripts/build_bin.py +103 -103
  368. package/scripts/ci_check_dist.sh +13 -13
  369. package/scripts/env.js +6 -6
  370. package/scripts/webserver.js +35 -35
  371. package/sonar-project.properties +11 -11
  372. package/src/BlockquoteInsertNewLineCommand.js +55 -55
  373. package/src/BlockquoteNodeSpec.js +30 -30
  374. package/src/BlockquoteToggleCommand.js +34 -34
  375. package/src/BookmarkNodeSpec.js +39 -39
  376. package/src/BulletListNodeSpec.js +61 -61
  377. package/src/CZIProseMirror.js +90 -90
  378. package/src/CodeBlockCommand.js +43 -43
  379. package/src/CodeBlockNodeSpec.js +24 -24
  380. package/src/CodeMarkSpec.js +14 -14
  381. package/src/ContentPlaceholderPlugin.js +187 -187
  382. package/src/CursorPlaceholderPlugin.js +115 -115
  383. package/src/DocLayoutCommand.js +94 -94
  384. package/src/DocNodeSpec.js +64 -64
  385. package/src/EMMarkSpec.js +14 -14
  386. package/src/EditorCommands.js +128 -128
  387. package/src/EditorKeyMap.js +187 -187
  388. package/src/EditorMarks.js +71 -71
  389. package/src/EditorNodes.js +60 -60
  390. package/src/EditorPageLayoutPlugin.js +67 -67
  391. package/src/EditorPlugins.js +8 -8
  392. package/src/EditorSchema.js +12 -12
  393. package/src/EditorState.js +7 -7
  394. package/src/FontSizeCommand.js +57 -73
  395. package/src/FontSizeMarkSpec.js +49 -49
  396. package/src/FontTypeCommand.js +100 -116
  397. package/src/FontTypeMarkSpec.js +80 -80
  398. package/src/HTMLMutator.js +59 -59
  399. package/src/HardBreakNodeSpec.js +15 -15
  400. package/src/HeadingCommand.js +51 -51
  401. package/src/HeadingNodeSpec.js +54 -54
  402. package/src/HistoryRedoCommand.js +20 -20
  403. package/src/HistoryUndoCommand.js +20 -20
  404. package/src/HorizontalRuleCommand.js +49 -49
  405. package/src/HorizontalRuleNodeSpec.js +39 -39
  406. package/src/ImageFromURLCommand.js +14 -14
  407. package/src/ImageNodeSpec.js +90 -90
  408. package/src/ImageSourceCommand.js +117 -117
  409. package/src/ImageUploadCommand.js +36 -36
  410. package/src/ImageUploadPlaceholderPlugin.js +192 -192
  411. package/src/IndentCommand.js +41 -54
  412. package/src/LinkMarkSpec.js +32 -32
  413. package/src/LinkSetURLCommand.js +103 -103
  414. package/src/LinkTooltipPlugin.js +203 -203
  415. package/src/ListItemInsertNewLineCommand.js +55 -55
  416. package/src/ListItemMergeCommand.js +177 -177
  417. package/src/ListItemNodeSpec.js +51 -51
  418. package/src/ListSplitCommand.js +32 -32
  419. package/src/ListToggleCommand.js +77 -117
  420. package/src/MarkNames.js +18 -19
  421. package/src/MarkToggleCommand.js +66 -168
  422. package/src/MarksClearCommand.js +42 -55
  423. package/src/MathEditCommand.js +110 -110
  424. package/src/MathNodeSpec.js +46 -46
  425. package/src/NodeNames.js +23 -23
  426. package/src/OrderedListNodeSpec.js +132 -132
  427. package/src/ParagraphNodeSpec.js +160 -250
  428. package/src/ParagraphSpacingCommand.js +121 -121
  429. package/src/PrintCommand.js +31 -31
  430. package/src/SelectionPlaceholderPlugin.js +131 -131
  431. package/src/SpacerMarkSpec.js +47 -47
  432. package/src/StrikeMarkSpec.js +21 -21
  433. package/src/StrongMarkSpec.js +25 -25
  434. package/src/StyleView.js +19 -19
  435. package/src/TableBackgroundColorCommand.js +75 -75
  436. package/src/TableBorderColorCommand.js +75 -75
  437. package/src/TableCellColorCommand.js +71 -71
  438. package/src/TableCellMenuPlugin.js +125 -125
  439. package/src/TableInsertCommand.js +112 -112
  440. package/src/TableMergeCellsCommand.js +90 -90
  441. package/src/TableNodesSpecs.js +78 -78
  442. package/src/TablePlugins.js +14 -14
  443. package/src/TableResizePlugin.js +631 -631
  444. package/src/TextAlignCommand.js +122 -138
  445. package/src/TextColorCommand.js +87 -112
  446. package/src/TextColorMarkSpec.js +35 -35
  447. package/src/TextHighlightCommand.js +91 -110
  448. package/src/TextHighlightMarkSpec.js +38 -38
  449. package/src/TextInsertTabSpaceCommand.js +83 -85
  450. package/src/TextLineSpacingCommand.js +157 -157
  451. package/src/TextNoWrapMarkSpec.js +14 -14
  452. package/src/TextNodeSpec.js +7 -7
  453. package/src/TextSelectionMarkSpec.js +24 -24
  454. package/src/TextSubMarkSpec.js +20 -20
  455. package/src/TextSuperMarkSpec.js +20 -20
  456. package/src/TextUnderlineMarkSpec.js +27 -27
  457. package/src/Types.js +75 -155
  458. package/src/WebFontLoader.js +22 -22
  459. package/src/applyMark.js +61 -64
  460. package/src/blockQuoteInputRule.js +36 -36
  461. package/src/browser.js +7 -7
  462. package/src/buildEditorPlugins.js +51 -53
  463. package/src/buildInputRules.js +81 -81
  464. package/src/clearMarks.js +128 -132
  465. package/src/client/CollabConnector.js +71 -75
  466. package/src/client/EditorConnection.js +307 -307
  467. package/src/client/Licit.js +562 -495
  468. package/src/client/Licit.test.js +65 -120
  469. package/src/client/Reporter.js +37 -37
  470. package/src/client/SimpleConnector.js +53 -53
  471. package/src/client/http.js +66 -66
  472. package/src/client/licit.css +12 -12
  473. package/src/client/throttle.js +27 -27
  474. package/src/compareNumber.js +11 -11
  475. package/src/consolidateListNodes.js +281 -281
  476. package/src/convertFromDOMElement.js +36 -36
  477. package/src/convertFromHTML.js +19 -19
  478. package/src/convertFromJSON.js +78 -78
  479. package/src/convertToCSSPTValue.js +22 -22
  480. package/src/convertToJSON.js +7 -7
  481. package/src/createCommand.js +40 -40
  482. package/src/createEditorKeyMap.js +94 -94
  483. package/src/createEmptyEditorState.js +41 -41
  484. package/src/createTableResizingPlugin.js +86 -86
  485. package/src/findActionableCell.js +74 -74
  486. package/src/findActiveMark.js +32 -32
  487. package/src/findNodesWithSameMark.js +89 -89
  488. package/src/hyphenize.js +17 -17
  489. package/src/index.js +10 -11
  490. package/src/insertTable.js +56 -56
  491. package/src/isBulletListNode.js +9 -9
  492. package/src/isEditorStateEmpty.js +32 -32
  493. package/src/isInsideListItem.js +13 -13
  494. package/src/isListNode.js +13 -13
  495. package/src/isNodeSelectionForNodeType.js +15 -15
  496. package/src/isOrderedListNode.js +9 -9
  497. package/src/isTableNode.js +15 -15
  498. package/src/isTextStyleMarkCommandEnabled.js +49 -49
  499. package/src/joinDown.js +27 -27
  500. package/src/joinListNode.js +55 -55
  501. package/src/joinUp.js +39 -39
  502. package/src/keymaps.js +185 -185
  503. package/src/lookUpElement.js +14 -14
  504. package/src/nodeAt.js +12 -12
  505. package/src/noop.js +5 -5
  506. package/src/normalizeHTML.js +78 -78
  507. package/src/patchAnchorElements.js +38 -38
  508. package/src/patchBreakElements.js +22 -22
  509. package/src/patchElementInlineStyles.js +92 -92
  510. package/src/patchListElements.js +276 -276
  511. package/src/patchMathElements.js +60 -60
  512. package/src/patchParagraphElements.js +20 -20
  513. package/src/patchStyleElements.js +194 -194
  514. package/src/patchTableElements.js +89 -89
  515. package/src/rebaseDocWithSteps.js +42 -42
  516. package/src/sanitizeURL.js +13 -13
  517. package/src/splitListItem.js +191 -191
  518. package/src/styles.css +19 -21
  519. package/src/styles0.css +29 -30
  520. package/src/toClosestFontPtSize.js +22 -22
  521. package/src/toSafeHTMLDocument.js +9 -9
  522. package/src/toggleBlockquote.js +91 -91
  523. package/src/toggleCodeBlock.js +102 -102
  524. package/src/toggleHeading.js +113 -113
  525. package/src/toggleList.js +450 -450
  526. package/src/transformAndPreserveTextSelection.js +151 -151
  527. package/src/ui/AlertInfo.js +64 -64
  528. package/src/ui/BookmarkNodeView.js +66 -66
  529. package/src/ui/ColorEditor.js +101 -101
  530. package/src/ui/CommandButton.js +68 -68
  531. package/src/ui/CommandMenu.js +75 -75
  532. package/src/ui/CommandMenuButton.js +131 -131
  533. package/src/ui/CustomButton.js +33 -33
  534. package/src/ui/CustomEditorView.js +28 -28
  535. package/src/ui/CustomMenu.js +17 -17
  536. package/src/ui/CustomMenuItem.js +36 -36
  537. package/src/ui/CustomNodeView.js +200 -196
  538. package/src/ui/CustomRadioButton.js +65 -65
  539. package/src/ui/DocLayoutEditor.js +146 -146
  540. package/src/ui/Editor.js +291 -291
  541. package/src/ui/EditorFrameset.js +81 -81
  542. package/src/ui/EditorToolbar.js +211 -211
  543. package/src/ui/EditorToolbarConfig.js +172 -178
  544. package/src/ui/FontSizeCommandMenuButton.js +66 -66
  545. package/src/ui/FontTypeCommandMenuButton.js +49 -49
  546. package/src/ui/Frag.js +13 -13
  547. package/src/ui/Icon.js +89 -89
  548. package/src/ui/ImageAlignEditor.js +60 -60
  549. package/src/ui/ImageInlineEditor.js +67 -67
  550. package/src/ui/ImageNodeView.js +404 -414
  551. package/src/ui/ImageResizeBox.js +219 -219
  552. package/src/ui/ImageURLEditor.js +119 -119
  553. package/src/ui/ImageUploadEditor.js +117 -117
  554. package/src/ui/KeyCodes.js +12 -12
  555. package/src/ui/LinkTooltip.js +85 -85
  556. package/src/ui/LinkURLEditor.js +111 -111
  557. package/src/ui/ListItemNodeView.js +98 -98
  558. package/src/ui/ListTypeButton.js +131 -131
  559. package/src/ui/ListTypeCommandButton.js +85 -86
  560. package/src/ui/ListTypeMenu.js +70 -70
  561. package/src/ui/LoadingIndicator.js +20 -20
  562. package/src/ui/MathEditor.js +78 -78
  563. package/src/ui/MathInlineEditor.js +102 -102
  564. package/src/ui/MathNodeView.js +175 -175
  565. package/src/ui/PasteMenu.js +57 -57
  566. package/src/ui/PointerSurface.js +141 -141
  567. package/src/ui/PopUp.js +77 -77
  568. package/src/ui/PopUpManager.js +213 -213
  569. package/src/ui/PopUpPosition.js +104 -104
  570. package/src/ui/ResizeObserver.js +106 -106
  571. package/src/ui/RichTextEditor.js +133 -133
  572. package/src/ui/SelectionObserver.js +134 -134
  573. package/src/ui/TableCellMenu.js +38 -38
  574. package/src/ui/TableGridSizeEditor.js +184 -184
  575. package/src/ui/TableNodeView.js +22 -22
  576. package/src/ui/TooltipSurface.js +76 -76
  577. package/src/ui/bindScrollHandler.js +46 -46
  578. package/src/ui/canUseCSSFont.js +43 -43
  579. package/src/ui/clamp.js +11 -11
  580. package/src/ui/createPopUp.js +205 -205
  581. package/src/ui/czi-animations.css +15 -15
  582. package/src/ui/czi-body-layout-editor.css +16 -16
  583. package/src/ui/czi-bookmark-view.css +10 -10
  584. package/src/ui/czi-color-editor.css +56 -56
  585. package/src/ui/czi-cursor-placeholder.css +36 -36
  586. package/src/ui/czi-custom-button.css +93 -93
  587. package/src/ui/czi-custom-menu-button.css +18 -18
  588. package/src/ui/czi-custom-menu-item.css +30 -30
  589. package/src/ui/czi-custom-menu.css +8 -8
  590. package/src/ui/czi-custom-radio-button.css +80 -80
  591. package/src/ui/czi-custom-scrollbar.css +21 -21
  592. package/src/ui/czi-editor-frameset.css +81 -81
  593. package/src/ui/czi-editor-toolbar.css +122 -122
  594. package/src/ui/czi-editor.css +220 -221
  595. package/src/ui/czi-form.css +104 -104
  596. package/src/ui/czi-frag.css +3 -3
  597. package/src/ui/czi-heading.css +40 -40
  598. package/src/ui/czi-icon.css +72 -72
  599. package/src/ui/czi-image-resize-box.css +165 -165
  600. package/src/ui/czi-image-upload-editor.css +57 -57
  601. package/src/ui/czi-image-upload-placeholder.css +50 -50
  602. package/src/ui/czi-image-url-editor.css +38 -38
  603. package/src/ui/czi-image-view.css +125 -125
  604. package/src/ui/czi-indent.css +137 -137
  605. package/src/ui/czi-inline-editor.css +20 -20
  606. package/src/ui/czi-link-tooltip.css +71 -71
  607. package/src/ui/czi-list.css +410 -410
  608. package/src/ui/czi-loading-indicator.css +111 -111
  609. package/src/ui/czi-math-view.css +62 -62
  610. package/src/ui/czi-pop-up.css +32 -32
  611. package/src/ui/czi-selection-placeholder.css +24 -24
  612. package/src/ui/czi-table-cell-menu.css +14 -14
  613. package/src/ui/czi-table-grid-size-editor.css +37 -37
  614. package/src/ui/czi-table.css +86 -86
  615. package/src/ui/czi-tooltip-surface.css +45 -45
  616. package/src/ui/czi-vars.css +46 -46
  617. package/src/ui/findActiveFontSize.js +58 -58
  618. package/src/ui/findActiveFontType.js +38 -38
  619. package/src/ui/fonts.css +471 -471
  620. package/src/ui/handleEditorDrop.js +28 -28
  621. package/src/ui/handleEditorKeyDown.js +39 -39
  622. package/src/ui/handleEditorPaste.js +33 -33
  623. package/src/ui/htmlElementToRect.js +18 -18
  624. package/src/ui/icon-font.css +10 -10
  625. package/src/ui/injectStyleSheet.js +42 -42
  626. package/src/ui/isElementFullyVisible.js +23 -23
  627. package/src/ui/isOffline.js +8 -8
  628. package/src/ui/isReactClass.js +12 -12
  629. package/src/ui/listType.css +21 -21
  630. package/src/ui/mathquill-editor/MathQuillEditor.js +159 -159
  631. package/src/ui/mathquill-editor/MathQuillEditorSymbols.js +483 -483
  632. package/src/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js +48 -48
  633. package/src/ui/mathquill-editor/czi-mathquill-editor-symbols-panel.css +39 -39
  634. package/src/ui/mathquill-editor/czi-mathquill-editor.css +50 -50
  635. package/src/ui/mathquill-editor/mathquill-import-kludge.js +24 -24
  636. package/src/ui/preventEventDefault.js +5 -5
  637. package/src/ui/rects.js +47 -47
  638. package/src/ui/renderLaTeXAsHTML.js +46 -46
  639. package/src/ui/resolveImage.js +123 -123
  640. package/src/ui/toCSSColor.js +51 -51
  641. package/src/ui/toCSSLineSpacing.js +82 -82
  642. package/src/ui/toHexColor.js +26 -26
  643. package/src/ui/uuid.js +9 -9
  644. package/src/updateIndentLevel.js +211 -260
  645. package/src/uuid.js +9 -9
  646. package/style-service.Dockerfile +26 -26
  647. package/utils/build_bin.js +9 -9
  648. package/utils/build_customstyle_server.js +71 -71
  649. package/utils/build_image_server.js +71 -71
  650. package/utils/build_licit_collab_server.js +75 -75
  651. package/utils/build_web_server.js +40 -40
  652. package/utils/env.js +6 -6
  653. package/webpack.config.js +126 -126
  654. package/dist/CustomStyleCommand.js +0 -1534
  655. package/dist/CustomStyleCommand.js.flow +0 -1690
  656. package/dist/StylePlugin.js +0 -533
  657. package/dist/StylePlugin.js.flow +0 -548
  658. package/dist/clearCustomStyleMarks.js +0 -43
  659. package/dist/clearCustomStyleMarks.js.flow +0 -34
  660. package/dist/customStyle.js +0 -185
  661. package/dist/customStyle.js.flow +0 -171
  662. package/dist/ui/CustomMenuButton.js +0 -155
  663. package/dist/ui/CustomMenuButton.js.flow +0 -129
  664. package/dist/ui/CustomMenuUI.js +0 -479
  665. package/dist/ui/CustomMenuUI.js.flow +0 -464
  666. package/dist/ui/CustomStyleEditor.js +0 -1216
  667. package/dist/ui/CustomStyleEditor.js.flow +0 -1325
  668. package/dist/ui/CustomStyleItem.js +0 -164
  669. package/dist/ui/CustomStyleItem.js.flow +0 -152
  670. package/dist/ui/CustomStyleSubMenu.js +0 -62
  671. package/dist/ui/CustomStyleSubMenu.js.flow +0 -54
  672. package/dist/ui/HeadingCommandMenuButton.js +0 -157
  673. package/dist/ui/HeadingCommandMenuButton.js.flow +0 -147
  674. package/dist/ui/custom-dropdown.css +0 -90
  675. package/dist/ui/custom-style-edit.css +0 -430
  676. package/dist/ui/czi-cust-style-numbered.css +0 -137
  677. package/dist/ui/findActiveCustomStyle.js +0 -53
  678. package/dist/ui/findActiveCustomStyle.js.flow +0 -38
  679. package/src/CustomStyleCommand.js +0 -1690
  680. package/src/StylePlugin.js +0 -548
  681. package/src/clearCustomStyleMarks.js +0 -34
  682. package/src/customStyle.js +0 -171
  683. package/src/ui/CustomMenuButton.js +0 -129
  684. package/src/ui/CustomMenuUI.js +0 -464
  685. package/src/ui/CustomStyleEditor.js +0 -1325
  686. package/src/ui/CustomStyleItem.js +0 -152
  687. package/src/ui/CustomStyleSubMenu.js +0 -54
  688. package/src/ui/HeadingCommandMenuButton.js +0 -147
  689. package/src/ui/custom-dropdown.css +0 -90
  690. package/src/ui/custom-style-edit.css +0 -430
  691. package/src/ui/czi-cust-style-numbered.css +0 -137
  692. package/src/ui/findActiveCustomStyle.js +0 -38
@@ -1,495 +1,562 @@
1
- // @flow
2
- import applyDevTools from 'prosemirror-dev-tools';
3
- import { EditorState, TextSelection, Plugin } from 'prosemirror-state';
4
- import { Node } from 'prosemirror-model';
5
- import { Transform } from 'prosemirror-transform';
6
- import { EditorView } from 'prosemirror-view';
7
- import * as React from 'react';
8
-
9
- import convertFromJSON from '../convertFromJSON';
10
- import RichTextEditor from '../ui/RichTextEditor';
11
- import uuid from '../uuid';
12
- import SimpleConnector from './SimpleConnector';
13
- import CollabConnector from './CollabConnector';
14
- import { EMPTY_DOC_JSON } from '../createEmptyEditorState';
15
- import type { EditorRuntime } from '../Types';
16
- import createPopUp from '../ui/createPopUp';
17
- import { atViewportCenter } from '../ui/PopUpPosition';
18
- import AlertInfo from '../ui/AlertInfo';
19
- import { SetDocAttrStep } from '@modusoperandi/licit-doc-attrs-step';
20
- import './licit.css';
21
- import DefaultEditorPlugins from '../buildEditorPlugins';
22
- import { Schema } from 'prosemirror-model';
23
- import EditorMarks from '../EditorMarks';
24
- import EditorNodes from '../EditorNodes';
25
-
26
- const ATTR_OBJID = 'objectId';
27
- const ATTR_OBJMETADATA = 'objectMetaData';
28
- /**
29
- * LICIT properties:
30
- * docID {number} [0] Collaborative Doument ID
31
- * debug {boolean} [false] To enable/disable ProseMirror Debug Tools, available only in development.
32
- * width {string} [100%] Width of the editor.
33
- * height {height} [100%] Height of the editor.
34
- * readOnly {boolean} [false] To enable/disable editing mode.
35
- * onChange {@callback} [null] Fires after each significant change.
36
- * @param data {JSON} Modified document data.
37
- * onReady {@callback} [null] Fires when the editor is fully ready.
38
- * @param ref {LICIT} Rerefence of the editor.
39
- * data {JSON} [null] Document data to be loaded into the editor.
40
- * disabled {boolean} [false] Disable the editor.
41
- * embedded {boolean} [false] Disable/Enable inline behaviour.
42
- * plugins [plugins] External Plugins into the editor.
43
- */
44
- class Licit extends React.Component<any, any> {
45
- _runtime: EditorRuntime;
46
- _connector: any;
47
- _clientID: string;
48
- _editorView: EditorView; // This will be handy in updating document's content.
49
- _skipSCU: boolean; // Flag to decide whether to skip shouldComponentUpdate
50
- _defaultEditorSchema: Schema;
51
- _defaultEditorPlugins: Array<Plugin>;
52
-
53
- _popUp = null;
54
-
55
- /**
56
- * Provides access to prosemirror view.
57
- */
58
- get editorView(): EditorView {
59
- return this._editorView;
60
- }
61
-
62
- constructor(props: any, context: any) {
63
- super(props, context);
64
- this.state = { loaded: false };
65
- setTimeout((p) => this.loadStyles(p), 100, props);
66
- }
67
-
68
- /**
69
- * Ensures that custom styles are loaded from server before the underlying
70
- * editor is rendered. This is a band-aid method, and is necessary here
71
- * because other parts of the editor attempt to use styles synchronously.
72
- *
73
- * @param {*} props Editor properties passed to constructor
74
- */
75
- async loadStyles(props: any): Promise<void> {
76
- // Only load styles if there's a method to load them.
77
- if (props.runtime && props.runtime.getStylesAsync) {
78
- // Force preload of styles before every editor instance is created.
79
- await props.runtime.getStylesAsync().catch((error) => {
80
- // Log the failure, but proceed to display editor without any styles.
81
- console.warn('Failed to load custom styles:', error);
82
- });
83
- }
84
- this.initialize(props);
85
- }
86
-
87
- initialize(props: any) {
88
- this._clientID = uuid();
89
- this._editorView = null;
90
- this._skipSCU = true;
91
-
92
- const noop = function () {};
93
-
94
- // [FS] IRAD-981 2020-06-10
95
- // Component's configurations.
96
- const docID = props.docID || 0; // 0 < means collaborative.
97
- const collaborative = 0 < docID;
98
- const debug = props.debug || false;
99
- // Default width and height to undefined
100
- const width = props.width || undefined;
101
- const height = props.height || undefined;
102
- const onChangeCB =
103
- typeof props.onChange === 'function' ? props.onChange : noop;
104
- const onReadyCB =
105
- typeof props.onReady === 'function' ? props.onReady : noop;
106
- const readOnly = props.readOnly || false;
107
- const data = props.data || null;
108
- const disabled = props.disabled || false;
109
- const embedded = props.embedded || false; // [FS] IRAD-996 2020-06-30
110
- // [FS] 2020-07-03
111
- // Handle Image Upload from Angular App
112
- const runtime = props.runtime || null;
113
- const plugins = props.plugins || null;
114
-
115
- this._defaultEditorSchema = new Schema({
116
- nodes: EditorNodes,
117
- marks: EditorMarks,
118
- });
119
- this._defaultEditorPlugins = new DefaultEditorPlugins(
120
- this._defaultEditorSchema
121
- ).get();
122
-
123
- let editorState = convertFromJSON(
124
- data,
125
- null,
126
- this._defaultEditorSchema,
127
- plugins,
128
- this._defaultEditorPlugins
129
- );
130
- // [FS] IRAD-1067 2020-09-19
131
- // The editorState will return null if the doc Json is mal-formed
132
- if (null === editorState) {
133
- editorState = convertFromJSON(
134
- EMPTY_DOC_JSON,
135
- null,
136
- this._defaultEditorSchema,
137
- plugins,
138
- this._defaultEditorPlugins
139
- );
140
- this.showAlert();
141
- }
142
-
143
- const setState = this.setState.bind(this);
144
- this._connector = collaborative
145
- ? new CollabConnector(
146
- editorState,
147
- setState,
148
- {
149
- docID,
150
- },
151
- this._defaultEditorSchema,
152
- this._defaultEditorPlugins
153
- )
154
- : new SimpleConnector(editorState, setState);
155
-
156
- const loaded = true;
157
-
158
- // FS IRAD-989 2020-18-06
159
- // updating properties should automatically render the changes
160
-
161
- this.setState({
162
- docID,
163
- data,
164
- editorState,
165
- width,
166
- height,
167
- readOnly,
168
- onChangeCB,
169
- onReadyCB,
170
- debug,
171
- disabled,
172
- embedded,
173
- runtime,
174
- loaded,
175
- });
176
-
177
- // FS IRAD-1040 2020-26-08
178
- // Get the modified schema from editorstate and send it to collab server
179
- if (this._connector.updateSchema) {
180
- // Use known editorState to update schema.
181
- this._connector.updateSchema(editorState.schema);
182
- }
183
- }
184
-
185
- // [FS] IRAD-1067 2020-09-19
186
- // Alert funtion to show document is corrupted
187
- showAlert() {
188
- const anchor = null;
189
- this._popUp = createPopUp(AlertInfo, null, {
190
- anchor,
191
- position: atViewportCenter,
192
- onClose: (val) => {
193
- if (this._popUp) {
194
- this._popUp = null;
195
- }
196
- },
197
- });
198
- }
199
-
200
- resetCounters(transaction: Transform) {
201
- for (let index = 1; index <= 10; index++) {
202
- const counterVar = 'set-cust-style-counter-' + index;
203
- const setCounterVal = window[counterVar];
204
- if (setCounterVal) {
205
- delete window[counterVar];
206
- }
207
- }
208
- this.setCounterFlags(transaction, true);
209
- }
210
-
211
- setCounterFlags(transaction: Transform, reset: boolean) {
212
- let modified = false;
213
- let counterFlags = null;
214
- const existingCFlags = transaction.doc.attrs.counterFlags;
215
- if (reset && !existingCFlags) {
216
- return;
217
- }
218
-
219
- for (let index = 1; index <= 10; index++) {
220
- const counterVar = 'set-cust-style-counter-' + index;
221
-
222
- const setCounterVal = window[counterVar];
223
- if (setCounterVal) {
224
- if (!counterFlags) {
225
- counterFlags = {};
226
- }
227
- counterFlags[counterVar] = true;
228
-
229
- if (!existingCFlags) {
230
- modified = true;
231
- }
232
- }
233
- if (!modified) {
234
- if (existingCFlags) {
235
- if (setCounterVal) {
236
- modified = undefined == existingCFlags[counterVar];
237
- } else {
238
- modified = undefined != existingCFlags[counterVar];
239
- }
240
- } else {
241
- modified = setCounterVal;
242
- }
243
- }
244
- }
245
-
246
- if (modified) {
247
- const tr = this._editorView.state.tr.step(
248
- new SetDocAttrStep('counterFlags', counterFlags)
249
- );
250
- this._editorView.dispatch(tr);
251
- }
252
- }
253
-
254
- getDeletedArtifactIds() {
255
- if (this._connector.getDeletedArtifactIds) {
256
- this._connector.getDeletedArtifactIds(this.state.editorState.schema);
257
- }
258
- }
259
-
260
- isNodeHasAttribute(node: Node, attrName: string) {
261
- return node.attrs && node.attrs[attrName];
262
- }
263
-
264
- setContent = (content: any = {}): void => {
265
- const { doc, schema } = this._connector.getState();
266
- let { tr } = this._connector.getState();
267
- const document = content
268
- ? schema.nodeFromJSON(content)
269
- : schema.nodeFromJSON(EMPTY_DOC_JSON);
270
-
271
- const selection = TextSelection.create(doc, 0, doc.content.size);
272
-
273
- tr = tr.setSelection(selection).replaceSelectionWith(document, false);
274
- // [FS] IRAD-1092 2020-12-03
275
- // set the value for object metadata and objectId
276
- tr = this.isNodeHasAttribute(document, ATTR_OBJMETADATA)
277
- ? tr.step(
278
- new SetDocAttrStep(ATTR_OBJMETADATA, document.attrs.objectMetaData)
279
- )
280
- : tr;
281
- tr = this.isNodeHasAttribute(document, ATTR_OBJID)
282
- ? tr.step(new SetDocAttrStep(ATTR_OBJID, document.attrs.objectId))
283
- : tr;
284
-
285
- this._skipSCU = true;
286
- this._editorView.dispatch(tr);
287
- };
288
-
289
- shouldComponentUpdate(nextProps: any, nextState: any) {
290
- // Only interested if properties are set from outside.
291
- if (!this._skipSCU) {
292
- this._skipSCU = false;
293
- let dataChanged = false;
294
-
295
- // Compare data, if found difference, update editorState
296
- if (this.state.data !== nextState.data) {
297
- dataChanged = true;
298
- } else if (null === nextState.data) {
299
- if (
300
- this.state.editorState.doc.textContent &&
301
- 0 < this.state.editorState.doc.textContent.trim().length
302
- ) {
303
- dataChanged = true;
304
- }
305
- }
306
-
307
- if (dataChanged) {
308
- // data changed, so update document content
309
- this.setContent(nextState.data);
310
- }
311
-
312
- if (this.state.docID !== nextState.docID) {
313
- // Collaborative mode changed
314
- const collabEditing = nextState.docID != 0;
315
- const editorState = this._connector.getState();
316
- const setState = this.setState.bind(this);
317
- const docID = nextState.docID || 1;
318
- // create new connector
319
- this._connector = collabEditing
320
- ? new CollabConnector(
321
- editorState,
322
- setState,
323
- {
324
- docID,
325
- },
326
- this._defaultEditorSchema,
327
- this._defaultEditorPlugins
328
- )
329
- : new SimpleConnector(editorState, setState);
330
- }
331
- }
332
-
333
- return true;
334
- }
335
-
336
- render(): React.Element<any> {
337
- if (this.state.loaded) {
338
- const {
339
- editorState,
340
- width,
341
- height,
342
- readOnly,
343
- disabled,
344
- embedded,
345
- runtime,
346
- } = this.state;
347
- // [FS] IRAD-978 2020-06-05
348
- // Using 100vw & 100vh (100% viewport) is not ideal for a component which is expected to be a part of a page,
349
- // so changing it to 100% width & height which will occupy the area relative to its parent.
350
- return (
351
- <RichTextEditor
352
- disabled={disabled}
353
- editorState={editorState}
354
- embedded={embedded}
355
- height={height}
356
- onChange={this._onChange}
357
- onReady={this._onReady}
358
- readOnly={readOnly}
359
- runtime={runtime}
360
- width={width}
361
- />
362
- );
363
- } else {
364
- return <div>Loading Styles...</div>;
365
- }
366
- }
367
-
368
- _onChange = (data: { state: EditorState, transaction: Transform }): void => {
369
- const { transaction } = data;
370
-
371
- /*
372
- ** ProseMirror Debug Tool's Snapshot creates a new state and sets that to editor view's state.
373
- ** This results in the connector's state as an orphan and thus transaction mismatch error.
374
- ** To resolve check and update the connector's state to keep in sync.
375
- */
376
-
377
- if (this._editorView) {
378
- const isSameState =
379
- this._connector._editorState == this._editorView.state;
380
- let invokeOnEdit = false;
381
-
382
- if (!isSameState) {
383
- this._connector._editorState = this._editorView.state;
384
- invokeOnEdit = true;
385
- } else {
386
- // [FS] IRAD-1264 2021-03-19
387
- // check if in non-collab mode.
388
- if (!(this._connector instanceof CollabConnector)) {
389
- invokeOnEdit = true;
390
- }
391
- }
392
- if (invokeOnEdit) {
393
- // [FS] IRAD-1236 2020-03-05
394
- // Only need to call if there is any difference in collab mode OR always in non-collab mode.
395
- this._connector.onEdit(transaction, this._editorView);
396
- }
397
-
398
- if (transaction.docChanged) {
399
- const docJson = transaction.doc.toJSON();
400
- let isEmpty = false;
401
-
402
- if (docJson.content && docJson.content.length === 1) {
403
- if (
404
- !docJson.content[0].content ||
405
- (docJson.content[0].content &&
406
- docJson.content[0].content[0].text &&
407
- '' === docJson.content[0].content[0].text.trim())
408
- ) {
409
- isEmpty = true;
410
- }
411
- }
412
-
413
- // setCFlags is/was always the opposite of isEmpty.
414
- if (isEmpty) {
415
- this.resetCounters(transaction);
416
- } else {
417
- this.setCounterFlags(transaction, false);
418
- }
419
-
420
- // Changing 2nd parameter from boolean to object was not in any way
421
- // backwards compatible. Any conditional logic placed on isEmpty was
422
- // broken. Reverting that change, then adding view as a 3rd parameter.
423
- this.state.onChangeCB(docJson, isEmpty, this._editorView);
424
-
425
- this.closeOpenedPopupModels();
426
- }
427
- }
428
- };
429
- // [FS] IRAD-1173 2021-02-25
430
- // Bug fix: Transaction mismatch error when a dialog is opened and keep typing.
431
- closeOpenedPopupModels() {
432
- const element = document.getElementsByClassName('czi-pop-up-element')[0];
433
- if (element && element.parentElement) {
434
- element.parentElement.removeChild(element);
435
- }
436
- }
437
-
438
- _onReady = (editorView: EditorView): void => {
439
- // [FS][06-APR-2020][IRAD-922]
440
- // Showing focus in the editor.
441
- const { state, dispatch } = editorView;
442
- this._editorView = editorView;
443
- const tr = state.tr;
444
- const doc = state.doc;
445
- const trx = tr.setSelection(TextSelection.create(doc, 0, doc.content.size));
446
- dispatch(trx.scrollIntoView());
447
- editorView.focus();
448
-
449
- if (this.state.onReadyCB) {
450
- this.state.onReadyCB(this);
451
- }
452
-
453
- if (this.state.debug) {
454
- window.debugProseMirror = () => {
455
- applyDevTools(editorView);
456
- };
457
- window.debugProseMirror();
458
- }
459
- };
460
-
461
- /**
462
- * LICIT properties:
463
- * docID {number} [0] Collaborative Doument ID
464
- * debug {boolean} [false] To enable/disable ProseMirror Debug Tools, available only in development.
465
- * width {string} [100%] Width of the editor.
466
- * height {height} [100%] Height of the editor.
467
- * readOnly {boolean} [false] To enable/disable editing mode.
468
- * onChange {@callback} [null] Fires after each significant change.
469
- * @param data {JSON} Modified document data.
470
- * onReady {@callback} [null] Fires when the editor is fully ready.
471
- * @param ref {LICIT} Rerefence of the editor.
472
- * data {JSON} [null] Document data to be loaded into the editor.
473
- * disabled {boolean} [false] Disable the editor.
474
- * embedded {boolean} [false] Disable/Enable inline behaviour.
475
- */
476
- setProps = (props: any): void => {
477
- if (this.state.readOnly) {
478
- // It should be possible to load content into the editor in readonly as well.
479
- // It should not be necessary to make the component writable any time during the process
480
- const propsCopy = {};
481
- this._skipSCU = true;
482
- Object.assign(propsCopy, props);
483
- // make writable without content change
484
- propsCopy.readOnly = false;
485
- delete propsCopy.data;
486
- this.setState(propsCopy);
487
- }
488
- // Need to go through shouldComponentUpdate lifecycle here, when updated from outside,
489
- // so that content is modified gracefully using transaction so that undo/redo works too.
490
- this._skipSCU = false;
491
- this.setState(props);
492
- };
493
- }
494
-
495
- export default Licit;
1
+ // @flow
2
+ import { EditorState, TextSelection, Plugin } from 'prosemirror-state';
3
+ import { Node } from 'prosemirror-model';
4
+ import { Transform } from 'prosemirror-transform';
5
+ import { EditorView } from 'prosemirror-view';
6
+ import * as React from 'react';
7
+ import ReactDOM from 'react-dom';
8
+ import { stringify } from 'flatted';
9
+
10
+ import convertFromJSON from '../convertFromJSON';
11
+ import RichTextEditor from '../ui/RichTextEditor';
12
+ import uuid from '../uuid';
13
+ import SimpleConnector from './SimpleConnector';
14
+ import CollabConnector from './CollabConnector';
15
+ import { EMPTY_DOC_JSON } from '../createEmptyEditorState';
16
+ import type { EditorRuntime } from '../Types';
17
+ import createPopUp from '../ui/createPopUp';
18
+ import { atViewportCenter } from '../ui/PopUpPosition';
19
+ import AlertInfo from '../ui/AlertInfo';
20
+ import { SetDocAttrStep } from '@modusoperandi/licit-doc-attrs-step';
21
+ import './licit.css';
22
+ import DefaultEditorPlugins from '../buildEditorPlugins';
23
+ import { Schema } from 'prosemirror-model';
24
+ import EditorMarks from '../EditorMarks';
25
+ import EditorNodes from '../EditorNodes';
26
+
27
+ const ATTR_OBJID = 'objectId';
28
+ const ATTR_OBJMETADATA = 'objectMetaData';
29
+ /**
30
+ * LICIT properties:
31
+ * docID {string} [] Collaborative Doument ID
32
+ * collabServiceURL {string} [/collaboration-service] Collaboration Service URL
33
+ * debug {boolean} [false] To enable/disable ProseMirror Debug Tools, available only in development.
34
+ * width {string} [100%] Width of the editor.
35
+ * height {string} [100%] Height of the editor.
36
+ * readOnly {boolean} [false] To enable/disable editing mode.
37
+ * onChange {@callback} [null] Fires after each significant change.
38
+ * @param data {JSON} Modified document data.
39
+ * onReady {@callback} [null] Fires when the editor is fully ready.
40
+ * @param ref {LICIT} Rerefence of the editor.
41
+ * data {JSON} [null] Document data to be loaded into the editor.
42
+ * disabled {boolean} [false] Disable the editor.
43
+ * embedded {boolean} [false] Disable/Enable inline behaviour.
44
+ * plugins [plugins] External Plugins into the editor.
45
+ */
46
+ class Licit extends React.Component<any, any> {
47
+ _runtime: EditorRuntime;
48
+ _connector: any;
49
+ _clientID: string;
50
+ _editorView: EditorView; // This will be handy in updating document's content.
51
+ _skipSCU: boolean; // Flag to decide whether to skip shouldComponentUpdate
52
+ _defaultEditorSchema: Schema;
53
+ _defaultEditorPlugins: Array<Plugin>;
54
+ _devTools: Promise<any>;
55
+ _applyDevTools: any;
56
+
57
+ _popUp = null;
58
+
59
+ /**
60
+ * Provides access to prosemirror view.
61
+ */
62
+ get editorView(): EditorView {
63
+ return this._editorView;
64
+ }
65
+
66
+ constructor(props: any, context: any) {
67
+ super(props, context);
68
+ this.initialize(props);
69
+ }
70
+
71
+ initialize(props: any) {
72
+ this._clientID = uuid();
73
+ this._editorView = null;
74
+ this._skipSCU = true;
75
+
76
+ const noop = function () {};
77
+
78
+ // [FS] IRAD-981 2020-06-10
79
+ // Component's configurations.
80
+ // [FS] IRAD-1552 2021-08-26
81
+ // Collaboration server / client should allow string values for document identifiers.
82
+ const docID = props.docID || ''; // Empty means collaborative.
83
+ const collaborative = docID !== '';
84
+ // [FS] IRAD-1553 2021-08-26
85
+ // Configurable Collaboration Service URL.
86
+ const collabServiceURL = props.collabServiceURL || '/collaboration-service';
87
+ const debug = props.debug || false;
88
+ // Default width and height to undefined
89
+ const width = props.width || undefined;
90
+ const height = props.height || undefined;
91
+ const onChangeCB =
92
+ typeof props.onChange === 'function' ? props.onChange : noop;
93
+ const onReadyCB =
94
+ typeof props.onReady === 'function' ? props.onReady : noop;
95
+ const readOnly = props.readOnly || false;
96
+ const data = props.data || null;
97
+ const disabled = props.disabled || false;
98
+ const embedded = props.embedded || false; // [FS] IRAD-996 2020-06-30
99
+ // [FS] 2020-07-03
100
+ // Handle Image Upload from Angular App
101
+ const runtime = props.runtime || null;
102
+ const plugins = props.plugins || null;
103
+
104
+ this._defaultEditorSchema = new Schema({
105
+ nodes: EditorNodes,
106
+ marks: EditorMarks,
107
+ });
108
+ this._defaultEditorPlugins = new DefaultEditorPlugins(
109
+ this._defaultEditorSchema
110
+ ).get();
111
+
112
+ let editorState = convertFromJSON(
113
+ data,
114
+ null,
115
+ this._defaultEditorSchema,
116
+ plugins,
117
+ this._defaultEditorPlugins
118
+ );
119
+ // [FS] IRAD-1067 2020-09-19
120
+ // The editorState will return null if the doc Json is mal-formed
121
+ if (null === editorState) {
122
+ editorState = convertFromJSON(
123
+ EMPTY_DOC_JSON,
124
+ null,
125
+ this._defaultEditorSchema,
126
+ plugins,
127
+ this._defaultEditorPlugins
128
+ );
129
+ this.showAlert();
130
+ }
131
+
132
+ const setState = this.setState.bind(this);
133
+ this._connector = collaborative
134
+ ? new CollabConnector(
135
+ editorState,
136
+ setState,
137
+ {
138
+ docID,
139
+ collabServiceURL,
140
+ },
141
+ this._defaultEditorSchema,
142
+ this._defaultEditorPlugins,
143
+ // [FS] IRAD-1578 2021-09-27
144
+ this.onReady.bind(this)
145
+ )
146
+ : new SimpleConnector(editorState, setState);
147
+
148
+ // FS IRAD-989 2020-18-06
149
+ // updating properties should automatically render the changes
150
+
151
+ this.state = {
152
+ docID,
153
+ collabServiceURL,
154
+ data,
155
+ editorState,
156
+ width,
157
+ height,
158
+ readOnly,
159
+ onChangeCB,
160
+ onReadyCB,
161
+ debug,
162
+ disabled,
163
+ embedded,
164
+ runtime,
165
+ };
166
+
167
+ // FS IRAD-1040 2020-26-08
168
+ // Get the modified schema from editorstate and send it to collab server
169
+ if (this._connector.updateSchema) {
170
+ // Use known editorState to update schema.
171
+ this._connector.updateSchema(editorState.schema);
172
+ }
173
+ }
174
+
175
+ // [FS] IRAD-1578 2021-09-27
176
+ onReady(state: EditorState) {
177
+ const collabEditing = this.state.docID !== '';
178
+
179
+ if (collabEditing) {
180
+ this._editorView && this._editorView.focus();
181
+ if (this.state.onReadyCB) {
182
+ this.state.onReadyCB(this);
183
+ }
184
+ }
185
+ }
186
+
187
+ // [FS] IRAD-1067 2020-09-19
188
+ // Alert funtion to show document is corrupted
189
+ showAlert() {
190
+ const anchor = null;
191
+ this._popUp = createPopUp(AlertInfo, null, {
192
+ anchor,
193
+ position: atViewportCenter,
194
+ onClose: (val) => {
195
+ if (this._popUp) {
196
+ this._popUp = null;
197
+ }
198
+ },
199
+ });
200
+ }
201
+
202
+ resetCounters(transaction: Transform) {
203
+ for (let index = 1; index <= 10; index++) {
204
+ const counterVar = 'set-cust-style-counter-' + index;
205
+ const setCounterVal = window[counterVar];
206
+ if (setCounterVal) {
207
+ delete window[counterVar];
208
+ }
209
+ }
210
+ this.setCounterFlags(transaction, true);
211
+ }
212
+
213
+ setCounterFlags(transaction: Transform, reset: boolean) {
214
+ let modified = false;
215
+ let counterFlags = null;
216
+ const existingCFlags = transaction.doc.attrs.counterFlags;
217
+ if (reset && !existingCFlags) {
218
+ return;
219
+ }
220
+
221
+ for (let index = 1; index <= 10; index++) {
222
+ const counterVar = 'set-cust-style-counter-' + index;
223
+
224
+ const setCounterVal = window[counterVar];
225
+ if (setCounterVal) {
226
+ if (!counterFlags) {
227
+ counterFlags = {};
228
+ }
229
+ counterFlags[counterVar] = true;
230
+
231
+ if (!existingCFlags) {
232
+ modified = true;
233
+ }
234
+ }
235
+ if (!modified) {
236
+ if (existingCFlags) {
237
+ if (setCounterVal) {
238
+ modified = undefined == existingCFlags[counterVar];
239
+ } else {
240
+ modified = undefined != existingCFlags[counterVar];
241
+ }
242
+ } else {
243
+ modified = setCounterVal;
244
+ }
245
+ }
246
+ }
247
+
248
+ if (modified) {
249
+ const tr = this._editorView.state.tr.step(
250
+ new SetDocAttrStep('counterFlags', counterFlags)
251
+ );
252
+ this._editorView.dispatch(tr);
253
+ }
254
+ }
255
+
256
+ getDeletedArtifactIds() {
257
+ if (this._connector.getDeletedArtifactIds) {
258
+ this._connector.getDeletedArtifactIds(this.state.editorState.schema);
259
+ }
260
+ }
261
+
262
+ isNodeHasAttribute(node: Node, attrName: string) {
263
+ return node.attrs && node.attrs[attrName];
264
+ }
265
+
266
+ setContent = (content: any = {}): void => {
267
+ // [FS] IRAD-1571 2021-09-27
268
+ // dispatch a transaction that MUST start from the view�s current state;
269
+ const editorState = this._editorView.state;
270
+ const { doc, schema } = editorState;
271
+ let { tr } = editorState;
272
+ const document = schema.nodeFromJSON(content ? content : EMPTY_DOC_JSON);
273
+
274
+ const selection = TextSelection.create(doc, 0, doc.content.size);
275
+
276
+ tr = tr.setSelection(selection).replaceSelectionWith(document, false);
277
+ // [FS] IRAD-1092 2020-12-03
278
+ // set the value for object metadata and objectId
279
+ tr = this.isNodeHasAttribute(document, ATTR_OBJMETADATA)
280
+ ? tr.step(
281
+ new SetDocAttrStep(ATTR_OBJMETADATA, document.attrs.objectMetaData)
282
+ )
283
+ : tr;
284
+ tr = this.isNodeHasAttribute(document, ATTR_OBJID)
285
+ ? tr.step(new SetDocAttrStep(ATTR_OBJID, document.attrs.objectId))
286
+ : tr;
287
+
288
+ this._skipSCU = true;
289
+ this._editorView.dispatch(tr);
290
+ };
291
+
292
+ shouldComponentUpdate(nextProps: any, nextState: any) {
293
+ // Only interested if properties are set from outside.
294
+ if (!this._skipSCU) {
295
+ this._skipSCU = false;
296
+ let dataChanged = false;
297
+
298
+ // [FS] IRAD-1571 2021-09-27
299
+ // dispatch a transaction that MUST start from the view�s current state;
300
+ // [FS] IRAD-1589 2021-10-04
301
+ // Do a proper circular JSON comparison.
302
+ if (stringify(this.state.data) !== stringify(nextState.data)) {
303
+ const editorState = this._editorView.state;
304
+ const nextDoc = editorState.schema.nodeFromJSON(
305
+ nextState.data ? nextState.data : EMPTY_DOC_JSON
306
+ );
307
+ dataChanged = !nextDoc.eq(editorState.doc);
308
+ }
309
+
310
+ if (dataChanged) {
311
+ // data changed, so update document content
312
+ this.setContent(nextState.data);
313
+ }
314
+
315
+ if (this.state.docID !== nextState.docID) {
316
+ // Collaborative mode changed
317
+ const collabEditing = nextState.docID !== '';
318
+ const editorState = this._editorView.state;
319
+ const setState = this.setState.bind(this);
320
+ const docID = nextState.docID || '';
321
+ const collabServiceURL =
322
+ nextState.collabServiceURL || '/collaboration-service';
323
+ // create new connector
324
+ this._connector = collabEditing
325
+ ? new CollabConnector(
326
+ editorState,
327
+ setState,
328
+ {
329
+ docID,
330
+ collabServiceURL,
331
+ },
332
+ this._defaultEditorSchema,
333
+ this._defaultEditorPlugins,
334
+ // [FS] IRAD-1578 2021-09-27
335
+ this.onReady.bind(this)
336
+ )
337
+ : new SimpleConnector(editorState, setState);
338
+ }
339
+ }
340
+
341
+ return true;
342
+ }
343
+
344
+ render(): React.Element<any> {
345
+ const {
346
+ editorState,
347
+ width,
348
+ height,
349
+ readOnly,
350
+ disabled,
351
+ embedded,
352
+ runtime,
353
+ } = this.state;
354
+ // [FS] IRAD-978 2020-06-05
355
+ // Using 100vw & 100vh (100% viewport) is not ideal for a component which is expected to be a part of a page,
356
+ // so changing it to 100% width & height which will occupy the area relative to its parent.
357
+ return (
358
+ <RichTextEditor
359
+ disabled={disabled}
360
+ editorState={editorState}
361
+ embedded={embedded}
362
+ height={height}
363
+ onChange={this._onChange}
364
+ onReady={this._onReady}
365
+ readOnly={readOnly}
366
+ runtime={runtime}
367
+ width={width}
368
+ />
369
+ );
370
+ }
371
+
372
+ _onChange = (data: { state: EditorState, transaction: Transform }): void => {
373
+ const { transaction } = data;
374
+
375
+ /*
376
+ ** ProseMirror Debug Tool's Snapshot creates a new state and sets that to editor view's state.
377
+ ** This results in the connector's state as an orphan and thus transaction mismatch error.
378
+ ** To resolve check and update the connector's state to keep in sync.
379
+ */
380
+
381
+ if (this._editorView) {
382
+ const isSameState =
383
+ this._connector._editorState == this._editorView.state;
384
+ let invokeOnEdit = false;
385
+
386
+ if (!isSameState) {
387
+ this._connector._editorState = this._editorView.state;
388
+ invokeOnEdit = true;
389
+ } else {
390
+ // [FS] IRAD-1264 2021-03-19
391
+ // check if in non-collab mode.
392
+ if (!(this._connector instanceof CollabConnector)) {
393
+ invokeOnEdit = true;
394
+ }
395
+ }
396
+ if (invokeOnEdit) {
397
+ // [FS] IRAD-1236 2020-03-05
398
+ // Only need to call if there is any difference in collab mode OR always in non-collab mode.
399
+ this._connector.onEdit(transaction, this._editorView);
400
+ }
401
+
402
+ if (transaction.docChanged) {
403
+ const docJson = transaction.doc.toJSON();
404
+ let isEmpty = false;
405
+
406
+ if (docJson.content && docJson.content.length === 1) {
407
+ if (
408
+ !docJson.content[0].content ||
409
+ (docJson.content[0].content &&
410
+ docJson.content[0].content[0].text &&
411
+ '' === docJson.content[0].content[0].text.trim())
412
+ ) {
413
+ isEmpty = true;
414
+ }
415
+ }
416
+
417
+ // setCFlags is/was always the opposite of isEmpty.
418
+ if (isEmpty) {
419
+ this.resetCounters(transaction);
420
+ } else {
421
+ this.setCounterFlags(transaction, false);
422
+ }
423
+
424
+ // Changing 2nd parameter from boolean to object was not in any way
425
+ // backwards compatible. Any conditional logic placed on isEmpty was
426
+ // broken. Reverting that change, then adding view as a 3rd parameter.
427
+ this.state.onChangeCB(docJson, isEmpty, this._editorView);
428
+
429
+ this.closeOpenedPopupModels();
430
+ }
431
+ }
432
+ };
433
+ // [FS] IRAD-1173 2021-02-25
434
+ // Bug fix: Transaction mismatch error when a dialog is opened and keep typing.
435
+ closeOpenedPopupModels() {
436
+ const element = document.getElementsByClassName('czi-pop-up-element')[0];
437
+ if (element && element.parentElement) {
438
+ element.parentElement.removeChild(element);
439
+ }
440
+ }
441
+
442
+ _onReady = (editorView: EditorView): void => {
443
+ // [FS][06-APR-2020][IRAD-922]
444
+ // Showing focus in the editor.
445
+ const { state, dispatch } = editorView;
446
+ this._editorView = editorView;
447
+ const tr = state.tr;
448
+ const doc = state.doc;
449
+ const trx = tr.setSelection(TextSelection.create(doc, 0, doc.content.size));
450
+ dispatch(trx.scrollIntoView());
451
+
452
+ // [FS] IRAD-1578 2021-09-27
453
+ // In collab mode, fire onRead only after getting the response from collab server.
454
+ if (this.state.onReadyCB && this.state.docID === '') {
455
+ editorView.focus();
456
+ this.state.onReadyCB(this);
457
+ }
458
+
459
+ this.initDevTool(this.state.debug, editorView);
460
+ };
461
+
462
+ initDevTool(debug: boolean, editorView: EditorView): void {
463
+ // [FS] IRAD-1575 2021-09-27
464
+ if (debug) {
465
+ if (!this._devTools) {
466
+ this._devTools = new Promise(async (resolve, reject) => {
467
+ try {
468
+ // Method is exported as both the default and named, Using named
469
+ // for clarity and future proofing.
470
+ const { applyDevTools } = await import('prosemirror-dev-tools');
471
+ // got the pm dev tools instance.
472
+ this._applyDevTools = applyDevTools;
473
+ // Attach debug tools to current editor instance.
474
+ this._applyDevTools(editorView);
475
+ resolve(() => {
476
+ // [FS] IRAD-1571 2021-10-08
477
+ // Prosemirror Dev Tools handles as if one only instance is used in a page and
478
+ // hence handling removal here gracefully.
479
+ const place = document.querySelector(
480
+ '.'.concat('__prosemirror-dev-tools__')
481
+ );
482
+ if (place) {
483
+ ReactDOM.unmountComponentAtNode(place);
484
+ place.innerHTML = '';
485
+ }
486
+ });
487
+ } catch (error) {
488
+ reject();
489
+ }
490
+ });
491
+ }
492
+
493
+ // Attach debug tools to current editor instance.
494
+ if (this._devTools && this._applyDevTools) {
495
+ this._applyDevTools(editorView);
496
+ }
497
+ }
498
+ }
499
+
500
+ destroyDevTool(): void {
501
+ // [FS] IRAD-1569 2021-09-15
502
+ // Unmount dev tools when component is destroyed,
503
+ // so that toggle effect is not occuring when the document is retrieved each time.
504
+ if (this._devTools) {
505
+ // Call the applyDevTools method again to trigger DOM removal
506
+ // prosemirror-dev-tools has outstanding pull-requests that affect
507
+ // dom removal. this may need to be addressed once those have been merged.
508
+ this._devTools.then((removeDevTools) => removeDevTools());
509
+ }
510
+ }
511
+
512
+ componentWillUnmount(): void {
513
+ this.destroyDevTool();
514
+ }
515
+
516
+ /**
517
+ * LICIT properties:
518
+ * docID {number} [0] Collaborative Doument ID
519
+ * debug {boolean} [false] To enable/disable ProseMirror Debug Tools, available only in development.
520
+ * width {string} [100%] Width of the editor.
521
+ * height {height} [100%] Height of the editor.
522
+ * readOnly {boolean} [false] To enable/disable editing mode.
523
+ * onChange {@callback} [null] Fires after each significant change.
524
+ * @param data {JSON} Modified document data.
525
+ * onReady {@callback} [null] Fires when the editor is fully ready.
526
+ * @param ref {LICIT} Rerefence of the editor.
527
+ * data {JSON} [null] Document data to be loaded into the editor.
528
+ * disabled {boolean} [false] Disable the editor.
529
+ * embedded {boolean} [false] Disable/Enable inline behaviour.
530
+ */
531
+ setProps = (props: any): void => {
532
+ // [FS] IRAD-1571 2021-10-08
533
+ // Since the debug lies outside the editor,
534
+ // any change to debug tool must be refreshed here.
535
+ if (this.state.debug !== props.debug) {
536
+ // change in debug flag.
537
+ if (props.debug) {
538
+ this.initDevTool(true, this._editorView);
539
+ } else {
540
+ this.destroyDevTool();
541
+ }
542
+ }
543
+
544
+ if (this.state.readOnly) {
545
+ // It should be possible to load content into the editor in readonly as well.
546
+ // It should not be necessary to make the component writable any time during the process
547
+ const propsCopy = {};
548
+ this._skipSCU = true;
549
+ Object.assign(propsCopy, props);
550
+ // make writable without content change
551
+ propsCopy.readOnly = false;
552
+ delete propsCopy.data;
553
+ this.setState(propsCopy);
554
+ }
555
+ // Need to go through shouldComponentUpdate lifecycle here, when updated from outside,
556
+ // so that content is modified gracefully using transaction so that undo/redo works too.
557
+ this._skipSCU = false;
558
+ this.setState(props);
559
+ };
560
+ }
561
+
562
+ export default Licit;