angular-three-soba 2.0.0-beta.261 → 2.0.0-beta.263
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/controls/index.d.ts +1 -0
- package/controls/lib/scroll-controls.d.ts +78 -0
- package/esm2022/controls/index.mjs +2 -1
- package/esm2022/controls/lib/scroll-controls.mjs +268 -0
- package/esm2022/staging/lib/environment.mjs +13 -4
- package/fesm2022/angular-three-soba-controls.mjs +271 -7
- package/fesm2022/angular-three-soba-controls.mjs.map +1 -1
- package/fesm2022/angular-three-soba-staging.mjs +12 -3
- package/fesm2022/angular-three-soba-staging.mjs.map +1 -1
- package/package.json +12 -12
- package/staging/README.md +4 -4
package/controls/index.d.ts
CHANGED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { NgtHTML } from 'angular-three';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export interface NgtsScrollControlsOptions {
|
|
4
|
+
/** Precision, default 0.00001 */
|
|
5
|
+
eps: number;
|
|
6
|
+
/** Horizontal scroll, default false (vertical) */
|
|
7
|
+
horizontal: boolean;
|
|
8
|
+
/** Infinite scroll, default false (experimental!) */
|
|
9
|
+
infinite: boolean;
|
|
10
|
+
/** Defines the lenght of the scroll area, each page is height:100%, default 1 */
|
|
11
|
+
pages: number;
|
|
12
|
+
/** A factor that increases scroll bar travel,default: 1 */
|
|
13
|
+
distance: number;
|
|
14
|
+
/** Friction in seconds, default: 0.25 (1/4 second) */
|
|
15
|
+
damping: number;
|
|
16
|
+
/** maxSpeed optionally allows you to clamp the maximum speed. If damping is 0.2s and looks OK
|
|
17
|
+
* going between, say, page 1 and 2, but not for pages far apart as it'll move very rapid,
|
|
18
|
+
* then a maxSpeed of e.g. 3 which will clamp the speed to 3 units per second, it may now
|
|
19
|
+
* take much longer than damping to reach the target if it is far away. Default: Infinity */
|
|
20
|
+
maxSpeed: number;
|
|
21
|
+
/** If true attaches the scroll container before the canvas */
|
|
22
|
+
prepend: boolean;
|
|
23
|
+
enabled: boolean;
|
|
24
|
+
style: Partial<CSSStyleDeclaration>;
|
|
25
|
+
}
|
|
26
|
+
export declare class NgtsScrollControls {
|
|
27
|
+
progress: import("@angular/core").ModelSignal<number>;
|
|
28
|
+
options: import("@angular/core").InputSignalWithTransform<NgtsScrollControlsOptions, "" | Partial<NgtsScrollControlsOptions>>;
|
|
29
|
+
private document;
|
|
30
|
+
private store;
|
|
31
|
+
private gl;
|
|
32
|
+
private events;
|
|
33
|
+
private invalidate;
|
|
34
|
+
private size;
|
|
35
|
+
private domElement;
|
|
36
|
+
private target;
|
|
37
|
+
private _el;
|
|
38
|
+
private _fill;
|
|
39
|
+
private _fixed;
|
|
40
|
+
private style;
|
|
41
|
+
private prepend;
|
|
42
|
+
private enabled;
|
|
43
|
+
private infinite;
|
|
44
|
+
private maxSpeed;
|
|
45
|
+
eps: import("@angular/core").Signal<number>;
|
|
46
|
+
horizontal: import("@angular/core").Signal<boolean>;
|
|
47
|
+
pages: import("@angular/core").Signal<number>;
|
|
48
|
+
distance: import("@angular/core").Signal<number>;
|
|
49
|
+
damping: import("@angular/core").Signal<number>;
|
|
50
|
+
scroll: number;
|
|
51
|
+
offset: number;
|
|
52
|
+
delta: number;
|
|
53
|
+
constructor();
|
|
54
|
+
get el(): HTMLDivElement;
|
|
55
|
+
get fill(): HTMLDivElement;
|
|
56
|
+
get fixed(): HTMLDivElement;
|
|
57
|
+
range(from: number, distance: number, margin?: number): number;
|
|
58
|
+
curve(from: number, distance: number, margin?: number): number;
|
|
59
|
+
visible(from: number, distance: number, margin?: number): boolean;
|
|
60
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsScrollControls, never>;
|
|
61
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<NgtsScrollControls, "ngts-scroll-controls", never, { "progress": { "alias": "progress"; "required": false; "isSignal": true; }; "options": { "alias": "options"; "required": false; "isSignal": true; }; }, { "progress": "progressChange"; }, never, ["*"], true, never>;
|
|
62
|
+
}
|
|
63
|
+
export declare class NgtsScrollCanvas {
|
|
64
|
+
private host;
|
|
65
|
+
private scrollControls;
|
|
66
|
+
private store;
|
|
67
|
+
private viewport;
|
|
68
|
+
constructor();
|
|
69
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsScrollCanvas, never>;
|
|
70
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsScrollCanvas, "ngt-group[ngts-scroll-canvas]", never, {}, {}, never, never, true, never>;
|
|
71
|
+
}
|
|
72
|
+
export declare class NgtsScrollHtml extends NgtHTML {
|
|
73
|
+
private scrollControls;
|
|
74
|
+
private size;
|
|
75
|
+
constructor();
|
|
76
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NgtsScrollHtml, never>;
|
|
77
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NgtsScrollHtml, "div[ngts-scroll-html]", never, {}, {}, never, never, true, never>;
|
|
78
|
+
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './lib/camera-controls';
|
|
2
2
|
export * from './lib/orbit-controls';
|
|
3
|
-
|
|
3
|
+
export * from './lib/scroll-controls';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3NvYmEvY29udHJvbHMvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY2FtZXJhLWNvbnRyb2xzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL29yYml0LWNvbnRyb2xzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Njcm9sbC1jb250cm9scyc7XG4iXX0=
|
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, Directive, ElementRef, inject, input, model, untracked, } from '@angular/core';
|
|
3
|
+
import { injectBeforeRender, injectStore, NgtHTML, pick, provideHTMLDomElement } from 'angular-three';
|
|
4
|
+
import { easing } from 'maath';
|
|
5
|
+
import { injectAutoEffect } from 'ngxtension/auto-effect';
|
|
6
|
+
import { mergeInputs } from 'ngxtension/inject-inputs';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
const defaultOptions = {
|
|
9
|
+
eps: 0.00001,
|
|
10
|
+
horizontal: false,
|
|
11
|
+
infinite: false,
|
|
12
|
+
pages: 1,
|
|
13
|
+
distance: 1,
|
|
14
|
+
damping: 0.25,
|
|
15
|
+
maxSpeed: Infinity,
|
|
16
|
+
prepend: false,
|
|
17
|
+
enabled: true,
|
|
18
|
+
style: {},
|
|
19
|
+
};
|
|
20
|
+
export class NgtsScrollControls {
|
|
21
|
+
constructor() {
|
|
22
|
+
this.progress = model(0);
|
|
23
|
+
this.options = input(defaultOptions, { transform: mergeInputs(defaultOptions) });
|
|
24
|
+
this.document = inject(DOCUMENT);
|
|
25
|
+
this.store = injectStore();
|
|
26
|
+
this.gl = this.store.select('gl');
|
|
27
|
+
this.events = this.store.select('events');
|
|
28
|
+
this.invalidate = this.store.select('invalidate');
|
|
29
|
+
this.size = this.store.select('size');
|
|
30
|
+
this.domElement = pick(this.gl, 'domElement');
|
|
31
|
+
this.target = pick(this.domElement, 'parentNode');
|
|
32
|
+
this._el = this.document.createElement('div');
|
|
33
|
+
this._fill = this.document.createElement('div');
|
|
34
|
+
this._fixed = this.document.createElement('div');
|
|
35
|
+
this.style = pick(this.options, 'style');
|
|
36
|
+
this.prepend = pick(this.options, 'prepend');
|
|
37
|
+
this.enabled = pick(this.options, 'enabled');
|
|
38
|
+
this.infinite = pick(this.options, 'infinite');
|
|
39
|
+
this.maxSpeed = pick(this.options, 'maxSpeed');
|
|
40
|
+
this.eps = pick(this.options, 'eps');
|
|
41
|
+
this.horizontal = pick(this.options, 'horizontal');
|
|
42
|
+
this.pages = pick(this.options, 'pages');
|
|
43
|
+
this.distance = pick(this.options, 'distance');
|
|
44
|
+
this.damping = pick(this.options, 'damping');
|
|
45
|
+
this.scroll = 0;
|
|
46
|
+
this.offset = 0;
|
|
47
|
+
this.delta = 0;
|
|
48
|
+
const autoEffect = injectAutoEffect();
|
|
49
|
+
afterNextRender(() => {
|
|
50
|
+
autoEffect(() => {
|
|
51
|
+
const target = this.target();
|
|
52
|
+
if (!target)
|
|
53
|
+
return;
|
|
54
|
+
const parent = target;
|
|
55
|
+
const [pages, distance, horizontal, el, fill, fixed, style, prepend, domElement, events] = [
|
|
56
|
+
this.pages(),
|
|
57
|
+
this.distance(),
|
|
58
|
+
this.horizontal(),
|
|
59
|
+
this.el,
|
|
60
|
+
this.fill,
|
|
61
|
+
this.fixed,
|
|
62
|
+
untracked(this.style),
|
|
63
|
+
untracked(this.prepend),
|
|
64
|
+
untracked(this.domElement),
|
|
65
|
+
untracked(this.events),
|
|
66
|
+
];
|
|
67
|
+
el.style.position = 'absolute';
|
|
68
|
+
el.style.width = '100%';
|
|
69
|
+
el.style.height = '100%';
|
|
70
|
+
el.style[horizontal ? 'overflowX' : 'overflowY'] = 'auto';
|
|
71
|
+
el.style[horizontal ? 'overflowY' : 'overflowX'] = 'hidden';
|
|
72
|
+
el.style.top = '0px';
|
|
73
|
+
el.style.left = '0px';
|
|
74
|
+
for (const key in style) {
|
|
75
|
+
el.style[key] = style[key];
|
|
76
|
+
}
|
|
77
|
+
fixed.style.position = 'sticky';
|
|
78
|
+
fixed.style.top = '0px';
|
|
79
|
+
fixed.style.left = '0px';
|
|
80
|
+
fixed.style.width = '100%';
|
|
81
|
+
fixed.style.height = '100%';
|
|
82
|
+
fixed.style.overflow = 'hidden';
|
|
83
|
+
el.appendChild(fixed);
|
|
84
|
+
fill.style.height = horizontal ? '100%' : `${pages * distance * 100}%`;
|
|
85
|
+
fill.style.width = horizontal ? `${pages * distance * 100}%` : '100%';
|
|
86
|
+
fill.style.pointerEvents = 'none';
|
|
87
|
+
el.appendChild(fill);
|
|
88
|
+
if (prepend)
|
|
89
|
+
parent.prepend(el);
|
|
90
|
+
else
|
|
91
|
+
parent.appendChild(el);
|
|
92
|
+
// Init scroll one pixel in to allow upward/leftward scroll
|
|
93
|
+
el[horizontal ? 'scrollLeft' : 'scrollTop'] = 1;
|
|
94
|
+
const oldTarget = (events.connected || domElement);
|
|
95
|
+
requestAnimationFrame(() => events.connect?.(el));
|
|
96
|
+
const oldCompute = events.compute?.bind(events);
|
|
97
|
+
this.store.snapshot.setEvents({
|
|
98
|
+
compute(event, store) {
|
|
99
|
+
const state = store.snapshot;
|
|
100
|
+
// we are using boundingClientRect because we could not rely on target.offsetTop as canvas could be positioned anywhere in dom
|
|
101
|
+
const { left, top } = parent.getBoundingClientRect();
|
|
102
|
+
const offsetX = event.clientX - left;
|
|
103
|
+
const offsetY = event.clientY - top;
|
|
104
|
+
state.pointer.set((offsetX / state.size.width) * 2 - 1, -(offsetY / state.size.height) * 2 + 1);
|
|
105
|
+
state.raycaster.setFromCamera(state.pointer, state.camera);
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
return () => {
|
|
109
|
+
parent.removeChild(el);
|
|
110
|
+
this.store.snapshot.setEvents({ compute: oldCompute });
|
|
111
|
+
events.connect?.(oldTarget);
|
|
112
|
+
};
|
|
113
|
+
});
|
|
114
|
+
autoEffect(() => {
|
|
115
|
+
const [el, events, size, infinite, invalidate, horizontal, enabled] = [
|
|
116
|
+
this.el,
|
|
117
|
+
this.events(),
|
|
118
|
+
this.size(),
|
|
119
|
+
this.infinite(),
|
|
120
|
+
this.invalidate(),
|
|
121
|
+
this.horizontal(),
|
|
122
|
+
this.enabled(),
|
|
123
|
+
];
|
|
124
|
+
if (events.connected !== el)
|
|
125
|
+
return;
|
|
126
|
+
const containerLength = size[horizontal ? 'width' : 'height'];
|
|
127
|
+
const scrollLength = el[horizontal ? 'scrollWidth' : 'scrollHeight'];
|
|
128
|
+
const scrollThreshold = scrollLength - containerLength;
|
|
129
|
+
let current = 0;
|
|
130
|
+
let disableScroll = true;
|
|
131
|
+
let firstRun = true;
|
|
132
|
+
const onScroll = () => {
|
|
133
|
+
// Prevent first scroll because it is indirectly caused by the one pixel offset
|
|
134
|
+
if (!enabled || firstRun)
|
|
135
|
+
return;
|
|
136
|
+
invalidate();
|
|
137
|
+
current = el[horizontal ? 'scrollLeft' : 'scrollTop'];
|
|
138
|
+
this.scroll = current / scrollThreshold;
|
|
139
|
+
if (infinite) {
|
|
140
|
+
if (!disableScroll) {
|
|
141
|
+
if (current >= scrollThreshold) {
|
|
142
|
+
const damp = 1 - this.offset;
|
|
143
|
+
el[horizontal ? 'scrollLeft' : 'scrollTop'] = 1;
|
|
144
|
+
this.scroll = this.offset = -damp;
|
|
145
|
+
disableScroll = true;
|
|
146
|
+
}
|
|
147
|
+
else if (current <= 0) {
|
|
148
|
+
const damp = 1 + this.offset;
|
|
149
|
+
el[horizontal ? 'scrollLeft' : 'scrollTop'] = scrollLength;
|
|
150
|
+
this.scroll = this.offset = damp;
|
|
151
|
+
disableScroll = true;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
if (disableScroll)
|
|
155
|
+
setTimeout(() => (disableScroll = false), 40);
|
|
156
|
+
}
|
|
157
|
+
untracked(() => {
|
|
158
|
+
this.progress.set(this.scroll);
|
|
159
|
+
});
|
|
160
|
+
};
|
|
161
|
+
el.addEventListener('scroll', onScroll, { passive: true });
|
|
162
|
+
requestAnimationFrame(() => (firstRun = false));
|
|
163
|
+
const onWheel = (e) => (el[horizontal ? 'scrollLeft' : 'scrollTop'] += e.deltaY / 2);
|
|
164
|
+
if (horizontal)
|
|
165
|
+
el.addEventListener('wheel', onWheel, { passive: true });
|
|
166
|
+
return () => {
|
|
167
|
+
el.removeEventListener('scroll', onScroll);
|
|
168
|
+
if (horizontal)
|
|
169
|
+
el.removeEventListener('wheel', onWheel);
|
|
170
|
+
};
|
|
171
|
+
});
|
|
172
|
+
});
|
|
173
|
+
let last = 0;
|
|
174
|
+
injectBeforeRender(({ delta }) => {
|
|
175
|
+
last = this.offset;
|
|
176
|
+
easing.damp(this, 'offset', this.scroll, this.damping(), delta, this.maxSpeed(), undefined, this.eps());
|
|
177
|
+
easing.damp(this, 'delta', Math.abs(last - this.offset), this.damping(), delta, this.maxSpeed(), undefined, this.eps());
|
|
178
|
+
if (this.delta > this.eps())
|
|
179
|
+
this.invalidate()();
|
|
180
|
+
});
|
|
181
|
+
}
|
|
182
|
+
get el() {
|
|
183
|
+
return this._el;
|
|
184
|
+
}
|
|
185
|
+
get fill() {
|
|
186
|
+
return this._fill;
|
|
187
|
+
}
|
|
188
|
+
get fixed() {
|
|
189
|
+
return this._fixed;
|
|
190
|
+
}
|
|
191
|
+
range(from, distance, margin = 0) {
|
|
192
|
+
const start = from - margin;
|
|
193
|
+
const end = start + distance + margin * 2;
|
|
194
|
+
return this.offset < start ? 0 : this.offset > end ? 1 : (this.offset - start) / (end - start);
|
|
195
|
+
}
|
|
196
|
+
curve(from, distance, margin = 0) {
|
|
197
|
+
return Math.sin(this.range(from, distance, margin) * Math.PI);
|
|
198
|
+
}
|
|
199
|
+
visible(from, distance, margin = 0) {
|
|
200
|
+
const start = from - margin;
|
|
201
|
+
const end = start + distance + margin * 2;
|
|
202
|
+
return this.offset >= start && this.offset <= end;
|
|
203
|
+
}
|
|
204
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollControls, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
205
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.1.0", type: NgtsScrollControls, isStandalone: true, selector: "ngts-scroll-controls", inputs: { progress: { classPropertyName: "progress", publicName: "progress", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { progress: "progressChange" }, ngImport: i0, template: `
|
|
206
|
+
<ng-content />
|
|
207
|
+
`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
208
|
+
}
|
|
209
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollControls, decorators: [{
|
|
210
|
+
type: Component,
|
|
211
|
+
args: [{
|
|
212
|
+
selector: 'ngts-scroll-controls',
|
|
213
|
+
standalone: true,
|
|
214
|
+
template: `
|
|
215
|
+
<ng-content />
|
|
216
|
+
`,
|
|
217
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
218
|
+
}]
|
|
219
|
+
}], ctorParameters: () => [] });
|
|
220
|
+
export class NgtsScrollCanvas {
|
|
221
|
+
constructor() {
|
|
222
|
+
this.host = inject(ElementRef);
|
|
223
|
+
this.scrollControls = inject(NgtsScrollControls);
|
|
224
|
+
this.store = injectStore();
|
|
225
|
+
this.viewport = this.store.select('viewport');
|
|
226
|
+
injectBeforeRender(() => {
|
|
227
|
+
const group = this.host.nativeElement;
|
|
228
|
+
group.position.x = this.scrollControls.horizontal()
|
|
229
|
+
? -this.viewport().width * (this.scrollControls.pages() - 1) * this.scrollControls.offset
|
|
230
|
+
: 0;
|
|
231
|
+
group.position.y = this.scrollControls.horizontal()
|
|
232
|
+
? 0
|
|
233
|
+
: this.viewport().height * (this.scrollControls.pages() - 1) * this.scrollControls.offset;
|
|
234
|
+
});
|
|
235
|
+
}
|
|
236
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollCanvas, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
237
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.0", type: NgtsScrollCanvas, isStandalone: true, selector: "ngt-group[ngts-scroll-canvas]", ngImport: i0 }); }
|
|
238
|
+
}
|
|
239
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollCanvas, decorators: [{
|
|
240
|
+
type: Directive,
|
|
241
|
+
args: [{ selector: 'ngt-group[ngts-scroll-canvas]', standalone: true }]
|
|
242
|
+
}], ctorParameters: () => [] });
|
|
243
|
+
export class NgtsScrollHtml extends NgtHTML {
|
|
244
|
+
constructor() {
|
|
245
|
+
super();
|
|
246
|
+
this.scrollControls = inject(NgtsScrollControls);
|
|
247
|
+
this.size = this.store.select('size');
|
|
248
|
+
injectBeforeRender(() => {
|
|
249
|
+
if (this.scrollControls.delta > this.scrollControls.eps()) {
|
|
250
|
+
this.host.nativeElement.style.transform = `translate3d(${this.scrollControls.horizontal()
|
|
251
|
+
? -this.size().width * (this.scrollControls.pages() - 1) * this.scrollControls.offset
|
|
252
|
+
: 0}px,${this.scrollControls.horizontal() ? 0 : this.size().height * (this.scrollControls.pages() - 1) * -this.scrollControls.offset}px,0)`;
|
|
253
|
+
}
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollHtml, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
257
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.0", type: NgtsScrollHtml, isStandalone: true, selector: "div[ngts-scroll-html]", host: { styleAttribute: "position: absolute; top: 0; left: 0; will-change: transform;" }, providers: [provideHTMLDomElement([NgtsScrollControls], (scrollControls) => scrollControls.fixed)], usesInheritance: true, ngImport: i0 }); }
|
|
258
|
+
}
|
|
259
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: NgtsScrollHtml, decorators: [{
|
|
260
|
+
type: Directive,
|
|
261
|
+
args: [{
|
|
262
|
+
selector: 'div[ngts-scroll-html]',
|
|
263
|
+
standalone: true,
|
|
264
|
+
host: { style: 'position: absolute; top: 0; left: 0; will-change: transform;' },
|
|
265
|
+
providers: [provideHTMLDomElement([NgtsScrollControls], (scrollControls) => scrollControls.fixed)],
|
|
266
|
+
}]
|
|
267
|
+
}], ctorParameters: () => [] });
|
|
268
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-controls.js","sourceRoot":"","sources":["../../../../../../libs/soba/controls/src/lib/scroll-controls.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n\tafterNextRender,\n\tChangeDetectionStrategy,\n\tComponent,\n\tDirective,\n\tElementRef,\n\tinject,\n\tinput,\n\tmodel,\n\tuntracked,\n} from '@angular/core';\nimport { injectBeforeRender, injectStore, NgtHTML, pick, provideHTMLDomElement } from 'angular-three';\nimport { easing } from 'maath';\nimport { injectAutoEffect } from 'ngxtension/auto-effect';\nimport { mergeInputs } from 'ngxtension/inject-inputs';\nimport { Group } from 'three';\n\nexport interface NgtsScrollControlsOptions {\n\t/** Precision, default 0.00001 */\n\teps: number;\n\t/** Horizontal scroll, default false (vertical) */\n\thorizontal: boolean;\n\t/** Infinite scroll, default false (experimental!) */\n\tinfinite: boolean;\n\t/** Defines the lenght of the scroll area, each page is height:100%, default 1 */\n\tpages: number;\n\t/** A factor that increases scroll bar travel,default: 1 */\n\tdistance: number;\n\t/** Friction in seconds, default: 0.25 (1/4 second) */\n\tdamping: number;\n\t/** maxSpeed optionally allows you to clamp the maximum speed. If damping is 0.2s and looks OK\n\t *  going between, say, page 1 and 2, but not for pages far apart as it'll move very rapid,\n\t *  then a maxSpeed of e.g. 3 which will clamp the speed to 3 units per second, it may now\n\t *  take much longer than damping to reach the target if it is far away. Default: Infinity */\n\tmaxSpeed: number;\n\t/** If true attaches the scroll container before the canvas */\n\tprepend: boolean;\n\tenabled: boolean;\n\tstyle: Partial<CSSStyleDeclaration>;\n}\n\nconst defaultOptions: NgtsScrollControlsOptions = {\n\teps: 0.00001,\n\thorizontal: false,\n\tinfinite: false,\n\tpages: 1,\n\tdistance: 1,\n\tdamping: 0.25,\n\tmaxSpeed: Infinity,\n\tprepend: false,\n\tenabled: true,\n\tstyle: {},\n};\n\n@Component({\n\tselector: 'ngts-scroll-controls',\n\tstandalone: true,\n\ttemplate: `\n\t\t<ng-content />\n\t`,\n\tchangeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NgtsScrollControls {\n\tprogress = model(0);\n\toptions = input(defaultOptions, { transform: mergeInputs(defaultOptions) });\n\n\tprivate document = inject(DOCUMENT);\n\tprivate store = injectStore();\n\tprivate gl = this.store.select('gl');\n\tprivate events = this.store.select('events');\n\tprivate invalidate = this.store.select('invalidate');\n\tprivate size = this.store.select('size');\n\n\tprivate domElement = pick(this.gl, 'domElement');\n\tprivate target = pick(this.domElement, 'parentNode');\n\n\tprivate _el = this.document.createElement('div');\n\tprivate _fill = this.document.createElement('div');\n\tprivate _fixed = this.document.createElement('div');\n\n\tprivate style = pick(this.options, 'style');\n\tprivate prepend = pick(this.options, 'prepend');\n\tprivate enabled = pick(this.options, 'enabled');\n\tprivate infinite = pick(this.options, 'infinite');\n\tprivate maxSpeed = pick(this.options, 'maxSpeed');\n\teps = pick(this.options, 'eps');\n\thorizontal = pick(this.options, 'horizontal');\n\tpages = pick(this.options, 'pages');\n\tdistance = pick(this.options, 'distance');\n\tdamping = pick(this.options, 'damping');\n\tscroll = 0;\n\toffset = 0;\n\tdelta = 0;\n\n\tconstructor() {\n\t\tconst autoEffect = injectAutoEffect();\n\n\t\tafterNextRender(() => {\n\t\t\tautoEffect(() => {\n\t\t\t\tconst target = this.target();\n\t\t\t\tif (!target) return;\n\n\t\t\t\tconst parent = target as HTMLElement;\n\t\t\t\tconst [pages, distance, horizontal, el, fill, fixed, style, prepend, domElement, events] = [\n\t\t\t\t\tthis.pages(),\n\t\t\t\t\tthis.distance(),\n\t\t\t\t\tthis.horizontal(),\n\t\t\t\t\tthis.el,\n\t\t\t\t\tthis.fill,\n\t\t\t\t\tthis.fixed,\n\t\t\t\t\tuntracked(this.style),\n\t\t\t\t\tuntracked(this.prepend),\n\t\t\t\t\tuntracked(this.domElement),\n\t\t\t\t\tuntracked(this.events),\n\t\t\t\t];\n\n\t\t\t\tel.style.position = 'absolute';\n\t\t\t\tel.style.width = '100%';\n\t\t\t\tel.style.height = '100%';\n\t\t\t\tel.style[horizontal ? 'overflowX' : 'overflowY'] = 'auto';\n\t\t\t\tel.style[horizontal ? 'overflowY' : 'overflowX'] = 'hidden';\n\t\t\t\tel.style.top = '0px';\n\t\t\t\tel.style.left = '0px';\n\n\t\t\t\tfor (const key in style) {\n\t\t\t\t\tel.style[key] = (style as CSSStyleDeclaration)[key];\n\t\t\t\t}\n\n\t\t\t\tfixed.style.position = 'sticky';\n\t\t\t\tfixed.style.top = '0px';\n\t\t\t\tfixed.style.left = '0px';\n\t\t\t\tfixed.style.width = '100%';\n\t\t\t\tfixed.style.height = '100%';\n\t\t\t\tfixed.style.overflow = 'hidden';\n\t\t\t\tel.appendChild(fixed);\n\n\t\t\t\tfill.style.height = horizontal ? '100%' : `${pages * distance * 100}%`;\n\t\t\t\tfill.style.width = horizontal ? `${pages * distance * 100}%` : '100%';\n\t\t\t\tfill.style.pointerEvents = 'none';\n\t\t\t\tel.appendChild(fill);\n\n\t\t\t\tif (prepend) parent.prepend(el);\n\t\t\t\telse parent.appendChild(el);\n\n\t\t\t\t// Init scroll one pixel in to allow upward/leftward scroll\n\t\t\t\tel[horizontal ? 'scrollLeft' : 'scrollTop'] = 1;\n\n\t\t\t\tconst oldTarget = (events.connected || domElement) as HTMLElement;\n\t\t\t\trequestAnimationFrame(() => events.connect?.(el));\n\t\t\t\tconst oldCompute = events.compute?.bind(events);\n\n\t\t\t\tthis.store.snapshot.setEvents({\n\t\t\t\t\tcompute(event, store) {\n\t\t\t\t\t\tconst state = store.snapshot;\n\t\t\t\t\t\t// we are using boundingClientRect because we could not rely on target.offsetTop as canvas could be positioned anywhere in dom\n\t\t\t\t\t\tconst { left, top } = parent.getBoundingClientRect();\n\t\t\t\t\t\tconst offsetX = event.clientX - left;\n\t\t\t\t\t\tconst offsetY = event.clientY - top;\n\t\t\t\t\t\tstate.pointer.set((offsetX / state.size.width) * 2 - 1, -(offsetY / state.size.height) * 2 + 1);\n\t\t\t\t\t\tstate.raycaster.setFromCamera(state.pointer, state.camera);\n\t\t\t\t\t},\n\t\t\t\t});\n\n\t\t\t\treturn () => {\n\t\t\t\t\tparent.removeChild(el);\n\t\t\t\t\tthis.store.snapshot.setEvents({ compute: oldCompute });\n\t\t\t\t\tevents.connect?.(oldTarget);\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tautoEffect(() => {\n\t\t\t\tconst [el, events, size, infinite, invalidate, horizontal, enabled] = [\n\t\t\t\t\tthis.el,\n\t\t\t\t\tthis.events(),\n\t\t\t\t\tthis.size(),\n\t\t\t\t\tthis.infinite(),\n\t\t\t\t\tthis.invalidate(),\n\t\t\t\t\tthis.horizontal(),\n\t\t\t\t\tthis.enabled(),\n\t\t\t\t];\n\n\t\t\t\tif (events.connected !== el) return;\n\n\t\t\t\tconst containerLength = size[horizontal ? 'width' : 'height'];\n\t\t\t\tconst scrollLength = el[horizontal ? 'scrollWidth' : 'scrollHeight'];\n\t\t\t\tconst scrollThreshold = scrollLength - containerLength;\n\n\t\t\t\tlet current = 0;\n\t\t\t\tlet disableScroll = true;\n\t\t\t\tlet firstRun = true;\n\n\t\t\t\tconst onScroll = () => {\n\t\t\t\t\t// Prevent first scroll because it is indirectly caused by the one pixel offset\n\t\t\t\t\tif (!enabled || firstRun) return;\n\t\t\t\t\tinvalidate();\n\t\t\t\t\tcurrent = el[horizontal ? 'scrollLeft' : 'scrollTop'];\n\t\t\t\t\tthis.scroll = current / scrollThreshold;\n\n\t\t\t\t\tif (infinite) {\n\t\t\t\t\t\tif (!disableScroll) {\n\t\t\t\t\t\t\tif (current >= scrollThreshold) {\n\t\t\t\t\t\t\t\tconst damp = 1 - this.offset;\n\t\t\t\t\t\t\t\tel[horizontal ? 'scrollLeft' : 'scrollTop'] = 1;\n\t\t\t\t\t\t\t\tthis.scroll = this.offset = -damp;\n\t\t\t\t\t\t\t\tdisableScroll = true;\n\t\t\t\t\t\t\t} else if (current <= 0) {\n\t\t\t\t\t\t\t\tconst damp = 1 + this.offset;\n\t\t\t\t\t\t\t\tel[horizontal ? 'scrollLeft' : 'scrollTop'] = scrollLength;\n\t\t\t\t\t\t\t\tthis.scroll = this.offset = damp;\n\t\t\t\t\t\t\t\tdisableScroll = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (disableScroll) setTimeout(() => (disableScroll = false), 40);\n\t\t\t\t\t}\n\n\t\t\t\t\tuntracked(() => {\n\t\t\t\t\t\tthis.progress.set(this.scroll);\n\t\t\t\t\t});\n\t\t\t\t};\n\n\t\t\t\tel.addEventListener('scroll', onScroll, { passive: true });\n\t\t\t\trequestAnimationFrame(() => (firstRun = false));\n\n\t\t\t\tconst onWheel = (e: WheelEvent) => (el[horizontal ? 'scrollLeft' : 'scrollTop'] += e.deltaY / 2);\n\t\t\t\tif (horizontal) el.addEventListener('wheel', onWheel, { passive: true });\n\n\t\t\t\treturn () => {\n\t\t\t\t\tel.removeEventListener('scroll', onScroll);\n\t\t\t\t\tif (horizontal) el.removeEventListener('wheel', onWheel);\n\t\t\t\t};\n\t\t\t});\n\t\t});\n\n\t\tlet last = 0;\n\t\tinjectBeforeRender(({ delta }) => {\n\t\t\tlast = this.offset;\n\t\t\teasing.damp(this, 'offset', this.scroll, this.damping(), delta, this.maxSpeed(), undefined, this.eps());\n\t\t\teasing.damp(\n\t\t\t\tthis,\n\t\t\t\t'delta',\n\t\t\t\tMath.abs(last - this.offset),\n\t\t\t\tthis.damping(),\n\t\t\t\tdelta,\n\t\t\t\tthis.maxSpeed(),\n\t\t\t\tundefined,\n\t\t\t\tthis.eps(),\n\t\t\t);\n\t\t\tif (this.delta > this.eps()) this.invalidate()();\n\t\t});\n\t}\n\n\tget el() {\n\t\treturn this._el;\n\t}\n\n\tget fill() {\n\t\treturn this._fill;\n\t}\n\n\tget fixed() {\n\t\treturn this._fixed;\n\t}\n\n\trange(from: number, distance: number, margin: number = 0): number {\n\t\tconst start = from - margin;\n\t\tconst end = start + distance + margin * 2;\n\t\treturn this.offset < start ? 0 : this.offset > end ? 1 : (this.offset - start) / (end - start);\n\t}\n\n\tcurve(from: number, distance: number, margin: number = 0): number {\n\t\treturn Math.sin(this.range(from, distance, margin) * Math.PI);\n\t}\n\n\tvisible(from: number, distance: number, margin: number = 0): boolean {\n\t\tconst start = from - margin;\n\t\tconst end = start + distance + margin * 2;\n\t\treturn this.offset >= start && this.offset <= end;\n\t}\n}\n\n@Directive({ selector: 'ngt-group[ngts-scroll-canvas]', standalone: true })\nexport class NgtsScrollCanvas {\n\tprivate host = inject<ElementRef<Group>>(ElementRef);\n\tprivate scrollControls = inject(NgtsScrollControls);\n\tprivate store = injectStore();\n\tprivate viewport = this.store.select('viewport');\n\n\tconstructor() {\n\t\tinjectBeforeRender(() => {\n\t\t\tconst group = this.host.nativeElement;\n\n\t\t\tgroup.position.x = this.scrollControls.horizontal()\n\t\t\t\t? -this.viewport().width * (this.scrollControls.pages() - 1) * this.scrollControls.offset\n\t\t\t\t: 0;\n\t\t\tgroup.position.y = this.scrollControls.horizontal()\n\t\t\t\t? 0\n\t\t\t\t: this.viewport().height * (this.scrollControls.pages() - 1) * this.scrollControls.offset;\n\t\t});\n\t}\n}\n\n@Directive({\n\tselector: 'div[ngts-scroll-html]',\n\tstandalone: true,\n\thost: { style: 'position: absolute; top: 0; left: 0; will-change: transform;' },\n\tproviders: [provideHTMLDomElement([NgtsScrollControls], (scrollControls) => scrollControls.fixed)],\n})\nexport class NgtsScrollHtml extends NgtHTML {\n\tprivate scrollControls = inject(NgtsScrollControls);\n\tprivate size = this.store.select('size');\n\n\tconstructor() {\n\t\tsuper();\n\t\tinjectBeforeRender(() => {\n\t\t\tif (this.scrollControls.delta > this.scrollControls.eps()) {\n\t\t\t\tthis.host.nativeElement.style.transform = `translate3d(${\n\t\t\t\t\tthis.scrollControls.horizontal()\n\t\t\t\t\t\t? -this.size().width * (this.scrollControls.pages() - 1) * this.scrollControls.offset\n\t\t\t\t\t\t: 0\n\t\t\t\t}px,${this.scrollControls.horizontal() ? 0 : this.size().height * (this.scrollControls.pages() - 1) * -this.scrollControls.offset}px,0)`;\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|