@modusoperandi/licit 0.1.10 → 0.13.3

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 (725) 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 +29 -35
  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 -286
  16. package/babel.config.json +54 -0
  17. package/build_collab_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 +2 -2
  26. package/dist/CodeBlockCommand.js.flow +43 -43
  27. package/dist/CodeBlockNodeSpec.js.flow +24 -24
  28. package/dist/CodeMarkSpec.js.flow +14 -14
  29. package/dist/ContentPlaceholderPlugin.js.flow +187 -187
  30. package/dist/CursorPlaceholderPlugin.js.flow +115 -115
  31. package/dist/DocLayoutCommand.js +2 -4
  32. package/dist/DocLayoutCommand.js.flow +94 -94
  33. package/dist/DocNodeSpec.js.flow +64 -64
  34. package/dist/EMMarkSpec.js.flow +14 -14
  35. package/dist/EditorCommands.js +22 -34
  36. package/dist/EditorCommands.js.flow +128 -128
  37. package/dist/EditorKeyMap.js.flow +187 -187
  38. package/dist/EditorMarks.js.flow +71 -71
  39. package/dist/EditorNodes.js.flow +60 -60
  40. package/dist/EditorPageLayoutPlugin.js.flow +67 -67
  41. package/dist/EditorPlugins.js.flow +8 -8
  42. package/dist/EditorSchema.js.flow +12 -12
  43. package/dist/EditorState.js.flow +7 -7
  44. package/dist/FontSizeMarkSpec.js.flow +49 -49
  45. package/dist/FontTypeMarkSpec.js.flow +80 -80
  46. package/dist/HTMLMutator.js.flow +59 -59
  47. package/dist/HardBreakNodeSpec.js.flow +15 -15
  48. package/dist/HeadingNodeSpec.js.flow +54 -54
  49. package/dist/HistoryRedoCommand.js.flow +20 -20
  50. package/dist/HistoryUndoCommand.js.flow +20 -20
  51. package/dist/HorizontalRuleCommand.js.flow +49 -49
  52. package/dist/HorizontalRuleNodeSpec.js.flow +39 -39
  53. package/dist/ImageFromURLCommand.js.flow +14 -14
  54. package/dist/ImageNodeSpec.js.flow +90 -90
  55. package/dist/ImageSourceCommand.js +2 -4
  56. package/dist/ImageSourceCommand.js.flow +117 -117
  57. package/dist/ImageUploadCommand.js.flow +36 -36
  58. package/dist/ImageUploadPlaceholderPlugin.js.flow +192 -192
  59. package/dist/LinkMarkSpec.js.flow +32 -32
  60. package/dist/LinkSetURLCommand.js +4 -8
  61. package/dist/LinkSetURLCommand.js.flow +103 -103
  62. package/dist/LinkTooltipPlugin.js +9 -15
  63. package/dist/LinkTooltipPlugin.js.flow +203 -203
  64. package/dist/ListItemInsertNewLineCommand.js.flow +55 -55
  65. package/dist/ListItemMergeCommand.js.flow +177 -177
  66. package/dist/ListItemNodeSpec.js.flow +51 -51
  67. package/dist/ListSplitCommand.js.flow +32 -32
  68. package/dist/ListToggleCommand.js +4 -10
  69. package/dist/ListToggleCommand.js.flow +77 -77
  70. package/dist/MarkNames.js.flow +18 -18
  71. package/dist/MarksClearCommand.js +3 -3
  72. package/dist/MarksClearCommand.js.flow +42 -42
  73. package/dist/MathEditCommand.js +2 -2
  74. package/dist/MathEditCommand.js.flow +110 -110
  75. package/dist/MathNodeSpec.js.flow +46 -46
  76. package/dist/NodeNames.js.flow +23 -23
  77. package/dist/OrderedListNodeSpec.js.flow +132 -132
  78. package/dist/ParagraphNodeSpec.js +1 -3
  79. package/dist/ParagraphNodeSpec.js.flow +156 -160
  80. package/dist/ParagraphSpacingCommand.js.flow +121 -121
  81. package/dist/PrintCommand.js.flow +31 -31
  82. package/dist/SelectionPlaceholderPlugin.js.flow +131 -131
  83. package/dist/SpacerMarkSpec.js.flow +47 -47
  84. package/dist/StrikeMarkSpec.js.flow +21 -21
  85. package/dist/StrongMarkSpec.js.flow +25 -25
  86. package/dist/StyleView.js.flow +19 -19
  87. package/dist/TableBackgroundColorCommand.js +3 -7
  88. package/dist/TableBackgroundColorCommand.js.flow +75 -75
  89. package/dist/TableBorderColorCommand.js +3 -7
  90. package/dist/TableBorderColorCommand.js.flow +75 -75
  91. package/dist/TableCellColorCommand.js +3 -7
  92. package/dist/TableCellColorCommand.js.flow +71 -71
  93. package/dist/TableCellMenuPlugin.js +4 -6
  94. package/dist/TableCellMenuPlugin.js.flow +125 -125
  95. package/dist/TableInsertCommand.js +3 -5
  96. package/dist/TableInsertCommand.js.flow +112 -112
  97. package/dist/TableMergeCellsCommand.js.flow +90 -90
  98. package/dist/TableNodesSpecs.js.flow +78 -78
  99. package/dist/TablePlugins.js.flow +14 -14
  100. package/dist/TableResizePlugin.js.flow +631 -631
  101. package/dist/TextColorMarkSpec.js.flow +35 -35
  102. package/dist/TextHighlightMarkSpec.js.flow +38 -38
  103. package/dist/TextInsertTabSpaceCommand.js +2 -4
  104. package/dist/TextInsertTabSpaceCommand.js.flow +83 -83
  105. package/dist/TextNoWrapMarkSpec.js.flow +14 -14
  106. package/dist/TextNodeSpec.js.flow +7 -7
  107. package/dist/TextSelectionMarkSpec.js.flow +24 -24
  108. package/dist/TextSubMarkSpec.js.flow +20 -20
  109. package/dist/TextSuperMarkSpec.js.flow +20 -20
  110. package/dist/TextUnderlineMarkSpec.js.flow +27 -27
  111. package/dist/Types.js.flow +75 -75
  112. package/dist/WebFontLoader.js.flow +22 -22
  113. package/dist/blockQuoteInputRule.js.flow +36 -36
  114. package/dist/bom.xml +11579 -6489
  115. package/dist/browser.js.flow +7 -7
  116. package/dist/buildEditorPlugins.js.flow +51 -51
  117. package/dist/buildInputRules.js.flow +81 -81
  118. package/dist/client/CollabConnector.js +17 -2
  119. package/dist/client/CollabConnector.js.flow +86 -71
  120. package/dist/client/EditorConnection.js +15 -4
  121. package/dist/client/EditorConnection.js.flow +318 -307
  122. package/dist/client/Licit.js +109 -94
  123. package/dist/client/Licit.js.flow +592 -578
  124. package/dist/client/Licit.test.js +7 -7
  125. package/dist/client/Licit.test.js.flow +67 -67
  126. package/dist/client/Reporter.js.flow +37 -37
  127. package/dist/client/SimpleConnector.js +3 -1
  128. package/dist/client/SimpleConnector.js.flow +55 -53
  129. package/dist/client/http.js.flow +66 -66
  130. package/dist/client/licit.css +12 -12
  131. package/dist/client/throttle.js.flow +27 -27
  132. package/dist/convertFromDOMElement.js.flow +36 -36
  133. package/dist/convertFromHTML.js.flow +19 -19
  134. package/dist/convertFromJSON.js.flow +78 -78
  135. package/dist/convertToCSSPTValue.js.flow +22 -22
  136. package/dist/convertToJSON.js.flow +7 -7
  137. package/dist/createCommand.js.flow +40 -40
  138. package/dist/createEditorKeyMap.js.flow +94 -94
  139. package/dist/createEmptyEditorState.js.flow +35 -35
  140. package/dist/createTableResizingPlugin.js.flow +86 -86
  141. package/dist/findActionableCell.js.flow +74 -74
  142. package/dist/findActiveMark.js.flow +32 -32
  143. package/dist/hyphenize.js.flow +17 -17
  144. package/dist/index.js.flow +10 -10
  145. package/dist/insertTable.js.flow +56 -56
  146. package/dist/isEditorStateEmpty.js.flow +32 -32
  147. package/dist/isTableNode.js.flow +15 -15
  148. package/dist/joinDown.js.flow +27 -27
  149. package/dist/joinListNode.js +2 -2
  150. package/dist/joinListNode.js.flow +55 -55
  151. package/dist/joinUp.js.flow +39 -39
  152. package/dist/keymaps.js.flow +185 -185
  153. package/dist/lookUpElement.js.flow +14 -14
  154. package/dist/nodeAt.js.flow +12 -12
  155. package/dist/normalizeHTML.js.flow +78 -78
  156. package/dist/patchAnchorElements.js.flow +38 -38
  157. package/dist/patchBreakElements.js.flow +22 -22
  158. package/dist/patchElementInlineStyles.js.flow +92 -92
  159. package/dist/patchListElements.js.flow +276 -276
  160. package/dist/patchMathElements.js.flow +60 -60
  161. package/dist/patchParagraphElements.js.flow +20 -20
  162. package/dist/patchStyleElements.js +2 -2
  163. package/dist/patchStyleElements.js.flow +194 -194
  164. package/dist/patchTableElements.js.flow +89 -89
  165. package/dist/rebaseDocWithSteps.js.flow +42 -42
  166. package/dist/sanitizeURL.js.flow +13 -13
  167. package/dist/splitListItem.js.flow +191 -191
  168. package/dist/styles.css +19 -19
  169. package/dist/styles0.css +29 -29
  170. package/dist/toClosestFontPtSize.js.flow +22 -22
  171. package/dist/toSafeHTMLDocument.js.flow +9 -9
  172. package/dist/toggleBlockquote.js +6 -14
  173. package/dist/toggleBlockquote.js.flow +91 -91
  174. package/dist/toggleCodeBlock.js +4 -10
  175. package/dist/toggleCodeBlock.js.flow +102 -102
  176. package/dist/ui/AlertInfo.js.flow +64 -64
  177. package/dist/ui/BookmarkNodeView.js.flow +66 -66
  178. package/dist/ui/CommandButton.js +2 -4
  179. package/dist/ui/CommandButton.js.flow +68 -68
  180. package/dist/ui/CommandMenu.js.flow +75 -75
  181. package/dist/ui/CommandMenuButton.js +3 -5
  182. package/dist/ui/CommandMenuButton.js.flow +131 -131
  183. package/dist/ui/CustomEditorView.js.flow +28 -28
  184. package/dist/ui/CustomMenu.js.flow +17 -17
  185. package/dist/ui/CustomMenuItem.js +3 -5
  186. package/dist/ui/CustomMenuItem.js.flow +36 -36
  187. package/dist/ui/CustomNodeView.js.flow +200 -200
  188. package/dist/ui/CustomRadioButton.js +6 -6
  189. package/dist/ui/CustomRadioButton.js.flow +65 -65
  190. package/dist/ui/DocLayoutEditor.js +4 -6
  191. package/dist/ui/DocLayoutEditor.js.flow +146 -146
  192. package/dist/ui/Editor.js.flow +290 -290
  193. package/dist/ui/EditorFrameset.js.flow +81 -81
  194. package/dist/ui/EditorToolbar.js +2 -2
  195. package/dist/ui/EditorToolbar.js.flow +211 -211
  196. package/dist/ui/EditorToolbarConfig.js.flow +172 -172
  197. package/dist/ui/FontSizeCommandMenuButton.js +3 -3
  198. package/dist/ui/FontSizeCommandMenuButton.js.flow +66 -66
  199. package/dist/ui/FontTypeCommandMenuButton.js +3 -3
  200. package/dist/ui/FontTypeCommandMenuButton.js.flow +49 -49
  201. package/dist/ui/Frag.js.flow +13 -13
  202. package/dist/ui/Icon.js.flow +89 -89
  203. package/dist/ui/ImageAlignEditor.js +4 -4
  204. package/dist/ui/ImageAlignEditor.js.flow +60 -60
  205. package/dist/ui/ImageInlineEditor.js +4 -4
  206. package/dist/ui/ImageInlineEditor.js.flow +67 -67
  207. package/dist/ui/ImageNodeView.js +3 -5
  208. package/dist/ui/ImageNodeView.js.flow +404 -404
  209. package/dist/ui/ImageResizeBox.js +3 -3
  210. package/dist/ui/ImageResizeBox.js.flow +219 -219
  211. package/dist/ui/ImageURLEditor.js +4 -6
  212. package/dist/ui/ImageURLEditor.js.flow +119 -119
  213. package/dist/ui/ImageUploadEditor.js +3 -5
  214. package/dist/ui/ImageUploadEditor.js.flow +117 -117
  215. package/dist/ui/KeyCodes.js.flow +12 -12
  216. package/dist/ui/LinkTooltip.js +4 -4
  217. package/dist/ui/LinkTooltip.js.flow +85 -85
  218. package/dist/ui/LinkURLEditor.js +4 -6
  219. package/dist/ui/LinkURLEditor.js.flow +111 -111
  220. package/dist/ui/ListItemNodeView.js.flow +98 -98
  221. package/dist/ui/ListTypeButton.js +3 -5
  222. package/dist/ui/ListTypeButton.js.flow +131 -131
  223. package/dist/ui/ListTypeCommandButton.js.flow +85 -85
  224. package/dist/ui/ListTypeMenu.js.flow +70 -70
  225. package/dist/ui/LoadingIndicator.js.flow +20 -20
  226. package/dist/ui/MathEditor.js +4 -6
  227. package/dist/ui/MathEditor.js.flow +78 -78
  228. package/dist/ui/MathInlineEditor.js +4 -6
  229. package/dist/ui/MathInlineEditor.js.flow +102 -102
  230. package/dist/ui/MathNodeView.js +3 -5
  231. package/dist/ui/MathNodeView.js.flow +175 -175
  232. package/dist/ui/PasteMenu.js.flow +57 -57
  233. package/dist/ui/ResizeObserver.js.flow +106 -106
  234. package/dist/ui/RichTextEditor.js.flow +133 -133
  235. package/dist/ui/SelectionObserver.js.flow +134 -134
  236. package/dist/ui/TableCellMenu.js.flow +38 -38
  237. package/dist/ui/TableGridSizeEditor.js +6 -8
  238. package/dist/ui/TableGridSizeEditor.js.flow +184 -184
  239. package/dist/ui/TableNodeView.js.flow +22 -22
  240. package/dist/ui/bindScrollHandler.js.flow +46 -46
  241. package/dist/ui/canUseCSSFont.js.flow +43 -43
  242. package/dist/ui/czi-body-layout-editor.css +16 -16
  243. package/dist/ui/czi-bookmark-view.css +10 -10
  244. package/dist/ui/czi-cursor-placeholder.css +36 -36
  245. package/dist/ui/czi-custom-menu-button.css +18 -18
  246. package/dist/ui/czi-custom-menu-item.css +30 -30
  247. package/dist/ui/czi-custom-menu.css +8 -8
  248. package/dist/ui/czi-custom-radio-button.css +80 -80
  249. package/dist/ui/czi-custom-scrollbar.css +21 -21
  250. package/dist/ui/czi-editor-frameset.css +81 -81
  251. package/dist/ui/czi-editor-toolbar.css +122 -122
  252. package/dist/ui/czi-editor.css +220 -220
  253. package/dist/ui/czi-form.css +104 -104
  254. package/dist/ui/czi-frag.css +3 -3
  255. package/dist/ui/czi-heading.css +40 -40
  256. package/dist/ui/czi-icon.css +72 -72
  257. package/dist/ui/czi-image-resize-box.css +165 -165
  258. package/dist/ui/czi-image-upload-editor.css +57 -57
  259. package/dist/ui/czi-image-upload-placeholder.css +50 -50
  260. package/dist/ui/czi-image-url-editor.css +38 -38
  261. package/dist/ui/czi-image-view.css +125 -125
  262. package/dist/ui/czi-indent.css +137 -137
  263. package/dist/ui/czi-inline-editor.css +20 -20
  264. package/dist/ui/czi-link-tooltip.css +71 -71
  265. package/dist/ui/czi-list.css +410 -410
  266. package/dist/ui/czi-loading-indicator.css +111 -111
  267. package/dist/ui/czi-math-view.css +62 -62
  268. package/dist/ui/czi-selection-placeholder.css +24 -24
  269. package/dist/ui/czi-table-cell-menu.css +14 -14
  270. package/dist/ui/czi-table-grid-size-editor.css +37 -37
  271. package/dist/ui/czi-table.css +86 -86
  272. package/dist/ui/czi-vars.css +2 -46
  273. package/dist/ui/findActiveFontSize.js.flow +58 -58
  274. package/dist/ui/findActiveFontType.js.flow +38 -38
  275. package/dist/ui/fonts.css +471 -471
  276. package/dist/ui/handleEditorDrop.js.flow +28 -28
  277. package/dist/ui/handleEditorKeyDown.js.flow +39 -39
  278. package/dist/ui/handleEditorPaste.js.flow +33 -33
  279. package/dist/ui/htmlElementToRect.js.flow +18 -18
  280. package/dist/ui/icon-font.css +10 -10
  281. package/dist/ui/injectStyleSheet.js.flow +42 -42
  282. package/dist/ui/isElementFullyVisible.js +2 -2
  283. package/dist/ui/isElementFullyVisible.js.flow +23 -23
  284. package/dist/ui/isOffline.js.flow +8 -8
  285. package/dist/ui/isReactClass.js.flow +12 -12
  286. package/dist/ui/listType.css +21 -21
  287. package/dist/ui/mathquill-editor/MathQuillEditor.js.flow +159 -159
  288. package/dist/ui/mathquill-editor/MathQuillEditorSymbols.js.flow +483 -483
  289. package/dist/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js +2 -2
  290. package/dist/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js.flow +48 -48
  291. package/dist/ui/mathquill-editor/czi-mathquill-editor-symbols-panel.css +39 -39
  292. package/dist/ui/mathquill-editor/czi-mathquill-editor.css +50 -50
  293. package/dist/ui/mathquill-editor/mathquill-import-kludge.js.flow +24 -24
  294. package/dist/ui/renderLaTeXAsHTML.js.flow +46 -46
  295. package/dist/ui/resolveImage.js.flow +123 -123
  296. package/dist/ui/toCSSColor.js.flow +51 -51
  297. package/dist/ui/toCSSLineSpacing.js +1 -36
  298. package/dist/ui/toCSSLineSpacing.js.flow +55 -82
  299. package/dist/ui/toHexColor.js.flow +26 -26
  300. package/dist/ui/uuid.js.flow +9 -9
  301. package/dist/uuid.js.flow +9 -9
  302. package/flow-typed/@modusoperandilicit-customstyles.js +5 -5
  303. package/flow-typed/@modusoperandilicit-doc-attrs-step.js +5 -5
  304. package/flow-typed/@modusoperandilicit-ui-commands.js +5 -0
  305. package/flow-typed/create-emotion.js +5 -5
  306. package/flow-typed/docs-editor.js +3 -3
  307. package/flow-typed/draft-convert.js +3 -3
  308. package/flow-typed/draft-js.js +3 -3
  309. package/flow-typed/flatted.js +5 -5
  310. package/flow-typed/jquery.js +5 -5
  311. package/flow-typed/katex.js +6 -6
  312. package/flow-typed/mathquill.js +5 -5
  313. package/flow-typed/prosemirror-collab.js +5 -5
  314. package/flow-typed/prosemirror-commands.js +5 -5
  315. package/flow-typed/prosemirror-dev-tools.js +5 -5
  316. package/flow-typed/prosemirror-dropcursor.js +5 -5
  317. package/flow-typed/prosemirror-gapcursor.js +5 -5
  318. package/flow-typed/prosemirror-history.js +5 -5
  319. package/flow-typed/prosemirror-inputrules.js +5 -5
  320. package/flow-typed/prosemirror-keymap.js +5 -5
  321. package/flow-typed/prosemirror-model.js +5 -5
  322. package/flow-typed/prosemirror-state.js +5 -5
  323. package/flow-typed/prosemirror-tables.js +5 -5
  324. package/flow-typed/prosemirror-transform.js +5 -5
  325. package/flow-typed/prosemirror-utils.js +5 -5
  326. package/flow-typed/prosemirror-view.js +5 -5
  327. package/flow-typed/resize-observer-polyfill.js +5 -5
  328. package/flow-typed/uuid.js +5 -5
  329. package/jest.config.js +207 -0
  330. package/jest.setup.js +5 -5
  331. package/licit/client/CustomLicitRuntime.js +95 -95
  332. package/licit/client/CustomStyleRuntime.js +136 -136
  333. package/licit/client/index.js +366 -366
  334. package/licit/index.html +11 -11
  335. package/licit/server/collab/instance.js +221 -221
  336. package/licit/server/collab/route.js +69 -69
  337. package/licit/server/collab/server.js +297 -297
  338. package/licit/server/collab/start.js +13 -13
  339. package/licit/server/image/start.js +58 -58
  340. package/lint.sh +4 -4
  341. package/node_modules/prosemirror-utils/LICENSE +13 -0
  342. package/{dist/ui/PopUpTypes.js.flow → node_modules/prosemirror-utils/README.md} +0 -0
  343. package/node_modules/prosemirror-utils/dist/helpers.js +119 -0
  344. package/node_modules/prosemirror-utils/dist/index.js +17 -0
  345. package/node_modules/prosemirror-utils/dist/index.js.map +1 -0
  346. package/node_modules/prosemirror-utils/dist/node.js +106 -0
  347. package/node_modules/prosemirror-utils/dist/selection.js +168 -0
  348. package/node_modules/prosemirror-utils/dist/transforms.js +257 -0
  349. package/node_modules/prosemirror-utils/package.json +81 -0
  350. package/node_modules/prosemirror-utils/typings.d.ts +79 -0
  351. package/package.json +172 -165
  352. package/run_collab_server.py +21 -21
  353. package/run_image_server.py +20 -20
  354. package/run_web_server.py +25 -25
  355. package/scripts/build_bin.js +10 -10
  356. package/scripts/build_bin.py +103 -103
  357. package/scripts/ci_check_dist.sh +13 -13
  358. package/scripts/env.js +6 -6
  359. package/scripts/webserver.js +35 -35
  360. package/sonar-project.properties +11 -11
  361. package/src/BlockquoteInsertNewLineCommand.js +55 -55
  362. package/src/BlockquoteNodeSpec.js +30 -30
  363. package/src/BlockquoteToggleCommand.js +34 -34
  364. package/src/BookmarkNodeSpec.js +39 -39
  365. package/src/BulletListNodeSpec.js +61 -61
  366. package/src/CZIProseMirror.js +90 -90
  367. package/src/CodeBlockCommand.js +43 -43
  368. package/src/CodeBlockNodeSpec.js +24 -24
  369. package/src/CodeMarkSpec.js +14 -14
  370. package/src/ContentPlaceholderPlugin.js +187 -187
  371. package/src/CursorPlaceholderPlugin.js +115 -115
  372. package/src/DocLayoutCommand.js +94 -94
  373. package/src/DocNodeSpec.js +64 -64
  374. package/src/EMMarkSpec.js +14 -14
  375. package/src/EditorCommands.js +128 -128
  376. package/src/EditorKeyMap.js +187 -187
  377. package/src/EditorMarks.js +71 -71
  378. package/src/EditorNodes.js +60 -60
  379. package/src/EditorPageLayoutPlugin.js +67 -67
  380. package/src/EditorPlugins.js +8 -8
  381. package/src/EditorSchema.js +12 -12
  382. package/src/EditorState.js +7 -7
  383. package/src/FontSizeMarkSpec.js +49 -49
  384. package/src/FontTypeMarkSpec.js +80 -80
  385. package/src/HTMLMutator.js +59 -59
  386. package/src/HardBreakNodeSpec.js +15 -15
  387. package/src/HeadingNodeSpec.js +54 -54
  388. package/src/HistoryRedoCommand.js +20 -20
  389. package/src/HistoryUndoCommand.js +20 -20
  390. package/src/HorizontalRuleCommand.js +49 -49
  391. package/src/HorizontalRuleNodeSpec.js +39 -39
  392. package/src/ImageFromURLCommand.js +14 -14
  393. package/src/ImageNodeSpec.js +90 -90
  394. package/src/ImageSourceCommand.js +117 -117
  395. package/src/ImageUploadCommand.js +36 -36
  396. package/src/ImageUploadPlaceholderPlugin.js +192 -192
  397. package/src/LinkMarkSpec.js +32 -32
  398. package/src/LinkSetURLCommand.js +103 -103
  399. package/src/LinkTooltipPlugin.js +203 -203
  400. package/src/ListItemInsertNewLineCommand.js +55 -55
  401. package/src/ListItemMergeCommand.js +177 -177
  402. package/src/ListItemNodeSpec.js +51 -51
  403. package/src/ListSplitCommand.js +32 -32
  404. package/src/ListToggleCommand.js +77 -77
  405. package/src/MarkNames.js +18 -18
  406. package/src/MarksClearCommand.js +42 -42
  407. package/src/MathEditCommand.js +110 -110
  408. package/src/MathNodeSpec.js +46 -46
  409. package/src/NodeNames.js +23 -23
  410. package/src/OrderedListNodeSpec.js +132 -132
  411. package/src/ParagraphNodeSpec.js +156 -160
  412. package/src/ParagraphSpacingCommand.js +121 -121
  413. package/src/PrintCommand.js +31 -31
  414. package/src/SelectionPlaceholderPlugin.js +131 -131
  415. package/src/SpacerMarkSpec.js +47 -47
  416. package/src/StrikeMarkSpec.js +21 -21
  417. package/src/StrongMarkSpec.js +25 -25
  418. package/src/StyleView.js +19 -19
  419. package/src/TableBackgroundColorCommand.js +75 -75
  420. package/src/TableBorderColorCommand.js +75 -75
  421. package/src/TableCellColorCommand.js +71 -71
  422. package/src/TableCellMenuPlugin.js +125 -125
  423. package/src/TableInsertCommand.js +112 -112
  424. package/src/TableMergeCellsCommand.js +90 -90
  425. package/src/TableNodesSpecs.js +78 -78
  426. package/src/TablePlugins.js +14 -14
  427. package/src/TableResizePlugin.js +631 -631
  428. package/src/TextColorMarkSpec.js +35 -35
  429. package/src/TextHighlightMarkSpec.js +38 -38
  430. package/src/TextInsertTabSpaceCommand.js +83 -83
  431. package/src/TextNoWrapMarkSpec.js +14 -14
  432. package/src/TextNodeSpec.js +7 -7
  433. package/src/TextSelectionMarkSpec.js +24 -24
  434. package/src/TextSubMarkSpec.js +20 -20
  435. package/src/TextSuperMarkSpec.js +20 -20
  436. package/src/TextUnderlineMarkSpec.js +27 -27
  437. package/src/Types.js +75 -75
  438. package/src/WebFontLoader.js +22 -22
  439. package/src/blockQuoteInputRule.js +36 -36
  440. package/src/browser.js +7 -7
  441. package/src/buildEditorPlugins.js +51 -51
  442. package/src/buildInputRules.js +81 -81
  443. package/src/client/CollabConnector.js +86 -71
  444. package/src/client/EditorConnection.js +318 -307
  445. package/src/client/Licit.js +592 -578
  446. package/src/client/Licit.test.js +67 -67
  447. package/src/client/Reporter.js +37 -37
  448. package/src/client/SimpleConnector.js +55 -53
  449. package/src/client/http.js +66 -66
  450. package/src/client/licit.css +12 -12
  451. package/src/client/throttle.js +27 -27
  452. package/src/convertFromDOMElement.js +36 -36
  453. package/src/convertFromHTML.js +19 -19
  454. package/src/convertFromJSON.js +78 -78
  455. package/src/convertToCSSPTValue.js +22 -22
  456. package/src/convertToJSON.js +7 -7
  457. package/src/createCommand.js +40 -40
  458. package/src/createEditorKeyMap.js +94 -94
  459. package/src/createEmptyEditorState.js +35 -35
  460. package/src/createTableResizingPlugin.js +86 -86
  461. package/src/findActionableCell.js +74 -74
  462. package/src/findActiveMark.js +32 -32
  463. package/src/hyphenize.js +17 -17
  464. package/src/index.js +10 -10
  465. package/src/insertTable.js +56 -56
  466. package/src/isEditorStateEmpty.js +32 -32
  467. package/src/isTableNode.js +15 -15
  468. package/src/joinDown.js +27 -27
  469. package/src/joinListNode.js +55 -55
  470. package/src/joinUp.js +39 -39
  471. package/src/keymaps.js +185 -185
  472. package/src/lookUpElement.js +14 -14
  473. package/src/nodeAt.js +12 -12
  474. package/src/normalizeHTML.js +78 -78
  475. package/src/patchAnchorElements.js +38 -38
  476. package/src/patchBreakElements.js +22 -22
  477. package/src/patchElementInlineStyles.js +92 -92
  478. package/src/patchListElements.js +276 -276
  479. package/src/patchMathElements.js +60 -60
  480. package/src/patchParagraphElements.js +20 -20
  481. package/src/patchStyleElements.js +194 -194
  482. package/src/patchTableElements.js +89 -89
  483. package/src/rebaseDocWithSteps.js +42 -42
  484. package/src/sanitizeURL.js +13 -13
  485. package/src/splitListItem.js +191 -191
  486. package/src/styles.css +19 -19
  487. package/src/styles0.css +29 -29
  488. package/src/toClosestFontPtSize.js +22 -22
  489. package/src/toSafeHTMLDocument.js +9 -9
  490. package/src/toggleBlockquote.js +91 -91
  491. package/src/toggleCodeBlock.js +102 -102
  492. package/src/ui/AlertInfo.js +64 -64
  493. package/src/ui/BookmarkNodeView.js +66 -66
  494. package/src/ui/CommandButton.js +68 -68
  495. package/src/ui/CommandMenu.js +75 -75
  496. package/src/ui/CommandMenuButton.js +131 -131
  497. package/src/ui/CustomEditorView.js +28 -28
  498. package/src/ui/CustomMenu.js +17 -17
  499. package/src/ui/CustomMenuItem.js +36 -36
  500. package/src/ui/CustomNodeView.js +200 -200
  501. package/src/ui/CustomRadioButton.js +65 -65
  502. package/src/ui/DocLayoutEditor.js +146 -146
  503. package/src/ui/Editor.js +290 -290
  504. package/src/ui/EditorFrameset.js +81 -81
  505. package/src/ui/EditorToolbar.js +211 -211
  506. package/src/ui/EditorToolbarConfig.js +172 -172
  507. package/src/ui/FontSizeCommandMenuButton.js +66 -66
  508. package/src/ui/FontTypeCommandMenuButton.js +49 -49
  509. package/src/ui/Frag.js +13 -13
  510. package/src/ui/Icon.js +89 -89
  511. package/src/ui/ImageAlignEditor.js +60 -60
  512. package/src/ui/ImageInlineEditor.js +67 -67
  513. package/src/ui/ImageNodeView.js +404 -404
  514. package/src/ui/ImageResizeBox.js +219 -219
  515. package/src/ui/ImageURLEditor.js +119 -119
  516. package/src/ui/ImageUploadEditor.js +117 -117
  517. package/src/ui/KeyCodes.js +12 -12
  518. package/src/ui/LinkTooltip.js +85 -85
  519. package/src/ui/LinkURLEditor.js +111 -111
  520. package/src/ui/ListItemNodeView.js +98 -98
  521. package/src/ui/ListTypeButton.js +131 -131
  522. package/src/ui/ListTypeCommandButton.js +85 -85
  523. package/src/ui/ListTypeMenu.js +70 -70
  524. package/src/ui/LoadingIndicator.js +20 -20
  525. package/src/ui/MathEditor.js +78 -78
  526. package/src/ui/MathInlineEditor.js +102 -102
  527. package/src/ui/MathNodeView.js +175 -175
  528. package/src/ui/PasteMenu.js +57 -57
  529. package/src/ui/ResizeObserver.js +106 -106
  530. package/src/ui/RichTextEditor.js +133 -133
  531. package/src/ui/SelectionObserver.js +134 -134
  532. package/src/ui/TableCellMenu.js +38 -38
  533. package/src/ui/TableGridSizeEditor.js +184 -184
  534. package/src/ui/TableNodeView.js +22 -22
  535. package/src/ui/bindScrollHandler.js +46 -46
  536. package/src/ui/canUseCSSFont.js +43 -43
  537. package/src/ui/czi-body-layout-editor.css +16 -16
  538. package/src/ui/czi-bookmark-view.css +10 -10
  539. package/src/ui/czi-cursor-placeholder.css +36 -36
  540. package/src/ui/czi-custom-menu-button.css +18 -18
  541. package/src/ui/czi-custom-menu-item.css +30 -30
  542. package/src/ui/czi-custom-menu.css +8 -8
  543. package/src/ui/czi-custom-radio-button.css +80 -80
  544. package/src/ui/czi-custom-scrollbar.css +21 -21
  545. package/src/ui/czi-editor-frameset.css +81 -81
  546. package/src/ui/czi-editor-toolbar.css +122 -122
  547. package/src/ui/czi-editor.css +220 -220
  548. package/src/ui/czi-form.css +104 -104
  549. package/src/ui/czi-frag.css +3 -3
  550. package/src/ui/czi-heading.css +40 -40
  551. package/src/ui/czi-icon.css +72 -72
  552. package/src/ui/czi-image-resize-box.css +165 -165
  553. package/src/ui/czi-image-upload-editor.css +57 -57
  554. package/src/ui/czi-image-upload-placeholder.css +50 -50
  555. package/src/ui/czi-image-url-editor.css +38 -38
  556. package/src/ui/czi-image-view.css +125 -125
  557. package/src/ui/czi-indent.css +137 -137
  558. package/src/ui/czi-inline-editor.css +20 -20
  559. package/src/ui/czi-link-tooltip.css +71 -71
  560. package/src/ui/czi-list.css +410 -410
  561. package/src/ui/czi-loading-indicator.css +111 -111
  562. package/src/ui/czi-math-view.css +62 -62
  563. package/src/ui/czi-selection-placeholder.css +24 -24
  564. package/src/ui/czi-table-cell-menu.css +14 -14
  565. package/src/ui/czi-table-grid-size-editor.css +37 -37
  566. package/src/ui/czi-table.css +86 -86
  567. package/src/ui/czi-vars.css +2 -46
  568. package/src/ui/findActiveFontSize.js +58 -58
  569. package/src/ui/findActiveFontType.js +38 -38
  570. package/src/ui/fonts.css +471 -471
  571. package/src/ui/handleEditorDrop.js +28 -28
  572. package/src/ui/handleEditorKeyDown.js +39 -39
  573. package/src/ui/handleEditorPaste.js +33 -33
  574. package/src/ui/htmlElementToRect.js +18 -18
  575. package/src/ui/icon-font.css +10 -10
  576. package/src/ui/injectStyleSheet.js +42 -42
  577. package/src/ui/isElementFullyVisible.js +23 -23
  578. package/src/ui/isOffline.js +8 -8
  579. package/src/ui/isReactClass.js +12 -12
  580. package/src/ui/listType.css +21 -21
  581. package/src/ui/mathquill-editor/MathQuillEditor.js +159 -159
  582. package/src/ui/mathquill-editor/MathQuillEditorSymbols.js +483 -483
  583. package/src/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js +48 -48
  584. package/src/ui/mathquill-editor/czi-mathquill-editor-symbols-panel.css +39 -39
  585. package/src/ui/mathquill-editor/czi-mathquill-editor.css +50 -50
  586. package/src/ui/mathquill-editor/mathquill-import-kludge.js +24 -24
  587. package/src/ui/renderLaTeXAsHTML.js +46 -46
  588. package/src/ui/resolveImage.js +123 -123
  589. package/src/ui/toCSSColor.js +51 -51
  590. package/src/ui/toCSSLineSpacing.js +55 -82
  591. package/src/ui/toHexColor.js +26 -26
  592. package/src/ui/uuid.js +9 -9
  593. package/src/uuid.js +9 -9
  594. package/style-service.Dockerfile +26 -26
  595. package/utils/build_bin.js +9 -9
  596. package/utils/build_image_server.js +71 -71
  597. package/utils/build_licit_collab_server.js +75 -75
  598. package/utils/build_web_server.js +40 -40
  599. package/utils/env.js +6 -6
  600. package/webpack.config.js +126 -126
  601. package/build_customstyle_server.py +0 -7
  602. package/dist/FontSizeCommand.js +0 -80
  603. package/dist/FontSizeCommand.js.flow +0 -57
  604. package/dist/FontTypeCommand.js +0 -137
  605. package/dist/FontTypeCommand.js.flow +0 -100
  606. package/dist/HeadingCommand.js +0 -65
  607. package/dist/HeadingCommand.js.flow +0 -51
  608. package/dist/IndentCommand.js +0 -57
  609. package/dist/IndentCommand.js.flow +0 -41
  610. package/dist/MarkToggleCommand.js +0 -90
  611. package/dist/MarkToggleCommand.js.flow +0 -66
  612. package/dist/TextAlignCommand.js +0 -151
  613. package/dist/TextAlignCommand.js.flow +0 -122
  614. package/dist/TextColorCommand.js +0 -114
  615. package/dist/TextColorCommand.js.flow +0 -87
  616. package/dist/TextHighlightCommand.js +0 -118
  617. package/dist/TextHighlightCommand.js.flow +0 -91
  618. package/dist/TextLineSpacingCommand.js +0 -177
  619. package/dist/TextLineSpacingCommand.js.flow +0 -157
  620. package/dist/applyMark.js +0 -84
  621. package/dist/applyMark.js.flow +0 -61
  622. package/dist/clearMarks.js +0 -160
  623. package/dist/clearMarks.js.flow +0 -128
  624. package/dist/compareNumber.js +0 -18
  625. package/dist/compareNumber.js.flow +0 -11
  626. package/dist/consolidateListNodes.js +0 -291
  627. package/dist/consolidateListNodes.js.flow +0 -281
  628. package/dist/findNodesWithSameMark.js +0 -89
  629. package/dist/findNodesWithSameMark.js.flow +0 -89
  630. package/dist/isBulletListNode.js +0 -14
  631. package/dist/isBulletListNode.js.flow +0 -9
  632. package/dist/isInsideListItem.js +0 -19
  633. package/dist/isInsideListItem.js.flow +0 -13
  634. package/dist/isListNode.js +0 -22
  635. package/dist/isListNode.js.flow +0 -13
  636. package/dist/isNodeSelectionForNodeType.js +0 -19
  637. package/dist/isNodeSelectionForNodeType.js.flow +0 -15
  638. package/dist/isOrderedListNode.js +0 -14
  639. package/dist/isOrderedListNode.js.flow +0 -9
  640. package/dist/isTextStyleMarkCommandEnabled.js +0 -59
  641. package/dist/isTextStyleMarkCommandEnabled.js.flow +0 -49
  642. package/dist/noop.js +0 -11
  643. package/dist/noop.js.flow +0 -5
  644. package/dist/toggleHeading.js +0 -135
  645. package/dist/toggleHeading.js.flow +0 -113
  646. package/dist/toggleList.js +0 -431
  647. package/dist/toggleList.js.flow +0 -450
  648. package/dist/transformAndPreserveTextSelection.js +0 -173
  649. package/dist/transformAndPreserveTextSelection.js.flow +0 -151
  650. package/dist/ui/ColorEditor.js +0 -118
  651. package/dist/ui/ColorEditor.js.flow +0 -101
  652. package/dist/ui/CustomButton.js +0 -64
  653. package/dist/ui/CustomButton.js.flow +0 -33
  654. package/dist/ui/PointerSurface.js +0 -173
  655. package/dist/ui/PointerSurface.js.flow +0 -141
  656. package/dist/ui/PopUp.js +0 -129
  657. package/dist/ui/PopUp.js.flow +0 -77
  658. package/dist/ui/PopUpManager.js +0 -266
  659. package/dist/ui/PopUpManager.js.flow +0 -213
  660. package/dist/ui/PopUpPosition.js +0 -156
  661. package/dist/ui/PopUpPosition.js.flow +0 -104
  662. package/dist/ui/PopUpTypes.js +0 -1
  663. package/dist/ui/TooltipSurface.js +0 -99
  664. package/dist/ui/TooltipSurface.js.flow +0 -76
  665. package/dist/ui/clamp.js +0 -18
  666. package/dist/ui/clamp.js.flow +0 -11
  667. package/dist/ui/createPopUp.js +0 -199
  668. package/dist/ui/createPopUp.js.flow +0 -205
  669. package/dist/ui/czi-animations.css +0 -15
  670. package/dist/ui/czi-color-editor.css +0 -56
  671. package/dist/ui/czi-custom-button.css +0 -93
  672. package/dist/ui/czi-pop-up.css +0 -32
  673. package/dist/ui/czi-tooltip-surface.css +0 -45
  674. package/dist/ui/preventEventDefault.js +0 -10
  675. package/dist/ui/preventEventDefault.js.flow +0 -5
  676. package/dist/ui/rects.js +0 -58
  677. package/dist/ui/rects.js.flow +0 -47
  678. package/dist/updateIndentLevel.js +0 -232
  679. package/dist/updateIndentLevel.js.flow +0 -211
  680. package/flow-typed/@molicit-citation.js +0 -5
  681. package/licit/server/customstyles/start.js +0 -184
  682. package/run_customstyle_server.py +0 -20
  683. package/src/FontSizeCommand.js +0 -57
  684. package/src/FontTypeCommand.js +0 -100
  685. package/src/HeadingCommand.js +0 -51
  686. package/src/IndentCommand.js +0 -41
  687. package/src/MarkToggleCommand.js +0 -66
  688. package/src/TextAlignCommand.js +0 -122
  689. package/src/TextColorCommand.js +0 -87
  690. package/src/TextHighlightCommand.js +0 -91
  691. package/src/TextLineSpacingCommand.js +0 -157
  692. package/src/applyMark.js +0 -61
  693. package/src/clearMarks.js +0 -128
  694. package/src/compareNumber.js +0 -11
  695. package/src/consolidateListNodes.js +0 -281
  696. package/src/findNodesWithSameMark.js +0 -89
  697. package/src/isBulletListNode.js +0 -9
  698. package/src/isInsideListItem.js +0 -13
  699. package/src/isListNode.js +0 -13
  700. package/src/isNodeSelectionForNodeType.js +0 -15
  701. package/src/isOrderedListNode.js +0 -9
  702. package/src/isTextStyleMarkCommandEnabled.js +0 -49
  703. package/src/noop.js +0 -5
  704. package/src/toggleHeading.js +0 -113
  705. package/src/toggleList.js +0 -450
  706. package/src/transformAndPreserveTextSelection.js +0 -151
  707. package/src/ui/ColorEditor.js +0 -101
  708. package/src/ui/CustomButton.js +0 -33
  709. package/src/ui/PointerSurface.js +0 -141
  710. package/src/ui/PopUp.js +0 -77
  711. package/src/ui/PopUpManager.js +0 -213
  712. package/src/ui/PopUpPosition.js +0 -104
  713. package/src/ui/PopUpTypes.js +0 -0
  714. package/src/ui/TooltipSurface.js +0 -76
  715. package/src/ui/clamp.js +0 -11
  716. package/src/ui/createPopUp.js +0 -205
  717. package/src/ui/czi-animations.css +0 -15
  718. package/src/ui/czi-color-editor.css +0 -56
  719. package/src/ui/czi-custom-button.css +0 -93
  720. package/src/ui/czi-pop-up.css +0 -32
  721. package/src/ui/czi-tooltip-surface.css +0 -45
  722. package/src/ui/preventEventDefault.js +0 -5
  723. package/src/ui/rects.js +0 -47
  724. package/src/updateIndentLevel.js +0 -211
  725. package/utils/build_customstyle_server.js +0 -72
