@vertexvis/viewer 0.13.2-canary.9 → 0.14.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 (323) hide show
  1. package/dist/cjs/{_commonjsHelpers-537d719a.js → _commonjsHelpers-dcc4cf71.js} +21 -0
  2. package/dist/cjs/{app-globals-3671e828.js → app-globals-2035678d.js} +1 -1
  3. package/dist/cjs/{browser.esm-075810bf.js → browser.esm-0bcdc581.js} +1 -1
  4. package/dist/cjs/{bundle.esm-618a5fe9.js → bundle.esm-22b6f2d6.js} +35 -1
  5. package/dist/cjs/{config-fb124bac.js → config-c63caa4f.js} +3 -2
  6. package/dist/cjs/{cursors-d71f6a74.js → cursors-f5d3c9a6.js} +13 -1
  7. package/dist/cjs/{dom-57ef84e9.js → dom-8d90bfaf.js} +1 -1
  8. package/dist/cjs/dom-d1bbd67c.js +10 -0
  9. package/dist/cjs/elementRectObserver-9b28f182.js +25 -0
  10. package/dist/cjs/entities-9eb7e608.js +41 -0
  11. package/dist/cjs/{entities-90f1347a.js → entities-e71231d8.js} +4 -4
  12. package/dist/cjs/{grpc-web-client.umd-60a79aae.js → grpc-web-client.umd-2af20c1b.js} +1 -1
  13. package/dist/cjs/{index-e100709a.js → index-4138aa2c.js} +1 -0
  14. package/dist/cjs/{index-3bc6bac0.js → index-b9d13137.js} +1 -1
  15. package/dist/cjs/index.cjs.js +25 -22
  16. package/dist/cjs/loader.cjs.js +4 -4
  17. package/dist/cjs/{mapper-80ee2957.js → mapper-08bbab48.js} +4 -4
  18. package/dist/cjs/{markup-7f7de5f2.js → markup-f7e61d16.js} +2 -2
  19. package/dist/cjs/{measurement-f1ae9248.js → measurement-3367e9b7.js} +2 -2
  20. package/dist/cjs/{model-55abd9ab.js → model-5ca87867.js} +1 -1
  21. package/dist/cjs/model-a9cfd037.js +246 -0
  22. package/dist/cjs/{overlays-68e8eff2.js → overlays-b0ba69fd.js} +2 -2
  23. package/dist/cjs/{png-decoder-076131d8.js → png-decoder-ef097f37.js} +2 -2
  24. package/dist/cjs/{results-e9496869.js → results-178e89a3.js} +1 -1
  25. package/dist/cjs/{scene-92728420.js → scene-b6b78909.js} +49 -12
  26. package/dist/cjs/{stencil-a664cd10.js → stencil-ef19638e.js} +5 -1
  27. package/dist/cjs/{streamAttributes-81eb52f2.js → streamAttributes-c343bdc8.js} +1993 -78
  28. package/dist/cjs/utils-78928e4e.js +162 -0
  29. package/dist/cjs/{utils-6397efca.js → utils-b157b0af.js} +1 -1
  30. package/dist/cjs/{utils-463cd52e.js → utils-c74b8bf0.js} +1 -1
  31. package/dist/cjs/vertex-scene-tree-search_3.cjs.entry.js +16 -6
  32. package/dist/cjs/vertex-scene-tree-table-cell.cjs.entry.js +16 -14
  33. package/dist/cjs/vertex-scene-tree-table-column.cjs.entry.js +1 -1
  34. package/dist/cjs/vertex-scene-tree-table-header.cjs.entry.js +1 -1
  35. package/dist/cjs/vertex-scene-tree-table-resize-divider.cjs.entry.js +3 -3
  36. package/dist/cjs/vertex-scene-tree-toolbar-group.cjs.entry.js +1 -1
  37. package/dist/cjs/vertex-scene-tree.cjs.entry.js +154 -27
  38. package/dist/cjs/vertex-viewer-button_3.cjs.entry.js +3 -3
  39. package/dist/cjs/vertex-viewer-default-toolbar.cjs.entry.js +1 -1
  40. package/dist/cjs/{vertex-viewer-dom-element_3.cjs.entry.js → vertex-viewer-dom-element_2.cjs.entry.js} +20 -178
  41. package/dist/cjs/vertex-viewer-dom-group.cjs.entry.js +191 -0
  42. package/dist/cjs/vertex-viewer-icon.cjs.entry.js +6 -3
  43. package/dist/cjs/vertex-viewer-layer.cjs.entry.js +1 -1
  44. package/dist/cjs/vertex-viewer-markup-arrow_3.cjs.entry.js +49 -196
  45. package/dist/cjs/vertex-viewer-markup-tool.cjs.entry.js +5 -5
  46. package/dist/cjs/vertex-viewer-markup.cjs.entry.js +5 -5
  47. package/dist/cjs/vertex-viewer-measurement-details.cjs.entry.js +8 -7
  48. package/dist/cjs/vertex-viewer-measurement-distance.cjs.entry.js +16 -15
  49. package/dist/cjs/vertex-viewer-measurement-line_2.cjs.entry.js +10 -9
  50. package/dist/cjs/vertex-viewer-measurement-precise.cjs.entry.js +18 -35
  51. package/dist/cjs/vertex-viewer-measurement-tool.cjs.entry.js +8 -7
  52. package/dist/cjs/vertex-viewer-measurements.cjs.entry.js +12 -11
  53. package/dist/cjs/vertex-viewer-pin-group.cjs.entry.js +167 -0
  54. package/dist/cjs/vertex-viewer-pin-label_2.cjs.entry.js +276 -0
  55. package/dist/cjs/vertex-viewer-pin-tool.cjs.entry.js +322 -0
  56. package/dist/cjs/vertex-viewer-transform-widget.cjs.entry.js +13272 -0
  57. package/dist/cjs/vertex-viewer-view-cube.cjs.entry.js +8 -7
  58. package/dist/cjs/vertex-viewer.cjs.entry.js +119 -52
  59. package/dist/cjs/viewer.cjs.js +4 -4
  60. package/dist/cjs/{viewport-54b1389d.js → viewport-5ca619f7.js} +14 -4
  61. package/dist/collection/__mocks__/regl-shape.js +6 -0
  62. package/dist/collection/__mocks__/regl.js +3 -0
  63. package/dist/collection/collection-manifest.json +5 -0
  64. package/dist/collection/components/scene-tree/lib/controller.js +17 -5
  65. package/dist/collection/components/scene-tree/lib/errors.js +7 -1
  66. package/dist/collection/components/scene-tree/lib/viewer-ops.js +12 -1
  67. package/dist/collection/components/scene-tree/scene-tree.js +112 -22
  68. package/dist/collection/components/scene-tree-table-cell/scene-tree-table-cell.css +0 -7
  69. package/dist/collection/components/scene-tree-table-cell/scene-tree-table-cell.js +34 -12
  70. package/dist/collection/components/scene-tree-table-layout/scene-tree-table-layout.js +14 -2
  71. package/dist/collection/components/viewer/viewer.js +79 -14
  72. package/dist/collection/components/viewer-dom-element/viewer-dom-element.js +32 -4
  73. package/dist/collection/components/viewer-dom-group/utils.js +3 -2
  74. package/dist/collection/components/viewer-dom-group/viewer-dom-group.js +30 -2
  75. package/dist/collection/components/viewer-icon/viewer-icon.js +5 -2
  76. package/dist/collection/components/viewer-markup/utils.js +3 -2
  77. package/dist/collection/components/viewer-measurement-details/viewer-measurement-details-results.js +2 -2
  78. package/dist/collection/components/viewer-pin-group/pin-renderer.js +12 -0
  79. package/dist/collection/components/viewer-pin-group/utils.js +24 -0
  80. package/dist/collection/components/viewer-pin-group/viewer-pin-group.css +83 -0
  81. package/dist/collection/components/viewer-pin-group/viewer-pin-group.js +276 -0
  82. package/dist/collection/components/viewer-pin-label/utils.js +4 -0
  83. package/dist/collection/components/viewer-pin-label/viewer-pin-label.css +154 -0
  84. package/dist/collection/components/viewer-pin-label/viewer-pin-label.js +410 -0
  85. package/dist/collection/components/viewer-pin-label-line/viewer-pin-label-line.css +36 -0
  86. package/dist/collection/components/viewer-pin-label-line/viewer-pin-label-line.js +61 -0
  87. package/dist/collection/components/viewer-pin-tool/viewer-pin-tool.css +9 -0
  88. package/dist/collection/components/viewer-pin-tool/viewer-pin-tool.js +277 -0
  89. package/dist/collection/components/viewer-transform-widget/__mocks__/widget.js +21 -0
  90. package/dist/collection/components/viewer-transform-widget/util.js +78 -0
  91. package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.css +48 -0
  92. package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.js +442 -0
  93. package/dist/collection/components/viewer-transform-widget/widget.js +259 -0
  94. package/dist/collection/lib/cursors.js +11 -1
  95. package/dist/collection/lib/interactions/baseInteractionHandler.js +9 -2
  96. package/dist/collection/lib/interactions/flyToPositionKeyInteraction.js +4 -3
  97. package/dist/collection/lib/interactions/interactionApi.js +21 -1
  98. package/dist/collection/lib/interactions/interactionApiOrthographic.js +18 -1
  99. package/dist/collection/lib/interactions/mouseInteractionHandler.js +4 -4
  100. package/dist/collection/lib/interactions/mouseInteractions.js +24 -1
  101. package/dist/collection/lib/interactions/multiTouchInteractionHandler.js +1 -2
  102. package/dist/collection/lib/interactions/pointerInteractionHandler.js +3 -3
  103. package/dist/collection/lib/mappers/streamAttributes.js +4 -2
  104. package/dist/collection/lib/pins/controller.js +100 -0
  105. package/dist/collection/lib/pins/interactions.js +183 -0
  106. package/dist/collection/lib/pins/model.js +136 -0
  107. package/dist/collection/lib/rendering/canvas.js +6 -28
  108. package/dist/collection/lib/scenes/camera.js +34 -2
  109. package/dist/collection/lib/scenes/colorMaterial.js +8 -8
  110. package/dist/collection/lib/scenes/mapper.js +2 -1
  111. package/dist/collection/lib/scenes/queries.js +6 -4
  112. package/dist/collection/lib/transforms/axis-lines.js +31 -0
  113. package/dist/collection/lib/transforms/axis-rotation.js +34 -0
  114. package/dist/collection/lib/transforms/axis-translation.js +30 -0
  115. package/dist/collection/lib/transforms/controller.js +117 -0
  116. package/dist/collection/lib/transforms/drawable.js +47 -0
  117. package/dist/collection/lib/transforms/hits.js +51 -0
  118. package/dist/collection/lib/transforms/line.js +58 -0
  119. package/dist/collection/lib/transforms/mesh.js +35 -0
  120. package/dist/collection/lib/transforms/shape.js +2 -0
  121. package/dist/collection/lib/transforms/util.js +4 -0
  122. package/dist/collection/lib/types/depthBuffer.js +2 -2
  123. package/dist/collection/lib/types/frameCamera.js +4 -6
  124. package/dist/collection/lib/types/viewport.js +14 -4
  125. package/dist/custom-elements/index.d.ts +30 -0
  126. package/dist/custom-elements/index.js +16835 -335
  127. package/dist/esm/{_commonjsHelpers-9943807e.js → _commonjsHelpers-11ca3be1.js} +20 -1
  128. package/dist/esm/{app-globals-3a04a531.js → app-globals-40df99a0.js} +1 -1
  129. package/dist/esm/{browser.esm-e72d80ad.js → browser.esm-1ddb69c9.js} +1 -1
  130. package/dist/esm/{bundle.esm-8ceccb91.js → bundle.esm-ce2c7ad3.js} +36 -2
  131. package/dist/esm/{config-fb7cd8ff.js → config-7075833a.js} +3 -2
  132. package/dist/esm/{cursors-fc2deed7.js → cursors-98b7d89d.js} +12 -2
  133. package/dist/esm/{dom-2cd18856.js → dom-5b164305.js} +1 -1
  134. package/dist/esm/dom-be140992.js +8 -0
  135. package/dist/esm/elementRectObserver-39cf7b95.js +23 -0
  136. package/dist/esm/{entities-78557270.js → entities-46be90d5.js} +4 -4
  137. package/dist/esm/entities-ce81dd7f.js +41 -0
  138. package/dist/esm/{grpc-web-client.umd-5982b7b0.js → grpc-web-client.umd-5409853c.js} +1 -1
  139. package/dist/esm/{index-10c1495a.js → index-a9fb8318.js} +1 -1
  140. package/dist/esm/{index-455380d0.js → index-e841d91b.js} +1 -1
  141. package/dist/esm/index.js +15 -14
  142. package/dist/esm/index.mjs +15 -14
  143. package/dist/esm/loader.js +4 -4
  144. package/dist/esm/loader.mjs +4 -4
  145. package/dist/esm/{mapper-da36de17.js → mapper-bde6c607.js} +4 -4
  146. package/dist/esm/{markup-c313d99c.js → markup-8904f2fe.js} +2 -2
  147. package/dist/esm/{measurement-544b69d5.js → measurement-3f9b0ae0.js} +2 -2
  148. package/dist/esm/{model-2a34b443.js → model-e54b081f.js} +1 -1
  149. package/dist/esm/model-f679c493.js +241 -0
  150. package/dist/esm/{overlays-354e275c.js → overlays-ea2d45ec.js} +2 -2
  151. package/dist/esm/{png-decoder-07de80d1.js → png-decoder-d4b65417.js} +2 -2
  152. package/dist/esm/{results-4d0c3568.js → results-3b4df2cf.js} +1 -1
  153. package/dist/esm/{scene-2bfcce74.js → scene-22ebacfd.js} +49 -12
  154. package/dist/esm/{stencil-9bf7fb9e.js → stencil-8b20e5a8.js} +5 -2
  155. package/dist/esm/{streamAttributes-d0b384b3.js → streamAttributes-72a92676.js} +1982 -67
  156. package/dist/esm/{utils-3ea0acdd.js → utils-0b980078.js} +1 -1
  157. package/dist/esm/utils-c714e2f7.js +153 -0
  158. package/dist/esm/{utils-e0941c61.js → utils-f11bd6f7.js} +1 -1
  159. package/dist/esm/vertex-scene-tree-search_3.entry.js +16 -6
  160. package/dist/esm/vertex-scene-tree-table-cell.entry.js +16 -14
  161. package/dist/esm/vertex-scene-tree-table-column.entry.js +1 -1
  162. package/dist/esm/vertex-scene-tree-table-header.entry.js +1 -1
  163. package/dist/esm/vertex-scene-tree-table-resize-divider.entry.js +3 -3
  164. package/dist/esm/vertex-scene-tree-toolbar-group.entry.js +1 -1
  165. package/dist/esm/vertex-scene-tree.entry.js +154 -27
  166. package/dist/esm/vertex-viewer-button_3.entry.js +3 -3
  167. package/dist/esm/vertex-viewer-default-toolbar.entry.js +1 -1
  168. package/dist/esm/{vertex-viewer-dom-element_3.entry.js → vertex-viewer-dom-element_2.entry.js} +21 -178
  169. package/dist/esm/vertex-viewer-dom-group.entry.js +187 -0
  170. package/dist/esm/vertex-viewer-icon.entry.js +6 -3
  171. package/dist/esm/vertex-viewer-layer.entry.js +1 -1
  172. package/dist/esm/vertex-viewer-markup-arrow_3.entry.js +8 -155
  173. package/dist/esm/vertex-viewer-markup-tool.entry.js +5 -5
  174. package/dist/esm/vertex-viewer-markup.entry.js +5 -5
  175. package/dist/esm/vertex-viewer-measurement-details.entry.js +8 -7
  176. package/dist/esm/vertex-viewer-measurement-distance.entry.js +16 -15
  177. package/dist/esm/vertex-viewer-measurement-line_2.entry.js +10 -9
  178. package/dist/esm/vertex-viewer-measurement-precise.entry.js +15 -32
  179. package/dist/esm/vertex-viewer-measurement-tool.entry.js +8 -7
  180. package/dist/esm/vertex-viewer-measurements.entry.js +12 -11
  181. package/dist/esm/vertex-viewer-pin-group.entry.js +163 -0
  182. package/dist/esm/vertex-viewer-pin-label_2.entry.js +271 -0
  183. package/dist/esm/vertex-viewer-pin-tool.entry.js +318 -0
  184. package/dist/esm/vertex-viewer-transform-widget.entry.js +13268 -0
  185. package/dist/esm/vertex-viewer-view-cube.entry.js +8 -7
  186. package/dist/esm/vertex-viewer.entry.js +118 -51
  187. package/dist/esm/viewer.js +4 -4
  188. package/dist/esm/{viewport-5cc7b128.js → viewport-e39e2eba.js} +14 -4
  189. package/dist/types/__mocks__/regl-shape.d.ts +5 -0
  190. package/dist/types/__mocks__/regl.d.ts +5 -0
  191. package/dist/types/components/scene-tree/lib/controller.d.ts +13 -1
  192. package/dist/types/components/scene-tree/lib/errors.d.ts +3 -1
  193. package/dist/types/components/scene-tree/lib/viewer-ops.d.ts +1 -0
  194. package/dist/types/components/scene-tree/scene-tree.d.ts +16 -4
  195. package/dist/types/components/scene-tree-table-cell/scene-tree-table-cell.d.ts +6 -2
  196. package/dist/types/components/scene-tree-table-layout/scene-tree-table-layout.d.ts +2 -0
  197. package/dist/types/components/viewer/viewer.d.ts +13 -1
  198. package/dist/types/components/viewer-dom-element/viewer-dom-element.d.ts +10 -2
  199. package/dist/types/components/viewer-dom-group/viewer-dom-group.d.ts +9 -1
  200. package/dist/types/components/viewer-icon/viewer-icon.d.ts +1 -1
  201. package/dist/types/components/viewer-pin-group/pin-renderer.d.ts +8 -0
  202. package/dist/types/components/viewer-pin-group/utils.d.ts +2 -0
  203. package/dist/types/components/viewer-pin-group/viewer-pin-group.d.ts +49 -0
  204. package/dist/types/components/viewer-pin-label/utils.d.ts +1 -0
  205. package/dist/types/components/viewer-pin-label/viewer-pin-label.d.ts +77 -0
  206. package/dist/types/components/viewer-pin-label-line/viewer-pin-label-line.d.ts +7 -0
  207. package/dist/types/components/viewer-pin-tool/viewer-pin-tool.d.ts +68 -0
  208. package/dist/types/components/viewer-transform-widget/__mocks__/widget.d.ts +11 -0
  209. package/dist/types/components/viewer-transform-widget/util.d.ts +5 -0
  210. package/dist/types/components/viewer-transform-widget/viewer-transform-widget.d.ts +81 -0
  211. package/dist/types/components/viewer-transform-widget/widget.d.ts +74 -0
  212. package/dist/types/components.d.ts +303 -12
  213. package/dist/types/interfaces.d.ts +1 -0
  214. package/dist/types/lib/cursors.d.ts +10 -0
  215. package/dist/types/lib/interactions/baseInteractionHandler.d.ts +4 -3
  216. package/dist/types/lib/interactions/interactionApi.d.ts +10 -1
  217. package/dist/types/lib/interactions/interactionApiOrthographic.d.ts +7 -0
  218. package/dist/types/lib/interactions/mouseInteractionHandler.d.ts +2 -2
  219. package/dist/types/lib/interactions/mouseInteractions.d.ts +6 -0
  220. package/dist/types/lib/pins/controller.d.ts +70 -0
  221. package/dist/types/lib/pins/interactions.d.ts +30 -0
  222. package/dist/types/lib/pins/model.d.ts +104 -0
  223. package/dist/types/lib/rendering/canvas.d.ts +1 -2
  224. package/dist/types/lib/scenes/camera.d.ts +10 -0
  225. package/dist/types/lib/scenes/colorMaterial.d.ts +1 -0
  226. package/dist/types/lib/scenes/queries.d.ts +4 -2
  227. package/dist/types/lib/transforms/axis-lines.d.ts +6 -0
  228. package/dist/types/lib/transforms/axis-rotation.d.ts +6 -0
  229. package/dist/types/lib/transforms/axis-translation.d.ts +6 -0
  230. package/dist/types/lib/transforms/controller.d.ts +17 -0
  231. package/dist/types/lib/transforms/drawable.d.ts +26 -0
  232. package/dist/types/lib/transforms/hits.d.ts +10 -0
  233. package/dist/types/lib/transforms/line.d.ts +31 -0
  234. package/dist/types/lib/transforms/mesh.d.ts +23 -0
  235. package/dist/types/lib/transforms/shape.d.ts +3 -0
  236. package/dist/types/lib/transforms/util.d.ts +2 -0
  237. package/dist/types/lib/types/frameCamera.d.ts +1 -0
  238. package/dist/types/lib/types/viewport.d.ts +8 -0
  239. package/dist/types/regl-shape.d.ts +26 -0
  240. package/dist/viewer/index.esm.js +1 -1
  241. package/dist/viewer/p-058632f4.js +4 -0
  242. package/dist/viewer/p-07aeee89.js +10 -0
  243. package/dist/viewer/{p-e75bba97.js → p-083f427e.js} +1 -1
  244. package/dist/viewer/{p-a455ae02.entry.js → p-08eda2b2.entry.js} +1 -1
  245. package/dist/viewer/{p-bcb66f97.js → p-096e60bd.js} +1 -1
  246. package/dist/viewer/p-0bc4b3f7.js +4 -0
  247. package/dist/viewer/p-148c5f1a.js +4 -0
  248. package/dist/viewer/p-1db9bd1a.entry.js +4 -0
  249. package/dist/viewer/{p-70ca1ea7.entry.js → p-1f251549.entry.js} +1 -1
  250. package/dist/viewer/p-29986489.js +4 -0
  251. package/dist/viewer/{p-cafa57a6.js → p-2e581b2a.js} +1 -1
  252. package/dist/viewer/{p-d2bcf788.entry.js → p-33daeb09.entry.js} +1 -1
  253. package/dist/viewer/p-39803f8f.js +4 -0
  254. package/dist/viewer/p-465a92d9.entry.js +4 -0
  255. package/dist/viewer/p-4a65ddb3.entry.js +4 -0
  256. package/dist/viewer/{p-099fe6ca.entry.js → p-4aaf02b4.entry.js} +1 -1
  257. package/dist/viewer/{p-31658489.entry.js → p-4c3a3738.entry.js} +1 -1
  258. package/dist/viewer/{p-e38458da.js → p-4d37d97c.js} +1 -1
  259. package/dist/viewer/p-4fdf8553.entry.js +4 -0
  260. package/dist/viewer/p-5679f46b.entry.js +4 -0
  261. package/dist/viewer/p-5809b400.js +4 -0
  262. package/dist/viewer/{p-fa9a0bed.js → p-58dacdce.js} +1 -1
  263. package/dist/viewer/p-61a042f0.entry.js +4 -0
  264. package/dist/viewer/{p-b8774c9c.js → p-6c377932.js} +1 -1
  265. package/dist/viewer/p-6d379d4a.js +4 -0
  266. package/dist/viewer/p-6d70b198.entry.js +4 -0
  267. package/dist/viewer/p-6e7e094a.entry.js +4 -0
  268. package/dist/viewer/{p-661f0612.js → p-70e5e8a8.js} +1 -1
  269. package/dist/viewer/p-74102b29.entry.js +32 -0
  270. package/dist/viewer/p-7a5a9a93.entry.js +4 -0
  271. package/dist/viewer/p-7c755e0e.entry.js +4 -0
  272. package/dist/viewer/{p-3a20a038.js → p-92fe4417.js} +1 -1
  273. package/dist/viewer/{p-7e0328aa.js → p-98e6a50e.js} +1 -1
  274. package/dist/viewer/{p-388a43f7.js → p-990f98c2.js} +1 -1
  275. package/dist/viewer/{p-487e054a.js → p-99352cf0.js} +1 -1
  276. package/dist/viewer/{p-1ca95f9a.entry.js → p-99799a71.entry.js} +1 -1
  277. package/dist/viewer/p-9acd1b44.js +4 -0
  278. package/dist/viewer/{p-69058178.js → p-9bcde9c8.js} +1 -1
  279. package/dist/viewer/{p-5b342e97.js → p-a2ef15e5.js} +1 -1
  280. package/dist/viewer/{p-61b1097b.entry.js → p-a32cc378.entry.js} +1 -1
  281. package/dist/viewer/p-a380f0c2.js +4 -0
  282. package/dist/viewer/{p-41028d3b.entry.js → p-af37b63e.entry.js} +1 -1
  283. package/dist/viewer/p-b6b727a6.entry.js +4 -0
  284. package/dist/viewer/p-c2e3312b.js +4 -0
  285. package/dist/viewer/{p-4717c98e.entry.js → p-c9f91798.entry.js} +1 -1
  286. package/dist/viewer/p-ca518dcb.entry.js +4 -0
  287. package/dist/viewer/p-d828fd18.entry.js +4 -0
  288. package/dist/viewer/p-d996b1d2.entry.js +4 -0
  289. package/dist/viewer/{p-3f0f83ad.js → p-db01460a.js} +1 -1
  290. package/dist/viewer/p-db716103.entry.js +4 -0
  291. package/dist/viewer/p-df8fbe56.js +4 -0
  292. package/dist/viewer/p-dfe5a97d.js +4 -0
  293. package/dist/viewer/p-e42cb163.js +4 -0
  294. package/dist/viewer/p-eb8e5db5.js +4 -0
  295. package/dist/viewer/{p-46459921.entry.js → p-ebb801c3.entry.js} +1 -1
  296. package/dist/viewer/p-ebd85d58.entry.js +4 -0
  297. package/dist/viewer/p-eefae62a.entry.js +4 -0
  298. package/dist/viewer/viewer.esm.js +1 -1
  299. package/package.json +12 -10
  300. package/readme.md +4 -4
  301. package/dist/viewer/p-0a189e62.entry.js +0 -4
  302. package/dist/viewer/p-112455b1.js +0 -4
  303. package/dist/viewer/p-3561d910.js +0 -4
  304. package/dist/viewer/p-49d36e94.entry.js +0 -4
  305. package/dist/viewer/p-73a5eacc.entry.js +0 -4
  306. package/dist/viewer/p-77be081a.js +0 -4
  307. package/dist/viewer/p-809d09d9.js +0 -4
  308. package/dist/viewer/p-858bd2c7.entry.js +0 -4
  309. package/dist/viewer/p-89b66838.entry.js +0 -32
  310. package/dist/viewer/p-90bb0a1f.entry.js +0 -4
  311. package/dist/viewer/p-a93a63a9.js +0 -4
  312. package/dist/viewer/p-b043b076.entry.js +0 -4
  313. package/dist/viewer/p-b0ac6b3c.entry.js +0 -4
  314. package/dist/viewer/p-bcde5521.entry.js +0 -4
  315. package/dist/viewer/p-d1584404.js +0 -4
  316. package/dist/viewer/p-d32b54cb.js +0 -4
  317. package/dist/viewer/p-d3a20af4.entry.js +0 -4
  318. package/dist/viewer/p-d9f99f4d.entry.js +0 -4
  319. package/dist/viewer/p-ebd55df7.entry.js +0 -4
  320. package/dist/viewer/p-f0411993.entry.js +0 -4
  321. package/dist/viewer/p-f482325b.js +0 -10
  322. package/dist/viewer/p-fad9693e.js +0 -4
  323. package/dist/viewer/p-ffdeb08c.js +0 -4
