@vertexvis/viewer 0.18.2-testing.0 → 0.18.2-testing.1
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-b99cd335.js +126 -1
- package/dist/esm/index-fd7d7b68.js +126 -1
- package/package.json +7 -7
- package/dist/components/_commonjsHelpers.js +0 -41
- package/dist/components/_commonjsHelpers.js.map +0 -1
- package/dist/components/browser.esm.js +0 -3173
- package/dist/components/browser.esm.js.map +0 -1
- package/dist/components/bundle.esm.js +0 -2250
- package/dist/components/bundle.esm.js.map +0 -1
- package/dist/components/bundle.esm2.js +0 -39740
- package/dist/components/bundle.esm2.js.map +0 -1
- package/dist/components/config.js +0 -81
- package/dist/components/config.js.map +0 -1
- package/dist/components/controller.js +0 -7627
- package/dist/components/controller.js.map +0 -1
- package/dist/components/controller2.js +0 -124
- package/dist/components/controller2.js.map +0 -1
- package/dist/components/controller3.js +0 -111
- package/dist/components/controller3.js.map +0 -1
- package/dist/components/cursors.js +0 -110
- package/dist/components/cursors.js.map +0 -1
- package/dist/components/dom.js +0 -43
- package/dist/components/dom.js.map +0 -1
- package/dist/components/dom2.js +0 -10
- package/dist/components/dom2.js.map +0 -1
- package/dist/components/elementRectObserver.js +0 -25
- package/dist/components/elementRectObserver.js.map +0 -1
- package/dist/components/entities.js +0 -179
- package/dist/components/entities.js.map +0 -1
- package/dist/components/errors.js +0 -80
- package/dist/components/errors.js.map +0 -1
- package/dist/components/events.js +0 -11
- package/dist/components/events.js.map +0 -1
- package/dist/components/index.d.ts +0 -26
- package/dist/components/index.js +0 -365
- package/dist/components/index.js.map +0 -1
- package/dist/components/index2.js +0 -63
- package/dist/components/index2.js.map +0 -1
- package/dist/components/interactions.js +0 -236
- package/dist/components/interactions.js.map +0 -1
- package/dist/components/mapper.js +0 -9811
- package/dist/components/mapper.js.map +0 -1
- package/dist/components/markup.js +0 -33
- package/dist/components/markup.js.map +0 -1
- package/dist/components/model.js +0 -134
- package/dist/components/model.js.map +0 -1
- package/dist/components/model2.js +0 -157
- package/dist/components/model2.js.map +0 -1
- package/dist/components/overlays.js +0 -76
- package/dist/components/overlays.js.map +0 -1
- package/dist/components/png-decoder.js +0 -2405
- package/dist/components/png-decoder.js.map +0 -1
- package/dist/components/regl-component.js +0 -12582
- package/dist/components/regl-component.js.map +0 -1
- package/dist/components/results.js +0 -24
- package/dist/components/results.js.map +0 -1
- package/dist/components/row.js +0 -32
- package/dist/components/row.js.map +0 -1
- package/dist/components/scene-tree-search.js +0 -146
- package/dist/components/scene-tree-search.js.map +0 -1
- package/dist/components/scene-tree-table-layout.js +0 -928
- package/dist/components/scene-tree-table-layout.js.map +0 -1
- package/dist/components/scene-tree-toolbar.js +0 -35
- package/dist/components/scene-tree-toolbar.js.map +0 -1
- package/dist/components/scene.js +0 -1508
- package/dist/components/scene.js.map +0 -1
- package/dist/components/stencil.js +0 -25
- package/dist/components/stencil.js.map +0 -1
- package/dist/components/streamAttributes.js +0 -40833
- package/dist/components/streamAttributes.js.map +0 -1
- package/dist/components/templates.js +0 -36
- package/dist/components/templates.js.map +0 -1
- package/dist/components/tslib.es6.js +0 -125
- package/dist/components/tslib.es6.js.map +0 -1
- package/dist/components/vertex-scene-tree-search.d.ts +0 -11
- package/dist/components/vertex-scene-tree-search.js +0 -11
- package/dist/components/vertex-scene-tree-search.js.map +0 -1
- package/dist/components/vertex-scene-tree-table-cell.d.ts +0 -11
- package/dist/components/vertex-scene-tree-table-cell.js +0 -209
- package/dist/components/vertex-scene-tree-table-cell.js.map +0 -1
- package/dist/components/vertex-scene-tree-table-column.d.ts +0 -11
- package/dist/components/vertex-scene-tree-table-column.js +0 -42
- package/dist/components/vertex-scene-tree-table-column.js.map +0 -1
- package/dist/components/vertex-scene-tree-table-header.d.ts +0 -11
- package/dist/components/vertex-scene-tree-table-header.js +0 -38
- package/dist/components/vertex-scene-tree-table-header.js.map +0 -1
- package/dist/components/vertex-scene-tree-table-layout.d.ts +0 -11
- package/dist/components/vertex-scene-tree-table-layout.js +0 -11
- package/dist/components/vertex-scene-tree-table-layout.js.map +0 -1
- package/dist/components/vertex-scene-tree-table-resize-divider.d.ts +0 -11
- package/dist/components/vertex-scene-tree-table-resize-divider.js +0 -57
- package/dist/components/vertex-scene-tree-table-resize-divider.js.map +0 -1
- package/dist/components/vertex-scene-tree-toolbar-group.d.ts +0 -11
- package/dist/components/vertex-scene-tree-toolbar-group.js +0 -38
- package/dist/components/vertex-scene-tree-toolbar-group.js.map +0 -1
- package/dist/components/vertex-scene-tree-toolbar.d.ts +0 -11
- package/dist/components/vertex-scene-tree-toolbar.js +0 -11
- package/dist/components/vertex-scene-tree-toolbar.js.map +0 -1
- package/dist/components/vertex-scene-tree.d.ts +0 -11
- package/dist/components/vertex-scene-tree.js +0 -803
- package/dist/components/vertex-scene-tree.js.map +0 -1
- package/dist/components/vertex-viewer-box-query-tool.d.ts +0 -11
- package/dist/components/vertex-viewer-box-query-tool.js +0 -352
- package/dist/components/vertex-viewer-box-query-tool.js.map +0 -1
- package/dist/components/vertex-viewer-button.d.ts +0 -11
- package/dist/components/vertex-viewer-button.js +0 -11
- package/dist/components/vertex-viewer-button.js.map +0 -1
- package/dist/components/vertex-viewer-default-toolbar.d.ts +0 -11
- package/dist/components/vertex-viewer-default-toolbar.js +0 -99
- package/dist/components/vertex-viewer-default-toolbar.js.map +0 -1
- package/dist/components/vertex-viewer-dom-element.d.ts +0 -11
- package/dist/components/vertex-viewer-dom-element.js +0 -11
- package/dist/components/vertex-viewer-dom-element.js.map +0 -1
- package/dist/components/vertex-viewer-dom-group.d.ts +0 -11
- package/dist/components/vertex-viewer-dom-group.js +0 -11
- package/dist/components/vertex-viewer-dom-group.js.map +0 -1
- package/dist/components/vertex-viewer-dom-renderer.d.ts +0 -11
- package/dist/components/vertex-viewer-dom-renderer.js +0 -11
- package/dist/components/vertex-viewer-dom-renderer.js.map +0 -1
- package/dist/components/vertex-viewer-hit-result-indicator.d.ts +0 -11
- package/dist/components/vertex-viewer-hit-result-indicator.js +0 -335
- package/dist/components/vertex-viewer-hit-result-indicator.js.map +0 -1
- package/dist/components/vertex-viewer-icon.d.ts +0 -11
- package/dist/components/vertex-viewer-icon.js +0 -11
- package/dist/components/vertex-viewer-icon.js.map +0 -1
- package/dist/components/vertex-viewer-layer.d.ts +0 -11
- package/dist/components/vertex-viewer-layer.js +0 -11
- package/dist/components/vertex-viewer-layer.js.map +0 -1
- package/dist/components/vertex-viewer-markup-arrow.d.ts +0 -11
- package/dist/components/vertex-viewer-markup-arrow.js +0 -11
- package/dist/components/vertex-viewer-markup-arrow.js.map +0 -1
- package/dist/components/vertex-viewer-markup-circle.d.ts +0 -11
- package/dist/components/vertex-viewer-markup-circle.js +0 -11
- package/dist/components/vertex-viewer-markup-circle.js.map +0 -1
- package/dist/components/vertex-viewer-markup-freeform.d.ts +0 -11
- package/dist/components/vertex-viewer-markup-freeform.js +0 -11
- package/dist/components/vertex-viewer-markup-freeform.js.map +0 -1
- package/dist/components/vertex-viewer-markup-tool.d.ts +0 -11
- package/dist/components/vertex-viewer-markup-tool.js +0 -257
- package/dist/components/vertex-viewer-markup-tool.js.map +0 -1
- package/dist/components/vertex-viewer-markup.d.ts +0 -11
- package/dist/components/vertex-viewer-markup.js +0 -362
- package/dist/components/vertex-viewer-markup.js.map +0 -1
- package/dist/components/vertex-viewer-measurement-details.d.ts +0 -11
- package/dist/components/vertex-viewer-measurement-details.js +0 -307
- package/dist/components/vertex-viewer-measurement-details.js.map +0 -1
- package/dist/components/vertex-viewer-measurement-distance.d.ts +0 -11
- package/dist/components/vertex-viewer-measurement-distance.js +0 -1067
- package/dist/components/vertex-viewer-measurement-distance.js.map +0 -1
- package/dist/components/vertex-viewer-measurement-line.d.ts +0 -11
- package/dist/components/vertex-viewer-measurement-line.js +0 -11
- package/dist/components/vertex-viewer-measurement-line.js.map +0 -1
- package/dist/components/vertex-viewer-measurement-overlays.d.ts +0 -11
- package/dist/components/vertex-viewer-measurement-overlays.js +0 -11
- package/dist/components/vertex-viewer-measurement-overlays.js.map +0 -1
- package/dist/components/vertex-viewer-measurement-precise.d.ts +0 -11
- package/dist/components/vertex-viewer-measurement-precise.js +0 -362
- package/dist/components/vertex-viewer-measurement-precise.js.map +0 -1
- package/dist/components/vertex-viewer-pin-group.d.ts +0 -11
- package/dist/components/vertex-viewer-pin-group.js +0 -11
- package/dist/components/vertex-viewer-pin-group.js.map +0 -1
- package/dist/components/vertex-viewer-pin-label-line.d.ts +0 -11
- package/dist/components/vertex-viewer-pin-label-line.js +0 -11
- package/dist/components/vertex-viewer-pin-label-line.js.map +0 -1
- package/dist/components/vertex-viewer-pin-label.d.ts +0 -11
- package/dist/components/vertex-viewer-pin-label.js +0 -11
- package/dist/components/vertex-viewer-pin-label.js.map +0 -1
- package/dist/components/vertex-viewer-pin-tool.d.ts +0 -11
- package/dist/components/vertex-viewer-pin-tool.js +0 -430
- package/dist/components/vertex-viewer-pin-tool.js.map +0 -1
- package/dist/components/vertex-viewer-spinner.d.ts +0 -11
- package/dist/components/vertex-viewer-spinner.js +0 -11
- package/dist/components/vertex-viewer-spinner.js.map +0 -1
- package/dist/components/vertex-viewer-toolbar-group.d.ts +0 -11
- package/dist/components/vertex-viewer-toolbar-group.js +0 -11
- package/dist/components/vertex-viewer-toolbar-group.js.map +0 -1
- package/dist/components/vertex-viewer-toolbar.d.ts +0 -11
- package/dist/components/vertex-viewer-toolbar.js +0 -11
- package/dist/components/vertex-viewer-toolbar.js.map +0 -1
- package/dist/components/vertex-viewer-transform-widget.d.ts +0 -11
- package/dist/components/vertex-viewer-transform-widget.js +0 -838
- package/dist/components/vertex-viewer-transform-widget.js.map +0 -1
- package/dist/components/vertex-viewer-view-cube.d.ts +0 -11
- package/dist/components/vertex-viewer-view-cube.js +0 -270
- package/dist/components/vertex-viewer-view-cube.js.map +0 -1
- package/dist/components/vertex-viewer.d.ts +0 -11
- package/dist/components/vertex-viewer.js +0 -3543
- package/dist/components/vertex-viewer.js.map +0 -1
- package/dist/components/viewer-button.js +0 -35
- package/dist/components/viewer-button.js.map +0 -1
- package/dist/components/viewer-dom-element.js +0 -250
- package/dist/components/viewer-dom-element.js.map +0 -1
- package/dist/components/viewer-dom-group.js +0 -214
- package/dist/components/viewer-dom-group.js.map +0 -1
- package/dist/components/viewer-dom-renderer.js +0 -295
- package/dist/components/viewer-dom-renderer.js.map +0 -1
- package/dist/components/viewer-icon.js +0 -87
- package/dist/components/viewer-icon.js.map +0 -1
- package/dist/components/viewer-layer.js +0 -46
- package/dist/components/viewer-layer.js.map +0 -1
- package/dist/components/viewer-markup-arrow.js +0 -235
- package/dist/components/viewer-markup-arrow.js.map +0 -1
- package/dist/components/viewer-markup-circle-components.js +0 -42
- package/dist/components/viewer-markup-circle-components.js.map +0 -1
- package/dist/components/viewer-markup-circle.js +0 -201
- package/dist/components/viewer-markup-circle.js.map +0 -1
- package/dist/components/viewer-markup-freeform.js +0 -251
- package/dist/components/viewer-markup-freeform.js.map +0 -1
- package/dist/components/viewer-measurement-line.js +0 -77
- package/dist/components/viewer-measurement-line.js.map +0 -1
- package/dist/components/viewer-measurement-overlays.js +0 -184
- package/dist/components/viewer-measurement-overlays.js.map +0 -1
- package/dist/components/viewer-pin-group.js +0 -207
- package/dist/components/viewer-pin-group.js.map +0 -1
- package/dist/components/viewer-pin-label-line.js +0 -43
- package/dist/components/viewer-pin-label-line.js.map +0 -1
- package/dist/components/viewer-pin-label.js +0 -427
- package/dist/components/viewer-pin-label.js.map +0 -1
- package/dist/components/viewer-spinner.js +0 -53
- package/dist/components/viewer-spinner.js.map +0 -1
- package/dist/components/viewer-toolbar-group.js +0 -42
- package/dist/components/viewer-toolbar-group.js.map +0 -1
- package/dist/components/viewer-toolbar.js +0 -61
- package/dist/components/viewer-toolbar.js.map +0 -1
- package/dist/components/viewport.js +0 -188
- package/dist/components/viewport.js.map +0 -1
- package/dist/components/wrappers_pb.js +0 -1926
- package/dist/components/wrappers_pb.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"file":"bundle.esm.js","mappings":"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,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC3E,IAAI,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;AAC3E,IAAI,IAAI,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAC7E,IAAI,IAAI,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;AAC/E,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AACpC,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CA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CAAC;AACf,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC5D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC5D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC7D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC7D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC5D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC5D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC7D,IAAI,IAAI,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;AAC7D,IAAI,IAAI,GAAG,GAAG,YAAY,EAAE,CAAC;AAC7B,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC3D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAC5D,IAAI,OAAO,GAAG,CAAC;AACf,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,SAAS,CAAC,MAAM,EAAE;AAC3B;AACA,IAAI,OAAO;AACX,QAAQ,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;AACnD,QAAQ,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;AACnD,QAAQ,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;AACpD,QAAQ,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC;AACpD,KAAK,CAAC;AACN;AACA,CAAC;AACD;AACA;AACA;AACA,SAAS,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE;AAChC,IAAI,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC9C,IAAI,IAAI,CAAC,GAAG,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;AAC5C;AACA,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACf,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AACd,IAAI,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;AACf;AACA,IAAI,OAAO,CAAC,CAAC;AACb,CAAC;AACD,SAAS,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE;AACjC,IAAI,IAAI,CAAC,GAAG,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;AAC5C,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AACtB,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AACtB,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC,CAAC;AACtB,IAAI,OAAO,CAAC,CAAC;AACb,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,CAAC,EAAE;AACrB;AACA,IAAI,OAAO;AACX,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;AACnD,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;AACnD,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;AACpD,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;AACpD,KAAK,CAAC;AACN;AACA,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,GAAG,EAAE;AACvB,IAAI,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,CAAC;AACnD,CAAC;AACD;AACG,IAAC,OAAO,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACzC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,YAAY,EAAE,YAAY;AAC5B,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,YAAY,EAAE,YAAY;AAC5B,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,gBAAgB,EAAE,gBAAgB;AACpC,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,gBAAgB,EAAE,gBAAgB;AACpC,EAAE,cAAc,EAAE,cAAc;AAChC,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,MAAM,EAAE,QAAQ;AAClB,CAAC,EAAE;AACH;AACA,SAAS,QAAQ,GAAG;AACpB,IAAI,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;AAC/B,IAAI,IAAI,IAAI,GAAG,EAAE,CAAC;AAClB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,IAAI,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACjC,KAAK;AACL,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;AAC3B,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAClE,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAClE,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAClE,SAAS,CAAC;AACV,KAAK;AACL,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;AAChC,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAChE,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAChE,YAAY,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAChE,SAAS,CAAC;AACV,KAAK;AACL,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC;AACZ,QAAQ,CAAC,EAAE,CAAC;AACZ,QAAQ,CAAC,EAAE,CAAC;AACZ,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,CAAC,EAAE,EAAE;AACrB,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;AACrC,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAC9E,CAAC;AACD;AACA;AACA;AACA,SAAS,eAAe,CAAC,MAAM,EAAE;AACjC,IAAI,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;AAC7B,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC;AAC1C,QAAQ,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC;AAC1C,QAAQ,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC;AAC1C,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,kBAAkB,CAAC,MAAM,EAAE;AACpC,IAAI,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;AAC7B,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC;AAC5C,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,UAAU,CAAC,IAAI,EAAE;AAC1B,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAC/B,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;AAC5B,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;AAC/C,QAAQ,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACjC,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;AAC5C,QAAQ,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACjC,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE;AACjC,IAAI,IAAI,MAAM,KAAK,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,CAAC,CAAC,EAAE;AAC1C,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AACzB,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC7B,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;AAC7B,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC7B,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,CAAC,EAAE,EAAE;AACrB,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;AACrC,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACrB,CAAC;AACD;AACA;AACA;AACA,SAAS,KAAK,GAAG;AACjB,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC7B,CAAC;AACD;AACA;AACA;AACA,SAAS,EAAE,GAAG;AACd,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC7B,CAAC;AACD;AACA;AACA;AACA,SAAS,OAAO,GAAG;AACnB,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9B,CAAC;AACD;AACA;AACA;AACA,SAAS,IAAI,GAAG;AAChB,IAAI,OAAO,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC;AACD;AACA;AACA;AACA,SAAS,IAAI,GAAG;AAChB,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC;AACD;AACA;AACA;AACA,SAAS,IAAI,GAAG;AAChB,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC7B,CAAC;AACD;AACA;AACA;AACA,SAAS,MAAM,GAAG;AAClB,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AAC7B,CAAC;AACD;AACA;AACA;AACA,SAAS,SAAS,CAAC,MAAM,EAAE;AAC3B,IAAI,IAAI,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;AACnC,IAAI,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC;AAChF,CAAC;AACD;AACA;AACA;AACA,SAAS,SAAS,CAAC,MAAM,EAAE;AAC3B,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC;AAC/C,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,gBAAgB,CAAC,MAAM,EAAE;AAClC,IAAI,OAAO,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;AAC3E,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE;AACrB,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AAChC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AAChC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AAChC,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,GAAG,CAAC,CAAC,EAAE;AAChB,IAAI,IAAI,OAAO,GAAG,EAAE,CAAC;AACrB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACxC,KAAK;AACL,IAAI,OAAO,OAAO,CAAC,MAAM,CAAC,UAAU,GAAG,EAAE,IAAI,EAAE;AAC/C,QAAQ,OAAO,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC;AAC3E,KAAK,EAAE,CAAC,CAAC,CAAC;AACV,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,CAAC,EAAE;AACrB,IAAI,IAAI,OAAO,GAAG,EAAE,CAAC;AACrB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACxC,KAAK;AACL,IAAI,OAAO,OAAO,CAAC,MAAM,CAAC,UAAU,GAAG,EAAE,IAAI,EAAE;AAC/C,QAAQ,OAAO,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC;AAC3E,KAAK,EAAE,CAAC,CAAC,CAAC;AACV,CAAC;AACD;AACA;AACA;AACA,SAAS,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE;AAC1B,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;AACxD,CAAC;AACD;AACA;AACA;AACA,SAAS,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE;AACjC,IAAI,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC;AAChF,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE;AACrB,IAAI,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAC7C,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE;AACvB,IAAI,IAAI,KAAK,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;AAC5D;AACA,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAC5B,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,CAAC,MAAM,EAAE,QAAQ,EAAE;AACnC,IAAI,OAAO,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,CAAC;AAC5E,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE;AACpE,IAAI,IAAI,KAAK,KAAK,CAAC,EAAE;AACrB,QAAQ,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAClD,QAAQ,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,CAAC,CAAC;AACvE,QAAQ,IAAI,CAAC,GAAG,aAAa,CAAC,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;AAC1E,QAAQ,IAAI,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACrF,aAAa,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACjC,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;AAC/B,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAC/D,QAAQ,IAAI,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACrF,aAAa,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACjC,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;AAC/B,YAAY,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAC9D,QAAQ,IAAI,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;AACrF,aAAa,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AACjC,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC;AAC/B,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;AAC/D,QAAQ,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC;AAC7C,KAAK;AACL,SAAS;AACT,QAAQ,OAAO,KAAK,CAAC;AACrB,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA,SAAS,iBAAiB,CAAC,MAAM,EAAE,CAAC,EAAE;AACtC,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;AACjD,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC1D,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;AACvD,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;AACvD,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC;AACxD,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,UAAU,CAAC,CAAC,EAAE,CAAC,EAAE;AAC1B,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC9C,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,iBAAiB,CAAC,CAAC,EAAE,CAAC,EAAE;AACjC,IAAI,IAAI,EAAE,GAAG,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC;AAC7D,IAAI,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACvC,CAAC;AACD;AACA;AACA;AACA,SAAS,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE;AACzB,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACrD,CAAC;AACD;AACA;AACA;AACA,SAAS,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE;AACnB,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,CAAC;AACD;AACA;AACA;AACA,SAAS,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE;AACnB,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,CAAC;AACD;AACA;AACA;AACA,SAAS,MAAM,CAAC,MAAM,EAAE;AACxB,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC;AACxD,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE;AACvB,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;AAC9B,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,wBAAwB,CAAC,GAAG,EAAE,WAAW,EAAE,uBAAuB,EAAE;AAC7E,IAAI,OAAO,iBAAiB,CAAC,iBAAiB,CAAC,GAAG,EAAE,uBAAuB,CAAC,EAAE,WAAW,CAAC,CAAC;AAC3F,CAAC;AACD;AACG,IAAC,OAAO,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACzC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,kBAAkB,EAAE,kBAAkB;AACxC,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,KAAK,EAAE,KAAK;AACd,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,gBAAgB,EAAE,gBAAgB;AACpC,EAAE,KAAK,EAAE,KAAK;AACd,EAAE,GAAG,EAAE,GAAG;AACV,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,GAAG,EAAE,KAAK;AACZ,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,eAAe,EAAE,iBAAiB;AACpC,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,eAAe,EAAE,iBAAiB;AACpC,EAAE,OAAO,EAAE,SAAS;AACpB,EAAE,GAAG,EAAE,GAAG;AACV,EAAE,GAAG,EAAE,GAAG;AACV,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,wBAAwB,EAAE,wBAAwB;AACpD,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,GAAG,EAAE,GAAG,EAAE;AACnC,IAAI,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAClC,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,WAAW,GAAG,UAAU,OAAO,EAAE;AACrC,IAAI,OAAO,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACrF,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,WAAW,EAAE;AACtC,IAAI,OAAO,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;AAC/D,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,WAAW,EAAE;AACtC,IAAI,OAAO,QAAQ,CAAC,WAAW,CAAC,GAAG,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC;AACtD,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,OAAO,GAAG,UAAU,WAAW,EAAE;AACrC,IAAI,QAAQ,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,EAAE,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE;AACjI,CAAC,CAAC;AACF,SAAS,KAAK,CAAC,GAAG,EAAE;AACpB,IAAI,IAAI,IAAI,GAAG,EAAE,CAAC;AAClB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACrC,KAAK;AACL,IAAI,IAAI,KAAK,GAAG,aAAa,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AACjD,IAAI,OAAO,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,EAAE;AACxC,QAAQ,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9D,KAAK,CAAC,CAAC;AACP,CAAC;AACD;AACA;AACG,IAAC,WAAW,gBAAgB,MAAM,CAAC,MAAM,CAAC;AAC7C,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,KAAK,EAAE,KAAK;AACd,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,aAAa,EAAE;AACxC,IAAI,IAAI,iBAAiB,GAAG,QAAQ,CAAC,aAAa,CAAC,CAAC;AACpD,IAAI,IAAI,qBAAqB,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;AAC/E,IAAI,IAAI,MAAM,GAAG,SAAS,CAAC,qBAAqB,CAAC,CAAC;AAClD,IAAI,IAAI,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,CAAC,iBAAiB,CAAC,CAAC,CAAC;AAChE,IAAI,IAAI,OAAO,GAAG,MAAM,KAAK,CAAC,GAAG,GAAG,GAAG,MAAM,GAAG,IAAI,CAAC;AACrD,IAAI,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;AAC3E,CAAC,CAAC;AACF;AACG,IAAC,cAAc,gBAAgB,MAAM,CAAC,MAAM,CAAC;AAChD,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE;AACvC,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AACxD,CAAC;AACD;AACA;AACA;AACA,SAAS,cAAc,CAAC,UAAU,EAAE;AACpC,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;AAC/D,CAAC;AACD;AACA;AACA;AACA,SAAS,sBAAsB,CAAC,KAAK,EAAE,UAAU,EAAE;AACnD,IAAI,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;AAC3E,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,UAAU,CAAC,SAAS,EAAE,aAAa,EAAE;AAC9C,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;AACtD,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;AACtD,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;AACtD,IAAI,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;AACtD,IAAI,OAAO,QAAQ,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,GAAG,IAAI,EAAE,IAAI,GAAG,IAAI,CAAC,CAAC;AAC1D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,YAAY,CAAC,EAAE,EAAE,IAAI,EAAE;AAChC,IAAI,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AACzE,IAAI,IAAI,YAAY,GAAG,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;AACtD,IAAI,IAAI,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;AACpE,IAAI,OAAO,sBAAsB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;AAC1D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,SAAS,CAAC,EAAE,EAAE,IAAI,EAAE;AAC7B,IAAI,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AACzE,IAAI,IAAI,YAAY,GAAG,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;AACtD,IAAI,IAAI,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;AACpE,IAAI,OAAO,sBAAsB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;AAC1D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,UAAU,CAAC,EAAE,EAAE,IAAI,EAAE;AAC9B,IAAI,IAAI,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC1D,IAAI,IAAI,YAAY,GAAG,KAAK,CAAC,iBAAiB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;AAC7D,IAAI,IAAI,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;AACtE,IAAI,OAAO,sBAAsB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;AAC1D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,OAAO,CAAC,IAAI,EAAE,aAAa,EAAE,MAAM,EAAE;AAC9C,IAAI,IAAI,MAAM,IAAI,IAAI,EAAE;AACxB,QAAQ,OAAO,OAAO,CAAC,IAAI,EAAE,aAAa,EAAE,aAAa,CAAC,CAAC;AAC3D,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;AAC7E,QAAQ,IAAI,MAAM,GAAG,aAAa,CAAC;AACnC,QAAQ,OAAO,QAAQ,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,KAAK,GAAG,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC;AACjF,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA,SAAS,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE;AACzB,IAAI,OAAO,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC5C,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE;AAC7B,IAAI,OAAO,sBAAsB,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC;AACrE,CAAC;AACD;AACA;AACA;AACA,SAAS,MAAM,CAAC,IAAI,EAAE;AACtB,IAAI,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;AACpC,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,IAAI,EAAE;AACxB,IAAI,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;AACvE,CAAC;AACD;AACA;AACA;AACA,SAAS,OAAO,CAAC,IAAI,EAAE;AACvB,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;AACpC,CAAC;AACD;AACA;AACA;AACA,SAAS,WAAW,CAAC,IAAI,EAAE;AAC3B,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AAC/D,CAAC;AACD;AACA;AACA;AACA,SAAS,UAAU,CAAC,IAAI,EAAE;AAC1B,IAAI,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;AACpC,CAAC;AACD;AACA;AACA;AACA,SAAS,WAAW,CAAC,IAAI,EAAE;AAC3B,IAAI,OAAO,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;AACpC,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,IAAI,EAAE;AACxB,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC;AACtC,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,GAAG,CAAC,IAAI,EAAE,OAAO,EAAE;AAC5B,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,CAAC,KAAK,GAAG,OAAO,GAAG,CAAC,EAAE,IAAI,CAAC,MAAM,GAAG,OAAO,GAAG,CAAC,CAAC,CAAC;AAC7G,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,cAAc,CAAC,IAAI,EAAE;AAC9B,IAAI,IAAI,MAAM,GAAG,EAAE,CAAC;AACpB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,MAAM,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACvC,KAAK;AACL,IAAI,OAAO,MAAM,CAAC,KAAK,CAAC,UAAU,KAAK,EAAE;AACzC,QAAQ,QAAQ,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC;AACjC,YAAY,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC;AAC1C,YAAY,IAAI,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC;AAC7B,YAAY,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,IAAI,KAAK,CAAC,CAAC,EAAE;AAC7C,KAAK,CAAC,CAAC;AACP,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,UAAU,CAAC,IAAI,EAAE;AAC1B,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAC/B,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;AAC5B,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;AACpE,QAAQ,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AAC7C,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,KAAK,GAAG,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;AACzE,QAAQ,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;AAC7C,KAAK;AACL,CAAC;AACD;AACG,IAAC,SAAS,gBAAgB,MAAM,CAAC,MAAM,CAAC;AAC3C,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,cAAc,EAAE,cAAc;AAChC,EAAE,sBAAsB,EAAE,sBAAsB;AAChD,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,UAAU,EAAE,YAAY;AAC1B,EAAE,OAAO,EAAE,SAAS;AACpB,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,KAAK,EAAE,OAAO;AAChB,EAAE,OAAO,EAAE,SAAS;AACpB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,IAAI,EAAE,MAAM;AACd,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,GAAG,EAAE,GAAG;AACV,EAAE,cAAc,EAAE,cAAc;AAChC,EAAE,QAAQ,EAAE,UAAU;AACtB,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,KAAK,EAAE,MAAM,EAAE;AACxC,IAAI,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AAC5C,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,MAAM,GAAG,UAAU,IAAI,EAAE;AAC7B,IAAI,OAAO,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAChC,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,OAAO,GAAG,UAAU,CAAC,EAAE,CAAC,EAAE;AAC9B,IAAI,OAAO,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,CAAC;AACxD,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,KAAK,GAAG,UAAU,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE;AAClD,IAAI,OAAO;AACX,QAAQ,KAAK,EAAE,UAAU,CAAC,KAAK,GAAG,MAAM;AACxC,QAAQ,MAAM,EAAE,UAAU,CAAC,MAAM,GAAG,MAAM;AAC1C,KAAK,CAAC;AACN,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,iBAAiB,GAAG,UAAU,WAAW,EAAE,UAAU,EAAE;AAC3D,IAAI,OAAO,KAAK,CAAC,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;AACvD,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,IAAI,GAAG,UAAU,EAAE,EAAE,UAAU,EAAE;AACrC,IAAI,OAAO;AACX,QAAQ,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,UAAU,CAAC,KAAK,CAAC;AACnD,QAAQ,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC;AACtD,KAAK,CAAC;AACN,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,UAAU,GAAG,UAAU,EAAE,EAAE,UAAU,EAAE;AAC3C,IAAI,IAAI,EAAE,GAAG,YAAY,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AAC1G,IAAI,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AAC5C,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,OAAO,GAAG,UAAU,EAAE,EAAE,UAAU,EAAE;AACxC,IAAI,IAAI,EAAE,GAAG,SAAS,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AACvG,IAAI,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AAC5C,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,EAAE,EAAE,UAAU,EAAE;AACzC,IAAI,IAAI,EAAE,GAAG,UAAU,CAAC,EAAE,EAAE,WAAW,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AAC3F,IAAI,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AAC5C,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,KAAK,GAAG,UAAU,UAAU,EAAE;AAClC,IAAI,OAAO;AACX,QAAQ,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC;AAC3C,QAAQ,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;AAC7C,KAAK,CAAC;AACN,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,KAAK,GAAG,UAAU,UAAU,EAAE;AAClC,IAAI,OAAO;AACX,QAAQ,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC;AAC3C,QAAQ,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;AAC7C,KAAK,CAAC;AACN,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,UAAU,EAAE;AACrC,IAAI,OAAO,EAAE,CAAC,EAAE,UAAU,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;AACjE,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,WAAW,GAAG,UAAU,EAAE,EAAE;AAChC,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AAC7C,IAAI,OAAO,KAAK,GAAG,MAAM,CAAC;AAC1B,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,IAAI,GAAG,UAAU,EAAE,EAAE;AACzB,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;AAC7C,IAAI,OAAO,KAAK,GAAG,MAAM,CAAC;AAC1B,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,UAAU,GAAG,UAAU,KAAK,EAAE,UAAU,EAAE;AAC9C,IAAI,IAAI,UAAU,CAAC,KAAK,IAAI,UAAU,CAAC,MAAM,GAAG,KAAK,EAAE;AACvD,QAAQ,OAAO,QAAQ,CAAC,UAAU,CAAC,MAAM,GAAG,KAAK,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;AACtE,KAAK;AACL,IAAI,OAAO,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,UAAU,CAAC,KAAK,GAAG,KAAK,CAAC,CAAC;AAChE,CAAC,CAAC;AACF;AACA;AACA;AACA,SAAS,WAAW,CAAC,UAAU,EAAE,QAAQ,EAAE;AAC3C,IAAI,IAAI,QAAQ,KAAK,KAAK,CAAC,EAAE,EAAE,QAAQ,GAAG,QAAQ,EAAE,CAAC,EAAE;AACvD,IAAI,OAAO,sBAAsB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;AACxD,CAAC;AACD;AACG,IAAC,UAAU,gBAAgB,MAAM,CAAC,MAAM,CAAC;AAC5C,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,KAAK,EAAE,KAAK;AACd,EAAE,iBAAiB,EAAE,iBAAiB;AACtC,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,OAAO,EAAE,OAAO;AAClB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,KAAK,EAAE,KAAK;AACd,EAAE,KAAK,EAAE,KAAK;AACd,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,IAAI,EAAE,IAAI;AACZ,EAAE,UAAU,EAAE,UAAU;AACxB,EAAE,WAAW,EAAE,WAAW;AAC1B,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,KAAK,EAAE;AACzB,IAAI,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;AACvB,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,EAAE,CAAC,EAAE;AACzC,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAC5D,QAAQ,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAC5D,QAAQ,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC;AAC5D,QAAQ,KAAK,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,KAAK,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,KAAK;AACxE,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,WAAW,CAAC,KAAK,EAAE;AAC5B,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,EAAE,CAAC,EAAE;AACzC,IAAI,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;AAC1J,IAAI,OAAO,QAAQ,CAAC;AACpB,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;AACvB,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;AACvB,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC;AACvB,QAAQ,KAAK,EAAE,KAAK;AACpB,KAAK,CAAC,CAAC;AACP,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,kBAAkB,CAAC,MAAM,EAAE,KAAK,EAAE;AAC3C,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,KAAK,CAAC,EAAE;AAC5C,IAAI,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;AAC7B,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AAC5B,IAAI,IAAI,KAAK,KAAK,KAAK,EAAE;AACzB,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC3C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,SAAS;AACT,KAAK;AACL,SAAS,IAAI,KAAK,KAAK,KAAK,EAAE;AAC9B,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC5C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,SAAS;AACT,KAAK;AACL,SAAS,IAAI,KAAK,KAAK,KAAK,EAAE;AAC9B,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC3C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,SAAS;AACT,KAAK;AACL,SAAS,IAAI,KAAK,KAAK,KAAK,EAAE;AAC9B,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC5C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,SAAS;AACT,KAAK;AACL,SAAS,IAAI,KAAK,KAAK,KAAK,EAAE;AAC9B,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC3C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,SAAS;AACT,KAAK;AACL,SAAS,IAAI,KAAK,KAAK,KAAK,EAAE;AAC9B,QAAQ,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAC5C,QAAQ,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AACzC,SAAS;AACT,aAAa;AACb,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;AAC1C,YAAY,CAAC,GAAG,CAAC,CAAC;AAClB,SAAS;AACT,KAAK;AACL,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAC9C,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,UAAU,CAAC,IAAI,EAAE;AAC1B,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAC/B,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;AAC5B,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;AAChG,QAAQ,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAClD,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,EAAE,GAAG,GAAG,CAAC,KAAK,EAAE,KAAK,GAAG,EAAE,KAAK,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE,CAAC;AAChG,QAAQ,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAClD,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,GAAG,EAAE;AACvB;AACA,IAAI,IAAI,CAAC,GAAG,GAAG,CAAC;AAChB,IAAI,QAAQ,CAAC,IAAI,IAAI;AACrB,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE;AACnC,CAAC;AACD;AACG,IAAC,KAAK,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACvC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,kBAAkB,EAAE,kBAAkB;AACxC,EAAE,QAAQ,EAAE,UAAU;AACtB,EAAE,MAAM,EAAE,QAAQ;AAClB,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,MAAM,EAAE;AAC1B,IAAI,IAAI,EAAE,EAAE,EAAE,CAAC;AACf,IAAI,IAAI,MAAM,KAAK,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,EAAE,CAAC,EAAE;AAC3C,IAAI,OAAO;AACX,QAAQ,KAAK,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC,KAAK,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,MAAM,EAAE;AAC5E,QAAQ,GAAG,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC,GAAG,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,MAAM,EAAE;AACxE,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,MAAM,CAAC,IAAI,EAAE;AACtB,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AAC3C,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;AACvC,IAAI,IAAI,KAAK,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACtD,IAAI,IAAI,GAAG,GAAG,iBAAiB,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;AAClD,IAAI,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACtC,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,IAAI,EAAE;AACxB,IAAI,OAAO,UAAU,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;AAC5C,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,eAAe,CAAC,IAAI,EAAE;AAC/B,IAAI,OAAO,iBAAiB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;AACnD,CAAC;AACD;AACA;AACA;AACA,SAAS,SAAS,CAAC,IAAI,EAAE;AACzB,IAAI,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;AAC1C,CAAC;AACD;AACG,IAAC,KAAK,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACvC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,SAAS,EAAE,SAAS;AACtB,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE;AAC7C,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE;AAChC,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE;AAChC,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE;AAChC,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,EAAE;AAChC,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC,EAAE;AAClC,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC,EAAE;AAClC,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC;AACtD,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,QAAQ,GAAG,YAAY;AAC3B,IAAI,OAAO,QAAQ,EAAE,CAAC;AACtB,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,WAAW,GAAG,UAAU,EAAE,EAAE,EAAE,EAAE;AACpC,IAAI,OAAO,SAAS,CAAC,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC;AACzC,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,QAAQ,GAAG,UAAU,OAAO,EAAE;AAClC,IAAI,OAAO,MAAM,CAAC,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;AACvC,CAAC,CAAC;AACF;AACA;AACA;AACA,IAAI,MAAM,GAAG,UAAU,OAAO,EAAE,MAAM,EAAE;AACxC,IAAI,IAAI,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC,CAAC;AACrC,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAChC,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAChC,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC;AAC5C,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC;AAC5C,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC;AAC7C,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC;AAC7C,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC;AACtD,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,SAAS,GAAG,UAAU,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE;AAC1C,IAAI,IAAI,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;AAC1D,IAAI,IAAI,KAAK,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC;AAC1D,IAAI,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAC1E,CAAC,CAAC;AACF;AACA;AACA;AACA;AACA,IAAI,cAAc,GAAG,UAAU,MAAM,EAAE,EAAE,EAAE;AAC3C,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC;AAC1D,IAAI,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC,EAAE,CAAC;AAC1D,IAAI,OAAO,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAC1B,CAAC,CAAC;AACF;AACG,IAAC,MAAM,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACxC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,cAAc,EAAE,cAAc;AAChC,CAAC,EAAE;AACH;AACA,SAAS,QAAQ,GAAG;AACpB,IAAI,IAAI,IAAI,GAAG,EAAE,CAAC;AAClB,IAAI,KAAK,IAAI,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,EAAE,EAAE;AAClD,QAAQ,IAAI,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;AACjC,KAAK;AACL,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;AAC3B,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AACxB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AACxB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AACxB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AACxB,SAAS,CAAC;AACV,KAAK;AACL,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;AAChC,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;AACtB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;AACtB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;AACtB,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;AACtB,SAAS,CAAC;AACV,KAAK;AACL,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC;AACZ,QAAQ,CAAC,EAAE,CAAC;AACZ,QAAQ,CAAC,EAAE,CAAC;AACZ,QAAQ,CAAC,EAAE,CAAC;AACZ,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,WAAW,CAAC,MAAM,EAAE;AAC7B,IAAI,OAAO,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;AACrD,CAAC;AACD;AACA;AACA;AACA,SAAS,GAAG,CAAC,MAAM,EAAE;AACrB,IAAI,OAAO,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;AACrD,CAAC;AACD;AACG,IAAC,OAAO,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACzC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,WAAW,EAAE,WAAW;AAC1B,EAAE,GAAG,EAAE,GAAG;AACV,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,MAAM,EAAE;AAC1B,IAAI,IAAI,MAAM,KAAK,KAAK,CAAC,EAAE,EAAE,MAAM,GAAG,EAAE,CAAC,EAAE;AAC3C,IAAI,OAAO,QAAQ,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;AAC/D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,0BAA0B,CAAC,MAAM,EAAE,KAAK,EAAE;AACnD,IAAI,IAAI,QAAQ,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AACzC,IAAI,OAAO,QAAQ,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;AAC5D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,eAAe,CAAC,KAAK,EAAE,KAAK,EAAE;AACvC,IAAI,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC;AACvD,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,aAAa,CAAC,KAAK,EAAE,IAAI,EAAE;AACpC,IAAI,IAAI,WAAW,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;AACtC,IAAI,IAAI,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;AACvD,IAAI,IAAI,WAAW,KAAK,CAAC,EAAE;AAC3B,QAAQ,IAAI,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;AACtD,YAAY,OAAO,IAAI,CAAC,KAAK,CAAC;AAC9B,SAAS;AACT,aAAa;AACb,YAAY,OAAO,SAAS,CAAC;AAC7B,SAAS;AACT,KAAK;AACL,IAAI,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,WAAW,CAAC;AAC9E,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;AACxB,QAAQ,OAAO,SAAS,CAAC;AACzB,KAAK;AACL,SAAS;AACT,QAAQ,OAAO,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,WAAW,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;AACxD,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,YAAY,CAAC,KAAK,EAAE,KAAK,EAAE;AACpC,IAAI,IAAI,CAAC,GAAG,eAAe,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;AAC1C,IAAI,OAAO,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;AACjD,CAAC;AACD;AACG,IAAC,KAAK,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACvC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,0BAA0B,EAAE,0BAA0B;AACxD,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,aAAa,EAAE,aAAa;AAC9B,EAAE,YAAY,EAAE,YAAY;AAC5B,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,KAAK,EAAE;AACzB,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,EAAE,CAAC,EAAE;AACzC,IAAI,OAAO,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;AACvD,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,QAAQ,CAAC,IAAI,EAAE;AACxB,IAAI,IAAI,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;AAC/B,IAAI,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;AAC5B,QAAQ,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;AAC3D,QAAQ,OAAO,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;AACpD,KAAK;AACL,SAAS;AACT,QAAQ,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC;AAC7B,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE;AACtC,IAAI,IAAI,SAAS,GAAG,OAAO,GAAG,CAAC,CAAC;AAChC,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AAChC,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACvB,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACvB,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;AACvB,IAAI,IAAI,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;AAChC,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;AACtC,CAAC;AACD;AACA;AACA;AACA;AACA,SAAS,kBAAkB,CAAC,MAAM,EAAE;AACpC,IAAI,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;AAC7B,IAAI,IAAI,KAAK,GAAG,eAAe,CAAC,MAAM,CAAC,CAAC;AACxC,IAAI,IAAI,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC1B,IAAI,IAAI,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC1B,IAAI,IAAI,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;AAC1B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,IAAI,GAAG,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC;AAC3B,IAAI,IAAI,KAAK,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AACnC,IAAI,IAAI,KAAK,GAAG,CAAC,EAAE;AACnB,QAAQ,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;AAC3C,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC;AACvB,SAAS,CAAC;AACV,KAAK;AACL,SAAS,IAAI,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE;AACzC,QAAQ,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;AACxD,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC;AACvB,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,SAAS,CAAC;AACV,KAAK;AACL,SAAS,IAAI,IAAI,GAAG,IAAI,EAAE;AAC1B,QAAQ,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;AACxD,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC;AACvB,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,SAAS,CAAC;AACV,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;AACxD,QAAQ,OAAO;AACf,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC;AACvB,YAAY,CAAC,EAAE,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;AAChC,SAAS,CAAC;AACV,KAAK;AACL,CAAC;AACD,SAAS,SAAS,CAAC,KAAK,EAAE;AAC1B,IAAI,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,CAAC,EAAE,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;AACtE,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AAC9B,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;AACnC,IAAI,QAAQ,KAAK;AACjB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,QAAQ,KAAK,KAAK;AAClB,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AAC5C,YAAY,MAAM;AAClB,KAAK;AACL,IAAI,OAAO,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;AACtC,CAAC;AACD;AACA;AACA;AACA,SAAS,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE;AACxB;AACA,IAAI,OAAO;AACX,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;AACxD,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA,SAAS,MAAM,CAAC,GAAG,EAAE;AACrB;AACA,IAAI,IAAI,CAAC,GAAG,GAAG,CAAC;AAChB,IAAI,QAAQ,CAAC,IAAI,IAAI;AACrB,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;AAC7B,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE;AAC/B,CAAC;AACD;AACG,IAAC,UAAU,gBAAgB,MAAM,CAAC,MAAM,CAAC;AAC5C,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,QAAQ;AAClB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,aAAa,EAAE,aAAa;AAC9B,EAAE,kBAAkB,EAAE,kBAAkB;AACxC,EAAE,SAAS,EAAE,SAAS;AACtB,EAAE,QAAQ,EAAE,QAAQ;AACpB,EAAE,MAAM,EAAE,MAAM;AAChB,CAAC,EAAE;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,MAAM,CAAC,KAAK,EAAE;AACvB,IAAI,IAAI,EAAE,EAAE,EAAE,CAAC;AACf,IAAI,IAAI,KAAK,KAAK,KAAK,CAAC,EAAE,EAAE,KAAK,GAAG,EAAE,CAAC,EAAE;AACzC,IAAI,OAAO;AACX,QAAQ,MAAM,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,MAAM,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,MAAM,EAAE;AAC7E,QAAQ,SAAS,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,SAAS,MAAM,IAAI,IAAI,EAAE,KAAK,KAAK,CAAC,GAAG,EAAE,GAAG,OAAO,EAAE;AACpF,KAAK,CAAC;AACN,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,EAAE,CAAC,GAAG,EAAE,QAAQ,EAAE;AAC3B,IAAI,OAAO,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;AAC7D,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,eAAe,CAAC,GAAG,EAAE,OAAO,EAAE;AACvC,IAAI,IAAI,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;AACjD,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE;AACjB;AACA,QAAQ,OAAO,eAAe,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;AAC1E,KAAK;AACL,SAAS;AACT,QAAQ,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AAC5E;AACA,QAAQ,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC;AACtC,KAAK;AACL,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,cAAc,CAAC,GAAG,EAAE,KAAK,EAAE;AACpC,IAAI,IAAI,CAAC,GAAG,eAAe,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACxC,IAAI,OAAO,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,SAAS,CAAC;AAC9C,CAAC;AACD;AACG,IAAC,GAAG,gBAAgB,MAAM,CAAC,MAAM,CAAC;AACrC,EAAE,SAAS,EAAE,IAAI;AACjB,EAAE,MAAM,EAAE,MAAM;AAChB,EAAE,EAAE,EAAE,EAAE;AACR,EAAE,eAAe,EAAE,eAAe;AAClC,EAAE,cAAc,EAAE,cAAc;AAChC,CAAC;;;;","names":[],"sources":["../geometry/dist/bundle.esm.js"],"sourcesContent":["import { __assign, __spreadArray } from 'tslib';\n\n/**\r\n * Clamps the given value between `min` and `max`.\r\n *\r\n * @param value The value to clamp.\r\n * @param min The min possible value.\r\n * @param max The max possible value.\r\n * @returns `value` or a value clamped to `min` or `max`.\r\n */\r\nfunction clamp(value, min, max) {\r\n return Math.max(min, Math.min(max, value));\r\n}\r\n/**\r\n * Linear interpolates a value between `a` and `b` by `t`. If `t` is 0, then the\r\n * result will be `a`. If `t` is 1, then the result will be `b`. `t` will be\r\n * clamped to a value between 0 and 1.\r\n *\r\n * @param a The start value.\r\n * @param b The end value.\r\n * @param t The interpolation value between 0 and 1.\r\n * @returns The interpolated value between `a` and `b`.\r\n */\r\nfunction lerp$2(a, b, t) {\r\n t = clamp(t, 0, 1);\r\n return t * (b - a) + a;\r\n}\n\n/**\r\n * Returns a new `Point` with the given horizontal and vertical position.\r\n */\r\nfunction create$c(x, y) {\r\n if (x === void 0) { x = 0; }\r\n if (y === void 0) { y = 0; }\r\n return { x: x, y: y };\r\n}\r\n/**\r\n * Converts a polar coordinate (length and angle) into a Cartesian coordinate.\r\n */\r\nfunction polar(length, radians) {\r\n var x = Math.cos(radians) * length;\r\n var y = Math.sin(radians) * length;\r\n return create$c(x, y);\r\n}\r\n/**\r\n * Returns the distance between two points.\r\n */\r\nfunction distance$2(a, b) {\r\n var delta = subtract$1(a, b);\r\n return Math.sqrt(delta.x * delta.x + delta.y * delta.y);\r\n}\r\n/**\r\n * Returns a new `Point` where `b` is subtracted from `a`.\r\n */\r\nfunction subtract$1(a, b) {\r\n return { x: a.x - b.x, y: a.y - b.y };\r\n}\r\n/**\r\n * Returns a new `Point` where `b` is added to `a`.\r\n */\r\nfunction add$1(a, b) {\r\n return { x: a.x + b.x, y: a.y + b.y };\r\n}\r\n/**\r\n * Returns `true` if the `x` and `y` positions of `a` and `b` are equal.\r\n */\r\nfunction isEqual$3(a, b) {\r\n return a.x === b.x && a.y === b.y;\r\n}\r\n/**\r\n * Performs a linear interpolation between `a` and `b` and returns the result.\r\n * The value of `t` is clamped between `[0, 1]`.\r\n *\r\n * @param a The start value.\r\n * @param b The end value.\r\n * @param t A value between 0 and 1.\r\n * @returns A point between `a` and `b`.\r\n */\r\nfunction lerp$1(a, b, t) {\r\n return {\r\n x: lerp$2(a.x, b.x, t),\r\n y: lerp$2(a.y, b.y, t),\r\n };\r\n}\r\n/**\r\n * Returns a new `Point` where `x` and `y` are inverted.\r\n */\r\nfunction negate$1(pt) {\r\n return create$c(-pt.x, -pt.y);\r\n}\r\n/**\r\n * Returns a new `Point` where `x` and `y` are multiplied by the given scale\r\n * factors.\r\n */\r\nfunction scale$4(pt, scaleX, scaleY) {\r\n return {\r\n x: pt.x * scaleX,\r\n y: pt.y * scaleY,\r\n };\r\n}\r\n/**\r\n * Parses a JSON string representation of a Point and returns an object.\r\n *\r\n * @param json A JSON string, either in the form `[x,y]` or `{\"x\": 0, \"y\": 0}`\r\n * @returns A parsed Point.\r\n */\r\nfunction fromJson$4(json) {\r\n var obj = JSON.parse(json);\r\n if (Array.isArray(obj)) {\r\n var x = obj[0], y = obj[1];\r\n return create$c(x, y);\r\n }\r\n else {\r\n var x = obj.x, y = obj.y;\r\n return create$c(x, y);\r\n }\r\n}\n\nvar point = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$c,\n polar: polar,\n distance: distance$2,\n subtract: subtract$1,\n add: add$1,\n isEqual: isEqual$3,\n lerp: lerp$1,\n negate: negate$1,\n scale: scale$4,\n fromJson: fromJson$4\n});\n\n/**\r\n * Returns an `Angle` between two points, in radians.\r\n *\r\n * @param a The starting point.\r\n * @param b The ending point.\r\n * @returns An angle in radians.\r\n */\r\nfunction fromPoints$1(a, b) {\r\n var delta = subtract$1(b, a);\r\n var theta = Math.atan2(delta.y, delta.x);\r\n return theta;\r\n}\r\n/**\r\n * Returns an `Angle` between two points, in degrees.\r\n *\r\n * An angle of 0 represents an upward vector, and increases in a clockwise\r\n * direction.\r\n *\r\n * @deprecated Use {@link fromPoints} instead.\r\n */\r\nfunction fromPointsInDegrees(a, b) {\r\n var delta = subtract$1(b, a);\r\n var theta = Math.atan2(delta.y, delta.x);\r\n return normalize$1(toDegrees(theta) - 270);\r\n}\r\n/**\r\n * Normalizes the given angle, in degrees, to a number between 0 and 359.\r\n */\r\nfunction normalize$1(degrees) {\r\n return (degrees + 3600) % 360;\r\n}\r\n/**\r\n * Converts the given radians to degrees.\r\n */\r\nfunction toDegrees(radians) {\r\n return radians * (180 / Math.PI);\r\n}\r\n/**\r\n * Converts the given degrees to radians.\r\n */\r\nfunction toRadians(degrees) {\r\n return degrees * (Math.PI / 180);\r\n}\n\nvar angle = /*#__PURE__*/Object.freeze({\n __proto__: null,\n fromPoints: fromPoints$1,\n fromPointsInDegrees: fromPointsInDegrees,\n normalize: normalize$1,\n toDegrees: toDegrees,\n toRadians: toRadians\n});\n\n/**\r\n * Creates a 4x4 matrix from a set of row-major components.\r\n */\r\nfunction fromValues(\r\n/* eslint-disable prettier/prettier */\r\nm11, m12, m13, m14, m21, m22, m23, m24, m31, m32, m33, m34, m41, m42, m43, m44) {\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n m11, m21, m31, m41,\r\n m12, m22, m32, m42,\r\n m13, m23, m33, m43,\r\n m14, m24, m34, m44,\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a `Matrix4` from an object representation.\r\n */\r\nfunction fromObject(obj) {\r\n /* eslint-disable prettier/prettier */\r\n return fromValues(obj.m11, obj.m12, obj.m13, obj.m14, obj.m21, obj.m22, obj.m23, obj.m24, obj.m31, obj.m32, obj.m33, obj.m34, obj.m41, obj.m42, obj.m43, obj.m44);\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Returns a new [identity matrix](https://en.wikipedia.org/wiki/Identity_matrix).\r\n */\r\nfunction makeIdentity() {\r\n return [1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1];\r\n}\r\n/**\r\n * Returns a matrix with all values as 0.\r\n */\r\nfunction makeZero() {\r\n return [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\r\n}\r\n/**\r\n * Creates a translation matrix.\r\n *\r\n * ```\r\n * 1, 0, 0, 0,\r\n * 0, 1, 0, 0,\r\n * 0, 0, 1, 0,\r\n * x, y, z, 1\r\n * ```\r\n *\r\n * @param translation A vector representing the translation components.\r\n * @returns A translation matrix.\r\n */\r\nfunction makeTranslation(translation) {\r\n var x = translation.x, y = translation.y, z = translation.z;\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n 1, 0, 0, 0,\r\n 0, 1, 0, 0,\r\n 0, 0, 1, 0,\r\n x, y, z, 1,\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a rotation matrix.\r\n *\r\n * ```\r\n * 1-2y²-2z², 2xy-2zw, 2xz+2yw, 0,\r\n * 2xy+2zw, 1-2x²-2z², 2yz-2xw, 0,\r\n * 2xz-2yw, 2yz+2xw, 1-2x²-2y², 0,\r\n * 0, 0, 0, 1,\r\n * ```\r\n *\r\n * @param rotation A quaternion representing the rotation.\r\n * @see https://en.wikipedia.org/wiki/Rotation_matrix#Quaternion\r\n * @returns A rotation matrix.\r\n */\r\nfunction makeRotation(rotation) {\r\n var x = rotation.x, y = rotation.y, z = rotation.z, w = rotation.w;\r\n var x2 = x + x, y2 = y + y, z2 = z + z;\r\n var xx = x * x2, xy = x * y2, xz = x * z2;\r\n var yy = y * y2, yz = y * z2, zz = z * z2;\r\n var wx = w * x2, wy = w * y2, wz = w * z2;\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n 1 - (yy + zz), xy + wz, xz - wy, 0,\r\n xy - wz, 1 - (xx + zz), yz + wx, 0,\r\n xz + wy, yz - wx, 1 - (xx + yy), 0,\r\n 0, 0, 0, 1\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a scale matrix.\r\n *\r\n * ```\r\n * x, 0, 0, 0,\r\n * 0, y, 0, 0,\r\n * 0, 0, z, 0,\r\n * 0, 0, 0, 1\r\n * ```\r\n *\r\n * @param scale A vector representing the different scale components.\r\n * @returns A scale matrix.\r\n */\r\nfunction makeScale(scale) {\r\n var x = scale.x, y = scale.y, z = scale.z;\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n x, 0, 0, 0,\r\n 0, y, 0, 0,\r\n 0, 0, z, 0,\r\n 0, 0, 0, 1,\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a matrix that has translation, rotation and scale applied to it.\r\n *\r\n * @param translation The translation applied to the matrix.\r\n * @param rotation The rotation applied to the matrix.\r\n * @param scale The scale applied to the matrix.\r\n * @returns A transformed matrix.\r\n */\r\nfunction makeTRS(translation, rotation, scale) {\r\n var t = makeTranslation(translation);\r\n var r = makeRotation(rotation);\r\n var s = makeScale(scale);\r\n return multiply$2(multiply$2(t, r), s);\r\n}\r\n/**\r\n * Returns a matrix that has the basis components (upper left 3x3 matrix) set to\r\n * the following x, y, and z axis.\r\n *\r\n * ```\r\n * x.x y.x z.x 0\r\n * x.y y.y z.y 0\r\n * x.z y.z z.z 0\r\n * 0 0 0 0\r\n * ```\r\n *\r\n * @param x The x axis to set.\r\n * @param y The y axis to set.\r\n * @param z The z axis to set.\r\n * @returns A matrix with its basis components populated.\r\n */\r\nfunction makeBasis(x, y, z) {\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n x.x, x.y, x.z, 0,\r\n y.x, y.y, y.z, 0,\r\n z.x, z.y, z.z, 0,\r\n 0, 0, 0, 1\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a rotation matrix that is rotated around a given axis by the given\r\n * angle.\r\n *\r\n * @param axis The axis of rotation.\r\n * @param radians The angle of rotation.\r\n * @returns A rotation matrix.\r\n */\r\nfunction makeRotationAxis(axis, radians) {\r\n var c = Math.cos(radians);\r\n var s = Math.sin(radians);\r\n var t = 1 - c;\r\n var x = axis.x, y = axis.y, z = axis.z;\r\n var tx = t * x;\r\n var ty = t * y;\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n tx * x + c, tx * y + s * z, tx * z - s * y, 0,\r\n tx * y - s * z, ty * y + c, ty * z + s * x, 0,\r\n tx * z + s * y, ty * z - s * x, t * z * z + c, 0,\r\n 0, 0, 0, 1\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a matrix used for [perspective\r\n * projections](https://en.wikipedia.org/wiki/3D_projection#Perspective_projection).\r\n *\r\n * The viewing volume is frustum-shaped and defined by the six parameters. Left,\r\n * right, top, and bottom specify coordinates in the near clipping plane where\r\n * the frustum edges intersect it, and the near and far parameters define the\r\n * forward distances of the view volume. The resulting volume can be vertically\r\n * and horizontally asymmetrical around the center of the near plane.\r\n *\r\n * @param left The left coordinate at the near plane.\r\n * @param right The right coordinate at the near plane.\r\n * @param top The top coordinate at the near plane.\r\n * @param bottom The bottom coordinate at the near plane.\r\n * @param near The near distance.\r\n * @param far The far distance.\r\n * @returns A matrix representing a view frustum.\r\n */\r\nfunction makeFrustum(left, right, top, bottom, near, far) {\r\n var x = (2 * near) / (right - left);\r\n var y = (2 * near) / (top - bottom);\r\n var a = (right + left) / (right - left);\r\n var b = (top + bottom) / (top - bottom);\r\n var c = -(far + near) / (far - near);\r\n var d = (-2 * far * near) / (far - near);\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n x, 0, 0, 0,\r\n 0, y, 0, 0,\r\n a, b, c, -1,\r\n 0, 0, d, 0\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Creates a perspective projection matrix.\r\n *\r\n * Related to: gluPerspective. The viewing volume is frustum-shaped amd defined\r\n * by the four parameters. The fovy and aspect ratio are used to compute the\r\n * positions of the left, right, top, and bottom sides of the viewing volume in\r\n * the zNear plane. The fovy is the y field-of-view, the angle made by the top\r\n * and bottom sides of frustum if they were to intersect. The aspect ratio is\r\n * the width of the frustum divided by its height. Note that the resulting\r\n * volume is both vertically and horizontally symmetrical around the center of\r\n * the near plane.\r\n *\r\n * @param near The near Z value.\r\n * @param far The far Z value.\r\n * @param fovY The field of view.\r\n * @param aspect The aspect ratio.\r\n * @returns A matrix.\r\n */\r\nfunction makePerspective(near, far, fovY, aspect) {\r\n var ymax = near * Math.tan(toRadians(fovY / 2.0));\r\n var xmax = ymax * aspect;\r\n var left = -xmax;\r\n var right = xmax;\r\n var top = ymax;\r\n var bottom = -ymax;\r\n return makeFrustum(left, right, top, bottom, near, far);\r\n}\r\n/**\r\n * Creates an orthographic projection matrix.\r\n *\r\n * Related to: gluOrtho. The viewing volume is cube-shaped and defined by\r\n * the six parameters. The left and right values represent the coordinates of\r\n * the vertical clipping planes, top and bottom values represent the coordinates\r\n * of the horizontal clipping planes, and near and far values represent the\r\n * coordinates of the depth clipping planes.\r\n *\r\n * @param left The coordinate of the left horizontal clipping plane.\r\n * @param right The coordinate of the right horizontal clipping plane.\r\n * @param bottom The coordinate of the bottom vertical clipping plane.\r\n * @param top The coordinate of the top vertical clipping plane.\r\n * @param near The coordinate of the near depth clipping plane.\r\n * @param far The coordinate of the far depth clipping plane.\r\n * @returns A matrix.\r\n */\r\nfunction makeOrthographic(left, right, bottom, top, near, far) {\r\n var w = 1.0 / (right - left);\r\n var h = 1.0 / (top - bottom);\r\n var d = 1.0 / (far - near);\r\n var x = (right + left) * w;\r\n var y = (top + bottom) * h;\r\n var z = (far + near) * d;\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n 2 * w, 0, 0, -x,\r\n 0, 2 * h, 0, -y,\r\n 0, 0, -2 * d, -z,\r\n 0, 0, 0, 1\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Matrix becomes a combination of an inverse translation and rotation.\r\n *\r\n * Related to: gluLookAt. This creates the inverse of makeLookAtMatrix. The\r\n * matrix will be an opposite translation from the 'eye' position, and it will\r\n * rotate things in the opposite direction of the eye-to-center orientation.\r\n * This is definitely confusing, but the main reason to use this transform is to\r\n * set up a view matrix for a camera that's looking at a certain point. To\r\n * achieve the effect of moving the camera somewhere and rotating it so that it\r\n * points at something, the rest of the world is moved in the opposite direction\r\n * and rotated in the opposite way around the camera. This way, you get the same\r\n * effect as moving the actual camera, but all the projection math can still be\r\n * done with the camera positioned at the origin (which makes it way simpler).\r\n *\r\n * @param position The position of the object.\r\n * @param lookAt The point which the object is looking at.\r\n * @param up The direction which the object considers up.\r\n * @returns A matrix.\r\n */\r\nfunction makeLookAtView(position, lookAt, up) {\r\n var z = normalize(subtract(position, lookAt));\r\n var x = normalize(cross(up, z));\r\n var y = cross(z, x);\r\n var dotX = -dot$1(x, position);\r\n var dotY = -dot$1(y, position);\r\n var dotZ = -dot$1(z, position);\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n x.x, y.x, z.x, 0,\r\n x.y, y.y, z.y, 0,\r\n x.z, y.z, z.z, 0,\r\n dotX, dotY, dotZ, 1,\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Matrix becomes a combination of translation and rotation.\r\n *\r\n * Matrix becomes a combination of a translation to the position of 'eye' and a\r\n * rotation matrix which orients an object to point towards 'center' along its\r\n * z-axis. Use this function if you want an object to look at a point from\r\n * another point in space.\r\n *\r\n * @param position The position of the object.\r\n * @param lookAt The point which the object is looking at.\r\n * @param up The direction which the object considers up.\r\n * @returns A matrix.\r\n */\r\nfunction makeLookAt(position, lookAt, up) {\r\n var z = normalize(subtract(position, lookAt));\r\n var x = normalize(cross(up, z));\r\n var y = cross(z, x);\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n x.x, x.y, x.z, 0,\r\n y.x, y.y, y.z, 0,\r\n z.x, z.y, z.z, 0,\r\n position.x, position.y, position.z, 1\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Returns the inverse of the given matrix. If the determinate of the matrix is\r\n * zero, then a zero matrix is returned.\r\n */\r\nfunction invert(matrix) {\r\n var a00 = matrix[0], a01 = matrix[1], a02 = matrix[2], a03 = matrix[3];\r\n var a10 = matrix[4], a11 = matrix[5], a12 = matrix[6], a13 = matrix[7];\r\n var a20 = matrix[8], a21 = matrix[9], a22 = matrix[10], a23 = matrix[11];\r\n var a30 = matrix[12], a31 = matrix[13], a32 = matrix[14], a33 = matrix[15];\r\n var b00 = a00 * a11 - a01 * a10;\r\n var b01 = a00 * a12 - a02 * a10;\r\n var b02 = a00 * a13 - a03 * a10;\r\n var b03 = a01 * a12 - a02 * a11;\r\n var b04 = a01 * a13 - a03 * a11;\r\n var b05 = a02 * a13 - a03 * a12;\r\n var b06 = a20 * a31 - a21 * a30;\r\n var b07 = a20 * a32 - a22 * a30;\r\n var b08 = a20 * a33 - a23 * a30;\r\n var b09 = a21 * a32 - a22 * a31;\r\n var b10 = a21 * a33 - a23 * a31;\r\n var b11 = a22 * a33 - a23 * a32;\r\n // Calculate the determinant\r\n var det = b00 * b11 - b01 * b10 + b02 * b09 + b03 * b08 - b04 * b07 + b05 * b06;\r\n if (!det) {\r\n return makeZero();\r\n }\r\n det = 1.0 / det;\r\n return [\r\n (a11 * b11 - a12 * b10 + a13 * b09) * det,\r\n (a02 * b10 - a01 * b11 - a03 * b09) * det,\r\n (a31 * b05 - a32 * b04 + a33 * b03) * det,\r\n (a22 * b04 - a21 * b05 - a23 * b03) * det,\r\n (a12 * b08 - a10 * b11 - a13 * b07) * det,\r\n (a00 * b11 - a02 * b08 + a03 * b07) * det,\r\n (a32 * b02 - a30 * b05 - a33 * b01) * det,\r\n (a20 * b05 - a22 * b02 + a23 * b01) * det,\r\n (a10 * b10 - a11 * b08 + a13 * b06) * det,\r\n (a01 * b08 - a00 * b10 - a03 * b06) * det,\r\n (a30 * b04 - a31 * b02 + a33 * b00) * det,\r\n (a21 * b02 - a20 * b04 - a23 * b00) * det,\r\n (a11 * b07 - a10 * b09 - a12 * b06) * det,\r\n (a00 * b09 - a01 * b07 + a02 * b06) * det,\r\n (a31 * b01 - a30 * b03 - a32 * b00) * det,\r\n (a20 * b03 - a21 * b01 + a22 * b00) * det,\r\n ];\r\n}\r\n/**\r\n * Returns a rotation matrix looking from position towards target and oriented\r\n * by an up vector.\r\n *\r\n * @param m The matrix to transform.\r\n * @param position The point from which to look at target.\r\n * @param target The point to look at.\r\n * @param up The orientation.\r\n * @returns A rotation matrix.\r\n */\r\nfunction lookAt(m, position, target, up) {\r\n var z = subtract(position, target);\r\n if (magnitudeSquared(z) === 0) {\r\n z = __assign(__assign({}, z), { z: 1 });\r\n }\r\n z = normalize(z);\r\n var x = cross(up, z);\r\n if (magnitudeSquared(x) === 0) {\r\n if (Math.abs(up.z) === 1) {\r\n z = __assign(__assign({}, z), { x: z.x + 0.0001 });\r\n }\r\n else {\r\n z = __assign(__assign({}, z), { z: z.z + 0.0001 });\r\n }\r\n z = normalize(z);\r\n x = cross(up, z);\r\n }\r\n x = normalize(x);\r\n var y = cross(z, x);\r\n var res = __spreadArray([], m, true);\r\n /* eslint-disable prettier/prettier */\r\n res[0] = x.x;\r\n res[4] = y.x;\r\n res[8] = z.x;\r\n res[1] = x.y;\r\n res[5] = y.y;\r\n res[9] = z.y;\r\n res[2] = x.z;\r\n res[6] = y.z;\r\n res[10] = z.z;\r\n /* eslint-enable prettier/prettier */\r\n return res;\r\n}\r\n/**\r\n * Returns a post-multiplied matrix.\r\n */\r\nfunction multiply$2(a, b) {\r\n var ae = a;\r\n var be = b;\r\n var a11 = ae[0], a12 = ae[4], a13 = ae[8], a14 = ae[12];\r\n var a21 = ae[1], a22 = ae[5], a23 = ae[9], a24 = ae[13];\r\n var a31 = ae[2], a32 = ae[6], a33 = ae[10], a34 = ae[14];\r\n var a41 = ae[3], a42 = ae[7], a43 = ae[11], a44 = ae[15];\r\n var b11 = be[0], b12 = be[4], b13 = be[8], b14 = be[12];\r\n var b21 = be[1], b22 = be[5], b23 = be[9], b24 = be[13];\r\n var b31 = be[2], b32 = be[6], b33 = be[10], b34 = be[14];\r\n var b41 = be[3], b42 = be[7], b43 = be[11], b44 = be[15];\r\n var mat = makeIdentity();\r\n mat[0] = a11 * b11 + a12 * b21 + a13 * b31 + a14 * b41;\r\n mat[4] = a11 * b12 + a12 * b22 + a13 * b32 + a14 * b42;\r\n mat[8] = a11 * b13 + a12 * b23 + a13 * b33 + a14 * b43;\r\n mat[12] = a11 * b14 + a12 * b24 + a13 * b34 + a14 * b44;\r\n mat[1] = a21 * b11 + a22 * b21 + a23 * b31 + a24 * b41;\r\n mat[5] = a21 * b12 + a22 * b22 + a23 * b32 + a24 * b42;\r\n mat[9] = a21 * b13 + a22 * b23 + a23 * b33 + a24 * b43;\r\n mat[13] = a21 * b14 + a22 * b24 + a23 * b34 + a24 * b44;\r\n mat[2] = a31 * b11 + a32 * b21 + a33 * b31 + a34 * b41;\r\n mat[6] = a31 * b12 + a32 * b22 + a33 * b32 + a34 * b42;\r\n mat[10] = a31 * b13 + a32 * b23 + a33 * b33 + a34 * b43;\r\n mat[14] = a31 * b14 + a32 * b24 + a33 * b34 + a34 * b44;\r\n mat[3] = a41 * b11 + a42 * b21 + a43 * b31 + a44 * b41;\r\n mat[7] = a41 * b12 + a42 * b22 + a43 * b32 + a44 * b42;\r\n mat[11] = a41 * b13 + a42 * b23 + a43 * b33 + a44 * b43;\r\n mat[15] = a41 * b14 + a42 * b24 + a43 * b34 + a44 * b44;\r\n return mat;\r\n}\r\n/**\r\n * Returns the [transpose](https://en.wikipedia.org/wiki/Transpose) of the given\r\n * matrix.\r\n */\r\nfunction transpose(matrix) {\r\n /* eslint-disable prettier/prettier */\r\n return [\r\n matrix[0], matrix[4], matrix[8], matrix[12],\r\n matrix[1], matrix[5], matrix[9], matrix[13],\r\n matrix[2], matrix[6], matrix[10], matrix[14],\r\n matrix[3], matrix[7], matrix[11], matrix[15],\r\n ];\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * Multiplies the columns of a matrix by the given vector.\r\n */\r\nfunction scale$3(matrix, scale) {\r\n var x = scale.x, y = scale.y, z = scale.z;\r\n var m = __spreadArray([], matrix, true);\r\n /* eslint-disable prettier/prettier */\r\n m[0] *= x;\r\n m[4] *= y;\r\n m[8] *= z;\r\n m[1] *= x;\r\n m[5] *= y;\r\n m[9] *= z;\r\n m[2] *= x;\r\n m[6] *= y;\r\n m[10] *= z;\r\n m[3] *= x;\r\n m[7] *= y;\r\n m[11] *= z;\r\n /* eslint-enable prettier/prettier */\r\n return m;\r\n}\r\nfunction position(matrix, other) {\r\n var m = __spreadArray([], matrix, true);\r\n m[12] = other[12];\r\n m[13] = other[13];\r\n m[14] = other[14];\r\n return m;\r\n}\r\n/**\r\n * Returns an object representation of a `Matrix4`.\r\n */\r\nfunction toObject(m) {\r\n /* eslint-disable prettier/prettier */\r\n return {\r\n m11: m[0], m12: m[4], m13: m[8], m14: m[12],\r\n m21: m[1], m22: m[5], m23: m[9], m24: m[13],\r\n m31: m[2], m32: m[6], m33: m[10], m34: m[14],\r\n m41: m[3], m42: m[7], m43: m[11], m44: m[15],\r\n };\r\n /* eslint-enable prettier/prettier */\r\n}\r\n/**\r\n * A type guard to check if `obj` is of type `Matrix4`.\r\n */\r\nfunction isType$2(obj) {\r\n return Array.isArray(obj) && obj.length === 16;\r\n}\n\nvar matrix4 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n fromValues: fromValues,\n fromObject: fromObject,\n makeIdentity: makeIdentity,\n makeZero: makeZero,\n makeTranslation: makeTranslation,\n makeRotation: makeRotation,\n makeScale: makeScale,\n makeTRS: makeTRS,\n makeBasis: makeBasis,\n makeRotationAxis: makeRotationAxis,\n makeFrustum: makeFrustum,\n makePerspective: makePerspective,\n makeOrthographic: makeOrthographic,\n makeLookAtView: makeLookAtView,\n makeLookAt: makeLookAt,\n invert: invert,\n lookAt: lookAt,\n multiply: multiply$2,\n transpose: transpose,\n scale: scale$3,\n position: position,\n toObject: toObject,\n isType: isType$2\n});\n\nfunction create$b() {\r\n var _a, _b, _c, _d, _e, _f;\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n if (args.length === 1) {\r\n return {\r\n x: (_a = args[0].x) !== null && _a !== void 0 ? _a : 0,\r\n y: (_b = args[0].y) !== null && _b !== void 0 ? _b : 0,\r\n z: (_c = args[0].z) !== null && _c !== void 0 ? _c : 0,\r\n };\r\n }\r\n else if (args.length === 3) {\r\n return {\r\n x: (_d = args[0]) !== null && _d !== void 0 ? _d : 0,\r\n y: (_e = args[1]) !== null && _e !== void 0 ? _e : 0,\r\n z: (_f = args[2]) !== null && _f !== void 0 ? _f : 0,\r\n };\r\n }\r\n return {\r\n x: 0,\r\n y: 0,\r\n z: 0,\r\n };\r\n}\r\n/* eslint-enable @typescript-eslint/no-explicit-any */\r\n/* eslint-enable padding-line-between-statements */\r\n/**\r\n * Checks if each component of the given vector is populated with a numeric\r\n * component. A component is invalid if it contains a non-finite or NaN value.\r\n */\r\nfunction isValid(_a) {\r\n var x = _a.x, y = _a.y, z = _a.z;\r\n return [x, y, z].every(function (v) { return isFinite(v) && !isNaN(v); });\r\n}\r\n/**\r\n * Returns a vector representing the scale elements of `matrix`.\r\n */\r\nfunction fromMatrixScale(matrix) {\r\n var m = toObject(matrix);\r\n return {\r\n x: Math.hypot(m.m11, m.m21, m.m31),\r\n y: Math.hypot(m.m12, m.m22, m.m32),\r\n z: Math.hypot(m.m13, m.m23, m.m33),\r\n };\r\n}\r\n/**\r\n * Returns a vector representing the position elements of `matrix`.\r\n */\r\nfunction fromMatrixPosition(matrix) {\r\n var m = toObject(matrix);\r\n return { x: m.m14, y: m.m24, z: m.m34 };\r\n}\r\n/**\r\n * Parses a JSON string representation of a Vector3 and returns an object.\r\n *\r\n * @param json A JSON string, either in the form `[x,y,z]` or `{\"x\": 0, \"y\": 0, \"z\": 0}`\r\n * @returns A parsed Vector3.\r\n */\r\nfunction fromJson$3(json) {\r\n var obj = JSON.parse(json);\r\n if (Array.isArray(obj)) {\r\n var x = obj[0], y = obj[1], z = obj[2];\r\n return create$b(x, y, z);\r\n }\r\n else {\r\n var x = obj.x, y = obj.y, z = obj.z;\r\n return create$b(x, y, z);\r\n }\r\n}\r\n/**\r\n * Creates a `Vector3` from an array. Pass `offset` to read values from the\r\n * starting index.\r\n *\r\n * @see #toArray()\r\n * @see #create()\r\n */\r\nfunction fromArray(nums, offset) {\r\n if (offset === void 0) { offset = 0; }\r\n var x = nums[offset];\r\n var y = nums[offset + 1];\r\n var z = nums[offset + 2];\r\n return create$b(x, y, z);\r\n}\r\n/**\r\n * Converts a Vector3 to an array where the values of the vector will be\r\n * represented as [x, y, z];\r\n *\r\n * @see #fromArray()\r\n * @see #create()\r\n */\r\nfunction toArray(_a) {\r\n var x = _a.x, y = _a.y, z = _a.z;\r\n return [x, y, z];\r\n}\r\n/**\r\n * Returns a directional vector on the positive x axis, Vector3(1, 0, 0).\r\n */\r\nfunction right() {\r\n return create$b(1, 0, 0);\r\n}\r\n/**\r\n * Returns a directional vector on the positive y axis, Vector3(0, 1, 0).\r\n */\r\nfunction up() {\r\n return create$b(0, 1, 0);\r\n}\r\n/**\r\n * Returns a directional vector on the positive z axis, Vector3(0, 0, -1).\r\n */\r\nfunction forward() {\r\n return create$b(0, 0, -1);\r\n}\r\n/**\r\n * Returns a directional vector on the negative x axis, Vector3(-1, 0, 0).\r\n */\r\nfunction left() {\r\n return create$b(-1, 0, 0);\r\n}\r\n/**\r\n * Returns a directional vector on the negative y axis, Vector3(0, -1, 0).\r\n */\r\nfunction down() {\r\n return create$b(0, -1, 0);\r\n}\r\n/**\r\n * Returns a directional vector on the negative z axis, Vector3(0, 0, 1).\r\n */\r\nfunction back() {\r\n return create$b(0, 0, 1);\r\n}\r\n/**\r\n * Returns a vector at the origin, Vector3(0, 0, 0).\r\n */\r\nfunction origin() {\r\n return create$b(0, 0, 0);\r\n}\r\n/**\r\n * Returns a vector with that will have a magnitude of 1.\r\n */\r\nfunction normalize(vector) {\r\n var length = magnitude(vector);\r\n return { x: vector.x / length, y: vector.y / length, z: vector.z / length };\r\n}\r\n/**\r\n * Returns the straight-line length from (0, 0, 0) to the given vector.\r\n */\r\nfunction magnitude(vector) {\r\n return Math.sqrt(magnitudeSquared(vector));\r\n}\r\n/**\r\n * Returns the straight-line length from (0, 0, 0) to the given vector).\r\n *\r\n * When comparing lengths of vectors, you should use this function as it's\r\n * slightly more efficient to calculate.\r\n */\r\nfunction magnitudeSquared(vector) {\r\n return vector.x * vector.x + vector.y * vector.y + vector.z * vector.z;\r\n}\r\n/**\r\n * Returns a vector that is the cross product of two vectors.\r\n *\r\n * The cross product of two vectors results in a third vector which is\r\n * perpendicular to the two input vectors. The result's magnitude is equal to\r\n * the magnitudes of the two inputs multiplied together and then multiplied by\r\n * the sine of the angle between the inputs. You can determine the direction of\r\n * the result vector using the \"left hand rule\".\r\n */\r\nfunction cross(a, b) {\r\n return {\r\n x: a.y * b.z - a.z * b.y,\r\n y: a.z * b.x - a.x * b.z,\r\n z: a.x * b.y - a.y * b.x,\r\n };\r\n}\r\n/**\r\n * Returns a vector that is the sum of two vectors.\r\n */\r\nfunction add(a) {\r\n var vectors = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n vectors[_i - 1] = arguments[_i];\r\n }\r\n return vectors.reduce(function (res, next) {\r\n return { x: res.x + next.x, y: res.y + next.y, z: res.z + next.z };\r\n }, a);\r\n}\r\n/**\r\n * Returns a vector that is the difference between two vectors.\r\n */\r\nfunction subtract(a) {\r\n var vectors = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n vectors[_i - 1] = arguments[_i];\r\n }\r\n return vectors.reduce(function (res, next) {\r\n return { x: res.x - next.x, y: res.y - next.y, z: res.z - next.z };\r\n }, a);\r\n}\r\n/**\r\n * Returns a vector that where each component of `b` is multiplied with `a`.\r\n */\r\nfunction multiply$1(a, b) {\r\n return { x: a.x * b.x, y: a.y * b.y, z: a.z * b.z };\r\n}\r\n/**\r\n * Returns a vector where each value of a vector is multiplied by the `scalar`.\r\n */\r\nfunction scale$2(scalar, vector) {\r\n return { x: vector.x * scalar, y: vector.y * scalar, z: vector.z * scalar };\r\n}\r\n/**\r\n * Returns a value representing the dot product of two vectors.\r\n *\r\n * The dot product is a float value equal to the magnitudes of the two vectors\r\n * multiplied together and then multiplied by the cosine of the angle between\r\n * them.\r\n */\r\nfunction dot$1(a, b) {\r\n return a.x * b.x + a.y * b.y + a.z * b.z;\r\n}\r\n/**\r\n * Returns the angle, in radians, between two vectors.\r\n *\r\n * The angle returned is the unsigned angle between the two vectors. This means\r\n * the smaller of the two possible angles between the two vectors is used. The\r\n * result is never greater than 180 degrees.\r\n */\r\nfunction angleTo(a, b) {\r\n var theta = dot$1(a, b) / (magnitude(a) * magnitude(b));\r\n // Clamp to avoid numerical problems.\r\n return Math.acos(theta);\r\n}\r\n/**\r\n * Performs a projection of a `vector` onto `onNormal`.\r\n *\r\n * A projection is represented as the nearest point along a normal to a vector,\r\n * which constructs a triangle from the origin, to the vector, to the projected\r\n * point.\r\n *\r\n * ```\r\n * Vector --> * * <-- Projected\r\n * \\\r\n * \\ | <-- Normal\r\n * \\|\r\n * * <-- Origin\r\n * ```\r\n */\r\nfunction project(vector, onNormal) {\r\n return scale$2(dot$1(onNormal, vector) / magnitude(onNormal), onNormal);\r\n}\r\n/**\r\n * Returns a vector that is rotated about an origin point.\r\n *\r\n * @param angle The angle to rotate, in radians.\r\n * @param point The origin point to rotate around.\r\n * @param axisDirection The direction used to compute the axis.\r\n * @param axisPosition The point of the axis.\r\n */\r\nfunction rotateAboutAxis(angle, point, axisDirection, axisPosition) {\r\n if (angle !== 0) {\r\n var x = point.x, y = point.y, z = point.z;\r\n var a = axisPosition.x, b = axisPosition.y, c = axisPosition.z;\r\n var u = axisDirection.x, v = axisDirection.y, w = axisDirection.z;\r\n var newX = (a * (v * v + w * w) - u * (b * v + c * w - u * x - v * y - w * z)) *\r\n (1 - Math.cos(angle)) +\r\n x * Math.cos(angle) +\r\n (-c * v + b * w - w * y + v * z) * Math.sin(angle);\r\n var newY = (b * (u * u + w * w) - v * (a * u + c * w - u * x - v * y - w * z)) *\r\n (1 - Math.cos(angle)) +\r\n y * Math.cos(angle) +\r\n (c * u - a * w + w * x - u * z) * Math.sin(angle);\r\n var newZ = (c * (u * u + v * v) - w * (a * u + b * v - u * x - v * y - w * z)) *\r\n (1 - Math.cos(angle)) +\r\n z * Math.cos(angle) +\r\n (-b * u + a * v - v * x + u * y) * Math.sin(angle);\r\n return { x: newX, y: newY, z: newZ };\r\n }\r\n else {\r\n return point;\r\n }\r\n}\r\n/**\r\n * Returns a vector that is multiplied with a matrix.\r\n */\r\nfunction transformMatrix$1(vector, m) {\r\n var x = vector.x, y = vector.y, z = vector.z;\r\n var w = 1 / (m[3] * x + m[7] * y + m[11] * z + m[15]);\r\n return {\r\n x: (m[0] * x + m[4] * y + m[8] * z + m[12]) * w,\r\n y: (m[1] * x + m[5] * y + m[9] * z + m[13]) * w,\r\n z: (m[2] * x + m[6] * y + m[10] * z + m[14]) * w,\r\n };\r\n}\r\n/**\r\n * Euclidean distance between two vectors\r\n */\r\nfunction distance$1(a, b) {\r\n return Math.sqrt(distanceSquared$1(a, b));\r\n}\r\n/**\r\n * Returns the squared distance between two vectors. If you're just comparing\r\n * distances, this is slightly more efficient than `distanceTo`.\r\n */\r\nfunction distanceSquared$1(a, b) {\r\n var _a = subtract(a, b), dx = _a.x, dy = _a.y, dz = _a.z;\r\n return dx * dx + dy * dy + dz * dz;\r\n}\r\n/**\r\n * Returns `true` if two vectors have the same values.\r\n */\r\nfunction isEqual$2(a, b) {\r\n return a.x === b.x && a.y === b.y && a.z === b.z;\r\n}\r\n/**\r\n * Returns a vector that contains the largest components of `a` and `b`.\r\n */\r\nfunction max(a, b) {\r\n return create$b(Math.max(a.x, b.x), Math.max(a.y, b.y), Math.max(a.z, b.z));\r\n}\r\n/**\r\n * Returns a vector that contains the smallest components of `a` and `b`.\r\n */\r\nfunction min(a, b) {\r\n return create$b(Math.min(a.x, b.x), Math.min(a.y, b.y), Math.min(a.z, b.z));\r\n}\r\n/**\r\n * Returns a vector that each of its component negated.\r\n */\r\nfunction negate(vector) {\r\n return { x: -vector.x, y: -vector.y, z: -vector.z };\r\n}\r\n/**\r\n * Performs a linear interpolation between `a` and `b` and returns the result.\r\n * The value of `t` is clamped between `[0, 1]`.\r\n *\r\n * @param a The start value.\r\n * @param b The end value.\r\n * @param t A value between 0 and 1.\r\n * @returns A point between `a` and `b`.\r\n */\r\nfunction lerp(a, b, t) {\r\n return {\r\n x: lerp$2(a.x, b.x, t),\r\n y: lerp$2(a.y, b.y, t),\r\n z: lerp$2(a.z, b.z, t),\r\n };\r\n}\r\n/**\r\n * Maps a normalized device coordinate (NDC) space to world space coordinates.\r\n *\r\n * @param ndc A point in normalized device coordinates.\r\n * @param worldMatrix A camera's world matrix.\r\n * @param projectionMatrixInverse A camera's inverse projection matrix.\r\n * @returns A point in world space coordinates.\r\n */\r\nfunction transformNdcToWorldSpace(ndc, worldMatrix, projectionMatrixInverse) {\r\n return transformMatrix$1(transformMatrix$1(ndc, projectionMatrixInverse), worldMatrix);\r\n}\n\nvar vector3 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$b,\n isValid: isValid,\n fromMatrixScale: fromMatrixScale,\n fromMatrixPosition: fromMatrixPosition,\n fromJson: fromJson$3,\n fromArray: fromArray,\n toArray: toArray,\n right: right,\n up: up,\n forward: forward,\n left: left,\n down: down,\n back: back,\n origin: origin,\n normalize: normalize,\n magnitude: magnitude,\n magnitudeSquared: magnitudeSquared,\n cross: cross,\n add: add,\n subtract: subtract,\n multiply: multiply$1,\n scale: scale$2,\n dot: dot$1,\n angleTo: angleTo,\n project: project,\n rotateAboutAxis: rotateAboutAxis,\n transformMatrix: transformMatrix$1,\n distance: distance$1,\n distanceSquared: distanceSquared$1,\n isEqual: isEqual$2,\n max: max,\n min: min,\n negate: negate,\n lerp: lerp,\n transformNdcToWorldSpace: transformNdcToWorldSpace\n});\n\n/**\r\n * Returns a `BoundingBox` with the given min and max points.\r\n */\r\nvar create$a = function (min, max) {\r\n return { min: min, max: max };\r\n};\r\n/**\r\n * Construct a minimal bounding box for a set of vectors, such that all vectors\r\n * are contained by the bounding box.\r\n */\r\nvar fromVectors = function (vectors) {\r\n return union.apply(void 0, vectors.map(function (v) { return create$a(v, v); }));\r\n};\r\n/**\r\n * Returns the center point of the given `BoundingBox`.\r\n */\r\nvar center$3 = function (boundingBox) {\r\n return scale$2(0.5, add(boundingBox.min, boundingBox.max));\r\n};\r\n/**\r\n * Returns the diagonal vector between the `min` and `max` vectors of the\r\n * given `BoundingBox`.\r\n */\r\nvar diagonal = function (boundingBox) {\r\n return subtract(boundingBox.max, boundingBox.min);\r\n};\r\n/**\r\n * Returns a floating-point spatial error tolerance based on the extents of the box.\r\n */\r\nvar epsilon = function (boundingBox) {\r\n return (Math.max(Math.max(magnitude(boundingBox.max), magnitude(boundingBox.min)), magnitude(diagonal(boundingBox))) * 1e-6);\r\n};\r\nfunction union(box) {\r\n var rest = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n rest[_i - 1] = arguments[_i];\r\n }\r\n var boxes = __spreadArray([box], rest, true);\r\n return boxes.reduce(function (a, b) {\r\n return create$a(min(a.min, b.min), max(a.max, b.max));\r\n });\r\n}\r\n/* eslint-enable padding-line-between-statements */\n\nvar boundingBox = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$a,\n fromVectors: fromVectors,\n center: center$3,\n diagonal: diagonal,\n epsilon: epsilon,\n union: union\n});\n\n/**\r\n * Returns a `BoundingSphere` that encompasses the provided `BoundingBox`.\r\n */\r\nvar create$9 = function (boundingBox$1) {\r\n var boundingBoxCenter = center$3(boundingBox$1);\r\n var centerToBoundingPlane = subtract(boundingBox$1.max, boundingBoxCenter);\r\n var radius = magnitude(centerToBoundingPlane);\r\n var length = Math.max(radius, magnitude(boundingBoxCenter));\r\n var epsilon = length === 0 ? 1.0 : length * 1e-6;\r\n return { center: boundingBoxCenter, radius: radius, epsilon: epsilon };\r\n};\n\nvar boundingSphere = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$9\n});\n\n/**\r\n * Returns a new `Rectangle` with the given position and size.\r\n */\r\nfunction create$8(x, y, width, height) {\r\n return { x: x, y: y, width: width, height: height };\r\n}\r\n/**\r\n * Returns a new `Rectangle` at the origin point and given size.\r\n */\r\nfunction fromDimensions(dimensions) {\r\n return create$8(0, 0, dimensions.width, dimensions.height);\r\n}\r\n/**\r\n * Returns a new `Rectangle` with the given position and size.\r\n */\r\nfunction fromPointAndDimensions(point, dimensions) {\r\n return create$8(point.x, point.y, dimensions.width, dimensions.height);\r\n}\r\n/**\r\n * Returns a new `Rectangle` with the given top-left and bottom-right positions.\r\n * The returned rectangle will always returns a positive width and height.\r\n */\r\nfunction fromPoints(topLeftPt, bottomRightPt) {\r\n var minX = Math.min(topLeftPt.x, bottomRightPt.x);\r\n var minY = Math.min(topLeftPt.y, bottomRightPt.y);\r\n var maxX = Math.max(topLeftPt.x, bottomRightPt.x);\r\n var maxY = Math.max(topLeftPt.y, bottomRightPt.y);\r\n return create$8(minX, minY, maxX - minX, maxY - minY);\r\n}\r\n/**\r\n * Returns a rectangle where the longest length of `rect` will be equal to the\r\n * shortest length of `to`. The shortest length of `rect` will be proportionally\r\n * scaled to match the aspect ratio of `rect`. The returned rectangle will be\r\n * centered within `to`.\r\n *\r\n * @see {@link cropFit}\r\n */\r\nfunction containFit$1(to, rect) {\r\n var scale = Math.min(to.width / rect.width, to.height / rect.height);\r\n var dimensions$1 = proportionalScale(scale, rect);\r\n var position = subtract$1(center$2(to), center$1(dimensions$1));\r\n return fromPointAndDimensions(position, dimensions$1);\r\n}\r\n/**\r\n * Returns a rectangle where the shortest length of `rect` will be equal to the\r\n * longest length of `to`. The longest length of `rect` will be proportionally\r\n * scaled to match the aspect ratio of `rect`. The returned rectangle will be\r\n * centered within `to`.\r\n *\r\n * @see {@link containFit}\r\n */\r\nfunction cropFit$1(to, rect) {\r\n var scale = Math.max(to.width / rect.width, to.height / rect.height);\r\n var dimensions$1 = proportionalScale(scale, rect);\r\n var position = subtract$1(center$2(to), center$1(dimensions$1));\r\n return fromPointAndDimensions(position, dimensions$1);\r\n}\r\n/**\r\n * Returns a rectangle where each side of `rect` will be reduced proportionally\r\n * to have an area less than or equal to the provided `to` value. The returned\r\n * rectangle will be centered within the original bounds of `rect`.\r\n *\r\n * @param to - the maximum area this rectangle can have\r\n * @param rect - the rectangle to scale to fit the specified area\r\n */\r\nfunction scaleFit$1(to, rect) {\r\n var scale = Math.min(Math.sqrt(to / area$1(rect)), 1);\r\n var dimensions$1 = floor(proportionalScale(scale, rect));\r\n var position = subtract$1(center$2(rect), center$1(dimensions$1));\r\n return fromPointAndDimensions(position, dimensions$1);\r\n}\r\n/**\r\n * Returns a rectangle where the position and dimensions are scaled by the given\r\n * factors. If `scaleY` is omitted, then the position and dimensions are scaled\r\n * uniformly by `scaleOrScaleX`.\r\n *\r\n * @param rect The rectangle to scale.\r\n * @param scaleOrScaleX The uniform scale factor, or the horizontal scale\r\n * factor.\r\n * @param scaleY The vertical scale factor.\r\n * @returns A scaled rectangle.\r\n */\r\nfunction scale$1(rect, scaleOrScaleX, scaleY) {\r\n if (scaleY == null) {\r\n return scale$1(rect, scaleOrScaleX, scaleOrScaleX);\r\n }\r\n else {\r\n var x = rect.x, y = rect.y, width = rect.width, height = rect.height;\r\n var scaleX = scaleOrScaleX;\r\n return create$8(x * scaleX, y * scaleY, width * scaleX, height * scaleY);\r\n }\r\n}\r\n/**\r\n * Returns true if two rectangles are equal in position and size.\r\n */\r\nfunction isEqual$1(a, b) {\r\n return isEqual$3(a, b) && isEqual(a, b);\r\n}\r\n/**\r\n * Returns a rectangle that has its position shifted by a given offset. The\r\n * size of the rectangle is unchanged.\r\n */\r\nfunction offset(delta, rect) {\r\n return fromPointAndDimensions(add$1(topLeft(rect), delta), rect);\r\n}\r\n/**\r\n * Returns the area of the rectangle.\r\n */\r\nfunction area$1(rect) {\r\n return rect.width * rect.height;\r\n}\r\n/**\r\n * Returns the center point of the rectangle.\r\n */\r\nfunction center$2(rect) {\r\n return { x: rect.x + rect.width / 2, y: rect.y + rect.height / 2 };\r\n}\r\n/**\r\n * Returns the top-left position of the rectangle, as a point.\r\n */\r\nfunction topLeft(rect) {\r\n return create$c(rect.x, rect.y);\r\n}\r\n/**\r\n * Returns the bottom-right position of the rectangle, as a point.\r\n */\r\nfunction bottomRight(rect) {\r\n return create$c(rect.x + rect.width, rect.y + rect.height);\r\n}\r\n/**\r\n * Returns `true` if the given rectangle has a portrait aspect ratio.\r\n */\r\nfunction isPortrait(rect) {\r\n return rect.width < rect.height;\r\n}\r\n/**\r\n * Returns `true` if the given rectangle has a landscape aspect ratio.\r\n */\r\nfunction isLandscape(rect) {\r\n return rect.width > rect.height;\r\n}\r\n/**\r\n * Returns `true` if the given rectangle has a square aspect ratio.\r\n */\r\nfunction isSquare(rect) {\r\n return rect.width === rect.height;\r\n}\r\n/**\r\n * Pads a rectangle by the given amount, maintaining the center position.\r\n *\r\n * @param rect The rectangle to apply padding to.\r\n * @param padding The padding to add.\r\n */\r\nfunction pad(rect, padding) {\r\n return create$8(rect.x - padding, rect.y - padding, rect.width + padding * 2, rect.height + padding * 2);\r\n}\r\n/**\r\n * Returns `true` if the given rectangle contains all the given `points`.\r\n *\r\n * @param rect The rectangle to check against.\r\n * @param points The points to check.\r\n */\r\nfunction containsPoints(rect) {\r\n var points = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n points[_i - 1] = arguments[_i];\r\n }\r\n return points.every(function (point) {\r\n return (rect.x <= point.x &&\r\n rect.x + rect.width >= point.x &&\r\n rect.y <= point.y &&\r\n rect.y + rect.height >= point.y);\r\n });\r\n}\r\n/**\r\n * Parses a JSON string representation of a Rectangle and returns an object.\r\n *\r\n * @param json A JSON string, either in the form `[x,y,width,height]` or `{\"x\": 0, \"y\": 0, \"width\": 10, \"height\": 10}`\r\n * @returns A parsed Point.\r\n */\r\nfunction fromJson$2(json) {\r\n var obj = JSON.parse(json);\r\n if (Array.isArray(obj)) {\r\n var x = obj[0], y = obj[1], width = obj[2], height = obj[3];\r\n return create$8(x, y, width, height);\r\n }\r\n else {\r\n var x = obj.x, y = obj.y, width = obj.width, height = obj.height;\r\n return create$8(x, y, width, height);\r\n }\r\n}\n\nvar rectangle = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$8,\n fromDimensions: fromDimensions,\n fromPointAndDimensions: fromPointAndDimensions,\n fromPoints: fromPoints,\n containFit: containFit$1,\n cropFit: cropFit$1,\n scaleFit: scaleFit$1,\n scale: scale$1,\n isEqual: isEqual$1,\n offset: offset,\n area: area$1,\n center: center$2,\n topLeft: topLeft,\n bottomRight: bottomRight,\n isPortrait: isPortrait,\n isLandscape: isLandscape,\n isSquare: isSquare,\n pad: pad,\n containsPoints: containsPoints,\n fromJson: fromJson$2\n});\n\n/**\r\n * Returns a `Dimensions` with the given width and height.\r\n *\r\n */\r\nvar create$7 = function (width, height) {\r\n return { width: width, height: height };\r\n};\r\n/**\r\n * Returns a `Dimensions` with the same width and height.\r\n */\r\nvar square = function (size) {\r\n return create$7(size, size);\r\n};\r\n/**\r\n * Returns `true` if two dimensions have the same width and height. Otherwise\r\n * `false`.\r\n */\r\nvar isEqual = function (a, b) {\r\n return a.width === b.width && a.height === b.height;\r\n};\r\n/**\r\n * Returns a scaled dimensions, where the width is scaled by `scaleX` and height\r\n * is scaled by `scaleY`.\r\n */\r\nvar scale = function (scaleX, scaleY, dimensions) {\r\n return {\r\n width: dimensions.width * scaleX,\r\n height: dimensions.height * scaleY,\r\n };\r\n};\r\n/**\r\n * Returns a dimension where each length is scaled by `scaleFactor`.\r\n */\r\nvar proportionalScale = function (scaleFactor, dimensions) {\r\n return scale(scaleFactor, scaleFactor, dimensions);\r\n};\r\n/**\r\n * Returns a `Dimensions` where the lengths of `dimensions` are trimmed to fit\r\n * into `to`.\r\n */\r\nvar trim = function (to, dimensions) {\r\n return {\r\n width: Math.min(to.width, dimensions.width),\r\n height: Math.min(to.height, dimensions.height),\r\n };\r\n};\r\n/**\r\n * Returns a `Dimensions` where the longest length of `dimensions` will be equal\r\n * to the shortest length of `to`. The shortest length of `dimensions` will be\r\n * proportionally scaled to match the aspect ratio of `dimensions`.\r\n *\r\n * @see #cropFit()\r\n */\r\nvar containFit = function (to, dimensions) {\r\n var _a = containFit$1(toRectangle(to), toRectangle(dimensions)), width = _a.width, height = _a.height;\r\n return { width: width, height: height };\r\n};\r\n/**\r\n * Returns a `Dimensions` where the shortest length of `dimensions` will be\r\n * equal to the longest length of `to`. The longest length of `dimensions` will\r\n * be proportionally scaled to match the aspect ratio of `dimensions`.\r\n *\r\n * @see #containFit()\r\n */\r\nvar cropFit = function (to, dimensions) {\r\n var _a = cropFit$1(toRectangle(to), toRectangle(dimensions)), width = _a.width, height = _a.height;\r\n return { width: width, height: height };\r\n};\r\n/**\r\n * Returns a `Dimensions` where each side of `dimensions` will be reduced proportionally\r\n * to have an area less than or equal to the provided `to` value. The returned\r\n * dimensions will be centered within the original bounds of `dimensions`.\r\n *\r\n * @param to - the maximum area this dimensions can have\r\n * @param dimensions - the dimensions to scale to fit the specified area\r\n */\r\nvar scaleFit = function (to, dimensions) {\r\n var _a = scaleFit$1(to, toRectangle(dimensions)), width = _a.width, height = _a.height;\r\n return { width: width, height: height };\r\n};\r\n/**\r\n * Returns a `Dimensions` with each length rounded.\r\n */\r\nvar round = function (dimensions) {\r\n return {\r\n width: Math.round(dimensions.width),\r\n height: Math.round(dimensions.height),\r\n };\r\n};\r\n/**\r\n * Returns a `Dimensions` with each length rounded down.\r\n */\r\nvar floor = function (dimensions) {\r\n return {\r\n width: Math.floor(dimensions.width),\r\n height: Math.floor(dimensions.height),\r\n };\r\n};\r\n/**\r\n * Returns the center point of the given `dimensions`.\r\n */\r\nvar center$1 = function (dimensions) {\r\n return { x: dimensions.width / 2, y: dimensions.height / 2 };\r\n};\r\n/**\r\n * Returns the aspect ratio of the given `dimensions`, as defined by width over\r\n * height.\r\n */\r\nvar aspectRatio = function (_a) {\r\n var width = _a.width, height = _a.height;\r\n return width / height;\r\n};\r\n/**\r\n * Returns the area of the given `dimensions`.\r\n */\r\nvar area = function (_a) {\r\n var width = _a.width, height = _a.height;\r\n return width * height;\r\n};\r\n/**\r\n * Returns a `Dimensions` fitted to the provided aspect ratio.\r\n *\r\n * @param ratio - Aspect ratio to fit the provided Dimensions to\r\n * @param dimensions - Dimensions to fit to the specified ratio\r\n */\r\nvar fitToRatio = function (ratio, dimensions) {\r\n if (dimensions.width >= dimensions.height * ratio) {\r\n return create$7(dimensions.height * ratio, dimensions.height);\r\n }\r\n return create$7(dimensions.width, dimensions.width / ratio);\r\n};\r\n/**\r\n * Converts a dimension to a rectangle, with an optional position.\r\n */\r\nfunction toRectangle(dimensions, position) {\r\n if (position === void 0) { position = create$c(); }\r\n return fromPointAndDimensions(position, dimensions);\r\n}\n\nvar dimensions = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$7,\n square: square,\n isEqual: isEqual,\n scale: scale,\n proportionalScale: proportionalScale,\n trim: trim,\n containFit: containFit,\n cropFit: cropFit,\n scaleFit: scaleFit,\n round: round,\n floor: floor,\n center: center$1,\n aspectRatio: aspectRatio,\n area: area,\n fitToRatio: fitToRatio,\n toRectangle: toRectangle\n});\n\n/**\r\n * Creates a new euler angle where each axis of rotation is defined by an angle,\r\n * in radians. If no value is given, then `{x: 0, y: 0, z: 0, order: 'xyz'}` is\r\n * returned.\r\n *\r\n * @param value The values to populate the euler angle with.\r\n * @returns A euler angle.\r\n */\r\nfunction create$6(value) {\r\n var _a, _b, _c, _d;\r\n if (value === void 0) { value = {}; }\r\n return {\r\n x: (_a = value.x) !== null && _a !== void 0 ? _a : 0,\r\n y: (_b = value.y) !== null && _b !== void 0 ? _b : 0,\r\n z: (_c = value.z) !== null && _c !== void 0 ? _c : 0,\r\n order: (_d = value.order) !== null && _d !== void 0 ? _d : 'xyz',\r\n };\r\n}\r\n/**\r\n * Creates a new euler angle where each axis of rotation is defined by an angle,\r\n * in degrees. If no value is given, then `{x: 0, y: 0, z: 0, order: 'xyz'}` is\r\n * returned.\r\n *\r\n * @param value The values to populate the euler angle with.\r\n * @returns A euler angle.\r\n */\r\nfunction fromDegrees(value) {\r\n if (value === void 0) { value = {}; }\r\n var _a = value.x, x = _a === void 0 ? 0 : _a, _b = value.y, y = _b === void 0 ? 0 : _b, _c = value.z, z = _c === void 0 ? 0 : _c, order = value.order;\r\n return create$6({\r\n x: toRadians(x),\r\n y: toRadians(y),\r\n z: toRadians(z),\r\n order: order,\r\n });\r\n}\r\n/**\r\n * Creates a euler angle from the rotation components of a 4x4 matrix. The\r\n * rotation components are represented by the upper 3x3 of the matrix.\r\n *\r\n * @param matrix A pure rotation matrix, unscaled.\r\n * @param order The order that the rotations are applied.\r\n */\r\nfunction fromRotationMatrix(matrix, order) {\r\n if (order === void 0) { order = 'xyz'; }\r\n var m = toObject(matrix);\r\n var x = 0, y = 0, z = 0;\r\n if (order === 'xyz') {\r\n y = Math.asin(clamp(m.m13, -1, 1));\r\n if (Math.abs(m.m13) < 0.9999999) {\r\n x = Math.atan2(-m.m23, m.m33);\r\n z = Math.atan2(-m.m12, m.m11);\r\n }\r\n else {\r\n x = Math.atan2(m.m32, m.m22);\r\n z = 0;\r\n }\r\n }\r\n else if (order === 'yxz') {\r\n x = Math.asin(-clamp(m.m23, -1, 1));\r\n if (Math.abs(m.m23) < 0.9999999) {\r\n y = Math.atan2(m.m13, m.m33);\r\n z = Math.atan2(m.m21, m.m22);\r\n }\r\n else {\r\n y = Math.atan2(-m.m31, m.m11);\r\n z = 0;\r\n }\r\n }\r\n else if (order === 'zxy') {\r\n x = Math.asin(clamp(m.m32, -1, 1));\r\n if (Math.abs(m.m32) < 0.9999999) {\r\n y = Math.atan2(-m.m31, m.m33);\r\n z = Math.atan2(-m.m12, m.m22);\r\n }\r\n else {\r\n y = 0;\r\n z = Math.atan2(m.m21, m.m11);\r\n }\r\n }\r\n else if (order === 'zyx') {\r\n y = Math.asin(-clamp(m.m31, -1, 1));\r\n if (Math.abs(m.m31) < 0.9999999) {\r\n x = Math.atan2(m.m32, m.m33);\r\n z = Math.atan2(m.m21, m.m11);\r\n }\r\n else {\r\n x = 0;\r\n z = Math.atan2(-m.m12, m.m22);\r\n }\r\n }\r\n else if (order === 'yzx') {\r\n z = Math.asin(clamp(m.m21, -1, 1));\r\n if (Math.abs(m.m21) < 0.9999999) {\r\n x = Math.atan2(-m.m23, m.m22);\r\n y = Math.atan2(-m.m31, m.m11);\r\n }\r\n else {\r\n x = 0;\r\n y = Math.atan2(m.m13, m.m33);\r\n }\r\n }\r\n else if (order === 'xzy') {\r\n z = Math.asin(-clamp(m.m12, -1, 1));\r\n if (Math.abs(m.m12) < 0.9999999) {\r\n x = Math.atan2(m.m32, m.m22);\r\n y = Math.atan2(m.m13, m.m11);\r\n }\r\n else {\r\n x = Math.atan2(-m.m23, m.m33);\r\n y = 0;\r\n }\r\n }\r\n return { x: x, y: y, z: z, order: order };\r\n}\r\n/**\r\n * Returns a euler angle that was decoded from a JSON string. Supports either\r\n * extracting values from an array `[x, y, z, order]` or object `{x, y, z,\r\n * order}`.\r\n *\r\n * @param json A JSON object.\r\n * @returns A euler angle.\r\n */\r\nfunction fromJson$1(json) {\r\n var obj = JSON.parse(json);\r\n if (Array.isArray(obj)) {\r\n var x = obj[0], y = obj[1], z = obj[2], _a = obj[3], order = _a === void 0 ? 'xyz' : _a;\r\n return { x: x, y: y, z: z, order: order };\r\n }\r\n else {\r\n var x = obj.x, y = obj.y, z = obj.z, _b = obj.order, order = _b === void 0 ? 'xyz' : _b;\r\n return { x: x, y: y, z: z, order: order };\r\n }\r\n}\r\n/**\r\n * Type guard that checks if the given type is a Euler.\r\n */\r\nfunction isType$1(obj) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n var o = obj;\r\n return (o != null &&\r\n o.hasOwnProperty('x') &&\r\n o.hasOwnProperty('y') &&\r\n o.hasOwnProperty('z') &&\r\n o.hasOwnProperty('order'));\r\n}\n\nvar euler = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$6,\n fromDegrees: fromDegrees,\n fromRotationMatrix: fromRotationMatrix,\n fromJson: fromJson$1,\n isType: isType$1\n});\n\n/**\r\n * Creates a new `Line3`. If unspecified, the start and end values of the line\r\n * will be at origin.\r\n *\r\n * @param values The values to assign to the line.\r\n */\r\nfunction create$5(values) {\r\n var _a, _b;\r\n if (values === void 0) { values = {}; }\r\n return {\r\n start: (_a = values.start) !== null && _a !== void 0 ? _a : origin(),\r\n end: (_b = values.end) !== null && _b !== void 0 ? _b : origin(),\r\n };\r\n}\r\n/**\r\n * Returns the point that is halfway between start and end.\r\n */\r\nfunction center(line) {\r\n return lerp(line.start, line.end, 0.5);\r\n}\r\n/**\r\n * Returns a line where the start and end points are transformed with the given\r\n * matrix.\r\n *\r\n * @param line The line to transform.\r\n * @param matrix The matrix to apply.\r\n * @returns A transformed line.\r\n */\r\nfunction transformMatrix(line, matrix) {\r\n var start = transformMatrix$1(line.start, matrix);\r\n var end = transformMatrix$1(line.end, matrix);\r\n return { start: start, end: end };\r\n}\r\n/**\r\n * Euclidean distance between the start and end points of the line.\r\n */\r\nfunction distance(line) {\r\n return distance$1(line.start, line.end);\r\n}\r\n/**\r\n * Returns the squared distance between a line's start and end point. If you're\r\n * just comparing distances, this is slightly more efficient than `distanceTo`.\r\n */\r\nfunction distanceSquared(line) {\r\n return distanceSquared$1(line.start, line.end);\r\n}\r\n/**\r\n * Returns a vector describing the direction of the line from start to end.\r\n */\r\nfunction direction(line) {\r\n return subtract(line.end, line.start);\r\n}\n\nvar line3 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$5,\n center: center,\n transformMatrix: transformMatrix,\n distance: distance,\n distanceSquared: distanceSquared,\n direction: direction\n});\n\n/**\r\n * Creates a new matrix. If arguments are undefined, returns an identity matrix.\r\n */\r\nvar create$4 = function (a, b, c, d, tx, ty) {\r\n if (a === void 0) { a = 1; }\r\n if (b === void 0) { b = 0; }\r\n if (c === void 0) { c = 0; }\r\n if (d === void 0) { d = 1; }\r\n if (tx === void 0) { tx = 0; }\r\n if (ty === void 0) { ty = 0; }\r\n return { a: a, b: b, c: c, d: d, tx: tx, ty: ty };\r\n};\r\n/**\r\n * Returns an identity matrix.\r\n */\r\nvar identity = function () {\r\n return create$4();\r\n};\r\n/**\r\n * Creates a matrix that is translated by the given `tx` and `ty` values.\r\n */\r\nvar translation = function (tx, ty) {\r\n return translate(tx, ty, identity());\r\n};\r\n/**\r\n * Creates a matrix that is rotated by the given degrees.\r\n */\r\nvar rotation = function (degrees) {\r\n return rotate(degrees, identity());\r\n};\r\n/**\r\n * Rotates the given matrix by the given degrees.\r\n */\r\nvar rotate = function (degrees, matrix) {\r\n var radians = toRadians(degrees);\r\n var cos = Math.cos(radians);\r\n var sin = Math.sin(radians);\r\n var a = matrix.a * cos + matrix.c * sin;\r\n var b = matrix.b * cos + matrix.d * sin;\r\n var c = matrix.a * -sin + matrix.c * cos;\r\n var d = matrix.b * -sin + matrix.d * cos;\r\n return create$4(a, b, c, d, matrix.tx, matrix.ty);\r\n};\r\n/**\r\n * Translates the given matrix along the horizontal and vertical axis by the\r\n * given `dx` and `dy` delta values.\r\n */\r\nvar translate = function (dx, dy, matrix) {\r\n var newTx = matrix.a * dx + matrix.c * dy + matrix.tx;\r\n var newTy = matrix.b * dx + matrix.d * dy + matrix.ty;\r\n return create$4(matrix.a, matrix.b, matrix.c, matrix.d, newTx, newTy);\r\n};\r\n/**\r\n * Returns the result of applying a geometric transformation of a matrix on the\r\n * given point.\r\n */\r\nvar transformPoint = function (matrix, pt) {\r\n var x = matrix.a * pt.x + matrix.c * pt.y + matrix.tx;\r\n var y = matrix.b * pt.x + matrix.d * pt.y + matrix.ty;\r\n return create$c(x, y);\r\n};\n\nvar matrix = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$4,\n identity: identity,\n translation: translation,\n rotation: rotation,\n rotate: rotate,\n translate: translate,\n transformPoint: transformPoint\n});\n\nfunction create$3() {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n if (args.length === 2) {\r\n return {\r\n a: args[0].x,\r\n b: args[0].y,\r\n c: args[1].x,\r\n d: args[1].y,\r\n };\r\n }\r\n else if (args.length === 4) {\r\n return {\r\n a: args[0],\r\n b: args[1],\r\n c: args[2],\r\n d: args[3],\r\n };\r\n }\r\n return {\r\n a: 0,\r\n b: 0,\r\n c: 0,\r\n d: 0,\r\n };\r\n}\r\n/**\r\n * Returns the determinant of the provided matrix.\r\n */\r\nfunction determinant(matrix) {\r\n return matrix.a * matrix.d - matrix.b * matrix.c;\r\n}\r\n/**\r\n * Returns the dot product of the two vectors represented in this matrix.\r\n */\r\nfunction dot(matrix) {\r\n return matrix.a * matrix.c + matrix.b * matrix.d;\r\n}\n\nvar matrix2 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$3,\n determinant: determinant,\n dot: dot\n});\n\n/**\r\n * Creates a new plane. Defaults to a normal of `[0,0,0]` and constant of `0`.\r\n *\r\n * @param values Values to assign to the plane.\r\n * @returns A new plane.\r\n */\r\nfunction create$2(values) {\r\n if (values === void 0) { values = {}; }\r\n return __assign({ normal: origin(), constant: 0 }, values);\r\n}\r\n/**\r\n * Creates a plane from a normal and an arbitrary point on a plane.\r\n *\r\n * @param normal A normal.\r\n * @param point A point on the plane.\r\n * @returns A new plane.\r\n */\r\nfunction fromNormalAndCoplanarPoint(normal, point) {\r\n var constant = -dot$1(point, normal);\r\n return create$2({ normal: normal, constant: constant });\r\n}\r\n/**\r\n * Returns the perpendicular distance from the plane to the given point.\r\n *\r\n * @param plane The plane.\r\n * @param point The point to calculate distance from `plane`.\r\n * @returns A distance.\r\n */\r\nfunction distanceToPoint(plane, point) {\r\n return dot$1(plane.normal, point) + plane.constant;\r\n}\r\n/**\r\n * Returns the point where the line intersects with this plane. If the line does\r\n * not intersect, then `undefined` is returned. If the line is on the plane,\r\n * then the starting point of the line is returned.\r\n *\r\n * @param plane The plane to intersect.\r\n * @param line The line to intersect.\r\n * @returns An intersecting point on the plane and line.\r\n */\r\nfunction intersectLine(plane, line) {\r\n var direction$1 = direction(line);\r\n var denominator = dot$1(plane.normal, direction$1);\r\n if (denominator === 0) {\r\n if (distanceToPoint(plane, line.start) === 0) {\r\n return line.start;\r\n }\r\n else {\r\n return undefined;\r\n }\r\n }\r\n var t = -(dot$1(line.start, plane.normal) + plane.constant) / denominator;\r\n if (t < 0 || t > 1) {\r\n return undefined;\r\n }\r\n else {\r\n return add(scale$2(t, direction$1), line.start);\r\n }\r\n}\r\n/**\r\n * Project's the given `point` onto the given `plane`.\r\n *\r\n * @param plane The plane to project onto.\r\n * @param point The point to project.\r\n * @returns The projected point.\r\n */\r\nfunction projectPoint(plane, point) {\r\n var d = distanceToPoint(plane, point);\r\n return add(point, scale$2(-d, plane.normal));\r\n}\n\nvar plane = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$2,\n fromNormalAndCoplanarPoint: fromNormalAndCoplanarPoint,\n distanceToPoint: distanceToPoint,\n intersectLine: intersectLine,\n projectPoint: projectPoint\n});\n\n/**\r\n * Returns a new quaternion. If `value` is undefined, then `{x: 0, y: 0, z: 0,\r\n * w: 1}` is returned.\r\n */\r\nfunction create$1(value) {\r\n if (value === void 0) { value = {}; }\r\n return __assign({ x: 0, y: 0, z: 0, w: 1 }, value);\r\n}\r\n/**\r\n * Parses a JSON string representation of a `Quaternion`.\r\n *\r\n * @param json A JSON string either in the form of `[x, y, z, w]` or `{\"x\": 0, \"y\": 0, \"z\": 0, \"w\": 0}`.\r\n * @returns A parsed `Quaternion`.\r\n */\r\nfunction fromJson(json) {\r\n var obj = JSON.parse(json);\r\n if (Array.isArray(obj)) {\r\n var x = obj[0], y = obj[1], z = obj[2], w = obj[3];\r\n return create$1({ x: x, y: y, z: z, w: w });\r\n }\r\n else {\r\n return create$1(obj);\r\n }\r\n}\r\n/**\r\n * Creates a `Quaternion` that is rotated the given radians around an axis.\r\n *\r\n * @param axis The axis to rotate around.\r\n * @param radians The rotation, in radians.\r\n * @returns A rotated quaternion.\r\n */\r\nfunction fromAxisAngle(axis, radians) {\r\n var halfAngle = radians / 2;\r\n var s = Math.sin(halfAngle);\r\n var x = axis.x * s;\r\n var y = axis.y * s;\r\n var z = axis.z * s;\r\n var w = Math.cos(halfAngle);\r\n return { x: x, y: y, z: z, w: w };\r\n}\r\n/**\r\n * Returns a quaternion using the upper 3x3 of a pure rotation matrix\r\n * (unscaled).\r\n */\r\nfunction fromMatrixRotation(matrix) {\r\n var m = toObject(matrix);\r\n var scale = fromMatrixScale(matrix);\r\n var is1 = 1 / scale.x;\r\n var is2 = 1 / scale.y;\r\n var is3 = 1 / scale.z;\r\n var sm11 = m.m11 * is1;\r\n var sm12 = m.m21 * is2;\r\n var sm13 = m.m31 * is3;\r\n var sm21 = m.m12 * is1;\r\n var sm22 = m.m22 * is2;\r\n var sm23 = m.m32 * is3;\r\n var sm31 = m.m13 * is1;\r\n var sm32 = m.m23 * is2;\r\n var sm33 = m.m33 * is3;\r\n var trace = sm11 + sm22 + sm33;\r\n if (trace > 0) {\r\n var s = Math.sqrt(trace + 1.0) * 2;\r\n return {\r\n x: (sm23 - sm32) / s,\r\n y: (sm31 - sm13) / s,\r\n z: (sm12 - sm21) / s,\r\n w: 0.25 * s,\r\n };\r\n }\r\n else if (sm11 > sm22 && sm11 > sm33) {\r\n var s = Math.sqrt(1.0 + sm11 - sm22 - sm33) * 2;\r\n return {\r\n x: 0.25 * s,\r\n y: (sm12 + sm21) / s,\r\n z: (sm31 + sm13) / s,\r\n w: (sm23 - sm32) / s,\r\n };\r\n }\r\n else if (sm22 > sm33) {\r\n var s = Math.sqrt(1.0 + sm22 - sm11 - sm33) * 2;\r\n return {\r\n x: (sm12 + sm21) / s,\r\n y: 0.25 * s,\r\n z: (sm23 + sm32) / s,\r\n w: (sm31 - sm13) / s,\r\n };\r\n }\r\n else {\r\n var s = Math.sqrt(1.0 + sm33 - sm11 - sm22) * 2;\r\n return {\r\n x: (sm31 + sm13) / s,\r\n y: (sm23 + sm32) / s,\r\n z: 0.25 * s,\r\n w: (sm12 - sm21) / s,\r\n };\r\n }\r\n}\r\nfunction fromEuler(euler) {\r\n var ex = euler.x, ey = euler.y, ez = euler.z, order = euler.order;\r\n var c1 = Math.cos(ex / 2);\r\n var c2 = Math.cos(ey / 2);\r\n var c3 = Math.cos(ez / 2);\r\n var s1 = Math.sin(ex / 2);\r\n var s2 = Math.sin(ey / 2);\r\n var s3 = Math.sin(ez / 2);\r\n var x = 0, y = 0, z = 0, w = 0;\r\n switch (order) {\r\n case 'xyz':\r\n x = s1 * c2 * c3 + c1 * s2 * s3;\r\n y = c1 * s2 * c3 - s1 * c2 * s3;\r\n z = c1 * c2 * s3 + s1 * s2 * c3;\r\n w = c1 * c2 * c3 - s1 * s2 * s3;\r\n break;\r\n case 'yxz':\r\n x = s1 * c2 * c3 + c1 * s2 * s3;\r\n y = c1 * s2 * c3 - s1 * c2 * s3;\r\n z = c1 * c2 * s3 - s1 * s2 * c3;\r\n w = c1 * c2 * c3 + s1 * s2 * s3;\r\n break;\r\n case 'zxy':\r\n x = s1 * c2 * c3 - c1 * s2 * s3;\r\n y = c1 * s2 * c3 + s1 * c2 * s3;\r\n z = c1 * c2 * s3 + s1 * s2 * c3;\r\n w = c1 * c2 * c3 - s1 * s2 * s3;\r\n break;\r\n case 'zyx':\r\n x = s1 * c2 * c3 - c1 * s2 * s3;\r\n y = c1 * s2 * c3 + s1 * c2 * s3;\r\n z = c1 * c2 * s3 - s1 * s2 * c3;\r\n w = c1 * c2 * c3 + s1 * s2 * s3;\r\n break;\r\n case 'yzx':\r\n x = s1 * c2 * c3 + c1 * s2 * s3;\r\n y = c1 * s2 * c3 + s1 * c2 * s3;\r\n z = c1 * c2 * s3 - s1 * s2 * c3;\r\n w = c1 * c2 * c3 - s1 * s2 * s3;\r\n break;\r\n case 'xzy':\r\n x = s1 * c2 * c3 - c1 * s2 * s3;\r\n y = c1 * s2 * c3 - s1 * c2 * s3;\r\n z = c1 * c2 * s3 + s1 * s2 * c3;\r\n w = c1 * c2 * c3 + s1 * s2 * s3;\r\n break;\r\n }\r\n return { x: x, y: y, z: z, w: w };\r\n}\r\n/**\r\n * Multiplies `a` x `b` and returns a new quaternion with the result.\r\n */\r\nfunction multiply(a, b) {\r\n // http://www.euclideanspace.com/maths/algebra/realNormedAlgebra/quaternions/code/index.htm\r\n return {\r\n x: a.x * b.w + a.w * b.x + a.y * b.z - a.z * b.y,\r\n y: a.y * b.w + a.w * b.y + a.z * b.x - a.x * b.z,\r\n z: a.z * b.w + a.w * b.z + a.x * b.y - a.y * b.x,\r\n w: a.w * b.w - a.x * b.x - a.y * b.y - a.z * b.z,\r\n };\r\n}\r\n/**\r\n * Type guard that checks if the given type is a Quaternion.\r\n */\r\nfunction isType(obj) {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n var o = obj;\r\n return (o != null &&\r\n o.hasOwnProperty('x') &&\r\n o.hasOwnProperty('y') &&\r\n o.hasOwnProperty('z') &&\r\n o.hasOwnProperty('w'));\r\n}\n\nvar quaternion = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create$1,\n fromJson: fromJson,\n fromAxisAngle: fromAxisAngle,\n fromMatrixRotation: fromMatrixRotation,\n fromEuler: fromEuler,\n multiply: multiply,\n isType: isType\n});\n\n/**\r\n * Creates a new ray with the given values, or using default values if none are\r\n * provided. The direction defaults to `{x: 0, y: 0, z: -1}` if undefined.\r\n *\r\n * @param value The values of the ray.\r\n * @returns A new ray.\r\n */\r\nfunction create(value) {\r\n var _a, _b;\r\n if (value === void 0) { value = {}; }\r\n return {\r\n origin: (_a = value.origin) !== null && _a !== void 0 ? _a : origin(),\r\n direction: (_b = value.direction) !== null && _b !== void 0 ? _b : forward(),\r\n };\r\n}\r\n/**\r\n * Returns a point at the given distance along this ray.\r\n *\r\n * @param ray The ray to get the point on.\r\n * @param distance A distance from origin along the ray's direction.\r\n * @returns A point on the ray.\r\n */\r\nfunction at(ray, distance) {\r\n return add(scale$2(distance, ray.direction), ray.origin);\r\n}\r\n/**\r\n * Computes the distance of the `ray`s origin to the given `plane`. Returns a\r\n * distance of 0 if the ray is coplanar and returns `undefined` if the ray does\r\n * not intersect with the plane.\r\n *\r\n * @param ray The ray to get the distance for.\r\n * @param plane The plane to compute the distance to.\r\n * @returns The distance to the plane, or `undefined` if it cannot be computed.\r\n */\r\nfunction distanceToPlane(ray, plane$1) {\r\n var d = dot$1(plane$1.normal, ray.direction);\r\n if (d === 0) {\r\n // Ray is on plane.\r\n return distanceToPoint(plane$1, ray.origin) === 0 ? 0 : undefined;\r\n }\r\n else {\r\n var t = -(dot$1(ray.origin, plane$1.normal) + plane$1.constant) / d;\r\n // Checks if ray intersects plane.\r\n return t >= 0 ? t : undefined;\r\n }\r\n}\r\n/**\r\n * Computes the intersection point of the given `ray` to the given `plane`. If\r\n * the ray does not intersect with the plane, then `undefined` is returned.\r\n *\r\n * @param ray The ray to intersect.\r\n * @param plane The plane to intersect with.\r\n * @returns The intersection point, or `undefined` if the ray does not\r\n * intersect.\r\n */\r\nfunction intersectPlane(ray, plane) {\r\n var t = distanceToPlane(ray, plane);\r\n return t != null ? at(ray, t) : undefined;\r\n}\n\nvar ray = /*#__PURE__*/Object.freeze({\n __proto__: null,\n create: create,\n at: at,\n distanceToPlane: distanceToPlane,\n intersectPlane: intersectPlane\n});\n\nexport { angle as Angle, boundingBox as BoundingBox, boundingSphere as BoundingSphere, dimensions as Dimensions, euler as Euler, line3 as Line3, matrix as Matrix, matrix2 as Matrix2, matrix4 as Matrix4, plane as Plane, point as Point, quaternion as Quaternion, ray as Ray, rectangle as Rectangle, vector3 as Vector3, clamp, lerp$2 as lerp };\n//# sourceMappingURL=bundle.esm.js.map\n"],"version":3}
|