@@ -1,20 +1,20 @@
1
- // @flow
2
-
3
- import {
4
- ATTRIBUTE_INDENT,
5
- convertMarginLeftToIndentValue,
6
- } from './ParagraphNodeSpec';
7
-
8
- export default function patchParagraphElements(doc: Document): void {
9
- Array.from(doc.querySelectorAll('p')).forEach(patchParagraphElement);
10
- }
11
-
12
- function patchParagraphElement(pElement: HTMLElement): void {
13
- const { marginLeft } = pElement.style;
14
- if (marginLeft) {
15
- const indent = convertMarginLeftToIndentValue(marginLeft);
16
- if (indent) {
17
- pElement.setAttribute(ATTRIBUTE_INDENT, String(indent));
18
- }
19
- }
20
- }
1
+ // @flow
2
+
3
+ import {
4
+ ATTRIBUTE_INDENT,
5
+ convertMarginLeftToIndentValue,
6
+ } from './ParagraphNodeSpec';
7
+
8
+ export default function patchParagraphElements(doc: Document): void {
9
+ Array.from(doc.querySelectorAll('p')).forEach(patchParagraphElement);
10
+ }
11
+
12
+ function patchParagraphElement(pElement: HTMLElement): void {
13
+ const { marginLeft } = pElement.style;
14
+ if (marginLeft) {
15
+ const indent = convertMarginLeftToIndentValue(marginLeft);
16
+ if (indent) {
17
+ pElement.setAttribute(ATTRIBUTE_INDENT, String(indent));
18
+ }
19
+ }
20
+ }
@@ -10,7 +10,7 @@ var _stable = _interopRequireDefault(require("stable"));
10
10
 
