@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,163 @@
1
+ /**!
2
+ * Copyright (c) 2022 Vertex Software LLC. All rights reserved.
3
+ */
4
+ import { h, F as Fragment, r as registerInstance } from './index-a9fb8318.js';
5
+ import { p as point, m as matrix4, v as vector3 } from './bundle.esm-ce2c7ad3.js';
6
+ import './cursors-98b7d89d.js';
7
+ import './mapper-bde6c607.js';
8
+ import './grpc-web-client.umd-5409853c.js';
9
+ import './streamAttributes-72a92676.js';
10
+ import './entities-ce81dd7f.js';
11
+ import { V as Viewport } from './viewport-e39e2eba.js';
12
+ import { i as isDefaultPin, b as isTextPin, P as PinModel, a as PinController } from './model-f679c493.js';
13
+ import { a as translatePointToScreen } from './utils-c714e2f7.js';
14
+ import { c as classnames } from './index-e841d91b.js';
15
+ import './browser.esm-1ddb69c9.js';
16
+ import './_commonjsHelpers-11ca3be1.js';
17
+ import './utils-f11bd6f7.js';
18
+
19
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
20
+ const PinRenderer = ({ pin, selected, }) => {
21
+ return (h(Fragment, null,
22
+ isTextPin(pin) && (h("div", { id: "pin-anchor", class: classnames('pin-anchor', { selected: selected }) })),
23
+ isDefaultPin(pin) && (h("vertex-viewer-icon", { name: "pin-fill", size: "lg", class: classnames('pin', {
24
+ 'pin-selected': selected,
25
+ }) }))));
26
+ };
27
+
28
+ function getClosestCenterToPoint(boxPoint, pointToMeasure, dimensions) {
29
+ const topPoint = {
30
+ x: boxPoint.x + dimensions.width / 2,
31
+ y: boxPoint.y,
32
+ };
33
+ const bottomPoint = {
34
+ x: boxPoint.x + dimensions.width / 2,
35
+ y: boxPoint.y + dimensions.height,
36
+ };
37
+ const rightPoint = {
38
+ x: boxPoint.x + dimensions.width,
39
+ y: boxPoint.y + dimensions.height / 2,
40
+ };
41
+ const leftPoint = {
42
+ x: boxPoint.x,
43
+ y: boxPoint.y + dimensions.height / 2,
44
+ };
45
+ const candidates = [topPoint, bottomPoint, leftPoint, rightPoint];
46
+ const distances = candidates.map((candidate) => point.distance(candidate, pointToMeasure));
47
+ const candidateIndex = distances.indexOf(Math.min(...distances));
48
+ return candidates[candidateIndex];
49
+ }
50
+
51
+ const viewerPinGroupCss = ":host{--viewer-annotations-pin-dot-color:var(--blue-600);--viewer-annotations-pin-color:var(--blue-700);--viewer-annotations-pin-font-size:0.75rem;--viewer-annotations-pin-selected-stroke:var(--white);--viewer-annotations-pin-selected-border:2px solid var(--white);--viewer-annotations-pin-label-border:2px solid var(--black);--viewer-annotations-pin-selected-stroke:var(--white);font-size:var(--viewer-annotations-pin-font-size);position:absolute;top:0;bottom:0;left:0;right:0;overflow:hidden;pointer-events:none}.pin-anchor{position:absolute;border-radius:50%;transform:translate(-50%, -50%);display:block;width:9px;height:9px;box-sizing:border-box;border:var(--viewer-annotations-pin-label-border);background:var(--viewer-annotations-pin-dot-color);pointer-events:auto;cursor:pointer}.selected{width:13px;height:13px;border:var(--viewer-annotations-pin-selected-border)}.pin{color:var(--viewer-annotations-pin-color);cursor:pointer}.pin-selected{stroke-width:1;stroke:var(--viewer-annotations-pin-selected-stroke)}";
52
+
53
+ let ViewerPinGroup = class {
54
+ constructor(hostRef) {
55
+ registerInstance(this, hostRef);
56
+ /**
57
+ * The local matrix of this element.
58
+ */
59
+ this.matrix = matrix4.makeIdentity();
60
+ /**
61
+ * Projection view matrix used for computing the position of the pin line
62
+ */
63
+ this.projectionViewMatrix = matrix4.makeIdentity();
64
+ /**
65
+ * The model that contains the entities and outcomes from performing pin operations
66
+ */
67
+ this.pinModel = new PinModel();
68
+ /**
69
+ * Whether or not the pin is "selected"
70
+ */
71
+ this.selected = false;
72
+ this.invalidateStateCounter = 0;
73
+ this.leafNodesRendered = false;
74
+ this.handleAnchorPointerDown = (event) => {
75
+ var _a, _b;
76
+ if (this.elementBounds != null &&
77
+ ((_a = this.pinController) === null || _a === void 0 ? void 0 : _a.getToolMode()) === 'edit' &&
78
+ this.pin != null) {
79
+ (_b = this.pinController) === null || _b === void 0 ? void 0 : _b.setDraggable({
80
+ id: this.pin.id,
81
+ });
82
+ }
83
+ };
84
+ }
85
+ componentDidLoad() {
86
+ this.setLabelObserver();
87
+ if (this.pinController == null) {
88
+ this.pinController = new PinController(this.pinModel);
89
+ }
90
+ this.leafNodesRendered = true;
91
+ }
92
+ disconnectedCallback() {
93
+ var _a, _b;
94
+ (_a = this.labelEl) === null || _a === void 0 ? void 0 : _a.removeEventListener('labelChanged', this.invalidateState);
95
+ (_b = this.resizeObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
96
+ }
97
+ render() {
98
+ var _a;
99
+ if (this.pin == null) {
100
+ throw new Error('Unable to draw pin');
101
+ }
102
+ const computed = this.computePinPoints(this.pin);
103
+ const { pinPoint, labelPoint } = computed;
104
+ return (h(Fragment, null, h("vertex-viewer-dom-element", { "data-testid": `drawn-pin-${this.pin.id}`, position: this.pin.worldPosition, onPointerDown: (e) => {
105
+ var _a, _b;
106
+ if (e.buttons !== 2) {
107
+ e.stopPropagation();
108
+ }
109
+ (_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setSelectedPinId((_b = this.pin) === null || _b === void 0 ? void 0 : _b.id);
110
+ this.handleAnchorPointerDown(e);
111
+ } }, this.leafNodesRendered && (h(PinRenderer, { pin: this.pin, selected: this.selected }))), isTextPin(this.pin) && (h(Fragment, null, h("vertex-viewer-pin-label-line", { id: `pin-label-line-${(_a = this.pin) === null || _a === void 0 ? void 0 : _a.id}`, pinPoint: pinPoint, labelPoint: labelPoint }), h("vertex-viewer-pin-label", { pin: this.pin, ref: (el) => {
112
+ this.labelEl = el;
113
+ }, elementBounds: this.elementBounds, pinController: this.pinController })))));
114
+ }
115
+ invalidateState() {
116
+ this.invalidateStateCounter = this.invalidateStateCounter + 1;
117
+ }
118
+ setLabelObserver() {
119
+ var _a;
120
+ const label = (_a = this.labelEl) === null || _a === void 0 ? void 0 : _a.addEventListener('labelChanged', this.invalidateState);
121
+ if (label != null) {
122
+ this.resizeObserver = new ResizeObserver(() => this.invalidateState());
123
+ this.resizeObserver.observe(label);
124
+ }
125
+ }
126
+ computePinPoints(pin) {
127
+ if (this.elementBounds != null && this.pin != null) {
128
+ return isTextPin(this.pin) && this.pin.label.point != null
129
+ ? this.computeTextPinPoints(this.pin, this.elementBounds)
130
+ : this.computeDefaultPinPoints(this.pin, this.elementBounds);
131
+ }
132
+ return {
133
+ pinPoint: pin.worldPosition,
134
+ };
135
+ }
136
+ computeDefaultPinPoints(pin, elementBounds) {
137
+ return {
138
+ pinPoint: this.getFromWorldPosition(pin.worldPosition, this.projectionViewMatrix, elementBounds),
139
+ };
140
+ }
141
+ computeTextPinPoints(pin, elementBounds) {
142
+ var _a, _b;
143
+ const { pinPoint } = this.computeDefaultPinPoints(pin, elementBounds);
144
+ const screenPosition = translatePointToScreen(pin.label.point, elementBounds);
145
+ const label = (_a = this.labelEl) === null || _a === void 0 ? void 0 : _a.querySelector(`#pin-label-${(_b = this.pin) === null || _b === void 0 ? void 0 : _b.id}`);
146
+ const labelWidth = (label === null || label === void 0 ? void 0 : label.clientWidth) || 0;
147
+ const labelHeight = (label === null || label === void 0 ? void 0 : label.clientHeight) || 0;
148
+ return {
149
+ pinPoint,
150
+ labelPoint: getClosestCenterToPoint(screenPosition, pinPoint, {
151
+ width: labelWidth,
152
+ height: labelHeight,
153
+ }),
154
+ };
155
+ }
156
+ getFromWorldPosition(pt, projectionViewMatrix, dimensions) {
157
+ const ndcPt = vector3.transformMatrix(pt, projectionViewMatrix);
158
+ return Viewport.fromDimensions(dimensions).transformVectorToViewport(ndcPt);
159
+ }
160
+ };
161
+ ViewerPinGroup.style = viewerPinGroupCss;
162
+
163
+ export { ViewerPinGroup as vertex_viewer_pin_group };
@@ -0,0 +1,271 @@
1
+ /**!
2
+ * Copyright (c) 2022 Vertex Software LLC. All rights reserved.
3
+ */
4
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-a9fb8318.js';
5
+ import { p as point } from './bundle.esm-ce2c7ad3.js';
6
+ import { c as classnames } from './index-e841d91b.js';
7
+ import { g as getMouseClientPosition } from './dom-5b164305.js';
8
+ import { a as PinController, P as PinModel, b as isTextPin } from './model-f679c493.js';
9
+ import { r as readDOM } from './stencil-8b20e5a8.js';
10
+ import { t as translatePointToRelative, a as translatePointToScreen } from './utils-c714e2f7.js';
11
+ import './_commonjsHelpers-11ca3be1.js';
12
+ import './browser.esm-1ddb69c9.js';
13
+ import './utils-f11bd6f7.js';
14
+
15
+ function getComputedStyle(el) {
16
+ return window.getComputedStyle(el);
17
+ }
18
+
19
+ 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)))}";
20
+
21
+ let VertexPinLabel = class {
22
+ constructor(hostRef) {
23
+ registerInstance(this, hostRef);
24
+ this.labelChanged = createEvent(this, "labelChanged", 7);
25
+ this.labelFocused = createEvent(this, "labelFocused", 7);
26
+ this.labelBlurred = createEvent(this, "labelBlurred", 7);
27
+ this.focused = false;
28
+ this.textareaRows = 1;
29
+ this.computeContentSize = () => {
30
+ readDOM(() => {
31
+ if (this.contentEl != null) {
32
+ this.contentElBounds = this.contentEl.getBoundingClientRect();
33
+ const computedStyles = getComputedStyle(this.contentEl);
34
+ this.textareaRows = Math.max(1, Math.ceil((parseFloat(computedStyles.height) -
35
+ parseFloat(computedStyles.borderWidth) * 2) /
36
+ parseFloat(computedStyles.lineHeight)));
37
+ }
38
+ });
39
+ };
40
+ this.handleInputKeyDown = (event) => {
41
+ if (event.key === 'Enter' && (event.ctrlKey || event.metaKey)) {
42
+ event.preventDefault();
43
+ this.submit();
44
+ }
45
+ else if (event.key === 'Enter') {
46
+ this.textareaRows += 1;
47
+ }
48
+ };
49
+ this.handlePointerDown = (event) => {
50
+ var _a;
51
+ if (!this.focused) {
52
+ if (this.elementBounds != null) {
53
+ this.relativePointerDownPosition = translatePointToRelative(getMouseClientPosition(event, this.elementBounds), this.elementBounds);
54
+ this.pinPointerDownPosition = (_a = this.pin) === null || _a === void 0 ? void 0 : _a.label.point;
55
+ window.addEventListener('pointermove', this.handlePointerMove);
56
+ window.addEventListener('pointerup', this.handlePointerUp);
57
+ }
58
+ }
59
+ };
60
+ this.handlePointerMove = (event) => {
61
+ var _a, _b;
62
+ if (this.elementBounds != null &&
63
+ this.relativePointerDownPosition &&
64
+ this.pinPointerDownPosition != null) {
65
+ const point$1 = getMouseClientPosition(event, this.elementBounds);
66
+ const relative = translatePointToRelative(point$1, this.elementBounds);
67
+ const relativeDelta = point.subtract(relative, this.relativePointerDownPosition);
68
+ const myUpdatedPin = this.pin != null
69
+ ? {
70
+ id: this.pin.id,
71
+ worldPosition: this.pin.worldPosition,
72
+ label: {
73
+ point: point.add(this.pinPointerDownPosition, relativeDelta),
74
+ text: this.pin.label.text,
75
+ },
76
+ partId: (_a = this.pin) === null || _a === void 0 ? void 0 : _a.partId,
77
+ }
78
+ : undefined;
79
+ if (myUpdatedPin) {
80
+ (_b = this.pinController) === null || _b === void 0 ? void 0 : _b.updatePin(myUpdatedPin);
81
+ this.computeScreenPosition();
82
+ }
83
+ }
84
+ };
85
+ this.handlePointerUp = (event) => {
86
+ var _a, _b;
87
+ if (((_a = this.pinController) === null || _a === void 0 ? void 0 : _a.getToolMode()) === 'edit' &&
88
+ this.relativePointerDownPosition != null &&
89
+ this.elementBounds != null) {
90
+ const pointerDownScreen = translatePointToScreen(this.relativePointerDownPosition, this.elementBounds);
91
+ const distanceBetweenStartAndEndPoint = point.distance(pointerDownScreen, getMouseClientPosition(event, this.elementBounds));
92
+ if (distanceBetweenStartAndEndPoint <= 2) {
93
+ this.focused = true;
94
+ this.labelFocused.emit((_b = this.pin) === null || _b === void 0 ? void 0 : _b.id);
95
+ }
96
+ }
97
+ this.relativePointerDownPosition = undefined;
98
+ this.pinPointerDownPosition = undefined;
99
+ window.removeEventListener('pointermove', this.handlePointerMove);
100
+ window.removeEventListener('pointerup', this.handlePointerUp);
101
+ };
102
+ this.handleTextBlur = () => {
103
+ this.submit();
104
+ };
105
+ this.handleTextInput = (event) => {
106
+ const input = event.target;
107
+ this.value = input.value;
108
+ };
109
+ this.value = this.getPinText();
110
+ }
111
+ /**
112
+ * Gives focus to the the component's internal text input.
113
+ */
114
+ async setFocus() {
115
+ var _a, _b, _c;
116
+ // HTMLInputElement.focus() doesn't exist in tests.
117
+ if (typeof ((_a = this.inputEl) === null || _a === void 0 ? void 0 : _a.focus) === 'function') {
118
+ if (this.focused) {
119
+ (_b = this.inputEl) === null || _b === void 0 ? void 0 : _b.focus();
120
+ }
121
+ else {
122
+ (_c = this.inputEl) === null || _c === void 0 ? void 0 : _c.blur();
123
+ }
124
+ }
125
+ }
126
+ watchFocusChange() {
127
+ var _a, _b;
128
+ this.labelChanged.emit();
129
+ if (this.focused) {
130
+ (_a = this.pinController) === null || _a === void 0 ? void 0 : _a.setSelectedPinId((_b = this.pin) === null || _b === void 0 ? void 0 : _b.id);
131
+ }
132
+ }
133
+ watchPinChange() {
134
+ this.value = this.getPinText();
135
+ this.computeScreenPosition();
136
+ }
137
+ watchElementBoundsChange() {
138
+ this.computeScreenPosition();
139
+ }
140
+ componentWillLoad() {
141
+ this.computeScreenPosition();
142
+ }
143
+ componentDidLoad() {
144
+ this.resizeObserver = new ResizeObserver(() => {
145
+ this.labelChanged.emit();
146
+ });
147
+ this.contentResizeObserver = new ResizeObserver(this.computeContentSize);
148
+ if (this.hostEl != null) {
149
+ this.resizeObserver.observe(this.hostEl);
150
+ }
151
+ if (this.contentEl != null) {
152
+ this.contentResizeObserver.observe(this.contentEl);
153
+ }
154
+ if (this.pinController == null) {
155
+ this.pinController = new PinController(new PinModel());
156
+ }
157
+ }
158
+ disconnectedCallback() {
159
+ var _a, _b;
160
+ (_a = this.resizeObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
161
+ (_b = this.contentResizeObserver) === null || _b === void 0 ? void 0 : _b.disconnect();
162
+ }
163
+ componentDidRender() {
164
+ if (this.focused && this.inputEl != null) {
165
+ this.setFocus();
166
+ }
167
+ }
168
+ render() {
169
+ var _a, _b, _c, _d;
170
+ return (h(Host, null, h("div", { id: `pin-label-${(_a = this.pin) === null || _a === void 0 ? void 0 : _a.id}`, class: classnames('pin-label-input-wrapper', {
171
+ focused: this.focused,
172
+ }), onPointerDown: this.handlePointerDown, style: {
173
+ top: `${((_b = this.computedScreenPosition) === null || _b === void 0 ? void 0 : _b.y.toString()) || 0}px`,
174
+ left: `${((_c = this.computedScreenPosition) === null || _c === void 0 ? void 0 : _c.x.toString()) || 0}px`,
175
+ minWidth: this.computeMinWidth(),
176
+ maxWidth: this.computeMaxWidth(),
177
+ maxHeight: this.computeMaxHeight(),
178
+ } }, h("textarea", { id: `pin-label-input-${(_d = this.pin) === null || _d === void 0 ? void 0 : _d.id}`, class: classnames('pin-label-input', 'pin-label-text', {
179
+ ['readonly']: !this.focused,
180
+ }), 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 && (h("div", { class: "pin-input-drag-target", onPointerDown: this.handlePointerDown }))), h("div", { ref: (el) => (this.contentEl = el), class: classnames('pin-label-text', 'pin-label-hidden'), style: {
181
+ maxWidth: this.computeMaxWidth(),
182
+ maxHeight: this.computeMaxHeight(),
183
+ } }, this.hiddenContent())));
184
+ }
185
+ hiddenContent() {
186
+ // This corrects some inconsistencies in how a newline character
187
+ // is represented in a div. Leveraging `<br>`s results in a more
188
+ // consistent representation of the newlines in a textarea.
189
+ return this.value.includes('\n')
190
+ ? this.value
191
+ .split('\n')
192
+ .reduce((res, str) => [...res, str, h("br", null)], [])
193
+ : [this.value];
194
+ }
195
+ computeMinWidth() {
196
+ if (this.contentElBounds != null) {
197
+ const expected = `${this.contentElBounds.width + 16}px`;
198
+ return `min(${expected}, ${this.computeMaxWidth()})`;
199
+ }
200
+ else {
201
+ return `var(--viewer-annotations-pin-label-min-width)`;
202
+ }
203
+ }
204
+ computeMaxWidth() {
205
+ const expected = `var(--viewer-annotations-pin-label-max-width)`;
206
+ return `min(${expected}, ${this.computeRemainingWidth()})`;
207
+ }
208
+ computeMaxHeight() {
209
+ const expected = `var(--viewer-annotations-pin-label-max-height)`;
210
+ return `min(${expected}, ${this.computeRemainingHeight()})`;
211
+ }
212
+ computeRemainingWidth() {
213
+ var _a, _b;
214
+ 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)`;
215
+ }
216
+ computeRemainingHeight() {
217
+ var _a, _b;
218
+ 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)`;
219
+ }
220
+ getPinText() {
221
+ var _a;
222
+ if (((_a = this.pin) === null || _a === void 0 ? void 0 : _a.label.text) != null) {
223
+ this.value = this.pin.label.text;
224
+ }
225
+ else {
226
+ this.value = '';
227
+ }
228
+ return this.value;
229
+ }
230
+ computeScreenPosition() {
231
+ this.computedScreenPosition =
232
+ isTextPin(this.pin) &&
233
+ this.elementBounds != null &&
234
+ this.pin.label.point != null
235
+ ? translatePointToScreen(this.pin.label.point, this.elementBounds)
236
+ : undefined;
237
+ }
238
+ submit() {
239
+ var _a, _b;
240
+ this.focused = false;
241
+ this.labelBlurred.emit((_a = this.pin) === null || _a === void 0 ? void 0 : _a.id);
242
+ if (this.pin != null) {
243
+ (_b = this.pinController) === null || _b === void 0 ? void 0 : _b.updatePin(Object.assign(Object.assign({}, this.pin), { label: {
244
+ point: this.pin.label.point,
245
+ text: this.value,
246
+ } }));
247
+ }
248
+ }
249
+ get hostEl() { return getElement(this); }
250
+ static get watchers() { return {
251
+ "focused": ["watchFocusChange"],
252
+ "pin": ["watchPinChange"],
253
+ "elementBounds": ["watchElementBoundsChange"]
254
+ }; }
255
+ };
256
+ VertexPinLabel.style = viewerPinLabelCss;
257
+
258
+ 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%}";
259
+
260
+ let VertexPinLabelLine = class {
261
+ constructor(hostRef) {
262
+ registerInstance(this, hostRef);
263
+ }
264
+ render() {
265
+ var _a, _b, _c, _d;
266
+ return (h(Host, null, h("svg", { class: "svg" }, 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 }))));
267
+ }
268
+ };
269
+ VertexPinLabelLine.style = viewerPinLabelLineCss;
270
+
271
+ export { VertexPinLabel as vertex_viewer_pin_label, VertexPinLabelLine as vertex_viewer_pin_label_line };