@pdftools/four-heights-pdf-web-viewer 4.3.6

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 (367) hide show
  1. package/LICENSE.md +446 -0
  2. package/README.md +145 -0
  3. package/css/pdf-web-viewer.css +2407 -0
  4. package/doc/PdfWebViewer.pdf +0 -0
  5. package/es6/common/Checkbox.d.ts +9 -0
  6. package/es6/common/Checkbox.js +8 -0
  7. package/es6/common/Color.d.ts +23 -0
  8. package/es6/common/Color.js +118 -0
  9. package/es6/common/ColorPicker.d.ts +15 -0
  10. package/es6/common/ColorPicker.js +46 -0
  11. package/es6/common/Contextbar.d.ts +6 -0
  12. package/es6/common/Contextbar.js +19 -0
  13. package/es6/common/DragMoveHandler.d.ts +51 -0
  14. package/es6/common/DragMoveHandler.js +175 -0
  15. package/es6/common/Dropdown.d.ts +36 -0
  16. package/es6/common/Dropdown.js +76 -0
  17. package/es6/common/DropdownMenu.d.ts +9 -0
  18. package/es6/common/DropdownMenu.js +10 -0
  19. package/es6/common/DropdownSeparator.d.ts +3 -0
  20. package/es6/common/DropdownSeparator.js +6 -0
  21. package/es6/common/Icon.d.ts +13 -0
  22. package/es6/common/Icon.js +8 -0
  23. package/es6/common/Loader.d.ts +3 -0
  24. package/es6/common/Loader.js +6 -0
  25. package/es6/common/RangeSlider.d.ts +17 -0
  26. package/es6/common/RangeSlider.js +42 -0
  27. package/es6/common/StrokeStylePicker.d.ts +11 -0
  28. package/es6/common/StrokeStylePicker.js +20 -0
  29. package/es6/common/StrokeWidthPicker.d.ts +11 -0
  30. package/es6/common/StrokeWidthPicker.js +20 -0
  31. package/es6/common/Toolbar.d.ts +10 -0
  32. package/es6/common/Toolbar.js +6 -0
  33. package/es6/common/ToolbarButton.d.ts +14 -0
  34. package/es6/common/ToolbarButton.js +21 -0
  35. package/es6/common/ToolbarFileButton.d.ts +15 -0
  36. package/es6/common/ToolbarFileButton.js +27 -0
  37. package/es6/common/ToolbarItemGroup.d.ts +8 -0
  38. package/es6/common/ToolbarItemGroup.js +12 -0
  39. package/es6/common/ToolbarSeparator.d.ts +3 -0
  40. package/es6/common/ToolbarSeparator.js +6 -0
  41. package/es6/common/Tools.d.ts +10 -0
  42. package/es6/common/Tools.js +89 -0
  43. package/es6/common/TooltipManager.d.ts +12 -0
  44. package/es6/common/TooltipManager.js +54 -0
  45. package/es6/common/TranslationManager.d.ts +11 -0
  46. package/es6/common/TranslationManager.js +61 -0
  47. package/es6/common/classNames.d.ts +2 -0
  48. package/es6/common/classNames.js +18 -0
  49. package/es6/common/formatDate.d.ts +1 -0
  50. package/es6/common/formatDate.js +1 -0
  51. package/es6/common/icons.d.ts +13 -0
  52. package/es6/common/icons.js +412 -0
  53. package/es6/common/utils.d.ts +2 -0
  54. package/es6/common/utils.js +19 -0
  55. package/es6/custom/history.d.ts +2 -0
  56. package/es6/custom/history.js +59 -0
  57. package/es6/index.d.ts +5 -0
  58. package/es6/index.js +5 -0
  59. package/es6/lib/hyperapp/index.d.ts +108 -0
  60. package/es6/lib/hyperapp/index.js +327 -0
  61. package/es6/modules/CanvasLayer.d.ts +32 -0
  62. package/es6/modules/CanvasLayer.js +83 -0
  63. package/es6/modules/CanvasModule.d.ts +59 -0
  64. package/es6/modules/CanvasModule.js +98 -0
  65. package/es6/modules/eraser/EraserLayer.d.ts +13 -0
  66. package/es6/modules/eraser/EraserLayer.js +141 -0
  67. package/es6/modules/eraser/EraserModule.d.ts +19 -0
  68. package/es6/modules/eraser/EraserModule.js +34 -0
  69. package/es6/modules/eraser/EraserToolbar.d.ts +10 -0
  70. package/es6/modules/eraser/EraserToolbar.js +30 -0
  71. package/es6/modules/form-fields/CheckBoxWidget.d.ts +9 -0
  72. package/es6/modules/form-fields/CheckBoxWidget.js +45 -0
  73. package/es6/modules/form-fields/ComboBoxWidget.d.ts +22 -0
  74. package/es6/modules/form-fields/ComboBoxWidget.js +152 -0
  75. package/es6/modules/form-fields/EditFormFieldLayer.d.ts +17 -0
  76. package/es6/modules/form-fields/EditFormFieldLayer.js +238 -0
  77. package/es6/modules/form-fields/FormFieldModule.d.ts +15 -0
  78. package/es6/modules/form-fields/FormFieldModule.js +27 -0
  79. package/es6/modules/form-fields/ListBoxWidget.d.ts +9 -0
  80. package/es6/modules/form-fields/ListBoxWidget.js +73 -0
  81. package/es6/modules/form-fields/RadioButtonWidget.d.ts +9 -0
  82. package/es6/modules/form-fields/RadioButtonWidget.js +45 -0
  83. package/es6/modules/form-fields/SelectListWidget.d.ts +9 -0
  84. package/es6/modules/form-fields/SelectListWidget.js +45 -0
  85. package/es6/modules/form-fields/TextBoxWidget.d.ts +9 -0
  86. package/es6/modules/form-fields/TextBoxWidget.js +53 -0
  87. package/es6/modules/form-fields/WidgetBase.d.ts +23 -0
  88. package/es6/modules/form-fields/WidgetBase.js +29 -0
  89. package/es6/modules/freetext-annotation/AddFreetextAnnotationLayer.d.ts +19 -0
  90. package/es6/modules/freetext-annotation/AddFreetextAnnotationLayer.js +181 -0
  91. package/es6/modules/freetext-annotation/AddFreetextAnnotationToolbar.d.ts +21 -0
  92. package/es6/modules/freetext-annotation/AddFreetextAnnotationToolbar.js +37 -0
  93. package/es6/modules/freetext-annotation/EditFreetextAnnotationLayer.d.ts +20 -0
  94. package/es6/modules/freetext-annotation/EditFreetextAnnotationLayer.js +211 -0
  95. package/es6/modules/freetext-annotation/EditFreetextAnnotationToolbar.d.ts +50 -0
  96. package/es6/modules/freetext-annotation/EditFreetextAnnotationToolbar.js +118 -0
  97. package/es6/modules/freetext-annotation/FreetextAnnotationModule.d.ts +28 -0
  98. package/es6/modules/freetext-annotation/FreetextAnnotationModule.js +58 -0
  99. package/es6/modules/freetext-annotation/RichTextEditor.d.ts +31 -0
  100. package/es6/modules/freetext-annotation/RichTextEditor.js +223 -0
  101. package/es6/modules/highlight-annotation/AddHighlightAnnotationLayer.d.ts +31 -0
  102. package/es6/modules/highlight-annotation/AddHighlightAnnotationLayer.js +289 -0
  103. package/es6/modules/highlight-annotation/AddHighlightAnnotationToolbar.d.ts +20 -0
  104. package/es6/modules/highlight-annotation/AddHighlightAnnotationToolbar.js +52 -0
  105. package/es6/modules/highlight-annotation/EditHighlightAnnotationLayer.d.ts +15 -0
  106. package/es6/modules/highlight-annotation/EditHighlightAnnotationLayer.js +104 -0
  107. package/es6/modules/highlight-annotation/EditHighlightAnnotationToolbar.d.ts +15 -0
  108. package/es6/modules/highlight-annotation/EditHighlightAnnotationToolbar.js +28 -0
  109. package/es6/modules/highlight-annotation/HighlightAnnotationModule.d.ts +27 -0
  110. package/es6/modules/highlight-annotation/HighlightAnnotationModule.js +54 -0
  111. package/es6/modules/image-annotations/ImageAnnotationModule.d.ts +23 -0
  112. package/es6/modules/image-annotations/ImageAnnotationModule.js +169 -0
  113. package/es6/modules/index.d.ts +13 -0
  114. package/es6/modules/index.js +13 -0
  115. package/es6/modules/ink-annotation/AddInkAnnotationLayer.d.ts +40 -0
  116. package/es6/modules/ink-annotation/AddInkAnnotationLayer.js +503 -0
  117. package/es6/modules/ink-annotation/AddInkAnnotationToolbar.d.ts +30 -0
  118. package/es6/modules/ink-annotation/AddInkAnnotationToolbar.js +53 -0
  119. package/es6/modules/ink-annotation/EditInkAnnotationLayer.d.ts +20 -0
  120. package/es6/modules/ink-annotation/EditInkAnnotationLayer.js +137 -0
  121. package/es6/modules/ink-annotation/EditInkAnnotationToolbar.d.ts +25 -0
  122. package/es6/modules/ink-annotation/EditInkAnnotationToolbar.js +47 -0
  123. package/es6/modules/ink-annotation/InkAnnotationModule.d.ts +27 -0
  124. package/es6/modules/ink-annotation/InkAnnotationModule.js +50 -0
  125. package/es6/modules/popup/Popup.d.ts +64 -0
  126. package/es6/modules/popup/Popup.js +360 -0
  127. package/es6/modules/popup/PopupLayer.d.ts +31 -0
  128. package/es6/modules/popup/PopupLayer.js +509 -0
  129. package/es6/modules/popup/PopupModule.d.ts +16 -0
  130. package/es6/modules/popup/PopupModule.js +25 -0
  131. package/es6/modules/print-service/PrintServiceDialog.d.ts +30 -0
  132. package/es6/modules/print-service/PrintServiceDialog.js +134 -0
  133. package/es6/modules/print-service/PrintServiceLayer.d.ts +24 -0
  134. package/es6/modules/print-service/PrintServiceLayer.js +310 -0
  135. package/es6/modules/print-service/PrintServiceModule.d.ts +18 -0
  136. package/es6/modules/print-service/PrintServiceModule.js +30 -0
  137. package/es6/modules/shape-annotations/AddShapeAnnotationLayer.d.ts +24 -0
  138. package/es6/modules/shape-annotations/AddShapeAnnotationLayer.js +210 -0
  139. package/es6/modules/shape-annotations/AddShapeAnnotationToolbar.d.ts +26 -0
  140. package/es6/modules/shape-annotations/AddShapeAnnotationToolbar.js +69 -0
  141. package/es6/modules/shape-annotations/EditShapeAnnotationLayer.d.ts +19 -0
  142. package/es6/modules/shape-annotations/EditShapeAnnotationLayer.js +148 -0
  143. package/es6/modules/shape-annotations/EditShapeAnnotationToolbar.d.ts +24 -0
  144. package/es6/modules/shape-annotations/EditShapeAnnotationToolbar.js +57 -0
  145. package/es6/modules/shape-annotations/ShapeAnnotationModule.d.ts +28 -0
  146. package/es6/modules/shape-annotations/ShapeAnnotationModule.js +50 -0
  147. package/es6/modules/stamp-annotation/AddStampAnnotationLayer.d.ts +19 -0
  148. package/es6/modules/stamp-annotation/AddStampAnnotationLayer.js +257 -0
  149. package/es6/modules/stamp-annotation/AddStampAnnotationToolbar.d.ts +17 -0
  150. package/es6/modules/stamp-annotation/AddStampAnnotationToolbar.js +68 -0
  151. package/es6/modules/stamp-annotation/StampAnnotationModule.d.ts +20 -0
  152. package/es6/modules/stamp-annotation/StampAnnotationModule.js +35 -0
  153. package/es6/modules/text-annotation/AddTextAnnotationLayer.d.ts +14 -0
  154. package/es6/modules/text-annotation/AddTextAnnotationLayer.js +132 -0
  155. package/es6/modules/text-annotation/AddTextAnnotationToolbar.d.ts +15 -0
  156. package/es6/modules/text-annotation/AddTextAnnotationToolbar.js +27 -0
  157. package/es6/modules/text-annotation/TextAnnotationModule.d.ts +19 -0
  158. package/es6/modules/text-annotation/TextAnnotationModule.js +34 -0
  159. package/es6/pdf-viewer-api/ImageContainer.d.ts +10 -0
  160. package/es6/pdf-viewer-api/ImageContainer.js +43 -0
  161. package/es6/pdf-viewer-api/PdfViewerApi.d.ts +463 -0
  162. package/es6/pdf-viewer-api/PdfViewerApi.js +732 -0
  163. package/es6/pdf-viewer-api/PdfViewingWrapper.d.ts +178 -0
  164. package/es6/pdf-viewer-api/PdfViewingWrapper.js +2037 -0
  165. package/es6/pdf-viewer-api/annotationDefaultBehaviors.d.ts +3 -0
  166. package/es6/pdf-viewer-api/annotationDefaultBehaviors.js +30 -0
  167. package/es6/pdf-viewer-api/enums.d.ts +100 -0
  168. package/es6/pdf-viewer-api/enums.js +113 -0
  169. package/es6/pdf-viewer-api/index.d.ts +3 -0
  170. package/es6/pdf-viewer-api/index.js +3 -0
  171. package/es6/pdf-viewer-api/types.d.ts +284 -0
  172. package/es6/pdf-viewer-api/types.js +6 -0
  173. package/es6/pdf-viewer-canvas/CanvasEvents.d.ts +76 -0
  174. package/es6/pdf-viewer-canvas/CanvasEvents.js +345 -0
  175. package/es6/pdf-viewer-canvas/PdfViewerCanvas.d.ts +175 -0
  176. package/es6/pdf-viewer-canvas/PdfViewerCanvas.js +1226 -0
  177. package/es6/pdf-viewer-canvas/state/annotations.d.ts +36 -0
  178. package/es6/pdf-viewer-canvas/state/annotations.js +157 -0
  179. package/es6/pdf-viewer-canvas/state/appState.d.ts +10 -0
  180. package/es6/pdf-viewer-canvas/state/appState.js +60 -0
  181. package/es6/pdf-viewer-canvas/state/canvas.d.ts +31 -0
  182. package/es6/pdf-viewer-canvas/state/canvas.js +41 -0
  183. package/es6/pdf-viewer-canvas/state/document.d.ts +50 -0
  184. package/es6/pdf-viewer-canvas/state/document.js +99 -0
  185. package/es6/pdf-viewer-canvas/state/pointer.d.ts +31 -0
  186. package/es6/pdf-viewer-canvas/state/pointer.js +31 -0
  187. package/es6/pdf-viewer-canvas/state/scroll.d.ts +22 -0
  188. package/es6/pdf-viewer-canvas/state/scroll.js +25 -0
  189. package/es6/pdf-viewer-canvas/state/search.d.ts +36 -0
  190. package/es6/pdf-viewer-canvas/state/search.js +27 -0
  191. package/es6/pdf-viewer-canvas/state/store.d.ts +39 -0
  192. package/es6/pdf-viewer-canvas/state/store.js +52 -0
  193. package/es6/pdf-viewer-canvas/state/viewer.d.ts +91 -0
  194. package/es6/pdf-viewer-canvas/state/viewer.js +175 -0
  195. package/es6/pdf-viewer-canvas/view-layers/AnnotationSelectionLayer.d.ts +28 -0
  196. package/es6/pdf-viewer-canvas/view-layers/AnnotationSelectionLayer.js +452 -0
  197. package/es6/pdf-viewer-canvas/view-layers/BusyStateLayer.d.ts +9 -0
  198. package/es6/pdf-viewer-canvas/view-layers/BusyStateLayer.js +25 -0
  199. package/es6/pdf-viewer-canvas/view-layers/PdfDocumentLayer.d.ts +10 -0
  200. package/es6/pdf-viewer-canvas/view-layers/PdfDocumentLayer.js +149 -0
  201. package/es6/pdf-viewer-canvas/view-layers/ScrollLayer.d.ts +48 -0
  202. package/es6/pdf-viewer-canvas/view-layers/ScrollLayer.js +308 -0
  203. package/es6/pdf-viewer-canvas/view-layers/TextSelectionLayer.d.ts +19 -0
  204. package/es6/pdf-viewer-canvas/view-layers/TextSelectionLayer.js +289 -0
  205. package/es6/pdf-viewer-canvas/view-layers/ViewLayerBase.d.ts +31 -0
  206. package/es6/pdf-viewer-canvas/view-layers/ViewLayerBase.js +106 -0
  207. package/es6/pdf-viewer-canvas/view-layers/canvasShapes.d.ts +11 -0
  208. package/es6/pdf-viewer-canvas/view-layers/canvasShapes.js +149 -0
  209. package/es6/pdf-viewer-canvas/view-layers/canvasUtlis.d.ts +3 -0
  210. package/es6/pdf-viewer-canvas/view-layers/canvasUtlis.js +10 -0
  211. package/es6/pdf-viewer-canvas/view-layers/views/AnnotationBorder.d.ts +52 -0
  212. package/es6/pdf-viewer-canvas/view-layers/views/AnnotationBorder.js +377 -0
  213. package/es6/pdf-viewer-canvas/view-layers/views/AnnotationContextBar.d.ts +47 -0
  214. package/es6/pdf-viewer-canvas/view-layers/views/AnnotationContextBar.js +102 -0
  215. package/es6/pdf-viewer-canvas/view-layers/views/TextSelectionContextBar.d.ts +14 -0
  216. package/es6/pdf-viewer-canvas/view-layers/views/TextSelectionContextBar.js +36 -0
  217. package/es6/pdf-viewing/PdfViewing.d.ts +4865 -0
  218. package/es6/pdf-viewing/PdfViewing.js +9611 -0
  219. package/es6/pdf-web-viewer/PdfWebViewer.d.ts +372 -0
  220. package/es6/pdf-web-viewer/PdfWebViewer.js +1386 -0
  221. package/es6/pdf-web-viewer/UserSettings.d.ts +8 -0
  222. package/es6/pdf-web-viewer/UserSettings.js +40 -0
  223. package/es6/pdf-web-viewer/WebViewerOptions.d.ts +387 -0
  224. package/es6/pdf-web-viewer/WebViewerOptions.js +582 -0
  225. package/es6/pdf-web-viewer/state/index.d.ts +80 -0
  226. package/es6/pdf-web-viewer/state/index.js +98 -0
  227. package/es6/pdf-web-viewer/state/layout.d.ts +24 -0
  228. package/es6/pdf-web-viewer/state/layout.js +21 -0
  229. package/es6/pdf-web-viewer/state/mobile.d.ts +16 -0
  230. package/es6/pdf-web-viewer/state/mobile.js +11 -0
  231. package/es6/pdf-web-viewer/state/navigationPanel.d.ts +61 -0
  232. package/es6/pdf-web-viewer/state/navigationPanel.js +84 -0
  233. package/es6/pdf-web-viewer/state/passwordForm.d.ts +18 -0
  234. package/es6/pdf-web-viewer/state/passwordForm.js +21 -0
  235. package/es6/pdf-web-viewer/state/pdfDocument.d.ts +31 -0
  236. package/es6/pdf-web-viewer/state/pdfDocument.js +41 -0
  237. package/es6/pdf-web-viewer/state/search.d.ts +29 -0
  238. package/es6/pdf-web-viewer/state/search.js +23 -0
  239. package/es6/pdf-web-viewer/views/App.d.ts +4 -0
  240. package/es6/pdf-web-viewer/views/App.js +19 -0
  241. package/es6/pdf-web-viewer/views/CustomButtons.d.ts +9 -0
  242. package/es6/pdf-web-viewer/views/CustomButtons.js +18 -0
  243. package/es6/pdf-web-viewer/views/DropZone.d.ts +9 -0
  244. package/es6/pdf-web-viewer/views/DropZone.js +53 -0
  245. package/es6/pdf-web-viewer/views/Layout.d.ts +4 -0
  246. package/es6/pdf-web-viewer/views/Layout.js +22 -0
  247. package/es6/pdf-web-viewer/views/annotationbar/Annotationbar.d.ts +4 -0
  248. package/es6/pdf-web-viewer/views/annotationbar/Annotationbar.js +21 -0
  249. package/es6/pdf-web-viewer/views/appbar/AddonsToolbar.d.ts +4 -0
  250. package/es6/pdf-web-viewer/views/appbar/AddonsToolbar.js +35 -0
  251. package/es6/pdf-web-viewer/views/appbar/AnnotationsMenu.d.ts +4 -0
  252. package/es6/pdf-web-viewer/views/appbar/AnnotationsMenu.js +22 -0
  253. package/es6/pdf-web-viewer/views/appbar/AppBar.d.ts +4 -0
  254. package/es6/pdf-web-viewer/views/appbar/AppBar.js +26 -0
  255. package/es6/pdf-web-viewer/views/appbar/DocumentBar.d.ts +4 -0
  256. package/es6/pdf-web-viewer/views/appbar/DocumentBar.js +36 -0
  257. package/es6/pdf-web-viewer/views/appbar/Menu.d.ts +4 -0
  258. package/es6/pdf-web-viewer/views/appbar/Menu.js +80 -0
  259. package/es6/pdf-web-viewer/views/appbar/NavigationBar.d.ts +4 -0
  260. package/es6/pdf-web-viewer/views/appbar/NavigationBar.js +74 -0
  261. package/es6/pdf-web-viewer/views/appbar/SearchBar.d.ts +4 -0
  262. package/es6/pdf-web-viewer/views/appbar/SearchBar.js +83 -0
  263. package/es6/pdf-web-viewer/views/appbar/SearchOptions.d.ts +10 -0
  264. package/es6/pdf-web-viewer/views/appbar/SearchOptions.js +55 -0
  265. package/es6/pdf-web-viewer/views/appbar/ViewBar.d.ts +4 -0
  266. package/es6/pdf-web-viewer/views/appbar/ViewBar.js +52 -0
  267. package/es6/pdf-web-viewer/views/appbar/ZoomBar.d.ts +4 -0
  268. package/es6/pdf-web-viewer/views/appbar/ZoomBar.js +18 -0
  269. package/es6/pdf-web-viewer/views/modal/ApplicationError.d.ts +4 -0
  270. package/es6/pdf-web-viewer/views/modal/ApplicationError.js +25 -0
  271. package/es6/pdf-web-viewer/views/modal/LoadApplication.d.ts +3 -0
  272. package/es6/pdf-web-viewer/views/modal/LoadApplication.js +6 -0
  273. package/es6/pdf-web-viewer/views/modal/LoadFile.d.ts +3 -0
  274. package/es6/pdf-web-viewer/views/modal/LoadFile.js +10 -0
  275. package/es6/pdf-web-viewer/views/modal/Modal.d.ts +4 -0
  276. package/es6/pdf-web-viewer/views/modal/Modal.js +39 -0
  277. package/es6/pdf-web-viewer/views/modal/OpenFile.d.ts +4 -0
  278. package/es6/pdf-web-viewer/views/modal/OpenFile.js +30 -0
  279. package/es6/pdf-web-viewer/views/modal/OpenFileError.d.ts +4 -0
  280. package/es6/pdf-web-viewer/views/modal/OpenFileError.js +13 -0
  281. package/es6/pdf-web-viewer/views/modal/PasswordForm.d.ts +4 -0
  282. package/es6/pdf-web-viewer/views/modal/PasswordForm.js +54 -0
  283. package/es6/pdf-web-viewer/views/modal/SaveFile.d.ts +4 -0
  284. package/es6/pdf-web-viewer/views/modal/SaveFile.js +10 -0
  285. package/es6/pdf-web-viewer/views/modal/UnsavedChanges.d.ts +4 -0
  286. package/es6/pdf-web-viewer/views/modal/UnsavedChanges.js +32 -0
  287. package/es6/pdf-web-viewer/views/navigation/AnnotationList.d.ts +8 -0
  288. package/es6/pdf-web-viewer/views/navigation/AnnotationList.js +26 -0
  289. package/es6/pdf-web-viewer/views/navigation/AnnotationListItem.d.ts +8 -0
  290. package/es6/pdf-web-viewer/views/navigation/AnnotationListItem.js +158 -0
  291. package/es6/pdf-web-viewer/views/navigation/AnnotationNavigation.d.ts +4 -0
  292. package/es6/pdf-web-viewer/views/navigation/AnnotationNavigation.js +11 -0
  293. package/es6/pdf-web-viewer/views/navigation/NavigationPanel.d.ts +4 -0
  294. package/es6/pdf-web-viewer/views/navigation/NavigationPanel.js +50 -0
  295. package/es6/pdf-web-viewer/views/navigation/OutlineList.d.ts +12 -0
  296. package/es6/pdf-web-viewer/views/navigation/OutlineList.js +19 -0
  297. package/es6/pdf-web-viewer/views/navigation/OutlineNavigation.d.ts +4 -0
  298. package/es6/pdf-web-viewer/views/navigation/OutlineNavigation.js +10 -0
  299. package/es6/pdf-web-viewer/views/navigation/ThumbnailNavigation.d.ts +16 -0
  300. package/es6/pdf-web-viewer/views/navigation/ThumbnailNavigation.js +32 -0
  301. package/package.json +24 -0
  302. package/pdfwebviewer/PdfViewing.data +0 -0
  303. package/pdfwebviewer/PdfViewing_Main.js +1 -0
  304. package/pdfwebviewer/PdfViewing_Main.wasm +0 -0
  305. package/pdfwebviewer/PdfViewing_Worker.js +1 -0
  306. package/pdfwebviewer/PdfViewing_Worker.wasm +0 -0
  307. package/pdfwebviewer/pdf-web-viewer.css +2407 -0
  308. package/pdfwebviewer/pdf-web-viewer.development.js +25955 -0
  309. package/pdfwebviewer/pdf-web-viewer.min.js +1 -0
  310. package/pdfwebviewer/translations.de.json +151 -0
  311. package/pdfwebviewer/translations.en.json +151 -0
  312. package/pdfwebviewer/translations.fr.json +151 -0
  313. package/pdfwebviewer/translations.it.json +151 -0
  314. package/scss/common/_breakpoints.scss +44 -0
  315. package/scss/common/_buttons.scss +42 -0
  316. package/scss/common/_colorpicker.scss +89 -0
  317. package/scss/common/_common.scss +21 -0
  318. package/scss/common/_contextbar.scss +44 -0
  319. package/scss/common/_dropdown.scss +176 -0
  320. package/scss/common/_icon.scss +9 -0
  321. package/scss/common/_index.scss +19 -0
  322. package/scss/common/_loader.scss +30 -0
  323. package/scss/common/_rangeslider.scss +24 -0
  324. package/scss/common/_scrollbars.scss +64 -0
  325. package/scss/common/_stroke-style-picker.scss +64 -0
  326. package/scss/common/_stroke-width-picker.scss +23 -0
  327. package/scss/common/_toolbar.scss +117 -0
  328. package/scss/common/_tooltip.scss +39 -0
  329. package/scss/modules/_eraser.scss +28 -0
  330. package/scss/modules/_forms.scss +56 -0
  331. package/scss/modules/_highlightannotation.scss +12 -0
  332. package/scss/modules/_index.scss +5 -0
  333. package/scss/modules/_inkannotation.scss +41 -0
  334. package/scss/modules/_stampannotation.scss +19 -0
  335. package/scss/pdf-viewer-canvas/_annotationborder.scss +107 -0
  336. package/scss/pdf-viewer-canvas/_busy-loader.scss +53 -0
  337. package/scss/pdf-viewer-canvas/_freetexteditor.scss +28 -0
  338. package/scss/pdf-viewer-canvas/_index.scss +7 -0
  339. package/scss/pdf-viewer-canvas/_layout.scss +52 -0
  340. package/scss/pdf-viewer-canvas/_popup.scss +217 -0
  341. package/scss/pdf-viewer-canvas/_printservice.scss +171 -0
  342. package/scss/pdf-viewer-canvas/_textselection.scss +17 -0
  343. package/scss/pdf-web-viewer/_annotationbar.scss +47 -0
  344. package/scss/pdf-web-viewer/_index.scss +8 -0
  345. package/scss/pdf-web-viewer/_layout.scss +63 -0
  346. package/scss/pdf-web-viewer/_modal.scss +186 -0
  347. package/scss/pdf-web-viewer/_navigationpanel.scss +398 -0
  348. package/scss/pdf-web-viewer/_searchbar.scss +47 -0
  349. package/scss/pdf-web-viewer/_toolbar.scss +134 -0
  350. package/scss/pdf-web-viewer/_viewer.scss +54 -0
  351. package/scss/pdf-web-viewer.scss +1 -0
  352. package/scss/themes/default/_light.scss +32 -0
  353. package/scss/themes/default/_mixins.scss +129 -0
  354. package/scss/themes/default/_theme.scss +161 -0
  355. package/scss/themes/pdf-web-viewer.scss +1 -0
  356. package/umd/pdf-web-viewer.development.js +25955 -0
  357. package/umd/pdf-web-viewer.development.js.map +1 -0
  358. package/umd/pdf-web-viewer.min.js +1 -0
  359. package/wasm/PdfViewing.data +0 -0
  360. package/wasm/PdfViewing_Main.js +1 -0
  361. package/wasm/PdfViewing_Main.wasm +0 -0
  362. package/wasm/PdfViewing_Worker.js +1 -0
  363. package/wasm/PdfViewing_Worker.wasm +0 -0
  364. package/wasm/translations.de.json +151 -0
  365. package/wasm/translations.en.json +151 -0
  366. package/wasm/translations.fr.json +151 -0
  367. package/wasm/translations.it.json +151 -0