11
11
  var _toCSSColor = _interopRequireDefault(require("./ui/toCSSColor"));
12
12
 
13
- var _toCSSLineSpacing = _interopRequireDefault(require("./ui/toCSSLineSpacing"));
13
+ var _licitUiCommands = require("@modusoperandi/licit-ui-commands");
14
14
 
15
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
16
 
@@ -81,7 +81,7 @@ function patchStyleElements(doc) {
81
81
  return;
82
82
  }
83
83
  } else if (key === 'line-height') {
84
- cssStyleValueStr = (0, _toCSSLineSpacing.default)(cssStyleValueStr);
84
+ cssStyleValueStr = (0, _licitUiCommands.toCSSLineSpacing)(cssStyleValueStr);
85
85
  }
86
86
 
87
87
  if (cssStyleValueStr) {
@@ -1,194 +1,194 @@
1
- // @flow
2
-
3
- import stable from 'stable';
4
- import toCSSColor from './ui/toCSSColor';
5
- import toCSSLineSpacing from './ui/toCSSLineSpacing';
6
-
7
- const LIST_ITEM_PSEUDO_ELEMENT_BEFORE = /li:+before/;
8
- const NODE_NAME_SELECTOR = /^[a-zA-Z]+\d*$/;
9
- const PSEUDO_ELEMENT_ANY = /:+[a-z]+/;
10
-
11
- // Assume these className from Google doc has less specificity.
12
- const WEAK_CLASS_SELECTOR = /\.title/;
13
-
14
- type SelectorTextToCSSText = {
15
- afterContent: ?string,
16
- beforeContent: ?string,
17
- cssText: string,
18
- selectorText: string,
19
- };
20
-
21
- export const ATTRIBUTE_CSS_BEFORE_CONTENT = 'data-attribute-css-before-content';
22
-
23
- // Node name only selector has less priority, we'll handle it
24
- // separately
25
-
26
- export default function patchStyleElements(doc: Document): void {
27
- const els = Array.from(doc.querySelectorAll('style'));
28
- if (!els.length) {
29
- return;
30
- }
31
-
32
- const selectorTextToCSSTexts = [];
33
-
34
- els.forEach((styleEl: any) => {
35
- const sheet = styleEl.sheet;
36
- if (!sheet) {
37
- // TODO: Find out why the browser does not support this.
38
- console.error('styleEl.sheet undefined', styleEl);
39
- return;
40
- }
41
- const cssRules = sheet.cssRules;
42
- if (!cssRules) {
43
- // TODO: Find out why the browser does not support this.
44
- console.error('sheet.cssRules undefined', sheet);
45
- return;
46
- }
47
-
48
- Array.from(cssRules).forEach((rule, cssRuleIndex) => {
49
- const selectorText = String(rule.selectorText || '');
50
- if (!selectorText) {
51
- // This could be `CSSImportRule.` created by @import().
52
- // ignore it.
53
- return;
54
- }
55
-
56
- if (!rule.styleMap) {
57
- // TODO: Find out why the browser does not support this.
58
- console.error('rule.styleMap undefined', rule);
59
- return;
60
- }
61
- let cssText = '';
62
- rule.styleMap.forEach((cssStyleValue, key) => {
63
- let cssStyleValueStr = String(cssStyleValue);
64
- // e.g. rules['color'] = 'red'.
65
- if (key === 'color') {
66
- const color = toCSSColor(cssStyleValueStr);
67
- if (!color) {
68
- return;
69
- }
70
- } else if (key === 'background-color') {
71
- const color = toCSSColor(cssStyleValueStr);
72
- if (!color) {
73
- return;
74
- }
75
- } else if (key === 'line-height') {
76
- cssStyleValueStr = toCSSLineSpacing(cssStyleValueStr);
77
- }
78
- if (cssStyleValueStr) {
79
- cssText += `${key}: ${cssStyleValueStr};`;
80
- }
81
- });
82
- if (selectorText.indexOf(',') > -1) {
83
- selectorText.split(/\s*,\s*/).forEach((st) => {
84
- buildSelectorTextToCSSText(selectorTextToCSSTexts, st, cssText);
85
- });
86
- } else {
87
- buildSelectorTextToCSSText(
88
- selectorTextToCSSTexts,
89
- selectorText,
90
- cssText
91
- );
92
- }
93
- });
94
- });
95
-
96
- // Sort selector by
97
- stable(selectorTextToCSSTexts, sortBySpecificity)
98
- .reduce(buildElementToCSSTexts.bind(null, doc), new Map<any, any>())
99
- .forEach(applyInlineStyleSheetCSSTexts);
100
- }
101
-
102
- function buildElementToCSSTexts(
103
- doc: Document,
104
- elementToCSSTexts: Map<HTMLElement, Array<string>>,
105
- bag: SelectorTextToCSSText
106
- ): Map<HTMLElement, Array<string>> {
107
- const { selectorText, cssText, beforeContent } = bag;
108
- const els = Array.from(doc.querySelectorAll(selectorText));
109
-
110
- els.forEach((el) => {
111
- const style = el.style;
112
- if (!style || !(el instanceof HTMLElement)) {
113
- return;
114
- }
115
- if (cssText) {
116
- const cssTexts = elementToCSSTexts.get(el) || [];
117
- cssTexts.push(cssText);
118
- elementToCSSTexts.set(el, cssTexts);
119
- }
120
- if (beforeContent) {
121
- // This simply adds the custom attribute 'data-before-content' to element,
122
- // developer must handle his attribute via NodeSpec separately if needed.
123
- el.setAttribute(ATTRIBUTE_CSS_BEFORE_CONTENT, beforeContent);
124
- }
125
- });
126
- return elementToCSSTexts;
127
- }
128
-
129
- function sortBySpecificity(
130
- one: SelectorTextToCSSText,
131
- two: SelectorTextToCSSText
132
- ): number {
133
- // This is just the naive implementation of sorting selectors by css
134
- // specificity.
135
- // 1. NodeName selectors has less priority.
136
- let aa = NODE_NAME_SELECTOR.test(one.selectorText);
137
- let bb = NODE_NAME_SELECTOR.test(two.selectorText);
138
- if (aa && !bb) {
139
- return -1;
140
- }
141
-
142
- if (!aa && bb) {
143
- return 1;
144
- }
145
-
146
- // Assume both are className selector.
147
- // Assume these className from Google doc has less specificity.
148
- aa = WEAK_CLASS_SELECTOR.test(one.selectorText);
149
- bb = WEAK_CLASS_SELECTOR.test(two.selectorText);
150
- if (aa && !bb) {
151
- return -1;
152
- }
153
- if (!aa && bb) {
154
- return 1;
155
- }
156
- return 0;
157
- }
158
-
159
- function buildSelectorTextToCSSText(
160
- result: Array<SelectorTextToCSSText>,
161
- selectorText: string,
162
- cssText: string
163
- ): void {
164
- let afterContent;
165
- let beforeContent;
166
-
167
- if (LIST_ITEM_PSEUDO_ELEMENT_BEFORE.test(selectorText)) {
168
- // Workaround to extract the list style content from HTML generated by
169
- // Google.
170
- // This converts `content:"\0025a0 "` to `\0025a0`
171
- beforeContent = cssText.replace(/^content:\s*"\s*/, '').replace(/";*$/, '');
172
- selectorText = selectorText.replace(/:+before/, '');
173
- cssText = '';
174
- } else if (PSEUDO_ELEMENT_ANY.test(selectorText)) {
175
- // TODO: Handle this later.
176
- return;
177
- }
178
-
179
- result.push({
180
- selectorText,
181
- cssText,
182
- afterContent,
183
- beforeContent,
184
- });
185
- }
186
-
187
- function applyInlineStyleSheetCSSTexts(
188
- cssTexts: Array<string>,
189
- el: HTMLElement
190
- ): void {
191
- if (cssTexts.length) {
192
- el.style.cssText = cssTexts.join(';') + ';' + el.style.cssText;
193
- }
194
- }
1
+ // @flow
2
+
3
+ import stable from 'stable';
4
+ import toCSSColor from './ui/toCSSColor';
5
+ import { toCSSLineSpacing } from '@modusoperandi/licit-ui-commands';
6
+
7
+ const LIST_ITEM_PSEUDO_ELEMENT_BEFORE = /li:+before/;
8
+ const NODE_NAME_SELECTOR = /^[a-zA-Z]+\d*$/;
9
+ const PSEUDO_ELEMENT_ANY = /:+[a-z]+/;
10
+
11
+ // Assume these className from Google doc has less specificity.
12
+ const WEAK_CLASS_SELECTOR = /\.title/;
13
+
14
+ type SelectorTextToCSSText = {
15
+ afterContent: ?string,
16
+ beforeContent: ?string,
17
+ cssText: string,
18
+ selectorText: string,
19
+ };
20
+
21
+ export const ATTRIBUTE_CSS_BEFORE_CONTENT = 'data-attribute-css-before-content';
22
+
23
+ // Node name only selector has less priority, we'll handle it
24
+ // separately
25
+
26
+ export default function patchStyleElements(doc: Document): void {
27
+ const els = Array.from(doc.querySelectorAll('style'));
28
+ if (!els.length) {
29
+ return;
30
+ }
31
+
32
+ const selectorTextToCSSTexts = [];
33
+
34
+ els.forEach((styleEl: any) => {
35
+ const sheet = styleEl.sheet;
36
+ if (!sheet) {
37
+ // TODO: Find out why the browser does not support this.
38
+ console.error('styleEl.sheet undefined', styleEl);
39
+ return;
40
+ }
41
+ const cssRules = sheet.cssRules;
42
+ if (!cssRules) {
43
+ // TODO: Find out why the browser does not support this.
44
+ console.error('sheet.cssRules undefined', sheet);
45
+ return;
46
+ }
47
+
48
+ Array.from(cssRules).forEach((rule, cssRuleIndex) => {
49
+ const selectorText = String(rule.selectorText || '');
50
+ if (!selectorText) {
51
+ // This could be `CSSImportRule.` created by @import().
52
+ // ignore it.
53
+ return;
54
+ }
55
+
56
+ if (!rule.styleMap) {
57
+ // TODO: Find out why the browser does not support this.
58
+ console.error('rule.styleMap undefined', rule);
59
+ return;
60
+ }
61
+ let cssText = '';
62
+ rule.styleMap.forEach((cssStyleValue, key) => {
63
+ let cssStyleValueStr = String(cssStyleValue);
64
+ // e.g. rules['color'] = 'red'.
65
+ if (key === 'color') {
66
+ const color = toCSSColor(cssStyleValueStr);
67
+ if (!color) {
68
+ return;
69
+ }
70
+ } else if (key === 'background-color') {
71
+ const color = toCSSColor(cssStyleValueStr);
72
+ if (!color) {
73
+ return;
74
+ }
75
+ } else if (key === 'line-height') {
76
+ cssStyleValueStr = toCSSLineSpacing(cssStyleValueStr);
77
+ }
78
+ if (cssStyleValueStr) {
79
+ cssText += `${key}: ${cssStyleValueStr};`;
80
+ }
81
+ });
82
+ if (selectorText.indexOf(',') > -1) {
83
+ selectorText.split(/\s*,\s*/).forEach((st) => {
84
+ buildSelectorTextToCSSText(selectorTextToCSSTexts, st, cssText);
85
+ });
86
+ } else {
87
+ buildSelectorTextToCSSText(
88
+ selectorTextToCSSTexts,
89
+ selectorText,
90
+ cssText
91
+ );
92
+ }
93
+ });
94
+ });
95
+
96
+ // Sort selector by
97
+ stable(selectorTextToCSSTexts, sortBySpecificity)
98
+ .reduce(buildElementToCSSTexts.bind(null, doc), new Map<any, any>())
99
+ .forEach(applyInlineStyleSheetCSSTexts);
100
+ }
101
+
102
+ function buildElementToCSSTexts(
103
+ doc: Document,
104
+ elementToCSSTexts: Map<HTMLElement, Array<string>>,
105
+ bag: SelectorTextToCSSText
106
+ ): Map<HTMLElement, Array<string>> {
107
+ const { selectorText, cssText, beforeContent } = bag;
108
+ const els = Array.from(doc.querySelectorAll(selectorText));
109
+
110
+ els.forEach((el) => {
111
+ const style = el.style;
112
+ if (!style || !(el instanceof HTMLElement)) {
113
+ return;
114
+ }
115
+ if (cssText) {
116
+ const cssTexts = elementToCSSTexts.get(el) || [];
117
+ cssTexts.push(cssText);
118
+ elementToCSSTexts.set(el, cssTexts);
119
+ }
120
+ if (beforeContent) {
121
+ // This simply adds the custom attribute 'data-before-content' to element,
122
+ // developer must handle his attribute via NodeSpec separately if needed.
123
+ el.setAttribute(ATTRIBUTE_CSS_BEFORE_CONTENT, beforeContent);
124
+ }
125
+ });
126
+ return elementToCSSTexts;
127
+ }
128
+
129
+ function sortBySpecificity(
130
+ one: SelectorTextToCSSText,
131
+ two: SelectorTextToCSSText
132
+ ): number {
133
+ // This is just the naive implementation of sorting selectors by css
134
+ // specificity.
135
+ // 1. NodeName selectors has less priority.
136
+ let aa = NODE_NAME_SELECTOR.test(one.selectorText);
137
+ let bb = NODE_NAME_SELECTOR.test(two.selectorText);
138
+ if (aa && !bb) {
139
+ return -1;
140
+ }
141
+
142
+ if (!aa && bb) {
143
+ return 1;
144
+ }
145
+
146
+ // Assume both are className selector.
147
+ // Assume these className from Google doc has less specificity.
148
+ aa = WEAK_CLASS_SELECTOR.test(one.selectorText);
149
+ bb = WEAK_CLASS_SELECTOR.test(two.selectorText);
150
+ if (aa && !bb) {
151
+ return -1;
152
+ }
153
+ if (!aa && bb) {
154
+ return 1;
155
+ }
156
+ return 0;
157
+ }
158
+
159
+ function buildSelectorTextToCSSText(
160
+ result: Array<SelectorTextToCSSText>,
161
+ selectorText: string,
162
+ cssText: string
163
+ ): void {
164
+ let afterContent;
165
+ let beforeContent;
166
+
167
+ if (LIST_ITEM_PSEUDO_ELEMENT_BEFORE.test(selectorText)) {
168
+ // Workaround to extract the list style content from HTML generated by
169
+ // Google.
170
+ // This converts `content:"\0025a0 "` to `\0025a0`
171
+ beforeContent = cssText.replace(/^content:\s*"\s*/, '').replace(/";*$/, '');
172
+ selectorText = selectorText.replace(/:+before/, '');
173
+ cssText = '';
174
+ } else if (PSEUDO_ELEMENT_ANY.test(selectorText)) {
175
+ // TODO: Handle this later.
176
+ return;
177
+ }
178
+
179
+ result.push({
180
+ selectorText,
181
+ cssText,
182
+ afterContent,
183
+ beforeContent,
184
+ });
185
+ }
186
+
187
+ function applyInlineStyleSheetCSSTexts(
188
+ cssTexts: Array<string>,
189
+ el: HTMLElement
190
+ ): void {
191
+ if (cssTexts.length) {
192
+ el.style.cssText = cssTexts.join(';') + ';' + el.style.cssText;
193
+ }
194
+ }
@@ -1,89 +1,89 @@
1
- // @flow
2
- import { PT_TO_PX_RATIO } from './convertToCSSPTValue';
3
- import convertToCSSPTValue from './convertToCSSPTValue';
4
- import toHexColor from './ui/toHexColor';
5
-
6
- export default function patchTableElements(doc: Document): void {
7
- Array.from(doc.querySelectorAll('td')).forEach(patchTableCell);
8
- Array.from(doc.querySelectorAll('tr[style^=height]')).forEach(patchTableRow);
9
- }
10
-
11
- // The height of each line: ~= 21px
12
- const LINE_HEIGHT_PT_VALUE = 15.81149997;
13
-
14
- // Workaround to patch HTML from Google Doc that Table Cells will apply
15
- // its background colr to all its inner <span />.
16
- function patchTableCell(tdElement: HTMLElement): void {
17
- const { style } = tdElement;
18
- if (!style) {
19
- return;
20
- }
21
- const { backgroundColor, width } = style;
22
- if (backgroundColor) {
23
- const tdBgColor = toHexColor(backgroundColor);
24
- const selector = 'span[style*=background-color]';
25
- const spans = Array.from(tdElement.querySelectorAll(selector));
26
- spans.some((spanElement) => {
27
- let retVal = true;
28
- const spanStyle = spanElement.style;
29
- if (!spanStyle || !spanStyle.backgroundColor) {
30
- retVal = false;
31
- } else {
32
- const spanBgColor = toHexColor(spanStyle.backgroundColor);
33
- if (spanBgColor === tdBgColor) {
34
- // The span has the same bg color as the cell does, erase its bg color.
35
- spanStyle.backgroundColor = '';
36
- }
37
- }
38
- return retVal;
39
- });
40
- }
41
-
42
- if (width) {
43
- const ptValue = convertToCSSPTValue(width);
44
- if (!ptValue) {
45
- return;
46
- }
47
- const pxValue = ptValue * PT_TO_PX_RATIO;
48
- // Attribute "data-colwidth" is defined at 'prosemirror-tables';
49
- tdElement.setAttribute('data-colwidth', String(Math.round(pxValue)));
50
- }
51
- }
52
-
53
- // Workaround to support "height" in table row by inject empty <p /> to
54
- // create space for the height.
55
- function patchTableRow(trElement: HTMLElement): void {
56
- const doc = trElement.ownerDocument;
57
- if (!doc) {
58
- return;
59
- }
60
- const height = trElement.style.height;
61
- if (!height) {
62
- return;
63
- }
64
- const firstCell = trElement.querySelector('td, th');
65
- if (!firstCell) {
66
- return;
67
- }
68
- const ptValue = convertToCSSPTValue(height);
69
- if (!ptValue) {
70
- return;
71
- }
72
-
73
- const pEls = firstCell.querySelectorAll('p');
74
- const heightNeeded = ptValue - LINE_HEIGHT_PT_VALUE * pEls.length;
75
- if (heightNeeded < 0) {
76
- return;
77
- }
78
- let pElsNeeded = Math.round(heightNeeded / LINE_HEIGHT_PT_VALUE);
79
- if (pElsNeeded <= 0) {
80
- return;
81
- }
82
- const frag = doc.createDocumentFragment();
83
- const line = doc.createElement('p');
84
- while (pElsNeeded > 0) {
85
- pElsNeeded--;
86
- frag.appendChild(line.cloneNode(false));
87
- }
88
- firstCell.appendChild(frag);
89
- }
1
+ // @flow
2
+ import { PT_TO_PX_RATIO } from './convertToCSSPTValue';
3
+ import convertToCSSPTValue from './convertToCSSPTValue';
4
+ import toHexColor from './ui/toHexColor';
5
+
6
+ export default function patchTableElements(doc: Document): void {
7
+ Array.from(doc.querySelectorAll('td')).forEach(patchTableCell);
8
+ Array.from(doc.querySelectorAll('tr[style^=height]')).forEach(patchTableRow);
9
+ }
10
+
11
+ // The height of each line: ~= 21px
12
+ const LINE_HEIGHT_PT_VALUE = 15.81149997;
13
+
14
+ // Workaround to patch HTML from Google Doc that Table Cells will apply
15
+ // its background colr to all its inner <span />.
16
+ function patchTableCell(tdElement: HTMLElement): void {
17
+ const { style } = tdElement;
18
+ if (!style) {
19
+ return;
20
+ }
21
+ const { backgroundColor, width } = style;
22
+ if (backgroundColor) {
23
+ const tdBgColor = toHexColor(backgroundColor);
24
+ const selector = 'span[style*=background-color]';
25
+ const spans = Array.from(tdElement.querySelectorAll(selector));
26
+ spans.some((spanElement) => {
27
+ let retVal = true;
28
+ const spanStyle = spanElement.style;
29
+ if (!spanStyle || !spanStyle.backgroundColor) {
30
+ retVal = false;
31
+ } else {
32
+ const spanBgColor = toHexColor(spanStyle.backgroundColor);
33
+ if (spanBgColor === tdBgColor) {
34
+ // The span has the same bg color as the cell does, erase its bg color.
35
+ spanStyle.backgroundColor = '';
36
+ }
37
+ }
38
+ return retVal;
39
+ });
40
+ }
41
+
42
+ if (width) {
43
+ const ptValue = convertToCSSPTValue(width);
44
+ if (!ptValue) {
45
+ return;
46
+ }
47
+ const pxValue = ptValue * PT_TO_PX_RATIO;
48
+ // Attribute "data-colwidth" is defined at 'prosemirror-tables';
49
+ tdElement.setAttribute('data-colwidth', String(Math.round(pxValue)));
50
+ }
51
+ }
52
+
53
+ // Workaround to support "height" in table row by inject empty <p /> to
54
+ // create space for the height.
55
+ function patchTableRow(trElement: HTMLElement): void {
56
+ const doc = trElement.ownerDocument;
57
+ if (!doc) {
58
+ return;
59
+ }
60
+ const height = trElement.style.height;
61
+ if (!height) {
62
+ return;
63
+ }
64
+ const firstCell = trElement.querySelector('td, th');
65
+ if (!firstCell) {
66
+ return;
67
+ }
68
+ const ptValue = convertToCSSPTValue(height);
69
+ if (!ptValue) {
70
+ return;
71
+ }
72
+
73
+ const pEls = firstCell.querySelectorAll('p');
74
+ const heightNeeded = ptValue - LINE_HEIGHT_PT_VALUE * pEls.length;
75
+ if (heightNeeded < 0) {
76
+ return;
77
+ }
78
+ let pElsNeeded = Math.round(heightNeeded / LINE_HEIGHT_PT_VALUE);
79
+ if (pElsNeeded <= 0) {
80
+ return;
81
+ }
82
+ const frag = doc.createDocumentFragment();
83
+ const line = doc.createElement('p');
84
+ while (pElsNeeded > 0) {
85
+ pElsNeeded--;
86
+ frag.appendChild(line.cloneNode(false));
87
+ }
88
+ firstCell.appendChild(frag);
89
+ }