@modusoperandi/licit 0.1.9 → 0.13.2

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 (340) hide show
  1. package/.github/workflows/build.yml +1 -7
  2. package/.github/workflows/lint.yml +1 -1
  3. package/README.md +1 -1
  4. package/babel.config.json +54 -0
  5. package/dist/BlockquoteNodeSpec.js +2 -2
  6. package/dist/CZIProseMirror.js +4 -4
  7. package/dist/CodeBlockCommand.js +2 -2
  8. package/dist/CodeBlockCommand.js.flow +1 -1
  9. package/dist/CursorPlaceholderPlugin.js +2 -2
  10. package/dist/DocLayoutCommand.js +2 -4
  11. package/dist/DocLayoutCommand.js.flow +1 -1
  12. package/dist/DocNodeSpec.js +1 -1
  13. package/dist/EditorCommands.js +23 -35
  14. package/dist/EditorCommands.js.flow +7 -7
  15. package/dist/EditorKeyMap.js +3 -3
  16. package/dist/FontTypeMarkSpec.js +1 -1
  17. package/dist/HeadingNodeSpec.js +2 -2
  18. package/dist/ImageSourceCommand.js +2 -4
  19. package/dist/ImageSourceCommand.js.flow +1 -1
  20. package/dist/ImageUploadPlaceholderPlugin.js +1 -1
  21. package/dist/LinkSetURLCommand.js +4 -8
  22. package/dist/LinkSetURLCommand.js.flow +3 -3
  23. package/dist/LinkTooltipPlugin.js +9 -15
  24. package/dist/LinkTooltipPlugin.js.flow +5 -5
  25. package/dist/ListToggleCommand.js +5 -11
  26. package/dist/ListToggleCommand.js.flow +3 -3
  27. package/dist/MarkNames.js +1 -1
  28. package/dist/MarksClearCommand.js +3 -3
  29. package/dist/MarksClearCommand.js.flow +1 -1
  30. package/dist/MathEditCommand.js +2 -2
  31. package/dist/MathEditCommand.js.flow +1 -1
  32. package/dist/ParagraphNodeSpec.js +3 -4
  33. package/dist/ParagraphNodeSpec.js.flow +2 -6
  34. package/dist/ParagraphSpacingCommand.js +3 -3
  35. package/dist/SelectionPlaceholderPlugin.js +2 -2
  36. package/dist/SpacerMarkSpec.js +1 -1
  37. package/dist/TableBackgroundColorCommand.js +3 -7
  38. package/dist/TableBackgroundColorCommand.js.flow +3 -3
  39. package/dist/TableBorderColorCommand.js +3 -7
  40. package/dist/TableBorderColorCommand.js.flow +3 -3
  41. package/dist/TableCellColorCommand.js +3 -7
  42. package/dist/TableCellColorCommand.js.flow +3 -3
  43. package/dist/TableCellMenuPlugin.js +4 -6
  44. package/dist/TableCellMenuPlugin.js.flow +3 -3
  45. package/dist/TableInsertCommand.js +3 -5
  46. package/dist/TableInsertCommand.js.flow +2 -2
  47. package/dist/TableResizePlugin.js +2 -2
  48. package/dist/TextInsertTabSpaceCommand.js +2 -4
  49. package/dist/TextInsertTabSpaceCommand.js.flow +1 -1
  50. package/dist/Types.js +1 -1
  51. package/dist/bom.xml +4970 -4167
  52. package/dist/client/CollabConnector.js +17 -2
  53. package/dist/client/CollabConnector.js.flow +17 -2
  54. package/dist/client/EditorConnection.js +15 -4
  55. package/dist/client/EditorConnection.js.flow +14 -3
  56. package/dist/client/Licit.js +73 -58
  57. package/dist/client/Licit.js.flow +101 -85
  58. package/dist/client/Licit.test.js +18 -17
  59. package/dist/client/Licit.test.js.flow +13 -11
  60. package/dist/client/SimpleConnector.js +4 -2
  61. package/dist/client/SimpleConnector.js.flow +3 -1
  62. package/dist/client/http.js +3 -3
  63. package/dist/convertToCSSPTValue.js +1 -1
  64. package/dist/createEmptyEditorState.js +1 -1
  65. package/dist/index.js +16 -16
  66. package/dist/joinListNode.js +2 -2
  67. package/dist/joinListNode.js.flow +1 -1
  68. package/dist/keymaps.js +2 -2
  69. package/dist/patchStyleElements.js +3 -3
  70. package/dist/patchStyleElements.js.flow +1 -1
  71. package/dist/splitListItem.js +2 -2
  72. package/dist/styles.css +2 -2
  73. package/dist/styles0.css +3 -3
  74. package/dist/toggleBlockquote.js +6 -14
  75. package/dist/toggleBlockquote.js.flow +4 -4
  76. package/dist/toggleCodeBlock.js +4 -10
  77. package/dist/toggleCodeBlock.js.flow +3 -3
  78. package/dist/ui/AlertInfo.js +2 -2
  79. package/dist/ui/CommandButton.js +2 -4
  80. package/dist/ui/CommandButton.js.flow +1 -1
  81. package/dist/ui/CommandMenuButton.js +5 -7
  82. package/dist/ui/CommandMenuButton.js.flow +2 -2
  83. package/dist/ui/CustomMenuItem.js +3 -5
  84. package/dist/ui/CustomMenuItem.js.flow +1 -1
  85. package/dist/ui/CustomNodeView.js +3 -3
  86. package/dist/ui/CustomRadioButton.js +8 -6
  87. package/dist/ui/CustomRadioButton.js.flow +3 -3
  88. package/dist/ui/DocLayoutEditor.js +5 -7
  89. package/dist/ui/DocLayoutEditor.js.flow +2 -2
  90. package/dist/ui/Editor.js +1 -2
  91. package/dist/ui/Editor.js.flow +1 -2
  92. package/dist/ui/EditorFrameset.js +1 -1
  93. package/dist/ui/EditorToolbar.js +4 -4
  94. package/dist/ui/EditorToolbar.js.flow +1 -1
  95. package/dist/ui/EditorToolbarConfig.js +1 -1
  96. package/dist/ui/FontSizeCommandMenuButton.js +3 -3
  97. package/dist/ui/FontSizeCommandMenuButton.js.flow +1 -1
  98. package/dist/ui/FontTypeCommandMenuButton.js +3 -3
  99. package/dist/ui/FontTypeCommandMenuButton.js.flow +1 -1
  100. package/dist/ui/ImageAlignEditor.js +5 -5
  101. package/dist/ui/ImageAlignEditor.js.flow +1 -1
  102. package/dist/ui/ImageInlineEditor.js +5 -5
  103. package/dist/ui/ImageInlineEditor.js.flow +1 -1
  104. package/dist/ui/ImageNodeView.js +5 -7
  105. package/dist/ui/ImageNodeView.js.flow +2 -2
  106. package/dist/ui/ImageResizeBox.js +4 -4
  107. package/dist/ui/ImageResizeBox.js.flow +1 -1
  108. package/dist/ui/ImageURLEditor.js +6 -8
  109. package/dist/ui/ImageURLEditor.js.flow +2 -2
  110. package/dist/ui/ImageUploadEditor.js +3 -5
  111. package/dist/ui/ImageUploadEditor.js.flow +2 -2
  112. package/dist/ui/LinkTooltip.js +4 -4
  113. package/dist/ui/LinkTooltip.js.flow +1 -1
  114. package/dist/ui/LinkURLEditor.js +4 -6
  115. package/dist/ui/LinkURLEditor.js.flow +2 -2
  116. package/dist/ui/ListTypeButton.js +5 -7
  117. package/dist/ui/ListTypeButton.js.flow +2 -2
  118. package/dist/ui/MathEditor.js +4 -6
  119. package/dist/ui/MathEditor.js.flow +2 -2
  120. package/dist/ui/MathInlineEditor.js +7 -9
  121. package/dist/ui/MathInlineEditor.js.flow +2 -2
  122. package/dist/ui/MathNodeView.js +5 -7
  123. package/dist/ui/MathNodeView.js.flow +2 -2
  124. package/dist/ui/ResizeObserver.js +1 -1
  125. package/dist/ui/TableGridSizeEditor.js +7 -9
  126. package/dist/ui/TableGridSizeEditor.js.flow +2 -2
  127. package/dist/ui/czi-link-tooltip.css +1 -1
  128. package/dist/ui/czi-vars.css +1 -45
  129. package/dist/ui/findActiveFontType.js +1 -1
  130. package/dist/ui/htmlElementToRect.js +1 -1
  131. package/dist/ui/isElementFullyVisible.js +2 -2
  132. package/dist/ui/isElementFullyVisible.js.flow +1 -1
  133. package/dist/ui/mathquill-editor/MathQuillEditorSymbols.js +1 -1
  134. package/dist/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js +2 -2
  135. package/dist/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js.flow +1 -1
  136. package/dist/ui/resolveImage.js +3 -3
  137. package/dist/ui/toCSSColor.js +1 -1
  138. package/dist/ui/toCSSLineSpacing.js +1 -36
  139. package/dist/ui/toCSSLineSpacing.js.flow +0 -27
  140. package/flow-typed/@modusoperandilicit-ui-commands.js +5 -0
  141. package/jest.config.js +207 -0
  142. package/lint.sh +0 -0
  143. package/node_modules/prosemirror-utils/LICENSE +13 -0
  144. package/{dist/ui/PopUpTypes.js.flow → node_modules/prosemirror-utils/README.md} +0 -0
  145. package/node_modules/prosemirror-utils/dist/helpers.js +119 -0
  146. package/node_modules/prosemirror-utils/dist/index.js +17 -0
  147. package/node_modules/prosemirror-utils/dist/index.js.map +1 -0
  148. package/node_modules/prosemirror-utils/dist/node.js +106 -0
  149. package/node_modules/prosemirror-utils/dist/selection.js +168 -0
  150. package/node_modules/prosemirror-utils/dist/transforms.js +257 -0
  151. package/node_modules/prosemirror-utils/package.json +81 -0
  152. package/node_modules/prosemirror-utils/typings.d.ts +79 -0
  153. package/package.json +14 -8
  154. package/scripts/build_bin.py +0 -0
  155. package/scripts/ci_check_dist.sh +0 -0
  156. package/src/CodeBlockCommand.js +1 -1
  157. package/src/DocLayoutCommand.js +1 -1
  158. package/src/EditorCommands.js +7 -7
  159. package/src/ImageSourceCommand.js +1 -1
  160. package/src/LinkSetURLCommand.js +3 -3
  161. package/src/LinkTooltipPlugin.js +5 -5
  162. package/src/ListToggleCommand.js +3 -3
  163. package/src/MarksClearCommand.js +1 -1
  164. package/src/MathEditCommand.js +1 -1
  165. package/src/ParagraphNodeSpec.js +2 -6
  166. package/src/TableBackgroundColorCommand.js +3 -3
  167. package/src/TableBorderColorCommand.js +3 -3
  168. package/src/TableCellColorCommand.js +3 -3
  169. package/src/TableCellMenuPlugin.js +3 -3
  170. package/src/TableInsertCommand.js +2 -2
  171. package/src/TextInsertTabSpaceCommand.js +1 -1
  172. package/src/client/CollabConnector.js +17 -2
  173. package/src/client/EditorConnection.js +14 -3
  174. package/src/client/Licit.js +101 -85
  175. package/src/client/Licit.test.js +13 -11
  176. package/src/client/SimpleConnector.js +3 -1
  177. package/src/joinListNode.js +1 -1
  178. package/src/patchStyleElements.js +1 -1
  179. package/src/styles.css +2 -2
  180. package/src/styles0.css +3 -3
  181. package/src/toggleBlockquote.js +4 -4
  182. package/src/toggleCodeBlock.js +3 -3
  183. package/src/ui/CommandButton.js +1 -1
  184. package/src/ui/CommandMenuButton.js +2 -2
  185. package/src/ui/CustomMenuItem.js +1 -1
  186. package/src/ui/CustomRadioButton.js +3 -3
  187. package/src/ui/DocLayoutEditor.js +2 -2
  188. package/src/ui/Editor.js +1 -2
  189. package/src/ui/EditorToolbar.js +1 -1
  190. package/src/ui/FontSizeCommandMenuButton.js +1 -1
  191. package/src/ui/FontTypeCommandMenuButton.js +1 -1
  192. package/src/ui/ImageAlignEditor.js +1 -1
  193. package/src/ui/ImageInlineEditor.js +1 -1
  194. package/src/ui/ImageNodeView.js +2 -2
  195. package/src/ui/ImageResizeBox.js +1 -1
  196. package/src/ui/ImageURLEditor.js +2 -2
  197. package/src/ui/ImageUploadEditor.js +2 -2
  198. package/src/ui/LinkTooltip.js +1 -1
  199. package/src/ui/LinkURLEditor.js +2 -2
  200. package/src/ui/ListTypeButton.js +2 -2
  201. package/src/ui/MathEditor.js +2 -2
  202. package/src/ui/MathInlineEditor.js +2 -2
  203. package/src/ui/MathNodeView.js +2 -2
  204. package/src/ui/TableGridSizeEditor.js +2 -2
  205. package/src/ui/czi-link-tooltip.css +1 -1
  206. package/src/ui/czi-vars.css +1 -45
  207. package/src/ui/isElementFullyVisible.js +1 -1
  208. package/src/ui/mathquill-editor/MathQuillEditorSymbolsPanel.js +1 -1
  209. package/src/ui/toCSSLineSpacing.js +0 -27
  210. package/build_customstyle_server.py +0 -7
  211. package/dist/FontSizeCommand.js +0 -80
  212. package/dist/FontSizeCommand.js.flow +0 -57
  213. package/dist/FontTypeCommand.js +0 -137
  214. package/dist/FontTypeCommand.js.flow +0 -100
  215. package/dist/HeadingCommand.js +0 -65
  216. package/dist/HeadingCommand.js.flow +0 -51
  217. package/dist/IndentCommand.js +0 -57
  218. package/dist/IndentCommand.js.flow +0 -41
  219. package/dist/MarkToggleCommand.js +0 -90
  220. package/dist/MarkToggleCommand.js.flow +0 -66
  221. package/dist/TextAlignCommand.js +0 -151
  222. package/dist/TextAlignCommand.js.flow +0 -122
  223. package/dist/TextColorCommand.js +0 -114
  224. package/dist/TextColorCommand.js.flow +0 -87
  225. package/dist/TextHighlightCommand.js +0 -118
  226. package/dist/TextHighlightCommand.js.flow +0 -91
  227. package/dist/TextLineSpacingCommand.js +0 -177
  228. package/dist/TextLineSpacingCommand.js.flow +0 -157
  229. package/dist/applyMark.js +0 -84
  230. package/dist/applyMark.js.flow +0 -61
  231. package/dist/clearMarks.js +0 -160
  232. package/dist/clearMarks.js.flow +0 -128
  233. package/dist/compareNumber.js +0 -18
  234. package/dist/compareNumber.js.flow +0 -11
  235. package/dist/consolidateListNodes.js +0 -291
  236. package/dist/consolidateListNodes.js.flow +0 -281
  237. package/dist/coverage/lcov-report/block-navigation.js +0 -77
  238. package/dist/coverage/lcov-report/block-navigation.js.flow +0 -79
  239. package/dist/coverage/lcov-report/prettify.js +0 -994
  240. package/dist/coverage/lcov-report/prettify.js.flow +0 -2
  241. package/dist/coverage/lcov-report/sorter.js +0 -187
  242. package/dist/coverage/lcov-report/sorter.js.flow +0 -170
  243. package/dist/findNodesWithSameMark.js +0 -89
  244. package/dist/findNodesWithSameMark.js.flow +0 -89
  245. package/dist/isBulletListNode.js +0 -14
  246. package/dist/isBulletListNode.js.flow +0 -9
  247. package/dist/isInsideListItem.js +0 -19
  248. package/dist/isInsideListItem.js.flow +0 -13
  249. package/dist/isListNode.js +0 -22
  250. package/dist/isListNode.js.flow +0 -13
  251. package/dist/isNodeSelectionForNodeType.js +0 -19
  252. package/dist/isNodeSelectionForNodeType.js.flow +0 -15
  253. package/dist/isOrderedListNode.js +0 -14
  254. package/dist/isOrderedListNode.js.flow +0 -9
  255. package/dist/isTextStyleMarkCommandEnabled.js +0 -59
  256. package/dist/isTextStyleMarkCommandEnabled.js.flow +0 -49
  257. package/dist/noop.js +0 -11
  258. package/dist/noop.js.flow +0 -5
  259. package/dist/toggleHeading.js +0 -135
  260. package/dist/toggleHeading.js.flow +0 -113
  261. package/dist/toggleList.js +0 -431
  262. package/dist/toggleList.js.flow +0 -450
  263. package/dist/transformAndPreserveTextSelection.js +0 -173
  264. package/dist/transformAndPreserveTextSelection.js.flow +0 -151
  265. package/dist/ui/ColorEditor.js +0 -118
  266. package/dist/ui/ColorEditor.js.flow +0 -101
  267. package/dist/ui/CustomButton.js +0 -62
  268. package/dist/ui/CustomButton.js.flow +0 -33
  269. package/dist/ui/PointerSurface.js +0 -173
  270. package/dist/ui/PointerSurface.js.flow +0 -141
  271. package/dist/ui/PopUp.js +0 -129
  272. package/dist/ui/PopUp.js.flow +0 -77
  273. package/dist/ui/PopUpManager.js +0 -266
  274. package/dist/ui/PopUpManager.js.flow +0 -213
  275. package/dist/ui/PopUpPosition.js +0 -156
  276. package/dist/ui/PopUpPosition.js.flow +0 -104
  277. package/dist/ui/PopUpTypes.js +0 -1
  278. package/dist/ui/TooltipSurface.js +0 -99
  279. package/dist/ui/TooltipSurface.js.flow +0 -76
  280. package/dist/ui/clamp.js +0 -18
  281. package/dist/ui/clamp.js.flow +0 -11
  282. package/dist/ui/createPopUp.js +0 -199
  283. package/dist/ui/createPopUp.js.flow +0 -205
  284. package/dist/ui/czi-animations.css +0 -15
  285. package/dist/ui/czi-color-editor.css +0 -56
  286. package/dist/ui/czi-custom-button.css +0 -93
  287. package/dist/ui/czi-pop-up.css +0 -32
  288. package/dist/ui/czi-tooltip-surface.css +0 -45
  289. package/dist/ui/preventEventDefault.js +0 -10
  290. package/dist/ui/preventEventDefault.js.flow +0 -5
  291. package/dist/ui/rects.js +0 -58
  292. package/dist/ui/rects.js.flow +0 -47
  293. package/dist/updateIndentLevel.js +0 -232
  294. package/dist/updateIndentLevel.js.flow +0 -211
  295. package/flow-typed/@molicit-citation.js +0 -5
  296. package/licit/server/customstyles/start.js +0 -184
  297. package/run_customstyle_server.py +0 -20
  298. package/src/FontSizeCommand.js +0 -57
  299. package/src/FontTypeCommand.js +0 -100
  300. package/src/HeadingCommand.js +0 -51
  301. package/src/IndentCommand.js +0 -41
  302. package/src/MarkToggleCommand.js +0 -66
  303. package/src/TextAlignCommand.js +0 -122
  304. package/src/TextColorCommand.js +0 -87
  305. package/src/TextHighlightCommand.js +0 -91
  306. package/src/TextLineSpacingCommand.js +0 -157
  307. package/src/applyMark.js +0 -61
  308. package/src/clearMarks.js +0 -128
  309. package/src/compareNumber.js +0 -11
  310. package/src/consolidateListNodes.js +0 -281
  311. package/src/findNodesWithSameMark.js +0 -89
  312. package/src/isBulletListNode.js +0 -9
  313. package/src/isInsideListItem.js +0 -13
  314. package/src/isListNode.js +0 -13
  315. package/src/isNodeSelectionForNodeType.js +0 -15
  316. package/src/isOrderedListNode.js +0 -9
  317. package/src/isTextStyleMarkCommandEnabled.js +0 -49
  318. package/src/noop.js +0 -5
  319. package/src/toggleHeading.js +0 -113
  320. package/src/toggleList.js +0 -450
  321. package/src/transformAndPreserveTextSelection.js +0 -151
  322. package/src/ui/ColorEditor.js +0 -101
  323. package/src/ui/CustomButton.js +0 -33
  324. package/src/ui/PointerSurface.js +0 -141
  325. package/src/ui/PopUp.js +0 -77
  326. package/src/ui/PopUpManager.js +0 -213
  327. package/src/ui/PopUpPosition.js +0 -104
  328. package/src/ui/PopUpTypes.js +0 -0
  329. package/src/ui/TooltipSurface.js +0 -76
  330. package/src/ui/clamp.js +0 -11
  331. package/src/ui/createPopUp.js +0 -205
  332. package/src/ui/czi-animations.css +0 -15
  333. package/src/ui/czi-color-editor.css +0 -56
  334. package/src/ui/czi-custom-button.css +0 -93
  335. package/src/ui/czi-pop-up.css +0 -32
  336. package/src/ui/czi-tooltip-surface.css +0 -45
  337. package/src/ui/preventEventDefault.js +0 -5
  338. package/src/ui/rects.js +0 -47
  339. package/src/updateIndentLevel.js +0 -211
  340. package/utils/build_customstyle_server.js +0 -72