@@ -0,0 +1,503 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { CanvasLayer } from '../CanvasLayer';
11
+ import { PdfItemType, AnnotationBorderStyle, } from '../../pdf-viewer-api';
12
+ import { CursorStyle } from '../../pdf-viewer-canvas/state/viewer';
13
+ import { createAddInkAnnotationToolbar, } from './AddInkAnnotationToolbar';
14
+ import { Color } from '../../common/Color';
15
+ const moduleLayerName = 'AddInkAnnotation';
16
+ export class AddInkAnnotationLayer extends CanvasLayer {
17
+ constructor() {
18
+ super(...arguments);
19
+ this.context = null;
20
+ this.drawing = false;
21
+ this.lines = [];
22
+ this.page = null;
23
+ this.zoom = null;
24
+ this.inkWidth = 1;
25
+ this.penColors = [];
26
+ this.penWidths = [];
27
+ this.penColor = '';
28
+ this.penOpacity = 1;
29
+ this.boundingBox = null;
30
+ this.toolbar = null;
31
+ this.currentAnnotation = null;
32
+ this.isUpdatingAnnotation = false;
33
+ this.pendingUpdate = false;
34
+ this.handlePointerMove = (e) => {
35
+ if (!e.isPrimary) {
36
+ this.handlePointerUp(e);
37
+ return;
38
+ }
39
+ const x = e.offsetX * devicePixelRatio;
40
+ const y = e.offsetY * devicePixelRatio;
41
+ const pdfPoint = this.pdfApi.getClosestPointOnPdfByScreenPoint({ x, y }, this.page);
42
+ this.lines[this.lines.length - 1].push(pdfPoint);
43
+ if (this.context) {
44
+ const screenPoint = this.pdfApi.transformPdfPointToScreenPoint(pdfPoint);
45
+ this.context.lineTo(screenPoint.x, screenPoint.y);
46
+ this.context.stroke();
47
+ }
48
+ };
49
+ this.handlePointerUp = (e) => {
50
+ if (this.context) {
51
+ const { canvas } = this.context;
52
+ canvas.removeEventListener('pointermove', this.handlePointerMove);
53
+ canvas.removeEventListener('pointerup', this.handlePointerUp);
54
+ canvas.removeEventListener('pointercancel', this.handlePointerUp);
55
+ }
56
+ this.endLine();
57
+ };
58
+ }
59
+ onCreate() {
60
+ this.setPenColor = this.setPenColor.bind(this);
61
+ this.setPenSize = this.setPenSize.bind(this);
62
+ this.setPenOpacity = this.setPenOpacity.bind(this);
63
+ this.add = this.add.bind(this);
64
+ this.undo = this.undo.bind(this);
65
+ this.save = this.save.bind(this);
66
+ const annotationOptions = this.options.annotation;
67
+ this.context = this.createCanvas();
68
+ this.penColors = annotationOptions.colors.foregroundColors;
69
+ this.penWidths = annotationOptions.strokeWidths;
70
+ this.inkWidth = annotationOptions.inkWidth;
71
+ this.setPenColor(annotationOptions.colors.inkColor);
72
+ this.setPenOpacity(annotationOptions.colors.inkOpacity);
73
+ this.currentAnnotation = null;
74
+ this.store.viewer.beginModule(moduleLayerName);
75
+ /* tslint:disable-next-line:align */
76
+ const toolbarElement = this.module.toolbarElement;
77
+ this.toolbar = createAddInkAnnotationToolbar({
78
+ penColors: this.penColors,
79
+ penWidths: this.penWidths,
80
+ selectedPenColor: annotationOptions.colors.inkColor,
81
+ selectedPenSize: annotationOptions.inkWidth,
82
+ penOpacity: annotationOptions.colors.inkOpacity,
83
+ onPenColorChanged: this.setPenColor,
84
+ onPenSizeChanged: this.setPenSize,
85
+ onPenOpacityChanged: this.setPenOpacity,
86
+ onSave: this.save,
87
+ onUndo: this.undo,
88
+ onAdd: this.add,
89
+ onCancel: this.remove,
90
+ }, toolbarElement);
91
+ }
92
+ onSave() {
93
+ const promise = new Promise((resolve) => {
94
+ this.remove();
95
+ resolve();
96
+ });
97
+ return promise;
98
+ }
99
+ onRemove() {
100
+ this.reset();
101
+ this.removeCanvasElements();
102
+ this.context = null;
103
+ /* tslint:disable-next-line:align */
104
+ const toolbarElement = this.module.toolbarElement;
105
+ toolbarElement.innerHTML = '';
106
+ this.store.viewer.endModule(moduleLayerName);
107
+ }
108
+ render(timestamp, state) {
109
+ if (this.drawing) {
110
+ return;
111
+ }
112
+ if (state.viewer.modeChanged && state.viewer.selectedModuleName !== moduleLayerName) {
113
+ this.remove();
114
+ return;
115
+ }
116
+ if (this.zoom === null || state.document.zoomChanged) {
117
+ this.zoom = state.document.zoom;
118
+ this.drawLines();
119
+ }
120
+ if (state.scroll.leftPositionChanged || state.scroll.topPositionChanged) {
121
+ this.drawLines();
122
+ }
123
+ const pointerPos = {
124
+ x: state.pointer.x.devicePixels,
125
+ y: state.pointer.y.devicePixels,
126
+ };
127
+ const pdfPoint = this.pdfApi.transformScreenPointToPdfPoint(pointerPos);
128
+ if (state.pointer.stateChanged) {
129
+ if (state.pointer.isDown) {
130
+ const page = pdfPoint.isOnPage ? pdfPoint.pdfPoint.page : null;
131
+ if (this.page === null && page) {
132
+ this.page = page;
133
+ }
134
+ if (typeof this.page === 'number' && this.page === page) {
135
+ const pdfPointRes = this.pdfApi.getClosestPointOnPdfByScreenPoint(pointerPos, this.page);
136
+ if (pdfPointRes) {
137
+ this.startLine(pointerPos, pdfPointRes);
138
+ }
139
+ }
140
+ }
141
+ }
142
+ if (state.pointer.positionChanged) {
143
+ if (pdfPoint.isOnPage && (this.page === null || pdfPoint.pdfPoint.page === this.page)) {
144
+ this.store.viewer.setCursorStyle(CursorStyle.CROSSHAIR);
145
+ }
146
+ else {
147
+ this.store.viewer.setCursorStyle(CursorStyle.NOT_ALLOWED);
148
+ }
149
+ }
150
+ }
151
+ startLine(point, pdfPoint) {
152
+ var _a;
153
+ this.lines.push([pdfPoint]);
154
+ this.pdfViewerCanvas.suspendCanvasEvents();
155
+ this.drawing = true;
156
+ if (this.context) {
157
+ const { canvas } = this.context;
158
+ canvas.addEventListener('pointermove', this.handlePointerMove);
159
+ canvas.addEventListener('pointerup', this.handlePointerUp);
160
+ canvas.addEventListener('pointercancel', this.handlePointerUp);
161
+ this.drawLines();
162
+ const ctx = this.context;
163
+ ctx.save();
164
+ ctx.strokeStyle = this.penColor;
165
+ ctx.lineWidth = this.inkWidth * devicePixelRatio * ((_a = this.zoom) !== null && _a !== void 0 ? _a : 1);
166
+ ctx.lineCap = 'round';
167
+ ctx.lineJoin = 'round';
168
+ ctx.moveTo(point.x, point.y);
169
+ }
170
+ }
171
+ endLine() {
172
+ var _a, _b;
173
+ return __awaiter(this, void 0, void 0, function* () {
174
+ this.drawing = false;
175
+ this.pdfViewerCanvas.resumeCanvasEvents();
176
+ (_a = this.context) === null || _a === void 0 ? void 0 : _a.restore();
177
+ this.drawBoundingBox();
178
+ (_b = this.toolbar) === null || _b === void 0 ? void 0 : _b.setLineCount(this.lines.length);
179
+ try {
180
+ yield this.debouncedRecreateInkAnnotation();
181
+ }
182
+ catch (error) {
183
+ console.warn(error);
184
+ }
185
+ });
186
+ }
187
+ drawLines() {
188
+ if (this.context) {
189
+ const ctx = this.context;
190
+ ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
191
+ const annotationOptions = this.options.annotation;
192
+ ctx.save();
193
+ ctx.strokeStyle = this.penColor;
194
+ ctx.lineWidth = this.inkWidth * devicePixelRatio * this.zoom;
195
+ ctx.lineCap = 'round';
196
+ ctx.lineJoin = 'round';
197
+ this.lines.forEach((pointList) => {
198
+ ctx.beginPath();
199
+ const p1 = this.pdfApi.transformPdfPointToScreenPoint(pointList[0]);
200
+ ctx.moveTo(p1.x, p1.y);
201
+ for (let i = 0; i < pointList.length; i++) {
202
+ const p = this.pdfApi.transformPdfPointToScreenPoint(pointList[i]);
203
+ ctx.lineTo(p.x, p.y);
204
+ }
205
+ ctx.stroke();
206
+ });
207
+ ctx.restore();
208
+ }
209
+ }
210
+ drawBoundingBox() {
211
+ if (this.context && this.lines && this.lines.length > 0) {
212
+ const pdfRect = {
213
+ pdfX: 0,
214
+ pdfY: 0,
215
+ pdfW: 0,
216
+ pdfH: 0,
217
+ page: this.page ? this.page : 0,
218
+ };
219
+ let x1 = 1000000000;
220
+ let x2 = 0;
221
+ let y1 = 1000000000;
222
+ let y2 = 0;
223
+ this.lines.forEach((pointList) => {
224
+ const line = [];
225
+ for (let i = 0; i < pointList.length; i++) {
226
+ const p = pointList[i];
227
+ if (p.pdfX < x1) {
228
+ x1 = p.pdfX;
229
+ }
230
+ if (p.pdfX > x2) {
231
+ x2 = p.pdfX;
232
+ }
233
+ if (p.pdfY < y1) {
234
+ y1 = p.pdfY;
235
+ }
236
+ if (p.pdfY > y2) {
237
+ y2 = p.pdfY;
238
+ }
239
+ }
240
+ });
241
+ pdfRect.pdfX = x1;
242
+ pdfRect.pdfY = y1;
243
+ pdfRect.pdfW = x2 - x1;
244
+ pdfRect.pdfH = y2 - y1;
245
+ const rect = this.pdfApi.transformPdfPageRectToScreenRect(pdfRect);
246
+ const ctx = this.context;
247
+ ctx.save();
248
+ ctx.strokeStyle = this.options.viewer.general.textSelectionColor;
249
+ ctx.lineWidth = 1 * devicePixelRatio;
250
+ ctx.setLineDash([2 * devicePixelRatio, 3 * devicePixelRatio]);
251
+ const p = this.inkWidth * devicePixelRatio;
252
+ const p2 = p * 2;
253
+ ctx.strokeRect(rect.x - p, rect.y - p, rect.w + p2, rect.h + p2);
254
+ ctx.restore();
255
+ }
256
+ }
257
+ setPenColor(color) {
258
+ return __awaiter(this, void 0, void 0, function* () {
259
+ this.options.annotation.colors.inkColor = color;
260
+ this.penColor = color;
261
+ this.drawLines();
262
+ this.drawBoundingBox();
263
+ if (this.lines.length > 0) {
264
+ yield this.debouncedRecreateInkAnnotation();
265
+ }
266
+ });
267
+ }
268
+ setPenOpacity(opacity) {
269
+ return __awaiter(this, void 0, void 0, function* () {
270
+ this.options.annotation.colors.inkOpacity = opacity;
271
+ this.penOpacity = opacity;
272
+ if (this.context) {
273
+ this.context.canvas.style.opacity = `${opacity / 100}`;
274
+ }
275
+ this.drawLines();
276
+ this.drawBoundingBox();
277
+ if (this.lines.length > 0) {
278
+ yield this.debouncedRecreateInkAnnotation();
279
+ }
280
+ });
281
+ }
282
+ setPenSize(size) {
283
+ return __awaiter(this, void 0, void 0, function* () {
284
+ this.inkWidth = size;
285
+ this.options.annotation.inkWidth = size;
286
+ this.drawLines();
287
+ this.drawBoundingBox();
288
+ if (this.lines.length > 0) {
289
+ yield this.debouncedRecreateInkAnnotation();
290
+ }
291
+ });
292
+ }
293
+ debouncedRecreateInkAnnotation() {
294
+ return __awaiter(this, void 0, void 0, function* () {
295
+ if (this.isUpdatingAnnotation) {
296
+ this.pendingUpdate = true;
297
+ return;
298
+ }
299
+ this.isUpdatingAnnotation = true;
300
+ this.pendingUpdate = false;
301
+ try {
302
+ yield this.recreateInkAnnotation();
303
+ if (this.pendingUpdate) {
304
+ this.pendingUpdate = false;
305
+ yield this.recreateInkAnnotation();
306
+ }
307
+ }
308
+ catch (error) {
309
+ console.warn(error);
310
+ }
311
+ finally {
312
+ this.isUpdatingAnnotation = false;
313
+ }
314
+ });
315
+ }
316
+ reset() {
317
+ this.lines = [];
318
+ this.page = null;
319
+ this.currentAnnotation = null;
320
+ this.boundingBox = null;
321
+ this.isUpdatingAnnotation = false;
322
+ this.pendingUpdate = false;
323
+ if (this.toolbar) {
324
+ this.toolbar.setLineCount(0);
325
+ }
326
+ }
327
+ save() {
328
+ this.reset();
329
+ this.remove();
330
+ }
331
+ add() {
332
+ this.reset();
333
+ this.drawLines();
334
+ }
335
+ undo() {
336
+ return __awaiter(this, void 0, void 0, function* () {
337
+ if (this.lines && this.lines.length > 0) {
338
+ this.lines.pop();
339
+ if (this.lines.length === 0) {
340
+ if (this.currentAnnotation) {
341
+ try {
342
+ yield this.pdfApi.deleteItem(this.currentAnnotation);
343
+ this.currentAnnotation = null;
344
+ }
345
+ catch (error) {
346
+ console.warn(error);
347
+ }
348
+ }
349
+ this.page = null;
350
+ this.boundingBox = null;
351
+ }
352
+ else {
353
+ this.boundingBox = this.getBoundingBox();
354
+ try {
355
+ yield this.recreateInkAnnotation();
356
+ }
357
+ catch (error) {
358
+ console.warn(error);
359
+ }
360
+ }
361
+ if (this.toolbar) {
362
+ this.toolbar.setLineCount(this.lines.length);
363
+ }
364
+ this.store.canvas.setCanvasInvalidated(true);
365
+ this.drawLines();
366
+ this.drawBoundingBox();
367
+ }
368
+ });
369
+ }
370
+ recreateInkAnnotation() {
371
+ const promise = new Promise((resolve, reject) => {
372
+ if (this.pdfApi && this.page && this.lines && this.lines.length > 0) {
373
+ const oldAnnotation = this.currentAnnotation;
374
+ this.createNewInkAnnotation()
375
+ .then(() => {
376
+ if (oldAnnotation) {
377
+ this.pdfApi
378
+ .deleteItem(oldAnnotation)
379
+ .then(() => {
380
+ resolve();
381
+ })
382
+ .catch((error) => {
383
+ resolve();
384
+ });
385
+ }
386
+ else {
387
+ resolve();
388
+ }
389
+ })
390
+ .catch(reject);
391
+ }
392
+ else {
393
+ resolve();
394
+ }
395
+ });
396
+ return promise;
397
+ }
398
+ createNewInkAnnotation() {
399
+ const promise = new Promise((resolve, reject) => {
400
+ if (this.pdfApi && this.page && this.lines && this.lines.length > 0) {
401
+ const inkList = [];
402
+ let x1 = 1000000000;
403
+ let x2 = 0;
404
+ let y1 = 1000000000;
405
+ let y2 = 0;
406
+ this.lines.forEach((pointList) => {
407
+ const line = [];
408
+ for (let i = 0; i < pointList.length; i++) {
409
+ const p = pointList[i];
410
+ if (p.pdfX < x1) {
411
+ x1 = p.pdfX;
412
+ }
413
+ if (p.pdfX > x2) {
414
+ x2 = p.pdfX;
415
+ }
416
+ if (p.pdfY < y1) {
417
+ y1 = p.pdfY;
418
+ }
419
+ if (p.pdfY > y2) {
420
+ y2 = p.pdfY;
421
+ }
422
+ line.push(p.pdfX);
423
+ line.push(p.pdfY);
424
+ }
425
+ inkList.push(line);
426
+ });
427
+ const rgbaColor = new Color(this.options.annotation.colors.inkColor);
428
+ rgbaColor.setOpacity(this.options.annotation.colors.inkOpacity / 100);
429
+ const inkAnnotation = {
430
+ itemType: PdfItemType.INK,
431
+ page: this.page,
432
+ pdfRect: {
433
+ pdfX: x1,
434
+ pdfY: y1,
435
+ pdfW: x2 - x1,
436
+ pdfH: y2 - y1,
437
+ page: this.page,
438
+ },
439
+ color: rgbaColor.toRgba(),
440
+ author: this.options.viewer.general.user,
441
+ border: {
442
+ style: AnnotationBorderStyle.SOLID,
443
+ width: this.options.annotation.inkWidth,
444
+ },
445
+ inkList,
446
+ };
447
+ this.pdfApi
448
+ .createItem(inkAnnotation)
449
+ .then((item) => {
450
+ this.currentAnnotation = item;
451
+ this.onAnnotationCreated(this.currentAnnotation);
452
+ resolve();
453
+ })
454
+ .catch((error) => {
455
+ console.warn(error);
456
+ reject(error);
457
+ });
458
+ }
459
+ else {
460
+ resolve();
461
+ }
462
+ });
463
+ return promise;
464
+ }
465
+ getBoundingBox() {
466
+ const pdfRect = {
467
+ pdfX: 0,
468
+ pdfY: 0,
469
+ pdfW: 0,
470
+ pdfH: 0,
471
+ page: this.page ? this.page : 0,
472
+ };
473
+ if (this.lines && this.lines.length > 0) {
474
+ let x1 = 1000000000;
475
+ let x2 = 0;
476
+ let y1 = 1000000000;
477
+ let y2 = 0;
478
+ this.lines.forEach((pointList) => {
479
+ const line = [];
480
+ for (let i = 0; i < pointList.length; i++) {
481
+ const p = pointList[i];
482
+ if (p.pdfX < x1) {
483
+ x1 = p.pdfX;
484
+ }
485
+ if (p.pdfX > x2) {
486
+ x2 = p.pdfX;
487
+ }
488
+ if (p.pdfY < y1) {
489
+ y1 = p.pdfY;
490
+ }
491
+ if (p.pdfY > y2) {
492
+ y2 = p.pdfY;
493
+ }
494
+ }
495
+ });
496
+ pdfRect.pdfX = x1;
497
+ pdfRect.pdfY = y1;
498
+ pdfRect.pdfW = x2 - x1;
499
+ pdfRect.pdfH = y2 - y1;
500
+ }
501
+ return pdfRect;
502
+ }
503
+ }
@@ -0,0 +1,30 @@
1
+ export interface AddInkAnnotationToolbarProps {
2
+ penColors: string[];
3
+ penWidths: number[];
4
+ selectedPenColor: string;
5
+ selectedPenSize: number;
6
+ penOpacity: number;
7
+ onPenColorChanged(color: string): void;
8
+ onPenSizeChanged(width: number): void;
9
+ onPenOpacityChanged(width: number): void;
10
+ onUndo(): void;
11
+ onCancel(): void;
12
+ onSave(): void;
13
+ onAdd(): void;
14
+ }
15
+ interface AddInkAnnotationToolbarState {
16
+ penColors: string[];
17
+ penWidths: number[];
18
+ selectedPenColor: string;
19
+ selectedPenSize: number;
20
+ penOpacity: number;
21
+ lineCount: number;
22
+ }
23
+ export interface AddInkAnnotationToolbarActions {
24
+ setPenColor(color: string): AddInkAnnotationToolbarState;
25
+ setPenSize(size: number): AddInkAnnotationToolbarState;
26
+ setPenOpacity(opacity: number): AddInkAnnotationToolbarState;
27
+ setLineCount(lineCount: number): AddInkAnnotationToolbarState;
28
+ }
29
+ export declare const createAddInkAnnotationToolbar: (props: AddInkAnnotationToolbarProps, element: HTMLElement) => AddInkAnnotationToolbarActions;
30
+ export {};
@@ -0,0 +1,53 @@
1
+ import { app, h } from '../../lib/hyperapp';
2
+ import { translationManager } from '../../common/TranslationManager';
3
+ import { Toolbar } from '../../common/Toolbar';
4
+ import { ToolbarItemGroup } from '../../common/ToolbarItemGroup';
5
+ import { ToolbarButton } from '../../common/ToolbarButton';
6
+ import { icons } from '../../common/icons';
7
+ import { ToolbarSeparator } from '../../common/ToolbarSeparator';
8
+ import { StrokeWidthPicker } from '../../common/StrokeWidthPicker';
9
+ import { RangeSlider } from '../../common/RangeSlider';
10
+ import { ColorPicker } from '../../common/ColorPicker';
11
+ export const createAddInkAnnotationToolbar = (props, element) => {
12
+ const state = {
13
+ penColors: props.penColors,
14
+ penWidths: props.penWidths,
15
+ selectedPenColor: props.selectedPenColor,
16
+ selectedPenSize: props.selectedPenSize,
17
+ penOpacity: props.penOpacity,
18
+ lineCount: 0,
19
+ };
20
+ const actions = {
21
+ setPenColor: (color) => ($state) => {
22
+ props.onPenColorChanged(color);
23
+ return Object.assign(Object.assign({}, $state), { selectedPenColor: color });
24
+ },
25
+ setPenSize: (width) => ($state) => {
26
+ props.onPenSizeChanged(width);
27
+ return Object.assign(Object.assign({}, $state), { selectedPenSize: width });
28
+ },
29
+ setPenOpacity: (opacity) => ($state) => {
30
+ props.onPenOpacityChanged(opacity);
31
+ return Object.assign(Object.assign({}, $state), { penOpacity: opacity });
32
+ },
33
+ setLineCount: (lineCount) => ($state) => (Object.assign(Object.assign({}, $state), { lineCount })),
34
+ };
35
+ const App = () => h(AddInkAnnotationToolbar, null);
36
+ const AddInkAnnotationToolbar = ({}) => ($state, $actions) => {
37
+ const strokeWidths = $state.penWidths.filter((w) => w > 0);
38
+ return (h(Toolbar, { allowWrap: true, alignCenter: true },
39
+ h(ToolbarItemGroup, null,
40
+ h(ColorPicker, { colors: $state.penColors, color: $state.selectedPenColor, icon: icons.fillColor, allowRgba: false, mode: "buttons", onChange: $actions.setPenColor })),
41
+ h(ToolbarItemGroup, null,
42
+ h(RangeSlider, { tooltip: translationManager.getText('annotFreeDrawing.opacity'), min: 10, max: 100, step: 1, value: $state.penOpacity, text: `${$state.penOpacity}%`, icon: icons.drop, onChange: $actions.setPenOpacity, className: "pwv-opacityslider" }),
43
+ h(StrokeWidthPicker, { tooltip: translationManager.getText('annotFreeDrawing.strokeWidth'), noneStrokeText: '', strokeWidths: strokeWidths, value: $state.selectedPenSize, onChange: $actions.setPenSize })),
44
+ h(ToolbarItemGroup, null,
45
+ h(ToolbarSeparator, null),
46
+ h(ToolbarButton, { tooltip: translationManager.getText('annotFreeDrawing.undo'), icon: icons.eraser, onClick: props.onUndo, disabled: $state.lineCount < 1 }),
47
+ h(ToolbarButton, { tooltip: translationManager.getText('annotFreeDrawing.addNew'), icon: icons.addLayer, onClick: props.onAdd, disabled: $state.lineCount < 1 })),
48
+ h(ToolbarItemGroup, { pushRight: true },
49
+ h(ToolbarSeparator, null),
50
+ $state.lineCount < 1 ? (h(ToolbarButton, { icon: icons.close, onClick: props.onCancel })) : (h(ToolbarButton, { icon: icons.ok, onClick: props.onSave })))));
51
+ };
52
+ return app(state, actions, App, element);
53
+ };
@@ -0,0 +1,20 @@
1
+ import { CanvasLayer } from '../CanvasLayer';
2
+ import { ViewerCanvasState } from '../../pdf-viewer-canvas/state/store';
3
+ export declare class EditInkAnnotationLayer extends CanvasLayer {
4
+ private inkAnnotation;
5
+ private context;
6
+ private penColors;
7
+ private penWidths;
8
+ private toolbar;
9
+ private updatePending;
10
+ private unsavedChanges;
11
+ onCreate(annotationId: number): void;
12
+ onSave(): Promise<void>;
13
+ onRemove(): void;
14
+ render(timestamp: number, state: ViewerCanvasState): void;
15
+ private close;
16
+ private setPenColor;
17
+ private setPenSize;
18
+ private setPenOpacity;
19
+ private updateInkAnnotation;
20
+ }