angular-three-soba 1.0.2 → 1.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/controls/lib/orbit-controls/orbit-controls.mjs +3 -3
- package/esm2020/loaders/index.mjs +4 -1
- package/esm2020/loaders/lib/loader/loader.mjs +133 -0
- package/esm2020/loaders/lib/progress/progress.mjs +39 -0
- package/esm2020/loaders/lib/texture-loader/texture-loader.mjs +19 -0
- package/esm2020/misc/angular-three-soba-misc.mjs +5 -0
- package/esm2020/misc/index.mjs +2 -0
- package/esm2020/misc/lib/bake-shadows/bake-shadows.mjs +25 -0
- package/esm2020/performance/angular-three-soba-performance.mjs +5 -0
- package/esm2020/performance/index.mjs +5 -0
- package/esm2020/performance/lib/adaptive/adaptive-dpr.mjs +46 -0
- package/esm2020/performance/lib/adaptive/adaptive-events.mjs +36 -0
- package/esm2020/performance/lib/detailed/detailed.mjs +50 -0
- package/esm2020/performance/lib/stats/stats.mjs +63 -0
- package/esm2020/shaders/angular-three-soba-shaders.mjs +5 -0
- package/esm2020/shaders/index.mjs +2 -0
- package/esm2020/shaders/lib/shader-material/shader-material.mjs +34 -0
- package/esm2020/staging/angular-three-soba-staging.mjs +5 -0
- package/esm2020/staging/index.mjs +13 -0
- package/esm2020/staging/lib/accumulative-shadows/accumulative-shadows.mjs +276 -0
- package/esm2020/staging/lib/accumulative-shadows/progressive-light-map.mjs +109 -0
- package/esm2020/staging/lib/accumulative-shadows/randomized-lights.mjs +196 -0
- package/esm2020/staging/lib/bounds/bounds.mjs +283 -0
- package/esm2020/staging/lib/center/center.mjs +142 -0
- package/esm2020/staging/lib/contact-shadows/contact-shadows.mjs +227 -0
- package/esm2020/staging/lib/environment/assets.mjs +13 -0
- package/esm2020/staging/lib/environment/environment-cube.mjs +40 -0
- package/esm2020/staging/lib/environment/environment-ground.mjs +66 -0
- package/esm2020/staging/lib/environment/environment-inputs.mjs +86 -0
- package/esm2020/staging/lib/environment/environment-map.mjs +38 -0
- package/esm2020/staging/lib/environment/environment-portal.mjs +110 -0
- package/esm2020/staging/lib/environment/environment.mjs +163 -0
- package/esm2020/staging/lib/environment/utils.mjs +70 -0
- package/esm2020/staging/lib/float/float.mjs +76 -0
- package/esm2020/staging/lib/sky/sky.mjs +111 -0
- package/esm2020/staging/lib/sparkles/sparkles.mjs +209 -0
- package/esm2020/staging/lib/stage/stage.mjs +369 -0
- package/esm2020/staging/lib/stars/stars.mjs +171 -0
- package/fesm2015/angular-three-soba-controls.mjs +3 -3
- package/fesm2015/angular-three-soba-loaders.mjs +187 -3
- package/fesm2015/angular-three-soba-loaders.mjs.map +1 -1
- package/fesm2015/angular-three-soba-misc.mjs +32 -0
- package/fesm2015/angular-three-soba-misc.mjs.map +1 -0
- package/fesm2015/angular-three-soba-performance.mjs +191 -0
- package/fesm2015/angular-three-soba-performance.mjs.map +1 -0
- package/fesm2015/angular-three-soba-shaders.mjs +38 -0
- package/fesm2015/angular-three-soba-shaders.mjs.map +1 -0
- package/fesm2015/angular-three-soba-staging.mjs +2647 -0
- package/fesm2015/angular-three-soba-staging.mjs.map +1 -0
- package/fesm2020/angular-three-soba-controls.mjs +3 -3
- package/fesm2020/angular-three-soba-loaders.mjs +186 -3
- package/fesm2020/angular-three-soba-loaders.mjs.map +1 -1
- package/fesm2020/angular-three-soba-misc.mjs +32 -0
- package/fesm2020/angular-three-soba-misc.mjs.map +1 -0
- package/fesm2020/angular-three-soba-performance.mjs +191 -0
- package/fesm2020/angular-three-soba-performance.mjs.map +1 -0
- package/fesm2020/angular-three-soba-shaders.mjs +41 -0
- package/fesm2020/angular-three-soba-shaders.mjs.map +1 -0
- package/fesm2020/angular-three-soba-staging.mjs +2654 -0
- package/fesm2020/angular-three-soba-staging.mjs.map +1 -0
- package/loaders/index.d.ts +3 -0
- package/loaders/lib/loader/loader.d.ts +26 -0
- package/loaders/lib/progress/progress.d.ts +16 -0
- package/loaders/lib/texture-loader/texture-loader.d.ts +5 -0
- package/misc/README.md +3 -0
- package/misc/index.d.ts +1 -0
- package/misc/lib/bake-shadows/bake-shadows.d.ts +9 -0
- package/package.json +37 -2
- package/performance/README.md +3 -0
- package/performance/index.d.ts +4 -0
- package/performance/lib/adaptive/adaptive-dpr.d.ts +11 -0
- package/performance/lib/adaptive/adaptive-events.d.ts +10 -0
- package/performance/lib/detailed/detailed.d.ts +12 -0
- package/performance/lib/stats/stats.d.ts +14 -0
- package/plugin/package.json +1 -1
- package/plugin/src/generators/init/init.js +13 -17
- package/plugin/src/generators/init/init.js.map +1 -1
- package/shaders/README.md +3 -0
- package/shaders/index.d.ts +1 -0
- package/shaders/lib/shader-material/shader-material.d.ts +6 -0
- package/staging/README.md +3 -0
- package/staging/index.d.ts +12 -0
- package/staging/lib/accumulative-shadows/accumulative-shadows.d.ts +64 -0
- package/staging/lib/accumulative-shadows/progressive-light-map.d.ts +34 -0
- package/staging/lib/accumulative-shadows/randomized-lights.d.ts +42 -0
- package/staging/lib/bounds/bounds.d.ts +48 -0
- package/staging/lib/center/center.d.ts +40 -0
- package/staging/lib/contact-shadows/contact-shadows.d.ts +29 -0
- package/staging/lib/environment/assets.d.ts +13 -0
- package/staging/lib/environment/environment-cube.d.ts +11 -0
- package/staging/lib/environment/environment-ground.d.ts +9 -0
- package/staging/lib/environment/environment-inputs.d.ts +28 -0
- package/staging/lib/environment/environment-map.d.ts +10 -0
- package/staging/lib/environment/environment-portal.d.ts +15 -0
- package/staging/lib/environment/environment.d.ts +12 -0
- package/staging/lib/environment/utils.d.ts +8 -0
- package/staging/lib/float/float.d.ts +16 -0
- package/staging/lib/sky/sky.d.ts +21 -0
- package/staging/lib/sparkles/sparkles.d.ts +29 -0
- package/staging/lib/stage/stage.d.ts +87 -0
- package/staging/lib/stars/stars.d.ts +20 -0
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { extend, injectNgtRef, NgtRxStore } from 'angular-three';
|
|
3
|
+
import { combineLatest } from 'rxjs';
|
|
4
|
+
import { Box3, Group, Sphere, Vector3 } from 'three';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
extend({ Group });
|
|
7
|
+
export class NgtsCenter extends NgtRxStore {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.centerRef = injectNgtRef();
|
|
11
|
+
this.outerRef = injectNgtRef();
|
|
12
|
+
this.innerRef = injectNgtRef();
|
|
13
|
+
this.centered = new EventEmitter();
|
|
14
|
+
}
|
|
15
|
+
set top(top) {
|
|
16
|
+
this.set({ top });
|
|
17
|
+
}
|
|
18
|
+
set right(right) {
|
|
19
|
+
this.set({ right });
|
|
20
|
+
}
|
|
21
|
+
set bottom(bottom) {
|
|
22
|
+
this.set({ bottom });
|
|
23
|
+
}
|
|
24
|
+
set left(left) {
|
|
25
|
+
this.set({ left });
|
|
26
|
+
}
|
|
27
|
+
set front(front) {
|
|
28
|
+
this.set({ front });
|
|
29
|
+
}
|
|
30
|
+
set back(back) {
|
|
31
|
+
this.set({ back });
|
|
32
|
+
}
|
|
33
|
+
set disableX(disableX) {
|
|
34
|
+
this.set({ disableX });
|
|
35
|
+
}
|
|
36
|
+
set disableY(disableY) {
|
|
37
|
+
this.set({ disableY });
|
|
38
|
+
}
|
|
39
|
+
set disableZ(disableZ) {
|
|
40
|
+
this.set({ disableZ });
|
|
41
|
+
}
|
|
42
|
+
set disabled(disabled) {
|
|
43
|
+
this.set({ disabled });
|
|
44
|
+
}
|
|
45
|
+
set precise(precise) {
|
|
46
|
+
this.set({ precise });
|
|
47
|
+
}
|
|
48
|
+
initialize() {
|
|
49
|
+
super.initialize();
|
|
50
|
+
this.set({ precise: true });
|
|
51
|
+
}
|
|
52
|
+
ngOnInit() {
|
|
53
|
+
this.setPosition();
|
|
54
|
+
}
|
|
55
|
+
setPosition() {
|
|
56
|
+
this.hold(combineLatest([this.innerRef.$, this.innerRef.children$()]), ([innerGroup]) => {
|
|
57
|
+
const { precise, top, left, front, disabled, disableX, disableY, disableZ, back, bottom, right } = this.get();
|
|
58
|
+
this.outerRef.nativeElement.matrixWorld.identity();
|
|
59
|
+
const box3 = new Box3().setFromObject(innerGroup, precise);
|
|
60
|
+
const center = new Vector3();
|
|
61
|
+
const sphere = new Sphere();
|
|
62
|
+
const width = box3.max.x - box3.min.x;
|
|
63
|
+
const height = box3.max.y - box3.min.y;
|
|
64
|
+
const depth = box3.max.z - box3.min.z;
|
|
65
|
+
box3.getCenter(center);
|
|
66
|
+
box3.getBoundingSphere(sphere);
|
|
67
|
+
const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;
|
|
68
|
+
const hAlign = left ? -width / 2 : right ? width / 2 : 0;
|
|
69
|
+
const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;
|
|
70
|
+
this.outerRef.nativeElement.position.set(disabled || disableX ? 0 : -center.x + hAlign, disabled || disableY ? 0 : -center.y + vAlign, disabled || disableZ ? 0 : -center.z + dAlign);
|
|
71
|
+
if (this.centered.observed) {
|
|
72
|
+
this.centered.emit({
|
|
73
|
+
parent: this.centerRef.nativeElement.parent,
|
|
74
|
+
container: this.centerRef.nativeElement,
|
|
75
|
+
width,
|
|
76
|
+
height,
|
|
77
|
+
depth,
|
|
78
|
+
boundingBox: box3,
|
|
79
|
+
boundingSphere: sphere,
|
|
80
|
+
center: center,
|
|
81
|
+
verticalAlignment: vAlign,
|
|
82
|
+
horizontalAlignment: hAlign,
|
|
83
|
+
depthAlignment: dAlign,
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
NgtsCenter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCenter, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
90
|
+
NgtsCenter.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsCenter, isStandalone: true, selector: "ngts-center", inputs: { centerRef: "centerRef", top: "top", right: "right", bottom: "bottom", left: "left", front: "front", back: "back", disableX: "disableX", disableY: "disableY", disableZ: "disableZ", disabled: "disabled", precise: "precise" }, outputs: { centered: "centered" }, usesInheritance: true, ngImport: i0, template: `
|
|
91
|
+
<ngt-group ngtCompound [ref]="centerRef">
|
|
92
|
+
<ngt-group [ref]="outerRef">
|
|
93
|
+
<ngt-group [ref]="innerRef">
|
|
94
|
+
<ng-content />
|
|
95
|
+
</ngt-group>
|
|
96
|
+
</ngt-group>
|
|
97
|
+
</ngt-group>
|
|
98
|
+
`, isInline: true });
|
|
99
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsCenter, decorators: [{
|
|
100
|
+
type: Component,
|
|
101
|
+
args: [{
|
|
102
|
+
selector: 'ngts-center',
|
|
103
|
+
standalone: true,
|
|
104
|
+
template: `
|
|
105
|
+
<ngt-group ngtCompound [ref]="centerRef">
|
|
106
|
+
<ngt-group [ref]="outerRef">
|
|
107
|
+
<ngt-group [ref]="innerRef">
|
|
108
|
+
<ng-content />
|
|
109
|
+
</ngt-group>
|
|
110
|
+
</ngt-group>
|
|
111
|
+
</ngt-group>
|
|
112
|
+
`,
|
|
113
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
114
|
+
}]
|
|
115
|
+
}], propDecorators: { centerRef: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], top: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], right: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], bottom: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], left: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], front: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], back: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], disableX: [{
|
|
130
|
+
type: Input
|
|
131
|
+
}], disableY: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], disableZ: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], disabled: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], precise: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], centered: [{
|
|
140
|
+
type: Output
|
|
141
|
+
}] } });
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"center.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/center/center.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { extend, injectNgtRef, NgtRxStore } from 'angular-three';\nimport { combineLatest } from 'rxjs';\nimport { Box3, Group, Sphere, Vector3 } from 'three';\n\nextend({ Group });\n\n@Component({\n    selector: 'ngts-center',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound [ref]=\"centerRef\">\n            <ngt-group [ref]=\"outerRef\">\n                <ngt-group [ref]=\"innerRef\">\n                    <ng-content />\n                </ngt-group>\n            </ngt-group>\n        </ngt-group>\n    `,\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsCenter extends NgtRxStore implements OnInit {\n    @Input() centerRef = injectNgtRef<Group>();\n\n    readonly outerRef = injectNgtRef<Group>();\n    readonly innerRef = injectNgtRef<Group>();\n\n    @Input() set top(top: boolean) {\n        this.set({ top });\n    }\n\n    @Input() set right(right: boolean) {\n        this.set({ right });\n    }\n\n    @Input() set bottom(bottom: boolean) {\n        this.set({ bottom });\n    }\n\n    @Input() set left(left: boolean) {\n        this.set({ left });\n    }\n\n    @Input() set front(front: boolean) {\n        this.set({ front });\n    }\n\n    @Input() set back(back: boolean) {\n        this.set({ back });\n    }\n\n    @Input() set disableX(disableX: boolean) {\n        this.set({ disableX });\n    }\n\n    @Input() set disableY(disableY: boolean) {\n        this.set({ disableY });\n    }\n\n    @Input() set disableZ(disableZ: boolean) {\n        this.set({ disableZ });\n    }\n\n    @Input() set disabled(disabled: boolean) {\n        this.set({ disabled });\n    }\n\n    @Input() set precise(precise: boolean) {\n        this.set({ precise });\n    }\n\n    @Output() centered = new EventEmitter<{\n        /** The next parent above <Center> */\n        parent: THREE.Object3D;\n        /** The outmost container group of the <Center> component */\n        container: THREE.Object3D;\n        width: number;\n        height: number;\n        depth: number;\n        boundingBox: THREE.Box3;\n        boundingSphere: THREE.Sphere;\n        center: THREE.Vector3;\n        verticalAlignment: number;\n        horizontalAlignment: number;\n        depthAlignment: number;\n    }>();\n\n    override initialize(): void {\n        super.initialize();\n        this.set({ precise: true });\n    }\n\n    ngOnInit(): void {\n        this.setPosition();\n    }\n\n    private setPosition() {\n        this.hold(combineLatest([this.innerRef.$, this.innerRef.children$()]), ([innerGroup]) => {\n            const { precise, top, left, front, disabled, disableX, disableY, disableZ, back, bottom, right } =\n                this.get();\n            this.outerRef.nativeElement.matrixWorld.identity();\n            const box3 = new Box3().setFromObject(innerGroup, precise);\n            const center = new Vector3();\n            const sphere = new Sphere();\n            const width = box3.max.x - box3.min.x;\n            const height = box3.max.y - box3.min.y;\n            const depth = box3.max.z - box3.min.z;\n\n            box3.getCenter(center);\n            box3.getBoundingSphere(sphere);\n\n            const vAlign = top ? height / 2 : bottom ? -height / 2 : 0;\n            const hAlign = left ? -width / 2 : right ? width / 2 : 0;\n            const dAlign = front ? depth / 2 : back ? -depth / 2 : 0;\n\n            this.outerRef.nativeElement.position.set(\n                disabled || disableX ? 0 : -center.x + hAlign,\n                disabled || disableY ? 0 : -center.y + vAlign,\n                disabled || disableZ ? 0 : -center.z + dAlign\n            );\n\n            if (this.centered.observed) {\n                this.centered.emit({\n                    parent: this.centerRef.nativeElement.parent!,\n                    container: this.centerRef.nativeElement,\n                    width,\n                    height,\n                    depth,\n                    boundingBox: box3,\n                    boundingSphere: sphere,\n                    center: center,\n                    verticalAlignment: vAlign,\n                    horizontalAlignment: hAlign,\n                    depthAlignment: dAlign,\n                });\n            }\n        });\n    }\n}\n"]}
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input } from '@angular/core';
|
|
3
|
+
import { extend, injectBeforeRender, injectNgtRef, NgtArgs, NgtPush, NgtRxStore, NgtStore, } from 'angular-three';
|
|
4
|
+
import * as THREE from 'three';
|
|
5
|
+
import { Group, Mesh, MeshBasicMaterial, OrthographicCamera } from 'three';
|
|
6
|
+
import { HorizontalBlurShader, VerticalBlurShader } from 'three-stdlib';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
extend({ Group, Mesh, MeshBasicMaterial, OrthographicCamera });
|
|
9
|
+
export class NgtsContactShadows extends NgtRxStore {
|
|
10
|
+
set opacity(opacity) {
|
|
11
|
+
this.set({ opacity });
|
|
12
|
+
}
|
|
13
|
+
set width(width) {
|
|
14
|
+
this.set({ width });
|
|
15
|
+
}
|
|
16
|
+
set height(height) {
|
|
17
|
+
this.set({ height });
|
|
18
|
+
}
|
|
19
|
+
set blur(blur) {
|
|
20
|
+
this.set({ blur });
|
|
21
|
+
}
|
|
22
|
+
set far(far) {
|
|
23
|
+
this.set({ far });
|
|
24
|
+
}
|
|
25
|
+
set smooth(smooth) {
|
|
26
|
+
this.set({ smooth });
|
|
27
|
+
}
|
|
28
|
+
set resolution(resolution) {
|
|
29
|
+
this.set({ resolution });
|
|
30
|
+
}
|
|
31
|
+
set frames(frames) {
|
|
32
|
+
this.set({ frames });
|
|
33
|
+
}
|
|
34
|
+
set scale(scale) {
|
|
35
|
+
this.set({ scale });
|
|
36
|
+
}
|
|
37
|
+
set color(color) {
|
|
38
|
+
this.set({ color });
|
|
39
|
+
}
|
|
40
|
+
set depthWrite(depthWrite) {
|
|
41
|
+
this.set({ depthWrite });
|
|
42
|
+
}
|
|
43
|
+
set renderOrder(renderOrder) {
|
|
44
|
+
this.set({ renderOrder });
|
|
45
|
+
}
|
|
46
|
+
constructor() {
|
|
47
|
+
super();
|
|
48
|
+
this.store = inject(NgtStore);
|
|
49
|
+
this.shadowCameraRef = injectNgtRef();
|
|
50
|
+
this.encoding = this.store.get('gl', 'outputEncoding');
|
|
51
|
+
this.contactShadows$ = this.select('contactShadows');
|
|
52
|
+
this.Math = Math;
|
|
53
|
+
this.contactShadowsRef = injectNgtRef();
|
|
54
|
+
injectBeforeRender(this.onBeforeRender.bind(this, 0));
|
|
55
|
+
}
|
|
56
|
+
initialize() {
|
|
57
|
+
super.initialize();
|
|
58
|
+
this.set({
|
|
59
|
+
scale: 10,
|
|
60
|
+
frames: Infinity,
|
|
61
|
+
opacity: 1,
|
|
62
|
+
width: 1,
|
|
63
|
+
height: 1,
|
|
64
|
+
blur: 1,
|
|
65
|
+
far: 10,
|
|
66
|
+
resolution: 512,
|
|
67
|
+
smooth: true,
|
|
68
|
+
color: '#000000',
|
|
69
|
+
depthWrite: false,
|
|
70
|
+
renderOrder: 0,
|
|
71
|
+
});
|
|
72
|
+
this.connect('scaledWidth', this.select(['width', 'scale'], ({ width, scale }) => width * (Array.isArray(scale) ? scale[0] : scale || 1)));
|
|
73
|
+
this.connect('scaledHeight', this.select(['height', 'scale'], ({ height, scale }) => height * (Array.isArray(scale) ? scale[1] : scale || 1)));
|
|
74
|
+
this.connect('cameraArgs', this.select(['scaledWidth', 'scaledHeight', 'far'], ({ scaledWidth: width, scaledHeight: height, far }) => {
|
|
75
|
+
return [-width / 2, width / 2, height / 2, -height / 2, 0, far];
|
|
76
|
+
}));
|
|
77
|
+
this.connect('contactShadows', this.select(['resolution', 'scaledWidth', 'scaledHeight', 'scale', 'color'], ({ resolution, scaledWidth: width, scaledHeight: height, color }) => {
|
|
78
|
+
const renderTarget = new THREE.WebGLRenderTarget(resolution, resolution);
|
|
79
|
+
const renderTargetBlur = new THREE.WebGLRenderTarget(resolution, resolution);
|
|
80
|
+
renderTargetBlur.texture.generateMipmaps = renderTarget.texture.generateMipmaps = false;
|
|
81
|
+
const planeGeometry = new THREE.PlaneGeometry(width, height).rotateX(Math.PI / 2);
|
|
82
|
+
const blurPlane = new Mesh(planeGeometry);
|
|
83
|
+
const depthMaterial = new THREE.MeshDepthMaterial();
|
|
84
|
+
depthMaterial.depthTest = depthMaterial.depthWrite = false;
|
|
85
|
+
depthMaterial.onBeforeCompile = (shader) => {
|
|
86
|
+
shader.uniforms = {
|
|
87
|
+
...shader.uniforms,
|
|
88
|
+
ucolor: { value: new THREE.Color(color) },
|
|
89
|
+
};
|
|
90
|
+
shader.fragmentShader = shader.fragmentShader.replace(`void main() {`, //
|
|
91
|
+
`uniform vec3 ucolor;
|
|
92
|
+
void main() {
|
|
93
|
+
`);
|
|
94
|
+
shader.fragmentShader = shader.fragmentShader.replace('vec4( vec3( 1.0 - fragCoordZ ), opacity );',
|
|
95
|
+
// Colorize the shadow, multiply by the falloff so that the center can remain darker
|
|
96
|
+
'vec4( ucolor * fragCoordZ * 2.0, ( 1.0 - fragCoordZ ) * 1.0 );');
|
|
97
|
+
};
|
|
98
|
+
const horizontalBlurMaterial = new THREE.ShaderMaterial(HorizontalBlurShader);
|
|
99
|
+
const verticalBlurMaterial = new THREE.ShaderMaterial(VerticalBlurShader);
|
|
100
|
+
verticalBlurMaterial.depthTest = horizontalBlurMaterial.depthTest = false;
|
|
101
|
+
return {
|
|
102
|
+
renderTarget,
|
|
103
|
+
planeGeometry,
|
|
104
|
+
depthMaterial,
|
|
105
|
+
blurPlane,
|
|
106
|
+
horizontalBlurMaterial,
|
|
107
|
+
verticalBlurMaterial,
|
|
108
|
+
renderTargetBlur,
|
|
109
|
+
};
|
|
110
|
+
}));
|
|
111
|
+
}
|
|
112
|
+
onBeforeRender(count, { scene, gl }) {
|
|
113
|
+
const { frames, blur, contactShadows: { depthMaterial, renderTarget }, smooth, } = this.get();
|
|
114
|
+
if (this.shadowCameraRef.nativeElement && (frames === Infinity || count < frames)) {
|
|
115
|
+
const initialBackground = scene.background;
|
|
116
|
+
scene.background = null;
|
|
117
|
+
const initialOverrideMaterial = scene.overrideMaterial;
|
|
118
|
+
scene.overrideMaterial = depthMaterial;
|
|
119
|
+
gl.setRenderTarget(renderTarget);
|
|
120
|
+
gl.render(scene, this.shadowCameraRef.nativeElement);
|
|
121
|
+
scene.overrideMaterial = initialOverrideMaterial;
|
|
122
|
+
this.blurShadows(blur);
|
|
123
|
+
if (smooth)
|
|
124
|
+
this.blurShadows(blur * 0.4);
|
|
125
|
+
gl.setRenderTarget(null);
|
|
126
|
+
scene.background = initialBackground;
|
|
127
|
+
count++;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
blurShadows(blur) {
|
|
131
|
+
const { blurPlane, horizontalBlurMaterial, verticalBlurMaterial, renderTargetBlur, renderTarget } = this.get('contactShadows');
|
|
132
|
+
const gl = this.store.get('gl');
|
|
133
|
+
blurPlane.visible = true;
|
|
134
|
+
blurPlane.material = horizontalBlurMaterial;
|
|
135
|
+
horizontalBlurMaterial.uniforms.tDiffuse.value = renderTarget.texture;
|
|
136
|
+
horizontalBlurMaterial.uniforms.h.value = (blur * 1) / 256;
|
|
137
|
+
gl.setRenderTarget(renderTargetBlur);
|
|
138
|
+
gl.render(blurPlane, this.shadowCameraRef.nativeElement);
|
|
139
|
+
blurPlane.material = verticalBlurMaterial;
|
|
140
|
+
verticalBlurMaterial.uniforms.tDiffuse.value = renderTargetBlur.texture;
|
|
141
|
+
verticalBlurMaterial.uniforms.v.value = (blur * 1) / 256;
|
|
142
|
+
gl.setRenderTarget(renderTarget);
|
|
143
|
+
gl.render(blurPlane, this.shadowCameraRef.nativeElement);
|
|
144
|
+
blurPlane.visible = false;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
NgtsContactShadows.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsContactShadows, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
148
|
+
NgtsContactShadows.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsContactShadows, isStandalone: true, selector: "ngts-contact-shadows", inputs: { contactShadowsRef: "contactShadowsRef", opacity: "opacity", width: "width", height: "height", blur: "blur", far: "far", smooth: "smooth", resolution: "resolution", frames: "frames", scale: "scale", color: "color", depthWrite: "depthWrite", renderOrder: "renderOrder" }, usesInheritance: true, ngImport: i0, template: `
|
|
149
|
+
<ngt-group ngtCompound [ref]="contactShadowsRef" [rotation]="[Math.PI / 2, 0, 0]">
|
|
150
|
+
<ng-container *ngIf="contactShadows$ | ngtPush : null as contactShadows">
|
|
151
|
+
<ngt-mesh
|
|
152
|
+
[renderOrder]="get('renderOrder')"
|
|
153
|
+
[geometry]="contactShadows.planeGeometry"
|
|
154
|
+
[scale]="[1, -1, 1]"
|
|
155
|
+
[rotation]="[-Math.PI / 2, 0, 0]"
|
|
156
|
+
>
|
|
157
|
+
<ngt-mesh-basic-material
|
|
158
|
+
[map]="contactShadows.renderTarget.texture"
|
|
159
|
+
transparent
|
|
160
|
+
[opacity]="get('opacity')"
|
|
161
|
+
[depthWrite]="get('depthWrite')"
|
|
162
|
+
>
|
|
163
|
+
<ngt-value [rawValue]="encoding" attach="map.encoding" />
|
|
164
|
+
</ngt-mesh-basic-material>
|
|
165
|
+
</ngt-mesh>
|
|
166
|
+
<ngt-orthographic-camera *args="get('cameraArgs')" [ref]="shadowCameraRef" />
|
|
167
|
+
</ng-container>
|
|
168
|
+
</ngt-group>
|
|
169
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: NgtPush, name: "ngtPush" }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }] });
|
|
170
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsContactShadows, decorators: [{
|
|
171
|
+
type: Component,
|
|
172
|
+
args: [{
|
|
173
|
+
selector: 'ngts-contact-shadows',
|
|
174
|
+
standalone: true,
|
|
175
|
+
template: `
|
|
176
|
+
<ngt-group ngtCompound [ref]="contactShadowsRef" [rotation]="[Math.PI / 2, 0, 0]">
|
|
177
|
+
<ng-container *ngIf="contactShadows$ | ngtPush : null as contactShadows">
|
|
178
|
+
<ngt-mesh
|
|
179
|
+
[renderOrder]="get('renderOrder')"
|
|
180
|
+
[geometry]="contactShadows.planeGeometry"
|
|
181
|
+
[scale]="[1, -1, 1]"
|
|
182
|
+
[rotation]="[-Math.PI / 2, 0, 0]"
|
|
183
|
+
>
|
|
184
|
+
<ngt-mesh-basic-material
|
|
185
|
+
[map]="contactShadows.renderTarget.texture"
|
|
186
|
+
transparent
|
|
187
|
+
[opacity]="get('opacity')"
|
|
188
|
+
[depthWrite]="get('depthWrite')"
|
|
189
|
+
>
|
|
190
|
+
<ngt-value [rawValue]="encoding" attach="map.encoding" />
|
|
191
|
+
</ngt-mesh-basic-material>
|
|
192
|
+
</ngt-mesh>
|
|
193
|
+
<ngt-orthographic-camera *args="get('cameraArgs')" [ref]="shadowCameraRef" />
|
|
194
|
+
</ng-container>
|
|
195
|
+
</ngt-group>
|
|
196
|
+
`,
|
|
197
|
+
imports: [NgIf, NgtPush, NgtArgs],
|
|
198
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
199
|
+
}]
|
|
200
|
+
}], ctorParameters: function () { return []; }, propDecorators: { contactShadowsRef: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], opacity: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], width: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], height: [{
|
|
207
|
+
type: Input
|
|
208
|
+
}], blur: [{
|
|
209
|
+
type: Input
|
|
210
|
+
}], far: [{
|
|
211
|
+
type: Input
|
|
212
|
+
}], smooth: [{
|
|
213
|
+
type: Input
|
|
214
|
+
}], resolution: [{
|
|
215
|
+
type: Input
|
|
216
|
+
}], frames: [{
|
|
217
|
+
type: Input
|
|
218
|
+
}], scale: [{
|
|
219
|
+
type: Input
|
|
220
|
+
}], color: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], depthWrite: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], renderOrder: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}] } });
|
|
227
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contact-shadows.js","sourceRoot":"","sources":["../../../../../../../libs/angular-three-soba/staging/src/lib/contact-shadows/contact-shadows.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgIf } from '@angular/common';\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, inject, Input } from '@angular/core';\nimport {\n    extend,\n    injectBeforeRender,\n    injectNgtRef,\n    NgtArgs,\n    NgtPush,\n    NgtRenderState,\n    NgtRxStore,\n    NgtStore,\n} from 'angular-three';\nimport * as THREE from 'three';\nimport { Group, Mesh, MeshBasicMaterial, OrthographicCamera } from 'three';\nimport { HorizontalBlurShader, VerticalBlurShader } from 'three-stdlib';\n\nextend({ Group, Mesh, MeshBasicMaterial, OrthographicCamera });\n\n@Component({\n    selector: 'ngts-contact-shadows',\n    standalone: true,\n    template: `\n        <ngt-group ngtCompound [ref]=\"contactShadowsRef\" [rotation]=\"[Math.PI / 2, 0, 0]\">\n            <ng-container *ngIf=\"contactShadows$ | ngtPush : null as contactShadows\">\n                <ngt-mesh\n                    [renderOrder]=\"get('renderOrder')\"\n                    [geometry]=\"contactShadows.planeGeometry\"\n                    [scale]=\"[1, -1, 1]\"\n                    [rotation]=\"[-Math.PI / 2, 0, 0]\"\n                >\n                    <ngt-mesh-basic-material\n                        [map]=\"contactShadows.renderTarget.texture\"\n                        transparent\n                        [opacity]=\"get('opacity')\"\n                        [depthWrite]=\"get('depthWrite')\"\n                    >\n                        <ngt-value [rawValue]=\"encoding\" attach=\"map.encoding\" />\n                    </ngt-mesh-basic-material>\n                </ngt-mesh>\n                <ngt-orthographic-camera *args=\"get('cameraArgs')\" [ref]=\"shadowCameraRef\" />\n            </ng-container>\n        </ngt-group>\n    `,\n    imports: [NgIf, NgtPush, NgtArgs],\n    schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class NgtsContactShadows extends NgtRxStore {\n    private readonly store = inject(NgtStore);\n    readonly shadowCameraRef = injectNgtRef<OrthographicCamera>();\n    readonly encoding = this.store.get('gl', 'outputEncoding');\n    readonly contactShadows$ = this.select('contactShadows');\n    readonly Math = Math;\n\n    @Input() contactShadowsRef = injectNgtRef<Group>();\n\n    @Input() set opacity(opacity: number) {\n        this.set({ opacity });\n    }\n\n    @Input() set width(width: number) {\n        this.set({ width });\n    }\n\n    @Input() set height(height: number) {\n        this.set({ height });\n    }\n\n    @Input() set blur(blur: number) {\n        this.set({ blur });\n    }\n\n    @Input() set far(far: number) {\n        this.set({ far });\n    }\n\n    @Input() set smooth(smooth: boolean) {\n        this.set({ smooth });\n    }\n\n    @Input() set resolution(resolution: number) {\n        this.set({ resolution });\n    }\n\n    @Input() set frames(frames: number) {\n        this.set({ frames });\n    }\n\n    @Input() set scale(scale: number | [x: number, y: number]) {\n        this.set({ scale });\n    }\n\n    @Input() set color(color: THREE.ColorRepresentation) {\n        this.set({ color });\n    }\n\n    @Input() set depthWrite(depthWrite: boolean) {\n        this.set({ depthWrite });\n    }\n\n    @Input() set renderOrder(renderOrder: number) {\n        this.set({ renderOrder });\n    }\n\n    constructor() {\n        super();\n        injectBeforeRender(this.onBeforeRender.bind(this, 0));\n    }\n\n    override initialize() {\n        super.initialize();\n        this.set({\n            scale: 10,\n            frames: Infinity,\n            opacity: 1,\n            width: 1,\n            height: 1,\n            blur: 1,\n            far: 10,\n            resolution: 512,\n            smooth: true,\n            color: '#000000',\n            depthWrite: false,\n            renderOrder: 0,\n        });\n        this.connect(\n            'scaledWidth',\n            this.select(\n                ['width', 'scale'],\n                ({ width, scale }) => width * (Array.isArray(scale) ? scale[0] : scale || 1)\n            )\n        );\n        this.connect(\n            'scaledHeight',\n            this.select(\n                ['height', 'scale'],\n                ({ height, scale }) => height * (Array.isArray(scale) ? scale[1] : scale || 1)\n            )\n        );\n        this.connect(\n            'cameraArgs',\n            this.select(['scaledWidth', 'scaledHeight', 'far'], ({ scaledWidth: width, scaledHeight: height, far }) => {\n                return [-width / 2, width / 2, height / 2, -height / 2, 0, far];\n            })\n        );\n        this.connect(\n            'contactShadows',\n            this.select(\n                ['resolution', 'scaledWidth', 'scaledHeight', 'scale', 'color'],\n                ({ resolution, scaledWidth: width, scaledHeight: height, color }) => {\n                    const renderTarget = new THREE.WebGLRenderTarget(resolution, resolution);\n                    const renderTargetBlur = new THREE.WebGLRenderTarget(resolution, resolution);\n                    renderTargetBlur.texture.generateMipmaps = renderTarget.texture.generateMipmaps = false;\n                    const planeGeometry = new THREE.PlaneGeometry(width, height).rotateX(Math.PI / 2);\n                    const blurPlane = new Mesh(planeGeometry);\n                    const depthMaterial = new THREE.MeshDepthMaterial();\n                    depthMaterial.depthTest = depthMaterial.depthWrite = false;\n                    depthMaterial.onBeforeCompile = (shader) => {\n                        shader.uniforms = {\n                            ...shader.uniforms,\n                            ucolor: { value: new THREE.Color(color) },\n                        };\n                        shader.fragmentShader = shader.fragmentShader.replace(\n                            `void main() {`, //\n                            `uniform vec3 ucolor;\n                             void main() {\n                            `\n                        );\n                        shader.fragmentShader = shader.fragmentShader.replace(\n                            'vec4( vec3( 1.0 - fragCoordZ ), opacity );',\n                            // Colorize the shadow, multiply by the falloff so that the center can remain darker\n                            'vec4( ucolor * fragCoordZ * 2.0, ( 1.0 - fragCoordZ ) * 1.0 );'\n                        );\n                    };\n\n                    const horizontalBlurMaterial = new THREE.ShaderMaterial(HorizontalBlurShader);\n                    const verticalBlurMaterial = new THREE.ShaderMaterial(VerticalBlurShader);\n                    verticalBlurMaterial.depthTest = horizontalBlurMaterial.depthTest = false;\n\n                    return {\n                        renderTarget,\n                        planeGeometry,\n                        depthMaterial,\n                        blurPlane,\n                        horizontalBlurMaterial,\n                        verticalBlurMaterial,\n                        renderTargetBlur,\n                    };\n                }\n            )\n        );\n    }\n\n    private onBeforeRender(count: number, { scene, gl }: NgtRenderState) {\n        const {\n            frames,\n            blur,\n            contactShadows: { depthMaterial, renderTarget },\n            smooth,\n        } = this.get();\n\n        if (this.shadowCameraRef.nativeElement && (frames === Infinity || count < frames)) {\n            const initialBackground = scene.background;\n            scene.background = null;\n            const initialOverrideMaterial = scene.overrideMaterial;\n            scene.overrideMaterial = depthMaterial;\n            gl.setRenderTarget(renderTarget);\n            gl.render(scene, this.shadowCameraRef.nativeElement);\n            scene.overrideMaterial = initialOverrideMaterial;\n\n            this.blurShadows(blur);\n            if (smooth) this.blurShadows(blur * 0.4);\n\n            gl.setRenderTarget(null);\n            scene.background = initialBackground;\n            count++;\n        }\n    }\n\n    private blurShadows(blur: number) {\n        const { blurPlane, horizontalBlurMaterial, verticalBlurMaterial, renderTargetBlur, renderTarget } =\n            this.get('contactShadows');\n        const gl = this.store.get('gl');\n\n        blurPlane.visible = true;\n\n        blurPlane.material = horizontalBlurMaterial;\n        horizontalBlurMaterial.uniforms.tDiffuse.value = renderTarget.texture;\n        horizontalBlurMaterial.uniforms.h.value = (blur * 1) / 256;\n\n        gl.setRenderTarget(renderTargetBlur);\n        gl.render(blurPlane, this.shadowCameraRef.nativeElement);\n\n        blurPlane.material = verticalBlurMaterial;\n        verticalBlurMaterial.uniforms.tDiffuse.value = renderTargetBlur.texture;\n        verticalBlurMaterial.uniforms.v.value = (blur * 1) / 256;\n\n        gl.setRenderTarget(renderTarget);\n        gl.render(blurPlane, this.shadowCameraRef.nativeElement);\n\n        blurPlane.visible = false;\n    }\n}\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const ngtsEnvironmentPresetsObj = {
|
|
2
|
+
sunset: 'venice/venice_sunset_1k.hdr',
|
|
3
|
+
dawn: 'kiara/kiara_1_dawn_1k.hdr',
|
|
4
|
+
night: 'dikhololo/dikhololo_night_1k.hdr',
|
|
5
|
+
warehouse: 'empty-wharehouse/empty_warehouse_01_1k.hdr',
|
|
6
|
+
forest: 'forrest-slope/forest_slope_1k.hdr',
|
|
7
|
+
apartment: 'lebombo/lebombo_1k.hdr',
|
|
8
|
+
studio: 'studio-small-3/studio_small_03_1k.hdr',
|
|
9
|
+
city: 'potsdamer-platz/potsdamer_platz_1k.hdr',
|
|
10
|
+
park: 'rooitou/rooitou_park_1k.hdr',
|
|
11
|
+
lobby: 'st-fagans/st_fagans_interior_1k.hdr',
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvc3RhZ2luZy9zcmMvbGliL2Vudmlyb25tZW50L2Fzc2V0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRztJQUNyQyxNQUFNLEVBQUUsNkJBQTZCO0lBQ3JDLElBQUksRUFBRSwyQkFBMkI7SUFDakMsS0FBSyxFQUFFLGtDQUFrQztJQUN6QyxTQUFTLEVBQUUsNENBQTRDO0lBQ3ZELE1BQU0sRUFBRSxtQ0FBbUM7SUFDM0MsU0FBUyxFQUFFLHdCQUF3QjtJQUNuQyxNQUFNLEVBQUUsdUNBQXVDO0lBQy9DLElBQUksRUFBRSx3Q0FBd0M7SUFDOUMsSUFBSSxFQUFFLDZCQUE2QjtJQUNuQyxLQUFLLEVBQUUscUNBQXFDO0NBQy9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3Qgbmd0c0Vudmlyb25tZW50UHJlc2V0c09iaiA9IHtcbiAgICBzdW5zZXQ6ICd2ZW5pY2UvdmVuaWNlX3N1bnNldF8xay5oZHInLFxuICAgIGRhd246ICdraWFyYS9raWFyYV8xX2Rhd25fMWsuaGRyJyxcbiAgICBuaWdodDogJ2Rpa2hvbG9sby9kaWtob2xvbG9fbmlnaHRfMWsuaGRyJyxcbiAgICB3YXJlaG91c2U6ICdlbXB0eS13aGFyZWhvdXNlL2VtcHR5X3dhcmVob3VzZV8wMV8xay5oZHInLFxuICAgIGZvcmVzdDogJ2ZvcnJlc3Qtc2xvcGUvZm9yZXN0X3Nsb3BlXzFrLmhkcicsXG4gICAgYXBhcnRtZW50OiAnbGVib21iby9sZWJvbWJvXzFrLmhkcicsXG4gICAgc3R1ZGlvOiAnc3R1ZGlvLXNtYWxsLTMvc3R1ZGlvX3NtYWxsXzAzXzFrLmhkcicsXG4gICAgY2l0eTogJ3BvdHNkYW1lci1wbGF0ei9wb3RzZGFtZXJfcGxhdHpfMWsuaGRyJyxcbiAgICBwYXJrOiAncm9vaXRvdS9yb29pdG91X3BhcmtfMWsuaGRyJyxcbiAgICBsb2JieTogJ3N0LWZhZ2Fucy9zdF9mYWdhbnNfaW50ZXJpb3JfMWsuaGRyJyxcbn07XG5cbmV4cG9ydCB0eXBlIE5ndHNFbnZpcm9ubWVudFByZXNldHNUeXBlID0ga2V5b2YgdHlwZW9mIG5ndHNFbnZpcm9ubWVudFByZXNldHNPYmo7XG4iXX0=
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import { startWithUndefined } from 'angular-three';
|
|
3
|
+
import { combineLatest, startWith } from 'rxjs';
|
|
4
|
+
import { NgtsEnvironmentInputs } from './environment-inputs';
|
|
5
|
+
import { injectNgtsEnvironment, setEnvProps } from './utils';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class NgtsEnvironmentCube extends NgtsEnvironmentInputs {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.textureRef = injectNgtsEnvironment((params) => this.select().pipe(startWith(params)));
|
|
11
|
+
}
|
|
12
|
+
initialize() {
|
|
13
|
+
super.initialize();
|
|
14
|
+
this.set({ background: false });
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.setEnvProps();
|
|
18
|
+
}
|
|
19
|
+
setEnvProps() {
|
|
20
|
+
this.effect(combineLatest([
|
|
21
|
+
this.store.select('scene'),
|
|
22
|
+
this.select('scene').pipe(startWithUndefined()),
|
|
23
|
+
this.select('background'),
|
|
24
|
+
this.select('blur').pipe(startWithUndefined()),
|
|
25
|
+
this.textureRef.$,
|
|
26
|
+
]), ([defaultScene, scene, background, blur, texture]) => {
|
|
27
|
+
return setEnvProps(background, scene, defaultScene, texture, blur);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
NgtsEnvironmentCube.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentCube, deps: null, target: i0.ɵɵFactoryTarget.Directive });
|
|
32
|
+
NgtsEnvironmentCube.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.3", type: NgtsEnvironmentCube, isStandalone: true, selector: "ngts-environment-cube", usesInheritance: true, ngImport: i0 });
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentCube, decorators: [{
|
|
34
|
+
type: Directive,
|
|
35
|
+
args: [{
|
|
36
|
+
selector: 'ngts-environment-cube',
|
|
37
|
+
standalone: true,
|
|
38
|
+
}]
|
|
39
|
+
}] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQtY3ViZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci10aHJlZS1zb2JhL3N0YWdpbmcvc3JjL2xpYi9lbnZpcm9ubWVudC9lbnZpcm9ubWVudC1jdWJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUM7O0FBTTdELE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxxQkFBcUI7SUFKOUQ7O1FBS2EsZUFBVSxHQUFHLHFCQUFxQixDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7S0F5QmxHO0lBdkJZLFVBQVU7UUFDZixLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLE1BQU0sQ0FDUCxhQUFhLENBQUM7WUFDVixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUM7WUFDMUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQztZQUN6QixJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1lBQzlDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUNwQixDQUFDLEVBQ0YsQ0FBQyxDQUFDLFlBQVksRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRSxPQUFPLENBQUMsRUFBRSxFQUFFO1lBQ2pELE9BQU8sV0FBVyxDQUFDLFVBQVUsRUFBRSxLQUFLLEVBQUUsWUFBWSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN2RSxDQUFDLENBQ0osQ0FBQztJQUNOLENBQUM7O2dIQXpCUSxtQkFBbUI7b0dBQW5CLG1CQUFtQjsyRkFBbkIsbUJBQW1CO2tCQUovQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFVBQVUsRUFBRSxJQUFJO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzdGFydFdpdGhVbmRlZmluZWQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IGNvbWJpbmVMYXRlc3QsIHN0YXJ0V2l0aCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50SW5wdXRzIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1pbnB1dHMnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0c0Vudmlyb25tZW50LCBzZXRFbnZQcm9wcyB9IGZyb20gJy4vdXRpbHMnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ25ndHMtZW52aXJvbm1lbnQtY3ViZScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c0Vudmlyb25tZW50Q3ViZSBleHRlbmRzIE5ndHNFbnZpcm9ubWVudElucHV0cyBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgcmVhZG9ubHkgdGV4dHVyZVJlZiA9IGluamVjdE5ndHNFbnZpcm9ubWVudCgocGFyYW1zKSA9PiB0aGlzLnNlbGVjdCgpLnBpcGUoc3RhcnRXaXRoKHBhcmFtcykpKTtcblxuICAgIG92ZXJyaWRlIGluaXRpYWxpemUoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLmluaXRpYWxpemUoKTtcbiAgICAgICAgdGhpcy5zZXQoeyBiYWNrZ3JvdW5kOiBmYWxzZSB9KTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5zZXRFbnZQcm9wcygpO1xuICAgIH1cblxuICAgIHByaXZhdGUgc2V0RW52UHJvcHMoKSB7XG4gICAgICAgIHRoaXMuZWZmZWN0KFxuICAgICAgICAgICAgY29tYmluZUxhdGVzdChbXG4gICAgICAgICAgICAgICAgdGhpcy5zdG9yZS5zZWxlY3QoJ3NjZW5lJyksXG4gICAgICAgICAgICAgICAgdGhpcy5zZWxlY3QoJ3NjZW5lJykucGlwZShzdGFydFdpdGhVbmRlZmluZWQoKSksXG4gICAgICAgICAgICAgICAgdGhpcy5zZWxlY3QoJ2JhY2tncm91bmQnKSxcbiAgICAgICAgICAgICAgICB0aGlzLnNlbGVjdCgnYmx1cicpLnBpcGUoc3RhcnRXaXRoVW5kZWZpbmVkKCkpLFxuICAgICAgICAgICAgICAgIHRoaXMudGV4dHVyZVJlZi4kLFxuICAgICAgICAgICAgXSksXG4gICAgICAgICAgICAoW2RlZmF1bHRTY2VuZSwgc2NlbmUsIGJhY2tncm91bmQsIGJsdXIsIHRleHR1cmVdKSA9PiB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHNldEVudlByb3BzKGJhY2tncm91bmQsIHNjZW5lLCBkZWZhdWx0U2NlbmUsIHRleHR1cmUsIGJsdXIpO1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
3
|
+
import { extend, NgtArgs, startWithUndefined } from 'angular-three';
|
|
4
|
+
import { combineLatest, map, startWith } from 'rxjs';
|
|
5
|
+
import { GroundProjectedEnv } from 'three-stdlib';
|
|
6
|
+
import { NgtsEnvironmentInputs } from './environment-inputs';
|
|
7
|
+
import { NgtsEnvironmentMap } from './environment-map';
|
|
8
|
+
import { injectNgtsEnvironment } from './utils';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
extend({ GroundProjectedEnv });
|
|
11
|
+
export class NgtsEnvironmentGround extends NgtsEnvironmentInputs {
|
|
12
|
+
constructor() {
|
|
13
|
+
super(...arguments);
|
|
14
|
+
this.defaultTexture = injectNgtsEnvironment((params) => this.select().pipe(startWith(params)));
|
|
15
|
+
}
|
|
16
|
+
ngOnInit() {
|
|
17
|
+
this.connect('texture', combineLatest([this.select('map').pipe(startWithUndefined()), this.defaultTexture.$]).pipe(map(([map, texture]) => map || texture)));
|
|
18
|
+
this.connect('groundArgs', this.select('texture').pipe(map((texture) => [texture])));
|
|
19
|
+
this.connect('groundHeight', this.select(['ground'], ({ ground }) => ground?.height));
|
|
20
|
+
this.connect('groundRadius', this.select(['ground'], ({ ground }) => ground?.radius));
|
|
21
|
+
this.connect('groundScale', this.select(['ground'], ({ ground }) => ground?.scale ?? 1000));
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
NgtsEnvironmentGround.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentGround, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
+
NgtsEnvironmentGround.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.3", type: NgtsEnvironmentGround, isStandalone: true, selector: "ngts-environment-ground", usesInheritance: true, ngImport: i0, template: `
|
|
26
|
+
<ngts-environment-map
|
|
27
|
+
[background]="get('background')"
|
|
28
|
+
[blur]="get('blur')"
|
|
29
|
+
[scene]="get('scene')"
|
|
30
|
+
[map]="get('texture')"
|
|
31
|
+
/>
|
|
32
|
+
<ng-container *ngIf="get('groundArgs') as groundArgs">
|
|
33
|
+
<ngt-ground-projected-env
|
|
34
|
+
*args="groundArgs"
|
|
35
|
+
[scale]="get('groundScale')"
|
|
36
|
+
[height]="get('groundHeight')"
|
|
37
|
+
[radius]="get('groundRadius')"
|
|
38
|
+
/>
|
|
39
|
+
</ng-container>
|
|
40
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: NgtsEnvironmentMap, selector: "ngts-environment-map" }, { kind: "directive", type: NgtArgs, selector: "[args]", inputs: ["args"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.3", ngImport: i0, type: NgtsEnvironmentGround, decorators: [{
|
|
42
|
+
type: Component,
|
|
43
|
+
args: [{
|
|
44
|
+
selector: 'ngts-environment-ground',
|
|
45
|
+
standalone: true,
|
|
46
|
+
template: `
|
|
47
|
+
<ngts-environment-map
|
|
48
|
+
[background]="get('background')"
|
|
49
|
+
[blur]="get('blur')"
|
|
50
|
+
[scene]="get('scene')"
|
|
51
|
+
[map]="get('texture')"
|
|
52
|
+
/>
|
|
53
|
+
<ng-container *ngIf="get('groundArgs') as groundArgs">
|
|
54
|
+
<ngt-ground-projected-env
|
|
55
|
+
*args="groundArgs"
|
|
56
|
+
[scale]="get('groundScale')"
|
|
57
|
+
[height]="get('groundHeight')"
|
|
58
|
+
[radius]="get('groundRadius')"
|
|
59
|
+
/>
|
|
60
|
+
</ng-container>
|
|
61
|
+
`,
|
|
62
|
+
imports: [NgtsEnvironmentMap, NgtArgs, NgIf],
|
|
63
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
64
|
+
}]
|
|
65
|
+
}] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQtZ3JvdW5kLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXRocmVlLXNvYmEvc3RhZ2luZy9zcmMvbGliL2Vudmlyb25tZW50L2Vudmlyb25tZW50LWdyb3VuZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBRSxzQkFBc0IsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMxRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLFNBQVMsQ0FBQzs7QUFFaEQsTUFBTSxDQUFDLEVBQUUsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO0FBd0IvQixNQUFNLE9BQU8scUJBQXNCLFNBQVEscUJBQXFCO0lBdEJoRTs7UUF1QmEsbUJBQWMsR0FBRyxxQkFBcUIsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBdUJ0RztJQXJCRyxRQUFRO1FBQ0osSUFBSSxDQUFDLE9BQU8sQ0FDUixTQUFTLEVBQ1QsYUFBYSxDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQ3RGLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxHQUFHLElBQUksT0FBTyxDQUFDLENBQzFDLENBQ0osQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNyRixJQUFJLENBQUMsT0FBTyxDQUNSLGNBQWMsRUFDZCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQzFELENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxDQUNSLGNBQWMsRUFDZCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxDQUFDLENBQzFELENBQUM7UUFDRixJQUFJLENBQUMsT0FBTyxDQUNSLGFBQWEsRUFDYixJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE1BQU0sRUFBRSxFQUFFLEVBQUUsQ0FBQyxNQUFNLEVBQUUsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUNqRSxDQUFDO0lBQ04sQ0FBQzs7a0hBdkJRLHFCQUFxQjtzR0FBckIscUJBQXFCLDBHQW5CcEI7Ozs7Ozs7Ozs7Ozs7OztLQWVULDREQUNTLGtCQUFrQixpRUFBRSxPQUFPLHFFQUFFLElBQUk7MkZBR2xDLHFCQUFxQjtrQkF0QmpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7O0tBZVQ7b0JBQ0QsT0FBTyxFQUFFLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQztvQkFDNUMsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZXh0ZW5kLCBOZ3RBcmdzLCBzdGFydFdpdGhVbmRlZmluZWQgfSBmcm9tICdhbmd1bGFyLXRocmVlJztcbmltcG9ydCB7IGNvbWJpbmVMYXRlc3QsIG1hcCwgc3RhcnRXaXRoIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBHcm91bmRQcm9qZWN0ZWRFbnYgfSBmcm9tICd0aHJlZS1zdGRsaWInO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50SW5wdXRzIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1pbnB1dHMnO1xuaW1wb3J0IHsgTmd0c0Vudmlyb25tZW50TWFwIH0gZnJvbSAnLi9lbnZpcm9ubWVudC1tYXAnO1xuaW1wb3J0IHsgaW5qZWN0Tmd0c0Vudmlyb25tZW50IH0gZnJvbSAnLi91dGlscyc7XG5cbmV4dGVuZCh7IEdyb3VuZFByb2plY3RlZEVudiB9KTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduZ3RzLWVudmlyb25tZW50LWdyb3VuZCcsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8bmd0cy1lbnZpcm9ubWVudC1tYXBcbiAgICAgICAgICAgIFtiYWNrZ3JvdW5kXT1cImdldCgnYmFja2dyb3VuZCcpXCJcbiAgICAgICAgICAgIFtibHVyXT1cImdldCgnYmx1cicpXCJcbiAgICAgICAgICAgIFtzY2VuZV09XCJnZXQoJ3NjZW5lJylcIlxuICAgICAgICAgICAgW21hcF09XCJnZXQoJ3RleHR1cmUnKVwiXG4gICAgICAgIC8+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJnZXQoJ2dyb3VuZEFyZ3MnKSBhcyBncm91bmRBcmdzXCI+XG4gICAgICAgICAgICA8bmd0LWdyb3VuZC1wcm9qZWN0ZWQtZW52XG4gICAgICAgICAgICAgICAgKmFyZ3M9XCJncm91bmRBcmdzXCJcbiAgICAgICAgICAgICAgICBbc2NhbGVdPVwiZ2V0KCdncm91bmRTY2FsZScpXCJcbiAgICAgICAgICAgICAgICBbaGVpZ2h0XT1cImdldCgnZ3JvdW5kSGVpZ2h0JylcIlxuICAgICAgICAgICAgICAgIFtyYWRpdXNdPVwiZ2V0KCdncm91bmRSYWRpdXMnKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICBgLFxuICAgIGltcG9ydHM6IFtOZ3RzRW52aXJvbm1lbnRNYXAsIE5ndEFyZ3MsIE5nSWZdLFxuICAgIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd0c0Vudmlyb25tZW50R3JvdW5kIGV4dGVuZHMgTmd0c0Vudmlyb25tZW50SW5wdXRzIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICByZWFkb25seSBkZWZhdWx0VGV4dHVyZSA9IGluamVjdE5ndHNFbnZpcm9ubWVudCgocGFyYW1zKSA9PiB0aGlzLnNlbGVjdCgpLnBpcGUoc3RhcnRXaXRoKHBhcmFtcykpKTtcblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmNvbm5lY3QoXG4gICAgICAgICAgICAndGV4dHVyZScsXG4gICAgICAgICAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLnNlbGVjdCgnbWFwJykucGlwZShzdGFydFdpdGhVbmRlZmluZWQoKSksIHRoaXMuZGVmYXVsdFRleHR1cmUuJF0pLnBpcGUoXG4gICAgICAgICAgICAgICAgbWFwKChbbWFwLCB0ZXh0dXJlXSkgPT4gbWFwIHx8IHRleHR1cmUpXG4gICAgICAgICAgICApXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMuY29ubmVjdCgnZ3JvdW5kQXJncycsIHRoaXMuc2VsZWN0KCd0ZXh0dXJlJykucGlwZShtYXAoKHRleHR1cmUpID0+IFt0ZXh0dXJlXSkpKTtcbiAgICAgICAgdGhpcy5jb25uZWN0KFxuICAgICAgICAgICAgJ2dyb3VuZEhlaWdodCcsXG4gICAgICAgICAgICB0aGlzLnNlbGVjdChbJ2dyb3VuZCddLCAoeyBncm91bmQgfSkgPT4gZ3JvdW5kPy5oZWlnaHQpXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMuY29ubmVjdChcbiAgICAgICAgICAgICdncm91bmRSYWRpdXMnLFxuICAgICAgICAgICAgdGhpcy5zZWxlY3QoWydncm91bmQnXSwgKHsgZ3JvdW5kIH0pID0+IGdyb3VuZD8ucmFkaXVzKVxuICAgICAgICApO1xuICAgICAgICB0aGlzLmNvbm5lY3QoXG4gICAgICAgICAgICAnZ3JvdW5kU2NhbGUnLFxuICAgICAgICAgICAgdGhpcy5zZWxlY3QoWydncm91bmQnXSwgKHsgZ3JvdW5kIH0pID0+IGdyb3VuZD8uc2NhbGUgPz8gMTAwMClcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
|