@vertexvis/viewer 0.13.2-canary.44 → 0.13.2-canary.45
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.
- package/dist/cjs/index.cjs.js +1 -1
- package/dist/cjs/vertex-viewer-dom-element_2.cjs.entry.js +1 -1
- package/dist/cjs/vertex-viewer-measurement-distance.cjs.entry.js +1 -1
- package/dist/cjs/vertex-viewer-pin-group.cjs.entry.js +1 -1
- package/dist/cjs/vertex-viewer-transform-widget.cjs.entry.js +61 -17
- package/dist/cjs/vertex-viewer.cjs.entry.js +1 -1
- package/dist/cjs/{viewport-a259d895.js → viewport-aeb8a3f3.js} +13 -3
- package/dist/collection/components/viewer-transform-widget/util.js +15 -4
- package/dist/collection/components/viewer-transform-widget/viewer-transform-widget.js +5 -3
- package/dist/collection/components/viewer-transform-widget/widget.js +25 -5
- package/dist/collection/lib/transforms/hits.js +12 -4
- package/dist/collection/lib/transforms/mesh.js +6 -3
- package/dist/collection/lib/types/viewport.js +14 -4
- package/dist/custom-elements/index.js +73 -19
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/vertex-viewer-dom-element_2.entry.js +1 -1
- package/dist/esm/vertex-viewer-measurement-distance.entry.js +1 -1
- package/dist/esm/vertex-viewer-pin-group.entry.js +1 -1
- package/dist/esm/vertex-viewer-transform-widget.entry.js +62 -18
- package/dist/esm/vertex-viewer.entry.js +1 -1
- package/dist/esm/{viewport-7421cd5c.js → viewport-7e612d0d.js} +13 -3
- package/dist/types/components/viewer-transform-widget/widget.d.ts +2 -0
- package/dist/types/lib/transforms/mesh.d.ts +2 -1
- package/dist/types/lib/types/viewport.d.ts +8 -0
- package/dist/viewer/index.esm.js +1 -1
- package/dist/viewer/p-4d6ea58f.entry.js +4 -0
- package/dist/viewer/{p-5d833a6d.entry.js → p-831fe8e4.entry.js} +1 -1
- package/dist/viewer/{p-b2a5d2ee.entry.js → p-8897b397.entry.js} +1 -1
- package/dist/viewer/p-8cf1d174.js +4 -0
- package/dist/viewer/{p-d2d6cf52.entry.js → p-b09a7169.entry.js} +1 -1
- package/dist/viewer/{p-10655c8a.entry.js → p-cfc93df0.entry.js} +1 -1
- package/dist/viewer/viewer.esm.js +1 -1
- package/package.json +7 -7
- package/dist/viewer/p-9e675bb3.entry.js +0 -4
- package/dist/viewer/p-aebcfde0.js +0 -4
package/dist/cjs/index.cjs.js
CHANGED
|
@@ -14,7 +14,7 @@ const results = require('./results-6cab066c.js');
|
|
|
14
14
|
const streamAttributes = require('./streamAttributes-07357da5.js');
|
|
15
15
|
const entities = require('./entities-9eb7e608.js');
|
|
16
16
|
const markup = require('./markup-d779dd54.js');
|
|
17
|
-
const viewport = require('./viewport-
|
|
17
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
18
18
|
require('./browser.esm-739c5a8a.js');
|
|
19
19
|
require('./bundle.esm-3581a1e0.js');
|
|
20
20
|
require('./mapper-7ee069ef.js');
|
|
@@ -10,7 +10,7 @@ const bundle_esm = require('./bundle.esm-3581a1e0.js');
|
|
|
10
10
|
const browser_esm = require('./browser.esm-739c5a8a.js');
|
|
11
11
|
require('./streamAttributes-07357da5.js');
|
|
12
12
|
require('./entities-9eb7e608.js');
|
|
13
|
-
const viewport = require('./viewport-
|
|
13
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
14
14
|
require('./_commonjsHelpers-dcc4cf71.js');
|
|
15
15
|
|
|
16
16
|
const viewerDomElementCss = ":host{position:absolute;pointer-events:none}:host(:not([interactions-off]))>*{pointer-events:auto}";
|
|
@@ -17,7 +17,7 @@ const model = require('./model-2dbabec1.js');
|
|
|
17
17
|
const overlays = require('./overlays-bac05f94.js');
|
|
18
18
|
const results = require('./results-6cab066c.js');
|
|
19
19
|
require('./entities-9eb7e608.js');
|
|
20
|
-
const viewport = require('./viewport-
|
|
20
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
21
21
|
const browser_esm = require('./browser.esm-739c5a8a.js');
|
|
22
22
|
const utils = require('./utils-1bfe6fec.js');
|
|
23
23
|
const index$1 = require('./index-b9d13137.js');
|
|
@@ -12,7 +12,7 @@ require('./mapper-7ee069ef.js');
|
|
|
12
12
|
require('./grpc-web-client.umd-2af20c1b.js');
|
|
13
13
|
require('./streamAttributes-07357da5.js');
|
|
14
14
|
require('./entities-9eb7e608.js');
|
|
15
|
-
const viewport = require('./viewport-
|
|
15
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
16
16
|
const model = require('./model-1fb38025.js');
|
|
17
17
|
const utils = require('./utils-cfcdeea5.js');
|
|
18
18
|
const index$1 = require('./index-b9d13137.js');
|
|
@@ -13,7 +13,7 @@ const browser_esm = require('./browser.esm-739c5a8a.js');
|
|
|
13
13
|
const _commonjsHelpers = require('./_commonjsHelpers-dcc4cf71.js');
|
|
14
14
|
require('./streamAttributes-07357da5.js');
|
|
15
15
|
require('./entities-9eb7e608.js');
|
|
16
|
-
const viewport = require('./viewport-
|
|
16
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
17
17
|
|
|
18
18
|
class TransformController {
|
|
19
19
|
constructor(stream) {
|
|
@@ -104,9 +104,20 @@ function convertPointToCanvas(point, bounds) {
|
|
|
104
104
|
}
|
|
105
105
|
function convertCanvasPointToWorld(point, frame, viewport, position) {
|
|
106
106
|
if (point != null && frame != null && viewport != null && position != null) {
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
107
|
+
if (frame.scene.camera.isOrthographic()) {
|
|
108
|
+
const ray = viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera);
|
|
109
|
+
// Offset the point to past the bounding sphere of the model to
|
|
110
|
+
// adjust the position plane location.
|
|
111
|
+
const offsetPoint = bundle_esm.ray.at(bundle_esm.ray.create({
|
|
112
|
+
origin: position,
|
|
113
|
+
direction: frame.scene.camera.direction,
|
|
114
|
+
}), bundle_esm.vector3.magnitude(frame.scene.camera.viewVector) * 2);
|
|
115
|
+
return bundle_esm.ray.intersectPlane(ray, bundle_esm.plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, offsetPoint));
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
|
|
119
|
+
return bundle_esm.ray.intersectPlane(ray, bundle_esm.plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position));
|
|
120
|
+
}
|
|
110
121
|
}
|
|
111
122
|
return undefined;
|
|
112
123
|
}
|
|
@@ -12464,13 +12475,16 @@ class TriangleMesh extends Mesh {
|
|
|
12464
12475
|
: browser_esm.color.toHexString(outlineColor), typeof fillColor === 'string' ? fillColor : browser_esm.color.toHexString(fillColor), shapeProps);
|
|
12465
12476
|
}
|
|
12466
12477
|
}
|
|
12467
|
-
function computeMesh2dBounds(...meshes) {
|
|
12478
|
+
function computeMesh2dBounds(viewport, ...meshes) {
|
|
12468
12479
|
let min = bundle_esm.point.create(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);
|
|
12469
12480
|
let max = bundle_esm.point.create();
|
|
12470
12481
|
meshes
|
|
12471
12482
|
.filter((m) => m.points.valid)
|
|
12472
12483
|
.map((m) => {
|
|
12473
|
-
m.points
|
|
12484
|
+
m.points
|
|
12485
|
+
.toArray()
|
|
12486
|
+
.map((pt) => viewport.transformNdcPointToViewport(pt))
|
|
12487
|
+
.forEach((pt) => {
|
|
12474
12488
|
min = bundle_esm.point.create(Math.min(pt.x, min.x), Math.min(pt.y, min.y));
|
|
12475
12489
|
max = bundle_esm.point.create(Math.max(pt.x, max.x), Math.max(pt.y, max.y));
|
|
12476
12490
|
});
|
|
@@ -12513,13 +12527,17 @@ function computeArrowNdcValues(widgetPosition, camera, direction, triangleSize)
|
|
|
12513
12527
|
*/
|
|
12514
12528
|
function testTriangleMesh(mesh, frame, viewport, point) {
|
|
12515
12529
|
var _a;
|
|
12516
|
-
const ray =
|
|
12530
|
+
const ray = frame.scene.camera.isOrthographic()
|
|
12531
|
+
? viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera)
|
|
12532
|
+
: viewport.transformPointToRay(point, frame.image, frame.scene.camera);
|
|
12517
12533
|
const edge1 = bundle_esm.vector3.subtract(mesh.points.worldRight, mesh.points.worldLeft);
|
|
12518
12534
|
const edge2 = bundle_esm.vector3.subtract(mesh.points.worldTip, mesh.points.worldLeft);
|
|
12519
12535
|
const epsilon = bundle_esm.boundingBox.epsilon((_a = bundle_esm.boundingBox.fromVectors([ray.direction, ray.origin, edge1, edge2])) !== null && _a !== void 0 ? _a : bundle_esm.boundingBox.create(edge1, edge2));
|
|
12520
12536
|
const p = bundle_esm.vector3.cross(ray.direction, edge2);
|
|
12521
12537
|
const det = bundle_esm.vector3.dot(edge1, p);
|
|
12522
|
-
|
|
12538
|
+
// This check causes a `det` of NaN or 0 to return false
|
|
12539
|
+
// without needing to perform the subsequent calculations.
|
|
12540
|
+
if (!(Math.abs(det) >= epsilon)) {
|
|
12523
12541
|
return false;
|
|
12524
12542
|
}
|
|
12525
12543
|
const t = bundle_esm.vector3.subtract(ray.origin, mesh.points.worldLeft);
|
|
@@ -12533,9 +12551,18 @@ function testTriangleMesh(mesh, frame, viewport, point) {
|
|
|
12533
12551
|
return false;
|
|
12534
12552
|
}
|
|
12535
12553
|
const r = bundle_esm.vector3.dot(edge2, q) / det;
|
|
12536
|
-
|
|
12537
|
-
|
|
12538
|
-
|
|
12554
|
+
// Ignore the case where the computed hit position is negative
|
|
12555
|
+
// if in orthographic to correctly return hit results when close
|
|
12556
|
+
// to the camera.
|
|
12557
|
+
// TODO: revisit with https://vertexvis.atlassian.net/browse/PLAT-1549
|
|
12558
|
+
return !isNaN(r) && (r > 0 || frame.scene.camera.isOrthographic());
|
|
12559
|
+
}
|
|
12560
|
+
|
|
12561
|
+
// Scalar that is used in combination with the camera
|
|
12562
|
+
// components to determine the relative size of the meshes.
|
|
12563
|
+
// This attempts to keep the widget approximately the same
|
|
12564
|
+
// size as zooming occurs.
|
|
12565
|
+
const DEFAULT_MESH_SCALAR = 0.005;
|
|
12539
12566
|
class TransformWidget {
|
|
12540
12567
|
constructor(canvasElement, colors = {}) {
|
|
12541
12568
|
this.canvasElement = canvasElement;
|
|
@@ -12563,7 +12590,7 @@ class TransformWidget {
|
|
|
12563
12590
|
boundsContainsPoint(point) {
|
|
12564
12591
|
return (this.bounds != null &&
|
|
12565
12592
|
this.frame != null &&
|
|
12566
|
-
bundle_esm.rectangle.containsPoints(this.bounds,
|
|
12593
|
+
bundle_esm.rectangle.containsPoints(this.bounds, point));
|
|
12567
12594
|
}
|
|
12568
12595
|
updateFrame(frame, updateMeshes = true) {
|
|
12569
12596
|
this.frame = frame;
|
|
@@ -12578,6 +12605,9 @@ class TransformWidget {
|
|
|
12578
12605
|
if (cursor != null && this.frame != null) {
|
|
12579
12606
|
this.updateHovered();
|
|
12580
12607
|
}
|
|
12608
|
+
else {
|
|
12609
|
+
this.clearHovered();
|
|
12610
|
+
}
|
|
12581
12611
|
}
|
|
12582
12612
|
updatePosition(position) {
|
|
12583
12613
|
var _a;
|
|
@@ -12630,7 +12660,9 @@ class TransformWidget {
|
|
|
12630
12660
|
const previousHovered = this.hoveredMesh;
|
|
12631
12661
|
const currentFrame = this.frame;
|
|
12632
12662
|
if (currentFrame != null) {
|
|
12633
|
-
this.hoveredMesh = this.triangleMeshes
|
|
12663
|
+
this.hoveredMesh = this.triangleMeshes
|
|
12664
|
+
.filter((m) => m.points.valid)
|
|
12665
|
+
.find((m) => this.cursor != null
|
|
12634
12666
|
? testTriangleMesh(m, currentFrame, this.viewport, this.cursor)
|
|
12635
12667
|
: false);
|
|
12636
12668
|
if (this.hoveredMesh !== previousHovered) {
|
|
@@ -12640,6 +12672,14 @@ class TransformWidget {
|
|
|
12640
12672
|
}
|
|
12641
12673
|
}
|
|
12642
12674
|
}
|
|
12675
|
+
clearHovered() {
|
|
12676
|
+
const previousHovered = this.hoveredMesh;
|
|
12677
|
+
this.hoveredMesh = undefined;
|
|
12678
|
+
if (this.hoveredMesh !== previousHovered) {
|
|
12679
|
+
this.hoveredChanged.emit(this.hoveredMesh);
|
|
12680
|
+
previousHovered.updateFillColor(previousHovered.initialFillColor);
|
|
12681
|
+
}
|
|
12682
|
+
}
|
|
12643
12683
|
sortMeshes(frame, ...meshes) {
|
|
12644
12684
|
const compare = (m1, m2) => m1.points.shortestDistanceFrom(frame.scene.camera.position) -
|
|
12645
12685
|
m2.points.shortestDistanceFrom(frame.scene.camera.position);
|
|
@@ -12659,7 +12699,7 @@ class TransformWidget {
|
|
|
12659
12699
|
else {
|
|
12660
12700
|
this.updateMeshes(position, frame);
|
|
12661
12701
|
}
|
|
12662
|
-
this.bounds = computeMesh2dBounds(...this.triangleMeshes);
|
|
12702
|
+
this.bounds = computeMesh2dBounds(this.viewport, ...this.triangleMeshes);
|
|
12663
12703
|
}
|
|
12664
12704
|
createMeshes(position, frame) {
|
|
12665
12705
|
this.reglCommand = regl({
|
|
@@ -12694,7 +12734,9 @@ class TransformWidget {
|
|
|
12694
12734
|
}
|
|
12695
12735
|
}
|
|
12696
12736
|
computeTriangleSize(position, frame) {
|
|
12697
|
-
return (
|
|
12737
|
+
return ((frame.scene.camera.isOrthographic()
|
|
12738
|
+
? frame.scene.camera.fovHeight
|
|
12739
|
+
: bundle_esm.vector3.magnitude(bundle_esm.vector3.subtract(position, frame.scene.camera.position))) * DEFAULT_MESH_SCALAR);
|
|
12698
12740
|
}
|
|
12699
12741
|
}
|
|
12700
12742
|
|
|
@@ -12748,8 +12790,10 @@ let ViewerTransformWidget = class {
|
|
|
12748
12790
|
var _a, _b;
|
|
12749
12791
|
if (this.dragging != null && this.lastWorldPosition != null) {
|
|
12750
12792
|
const currentWorld = convertCanvasPointToWorld(convertPointToCanvas(bundle_esm.point.create(event.clientX, event.clientY), this.getCanvasBounds()), (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame, (_b = this.viewer) === null || _b === void 0 ? void 0 : _b.viewport, this.currentPosition);
|
|
12751
|
-
|
|
12752
|
-
|
|
12793
|
+
if (currentWorld != null) {
|
|
12794
|
+
this.transform(this.lastWorldPosition, currentWorld);
|
|
12795
|
+
this.lastWorldPosition = currentWorld;
|
|
12796
|
+
}
|
|
12753
12797
|
}
|
|
12754
12798
|
};
|
|
12755
12799
|
this.handleEndTransform = async (event) => {
|
|
@@ -15,7 +15,7 @@ const cursors = require('./cursors-6b087455.js');
|
|
|
15
15
|
const dom = require('./dom-b82f5a23.js');
|
|
16
16
|
const scene = require('./scene-7f29039e.js');
|
|
17
17
|
const entities = require('./entities-9eb7e608.js');
|
|
18
|
-
const viewport = require('./viewport-
|
|
18
|
+
const viewport = require('./viewport-aeb8a3f3.js');
|
|
19
19
|
require('./_commonjsHelpers-dcc4cf71.js');
|
|
20
20
|
|
|
21
21
|
/**
|
|
@@ -37,6 +37,16 @@ class Viewport {
|
|
|
37
37
|
static fromDimensions(dimensions) {
|
|
38
38
|
return new Viewport(dimensions.width, dimensions.height);
|
|
39
39
|
}
|
|
40
|
+
/**
|
|
41
|
+
* Transforms a normalized device coordinate to a 2D point within the
|
|
42
|
+
* viewport.
|
|
43
|
+
*
|
|
44
|
+
* @param ndc A 2D point in NDC.
|
|
45
|
+
* @returns A 2D point in the coordinate space of the viewport.
|
|
46
|
+
*/
|
|
47
|
+
transformNdcPointToViewport(ndc) {
|
|
48
|
+
return bundle_esm.point.create(ndc.x * this.center.x + this.center.x, -ndc.y * this.center.y + this.center.y);
|
|
49
|
+
}
|
|
40
50
|
/**
|
|
41
51
|
* Transforms a normalized device coordinate to a 2D point within the
|
|
42
52
|
* viewport.
|
|
@@ -45,7 +55,7 @@ class Viewport {
|
|
|
45
55
|
* @returns A 2D point in the coordinate space of the viewport.
|
|
46
56
|
*/
|
|
47
57
|
transformVectorToViewport(ndc) {
|
|
48
|
-
return
|
|
58
|
+
return this.transformNdcPointToViewport(ndc);
|
|
49
59
|
}
|
|
50
60
|
/**
|
|
51
61
|
* Transforms a world point to 2D point in viewport space.
|
|
@@ -133,9 +143,9 @@ class Viewport {
|
|
|
133
143
|
*/
|
|
134
144
|
transformPointToOrthographicRay(pt, image, camera) {
|
|
135
145
|
const ndc = this.transformScreenPointToNdc(pt, image);
|
|
136
|
-
const
|
|
146
|
+
const origin = bundle_esm.vector3.transformNdcToWorldSpace(bundle_esm.vector3.create(ndc.x, ndc.y, 0), camera.worldMatrix, camera.projectionMatrixInverse);
|
|
137
147
|
return bundle_esm.ray.create({
|
|
138
|
-
origin
|
|
148
|
+
origin,
|
|
139
149
|
direction: bundle_esm.vector3.normalize(camera.viewVector),
|
|
140
150
|
});
|
|
141
151
|
}
|
|
@@ -6,9 +6,20 @@ export function convertPointToCanvas(point, bounds) {
|
|
|
6
6
|
}
|
|
7
7
|
export function convertCanvasPointToWorld(point, frame, viewport, position) {
|
|
8
8
|
if (point != null && frame != null && viewport != null && position != null) {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
if (frame.scene.camera.isOrthographic()) {
|
|
10
|
+
const ray = viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera);
|
|
11
|
+
// Offset the point to past the bounding sphere of the model to
|
|
12
|
+
// adjust the position plane location.
|
|
13
|
+
const offsetPoint = Ray.at(Ray.create({
|
|
14
|
+
origin: position,
|
|
15
|
+
direction: frame.scene.camera.direction,
|
|
16
|
+
}), Vector3.magnitude(frame.scene.camera.viewVector) * 2);
|
|
17
|
+
return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, offsetPoint));
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
const ray = viewport.transformPointToRay(point, frame.image, frame.scene.camera);
|
|
21
|
+
return Ray.intersectPlane(ray, Plane.fromNormalAndCoplanarPoint(frame.scene.camera.direction, position));
|
|
22
|
+
}
|
|
12
23
|
}
|
|
13
24
|
return undefined;
|
|
14
25
|
}
|
|
@@ -24,4 +35,4 @@ export function computeUpdatedPosition(current, previous, next, identifier) {
|
|
|
24
35
|
return current;
|
|
25
36
|
}
|
|
26
37
|
}
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL3ZpZXdlci10cmFuc2Zvcm0td2lkZ2V0L3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBSWpFLE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsS0FBa0IsRUFDbEIsTUFBZ0I7RUFFaEIsT0FBTyxNQUFNLElBQUksSUFBSTtJQUNuQixDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDO0lBQzNELENBQUMsQ0FBQyxTQUFTLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSx5QkFBeUIsQ0FDdkMsS0FBbUIsRUFDbkIsS0FBYSxFQUNiLFFBQW1CLEVBQ25CLFFBQTBCO0VBRTFCLElBQUksS0FBSyxJQUFJLElBQUksSUFBSSxLQUFLLElBQUksSUFBSSxJQUFJLFFBQVEsSUFBSSxJQUFJLElBQUksUUFBUSxJQUFJLElBQUksRUFBRTtJQUMxRSxJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsRUFBRSxFQUFFO01BQ3ZDLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQywrQkFBK0IsQ0FDbEQsS0FBSyxFQUNMLEtBQUssQ0FBQyxLQUFLLEVBQ1gsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQ25CLENBQUM7TUFDRiwrREFBK0Q7TUFDL0Qsc0NBQXNDO01BQ3RDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQyxFQUFFLENBQ3hCLEdBQUcsQ0FBQyxNQUFNLENBQUM7UUFDVCxNQUFNLEVBQUUsUUFBUTtRQUNoQixTQUFTLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUztPQUN4QyxDQUFDLEVBQ0YsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQ3JELENBQUM7TUFFRixPQUFPLEdBQUcsQ0FBQyxjQUFjLENBQ3ZCLEdBQUcsRUFDSCxLQUFLLENBQUMsMEJBQTBCLENBQzlCLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFDNUIsV0FBVyxDQUNaLENBQ0YsQ0FBQztLQUNIO1NBQU07TUFDTCxNQUFNLEdBQUcsR0FBRyxRQUFRLENBQUMsbUJBQW1CLENBQ3RDLEtBQUssRUFDTCxLQUFLLENBQUMsS0FBSyxFQUNYLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUNuQixDQUFDO01BRUYsT0FBTyxHQUFHLENBQUMsY0FBYyxDQUN2QixHQUFHLEVBQ0gsS0FBSyxDQUFDLDBCQUEwQixDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsQ0FDekUsQ0FBQztLQUNIO0dBQ0Y7RUFDRCxPQUFPLFNBQVMsQ0FBQztBQUNuQixDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQixDQUNwQyxPQUF3QixFQUN4QixRQUF5QixFQUN6QixJQUFxQixFQUNyQixVQUFrQjtFQUVsQixRQUFRLFVBQVUsRUFBRTtJQUNsQixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSixLQUFLLGFBQWE7TUFDaEIsdUNBQ0ssT0FBTyxLQUNWLENBQUMsRUFBRSxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUMsSUFDakQ7SUFDSjtNQUNFLE9BQU8sT0FBTyxDQUFDO0dBQ2xCO0FBQ0gsQ0FBQyJ9
|
|
@@ -51,8 +51,10 @@ export class ViewerTransformWidget {
|
|
|
51
51
|
var _a, _b;
|
|
52
52
|
if (this.dragging != null && this.lastWorldPosition != null) {
|
|
53
53
|
const currentWorld = convertCanvasPointToWorld(convertPointToCanvas(Point.create(event.clientX, event.clientY), this.getCanvasBounds()), (_a = this.viewer) === null || _a === void 0 ? void 0 : _a.frame, (_b = this.viewer) === null || _b === void 0 ? void 0 : _b.viewport, this.currentPosition);
|
|
54
|
-
|
|
55
|
-
|
|
54
|
+
if (currentWorld != null) {
|
|
55
|
+
this.transform(this.lastWorldPosition, currentWorld);
|
|
56
|
+
this.lastWorldPosition = currentWorld;
|
|
57
|
+
}
|
|
56
58
|
}
|
|
57
59
|
};
|
|
58
60
|
this.handleEndTransform = async (event) => {
|
|
@@ -344,4 +346,4 @@ export class ViewerTransformWidget {
|
|
|
344
346
|
"methodName": "handlePositionChanged"
|
|
345
347
|
}]; }
|
|
346
348
|
}
|
|
347
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-transform-widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/viewer-transform-widget.tsx"],"names":[],"mappings":"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"}
|
|
349
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewer-transform-widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/viewer-transform-widget.tsx"],"names":[],"mappings":"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"}
|
|
@@ -7,6 +7,11 @@ import { xAxisArrowPositions, yAxisArrowPositions, zAxisArrowPositions, } from '
|
|
|
7
7
|
import { testTriangleMesh } from '../../lib/transforms/hits';
|
|
8
8
|
import { AxisMesh, computeMesh2dBounds, TriangleMesh, } from '../../lib/transforms/mesh';
|
|
9
9
|
import { Viewport } from '../../lib/types';
|
|
10
|
+
// Scalar that is used in combination with the camera
|
|
11
|
+
// components to determine the relative size of the meshes.
|
|
12
|
+
// This attempts to keep the widget approximately the same
|
|
13
|
+
// size as zooming occurs.
|
|
14
|
+
export const DEFAULT_MESH_SCALAR = 0.005;
|
|
10
15
|
export class TransformWidget {
|
|
11
16
|
constructor(canvasElement, colors = {}) {
|
|
12
17
|
this.canvasElement = canvasElement;
|
|
@@ -34,7 +39,7 @@ export class TransformWidget {
|
|
|
34
39
|
boundsContainsPoint(point) {
|
|
35
40
|
return (this.bounds != null &&
|
|
36
41
|
this.frame != null &&
|
|
37
|
-
Rectangle.containsPoints(this.bounds,
|
|
42
|
+
Rectangle.containsPoints(this.bounds, point));
|
|
38
43
|
}
|
|
39
44
|
updateFrame(frame, updateMeshes = true) {
|
|
40
45
|
this.frame = frame;
|
|
@@ -49,6 +54,9 @@ export class TransformWidget {
|
|
|
49
54
|
if (cursor != null && this.frame != null) {
|
|
50
55
|
this.updateHovered();
|
|
51
56
|
}
|
|
57
|
+
else {
|
|
58
|
+
this.clearHovered();
|
|
59
|
+
}
|
|
52
60
|
}
|
|
53
61
|
updatePosition(position) {
|
|
54
62
|
var _a;
|
|
@@ -101,7 +109,9 @@ export class TransformWidget {
|
|
|
101
109
|
const previousHovered = this.hoveredMesh;
|
|
102
110
|
const currentFrame = this.frame;
|
|
103
111
|
if (currentFrame != null) {
|
|
104
|
-
this.hoveredMesh = this.triangleMeshes
|
|
112
|
+
this.hoveredMesh = this.triangleMeshes
|
|
113
|
+
.filter((m) => m.points.valid)
|
|
114
|
+
.find((m) => this.cursor != null
|
|
105
115
|
? testTriangleMesh(m, currentFrame, this.viewport, this.cursor)
|
|
106
116
|
: false);
|
|
107
117
|
if (this.hoveredMesh !== previousHovered) {
|
|
@@ -111,6 +121,14 @@ export class TransformWidget {
|
|
|
111
121
|
}
|
|
112
122
|
}
|
|
113
123
|
}
|
|
124
|
+
clearHovered() {
|
|
125
|
+
const previousHovered = this.hoveredMesh;
|
|
126
|
+
this.hoveredMesh = undefined;
|
|
127
|
+
if (this.hoveredMesh !== previousHovered) {
|
|
128
|
+
this.hoveredChanged.emit(this.hoveredMesh);
|
|
129
|
+
previousHovered.updateFillColor(previousHovered.initialFillColor);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
114
132
|
sortMeshes(frame, ...meshes) {
|
|
115
133
|
const compare = (m1, m2) => m1.points.shortestDistanceFrom(frame.scene.camera.position) -
|
|
116
134
|
m2.points.shortestDistanceFrom(frame.scene.camera.position);
|
|
@@ -130,7 +148,7 @@ export class TransformWidget {
|
|
|
130
148
|
else {
|
|
131
149
|
this.updateMeshes(position, frame);
|
|
132
150
|
}
|
|
133
|
-
this.bounds = computeMesh2dBounds(...this.triangleMeshes);
|
|
151
|
+
this.bounds = computeMesh2dBounds(this.viewport, ...this.triangleMeshes);
|
|
134
152
|
}
|
|
135
153
|
createMeshes(position, frame) {
|
|
136
154
|
this.reglCommand = regl({
|
|
@@ -165,7 +183,9 @@ export class TransformWidget {
|
|
|
165
183
|
}
|
|
166
184
|
}
|
|
167
185
|
computeTriangleSize(position, frame) {
|
|
168
|
-
return (
|
|
186
|
+
return ((frame.scene.camera.isOrthographic()
|
|
187
|
+
? frame.scene.camera.fovHeight
|
|
188
|
+
: Vector3.magnitude(Vector3.subtract(position, frame.scene.camera.position))) * DEFAULT_MESH_SCALAR);
|
|
169
189
|
}
|
|
170
190
|
}
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/widget.ts"],"names":[],"mappings":"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"}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"","sources":["../../../src/components/viewer-transform-widget/widget.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,13 +4,17 @@ import { BoundingBox, Vector3 } from '@vertexvis/geometry';
|
|
|
4
4
|
*/
|
|
5
5
|
export function testTriangleMesh(mesh, frame, viewport, point) {
|
|
6
6
|
var _a;
|
|
7
|
-
const ray =
|
|
7
|
+
const ray = frame.scene.camera.isOrthographic()
|
|
8
|
+
? viewport.transformPointToOrthographicRay(point, frame.image, frame.scene.camera)
|
|
9
|
+
: viewport.transformPointToRay(point, frame.image, frame.scene.camera);
|
|
8
10
|
const edge1 = Vector3.subtract(mesh.points.worldRight, mesh.points.worldLeft);
|
|
9
11
|
const edge2 = Vector3.subtract(mesh.points.worldTip, mesh.points.worldLeft);
|
|
10
12
|
const epsilon = BoundingBox.epsilon((_a = BoundingBox.fromVectors([ray.direction, ray.origin, edge1, edge2])) !== null && _a !== void 0 ? _a : BoundingBox.create(edge1, edge2));
|
|
11
13
|
const p = Vector3.cross(ray.direction, edge2);
|
|
12
14
|
const det = Vector3.dot(edge1, p);
|
|
13
|
-
|
|
15
|
+
// This check causes a `det` of NaN or 0 to return false
|
|
16
|
+
// without needing to perform the subsequent calculations.
|
|
17
|
+
if (!(Math.abs(det) >= epsilon)) {
|
|
14
18
|
return false;
|
|
15
19
|
}
|
|
16
20
|
const t = Vector3.subtract(ray.origin, mesh.points.worldLeft);
|
|
@@ -24,6 +28,10 @@ export function testTriangleMesh(mesh, frame, viewport, point) {
|
|
|
24
28
|
return false;
|
|
25
29
|
}
|
|
26
30
|
const r = Vector3.dot(edge2, q) / det;
|
|
27
|
-
|
|
31
|
+
// Ignore the case where the computed hit position is negative
|
|
32
|
+
// if in orthographic to correctly return hit results when close
|
|
33
|
+
// to the camera.
|
|
34
|
+
// TODO: revisit with https://vertexvis.atlassian.net/browse/PLAT-1549
|
|
35
|
+
return !isNaN(r) && (r > 0 || frame.scene.camera.isOrthographic());
|
|
28
36
|
}
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGl0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9oaXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQVMsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFLbEU7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQzlCLElBQWtCLEVBQ2xCLEtBQVksRUFDWixRQUFrQixFQUNsQixLQUFrQjs7RUFFbEIsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsY0FBYyxFQUFFO0lBQzdDLENBQUMsQ0FBQyxRQUFRLENBQUMsK0JBQStCLENBQ3RDLEtBQUssRUFDTCxLQUFLLENBQUMsS0FBSyxFQUNYLEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUNuQjtJQUNILENBQUMsQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztFQUV6RSxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFDOUUsTUFBTSxLQUFLLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0VBRTVFLE1BQU0sT0FBTyxHQUFHLFdBQVcsQ0FBQyxPQUFPLENBQ2pDLE1BQUEsV0FBVyxDQUFDLFdBQVcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsR0FBRyxDQUFDLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsbUNBQ2hFLFdBQVcsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUNuQyxDQUFDO0VBRUYsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO0VBQzlDLE1BQU0sR0FBRyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO0VBRWxDLHdEQUF3RDtFQUN4RCwwREFBMEQ7RUFDMUQsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxPQUFPLENBQUMsRUFBRTtJQUMvQixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7RUFDOUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRWxDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFO0lBQ2xCLE9BQU8sS0FBSyxDQUFDO0dBQ2Q7RUFFRCxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztFQUNsQyxNQUFNLENBQUMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRTlDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtJQUN0QixPQUFPLEtBQUssQ0FBQztHQUNkO0VBRUQsTUFBTSxDQUFDLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsR0FBRyxDQUFDO0VBRXRDLDhEQUE4RDtFQUM5RCxnRUFBZ0U7RUFDaEUsaUJBQWlCO0VBQ2pCLHNFQUFzRTtFQUN0RSxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsSUFBSSxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDO0FBQ3JFLENBQUMifQ==
|
|
@@ -84,17 +84,20 @@ export class TriangleMesh extends Mesh {
|
|
|
84
84
|
: Color.toHexString(outlineColor), typeof fillColor === 'string' ? fillColor : Color.toHexString(fillColor), shapeProps);
|
|
85
85
|
}
|
|
86
86
|
}
|
|
87
|
-
export function computeMesh2dBounds(...meshes) {
|
|
87
|
+
export function computeMesh2dBounds(viewport, ...meshes) {
|
|
88
88
|
let min = Point.create(Number.MAX_SAFE_INTEGER, Number.MAX_SAFE_INTEGER);
|
|
89
89
|
let max = Point.create();
|
|
90
90
|
meshes
|
|
91
91
|
.filter((m) => m.points.valid)
|
|
92
92
|
.map((m) => {
|
|
93
|
-
m.points
|
|
93
|
+
m.points
|
|
94
|
+
.toArray()
|
|
95
|
+
.map((pt) => viewport.transformNdcPointToViewport(pt))
|
|
96
|
+
.forEach((pt) => {
|
|
94
97
|
min = Point.create(Math.min(pt.x, min.x), Math.min(pt.y, min.y));
|
|
95
98
|
max = Point.create(Math.max(pt.x, max.x), Math.max(pt.y, max.y));
|
|
96
99
|
});
|
|
97
100
|
});
|
|
98
101
|
return Rectangle.fromPoints(min, max);
|
|
99
102
|
}
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvdHJhbnNmb3Jtcy9tZXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUt6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFXM0MsTUFBTSxPQUFnQixJQUFJO0VBT3hCLFlBQ1ksV0FBd0IsRUFDM0IsVUFBa0IsRUFDbEIsTUFBUyxFQUNULFlBQW9CLEVBQ3BCLFNBQWlCLEVBQ2pCLGFBQWtDLEVBQUU7SUFMakMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFDM0IsZUFBVSxHQUFWLFVBQVUsQ0FBUTtJQUNsQixXQUFNLEdBQU4sTUFBTSxDQUFHO0lBQ1QsaUJBQVksR0FBWixZQUFZLENBQVE7SUFDcEIsY0FBUyxHQUFULFNBQVMsQ0FBUTtJQUNqQixlQUFVLEdBQVYsVUFBVSxDQUEwQjtJQUUzQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7SUFFdkMsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLFlBQVksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQzlELGlCQUFpQixDQUFDLGFBQWEsQ0FBQyxDQUFDLE9BQU8sQ0FDdEMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQ3BDLENBQUM7SUFFRixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsU0FBUyxDQUFDO0lBRWxDLElBQUksQ0FBQyxJQUFJLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQyxXQUFXLGtCQUN0QyxLQUFLLEVBQUUsYUFBYSxDQUFDLE1BQU0sRUFDM0IsU0FBUyxFQUFFLENBQUMsRUFDWixJQUFJLEVBQUUsTUFBbUIsRUFDekIsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQ3BCLEtBQUssRUFBRSxJQUFJLENBQUMsWUFBWSxJQUNyQixVQUFVLEVBQ2IsQ0FBQztFQUNMLENBQUM7RUFFTSxlQUFlLENBQUMsS0FBNEI7SUFDakQsSUFBSSxLQUFLLElBQUksSUFBSSxFQUFFO01BQ2pCLElBQUksQ0FBQyxTQUFTO1FBQ1osT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7S0FDaEU7RUFDSCxDQUFDO0VBRU0sWUFBWSxDQUFDLE1BQVM7SUFDM0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDckIsaUJBQWlCLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTyxDQUN6QyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FDcEMsQ0FBQztFQUNKLENBQUM7Q0FDRjtBQUVELE1BQU0sT0FBTyxjQUFjO0VBQ3pCLFlBQ1MsS0FBYyxFQUNkLFdBQTRCLEVBQzVCLFFBQXlCLEVBQ3pCLE1BQW1CLEVBQ25CLEdBQWdCO0lBSmhCLFVBQUssR0FBTCxLQUFLLENBQVM7SUFDZCxnQkFBVyxHQUFYLFdBQVcsQ0FBaUI7SUFDNUIsYUFBUSxHQUFSLFFBQVEsQ0FBaUI7SUFDekIsV0FBTSxHQUFOLE1BQU0sQ0FBYTtJQUNuQixRQUFHLEdBQUgsR0FBRyxDQUFhO0VBQ3RCLENBQUM7RUFFRyxvQkFBb0IsQ0FBQyxNQUF1QjtJQUNqRCxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUU7T0FDdkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztPQUN2QyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7RUFDOUIsQ0FBQztFQUVNLFlBQVk7SUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0VBQzNDLENBQUM7RUFFTSxPQUFPO0lBQ1osT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0VBQ2pDLENBQUM7Q0FDRjtBQUVELE1BQU0sT0FBTyxRQUFTLFNBQVEsSUFBb0I7RUFDaEQsWUFDRSxXQUF3QixFQUN4QixVQUFrQixFQUNsQixNQUFzQixFQUN0QixlQUFxQyxTQUFTLEVBQzlDLFlBQWtDLFNBQVMsRUFDM0MsYUFBa0MsRUFBRTtJQUVwQyxLQUFLLENBQ0gsV0FBVyxFQUNYLFVBQVUsRUFDVixNQUFNLEVBQ04sT0FBTyxZQUFZLEtBQUssUUFBUTtNQUM5QixDQUFDLENBQUMsWUFBWTtNQUNkLENBQUMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLFlBQVksQ0FBQyxFQUNuQyxPQUFPLFNBQVMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsRUFDeEUsVUFBVSxDQUNYLENBQUM7RUFDSixDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sa0JBQWtCO0VBQzdCLFlBQ1MsS0FBYyxFQUNkLFNBQTBCLEVBQzFCLFNBQTBCLEVBQzFCLFVBQTJCLEVBQzNCLFFBQXlCLEVBQ3pCLElBQWlCLEVBQ2pCLElBQWlCLEVBQ2pCLEtBQWtCLEVBQ2xCLEdBQWdCO0lBUmhCLFVBQUssR0FBTCxLQUFLLENBQVM7SUFDZCxjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUMxQixjQUFTLEdBQVQsU0FBUyxDQUFpQjtJQUMxQixlQUFVLEdBQVYsVUFBVSxDQUFpQjtJQUMzQixhQUFRLEdBQVIsUUFBUSxDQUFpQjtJQUN6QixTQUFJLEdBQUosSUFBSSxDQUFhO0lBQ2pCLFNBQUksR0FBSixJQUFJLENBQWE7SUFDakIsVUFBSyxHQUFMLEtBQUssQ0FBYTtJQUNsQixRQUFHLEdBQUgsR0FBRyxDQUFhO0VBQ3RCLENBQUM7RUFFRyxvQkFBb0IsQ0FBQyxNQUF1QjtJQUNqRCxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUU7T0FDdkIsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQztPQUN2QyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7RUFDOUIsQ0FBQztFQUVNLFlBQVk7SUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztFQUMxRSxDQUFDO0VBRU0sT0FBTztJQUNaLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztFQUNqRSxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sWUFBYSxTQUFRLElBQXdCO0VBQ3hELFlBQ0UsV0FBd0IsRUFDeEIsVUFBa0IsRUFDbEIsTUFBMEIsRUFDMUIsZUFBcUMsU0FBUyxFQUM5QyxZQUFrQyxTQUFTLEVBQzNDLGFBQWtDLEVBQUU7SUFFcEMsS0FBSyxDQUNILFdBQVcsRUFDWCxVQUFVLEVBQ1YsTUFBTSxFQUNOLE9BQU8sWUFBWSxLQUFLLFFBQVE7TUFDOUIsQ0FBQyxDQUFDLFlBQVk7TUFDZCxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsRUFDbkMsT0FBTyxTQUFTLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsU0FBUyxDQUFDLEVBQ3hFLFVBQVUsQ0FDWCxDQUFDO0VBQ0osQ0FBQztDQUNGO0FBRUQsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxRQUFrQixFQUNsQixHQUFHLE1BQWM7RUFFakIsSUFBSSxHQUFHLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLEVBQUUsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7RUFDekUsSUFBSSxHQUFHLEdBQUcsS0FBSyxDQUFDLE1BQU0sRUFBRSxDQUFDO0VBRXpCLE1BQU07S0FDSCxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO0tBQzdCLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO0lBQ1QsQ0FBQyxDQUFDLE1BQU07T0FDTCxPQUFPLEVBQUU7T0FDVCxHQUFHLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQywyQkFBMkIsQ0FBQyxFQUFFLENBQUMsQ0FBQztPQUNyRCxPQUFPLENBQUMsQ0FBQyxFQUFFLEVBQUUsRUFBRTtNQUNkLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO01BQ2pFLEdBQUcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25FLENBQUMsQ0FBQyxDQUFDO0VBQ1AsQ0FBQyxDQUFDLENBQUM7RUFFTCxPQUFPLFNBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0FBQ3hDLENBQUMifQ==
|