js-draw 0.25.0 → 1.0.0

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 (810) hide show
  1. package/README.md +60 -20
  2. package/build-config.json +22 -21
  3. package/dist/Editor.css +1281 -0
  4. package/dist/bundle.js +3 -3
  5. package/dist/bundledStyles.js +1 -1
  6. package/dist/cjs/Editor.d.ts +91 -12
  7. package/dist/cjs/Editor.js +619 -590
  8. package/dist/cjs/EditorImage.d.ts +5 -2
  9. package/dist/cjs/EditorImage.js +258 -297
  10. package/dist/cjs/EventDispatcher.js +17 -19
  11. package/dist/cjs/Pointer.d.ts +3 -1
  12. package/dist/cjs/Pointer.js +44 -45
  13. package/dist/cjs/SVGLoader.d.ts +7 -1
  14. package/dist/cjs/SVGLoader.js +373 -474
  15. package/dist/cjs/UndoRedoHistory.js +28 -40
  16. package/dist/cjs/Viewport.d.ts +1 -4
  17. package/dist/cjs/Viewport.js +150 -193
  18. package/dist/cjs/bundle/bundled.js +4 -1
  19. package/dist/cjs/commands/Command.js +22 -49
  20. package/dist/cjs/commands/Duplicate.js +28 -44
  21. package/dist/cjs/commands/Erase.js +36 -54
  22. package/dist/cjs/commands/SerializableCommand.js +20 -35
  23. package/dist/cjs/commands/UnresolvedCommand.js +14 -29
  24. package/dist/cjs/commands/invertCommand.js +29 -51
  25. package/dist/cjs/commands/lib.js +9 -6
  26. package/dist/cjs/commands/localization.d.ts +1 -1
  27. package/dist/cjs/commands/localization.js +9 -9
  28. package/dist/cjs/commands/uniteCommands.js +57 -87
  29. package/dist/cjs/components/AbstractComponent.d.ts +11 -3
  30. package/dist/cjs/components/AbstractComponent.js +141 -169
  31. package/dist/cjs/components/BackgroundComponent.d.ts +3 -6
  32. package/dist/cjs/components/BackgroundComponent.js +124 -149
  33. package/dist/cjs/components/ImageComponent.d.ts +3 -5
  34. package/dist/cjs/components/ImageComponent.js +95 -175
  35. package/dist/cjs/components/RestylableComponent.d.ts +1 -1
  36. package/dist/cjs/components/RestylableComponent.js +41 -56
  37. package/dist/cjs/components/SVGGlobalAttributesObject.d.ts +1 -3
  38. package/dist/cjs/components/SVGGlobalAttributesObject.js +34 -51
  39. package/dist/cjs/components/Stroke.d.ts +4 -6
  40. package/dist/cjs/components/Stroke.js +95 -121
  41. package/dist/cjs/components/TextComponent.d.ts +2 -4
  42. package/dist/cjs/components/TextComponent.js +189 -234
  43. package/dist/cjs/components/UnknownSVGObject.d.ts +1 -3
  44. package/dist/cjs/components/UnknownSVGObject.js +30 -43
  45. package/dist/cjs/components/builders/ArrowBuilder.d.ts +1 -1
  46. package/dist/cjs/components/builders/ArrowBuilder.js +43 -42
  47. package/dist/cjs/components/builders/CircleBuilder.js +43 -43
  48. package/dist/cjs/components/builders/FreehandLineBuilder.d.ts +3 -2
  49. package/dist/cjs/components/builders/FreehandLineBuilder.js +73 -86
  50. package/dist/cjs/components/builders/LineBuilder.d.ts +1 -1
  51. package/dist/cjs/components/builders/LineBuilder.js +38 -36
  52. package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +1 -1
  53. package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.js +131 -139
  54. package/dist/cjs/components/builders/RectangleBuilder.d.ts +1 -1
  55. package/dist/cjs/components/builders/RectangleBuilder.js +31 -31
  56. package/dist/cjs/components/builders/types.d.ts +1 -1
  57. package/dist/cjs/components/lib.d.ts +3 -1
  58. package/dist/cjs/components/lib.js +10 -7
  59. package/dist/cjs/components/localization.js +4 -4
  60. package/dist/cjs/components/util/StrokeSmoother.d.ts +1 -2
  61. package/dist/cjs/components/util/StrokeSmoother.js +67 -72
  62. package/dist/cjs/components/util/describeComponentList.d.ts +1 -1
  63. package/dist/cjs/components/util/describeComponentList.js +4 -5
  64. package/dist/cjs/dialogs/makeAboutDialog.d.ts +15 -0
  65. package/dist/cjs/dialogs/makeAboutDialog.js +54 -0
  66. package/dist/cjs/inputEvents.d.ts +84 -0
  67. package/dist/cjs/inputEvents.js +40 -0
  68. package/dist/cjs/lib.d.ts +29 -13
  69. package/dist/cjs/lib.js +38 -23
  70. package/dist/cjs/localization.js +19 -18
  71. package/dist/cjs/localizations/de.js +117 -13
  72. package/dist/cjs/localizations/en.js +4 -13
  73. package/dist/cjs/localizations/es.js +62 -23
  74. package/dist/cjs/localizations/getLocalizationTable.js +15 -13
  75. package/dist/cjs/rendering/Display.d.ts +1 -2
  76. package/dist/cjs/rendering/Display.js +70 -83
  77. package/dist/cjs/rendering/RenderablePathSpec.d.ts +15 -0
  78. package/dist/cjs/rendering/RenderablePathSpec.js +70 -0
  79. package/dist/cjs/rendering/RenderingStyle.d.ts +4 -4
  80. package/dist/cjs/rendering/RenderingStyle.js +18 -28
  81. package/dist/cjs/rendering/TextRenderingStyle.d.ts +10 -10
  82. package/dist/cjs/rendering/TextRenderingStyle.js +13 -18
  83. package/dist/cjs/rendering/caching/CacheRecord.d.ts +1 -2
  84. package/dist/cjs/rendering/caching/CacheRecord.js +20 -22
  85. package/dist/cjs/rendering/caching/CacheRecordManager.d.ts +1 -1
  86. package/dist/cjs/rendering/caching/CacheRecordManager.js +17 -15
  87. package/dist/cjs/rendering/caching/RenderingCache.js +19 -19
  88. package/dist/cjs/rendering/caching/RenderingCacheNode.d.ts +1 -1
  89. package/dist/cjs/rendering/caching/RenderingCacheNode.js +98 -118
  90. package/dist/cjs/rendering/caching/testUtils.js +24 -23
  91. package/dist/cjs/rendering/caching/types.d.ts +3 -3
  92. package/dist/cjs/rendering/lib.js +8 -5
  93. package/dist/cjs/rendering/localization.js +5 -5
  94. package/dist/cjs/rendering/renderers/AbstractRenderer.d.ts +2 -11
  95. package/dist/cjs/rendering/renderers/AbstractRenderer.js +53 -57
  96. package/dist/cjs/rendering/renderers/CanvasRenderer.d.ts +3 -5
  97. package/dist/cjs/rendering/renderers/CanvasRenderer.js +91 -106
  98. package/dist/cjs/rendering/renderers/DummyRenderer.d.ts +1 -4
  99. package/dist/cjs/rendering/renderers/DummyRenderer.js +56 -76
  100. package/dist/cjs/rendering/renderers/SVGRenderer.d.ts +5 -5
  101. package/dist/cjs/rendering/renderers/SVGRenderer.js +194 -176
  102. package/dist/cjs/rendering/renderers/TextOnlyRenderer.d.ts +1 -3
  103. package/dist/cjs/rendering/renderers/TextOnlyRenderer.js +47 -72
  104. package/dist/cjs/shortcuts/KeyBinding.d.ts +5 -0
  105. package/dist/cjs/shortcuts/KeyBinding.js +94 -70
  106. package/dist/cjs/shortcuts/KeyboardShortcutManager.d.ts +1 -1
  107. package/dist/cjs/shortcuts/KeyboardShortcutManager.js +36 -45
  108. package/dist/cjs/shortcuts/lib.js +5 -2
  109. package/dist/cjs/testing/createEditor.js +7 -4
  110. package/dist/cjs/testing/getUniquePointerId.js +4 -5
  111. package/dist/cjs/testing/lib.js +5 -2
  112. package/dist/cjs/testing/sendPenEvent.d.ts +2 -2
  113. package/dist/cjs/testing/sendPenEvent.js +10 -7
  114. package/dist/cjs/testing/sendTouchEvent.d.ts +2 -2
  115. package/dist/cjs/testing/sendTouchEvent.js +34 -16
  116. package/dist/cjs/toolbar/AbstractToolbar.d.ts +166 -0
  117. package/dist/cjs/toolbar/AbstractToolbar.js +410 -0
  118. package/dist/cjs/toolbar/DropdownToolbar.d.ts +43 -0
  119. package/dist/cjs/toolbar/DropdownToolbar.js +176 -0
  120. package/dist/cjs/toolbar/EdgeToolbar.d.ts +47 -0
  121. package/dist/cjs/toolbar/EdgeToolbar.js +422 -0
  122. package/dist/cjs/toolbar/IconProvider.d.ts +54 -30
  123. package/dist/cjs/toolbar/IconProvider.js +652 -224
  124. package/dist/cjs/toolbar/constants.d.ts +1 -0
  125. package/dist/cjs/toolbar/constants.js +4 -0
  126. package/dist/cjs/toolbar/lib.d.ts +4 -2
  127. package/dist/cjs/toolbar/lib.js +10 -3
  128. package/dist/cjs/toolbar/localization.d.ts +9 -2
  129. package/dist/cjs/toolbar/localization.js +26 -19
  130. package/dist/cjs/toolbar/types.d.ts +7 -0
  131. package/dist/cjs/toolbar/widgets/ActionButtonWidget.d.ts +1 -1
  132. package/dist/cjs/toolbar/widgets/ActionButtonWidget.js +23 -39
  133. package/dist/cjs/toolbar/widgets/BaseToolWidget.d.ts +1 -1
  134. package/dist/cjs/toolbar/widgets/BaseToolWidget.js +35 -37
  135. package/dist/cjs/toolbar/widgets/BaseWidget.d.ts +60 -5
  136. package/dist/cjs/toolbar/widgets/BaseWidget.js +232 -177
  137. package/dist/cjs/toolbar/widgets/DocumentPropertiesWidget.js +130 -117
  138. package/dist/cjs/toolbar/widgets/EraserToolWidget.d.ts +1 -3
  139. package/dist/cjs/toolbar/widgets/EraserToolWidget.js +45 -73
  140. package/dist/cjs/toolbar/widgets/HandToolWidget.d.ts +1 -0
  141. package/dist/cjs/toolbar/widgets/HandToolWidget.js +126 -141
  142. package/dist/cjs/toolbar/widgets/InsertImageWidget.d.ts +9 -7
  143. package/dist/cjs/toolbar/widgets/InsertImageWidget.js +147 -212
  144. package/dist/cjs/toolbar/widgets/OverflowWidget.js +33 -61
  145. package/dist/cjs/toolbar/widgets/PenToolWidget.d.ts +8 -1
  146. package/dist/cjs/toolbar/widgets/PenToolWidget.js +162 -234
  147. package/dist/cjs/toolbar/widgets/SelectionToolWidget.d.ts +3 -1
  148. package/dist/cjs/toolbar/widgets/SelectionToolWidget.js +105 -177
  149. package/dist/cjs/toolbar/widgets/TextToolWidget.js +64 -87
  150. package/dist/cjs/toolbar/widgets/components/makeColorInput.d.ts +10 -0
  151. package/dist/cjs/toolbar/{makeColorInput.js → widgets/components/makeColorInput.js} +57 -34
  152. package/dist/cjs/toolbar/widgets/components/makeFileInput.d.ts +12 -0
  153. package/dist/cjs/toolbar/widgets/components/makeFileInput.js +111 -0
  154. package/dist/cjs/toolbar/widgets/components/makeGridSelector.d.ts +24 -0
  155. package/dist/cjs/toolbar/widgets/components/makeGridSelector.js +127 -0
  156. package/dist/cjs/toolbar/widgets/components/makeSeparator.d.ts +7 -0
  157. package/dist/cjs/toolbar/widgets/components/makeSeparator.js +16 -0
  158. package/dist/cjs/toolbar/widgets/components/makeThicknessSlider.d.ts +8 -0
  159. package/dist/cjs/toolbar/widgets/components/makeThicknessSlider.js +47 -0
  160. package/dist/cjs/toolbar/widgets/keybindings.js +8 -5
  161. package/dist/cjs/toolbar/widgets/layout/DropdownLayoutManager.d.ts +21 -0
  162. package/dist/cjs/toolbar/widgets/layout/DropdownLayoutManager.js +199 -0
  163. package/dist/cjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.d.ts +14 -0
  164. package/dist/cjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.js +60 -0
  165. package/dist/cjs/toolbar/widgets/layout/types.d.ts +63 -0
  166. package/dist/cjs/toolbar/widgets/layout/types.js +2 -0
  167. package/dist/cjs/toolbar/widgets/lib.d.ts +1 -1
  168. package/dist/cjs/toolbar/widgets/lib.js +15 -11
  169. package/dist/cjs/tools/BaseTool.d.ts +28 -9
  170. package/dist/cjs/tools/BaseTool.js +128 -51
  171. package/dist/cjs/tools/Eraser.d.ts +8 -1
  172. package/dist/cjs/tools/Eraser.js +82 -92
  173. package/dist/cjs/tools/FindTool.d.ts +1 -1
  174. package/dist/cjs/tools/FindTool.js +61 -77
  175. package/dist/cjs/tools/InputFilter/FunctionMapper.d.ts +12 -0
  176. package/dist/cjs/tools/InputFilter/FunctionMapper.js +21 -0
  177. package/dist/cjs/tools/InputFilter/InputMapper.d.ts +23 -0
  178. package/dist/cjs/tools/InputFilter/InputMapper.js +38 -0
  179. package/dist/cjs/tools/InputFilter/InputPipeline.d.ts +15 -0
  180. package/dist/cjs/tools/InputFilter/InputPipeline.js +54 -0
  181. package/dist/cjs/tools/InputFilter/InputStabilizer.d.ts +29 -0
  182. package/dist/cjs/tools/InputFilter/InputStabilizer.js +181 -0
  183. package/dist/cjs/tools/InputFilter/StrokeKeyboardControl.d.ts +21 -0
  184. package/dist/cjs/tools/InputFilter/StrokeKeyboardControl.js +84 -0
  185. package/dist/cjs/tools/PanZoom.d.ts +4 -2
  186. package/dist/cjs/tools/PanZoom.js +186 -248
  187. package/dist/cjs/tools/PasteHandler.d.ts +1 -1
  188. package/dist/cjs/tools/PasteHandler.js +49 -148
  189. package/dist/cjs/tools/Pen.d.ts +12 -11
  190. package/dist/cjs/tools/Pen.js +123 -158
  191. package/dist/cjs/tools/PipetteTool.d.ts +11 -2
  192. package/dist/cjs/tools/PipetteTool.js +51 -48
  193. package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +1 -1
  194. package/dist/cjs/tools/SelectionTool/SelectAllShortcutHandler.js +15 -30
  195. package/dist/cjs/tools/SelectionTool/Selection.d.ts +5 -5
  196. package/dist/cjs/tools/SelectionTool/Selection.js +308 -415
  197. package/dist/cjs/tools/SelectionTool/SelectionHandle.d.ts +15 -5
  198. package/dist/cjs/tools/SelectionTool/SelectionHandle.js +63 -37
  199. package/dist/cjs/tools/SelectionTool/SelectionTool.d.ts +4 -4
  200. package/dist/cjs/tools/SelectionTool/SelectionTool.js +164 -187
  201. package/dist/cjs/tools/SelectionTool/TransformMode.d.ts +1 -1
  202. package/dist/cjs/tools/SelectionTool/TransformMode.js +65 -66
  203. package/dist/cjs/tools/SoundUITool.d.ts +2 -1
  204. package/dist/cjs/tools/SoundUITool.js +70 -84
  205. package/dist/cjs/tools/TextTool.d.ts +5 -3
  206. package/dist/cjs/tools/TextTool.js +169 -173
  207. package/dist/cjs/tools/ToolController.d.ts +16 -2
  208. package/dist/cjs/tools/ToolController.js +124 -100
  209. package/dist/cjs/tools/ToolEnabledGroup.js +6 -9
  210. package/dist/cjs/tools/ToolSwitcherShortcut.d.ts +1 -1
  211. package/dist/cjs/tools/ToolSwitcherShortcut.js +16 -32
  212. package/dist/cjs/tools/ToolbarShortcutHandler.d.ts +1 -1
  213. package/dist/cjs/tools/ToolbarShortcutHandler.js +17 -33
  214. package/dist/cjs/tools/UndoRedoShortcut.d.ts +1 -1
  215. package/dist/cjs/tools/UndoRedoShortcut.js +12 -27
  216. package/dist/cjs/tools/keybindings.js +21 -18
  217. package/dist/cjs/tools/lib.js +17 -14
  218. package/dist/cjs/tools/localization.d.ts +2 -1
  219. package/dist/cjs/tools/localization.js +8 -7
  220. package/dist/cjs/types.d.ts +22 -80
  221. package/dist/cjs/types.js +8 -16
  222. package/dist/cjs/util/ReactiveValue.d.ts +65 -0
  223. package/dist/cjs/util/ReactiveValue.js +166 -0
  224. package/dist/cjs/util/assertions.js +5 -8
  225. package/dist/cjs/util/fileToBase64.js +6 -6
  226. package/dist/cjs/util/guessKeyCodeFromKey.d.ts +9 -0
  227. package/dist/cjs/util/guessKeyCodeFromKey.js +32 -0
  228. package/dist/cjs/util/listPrefixMatch.d.ts +6 -0
  229. package/dist/cjs/util/listPrefixMatch.js +17 -0
  230. package/dist/cjs/util/stopPropagationOfScrollingWheelEvents.d.ts +2 -0
  231. package/dist/cjs/util/stopPropagationOfScrollingWheelEvents.js +17 -0
  232. package/dist/cjs/util/untilNextAnimationFrame.js +3 -3
  233. package/dist/cjs/util/waitForAll.js +3 -3
  234. package/dist/cjs/util/waitForTimeout.js +3 -3
  235. package/dist/cjs/version.d.ts +4 -0
  236. package/dist/cjs/version.js +5 -0
  237. package/dist/mjs/Editor.d.ts +91 -12
  238. package/dist/mjs/Editor.mjs +565 -563
  239. package/dist/mjs/EditorImage.d.ts +5 -2
  240. package/dist/mjs/EditorImage.mjs +248 -291
  241. package/dist/mjs/EventDispatcher.mjs +17 -20
  242. package/dist/mjs/Pointer.d.ts +3 -1
  243. package/dist/mjs/Pointer.mjs +43 -45
  244. package/dist/mjs/SVGLoader.d.ts +7 -1
  245. package/dist/mjs/SVGLoader.mjs +338 -466
  246. package/dist/mjs/UndoRedoHistory.mjs +27 -39
  247. package/dist/mjs/Viewport.d.ts +1 -4
  248. package/dist/mjs/Viewport.mjs +139 -187
  249. package/dist/mjs/commands/Command.mjs +21 -49
  250. package/dist/mjs/commands/Duplicate.mjs +22 -41
  251. package/dist/mjs/commands/Erase.mjs +30 -51
  252. package/dist/mjs/commands/SerializableCommand.mjs +16 -34
  253. package/dist/mjs/commands/UnresolvedCommand.mjs +10 -29
  254. package/dist/mjs/commands/invertCommand.mjs +24 -49
  255. package/dist/mjs/commands/localization.d.ts +1 -1
  256. package/dist/mjs/commands/localization.mjs +10 -10
  257. package/dist/mjs/commands/uniteCommands.mjs +52 -85
  258. package/dist/mjs/components/AbstractComponent.d.ts +11 -3
  259. package/dist/mjs/components/AbstractComponent.mjs +135 -166
  260. package/dist/mjs/components/BackgroundComponent.d.ts +3 -6
  261. package/dist/mjs/components/BackgroundComponent.mjs +107 -136
  262. package/dist/mjs/components/ImageComponent.d.ts +3 -5
  263. package/dist/mjs/components/ImageComponent.mjs +90 -174
  264. package/dist/mjs/components/RestylableComponent.d.ts +1 -1
  265. package/dist/mjs/components/RestylableComponent.mjs +35 -53
  266. package/dist/mjs/components/SVGGlobalAttributesObject.d.ts +1 -3
  267. package/dist/mjs/components/SVGGlobalAttributesObject.mjs +29 -50
  268. package/dist/mjs/components/Stroke.d.ts +4 -6
  269. package/dist/mjs/components/Stroke.mjs +89 -119
  270. package/dist/mjs/components/TextComponent.d.ts +2 -4
  271. package/dist/mjs/components/TextComponent.mjs +180 -228
  272. package/dist/mjs/components/UnknownSVGObject.d.ts +1 -3
  273. package/dist/mjs/components/UnknownSVGObject.mjs +26 -43
  274. package/dist/mjs/components/builders/ArrowBuilder.d.ts +1 -1
  275. package/dist/mjs/components/builders/ArrowBuilder.mjs +32 -35
  276. package/dist/mjs/components/builders/CircleBuilder.mjs +35 -38
  277. package/dist/mjs/components/builders/FreehandLineBuilder.d.ts +3 -2
  278. package/dist/mjs/components/builders/FreehandLineBuilder.mjs +52 -69
  279. package/dist/mjs/components/builders/LineBuilder.d.ts +1 -1
  280. package/dist/mjs/components/builders/LineBuilder.mjs +30 -32
  281. package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.d.ts +1 -1
  282. package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.mjs +103 -115
  283. package/dist/mjs/components/builders/RectangleBuilder.d.ts +1 -1
  284. package/dist/mjs/components/builders/RectangleBuilder.mjs +27 -31
  285. package/dist/mjs/components/builders/types.d.ts +1 -1
  286. package/dist/mjs/components/lib.d.ts +3 -1
  287. package/dist/mjs/components/lib.mjs +1 -1
  288. package/dist/mjs/components/localization.mjs +5 -5
  289. package/dist/mjs/components/util/StrokeSmoother.d.ts +1 -2
  290. package/dist/mjs/components/util/StrokeSmoother.mjs +63 -69
  291. package/dist/mjs/components/util/describeComponentList.d.ts +1 -1
  292. package/dist/mjs/components/util/describeComponentList.mjs +4 -5
  293. package/dist/mjs/dialogs/makeAboutDialog.d.ts +15 -0
  294. package/dist/mjs/dialogs/makeAboutDialog.mjs +52 -0
  295. package/dist/mjs/inputEvents.d.ts +84 -0
  296. package/dist/mjs/inputEvents.mjs +34 -0
  297. package/dist/mjs/lib.d.ts +29 -13
  298. package/dist/mjs/lib.mjs +30 -13
  299. package/dist/mjs/localization.mjs +14 -13
  300. package/dist/mjs/localizations/de.mjs +116 -12
  301. package/dist/mjs/localizations/en.mjs +3 -12
  302. package/dist/mjs/localizations/es.mjs +61 -22
  303. package/dist/mjs/localizations/getLocalizationTable.mjs +12 -13
  304. package/dist/mjs/rendering/Display.d.ts +1 -2
  305. package/dist/mjs/rendering/Display.mjs +62 -79
  306. package/dist/mjs/rendering/RenderablePathSpec.d.ts +15 -0
  307. package/dist/mjs/rendering/RenderablePathSpec.mjs +64 -0
  308. package/dist/mjs/rendering/RenderingStyle.d.ts +4 -4
  309. package/dist/mjs/rendering/RenderingStyle.mjs +16 -26
  310. package/dist/mjs/rendering/TextRenderingStyle.d.ts +10 -10
  311. package/dist/mjs/rendering/TextRenderingStyle.mjs +12 -17
  312. package/dist/mjs/rendering/caching/CacheRecord.d.ts +1 -2
  313. package/dist/mjs/rendering/caching/CacheRecord.mjs +20 -23
  314. package/dist/mjs/rendering/caching/CacheRecordManager.d.ts +1 -1
  315. package/dist/mjs/rendering/caching/CacheRecordManager.mjs +13 -15
  316. package/dist/mjs/rendering/caching/RenderingCache.mjs +13 -17
  317. package/dist/mjs/rendering/caching/RenderingCacheNode.d.ts +1 -1
  318. package/dist/mjs/rendering/caching/RenderingCacheNode.mjs +94 -115
  319. package/dist/mjs/rendering/caching/testUtils.mjs +19 -21
  320. package/dist/mjs/rendering/caching/types.d.ts +3 -3
  321. package/dist/mjs/rendering/localization.mjs +6 -6
  322. package/dist/mjs/rendering/renderers/AbstractRenderer.d.ts +2 -11
  323. package/dist/mjs/rendering/renderers/AbstractRenderer.mjs +47 -52
  324. package/dist/mjs/rendering/renderers/CanvasRenderer.d.ts +3 -5
  325. package/dist/mjs/rendering/renderers/CanvasRenderer.mjs +84 -103
  326. package/dist/mjs/rendering/renderers/DummyRenderer.d.ts +1 -4
  327. package/dist/mjs/rendering/renderers/DummyRenderer.mjs +51 -75
  328. package/dist/mjs/rendering/renderers/SVGRenderer.d.ts +5 -5
  329. package/dist/mjs/rendering/renderers/SVGRenderer.mjs +185 -171
  330. package/dist/mjs/rendering/renderers/TextOnlyRenderer.d.ts +1 -3
  331. package/dist/mjs/rendering/renderers/TextOnlyRenderer.mjs +43 -72
  332. package/dist/mjs/shortcuts/KeyBinding.d.ts +5 -0
  333. package/dist/mjs/shortcuts/KeyBinding.mjs +94 -71
  334. package/dist/mjs/shortcuts/KeyboardShortcutManager.d.ts +1 -1
  335. package/dist/mjs/shortcuts/KeyboardShortcutManager.mjs +32 -44
  336. package/dist/mjs/testing/createEditor.mjs +2 -2
  337. package/dist/mjs/testing/getUniquePointerId.mjs +4 -5
  338. package/dist/mjs/testing/sendPenEvent.d.ts +2 -2
  339. package/dist/mjs/testing/sendPenEvent.mjs +5 -5
  340. package/dist/mjs/testing/sendTouchEvent.d.ts +2 -2
  341. package/dist/mjs/testing/sendTouchEvent.mjs +8 -16
  342. package/dist/mjs/toolbar/AbstractToolbar.d.ts +166 -0
  343. package/dist/mjs/toolbar/AbstractToolbar.mjs +405 -0
  344. package/dist/mjs/toolbar/DropdownToolbar.d.ts +43 -0
  345. package/dist/mjs/toolbar/DropdownToolbar.mjs +168 -0
  346. package/dist/mjs/toolbar/EdgeToolbar.d.ts +47 -0
  347. package/dist/mjs/toolbar/EdgeToolbar.mjs +414 -0
  348. package/dist/mjs/toolbar/IconProvider.d.ts +54 -30
  349. package/dist/mjs/toolbar/IconProvider.mjs +644 -219
  350. package/dist/mjs/toolbar/constants.d.ts +1 -0
  351. package/dist/mjs/toolbar/constants.mjs +1 -0
  352. package/dist/mjs/toolbar/lib.d.ts +4 -2
  353. package/dist/mjs/toolbar/lib.mjs +3 -1
  354. package/dist/mjs/toolbar/localization.d.ts +9 -2
  355. package/dist/mjs/toolbar/localization.mjs +27 -20
  356. package/dist/mjs/toolbar/types.d.ts +7 -0
  357. package/dist/mjs/toolbar/widgets/ActionButtonWidget.d.ts +1 -1
  358. package/dist/mjs/toolbar/widgets/ActionButtonWidget.mjs +19 -39
  359. package/dist/mjs/toolbar/widgets/BaseToolWidget.d.ts +1 -1
  360. package/dist/mjs/toolbar/widgets/BaseToolWidget.mjs +30 -36
  361. package/dist/mjs/toolbar/widgets/BaseWidget.d.ts +60 -5
  362. package/dist/mjs/toolbar/widgets/BaseWidget.mjs +227 -176
  363. package/dist/mjs/toolbar/widgets/DocumentPropertiesWidget.mjs +98 -111
  364. package/dist/mjs/toolbar/widgets/EraserToolWidget.d.ts +1 -3
  365. package/dist/mjs/toolbar/widgets/EraserToolWidget.mjs +41 -73
  366. package/dist/mjs/toolbar/widgets/HandToolWidget.d.ts +1 -0
  367. package/dist/mjs/toolbar/widgets/HandToolWidget.mjs +94 -136
  368. package/dist/mjs/toolbar/widgets/InsertImageWidget.d.ts +9 -7
  369. package/dist/mjs/toolbar/widgets/InsertImageWidget.mjs +140 -208
  370. package/dist/mjs/toolbar/widgets/OverflowWidget.mjs +30 -62
  371. package/dist/mjs/toolbar/widgets/PenToolWidget.d.ts +8 -1
  372. package/dist/mjs/toolbar/widgets/PenToolWidget.mjs +150 -225
  373. package/dist/mjs/toolbar/widgets/SelectionToolWidget.d.ts +3 -1
  374. package/dist/mjs/toolbar/widgets/SelectionToolWidget.mjs +97 -173
  375. package/dist/mjs/toolbar/widgets/TextToolWidget.mjs +59 -85
  376. package/dist/mjs/toolbar/widgets/components/makeColorInput.d.ts +10 -0
  377. package/dist/mjs/toolbar/{makeColorInput.mjs → widgets/components/makeColorInput.mjs} +53 -33
  378. package/dist/mjs/toolbar/widgets/components/makeFileInput.d.ts +12 -0
  379. package/dist/mjs/toolbar/widgets/components/makeFileInput.mjs +106 -0
  380. package/dist/mjs/toolbar/widgets/components/makeGridSelector.d.ts +24 -0
  381. package/dist/mjs/toolbar/widgets/components/makeGridSelector.mjs +122 -0
  382. package/dist/mjs/toolbar/widgets/components/makeSeparator.d.ts +7 -0
  383. package/dist/mjs/toolbar/widgets/components/makeSeparator.mjs +14 -0
  384. package/dist/mjs/toolbar/widgets/components/makeThicknessSlider.d.ts +8 -0
  385. package/dist/mjs/toolbar/widgets/components/makeThicknessSlider.mjs +45 -0
  386. package/dist/mjs/toolbar/widgets/keybindings.mjs +5 -5
  387. package/dist/mjs/toolbar/widgets/layout/DropdownLayoutManager.d.ts +21 -0
  388. package/dist/mjs/toolbar/widgets/layout/DropdownLayoutManager.mjs +193 -0
  389. package/dist/mjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.d.ts +14 -0
  390. package/dist/mjs/toolbar/widgets/layout/EdgeToolbarLayoutManager.mjs +57 -0
  391. package/dist/mjs/toolbar/widgets/layout/types.d.ts +63 -0
  392. package/dist/mjs/toolbar/widgets/lib.d.ts +1 -1
  393. package/dist/mjs/toolbar/widgets/lib.mjs +1 -1
  394. package/dist/mjs/tools/BaseTool.d.ts +28 -9
  395. package/dist/mjs/tools/BaseTool.mjs +127 -50
  396. package/dist/mjs/tools/Eraser.d.ts +8 -1
  397. package/dist/mjs/tools/Eraser.mjs +72 -86
  398. package/dist/mjs/tools/FindTool.d.ts +1 -1
  399. package/dist/mjs/tools/FindTool.mjs +55 -75
  400. package/dist/mjs/tools/InputFilter/FunctionMapper.d.ts +12 -0
  401. package/dist/mjs/tools/InputFilter/FunctionMapper.mjs +15 -0
  402. package/dist/mjs/tools/InputFilter/InputMapper.d.ts +23 -0
  403. package/dist/mjs/tools/InputFilter/InputMapper.mjs +36 -0
  404. package/dist/mjs/tools/InputFilter/InputPipeline.d.ts +15 -0
  405. package/dist/mjs/tools/InputFilter/InputPipeline.mjs +49 -0
  406. package/dist/mjs/tools/InputFilter/InputStabilizer.d.ts +29 -0
  407. package/dist/mjs/tools/InputFilter/InputStabilizer.mjs +175 -0
  408. package/dist/mjs/tools/InputFilter/StrokeKeyboardControl.d.ts +21 -0
  409. package/dist/mjs/tools/InputFilter/StrokeKeyboardControl.mjs +78 -0
  410. package/dist/mjs/tools/PanZoom.d.ts +4 -2
  411. package/dist/mjs/tools/PanZoom.mjs +169 -235
  412. package/dist/mjs/tools/PasteHandler.d.ts +1 -1
  413. package/dist/mjs/tools/PasteHandler.mjs +42 -145
  414. package/dist/mjs/tools/Pen.d.ts +12 -11
  415. package/dist/mjs/tools/Pen.mjs +115 -154
  416. package/dist/mjs/tools/PipetteTool.d.ts +11 -2
  417. package/dist/mjs/tools/PipetteTool.mjs +47 -48
  418. package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.d.ts +1 -1
  419. package/dist/mjs/tools/SelectionTool/SelectAllShortcutHandler.mjs +9 -28
  420. package/dist/mjs/tools/SelectionTool/Selection.d.ts +5 -5
  421. package/dist/mjs/tools/SelectionTool/Selection.mjs +268 -401
  422. package/dist/mjs/tools/SelectionTool/SelectionHandle.d.ts +15 -5
  423. package/dist/mjs/tools/SelectionTool/SelectionHandle.mjs +62 -37
  424. package/dist/mjs/tools/SelectionTool/SelectionTool.d.ts +4 -4
  425. package/dist/mjs/tools/SelectionTool/SelectionTool.mjs +153 -179
  426. package/dist/mjs/tools/SelectionTool/TransformMode.d.ts +1 -1
  427. package/dist/mjs/tools/SelectionTool/TransformMode.mjs +52 -59
  428. package/dist/mjs/tools/SoundUITool.d.ts +2 -1
  429. package/dist/mjs/tools/SoundUITool.mjs +66 -84
  430. package/dist/mjs/tools/TextTool.d.ts +5 -3
  431. package/dist/mjs/tools/TextTool.mjs +155 -163
  432. package/dist/mjs/tools/ToolController.d.ts +16 -2
  433. package/dist/mjs/tools/ToolController.mjs +81 -84
  434. package/dist/mjs/tools/ToolEnabledGroup.mjs +6 -10
  435. package/dist/mjs/tools/ToolSwitcherShortcut.d.ts +1 -1
  436. package/dist/mjs/tools/ToolSwitcherShortcut.mjs +12 -32
  437. package/dist/mjs/tools/ToolbarShortcutHandler.d.ts +1 -1
  438. package/dist/mjs/tools/ToolbarShortcutHandler.mjs +13 -33
  439. package/dist/mjs/tools/UndoRedoShortcut.d.ts +1 -1
  440. package/dist/mjs/tools/UndoRedoShortcut.mjs +7 -26
  441. package/dist/mjs/tools/keybindings.mjs +34 -34
  442. package/dist/mjs/tools/localization.d.ts +2 -1
  443. package/dist/mjs/tools/localization.mjs +9 -8
  444. package/dist/mjs/types.d.ts +22 -80
  445. package/dist/mjs/types.mjs +7 -15
  446. package/dist/mjs/util/ReactiveValue.d.ts +65 -0
  447. package/dist/mjs/util/ReactiveValue.mjs +161 -0
  448. package/dist/mjs/util/assertions.mjs +5 -8
  449. package/dist/mjs/util/fileToBase64.mjs +6 -6
  450. package/dist/mjs/util/guessKeyCodeFromKey.d.ts +9 -0
  451. package/dist/mjs/util/guessKeyCodeFromKey.mjs +30 -0
  452. package/dist/mjs/util/listPrefixMatch.d.ts +6 -0
  453. package/dist/mjs/util/listPrefixMatch.mjs +15 -0
  454. package/dist/mjs/util/stopPropagationOfScrollingWheelEvents.d.ts +2 -0
  455. package/dist/mjs/util/stopPropagationOfScrollingWheelEvents.mjs +15 -0
  456. package/dist/mjs/util/untilNextAnimationFrame.mjs +3 -3
  457. package/dist/mjs/util/waitForAll.mjs +3 -3
  458. package/dist/mjs/util/waitForTimeout.mjs +3 -3
  459. package/dist/mjs/version.d.ts +4 -0
  460. package/dist/mjs/version.mjs +3 -0
  461. package/package.json +11 -22
  462. package/src/Coloris.css +8 -8
  463. package/src/Editor.scss +148 -0
  464. package/src/dialogs/dialogs.scss +36 -0
  465. package/src/dialogs/makeAboutDialog.scss +41 -0
  466. package/src/styles.js +1 -1
  467. package/src/toolbar/{toolbar.css → AbstractToolbar.scss} +47 -85
  468. package/src/toolbar/DropdownToolbar.scss +46 -0
  469. package/src/toolbar/EdgeToolbar.scss +511 -0
  470. package/src/toolbar/toolbar.scss +11 -0
  471. package/src/toolbar/widgets/DocumentPropertiesWidget.scss +7 -0
  472. package/src/toolbar/widgets/HandToolWidget.scss +14 -0
  473. package/src/toolbar/widgets/InsertImageWidget.scss +41 -0
  474. package/src/toolbar/widgets/PenToolWidget.css +0 -51
  475. package/src/toolbar/widgets/SelectionToolWidget.scss +6 -0
  476. package/src/toolbar/widgets/components/components.scss +5 -0
  477. package/src/toolbar/widgets/components/makeColorInput.scss +82 -0
  478. package/src/toolbar/widgets/components/makeFileInput.scss +77 -0
  479. package/src/toolbar/widgets/components/makeGridSelector.scss +60 -0
  480. package/src/toolbar/widgets/components/makeSeparator.scss +14 -0
  481. package/src/toolbar/widgets/components/makeThicknessSlider.scss +9 -0
  482. package/src/tools/FindTool.css +3 -3
  483. package/src/tools/SelectionTool/SelectionTool.css +23 -11
  484. package/src/tools/tools.scss +4 -0
  485. package/tsconfig.json +1 -1
  486. package/typedoc.json +4 -0
  487. package/dist/cjs/Color4.d.ts +0 -69
  488. package/dist/cjs/Color4.js +0 -263
  489. package/dist/cjs/Editor.loadFrom.test.d.ts +0 -1
  490. package/dist/cjs/Editor.toSVG.test.d.ts +0 -1
  491. package/dist/cjs/EditorImage.test.d.ts +0 -1
  492. package/dist/cjs/EventDispatcher.test.d.ts +0 -1
  493. package/dist/cjs/SVGLoader.test.d.ts +0 -1
  494. package/dist/cjs/UndoRedoHistory.test.d.ts +0 -1
  495. package/dist/cjs/commands/uniteCommands.test.d.ts +0 -1
  496. package/dist/cjs/components/AbstractComponent.transformBy.test.d.ts +0 -1
  497. package/dist/cjs/components/BackgroundComponent.test.d.ts +0 -1
  498. package/dist/cjs/components/Stroke.test.d.ts +0 -1
  499. package/dist/cjs/components/TextComponent.test.d.ts +0 -1
  500. package/dist/cjs/components/UnknownSVGObject.test.d.ts +0 -1
  501. package/dist/cjs/components/builders/FreehandLineBuilder.test.d.ts +0 -1
  502. package/dist/cjs/localizations/getLocalizationTable.test.d.ts +0 -1
  503. package/dist/cjs/math/Mat33.d.ts +0 -123
  504. package/dist/cjs/math/Mat33.js +0 -340
  505. package/dist/cjs/math/Mat33.test.d.ts +0 -1
  506. package/dist/cjs/math/Vec2.d.ts +0 -33
  507. package/dist/cjs/math/Vec2.js +0 -37
  508. package/dist/cjs/math/Vec2.test.d.ts +0 -1
  509. package/dist/cjs/math/Vec3.d.ts +0 -106
  510. package/dist/cjs/math/Vec3.js +0 -183
  511. package/dist/cjs/math/Vec3.test.d.ts +0 -1
  512. package/dist/cjs/math/lib.d.ts +0 -7
  513. package/dist/cjs/math/lib.js +0 -15
  514. package/dist/cjs/math/polynomial/solveQuadratic.d.ts +0 -9
  515. package/dist/cjs/math/polynomial/solveQuadratic.js +0 -39
  516. package/dist/cjs/math/polynomial/solveQuadratic.test.d.ts +0 -1
  517. package/dist/cjs/math/rounding.d.ts +0 -4
  518. package/dist/cjs/math/rounding.js +0 -140
  519. package/dist/cjs/math/rounding.test.d.ts +0 -1
  520. package/dist/cjs/math/shapes/Abstract2DShape.d.ts +0 -49
  521. package/dist/cjs/math/shapes/Abstract2DShape.js +0 -42
  522. package/dist/cjs/math/shapes/BezierJSWrapper.d.ts +0 -36
  523. package/dist/cjs/math/shapes/BezierJSWrapper.js +0 -109
  524. package/dist/cjs/math/shapes/CubicBezier.d.ts +0 -17
  525. package/dist/cjs/math/shapes/CubicBezier.js +0 -50
  526. package/dist/cjs/math/shapes/LineSegment2.d.ts +0 -70
  527. package/dist/cjs/math/shapes/LineSegment2.js +0 -204
  528. package/dist/cjs/math/shapes/LineSegment2.test.d.ts +0 -1
  529. package/dist/cjs/math/shapes/Path.d.ts +0 -93
  530. package/dist/cjs/math/shapes/Path.fromString.test.d.ts +0 -1
  531. package/dist/cjs/math/shapes/Path.js +0 -865
  532. package/dist/cjs/math/shapes/Path.test.d.ts +0 -1
  533. package/dist/cjs/math/shapes/Path.toString.test.d.ts +0 -1
  534. package/dist/cjs/math/shapes/PointShape2D.d.ts +0 -18
  535. package/dist/cjs/math/shapes/PointShape2D.js +0 -46
  536. package/dist/cjs/math/shapes/QuadraticBezier.d.ts +0 -34
  537. package/dist/cjs/math/shapes/QuadraticBezier.js +0 -133
  538. package/dist/cjs/math/shapes/QuadraticBezier.test.d.ts +0 -1
  539. package/dist/cjs/math/shapes/Rect2.d.ts +0 -57
  540. package/dist/cjs/math/shapes/Rect2.js +0 -311
  541. package/dist/cjs/math/shapes/Rect2.test.d.ts +0 -1
  542. package/dist/cjs/math/shapes/Triangle.d.ts +0 -46
  543. package/dist/cjs/math/shapes/Triangle.js +0 -148
  544. package/dist/cjs/math/shapes/Triangle.test.d.ts +0 -1
  545. package/dist/cjs/rendering/RenderingStyle.test.d.ts +0 -1
  546. package/dist/cjs/rendering/caching/CacheRecord.test.d.ts +0 -1
  547. package/dist/cjs/rendering/caching/RenderingCache.test.d.ts +0 -1
  548. package/dist/cjs/rendering/renderers/DummyRenderer.test.d.ts +0 -1
  549. package/dist/cjs/rendering/renderers/TextOnlyRenderer.test.d.ts +0 -1
  550. package/dist/cjs/shortcuts/KeyBinding.test.d.ts +0 -1
  551. package/dist/cjs/shortcuts/KeyboardShortcutManager.test.d.ts +0 -1
  552. package/dist/cjs/toolbar/HTMLToolbar.d.ts +0 -105
  553. package/dist/cjs/toolbar/HTMLToolbar.js +0 -465
  554. package/dist/cjs/toolbar/makeColorInput.d.ts +0 -6
  555. package/dist/cjs/tools/Eraser.test.d.ts +0 -1
  556. package/dist/cjs/tools/PanZoom.test.d.ts +0 -1
  557. package/dist/cjs/tools/Pen.test.d.ts +0 -1
  558. package/dist/cjs/tools/SelectionTool/SelectionTool.test.d.ts +0 -1
  559. package/dist/cjs/tools/UndoRedoShortcut.test.d.ts +0 -1
  560. package/dist/mjs/Color4.d.ts +0 -69
  561. package/dist/mjs/Color4.mjs +0 -260
  562. package/dist/mjs/Color4.test.d.ts +0 -1
  563. package/dist/mjs/Editor.loadFrom.test.d.ts +0 -1
  564. package/dist/mjs/Editor.toSVG.test.d.ts +0 -1
  565. package/dist/mjs/EditorImage.test.d.ts +0 -1
  566. package/dist/mjs/EventDispatcher.test.d.ts +0 -1
  567. package/dist/mjs/SVGLoader.test.d.ts +0 -1
  568. package/dist/mjs/UndoRedoHistory.test.d.ts +0 -1
  569. package/dist/mjs/commands/uniteCommands.test.d.ts +0 -1
  570. package/dist/mjs/components/AbstractComponent.transformBy.test.d.ts +0 -1
  571. package/dist/mjs/components/BackgroundComponent.test.d.ts +0 -1
  572. package/dist/mjs/components/Stroke.test.d.ts +0 -1
  573. package/dist/mjs/components/TextComponent.test.d.ts +0 -1
  574. package/dist/mjs/components/UnknownSVGObject.test.d.ts +0 -1
  575. package/dist/mjs/components/builders/FreehandLineBuilder.test.d.ts +0 -1
  576. package/dist/mjs/localizations/getLocalizationTable.test.d.ts +0 -1
  577. package/dist/mjs/math/Mat33.d.ts +0 -123
  578. package/dist/mjs/math/Mat33.mjs +0 -338
  579. package/dist/mjs/math/Mat33.test.d.ts +0 -1
  580. package/dist/mjs/math/Vec2.d.ts +0 -33
  581. package/dist/mjs/math/Vec2.mjs +0 -34
  582. package/dist/mjs/math/Vec2.test.d.ts +0 -1
  583. package/dist/mjs/math/Vec3.d.ts +0 -106
  584. package/dist/mjs/math/Vec3.mjs +0 -181
  585. package/dist/mjs/math/Vec3.test.d.ts +0 -1
  586. package/dist/mjs/math/lib.d.ts +0 -7
  587. package/dist/mjs/math/lib.mjs +0 -7
  588. package/dist/mjs/math/polynomial/solveQuadratic.d.ts +0 -9
  589. package/dist/mjs/math/polynomial/solveQuadratic.mjs +0 -37
  590. package/dist/mjs/math/polynomial/solveQuadratic.test.d.ts +0 -1
  591. package/dist/mjs/math/rounding.d.ts +0 -4
  592. package/dist/mjs/math/rounding.mjs +0 -133
  593. package/dist/mjs/math/rounding.test.d.ts +0 -1
  594. package/dist/mjs/math/shapes/Abstract2DShape.d.ts +0 -49
  595. package/dist/mjs/math/shapes/Abstract2DShape.mjs +0 -40
  596. package/dist/mjs/math/shapes/BezierJSWrapper.d.ts +0 -36
  597. package/dist/mjs/math/shapes/BezierJSWrapper.mjs +0 -107
  598. package/dist/mjs/math/shapes/CubicBezier.d.ts +0 -17
  599. package/dist/mjs/math/shapes/CubicBezier.mjs +0 -48
  600. package/dist/mjs/math/shapes/LineSegment2.d.ts +0 -70
  601. package/dist/mjs/math/shapes/LineSegment2.mjs +0 -202
  602. package/dist/mjs/math/shapes/LineSegment2.test.d.ts +0 -1
  603. package/dist/mjs/math/shapes/Path.d.ts +0 -93
  604. package/dist/mjs/math/shapes/Path.fromString.test.d.ts +0 -1
  605. package/dist/mjs/math/shapes/Path.mjs +0 -862
  606. package/dist/mjs/math/shapes/Path.test.d.ts +0 -1
  607. package/dist/mjs/math/shapes/Path.toString.test.d.ts +0 -1
  608. package/dist/mjs/math/shapes/PointShape2D.d.ts +0 -18
  609. package/dist/mjs/math/shapes/PointShape2D.mjs +0 -44
  610. package/dist/mjs/math/shapes/QuadraticBezier.d.ts +0 -34
  611. package/dist/mjs/math/shapes/QuadraticBezier.mjs +0 -131
  612. package/dist/mjs/math/shapes/QuadraticBezier.test.d.ts +0 -1
  613. package/dist/mjs/math/shapes/Rect2.d.ts +0 -57
  614. package/dist/mjs/math/shapes/Rect2.mjs +0 -309
  615. package/dist/mjs/math/shapes/Rect2.test.d.ts +0 -1
  616. package/dist/mjs/math/shapes/Triangle.d.ts +0 -46
  617. package/dist/mjs/math/shapes/Triangle.mjs +0 -146
  618. package/dist/mjs/math/shapes/Triangle.test.d.ts +0 -1
  619. package/dist/mjs/rendering/RenderingStyle.test.d.ts +0 -1
  620. package/dist/mjs/rendering/caching/CacheRecord.test.d.ts +0 -1
  621. package/dist/mjs/rendering/caching/RenderingCache.test.d.ts +0 -1
  622. package/dist/mjs/rendering/renderers/DummyRenderer.test.d.ts +0 -1
  623. package/dist/mjs/rendering/renderers/TextOnlyRenderer.test.d.ts +0 -1
  624. package/dist/mjs/shortcuts/KeyBinding.test.d.ts +0 -1
  625. package/dist/mjs/shortcuts/KeyboardShortcutManager.test.d.ts +0 -1
  626. package/dist/mjs/toolbar/HTMLToolbar.d.ts +0 -105
  627. package/dist/mjs/toolbar/HTMLToolbar.mjs +0 -462
  628. package/dist/mjs/toolbar/makeColorInput.d.ts +0 -6
  629. package/dist/mjs/tools/Eraser.test.d.ts +0 -1
  630. package/dist/mjs/tools/PanZoom.test.d.ts +0 -1
  631. package/dist/mjs/tools/Pen.test.d.ts +0 -1
  632. package/dist/mjs/tools/SelectionTool/SelectionTool.test.d.ts +0 -1
  633. package/dist/mjs/tools/UndoRedoShortcut.test.d.ts +0 -1
  634. package/dist-test/test_imports/package-lock.json +0 -13
  635. package/dist-test/test_imports/package.json +0 -12
  636. package/dist-test/test_imports/test-imports.js +0 -17
  637. package/dist-test/test_imports/test-require.cjs +0 -19
  638. package/src/Color4.test.ts +0 -47
  639. package/src/Color4.ts +0 -304
  640. package/src/Editor.css +0 -98
  641. package/src/Editor.loadFrom.test.ts +0 -24
  642. package/src/Editor.toSVG.test.ts +0 -111
  643. package/src/Editor.ts +0 -1171
  644. package/src/EditorImage.test.ts +0 -120
  645. package/src/EditorImage.ts +0 -603
  646. package/src/EventDispatcher.test.ts +0 -123
  647. package/src/EventDispatcher.ts +0 -72
  648. package/src/Pointer.ts +0 -167
  649. package/src/SVGLoader.test.ts +0 -114
  650. package/src/SVGLoader.ts +0 -610
  651. package/src/UndoRedoHistory.test.ts +0 -33
  652. package/src/UndoRedoHistory.ts +0 -102
  653. package/src/Viewport.ts +0 -325
  654. package/src/bundle/bundled.ts +0 -7
  655. package/src/commands/Command.ts +0 -45
  656. package/src/commands/Duplicate.ts +0 -75
  657. package/src/commands/Erase.ts +0 -94
  658. package/src/commands/SerializableCommand.ts +0 -49
  659. package/src/commands/UnresolvedCommand.ts +0 -37
  660. package/src/commands/invertCommand.ts +0 -58
  661. package/src/commands/lib.ts +0 -16
  662. package/src/commands/localization.ts +0 -47
  663. package/src/commands/uniteCommands.test.ts +0 -23
  664. package/src/commands/uniteCommands.ts +0 -140
  665. package/src/components/AbstractComponent.transformBy.test.ts +0 -22
  666. package/src/components/AbstractComponent.ts +0 -374
  667. package/src/components/BackgroundComponent.test.ts +0 -45
  668. package/src/components/BackgroundComponent.ts +0 -353
  669. package/src/components/ImageComponent.ts +0 -178
  670. package/src/components/RestylableComponent.ts +0 -161
  671. package/src/components/SVGGlobalAttributesObject.ts +0 -81
  672. package/src/components/Stroke.test.ts +0 -139
  673. package/src/components/Stroke.ts +0 -296
  674. package/src/components/TextComponent.test.ts +0 -204
  675. package/src/components/TextComponent.ts +0 -432
  676. package/src/components/UnknownSVGObject.test.ts +0 -10
  677. package/src/components/UnknownSVGObject.ts +0 -60
  678. package/src/components/builders/ArrowBuilder.ts +0 -107
  679. package/src/components/builders/CircleBuilder.ts +0 -102
  680. package/src/components/builders/FreehandLineBuilder.test.ts +0 -25
  681. package/src/components/builders/FreehandLineBuilder.ts +0 -212
  682. package/src/components/builders/LineBuilder.ts +0 -77
  683. package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +0 -454
  684. package/src/components/builders/RectangleBuilder.ts +0 -74
  685. package/src/components/builders/types.ts +0 -15
  686. package/src/components/lib.ts +0 -31
  687. package/src/components/localization.ts +0 -24
  688. package/src/components/util/StrokeSmoother.ts +0 -302
  689. package/src/components/util/describeComponentList.ts +0 -18
  690. package/src/lib.ts +0 -69
  691. package/src/localization.ts +0 -34
  692. package/src/localizations/de.ts +0 -146
  693. package/src/localizations/en.ts +0 -8
  694. package/src/localizations/es.ts +0 -74
  695. package/src/localizations/getLocalizationTable.test.ts +0 -27
  696. package/src/localizations/getLocalizationTable.ts +0 -74
  697. package/src/math/Mat33.test.ts +0 -244
  698. package/src/math/Mat33.ts +0 -442
  699. package/src/math/Vec2.test.ts +0 -30
  700. package/src/math/Vec2.ts +0 -40
  701. package/src/math/Vec3.test.ts +0 -44
  702. package/src/math/Vec3.ts +0 -218
  703. package/src/math/lib.ts +0 -15
  704. package/src/math/polynomial/solveQuadratic.test.ts +0 -39
  705. package/src/math/polynomial/solveQuadratic.ts +0 -43
  706. package/src/math/rounding.test.ts +0 -65
  707. package/src/math/rounding.ts +0 -156
  708. package/src/math/shapes/Abstract2DShape.ts +0 -63
  709. package/src/math/shapes/BezierJSWrapper.ts +0 -93
  710. package/src/math/shapes/CubicBezier.ts +0 -35
  711. package/src/math/shapes/LineSegment2.test.ts +0 -99
  712. package/src/math/shapes/LineSegment2.ts +0 -231
  713. package/src/math/shapes/Path.fromString.test.ts +0 -223
  714. package/src/math/shapes/Path.test.ts +0 -309
  715. package/src/math/shapes/Path.toString.test.ts +0 -77
  716. package/src/math/shapes/Path.ts +0 -1027
  717. package/src/math/shapes/PointShape2D.ts +0 -33
  718. package/src/math/shapes/QuadraticBezier.test.ts +0 -31
  719. package/src/math/shapes/QuadraticBezier.ts +0 -141
  720. package/src/math/shapes/Rect2.test.ts +0 -209
  721. package/src/math/shapes/Rect2.ts +0 -344
  722. package/src/math/shapes/Triangle.test.ts +0 -61
  723. package/src/math/shapes/Triangle.ts +0 -139
  724. package/src/rendering/Display.ts +0 -248
  725. package/src/rendering/RenderingStyle.test.ts +0 -68
  726. package/src/rendering/RenderingStyle.ts +0 -55
  727. package/src/rendering/TextRenderingStyle.ts +0 -55
  728. package/src/rendering/caching/CacheRecord.test.ts +0 -49
  729. package/src/rendering/caching/CacheRecord.ts +0 -77
  730. package/src/rendering/caching/CacheRecordManager.ts +0 -71
  731. package/src/rendering/caching/RenderingCache.test.ts +0 -44
  732. package/src/rendering/caching/RenderingCache.ts +0 -66
  733. package/src/rendering/caching/RenderingCacheNode.ts +0 -405
  734. package/src/rendering/caching/testUtils.ts +0 -35
  735. package/src/rendering/caching/types.ts +0 -34
  736. package/src/rendering/lib.ts +0 -8
  737. package/src/rendering/localization.ts +0 -20
  738. package/src/rendering/renderers/AbstractRenderer.ts +0 -242
  739. package/src/rendering/renderers/CanvasRenderer.ts +0 -307
  740. package/src/rendering/renderers/DummyRenderer.test.ts +0 -42
  741. package/src/rendering/renderers/DummyRenderer.ts +0 -145
  742. package/src/rendering/renderers/SVGRenderer.ts +0 -377
  743. package/src/rendering/renderers/TextOnlyRenderer.test.ts +0 -34
  744. package/src/rendering/renderers/TextOnlyRenderer.ts +0 -71
  745. package/src/shortcuts/KeyBinding.test.ts +0 -51
  746. package/src/shortcuts/KeyBinding.ts +0 -218
  747. package/src/shortcuts/KeyboardShortcutManager.test.ts +0 -95
  748. package/src/shortcuts/KeyboardShortcutManager.ts +0 -163
  749. package/src/shortcuts/lib.ts +0 -3
  750. package/src/testing/createEditor.ts +0 -11
  751. package/src/testing/getUniquePointerId.ts +0 -18
  752. package/src/testing/lib.ts +0 -3
  753. package/src/testing/sendPenEvent.ts +0 -36
  754. package/src/testing/sendTouchEvent.ts +0 -71
  755. package/src/toolbar/HTMLToolbar.ts +0 -567
  756. package/src/toolbar/IconProvider.ts +0 -805
  757. package/src/toolbar/lib.ts +0 -4
  758. package/src/toolbar/localization.ts +0 -114
  759. package/src/toolbar/makeColorInput.ts +0 -159
  760. package/src/toolbar/types.ts +0 -5
  761. package/src/toolbar/widgets/ActionButtonWidget.ts +0 -39
  762. package/src/toolbar/widgets/BaseToolWidget.ts +0 -65
  763. package/src/toolbar/widgets/BaseWidget.ts +0 -428
  764. package/src/toolbar/widgets/DocumentPropertiesWidget.ts +0 -234
  765. package/src/toolbar/widgets/EraserToolWidget.ts +0 -85
  766. package/src/toolbar/widgets/HandToolWidget.ts +0 -250
  767. package/src/toolbar/widgets/InsertImageWidget.css +0 -44
  768. package/src/toolbar/widgets/InsertImageWidget.ts +0 -223
  769. package/src/toolbar/widgets/OverflowWidget.ts +0 -92
  770. package/src/toolbar/widgets/PenToolWidget.ts +0 -409
  771. package/src/toolbar/widgets/SelectionToolWidget.ts +0 -197
  772. package/src/toolbar/widgets/TextToolWidget.ts +0 -145
  773. package/src/toolbar/widgets/keybindings.ts +0 -21
  774. package/src/toolbar/widgets/lib.ts +0 -13
  775. package/src/tools/BaseTool.ts +0 -97
  776. package/src/tools/Eraser.test.ts +0 -103
  777. package/src/tools/Eraser.ts +0 -160
  778. package/src/tools/FindTool.ts +0 -153
  779. package/src/tools/PanZoom.test.ts +0 -349
  780. package/src/tools/PanZoom.ts +0 -502
  781. package/src/tools/PasteHandler.ts +0 -95
  782. package/src/tools/Pen.test.ts +0 -262
  783. package/src/tools/Pen.ts +0 -300
  784. package/src/tools/PipetteTool.ts +0 -55
  785. package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +0 -29
  786. package/src/tools/SelectionTool/Selection.ts +0 -611
  787. package/src/tools/SelectionTool/SelectionHandle.ts +0 -108
  788. package/src/tools/SelectionTool/SelectionTool.test.ts +0 -261
  789. package/src/tools/SelectionTool/SelectionTool.ts +0 -496
  790. package/src/tools/SelectionTool/TransformMode.ts +0 -114
  791. package/src/tools/SelectionTool/types.ts +0 -11
  792. package/src/tools/SoundUITool.ts +0 -212
  793. package/src/tools/TextTool.ts +0 -340
  794. package/src/tools/ToolController.ts +0 -200
  795. package/src/tools/ToolEnabledGroup.ts +0 -14
  796. package/src/tools/ToolSwitcherShortcut.ts +0 -39
  797. package/src/tools/ToolbarShortcutHandler.ts +0 -39
  798. package/src/tools/UndoRedoShortcut.test.ts +0 -56
  799. package/src/tools/UndoRedoShortcut.ts +0 -24
  800. package/src/tools/keybindings.ts +0 -85
  801. package/src/tools/lib.ts +0 -22
  802. package/src/tools/localization.ts +0 -74
  803. package/src/tools/tools.css +0 -4
  804. package/src/types.ts +0 -239
  805. package/src/util/assertions.ts +0 -55
  806. package/src/util/fileToBase64.ts +0 -18
  807. package/src/util/untilNextAnimationFrame.ts +0 -9
  808. package/src/util/waitForAll.ts +0 -18
  809. package/src/util/waitForTimeout.ts +0 -9
  810. /package/dist/{cjs/Color4.test.d.ts → mjs/toolbar/widgets/layout/types.mjs} +0 -0