@@ -1,213 +0,0 @@
1
- // @flow
2
-
3
- import clamp from './clamp';
4
- import { fromHTMlElement, fromXY, isIntersected } from './rects';
5
-
6
- import type { PositionHandler } from './PopUpPosition';
7
- import type { Rect } from './rects';
8
-
9
- export type PopUpDetails = {
10
- anchor: ?HTMLElement,
11
- anchorRect?: ?Rect,
12
- autoDismiss: boolean,
13
- body: ?HTMLElement,
14
- bodyRect?: ?Rect,
15
- close: (val: any) => void,
16
- modal: boolean,
17
- position: PositionHandler,
18
- };
19
-
20
- export type PopUpBridge = {
21
- getDetails: () => PopUpDetails,
22
- };
23
-
24
- const CLICK_INTERVAL = 350;
25
- const DUMMY_RECT = { x: -10000, y: -10000, w: 0, h: 0 };
26
-
27
- class PopUpManager {
28
- _bridges = new Map<any, any>();
29
- _positions = new Map<any, any>();
30
-
31
- _mx = 0;
32
- _my = 0;
33
- _rafID = 0;
34
-
35
- register(bridge: PopUpBridge): void {
36
- this._bridges.set(bridge, Date.now());
37
- this._positions.set(bridge, null);
38
- if (this._bridges.size === 1) {
39
- this._observe();
40
- }
41
- this._rafID = requestAnimationFrame(this._syncPosition);
42
- }
43
-
44
- unregister(bridge: PopUpBridge): void {
45
- this._bridges.delete(bridge);
46
- this._positions.delete(bridge);
47
- if (this._bridges.size === 0) {
48
- this._unobserve();
49
- }
50
- this._rafID && cancelAnimationFrame(this._rafID);
51
- }
52
-
53
- _observe(): void {
54
- document.addEventListener('mousemove', this._onMouseChange, false);
55
- document.addEventListener('mouseup', this._onMouseChange, false);
56
- document.addEventListener('click', this._onClick, false);
57
- window.addEventListener('scroll', this._onScroll, true);
58
- window.addEventListener('resize', this._onResize, true);
59
- }
60
-
61
- _unobserve(): void {
62
- document.removeEventListener('mousemove', this._onMouseChange, false);
63
- document.removeEventListener('mouseup', this._onMouseChange, false);
64
- document.removeEventListener('click', this._onClick, false);
65
- window.removeEventListener('scroll', this._onScroll, true);
66
- window.removeEventListener('resize', this._onResize, true);
67
- this._rafID && cancelAnimationFrame(this._rafID);
68
- }
69
-
70
- _onScroll = (e: Event): void => {
71
- this._rafID && cancelAnimationFrame(this._rafID);
72
- this._rafID = requestAnimationFrame(this._syncPosition);
73
- };
74
-
75
- _onResize = (e: Event): void => {
76
- this._rafID && cancelAnimationFrame(this._rafID);
77
- this._rafID = requestAnimationFrame(this._syncPosition);
78
- };
79
-
80
- _onMouseChange = (e: MouseEvent): void => {
81
- this._mx = Math.round(e.clientX);
82
- this._my = Math.round(e.clientY);
83
- this._rafID && cancelAnimationFrame(this._rafID);
84
- this._rafID = requestAnimationFrame(this._syncPosition);
85
- };
86
-
87
- _onClick = (e: MouseEvent): void => {
88
- const now = Date.now();
89
- let detailsWithModalToDismiss;
90
- for (const [bridge, registeredAt] of this._bridges) {
91
- if (now - registeredAt > CLICK_INTERVAL) {
92
- const details = bridge.getDetails();
93
- if (details.modal && details.autoDismiss) {
94
- detailsWithModalToDismiss = details;
95
- }
96
- }
97
- }
98
- if (!detailsWithModalToDismiss) {
99
- return;
100
- }
101
- const { body, close } = detailsWithModalToDismiss;
102
- const pointer = fromXY(e.clientX, e.clientY, 1);
103
- const bodyRect = body ? fromHTMlElement(body) : null;
104
- if (!bodyRect || !isIntersected(pointer, bodyRect)) {
105
- close();
106
- }
107
- };
108
-
109
- _syncPosition = (): void => {
110
- this._rafID = 0;
111
-
112
- const bridgeToDetails = new Map<any, any>();
113
- for (const [
114
- bridge,
115
- // eslint-disable-next-line no-unused-vars
116
- registeredAt,
117
- ] of this._bridges) {
118
- const details = bridge.getDetails();
119
- bridgeToDetails.set(bridge, details);
120
- const { anchor, body } = details;
121
- if (body instanceof HTMLElement) {
122
- details.bodyRect = fromHTMlElement(body);
123
- }
124
- if (anchor instanceof HTMLElement) {
125
- details.anchorRect = fromHTMlElement(anchor);
126
- }
127
- }
128
-
129
- const pointer = fromXY(this._mx, this._my, 2);
130
- const hoveredAnchors = new Set();
131
- for (const [bridge, details] of bridgeToDetails) {
132
- const { anchor, bodyRect, anchorRect, position, body } = details;
133
- if (!bodyRect && !anchorRect) {
134
- continue;
135
- }
136
-
137
- const { x, y } = position(anchorRect, bodyRect);
138
- const positionKey = `${x}-${y}`;
139
-
140
- if (body && bodyRect && this._positions.get(bridge) !== positionKey) {
141
- const ax = anchorRect
142
- ? clamp(
143
- 0,
144
- anchorRect.x - x + anchorRect.w / 2,
145
- bodyRect.w - anchorRect.w / 2
146
- )
147
- : 0;
148
- this._positions.set(bridge, positionKey);
149
- const bodyStyle = body.style;
150
- bodyStyle.position = 'absolute';
151
- bodyStyle.left = `${x}px`;
152
- bodyStyle.top = `${y}px`;
153
- bodyStyle.setProperty('--czi-pop-up-anchor-offset-left', `${ax}px`);
154
- bodyRect.x = x;
155
- bodyRect.y = y;
156
- }
157
-
158
- if (
159
- isIntersected(pointer, bodyRect || DUMMY_RECT, 0) ||
160
- isIntersected(pointer, anchorRect || DUMMY_RECT, 0)
161
- ) {
162
- if (anchor) {
163
- hoveredAnchors.add(anchor);
164
- }
165
- }
166
- }
167
-
168
- while (true) {
169
- const size = hoveredAnchors.size;
170
- for (const [
171
- // eslint-disable-next-line no-unused-vars
172
- bridge,
173
- details,
174
- ] of bridgeToDetails) {
175
- const { anchor, body } = details;
176
- for (const ha of hoveredAnchors) {
177
- if (
178
- anchor &&
179
- body &&
180
- !hoveredAnchors.has(anchor) &&
181
- body.contains(ha)
182
- ) {
183
- hoveredAnchors.add(anchor);
184
- }
185
- }
186
- }
187
- if (hoveredAnchors.size === size) {
188
- break;
189
- }
190
- }
191
-
192
- const now = Date.now();
193
- for (const [bridge, registeredAt] of this._bridges) {
194
- const details = bridgeToDetails.get(bridge);
195
- if (details) {
196
- const { autoDismiss, anchor, close, modal } = details;
197
- if (
198
- autoDismiss &&
199
- // Modal is handled separately at `onClick`
200
- !modal &&
201
- now - registeredAt > CLICK_INTERVAL &&
202
- !hoveredAnchors.has(anchor)
203
- ) {
204
- close();
205
- }
206
- }
207
- }
208
- };
209
- }
210
-
211
- const instance = new PopUpManager();
212
-
213
- export default instance;
@@ -1,156 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.atAnchorBottomLeft = atAnchorBottomLeft;
7
- exports.atAnchorBottomCenter = atAnchorBottomCenter;
8
- exports.atAnchorRight = atAnchorRight;
9
- exports.atViewportCenter = atViewportCenter;
10
- exports.atAnchorTopRight = atAnchorTopRight;
11
- exports.atAnchorTopCenter = atAnchorTopCenter;
12
- exports.bpfrpt_proptype_PositionHandler = void 0;
13
-
14
- var _rects = require("./rects");
15
-
16
- var _propTypes = _interopRequireDefault(require("prop-types"));
17
-
18
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
-
20
- var bpfrpt_proptype_PositionHandler = _propTypes.default.func;
21
- exports.bpfrpt_proptype_PositionHandler = bpfrpt_proptype_PositionHandler;
22
-
23
- function atAnchorBottomLeft(anchorRect, bodyRect) {
24
- const rect = {
25
- x: 0,
26
- y: 0,
27
- w: 0,
28
- h: 0
29
- };
30
-
31
- if (anchorRect && bodyRect) {
32
- rect.x = anchorRect.x;
33
- rect.y = anchorRect.y + anchorRect.h;
34
- const viewportWidth = window.innerWidth;
35
- const viewportHeight = window.innerHeight;
36
-
37
- if (rect.x + bodyRect.w > viewportWidth) {
38
- rect.x = anchorRect.x - bodyRect.w + anchorRect.w;
39
- }
40
-
41
- if (rect.y + bodyRect.h > viewportHeight) {
42
- rect.y = Math.max(anchorRect.y - bodyRect.h, 2);
43
- }
44
- }
45
-
46
- if (!anchorRect || (0, _rects.isCollapsed)(anchorRect)) {
47
- rect.x = -10000;
48
- }
49
-
50
- return rect;
51
- }
52
-
53
- function atAnchorBottomCenter(anchorRect, bodyRect) {
54
- const rect = {
55
- x: 0,
56
- y: 0,
57
- w: 0,
58
- h: 0
59
- };
60
-
61
- if (anchorRect && bodyRect) {
62
- rect.x = Math.max(anchorRect.x - (bodyRect.w - anchorRect.w) / 2, 10);
63
- rect.y = anchorRect.y + anchorRect.h;
64
- }
65
-
66
- if (!anchorRect || (0, _rects.isCollapsed)(anchorRect)) {
67
- rect.x = -10000;
68
- }
69
-
70
- return rect;
71
- }
72
-
73
- function atAnchorRight(anchorRect, bodyRect) {
74
- const rect = {
75
- x: 0,
76
- y: 0,
77
- w: 0,
78
- h: 0
79
- };
80
-
81
- if (anchorRect && bodyRect) {
82
- rect.x = anchorRect.x + anchorRect.w + 1;
83
- rect.y = anchorRect.y;
84
- const viewportWidth = window.innerWidth;
85
-
86
- if (rect.x + bodyRect.w > viewportWidth) {
87
- rect.x = Math.max(2, anchorRect.x - bodyRect.w);
88
- }
89
- }
90
-
91
- if (!anchorRect || (0, _rects.isCollapsed)(anchorRect)) {
92
- rect.x = -10000;
93
- }
94
-
95
- return rect;
96
- }
97
-
98
- function atViewportCenter(anchorRect, bodyRect) {
99
- const rect = {
100
- x: 0,
101
- y: 0,
102
- w: 0,
103
- h: 0
104
- };
105
-
106
- if (bodyRect) {
107
- rect.x = (window.innerWidth - bodyRect.w) / 2;
108
- rect.y = (window.innerHeight - bodyRect.h) / 2;
109
- }
110
-
111
- if (!bodyRect || (0, _rects.isCollapsed)(bodyRect)) {
112
- rect.x = -10000;
113
- }
114
-
115
- return rect;
116
- }
117
-
118
- function atAnchorTopRight(anchorRect, bodyRect) {
119
- const rect = {
120
- x: 0,
121
- y: 0,
122
- w: 0,
123
- h: 0
124
- };
125
-
126
- if (anchorRect && bodyRect) {
127
- rect.x = anchorRect.x + anchorRect.w + 1 - bodyRect.w;
128
- rect.y = anchorRect.y;
129
- }
130
-
131
- if (!anchorRect || (0, _rects.isCollapsed)(anchorRect)) {
132
- rect.x = -10000;
133
- }
134
-
135
- return rect;
136
- }
137
-
138
- function atAnchorTopCenter(anchorRect, bodyRect) {
139
- const rect = {
140
- x: 0,
141
- y: 0,
142
- w: 0,
143
- h: 0
144
- };
145
-
146
- if (anchorRect && bodyRect) {
147
- rect.x = anchorRect.x + (anchorRect.w - bodyRect.w) / 2;
148
- rect.y = anchorRect.y;
149
- }
150
-
151
- if (!anchorRect || (0, _rects.isCollapsed)(anchorRect)) {
152
- rect.x = -10000;
153
- }
154
-
155
- return rect;
156
- }
@@ -1,104 +0,0 @@
1
- // @flow
2
-
3
- import { isCollapsed } from './rects';
4
-
5
- import type { Rect } from './rects';
6
-
7
- export type PositionHandler = (anchorRect: ?Rect, bodyRect: ?Rect) => Rect;
8
-
9
- export function atAnchorBottomLeft(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
10
- const rect = { x: 0, y: 0, w: 0, h: 0 };
11
- if (anchorRect && bodyRect) {
12
- rect.x = anchorRect.x;
13
- rect.y = anchorRect.y + anchorRect.h;
14
-
15
- const viewportWidth = window.innerWidth;
16
- const viewportHeight = window.innerHeight;
17
- if (rect.x + bodyRect.w > viewportWidth) {
18
- rect.x = anchorRect.x - bodyRect.w + anchorRect.w;
19
- }
20
- if (rect.y + bodyRect.h > viewportHeight) {
21
- rect.y = Math.max(anchorRect.y - bodyRect.h, 2);
22
- }
23
- }
24
-
25
- if (!anchorRect || isCollapsed(anchorRect)) {
26
- rect.x = -10000;
27
- }
28
-
29
- return rect;
30
- }
31
-
32
- export function atAnchorBottomCenter(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
33
- const rect = { x: 0, y: 0, w: 0, h: 0 };
34
- if (anchorRect && bodyRect) {
35
- rect.x = Math.max(anchorRect.x - (bodyRect.w - anchorRect.w) / 2, 10);
36
- rect.y = anchorRect.y + anchorRect.h;
37
- }
38
-
39
- if (!anchorRect || isCollapsed(anchorRect)) {
40
- rect.x = -10000;
41
- }
42
-
43
- return rect;
44
- }
45
-
46
- export function atAnchorRight(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
47
- const rect = { x: 0, y: 0, w: 0, h: 0 };
48
- if (anchorRect && bodyRect) {
49
- rect.x = anchorRect.x + anchorRect.w + 1;
50
- rect.y = anchorRect.y;
51
- const viewportWidth = window.innerWidth;
52
- if (rect.x + bodyRect.w > viewportWidth) {
53
- rect.x = Math.max(2, anchorRect.x - bodyRect.w);
54
- }
55
- }
56
-
57
- if (!anchorRect || isCollapsed(anchorRect)) {
58
- rect.x = -10000;
59
- }
60
-
61
- return rect;
62
- }
63
-
64
- export function atViewportCenter(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
65
- const rect = { x: 0, y: 0, w: 0, h: 0 };
66
- if (bodyRect) {
67
- rect.x = (window.innerWidth - bodyRect.w) / 2;
68
- rect.y = (window.innerHeight - bodyRect.h) / 2;
69
- }
70
-
71
- if (!bodyRect || isCollapsed(bodyRect)) {
72
- rect.x = -10000;
73
- }
74
-
75
- return rect;
76
- }
77
-
78
- export function atAnchorTopRight(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
79
- const rect = { x: 0, y: 0, w: 0, h: 0 };
80
- if (anchorRect && bodyRect) {
81
- rect.x = anchorRect.x + anchorRect.w + 1 - bodyRect.w;
82
- rect.y = anchorRect.y;
83
- }
84
-
85
- if (!anchorRect || isCollapsed(anchorRect)) {
86
- rect.x = -10000;
87
- }
88
-
89
- return rect;
90
- }
91
-
92
- export function atAnchorTopCenter(anchorRect: ?Rect, bodyRect: ?Rect): Rect {
93
- const rect = { x: 0, y: 0, w: 0, h: 0 };
94
- if (anchorRect && bodyRect) {
95
- rect.x = anchorRect.x + (anchorRect.w - bodyRect.w) / 2;
96
- rect.y = anchorRect.y;
97
- }
98
-
99
- if (!anchorRect || isCollapsed(anchorRect)) {
100
- rect.x = -10000;
101
- }
102
-
103
- return rect;
104
- }
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,99 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
-
8
- require("./czi-tooltip-surface.css");
9
-
10
- require("./czi-animations.css");
11
-
12
- var React = _interopRequireWildcard(require("react"));
13
-
14
- var _createPopUp = _interopRequireDefault(require("./createPopUp"));
15
-
16
- var _PopUpPosition = require("./PopUpPosition");
17
-
18
- var _uuid = _interopRequireDefault(require("./uuid"));
19
-
20
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
-
22
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
-
24
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
25
-
26
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
27
-
28
- class TooltipView extends React.PureComponent {
29
- render() {
30
- const {
31
- tooltip
32
- } = this.props;
33
- return /*#__PURE__*/React.createElement("div", {
34
- className: "czi-tooltip-view czi-animation-fade-in"
35
- }, tooltip);
36
- }
37
-
38
- }
39
-
40
- class TooltipSurface extends React.PureComponent {
41
- constructor() {
42
- super(...arguments);
43
-
44
- _defineProperty(this, "_id", (0, _uuid.default)());
45
-
46
- _defineProperty(this, "_popUp", null);
47
-
48
- _defineProperty(this, "props", void 0);
49
-
50
- _defineProperty(this, "_onMouseEnter", () => {
51
- if (!this._popUp) {
52
- const {
53
- tooltip
54
- } = this.props;
55
- this._popUp = (0, _createPopUp.default)(TooltipView, {
56
- tooltip
57
- }, {
58
- anchor: document.getElementById(this._id),
59
- onClose: this._onClose,
60
- position: _PopUpPosition.atAnchorBottomCenter
61
- });
62
- }
63
- });
64
-
65
- _defineProperty(this, "_onMouseLeave", () => {
66
- this._popUp && this._popUp.close();
67
- this._popUp = null;
68
- });
69
-
70
- _defineProperty(this, "_onClose", () => {
71
- this._popUp = null;
72
- });
73
- }
74
-
75
- componentWillUnmount() {
76
- this._popUp && this._popUp.close();
77
- }
78
-
79
- render() {
80
- const {
81
- tooltip,
82
- children
83
- } = this.props;
84
- return /*#__PURE__*/React.createElement("span", {
85
- "aria-label": tooltip,
86
- className: "czi-tooltip-surface",
87
- "data-tooltip": tooltip,
88
- id: this._id,
89
- onMouseDown: tooltip && this._onMouseLeave,
90
- onMouseEnter: tooltip && this._onMouseEnter,
91
- onMouseLeave: tooltip && this._onMouseLeave,
92
- role: "tooltip"
93
- }, children);
94
- }
95
-
96
- }
97
-
98
- var _default = TooltipSurface;
99
- exports.default = _default;
@@ -1,76 +0,0 @@
1
- // @flow
2
-
3
- import './czi-tooltip-surface.css';
4
- import './czi-animations.css';
5
-
6
- import * as React from 'react';
7
- import createPopUp from './createPopUp';
8
- import { atAnchorBottomCenter } from './PopUpPosition';
9
- import uuid from './uuid';
10
-
11
- class TooltipView extends React.PureComponent<any, any> {
12
- render(): React.Element<any> {
13
- const { tooltip } = this.props;
14
- return (
15
- <div className="czi-tooltip-view czi-animation-fade-in">{tooltip}</div>
16
- );
17
- }
18
- }
19
-
20
- class TooltipSurface extends React.PureComponent<any, any> {
21
- _id = uuid();
22
- _popUp = null;
23
-
24
- props: {
25
- tooltip: string,
26
- children?: any,
27
- };
28
-
29
- componentWillUnmount(): void {
30
- this._popUp && this._popUp.close();
31
- }
32
-
33
- render(): React.Element<any> {
34
- const { tooltip, children } = this.props;
35
- return (
36
- <span
37
- aria-label={tooltip}
38
- className="czi-tooltip-surface"
39
- data-tooltip={tooltip}
40
- id={this._id}
41
- onMouseDown={tooltip && this._onMouseLeave}
42
- onMouseEnter={tooltip && this._onMouseEnter}
43
- onMouseLeave={tooltip && this._onMouseLeave}
44
- role="tooltip"
45
- >
46
- {children}
47
- </span>
48
- );
49
- }
50
-
51
- _onMouseEnter = (): void => {
52
- if (!this._popUp) {
53
- const { tooltip } = this.props;
54
- this._popUp = createPopUp(
55
- TooltipView,
56
- { tooltip },
57
- {
58
- anchor: document.getElementById(this._id),
59
- onClose: this._onClose,
60
- position: atAnchorBottomCenter,
61
- }
62
- );
63
- }
64
- };
65
-
66
- _onMouseLeave = (): void => {
67
- this._popUp && this._popUp.close();
68
- this._popUp = null;
69
- };
70
-
71
- _onClose = (): void => {
72
- this._popUp = null;
73
- };
74
- }
75
-
76
- export default TooltipSurface;
package/dist/ui/clamp.js DELETED
@@ -1,18 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = clamp;
7
-
8
- function clamp(min, val, max) {
9
- if (val < min) {
10
- return min;
11
- }
12
-
13
- if (val > max) {
14
- return max;
15
- }
16
-
17
- return val;
18
- }
@@ -1,11 +0,0 @@
1
- // @flow
2
-
3
- export default function clamp(min: number, val: number, max: number): number {
4
- if (val < min) {
5
- return min;
6
- }
7
- if (val > max) {
8
- return max;
9
- }
10
- return val;
11
- }