@@ -0,0 +1,276 @@
1
+ /**!
2
+ * Copyright (c) 2022 Vertex Software LLC. All rights reserved.
3
+ */
4
+ 'use strict';
5
+
6
+ Object.defineProperty(exports, '__esModule', { value: true });
7
+
8
+ const index = require('./index-4138aa2c.js');
9
+ const bundle_esm = require('./bundle.esm-22b6f2d6.js');
10
+ const index$1 = require('./index-b9d13137.js');
11
+ const dom = require('./dom-8d90bfaf.js');
12
+ const model = require('./model-a9cfd037.js');
13
+ const stencil = require('./stencil-ef19638e.js');
14
+ const utils = require('./utils-78928e4e.js');
15
+ require('./_commonjsHelpers-dcc4cf71.js');
16
+ require('./browser.esm-0bcdc581.js');
17
+ require('./utils-b157b0af.js');
18
+
19
+ function getComputedStyle(el) {
20
+ return window.getComputedStyle(el);
21
+ }
22
+
23
+ const viewerPinLabelCss = ":host{--viewer-annotations-pin-label-background-color:var(--blue-200);--viewer-annotations-pin-label-border-color:var(--blue-600);--viewer-annotations-pin-label-focused-border-color:var(--blue-700);--viewer-annotations-pin-label-color:var(--white);--viewer-annotations-pin-label-padding-y:0.375em;--viewer-annotations-pin-label-padding-x:0.5em;--viewer-annotations-pin-label-border-width:2px;--viewer-annotations-pin-label-border-style:solid;--viewer-annotations-pin-label-border-radius:0.25em;--viewer-annotations-pin-label-min-width:2rem;--viewer-annotations-pin-label-max-width:25rem;--viewer-annotations-pin-label-max-height:50rem;overflow:hidden;pointer-events:none}:host([mode='']) .pin-label{color:var(--viewer-annotations-pin-label-color);background:var(--viewer-annotations-pin-label-background-color)}.pin-label-text{font-family:Arial, Helvetica, sans-serif;font-size:0.875rem;line-height:1rem;word-break:break-word;white-space:pre-wrap}.pin-label-input-wrapper{display:flex;position:absolute;pointer-events:auto;box-sizing:border-box;min-width:var(--viewer-annotations-pin-label-min-width);max-width:var(--viewer-annotations-pin-label-max-width);max-height:var(--viewer-annotations-pin-label-max-height);background:var(--viewer-annotations-pin-label-background-color);border-width:var(--viewer-annotations-pin-label-border-width);border-style:var(--viewer-annotations-pin-label-border-style);border-color:var(--viewer-annotations-pin-label-border-color);border-radius:var(--viewer-annotations-pin-label-border-radius)}.pin-label-input-wrapper.focused{min-width:var(--viewer-annotations-pin-label-max-width);border-color:var(--viewer-annotations-pin-label-focused-border-color)}.pin-input-drag-target{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer}.pin-label-input{resize:none;position:relative;outline:none;border:none;word-break:break-word;padding:0 0 0 0;background-color:transparent;margin:var(--viewer-annotations-pin-label-padding-y) var(--viewer-annotations-pin-label-padding-x);width:var(--viewer-annotations-pin-label-min-width);flex-grow:1;overflow:hidden;max-width:calc(var(--viewer-annotations-pin-label-max-width) - calc(2 * var(--viewer-annotations-pin-label-padding-x)))}.pin-label-input.readonly{pointer-events:auto;color:black;cursor:pointer}.pin-label-hidden{position:absolute;visibility:hidden;pointer-events:none;width:auto;height:auto;box-sizing:border-box;border-width:var(--viewer-annotations-pin-label-border-width);border-style:var(--viewer-annotations-pin-label-border-style);border-color:var(--viewer-annotations-pin-label-border-color);margin:var(--viewer-annotations-pin-label-padding-y) 0;padding:0 var(--viewer-annotations-pin-label-padding-x);max-width:calc(var(--viewer-annotations-pin-label-max-width) - calc(2 * var(--viewer-annotations-pin-label-padding-x)))}";
24
+
25
+ let VertexPinLabel = class {
26
+ constructor(hostRef) {
27
+ index.registerInstance(this, hostRef);
28
+ this.labelChanged = index.createEvent(this, "labelChanged", 7);
29
+ this.labelFocused = index.createEvent(this, "labelFocused", 7);
30
+ this.labelBlurred = index.createEvent(this, "labelBlurred", 7);
31
+ this.focused = false;
32
+ this.textareaRows = 1;
33
+ this.computeContentSize = () => {
34
+ stencil.readDOM(() => {
35
+ if (this.contentEl != null) {
36
+ this.contentElBounds = this.contentEl.getBoundingClientRect();
37
+ const computedStyles = getComputedStyle(this.contentEl);
38
+ this.textareaRows = Math.max(1, Math.ceil((parseFloat(computedStyles.height) -
39
+ parseFloat(computedStyles.borderWidth) * 2) /
40
+ parseFloat(computedStyles.lineHeight)));
41
+ }
42
+ });
43
+ };
44
+ this.handleInputKeyDown = (event) => {
45
+ if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
46
+ event.preventDefault();
47
+ this.submit();
48
+ }
49
+ else if (event.key === 'Enter') {
50
+ this.textareaRows += 1;
51
+ }
52
+ };
53
+ this.handlePointerDown = (event) => {
54
+ var _a;
55
+ if (!this.focused) {
56
+ if (this.elementBounds != null) {
57
+ this.relativePointerDownPosition = utils.translatePointToRelative(dom.getMouseClientPosition(event, this.elementBounds), this.elementBounds);
58
+ this.pinPointerDownPosition = (_a = this.pin) === null || _a === void 0 ? void 0 : _a.label.point;
59
+ window.addEventListener('pointermove', this.handlePointerMove);
60
+ window.addEventListener('pointerup', this.handlePointerUp);
61
+ }
62
+ }
63
+ };
64
+ this.handlePointerMove = (event) => {
65
+ var _a, _b;
66
+ if (this.elementBounds != null &&
67
+ this.relativePointerDownPosition &&
68
+ this.pinPointerDownPosition != null) {
69
+ const point = dom.getMouseClientPosition(event, this.elementBounds);
70
+ const relative = utils.translatePointToRelative(point, this.elementBounds);
71
+ const relativeDelta = bundle_esm.point.subtract(relative, this.relativePointerDownPosition);
72
+ const myUpdatedPin = this.pin != null
73
+ ? {
74
+ id: this.pin.id,
75
+ worldPosition: this.pin.worldPosition,
76
+ label: {
77
+ point: bundle_esm.point.add(this.pinPointerDownPosition, relativeDelta),
78
+ text: this.pin.label.text,
79
+ },
80
+ partId: (_a = this.pin) === null || _a === void 0 ? void 0 : _a.partId,
81
+ }
82
+ : undefined;
83
+ if (myUpdatedPin) {
84
+ (_b = this.pinController) === null || _b === void 0 ? void 0 : _b.updatePin(myUpdatedPin);
85
+ this.computeScreenPosition();
86
+ }
87
+ }
88
+ };
89
+ this.handlePointerUp = (event) => {
90
+ var _a, _b;
91
+ if (((_a = this.pinController) === null || _a === void 0 ? void 0 : _a.getToolMode()) === 'edit' &&
92
+ this.relativePointerDownPosition != null &&
93
+ this.elementBounds != null) {
94
+ const pointerDownScreen = utils.translatePointToScreen(this.relativePointerDownPosition, this.elementBounds);
95
+ const distanceBetweenStartAndEndPoint = bundle_esm.point.distance(pointerDownScreen, dom.getMouseClientPosition(event, this.elementBounds));
96
+ if (distanceBetweenStartAndEndPoint <= 2) {
97
+ this.focused = true;
98
+ this.labelFocused.emit((_b = this.pin) === null || _b === void 0 ? void 0 : _b.id);
99
+ }
100
+ }
101
+ this.relativePointerDownPosition = undefined;
102
+ this.pinPointerDownPosition = undefined;
103
+ window.removeEventListener('pointermove', this.handlePointerMove);
104
+ window.removeEventListener('pointerup', this.handlePointerUp);
105
+ };
106
+ this.handleTextBlur = () => {
107
+ this.submit();
108
+ };
109
+ this.handleTextInput = (event) => {
110
+ const input = event.target;
111
+ this.value = input.value;
112
+ };
113
+ this.value = this.getPinText();
114
+ }
115
+ /**
116
+ * Gives focus to the the component's internal text input.
117
+ */
118
+ async setFocus() {
119
+ var _a, _b, _c;
120
+ // HTMLInputElement.focus() doesn't exist in tests.
121
+ if (typeof ((_a = this.inputEl) === null || _a === void 0 ? void 0 : _a.focus) === 'function') {
122
+ if (this.focused) {
123
+ (_b = this.inputEl) === null || _b === void 0 ? void 0 : _b.focus();
124
+ }
125
+ else {
126
+ (_c = this.inputEl) === null || _c === void 0 ? void 0 : _c.blur();
127
+ }
128
+ }
129
+ }
130
+ watchFocusChange() {
131
+ var _a, _b;
132
+ this.labelChanged.emit();
133
+ if (this.focused) {
134
+ (_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setSelectedPinId((_b = this.pin) === null || _b === void 0 ? void 0 : _b.id);
135
+ }
136
+ }
137
+ watchPinChange() {
138
+ this.value = this.getPinText();
139
+ this.computeScreenPosition();
140
+ }
141
+ watchElementBoundsChange() {
142
+ this.computeScreenPosition();
143
+ }
144
+ componentWillLoad() {
145
+ this.computeScreenPosition();
146
+ }
147
+ componentDidLoad() {
148
+ this.resizeObserver = new ResizeObserver(() => {
149
+ this.labelChanged.emit();
150
+ });
151
+ this.contentResizeObserver = new ResizeObserver(this.computeContentSize);
152
+ if (this.hostEl != null) {
153
+ this.resizeObserver.observe(this.hostEl);
154
+ }
155
+ if (this.contentEl != null) {
156
+ this.contentResizeObserver.observe(this.contentEl);
157
+ }
158
+ if (this.pinController == null) {
159
+ this.pinController = new model.PinController(new model.PinModel());
160
+ }
161
+ }
162
+ disconnectedCallback() {
163
+ var _a, _b;
164
+ (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
165
+ (_b = this.contentResizeObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
166
+ }
167
+ componentDidRender() {
168
+ if (this.focused && this.inputEl != null) {
169
+ this.setFocus();
170
+ }
171
+ }
172
+ render() {
173
+ var _a, _b, _c, _d;
174
+ return (index.h(index.Host, null, index.h("div", { id: `pin-label-${(_a = this.pin) === null || _a === void 0 ? void 0 : _a.id}`, class: index$1.classnames('pin-label-input-wrapper', {
175
+ focused: this.focused,
176
+ }), onPointerDown: this.handlePointerDown, style: {
177
+ top: `${((_b = this.computedScreenPosition) === null || _b === void 0 ? void 0 : _b.y.toString()) || 0}px`,
178
+ left: `${((_c = this.computedScreenPosition) === null || _c === void 0 ? void 0 : _c.x.toString()) || 0}px`,
179
+ minWidth: this.computeMinWidth(),
180
+ maxWidth: this.computeMaxWidth(),
181
+ maxHeight: this.computeMaxHeight(),
182
+ } }, index.h("textarea", { id: `pin-label-input-${(_d = this.pin) === null || _d === void 0 ? void 0 : _d.id}`, class: index$1.classnames('pin-label-input', 'pin-label-text', {
183
+ ['readonly']: !this.focused,
184
+ }), disabled: !this.focused, ref: (ref) => (this.inputEl = ref), value: this.value, rows: this.textareaRows, onKeyDown: this.handleInputKeyDown, onInput: this.handleTextInput, onBlur: this.handleTextBlur }), !this.focused && (index.h("div", { class: "pin-input-drag-target", onPointerDown: this.handlePointerDown }))), index.h("div", { ref: (el) => (this.contentEl = el), class: index$1.classnames('pin-label-text', 'pin-label-hidden'), style: {
185
+ maxWidth: this.computeMaxWidth(),
186
+ maxHeight: this.computeMaxHeight(),
187
+ } }, this.hiddenContent())));
188
+ }
189
+ hiddenContent() {
190
+ // This corrects some inconsistencies in how a newline character
191
+ // is represented in a div. Leveraging `<br>`s results in a more
192
+ // consistent representation of the newlines in a textarea.
193
+ return this.value.includes('\n')
194
+ ? this.value
195
+ .split('\n')
196
+ .reduce((res, str) => [...res, str, index.h("br", null)], [])
197
+ : [this.value];
198
+ }
199
+ computeMinWidth() {
200
+ if (this.contentElBounds != null) {
201
+ const expected = `${this.contentElBounds.width + 16}px`;
202
+ return `min(${expected}, ${this.computeMaxWidth()})`;
203
+ }
204
+ else {
205
+ return `var(--viewer-annotations-pin-label-min-width)`;
206
+ }
207
+ }
208
+ computeMaxWidth() {
209
+ const expected = `var(--viewer-annotations-pin-label-max-width)`;
210
+ return `min(${expected}, ${this.computeRemainingWidth()})`;
211
+ }
212
+ computeMaxHeight() {
213
+ const expected = `var(--viewer-annotations-pin-label-max-height)`;
214
+ return `min(${expected}, ${this.computeRemainingHeight()})`;
215
+ }
216
+ computeRemainingWidth() {
217
+ var _a, _b;
218
+ return `calc(${((_a = this.elementBounds) === null || _a === void 0 ? void 0 : _a.width.toString()) || 0}px - ${((_b = this.computedScreenPosition) === null || _b === void 0 ? void 0 : _b.x.toString()) || 0}px)`;
219
+ }
220
+ computeRemainingHeight() {
221
+ var _a, _b;
222
+ return `calc(${((_a = this.elementBounds) === null || _a === void 0 ? void 0 : _a.height.toString()) || 0}px - ${((_b = this.computedScreenPosition) === null || _b === void 0 ? void 0 : _b.y.toString()) || 0}px)`;
223
+ }
224
+ getPinText() {
225
+ var _a;
226
+ if (((_a = this.pin) === null || _a === void 0 ? void 0 : _a.label.text) != null) {
227
+ this.value = this.pin.label.text;
228
+ }
229
+ else {
230
+ this.value = '';
231
+ }
232
+ return this.value;
233
+ }
234
+ computeScreenPosition() {
235
+ this.computedScreenPosition =
236
+ model.isTextPin(this.pin) &&
237
+ this.elementBounds != null &&
238
+ this.pin.label.point != null
239
+ ? utils.translatePointToScreen(this.pin.label.point, this.elementBounds)
240
+ : undefined;
241
+ }
242
+ submit() {
243
+ var _a, _b;
244
+ this.focused = false;
245
+ this.labelBlurred.emit((_a = this.pin) === null || _a === void 0 ? void 0 : _a.id);
246
+ if (this.pin != null) {
247
+ (_b = this.pinController) === null || _b === void 0 ? void 0 : _b.updatePin(Object.assign(Object.assign({}, this.pin), { label: {
248
+ point: this.pin.label.point,
249
+ text: this.value,
250
+ } }));
251
+ }
252
+ }
253
+ get hostEl() { return index.getElement(this); }
254
+ static get watchers() { return {
255
+ "focused": ["watchFocusChange"],
256
+ "pin": ["watchPinChange"],
257
+ "elementBounds": ["watchElementBoundsChange"]
258
+ }; }
259
+ };
260
+ VertexPinLabel.style = viewerPinLabelCss;
261
+
262
+ const viewerPinLabelLineCss = ":host{--viewer-annotations-pin-label-line-color:var(--blue-600);--viewer-annotations-pin-label-line-width:1\n\n overflow: hidden;pointer-events:none}.label-line{pointer-events:auto;stroke:var(--viewer-annotations-pin-label-line-color);stroke-width:var( --viewer-annotations-pin-label-line-width);cursor:default}.svg{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;pointer-events:none;height:100%;width:100%}";
263
+
264
+ let VertexPinLabelLine = class {
265
+ constructor(hostRef) {
266
+ index.registerInstance(this, hostRef);
267
+ }
268
+ render() {
269
+ var _a, _b, _c, _d;
270
+ return (index.h(index.Host, null, index.h("svg", { class: "svg" }, index.h("line", { class: "label-line", x1: (_a = this.labelPoint) === null || _a === void 0 ? void 0 : _a.x, y1: (_b = this.labelPoint) === null || _b === void 0 ? void 0 : _b.y, x2: (_c = this.pinPoint) === null || _c === void 0 ? void 0 : _c.x, y2: (_d = this.pinPoint) === null || _d === void 0 ? void 0 : _d.y }))));
271
+ }
272
+ };
273
+ VertexPinLabelLine.style = viewerPinLabelLineCss;
274
+
275
+ exports.vertex_viewer_pin_label = VertexPinLabel;
276
+ exports.vertex_viewer_pin_label_line = VertexPinLabelLine;
@@ -0,0 +1,322 @@
1
+ /**!
2
+ * Copyright (c) 2022 Vertex Software LLC. All rights reserved.
3
+ */
4
+ 'use strict';
5
+
6
+ Object.defineProperty(exports, '__esModule', { value: true });
7
+
8
+ const index = require('./index-4138aa2c.js');
9
+ const model = require('./model-a9cfd037.js');
10
+ const bundle_esm = require('./bundle.esm-22b6f2d6.js');
11
+ const browser_esm = require('./browser.esm-0bcdc581.js');
12
+ const utils = require('./utils-78928e4e.js');
13
+ const cursors = require('./cursors-f5d3c9a6.js');
14
+ const dom = require('./dom-8d90bfaf.js');
15
+ const elementRectObserver = require('./elementRectObserver-9b28f182.js');
16
+ const entities = require('./entities-9eb7e608.js');
17
+ const dom$1 = require('./dom-d1bbd67c.js');
18
+ require('./utils-b157b0af.js');
19
+
20
+ class PinsInteractionHandler {
21
+ constructor(controller) {
22
+ this.rectObserver = new elementRectObserver.ElementRectObserver();
23
+ this.droppableSurfaces = [
24
+ entities.EntityType.PRECISE_SURFACE,
25
+ entities.EntityType.IMPRECISE_SURFACE,
26
+ entities.EntityType.GENERIC_GEOMETRY,
27
+ ];
28
+ this.handlePointerMove = async (event) => {
29
+ const isDroppableSurface = await this.isDroppableSurface(event);
30
+ const draggable = this.controller.getDraggable();
31
+ if (draggable != null && isDroppableSurface) {
32
+ this.handleDrag(draggable, event);
33
+ }
34
+ if (this.controller.getDraggable() == null &&
35
+ this.controller.getToolMode() === 'edit' &&
36
+ isDroppableSurface) {
37
+ this.addCursor(this.getCusorType());
38
+ }
39
+ else {
40
+ this.clearCursor();
41
+ }
42
+ };
43
+ this.handleDrag = async (draggable, event) => {
44
+ const pt = dom.getMouseClientPosition(event, this.elementRect);
45
+ const worldPosition = await this.getWorldPositionForPoint(pt);
46
+ if (worldPosition != null) {
47
+ this.controller.updateDraggable(Object.assign(Object.assign({}, draggable), { lastPoint: pt }), worldPosition);
48
+ }
49
+ };
50
+ this.handlePointerDown = async (pointerDown) => {
51
+ const pointerUp = (pointerUp) => {
52
+ const distanceBetweenStartAndEndPoint = bundle_esm.point.distance(bundle_esm.point.create(pointerDown.clientX, pointerUp.clientY), bundle_esm.point.create(pointerUp.clientX, pointerUp.clientY));
53
+ if (distanceBetweenStartAndEndPoint <= 2 && pointerDown.buttons !== 2) {
54
+ if (this.controller.getToolMode() === 'edit') {
55
+ const pt = dom.getMouseClientPosition(pointerDown, this.elementRect);
56
+ this.handlePlacePin(pt);
57
+ }
58
+ }
59
+ dispose();
60
+ };
61
+ const dispose = () => {
62
+ window.removeEventListener('pointerup', pointerUp);
63
+ };
64
+ window.addEventListener('pointerup', pointerUp);
65
+ return {
66
+ dispose,
67
+ };
68
+ };
69
+ this.handlePointerUp = async () => {
70
+ const draggable = this.controller.getDraggable();
71
+ const lastPoint = draggable === null || draggable === void 0 ? void 0 : draggable.lastPoint;
72
+ this.controller.setDraggable(undefined);
73
+ if (lastPoint != null && draggable != null) {
74
+ this.ifInitialized(async ({ api }) => {
75
+ var _a, _b, _c, _d, _e, _f;
76
+ const [hit] = await api.hitItems(lastPoint);
77
+ if ((hit === null || hit === void 0 ? void 0 : hit.hitPoint) != null &&
78
+ ((_a = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _a === void 0 ? void 0 : _a.x) != null &&
79
+ ((_b = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _b === void 0 ? void 0 : _b.y) != null &&
80
+ ((_c = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _c === void 0 ? void 0 : _c.z) != null) {
81
+ this.controller.updateDraggable(Object.assign(Object.assign({}, draggable), { lastPoint }), {
82
+ x: (_d = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _d === void 0 ? void 0 : _d.x,
83
+ y: hit === null || hit === void 0 ? void 0 : hit.hitPoint.y,
84
+ z: hit === null || hit === void 0 ? void 0 : hit.hitPoint.z,
85
+ }, (_f = (_e = hit === null || hit === void 0 ? void 0 : hit.partId) === null || _e === void 0 ? void 0 : _e.hex) !== null && _f !== void 0 ? _f : undefined);
86
+ }
87
+ });
88
+ }
89
+ };
90
+ this.controller = controller;
91
+ }
92
+ get elementRect() {
93
+ return this.rectObserver.rect;
94
+ }
95
+ initialize(element, api) {
96
+ this.element = element;
97
+ this.api = api;
98
+ this.rectObserver.observe(element);
99
+ element.addEventListener('pointermove', this.handlePointerMove);
100
+ element.addEventListener('pointerdown', this.handlePointerDown);
101
+ window.addEventListener('pointerup', this.handlePointerUp);
102
+ }
103
+ dispose() {
104
+ var _a, _b;
105
+ this.rectObserver.disconnect();
106
+ (_a = this.element) === null || _a === void 0 ? void 0 : _a.removeEventListener('pointermove', this.handlePointerMove);
107
+ (_b = this.element) === null || _b === void 0 ? void 0 : _b.removeEventListener('pointerdown', this.handlePointerDown);
108
+ window.removeEventListener('pointerup', this.handlePointerUp);
109
+ this.element = undefined;
110
+ this.api = undefined;
111
+ }
112
+ async getWorldPositionForPoint(pt) {
113
+ return this.ifInitialized(async ({ api }) => {
114
+ const vector3 = await api.getWorldPointFromViewport(pt);
115
+ return vector3;
116
+ });
117
+ }
118
+ async handlePlacePin(pt, existingPin) {
119
+ this.ifInitialized(async ({ api }) => {
120
+ var _a, _b, _c, _d, _e, _f;
121
+ const [hit] = await api.hitItems(pt);
122
+ if ((hit === null || hit === void 0 ? void 0 : hit.hitPoint) != null && this.elementRect != null) {
123
+ const relativePoint = utils.translatePointToRelative(Object.assign({}, pt), this.elementRect);
124
+ if ((hit === null || hit === void 0 ? void 0 : hit.hitPoint) != null &&
125
+ (hit === null || hit === void 0 ? void 0 : hit.hitPoint.x) != null &&
126
+ (hit === null || hit === void 0 ? void 0 : hit.hitPoint.y) != null &&
127
+ (hit === null || hit === void 0 ? void 0 : hit.hitPoint.z) != null) {
128
+ const pinId = existingPin != null ? existingPin.id : browser_esm.uuid.create();
129
+ switch (this.controller.getToolType()) {
130
+ case 'pin':
131
+ this.controller.setPin({
132
+ id: pinId,
133
+ worldPosition: {
134
+ x: (_a = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _a === void 0 ? void 0 : _a.x,
135
+ y: hit === null || hit === void 0 ? void 0 : hit.hitPoint.y,
136
+ z: hit === null || hit === void 0 ? void 0 : hit.hitPoint.z,
137
+ },
138
+ partId: (_c = (_b = hit === null || hit === void 0 ? void 0 : hit.itemId) === null || _b === void 0 ? void 0 : _b.hex) !== null && _c !== void 0 ? _c : undefined,
139
+ });
140
+ break;
141
+ case 'pin-label':
142
+ this.controller.setPin({
143
+ id: pinId,
144
+ worldPosition: {
145
+ x: (_d = hit === null || hit === void 0 ? void 0 : hit.hitPoint) === null || _d === void 0 ? void 0 : _d.x,
146
+ y: hit === null || hit === void 0 ? void 0 : hit.hitPoint.y,
147
+ z: hit === null || hit === void 0 ? void 0 : hit.hitPoint.z,
148
+ },
149
+ partId: (_f = (_e = hit === null || hit === void 0 ? void 0 : hit.itemId) === null || _e === void 0 ? void 0 : _e.hex) !== null && _f !== void 0 ? _f : undefined,
150
+ label: {
151
+ point: relativePoint,
152
+ },
153
+ });
154
+ break;
155
+ }
156
+ }
157
+ }
158
+ else {
159
+ this.controller.setSelectedPinId();
160
+ }
161
+ });
162
+ }
163
+ getCusorType() {
164
+ switch (this.controller.getToolType()) {
165
+ case 'pin':
166
+ return cursors.pinCursor;
167
+ case 'pin-label':
168
+ return cursors.labelPinCursor;
169
+ }
170
+ }
171
+ addCursor(cursor) {
172
+ this.clearCursor();
173
+ this.cursor = this.ifInitialized(({ api }) => api.addCursor(cursor));
174
+ }
175
+ async isDroppableSurface(event) {
176
+ var _a;
177
+ const pt = dom.getMouseClientPosition(event, this.elementRect);
178
+ const type = await ((_a = this.api) === null || _a === void 0 ? void 0 : _a.getEntityTypeAtPoint(pt));
179
+ return type != null && this.droppableSurfaces.includes(type);
180
+ }
181
+ ifInitialized(f) {
182
+ if (this.element != null && this.api != null) {
183
+ return f({ element: this.element, api: this.api });
184
+ }
185
+ else {
186
+ throw new Error('Pins interaction handler not initialized.');
187
+ }
188
+ }
189
+ clearCursor() {
190
+ var _a;
191
+ (_a = this.cursor) === null || _a === void 0 ? void 0 : _a.dispose();
192
+ this.cursor = undefined;
193
+ }
194
+ }
195
+
196
+ const viewerPinToolCss = ":host{position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;pointer-events:none}";
197
+
198
+ let ViewerPinTool = class {
199
+ constructor(hostRef) {
200
+ index.registerInstance(this, hostRef);
201
+ /**
202
+ * The model that contains the entities and outcomes from performing pin annotations
203
+ */
204
+ this.pinModel = new model.PinModel();
205
+ this.pins = [];
206
+ /**
207
+ * The type of pin.
208
+ *
209
+ * This property will automatically be set.
210
+ */
211
+ this.tool = 'pin';
212
+ /**
213
+ * The mode of the pin tool
214
+ */
215
+ this.mode = 'view';
216
+ this.handleSetProjectionMatrix = () => {
217
+ var _a, _b;
218
+ this.projectionViewMatrix =
219
+ (_b = (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame) === null || _b === void 0 ? void 0 : _b.scene.camera.projectionViewMatrix;
220
+ };
221
+ }
222
+ /**
223
+ * @ignore
224
+ */
225
+ watchModeChange() {
226
+ var _a;
227
+ (_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setToolMode(this.mode);
228
+ this.setupInteractionHandler();
229
+ }
230
+ /**
231
+ * @ignore
232
+ */
233
+ watchTypeChange() {
234
+ var _a;
235
+ (_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setToolType(this.tool);
236
+ this.setupInteractionHandler();
237
+ }
238
+ /**
239
+ * @ignore
240
+ */
241
+ connectedCallback() {
242
+ this.setupInteractionHandler();
243
+ }
244
+ /**
245
+ * @ignore
246
+ */
247
+ componentWillLoad() {
248
+ this.updateViewport();
249
+ this.setupController();
250
+ this.setupInteractionHandler();
251
+ this.pinModel.onEntitiesChanged((entities) => {
252
+ this.pins = entities;
253
+ });
254
+ this.pinModel.onSelectionChange((selectedId) => {
255
+ this.selectedPinId = selectedId;
256
+ });
257
+ }
258
+ componentDidLoad() {
259
+ this.resizeObserver = new ResizeObserver(() => this.updateViewport());
260
+ this.resizeObserver.observe(this.hostEl);
261
+ }
262
+ /**
263
+ * @ignore
264
+ */
265
+ disconnectedCallback() {
266
+ this.clearInteractionHandler();
267
+ this.clearModelListeners();
268
+ }
269
+ /**
270
+ * @ignore
271
+ */
272
+ handleViewerChanged(newViewer, oldViewer) {
273
+ this.setupInteractionHandler();
274
+ if (oldViewer != null) {
275
+ oldViewer.removeEventListener('frameDrawn', this.handleSetProjectionMatrix);
276
+ }
277
+ if (newViewer != null) {
278
+ newViewer.addEventListener('frameDrawn', this.handleSetProjectionMatrix);
279
+ }
280
+ this.handleSetProjectionMatrix();
281
+ }
282
+ render() {
283
+ return (index.h(index.Host, null, index.h("vertex-viewer-dom-renderer", { viewer: this.viewer, drawMode: "2d" }, this.pins.map((pin) => {
284
+ return (index.h("vertex-viewer-pin-group", { id: `pin-group-${pin.id}`, "data-is-dom-group-element": true, pin: pin, elementBounds: this.elementBounds, pinModel: this.pinModel, pinController: this.pinController, projectionViewMatrix: this.projectionViewMatrix, selected: this.selectedPinId === pin.id }));
285
+ }))));
286
+ }
287
+ setupController() {
288
+ this.pinController = new model.PinController(this.pinModel, this.mode, this.tool);
289
+ }
290
+ clearInteractionHandler() {
291
+ var _a;
292
+ (_a = this.registeredInteractionHandler) === null || _a === void 0 ? void 0 : _a.then((handler) => handler.dispose());
293
+ this.registeredInteractionHandler = undefined;
294
+ }
295
+ setupInteractionHandler() {
296
+ var _a;
297
+ this.clearInteractionHandler();
298
+ if (this.pinController != null) {
299
+ this.registeredInteractionHandler =
300
+ (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.registerInteractionHandler(new PinsInteractionHandler(this.pinController));
301
+ }
302
+ }
303
+ clearModelListeners() {
304
+ var _a, _b;
305
+ (_a = this.onEntitiesChangedHandler) === null || _a === void 0 ? void 0 : _a.dispose();
306
+ this.onEntitiesChangedHandler = undefined;
307
+ (_b = this.resizeObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
308
+ }
309
+ updateViewport() {
310
+ const rect = dom$1.getMarkupBoundingClientRect(this.hostEl);
311
+ this.elementBounds = rect;
312
+ }
313
+ get hostEl() { return index.getElement(this); }
314
+ static get watchers() { return {
315
+ "mode": ["watchModeChange"],
316
+ "tool": ["watchTypeChange"],
317
+ "viewer": ["handleViewerChanged"]
318
+ }; }
319
+ };
320
+ ViewerPinTool.style = viewerPinToolCss;
321
+
322
+ exports.vertex_viewer_pin_tool = ViewerPinTool;