@@ -0,0 +1,1281 @@
1
+ :root .insert-image-widget-dropdown-content.insert-image-widget-dropdown-content.insert-image-widget-dropdown-content > div > div {
2
+ padding: 5px;
3
+ }
4
+ :root .insert-image-widget-dropdown-content.insert-image-widget-dropdown-content.insert-image-widget-dropdown-content > div {
5
+ min-height: 0;
6
+ }
7
+ :root .insert-image-widget-dropdown-content.insert-image-widget-dropdown-content.insert-image-widget-dropdown-content img {
8
+ max-width: min(50vw, 75%);
9
+ max-height: 50vh;
10
+ /* Center */
11
+ display: block;
12
+ margin-left: auto;
13
+ margin-right: auto;
14
+ }
15
+ :root .insert-image-widget-dropdown-content.insert-image-widget-dropdown-content.insert-image-widget-dropdown-content .action-button-row {
16
+ margin-top: 4px;
17
+ display: flex;
18
+ flex-direction: row;
19
+ justify-content: flex-end;
20
+ padding-bottom: 0;
21
+ margin-bottom: 0;
22
+ }
23
+ :root .insert-image-widget-dropdown-content.insert-image-widget-dropdown-content.insert-image-widget-dropdown-content .action-button-row > button {
24
+ flex-grow: 1;
25
+ text-align: end;
26
+ max-width: 50%;
27
+ min-width: min(100%, 40px);
28
+ }
29
+
30
+ .toolbar-overflow-widget-overflow-list {
31
+ display: flex;
32
+ flex-direction: column;
33
+ flex-wrap: wrap;
34
+ justify-content: center;
35
+ }
36
+
37
+ .toolbar-overflow-widget-overflow-list > .toolbar-toolContainer > .toolbar-button {
38
+ height: var(--toolbar-button-height);
39
+ }
40
+
41
+ .toolbar-overflow-widget.horizontal .toolbar-overflow-widget-overflow-list {
42
+ flex-direction: row;
43
+ }
44
+
45
+ .toolbar-overflow-widget.horizontal > .toolbar-dropdown {
46
+ max-width: 100%;
47
+ left: 15px;
48
+ right: 15px;
49
+ /*
50
+ Override the default transform and margin-left.
51
+
52
+ Setting translate to none prevents the dropdown from being shifted off the
53
+ screen on window resize by dropdown-repositioning logic.
54
+ */
55
+ margin-left: 0 !important;
56
+ translate: none !important;
57
+ padding: 4px;
58
+ }
59
+
60
+ .toolbar-zoomLevelEditor {
61
+ display: flex;
62
+ flex-direction: row;
63
+ align-items: center;
64
+ }
65
+
66
+ .toolbar-zoomLevelEditor .zoomDisplay {
67
+ flex-grow: 1;
68
+ }
69
+
70
+ .toolbar-zoomLevelEditor button {
71
+ min-width: 48px;
72
+ }
73
+
74
+ .selection-format-menu.disabled {
75
+ opacity: 0.5;
76
+ }
77
+
78
+ .toolbar-document-properties-widget button.about-button {
79
+ width: 100%;
80
+ text-align: end;
81
+ }
82
+
83
+ .toolbar-thicknessSliderContainer {
84
+ display: flex;
85
+ flex-direction: row;
86
+ }
87
+ .toolbar-thicknessSliderContainer input {
88
+ flex-grow: 1;
89
+ }
90
+
91
+ /* Make color selection buttons fill their containing label */
92
+ .toolbar-element .clr-field * {
93
+ cursor: pointer;
94
+ }
95
+ .toolbar-element .clr-field button {
96
+ width: 1.2em;
97
+ height: 1.2em;
98
+ top: 50%;
99
+ left: 0;
100
+ border-radius: 50%;
101
+ margin-left: 0;
102
+ margin-right: 0;
103
+ }
104
+ .toolbar-element .clr-field input {
105
+ opacity: 0;
106
+ }
107
+
108
+ .color-input-container {
109
+ display: inline-flex;
110
+ flex-direction: row;
111
+ }
112
+ .color-input-container.picker-open .clr-field {
113
+ pointer-events: none;
114
+ }
115
+
116
+ :root .color-input-container > button.pipetteButton {
117
+ width: 30px;
118
+ height: 30px;
119
+ padding: 0;
120
+ display: inline-flex;
121
+ }
122
+
123
+ .color-input-container .pipetteButton > svg {
124
+ width: 100%;
125
+ }
126
+
127
+ .color-input-container .pipetteButton .pickColorInstructions {
128
+ display: none;
129
+ font-size: 1em;
130
+ position: absolute;
131
+ margin-left: 30px;
132
+ background-color: var(--background-color-1);
133
+ border-radius: 30px;
134
+ padding: 4px;
135
+ opacity: 0;
136
+ transition: 0.2s ease opacity;
137
+ }
138
+ @media (prefers-reduced-motion: reduce) {
139
+ .color-input-container .pipetteButton .pickColorInstructions {
140
+ transition: none;
141
+ }
142
+ }
143
+
144
+ .color-input-container .pipetteButton.active {
145
+ background-color: var(--selection-background-color);
146
+ --icon-color: var(--selection-foreground-color);
147
+ }
148
+ .color-input-container .pipetteButton.active .pickColorInstructions {
149
+ display: block;
150
+ opacity: 0.8;
151
+ }
152
+
153
+ .tool-dropdown-separator {
154
+ --border-color: rgba(100, 100, 100, 0.2);
155
+ --border-color: color-mix(in srgb, var(--foreground-color-1), rgba(0, 0, 0, 0) 80%);
156
+ border-top: 1px solid var(--border-color);
157
+ padding-left: 2px;
158
+ margin-top: 10px;
159
+ margin-bottom: 10px;
160
+ }
161
+
162
+ .toolbar-element .toolbar--file-input-container {
163
+ display: flex;
164
+ }
165
+ .toolbar-element .toolbar--file-input-container > input[type=file] {
166
+ opacity: 0;
167
+ width: 0;
168
+ min-width: 0 !important;
169
+ max-width: 0;
170
+ height: 0;
171
+ }
172
+ .toolbar-element .toolbar--file-input-container > label {
173
+ display: block;
174
+ flex-grow: 1;
175
+ padding: 0 !important;
176
+ padding-bottom: 5px;
177
+ --active-border-color: rgba(100, 100, 100, 0.5);
178
+ --active-border-color: color-mix(
179
+ in srgb, var(--foreground-color-1), transparent
180
+ );
181
+ }
182
+ .toolbar-element .toolbar--file-input-container > label > .toolbar--file-input-description {
183
+ background-color: var(--background-color-3);
184
+ color: var(--foreground-color-3);
185
+ border: 1px dashed var(--active-border-color);
186
+ padding: 10px;
187
+ margin-top: 10px;
188
+ display: flex;
189
+ flex-direction: column;
190
+ align-items: center;
191
+ text-align: center;
192
+ --action-color: var(--primary-action-foreground-color);
193
+ --icon-color: var(--action-color);
194
+ }
195
+ .toolbar-element .toolbar--file-input-container > label > .toolbar--file-input-description > span {
196
+ white-space: pre-wrap;
197
+ }
198
+ .toolbar-element .toolbar--file-input-container > label > .toolbar--file-input-description > span > b {
199
+ color: var(--action-color);
200
+ cursor: pointer;
201
+ }
202
+ .toolbar-element .toolbar--file-input-container > label > .toolbar--file-input-description > .icon {
203
+ width: min(50vw, 42px);
204
+ height: min(50vw, 42px);
205
+ margin-bottom: 8px;
206
+ display: block;
207
+ }
208
+ .toolbar-element .toolbar--file-input-container > label:active, .toolbar-element .toolbar--file-input-container > label:hover, .toolbar-element .toolbar--file-input-container > label.drag-target {
209
+ --active-border-color: var(--foreground-color-1);
210
+ }
211
+ .toolbar-element .toolbar--file-input-container > label.drag-target > .toolbar--file-input-description {
212
+ border-width: 2px;
213
+ }
214
+
215
+ .toolbar-grid-selector {
216
+ position: relative;
217
+ }
218
+ .toolbar-grid-selector > div {
219
+ display: flex;
220
+ flex-direction: row;
221
+ max-width: 350px;
222
+ flex-wrap: wrap;
223
+ --button-size: 48px;
224
+ }
225
+ .toolbar-grid-selector .choice-button {
226
+ display: flex;
227
+ flex-direction: column-reverse;
228
+ box-sizing: border-box;
229
+ flex-shrink: 1;
230
+ margin: 2px;
231
+ }
232
+ .toolbar-grid-selector .choice-button:focus-within {
233
+ outline: 2px solid var(--foreground-color-1);
234
+ }
235
+ .toolbar-grid-selector .choice-button input {
236
+ opacity: 0;
237
+ height: 0;
238
+ }
239
+ .toolbar-grid-selector .choice-button label {
240
+ display: flex;
241
+ flex-direction: column;
242
+ box-sizing: border-box;
243
+ width: var(--button-size);
244
+ height: var(--button-size);
245
+ font-size: 0.7rem;
246
+ align-items: center;
247
+ justify-content: center;
248
+ padding: 4px;
249
+ }
250
+ .toolbar-grid-selector .choice-button .icon {
251
+ flex-grow: 1;
252
+ flex-shrink: 1;
253
+ width: 100%;
254
+ }
255
+ .toolbar-grid-selector .choice-button.checked {
256
+ background-color: var(--selection-background-color);
257
+ color: var(--selection-foreground-color);
258
+ }
259
+
260
+ /* The *main* root toolbar element */
261
+ .toolbar-root {
262
+ background-color: var(--background-color-1);
263
+ --icon-color: var(--foreground-color-1);
264
+ --toolbar-button-height: min(20vh, 60px);
265
+ flex-wrap: wrap;
266
+ box-sizing: border-box;
267
+ width: 100%;
268
+ display: flex;
269
+ flex-direction: row;
270
+ justify-content: center;
271
+ }
272
+
273
+ /* Any root toolbar element */
274
+ .toolbar-element {
275
+ z-index: 1;
276
+ font-family: system-ui, -apple-system, sans-serif;
277
+ }
278
+ .toolbar-element details > summary {
279
+ cursor: pointer;
280
+ }
281
+
282
+ .toolbar-element > .toolbar-toolContainer > .toolbar-button,
283
+ .toolbar-element > .toolbar-toolContainer > * > button,
284
+ .toolbar-element > .toolbar-buttonGroup > button,
285
+ .toolbar-element > .toolbar-button {
286
+ white-space: pre;
287
+ height: var(--toolbar-button-height);
288
+ }
289
+
290
+ .toolbar-dropdown .toolbar-button > .toolbar-icon {
291
+ max-width: 50px;
292
+ width: 100%;
293
+ }
294
+
295
+ .toolbar-button.disabled {
296
+ filter: opacity(0.5) sepia(0.2);
297
+ cursor: unset;
298
+ }
299
+
300
+ .toolbar-button, .toolbar-element button {
301
+ cursor: pointer;
302
+ text-align: center;
303
+ border-radius: 6px;
304
+ border: none;
305
+ box-shadow: 0px 0px 2px var(--shadow-color);
306
+ transition: background-color 0.15s ease, box-shadow 0.25s ease, opacity 0.2s ease;
307
+ }
308
+
309
+ .toolbar-button,
310
+ .toolbar-buttonGroup > button,
311
+ .toolbar-toolContainer > * > button,
312
+ .toolbar-root > button {
313
+ display: flex;
314
+ flex-direction: column;
315
+ align-items: center;
316
+ justify-content: center;
317
+ padding-left: 3px;
318
+ padding-right: 3px;
319
+ min-width: 40px;
320
+ max-width: 105px;
321
+ width: min-content;
322
+ font-size: 1em;
323
+ }
324
+
325
+ .toolbar-button > label {
326
+ cursor: inherit;
327
+ user-select: none;
328
+ -webkit-user-select: none;
329
+ }
330
+
331
+ /* Decrease the font size of labels in the main toolbar if they're long. */
332
+ .toolbar-root > .toolbar-toolContainer > .toolbar-button > label.long-label {
333
+ font-size: 0.75em;
334
+ }
335
+
336
+ .toolbar-dropdown > .toolbar-toolContainer > button,
337
+ .toolbar-dropdown > .toolbar-toolContainer > .toolbar-button {
338
+ width: 6em;
339
+ }
340
+
341
+ .toolbar-button:not(.disabled):hover, .toolbar-root button:not(:disabled):hover {
342
+ box-shadow: 0px 2px 4px var(--shadow-color);
343
+ }
344
+
345
+ .toolbar-root button:disabled {
346
+ cursor: inherit;
347
+ filter: opacity(0.5);
348
+ }
349
+
350
+ .toolbar-root .toolbar-icon {
351
+ flex-shrink: 1;
352
+ user-select: none;
353
+ width: 100%;
354
+ min-width: 20px;
355
+ min-height: 20px;
356
+ }
357
+
358
+ .toolbar-toolContainer.selected > .toolbar-button {
359
+ background-color: var(--selection-background-color);
360
+ color: var(--selection-foreground-color);
361
+ --icon-color: var(--selection-foreground-color);
362
+ }
363
+
364
+ .toolbar-toolContainer:not(.selected):not(.dropdownShowable) > .toolbar-button > .toolbar-showHideDropdownIcon {
365
+ display: none;
366
+ }
367
+
368
+ .toolbar-toolContainer > .toolbar-button > .toolbar-showHideDropdownIcon {
369
+ height: 15px;
370
+ transition: transform 0.25s ease;
371
+ }
372
+
373
+ .toolbar-toolContainer.dropdownVisible > .toolbar-button > .toolbar-showHideDropdownIcon {
374
+ transform: rotate(180deg);
375
+ }
376
+
377
+ .toolbar-dropdown.hidden,
378
+ .toolbar-toolContainer:not(.selected):not(.dropdownShowable) > .toolbar-dropdown:not(.hiding) {
379
+ display: none;
380
+ }
381
+
382
+ .toolbar-dropdown {
383
+ position: absolute;
384
+ padding: 15px;
385
+ padding-top: 5px;
386
+ display: flex;
387
+ flex-wrap: wrap;
388
+ flex-direction: column;
389
+ max-height: 80vh;
390
+ max-width: fit-content;
391
+ /* Prevent overlap/being displayed under the undo/redo buttons */
392
+ z-index: 2;
393
+ background-color: var(--background-color-1);
394
+ box-shadow: 0px 3px 3px var(--shadow-color);
395
+ }
396
+
397
+ /* Animate showing/hiding the dropdown. Animations triggered in JavaScript. */
398
+ @keyframes dropdown-transition-in {
399
+ 0% {
400
+ opacity: 0;
401
+ transform: scale(1, 0);
402
+ }
403
+ 100% {
404
+ opacity: 1;
405
+ transform: scale(1, 1);
406
+ }
407
+ }
408
+ @keyframes dropdown-transition-out {
409
+ 0% {
410
+ opacity: 1;
411
+ transform: scale(1, 1);
412
+ }
413
+ 100% {
414
+ opacity: 0;
415
+ transform: scale(1, 0);
416
+ }
417
+ }
418
+ .toolbar-dropdown {
419
+ /* Ensure the animation begins from the correct location. */
420
+ transform-origin: top left;
421
+ --dropdown-show-animation: dropdown-transition-in;
422
+ --dropdown-hide-animation: dropdown-transition-out;
423
+ }
424
+
425
+ @media (prefers-reduced-motion: reduce) {
426
+ /* Disable toolbar animations if reducing motion */
427
+ .toolbar-dropdown {
428
+ --dropdown-show-animation: none;
429
+ --dropdown-hide-animation: none;
430
+ }
431
+ .toolbar-dropdown.hiding {
432
+ display: none;
433
+ }
434
+ /* Also disable arrow rotation */
435
+ .toolbar-toolContainer > .toolbar-button > .toolbar-showHideDropdownIcon {
436
+ transition: none;
437
+ }
438
+ /* ...and background color animation. */
439
+ :root .toolbar-button, .toolbar-root button {
440
+ transition: none;
441
+ }
442
+ }
443
+ .toolbar-buttonGroup {
444
+ display: flex;
445
+ flex-direction: row;
446
+ justify-content: center;
447
+ }
448
+
449
+ .toolbar-closeColorPickerOverlay {
450
+ display: none;
451
+ position: fixed;
452
+ top: 0;
453
+ left: 0;
454
+ bottom: 0;
455
+ right: 0;
456
+ touch-action: none;
457
+ background-color: var(--background-color-1);
458
+ opacity: 0.3;
459
+ z-index: 2;
460
+ }
461
+
462
+ .toolbar-spacedList > * {
463
+ padding-bottom: 5px;
464
+ padding-top: 5px;
465
+ }
466
+
467
+ .toolbar-indentedList {
468
+ padding-left: 10px;
469
+ }
470
+
471
+ @media print {
472
+ /* Hide all toolbar elements on print. */
473
+ .toolbar-element {
474
+ display: none;
475
+ }
476
+ }
477
+ @keyframes toolbar--edgemenu-transition-in {
478
+ from {
479
+ translate: 0 100%;
480
+ }
481
+ to {
482
+ translate: 0;
483
+ }
484
+ }
485
+ @keyframes toolbar--edgemenu-transition-out {
486
+ to {
487
+ translate: 0 100%;
488
+ }
489
+ }
490
+ @keyframes toolbar--edgemenu-container-transition-in {
491
+ from {
492
+ overflow-y: hidden;
493
+ }
494
+ to {
495
+ overflow-y: hidden;
496
+ }
497
+ }
498
+ @keyframes toolbar--edgemenu-container-transition-out {
499
+ from {
500
+ overflow-y: hidden;
501
+ }
502
+ to {
503
+ overflow-y: hidden;
504
+ }
505
+ }
506
+ .toolbar-edge-toolbar {
507
+ --toolbar-button-height: min(20vh, 48px);
508
+ --toolbar-button-size: var(--toolbar-button-height);
509
+ --label-hover-offset-size: calc(14px + var(--toolbar-button-height));
510
+ box-sizing: border-box;
511
+ flex-direction: row;
512
+ justify-content: space-around;
513
+ --button-label-hover-offset-y: var(--label-hover-offset-size);
514
+ --button-label-hover-offset-x: 0;
515
+ }
516
+ @media screen and (min-width: 610px) {
517
+ .toolbar-edge-toolbar {
518
+ flex-wrap: nowrap;
519
+ }
520
+ .toolbar-edge-toolbar > .toolbar-action-row {
521
+ max-width: 50vw;
522
+ }
523
+ }
524
+ @media screen and (max-width: 700px) {
525
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline {
526
+ font-size: 0.9em;
527
+ }
528
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button label {
529
+ opacity: 0;
530
+ animation: 0.2s linear hide-initially;
531
+ }
532
+ @keyframes hide-initially {
533
+ from {
534
+ opacity: 0;
535
+ }
536
+ to {
537
+ opacity: 0;
538
+ }
539
+ }
540
+ @keyframes rehide-label {
541
+ 0% {
542
+ opacity: 0.8;
543
+ }
544
+ 80% {
545
+ opacity: 0.8;
546
+ }
547
+ 100% {
548
+ opacity: 0.1;
549
+ }
550
+ }
551
+ @keyframes show-label {
552
+ 0% {
553
+ opacity: 0;
554
+ }
555
+ 80% {
556
+ opacity: 0;
557
+ }
558
+ 100% {
559
+ opacity: 0.8;
560
+ }
561
+ }
562
+ @keyframes keep-label-hidden {
563
+ 0% {
564
+ opacity: 0;
565
+ }
566
+ 100% {
567
+ opacity: 0;
568
+ }
569
+ }
570
+ }
571
+ @media screen and (max-width: 700px) and (hover: hover) {
572
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button:hover > label {
573
+ opacity: 0.8;
574
+ animation: 1s ease show-label;
575
+ }
576
+ }
577
+ @media screen and (max-width: 700px) {
578
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button:active > label {
579
+ opacity: 0.8;
580
+ animation: 0.5s ease show-label;
581
+ }
582
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button:focus-visible > label {
583
+ animation: 1.5s ease rehide-label;
584
+ opacity: 0;
585
+ }
586
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button:has(:focus-visible) > label {
587
+ animation: 1.5s ease rehide-label;
588
+ opacity: 0;
589
+ }
590
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button > label {
591
+ opacity: 0;
592
+ position: absolute;
593
+ margin-top: var(--button-label-hover-offset-y);
594
+ margin-left: var(--button-label-hover-offset-x);
595
+ pointer-events: none;
596
+ background-color: var(--background-color-1);
597
+ color: var(--foreground-color-1);
598
+ border-radius: 25px;
599
+ padding: 10px;
600
+ transition: 0.2s ease opacity, 0.2s ease margin-top;
601
+ }
602
+ }
603
+ @media screen and (max-width: 700px) and (prefers-reduced-motion: reduce) {
604
+ .toolbar-edge-toolbar.one-row > * > .toolbar-toolContainer.label-inline .toolbar-button > label {
605
+ transition: none;
606
+ }
607
+ }
608
+ .toolbar-edge-toolbar > div.toolbar-element {
609
+ flex-direction: row;
610
+ display: flex;
611
+ flex-grow: 1;
612
+ justify-content: center;
613
+ background-color: var(--background-color-2);
614
+ color: var(--foreground-color-2);
615
+ --icon-color: var(--foreground-color-2);
616
+ --extra-left-right-padding: 0px;
617
+ }
618
+ .toolbar-edge-toolbar > div.toolbar-element::-webkit-scrollbar {
619
+ width: 3px;
620
+ height: 3px;
621
+ }
622
+ .toolbar-edge-toolbar > div.toolbar-element::-webkit-scrollbar-thumb {
623
+ background-color: var(--shadow-color);
624
+ }
625
+ .toolbar-edge-toolbar > div.toolbar-element.toolbar-tool-row {
626
+ overflow-x: auto;
627
+ overflow-y: hidden;
628
+ flex-grow: 100;
629
+ }
630
+ .toolbar-edge-toolbar > div.toolbar-element.toolbar-action-row {
631
+ z-index: 2;
632
+ background-color: var(--background-color-3);
633
+ color: var(--foreground-color-3);
634
+ --icon-color: var(--foreground-color-3);
635
+ }
636
+ .toolbar-edge-toolbar > div.toolbar-element.has-scroll {
637
+ justify-content: start;
638
+ position: relative;
639
+ --button-label-hover-offset-y: 0;
640
+ --button-label-hover-offset-x: calc(0px - var(--label-hover-offset-size));
641
+ }
642
+ .toolbar-edge-toolbar > div.toolbar-element.has-scroll > :nth-child(1) {
643
+ --button-label-hover-offset-x: var(--label-hover-offset-size);
644
+ }
645
+ .toolbar-edge-toolbar .toolbar-toolContainer.selected > .toolbar-button {
646
+ background-color: var(--selection-background-color);
647
+ color: var(--selection-foreground-color);
648
+ --icon-color: var(--selection-foreground-color);
649
+ }
650
+ .toolbar-edge-toolbar .toolbar-button {
651
+ box-sizing: border-box;
652
+ background-color: transparent;
653
+ }
654
+ .toolbar-edge-toolbar .toolbar-button .toolbar-showHideDropdownIcon {
655
+ flex-shrink: 0.01;
656
+ height: 12px;
657
+ }
658
+ .toolbar-edge-toolbar .toolbar-toolContainer {
659
+ order: 1;
660
+ }
661
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline {
662
+ flex-grow: 1;
663
+ display: flex;
664
+ --button-flex-direction: row;
665
+ }
666
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline.label-left {
667
+ justify-content: end;
668
+ --button-flex-direction: row-reverse;
669
+ order: 100;
670
+ }
671
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline.label-left > .toolbar-button > .toolbar-icon {
672
+ margin-left: 10px;
673
+ }
674
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline.label-right {
675
+ order: -1;
676
+ }
677
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline > .toolbar-button {
678
+ width: auto;
679
+ flex-direction: var(--button-flex-direction);
680
+ }
681
+ .toolbar-edge-toolbar .toolbar-toolContainer.label-inline > .toolbar-button > .toolbar-icon {
682
+ height: 100%;
683
+ margin-right: 10px;
684
+ }
685
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button {
686
+ width: calc(var(--toolbar-button-size) + var(--extra-left-right-padding));
687
+ height: var(--toolbar-button-size);
688
+ }
689
+ @keyframes rehide-label {
690
+ 0% {
691
+ opacity: 0.8;
692
+ }
693
+ 80% {
694
+ opacity: 0.8;
695
+ }
696
+ 100% {
697
+ opacity: 0.1;
698
+ }
699
+ }
700
+ @keyframes show-label {
701
+ 0% {
702
+ opacity: 0;
703
+ }
704
+ 80% {
705
+ opacity: 0;
706
+ }
707
+ 100% {
708
+ opacity: 0.8;
709
+ }
710
+ }
711
+ @keyframes keep-label-hidden {
712
+ 0% {
713
+ opacity: 0;
714
+ }
715
+ 100% {
716
+ opacity: 0;
717
+ }
718
+ }
719
+ @media (hover: hover) {
720
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button:hover > label {
721
+ opacity: 0.8;
722
+ animation: 1s ease show-label;
723
+ }
724
+ }
725
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button:active > label {
726
+ opacity: 0.8;
727
+ animation: 0.5s ease show-label;
728
+ }
729
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button:focus-visible > label {
730
+ animation: 1.5s ease rehide-label;
731
+ opacity: 0;
732
+ }
733
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button:has(:focus-visible) > label {
734
+ animation: 1.5s ease rehide-label;
735
+ opacity: 0;
736
+ }
737
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button > label {
738
+ opacity: 0;
739
+ position: absolute;
740
+ margin-top: var(--button-label-hover-offset-y);
741
+ margin-left: var(--button-label-hover-offset-x);
742
+ pointer-events: none;
743
+ background-color: var(--background-color-1);
744
+ color: var(--foreground-color-1);
745
+ border-radius: 25px;
746
+ padding: 10px;
747
+ transition: 0.2s ease opacity, 0.2s ease margin-top;
748
+ }
749
+ @media (prefers-reduced-motion: reduce) {
750
+ .toolbar-edge-toolbar .toolbar-toolContainer:not(.no-icon):not(.label-inline) .toolbar-button > label {
751
+ transition: none;
752
+ }
753
+ }
754
+ .toolbar-edge-toolbar > div > .toolbar-toolContainer:not(.selected):not(.dropdownShowable) > .toolbar-button > .toolbar-showHideDropdownIcon {
755
+ display: block;
756
+ visibility: hidden;
757
+ }
758
+ .toolbar-edge-toolbar .toolbar-toolContainer > .toolbar-button {
759
+ margin: 0;
760
+ border-radius: 0;
761
+ padding: 8px;
762
+ box-shadow: none;
763
+ }
764
+ .toolbar-edge-toolbar .toolbar-toolContainer > .toolbar-button.has-dropdown {
765
+ padding-left: 8px;
766
+ padding-right: 8px;
767
+ padding-top: 8px;
768
+ padding-bottom: 0px;
769
+ }
770
+
771
+ .imageEditorContainer.pipette--color-selection-in-progress .toolbar-edgemenu-container {
772
+ height: 0;
773
+ background-color: transparent;
774
+ opacity: 0.9;
775
+ }
776
+ .imageEditorContainer.pipette--color-selection-in-progress .toolbar-edgemenu-container .toolbar-edgemenu {
777
+ position: absolute;
778
+ }
779
+
780
+ .toolbar-edgemenu-container {
781
+ background-color: var(--background-color-transparent);
782
+ transition: 0.15s ease-in-out height, 0.15s ease-in-out background-color, 0.2s ease-in-out opacity;
783
+ position: absolute;
784
+ width: var(--editor-current-width-px);
785
+ height: var(--editor-current-height-px);
786
+ box-sizing: border-box;
787
+ display: flex;
788
+ flex-direction: column-reverse;
789
+ align-items: center;
790
+ z-index: 2;
791
+ }
792
+ @media (prefers-reduced-motion: reduce) {
793
+ .toolbar-edgemenu-container {
794
+ transition: none;
795
+ }
796
+ }
797
+ .toolbar-edgemenu-container.dropdown-below-edge {
798
+ overflow-y: hidden;
799
+ }
800
+ .toolbar-edgemenu-container button {
801
+ font-size: 1.2em;
802
+ box-shadow: none;
803
+ border: none;
804
+ padding: 10px;
805
+ color: var(--foreground-color-1);
806
+ transition: 0.2s ease box-shadow;
807
+ font-weight: bold;
808
+ color: var(--primary-action-foreground-color);
809
+ }
810
+ .toolbar-edgemenu-container button:hover {
811
+ box-shadow: 0 1px 2px var(--shadow-color);
812
+ }
813
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button {
814
+ --button-label-hover-offset-y: var(--button-size);
815
+ }
816
+ @keyframes rehide-label {
817
+ 0% {
818
+ opacity: 0.8;
819
+ }
820
+ 80% {
821
+ opacity: 0.8;
822
+ }
823
+ 100% {
824
+ opacity: 0.1;
825
+ }
826
+ }
827
+ @keyframes show-label {
828
+ 0% {
829
+ opacity: 0;
830
+ }
831
+ 80% {
832
+ opacity: 0;
833
+ }
834
+ 100% {
835
+ opacity: 0.8;
836
+ }
837
+ }
838
+ @keyframes keep-label-hidden {
839
+ 0% {
840
+ opacity: 0;
841
+ }
842
+ 100% {
843
+ opacity: 0;
844
+ }
845
+ }
846
+ @media (hover: hover) {
847
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button:hover > label > .button-label-text {
848
+ opacity: 0.8;
849
+ animation: 1s ease show-label;
850
+ }
851
+ }
852
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button:active > label > .button-label-text {
853
+ opacity: 0.8;
854
+ animation: 0.5s ease show-label;
855
+ }
856
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button:focus-visible > label > .button-label-text {
857
+ animation: 1.5s ease rehide-label;
858
+ opacity: 0;
859
+ }
860
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button:has(:focus-visible) > label > .button-label-text {
861
+ animation: 1.5s ease rehide-label;
862
+ opacity: 0;
863
+ }
864
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button > label > .button-label-text {
865
+ opacity: 0;
866
+ position: absolute;
867
+ margin-top: var(--button-label-hover-offset-y);
868
+ margin-left: var(--button-label-hover-offset-x);
869
+ pointer-events: none;
870
+ background-color: var(--background-color-1);
871
+ color: var(--foreground-color-1);
872
+ border-radius: 25px;
873
+ padding: 10px;
874
+ transition: 0.2s ease opacity, 0.2s ease margin-top;
875
+ }
876
+ @media (prefers-reduced-motion: reduce) {
877
+ .toolbar-edgemenu-container .toolbar-grid-selector .choice-button > label > .button-label-text {
878
+ transition: none;
879
+ }
880
+ }
881
+
882
+ .toolbar-edgemenu-container .toolbar-edgemenu {
883
+ --toolbar-button-height: 48px;
884
+ touch-action: none;
885
+ user-select: none;
886
+ background-color: var(--background-color-2);
887
+ --icon-color: var(--foreground-color-2);
888
+ box-shadow: 0px 0px 1px var(--shadow-color);
889
+ padding-left: 10px;
890
+ padding-right: 10px;
891
+ width: min(400px, 100vw);
892
+ box-sizing: border-box;
893
+ border-top-left-radius: 30px;
894
+ border-top-right-radius: 30px;
895
+ transition: translate 0.1s ease, padding-bottom 0.1s ease;
896
+ }
897
+ .toolbar-edgemenu-container .toolbar-edgemenu input, .toolbar-edgemenu-container .toolbar-edgemenu textarea {
898
+ user-select: auto;
899
+ }
900
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer {
901
+ display: inline-block;
902
+ }
903
+ .toolbar-edgemenu-container .toolbar-edgemenu button {
904
+ background-color: transparent;
905
+ }
906
+ .toolbar-edgemenu-container .toolbar-edgemenu > button.drag-elem {
907
+ height: 40px;
908
+ display: block;
909
+ cursor: ns-resize;
910
+ position: relative;
911
+ margin-top: -15px;
912
+ margin-bottom: 10px;
913
+ width: 100%;
914
+ border: none;
915
+ box-shadow: none;
916
+ background: transparent;
917
+ }
918
+ .toolbar-edgemenu-container .toolbar-edgemenu > button.drag-elem::before {
919
+ content: "";
920
+ background-color: var(--icon-color);
921
+ opacity: 0.2;
922
+ display: block;
923
+ position: relative;
924
+ top: 10px;
925
+ height: 5px;
926
+ border-radius: 5px;
927
+ width: min(80%, 40px);
928
+ margin-left: auto;
929
+ margin-right: auto;
930
+ }
931
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer {
932
+ display: block;
933
+ }
934
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer .toolbar-button {
935
+ flex-direction: row;
936
+ max-width: unset;
937
+ width: 100%;
938
+ box-sizing: border-box;
939
+ justify-content: flex-start;
940
+ box-shadow: none;
941
+ padding: 2px;
942
+ }
943
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer .toolbar-button > .toolbar-icon {
944
+ width: 25px;
945
+ height: 25px;
946
+ padding: 13px;
947
+ margin-right: 15px;
948
+ }
949
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer .toolbar-button label, .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-toolContainer .toolbar-button > label.long-label {
950
+ font-size: 1em;
951
+ }
952
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-nonbutton-controls-main-list {
953
+ padding-left: 10px;
954
+ padding-right: 10px;
955
+ }
956
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-spacedList {
957
+ box-sizing: border-box;
958
+ }
959
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-spacedList > div {
960
+ display: flex;
961
+ align-items: center;
962
+ margin-top: 5px;
963
+ min-height: 35px;
964
+ }
965
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-spacedList > div > label {
966
+ padding-right: 35px;
967
+ min-width: 105px;
968
+ flex-shrink: 1;
969
+ box-sizing: border-box;
970
+ }
971
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-spacedList > div > input[type=checkbox] {
972
+ width: 20px;
973
+ height: 20px;
974
+ }
975
+ .toolbar-edgemenu-container .toolbar-edgemenu .toolbar-spacedList > div > input:not([type=checkbox]) {
976
+ flex-grow: 1;
977
+ min-width: 48px;
978
+ flex-shrink: 1;
979
+ }
980
+
981
+ .toolbar-dropdown-toolbar button, .toolbar-dropdown-toolbar .toolbar-button {
982
+ background-color: var(--background-color-2);
983
+ color: var(--foreground-color-2);
984
+ --icon-color: var(--foreground-color-2);
985
+ }
986
+ .toolbar-dropdown-toolbar, .toolbar-dropdown-toolbar .toolbar-dropdown {
987
+ background-color: var(--background-color-3);
988
+ color: var(--foreground-color-3);
989
+ }
990
+ .toolbar-dropdown-toolbar .toolbar-spacedList > div > label {
991
+ padding-right: 10px;
992
+ min-width: 50px;
993
+ }
994
+ .toolbar-dropdown-toolbar .clr-field button {
995
+ width: 100%;
996
+ height: 100%;
997
+ top: 50%;
998
+ left: 0;
999
+ border-radius: 5px;
1000
+ }
1001
+ .toolbar-dropdown-toolbar .toolbar-grid-selector > div {
1002
+ --button-size: 57px;
1003
+ }
1004
+ .toolbar-dropdown-toolbar .toolbar-dropdown > div > .toolbar-toolContainer {
1005
+ display: inline-block;
1006
+ }
1007
+
1008
+ .selection-tool-selection-background {
1009
+ background-color: var(--selection-background-color);
1010
+ opacity: 0.5;
1011
+ overflow: visible;
1012
+ position: absolute;
1013
+ }
1014
+
1015
+ .selection-tool-handle {
1016
+ border: 1px solid var(--foreground-color-1);
1017
+ background: var(--background-color-1);
1018
+ position: absolute;
1019
+ cursor: grab;
1020
+ }
1021
+
1022
+ .selection-tool-handle.selection-tool-circle {
1023
+ border-radius: 100%;
1024
+ }
1025
+
1026
+ .overlay.handleOverlay {
1027
+ height: 0;
1028
+ overflow: visible;
1029
+ }
1030
+
1031
+ @keyframes selection-duplicated-animation {
1032
+ 0% {
1033
+ transform: scale(1, 1);
1034
+ }
1035
+ 50% {
1036
+ transform: scale(1.02, 1.02);
1037
+ }
1038
+ 100% {
1039
+ transform: scale(1, 1);
1040
+ }
1041
+ }
1042
+ /* Do not run the animation when the user has disabled motion animations. */
1043
+ @media (prefers-reduced-motion: reduce) {
1044
+ @keyframes selection-duplicated-animation {}
1045
+ }
1046
+ .find-tool-overlay {
1047
+ /* Show at the bottom of the screen. */
1048
+ order: -1;
1049
+ position: absolute;
1050
+ }
1051
+
1052
+ .js-draw-sound-ui-toggle {
1053
+ width: 0px;
1054
+ height: 0px;
1055
+ overflow: hidden;
1056
+ }
1057
+
1058
+ .js-draw-sound-ui-toggle:focus-within, .js-draw-sound-ui-toggle.sound-ui-tool-enabled {
1059
+ overflow: visible;
1060
+ z-index: 5;
1061
+ }
1062
+
1063
+ .js-draw-sound-ui-toggle:not(:focus-within):not(:hover).sound-ui-tool-enabled {
1064
+ opacity: 0.5;
1065
+ }
1066
+
1067
+ .about-dialog-container dialog {
1068
+ display: flex;
1069
+ flex-direction: column;
1070
+ }
1071
+ .about-dialog-container dialog .close-button {
1072
+ display: block;
1073
+ margin-left: auto;
1074
+ margin-right: auto;
1075
+ }
1076
+ .about-dialog-container dialog .about-entry-container {
1077
+ flex-grow: 1;
1078
+ flex-shrink: 1;
1079
+ overflow-y: auto;
1080
+ margin-left: 20px;
1081
+ margin-right: 20px;
1082
+ padding-bottom: 20px;
1083
+ white-space: pre-wrap;
1084
+ font-family: monospace;
1085
+ }
1086
+ .about-dialog-container dialog .about-entry-container > h2, .about-dialog-container dialog .about-entry-container > details > summary {
1087
+ cursor: pointer;
1088
+ margin-top: 15px;
1089
+ font-size: 1.2em;
1090
+ font-weight: bold;
1091
+ }
1092
+ .about-dialog-container dialog .about-entry-container > h2 a, .about-dialog-container dialog .about-entry-container > details > summary a {
1093
+ color: var(--foreground-color-1);
1094
+ text-decoration: underline;
1095
+ }
1096
+
1097
+ .dialog-container {
1098
+ background-color: var(--background-color-transparent);
1099
+ backdrop-filter: blur(5px);
1100
+ -webkit-backdrop-filter: blur(5px);
1101
+ position: absolute;
1102
+ z-index: 3;
1103
+ width: var(--editor-current-width-px);
1104
+ height: var(--editor-current-height-px);
1105
+ display: flex;
1106
+ flex-direction: column-reverse;
1107
+ align-items: center;
1108
+ justify-content: center;
1109
+ }
1110
+ .dialog-container dialog {
1111
+ background-color: var(--background-color-1);
1112
+ color: var(--foreground-color-1);
1113
+ border: none;
1114
+ outline: none;
1115
+ box-shadow: 0 0 2px var(--shadow-color);
1116
+ border-radius: 8px;
1117
+ max-height: 90vh;
1118
+ width: min(100%, 500px);
1119
+ box-sizing: border-box;
1120
+ }
1121
+
1122
+ /* Imports Coloris' CSS and makes additional changes to the color picker */
1123
+ #clr-picker {
1124
+ --clr-slider-size: 30px;
1125
+ }
1126
+
1127
+ /* Coloris: Try to avoid scrolling instead of updating the color input. */
1128
+ #clr-picker #clr-color-area, #clr-picker .clr_hue {
1129
+ touch-action: none;
1130
+ }
1131
+
1132
+ /* Increase space between inputs */
1133
+ #clr-picker .clr-alpha {
1134
+ margin-top: 15px;
1135
+ margin-bottom: 15px;
1136
+ }
1137
+
1138
+ /* Increase size of input thumb to make it easier to select colors. */
1139
+ #clr-picker.clr-picker input[type=range]::-moz-range-thumb {
1140
+ width: var(--clr-slider-size);
1141
+ height: var(--clr-slider-size);
1142
+ }
1143
+
1144
+ /* Also apply to Chrome/iOS */
1145
+ #clr-picker.clr-picker input[type=range]::-webkit-slider-thumb {
1146
+ /*
1147
+ Note: This doesn't seem to take effect in iOS if it's combined with the
1148
+ ::-moz-range-thumb rule above
1149
+ */
1150
+ width: var(--clr-slider-size);
1151
+ height: var(--clr-slider-size);
1152
+ }
1153
+
1154
+ #clr-picker.clr-picker input[type=range]::-webkit-slider-runnable-track {
1155
+ height: var(--clr-slider-size);
1156
+ }
1157
+
1158
+ #clr-picker.clr-picker input[type=range]::-moz-range-track {
1159
+ height: var(--clr-slider-size);
1160
+ }
1161
+
1162
+ /*
1163
+ Debugging: Uncommenting this rule makes Coloris' sliders more
1164
+ visible.
1165
+
1166
+ #clr-picker.clr-picker input[type="range"] {
1167
+ opacity: 0.5;
1168
+ -webkit-appearance: auto;
1169
+ appearance: auto;
1170
+ }
1171
+ */
1172
+ /* Deafult colors for the editor */
1173
+ .imageEditorContainer {
1174
+ --background-color-1: white;
1175
+ --foreground-color-1: black;
1176
+ --background-color-2: #f5f5f5;
1177
+ --foreground-color-2: #2c303a;
1178
+ --background-color-3: #e5e5e5;
1179
+ --foreground-color-3: #1c202a;
1180
+ --selection-background-color: #cbdaf1;
1181
+ --selection-foreground-color: #2c303a;
1182
+ --background-color-transparent: rgba(105, 100, 100, 0.5);
1183
+ --shadow-color: rgba(0, 0, 0, 0.5);
1184
+ --primary-action-foreground-color: #15b;
1185
+ }
1186
+
1187
+ @media (prefers-color-scheme: dark) {
1188
+ .imageEditorContainer {
1189
+ --background-color-1: #151515;
1190
+ --foreground-color-1: white;
1191
+ --background-color-2: #222;
1192
+ --foreground-color-2: #efefef;
1193
+ --background-color-3: #272627;
1194
+ --foreground-color-3: #eee;
1195
+ --selection-background-color: #607;
1196
+ --selection-foreground-color: white;
1197
+ --shadow-color: rgba(250, 250, 250, 0.5);
1198
+ --background-color-transparent: rgba(50, 50, 50, 0.5);
1199
+ --primary-action-foreground-color: #7ae;
1200
+ }
1201
+ }
1202
+ .imageEditorContainer {
1203
+ color: var(--foreground-color-1);
1204
+ font-family: system-ui, -apple-system, sans-serif;
1205
+ background-color: var(--background-color-1);
1206
+ width: 100%;
1207
+ height: 400px;
1208
+ min-height: 220px;
1209
+ min-width: 100px;
1210
+ box-sizing: border-box;
1211
+ display: flex;
1212
+ flex-direction: column-reverse;
1213
+ }
1214
+ .imageEditorContainer input {
1215
+ accent-color: var(--primary-action-foreground-color);
1216
+ }
1217
+
1218
+ .imageEditorContainer .imageEditorRenderArea {
1219
+ display: grid;
1220
+ grid-template-columns: 1fr;
1221
+ flex-grow: 2;
1222
+ flex-shrink: 1;
1223
+ min-height: 100px;
1224
+ min-width: 0;
1225
+ width: 100%;
1226
+ height: 100%;
1227
+ }
1228
+
1229
+ .imageEditorContainer .imageEditorRenderArea canvas {
1230
+ /* Stack all canvases on top of each other */
1231
+ grid-row: 1/1;
1232
+ grid-column: 1/1;
1233
+ touch-action: none;
1234
+ /* Fill the container */
1235
+ box-sizing: border-box;
1236
+ width: 100%;
1237
+ height: 100%;
1238
+ /* Allow the canvas to shrink (needed in Chrome) */
1239
+ min-width: 0;
1240
+ max-width: inherit;
1241
+ min-height: 0px;
1242
+ max-height: inherit;
1243
+ }
1244
+
1245
+ .imageEditorContainer .loadingMessage {
1246
+ position: fixed;
1247
+ text-align: center;
1248
+ font-size: 2em;
1249
+ bottom: 0;
1250
+ left: 0;
1251
+ right: 0;
1252
+ }
1253
+
1254
+ .imageEditorContainer .accessibilityAnnouncement {
1255
+ opacity: 0;
1256
+ width: 0;
1257
+ height: 0;
1258
+ overflow: hidden;
1259
+ pointer-events: none;
1260
+ }
1261
+
1262
+ .imageEditorContainer .textRendererOutputContainer {
1263
+ width: 1px;
1264
+ height: 1px;
1265
+ overflow: hidden;
1266
+ }
1267
+
1268
+ .imageEditorContainer .textRendererOutputContainer:focus-within {
1269
+ overflow: visible;
1270
+ z-index: 5;
1271
+ }
1272
+
1273
+ @media print {
1274
+ .imageEditorContainer .loadingMessage {
1275
+ display: none;
1276
+ }
1277
+ .imageEditorContainer .imageEditorRenderArea canvas {
1278
+ width: 100%;
1279
+ height: initial;
1280
+ }
1281
+ }