@ethlete/core 1.10.0 → 2.0.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/esm2022/lib/components/structured-data/structured-data.component.mjs +38 -0
- package/esm2022/lib/directives/animatable/animatable.directive.mjs +114 -0
- package/esm2022/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +113 -0
- package/esm2022/lib/directives/animated-lifecycle/index.mjs +2 -0
- package/esm2022/lib/directives/animated-overlay/animated-overlay.directive.mjs +181 -0
- package/esm2022/lib/directives/animated-overlay/public-api.mjs +2 -0
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +38 -0
- package/esm2022/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +147 -0
- package/esm2022/lib/directives/delayable/delayable.directive.mjs +56 -0
- package/esm2022/lib/directives/let/let.directive.mjs +41 -0
- package/esm2022/lib/directives/observe-content/observe-content.directive.mjs +69 -0
- package/esm2022/lib/directives/observe-resize/observe-resize.directive.mjs +69 -0
- package/esm2022/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +175 -0
- package/esm2022/lib/directives/public-api.mjs +16 -0
- package/esm2022/lib/directives/repeat/repeat.directive.mjs +37 -0
- package/esm2022/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +32 -0
- package/esm2022/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +19 -0
- package/esm2022/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +35 -0
- package/esm2022/lib/directives/seo/seo.directive.mjs +167 -0
- package/esm2022/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +16 -0
- package/esm2022/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +16 -0
- package/esm2022/lib/pipes/to-array/to-array.pipe.mjs +16 -0
- package/esm2022/lib/services/click-observer.service.mjs +75 -0
- package/esm2022/lib/services/content-observer.service.mjs +81 -0
- package/esm2022/lib/services/focus-visible.service.mjs +35 -0
- package/esm2022/lib/services/public-api.mjs +8 -0
- package/esm2022/lib/services/resize-observer.service.mjs +77 -0
- package/esm2022/lib/services/router-state.service.mjs +116 -0
- package/esm2022/lib/services/viewport.service.mjs +169 -0
- package/esm2022/lib/types/angular.types.mjs +15 -0
- package/esm2022/lib/utils/destroy.utils.mjs +13 -0
- package/esm2022/lib/utils/public-api.mjs +13 -0
- package/esm2022/lib/utils/reactive-binding.util.mjs +112 -0
- package/esm2022/lib/utils/scrollable.utils.mjs +85 -0
- package/{fesm2020 → fesm2022}/ethlete-core.mjs +745 -605
- package/fesm2022/ethlete-core.mjs.map +1 -0
- package/lib/components/structured-data/structured-data.component.d.ts +1 -1
- package/lib/directives/animatable/animatable.directive.d.ts +1 -1
- package/lib/directives/animated-lifecycle/index.d.ts +1 -0
- package/lib/directives/animated-overlay/animated-overlay.directive.d.ts +62 -0
- package/lib/directives/animated-overlay/public-api.d.ts +1 -0
- package/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.d.ts +1 -1
- package/lib/directives/let/let.directive.d.ts +1 -1
- package/lib/directives/observe-content/observe-content.directive.d.ts +1 -1
- package/lib/directives/observe-resize/observe-resize.directive.d.ts +1 -1
- package/lib/directives/observe-scroll-state/observe-scroll-state.directive.d.ts +1 -1
- package/lib/directives/public-api.d.ts +1 -0
- package/lib/directives/repeat/repeat.directive.d.ts +1 -1
- package/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.d.ts +1 -1
- package/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.d.ts +1 -1
- package/lib/services/public-api.d.ts +0 -1
- package/lib/types/angular.types.d.ts +0 -7
- package/lib/utils/destroy.utils.d.ts +1 -0
- package/lib/utils/public-api.d.ts +1 -0
- package/package.json +14 -19
- package/esm2020/lib/components/structured-data/structured-data.component.mjs +0 -37
- package/esm2020/lib/directives/animatable/animatable.directive.mjs +0 -115
- package/esm2020/lib/directives/animated-lifecycle/animated-lifecycle.directive.mjs +0 -115
- package/esm2020/lib/directives/click-outside/click-outside.directive.mjs +0 -37
- package/esm2020/lib/directives/cursor-drag-scroll/cursor-drag-scroll.directive.mjs +0 -147
- package/esm2020/lib/directives/delayable/delayable.directive.mjs +0 -55
- package/esm2020/lib/directives/let/let.directive.mjs +0 -40
- package/esm2020/lib/directives/observe-content/observe-content.directive.mjs +0 -68
- package/esm2020/lib/directives/observe-resize/observe-resize.directive.mjs +0 -68
- package/esm2020/lib/directives/observe-scroll-state/observe-scroll-state.directive.mjs +0 -176
- package/esm2020/lib/directives/public-api.mjs +0 -15
- package/esm2020/lib/directives/repeat/repeat.directive.mjs +0 -36
- package/esm2020/lib/directives/scroll-observer-first-element/scroll-observer-first-element.directive.mjs +0 -31
- package/esm2020/lib/directives/scroll-observer-ignore-target/scroll-observer-ignore-target.directive.mjs +0 -18
- package/esm2020/lib/directives/scroll-observer-last-element/scroll-observer-last-element.directive.mjs +0 -34
- package/esm2020/lib/directives/seo/seo.directive.mjs +0 -166
- package/esm2020/lib/pipes/normalize-game-result-type/normalize-game-result-type.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-participants/normalize-match-participants.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-score/normalize-match-score.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-state/normalize-match-state.pipe.mjs +0 -15
- package/esm2020/lib/pipes/normalize-match-type/normalize-match-type.pipe.mjs +0 -15
- package/esm2020/lib/pipes/to-array/to-array.pipe.mjs +0 -15
- package/esm2020/lib/services/click-observer.service.mjs +0 -73
- package/esm2020/lib/services/content-observer.service.mjs +0 -79
- package/esm2020/lib/services/destroy.service.mjs +0 -23
- package/esm2020/lib/services/focus-visible.service.mjs +0 -34
- package/esm2020/lib/services/public-api.mjs +0 -9
- package/esm2020/lib/services/resize-observer.service.mjs +0 -75
- package/esm2020/lib/services/router-state.service.mjs +0 -115
- package/esm2020/lib/services/viewport.service.mjs +0 -168
- package/esm2020/lib/types/angular.types.mjs +0 -36
- package/esm2020/lib/utils/public-api.mjs +0 -12
- package/esm2020/lib/utils/reactive-binding.util.mjs +0 -111
- package/esm2020/lib/utils/scrollable.utils.mjs +0 -85
- package/fesm2015/ethlete-core.mjs +0 -2787
- package/fesm2015/ethlete-core.mjs.map +0 -1
- package/fesm2020/ethlete-core.mjs.map +0 -1
- package/lib/services/destroy.service.d.ts +0 -12
- /package/{esm2020 → esm2022}/ethlete-core.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/structured-data/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/constants/viewport.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/memo/memo.decorator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/memo/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/decorators/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animatable/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animatable/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/animated-lifecycle/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/click-outside/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/cursor-drag-scroll.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/cursor-drag-scroll/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/delayable/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/let/let.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/let/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-content/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-resize/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/observe-scroll-state.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/observe-scroll-state/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/repeat/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-first-element/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-ignore-target/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/scroll-observer-last-element/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/directives/seo/seo.directive.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/normalize-game-result-type.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-game-result-type/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/normalize-match-participants.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-participants/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/normalize-match-score.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-score/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.constants.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/normalize-match-state.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-state/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/normalize-match-type.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/normalize-match-type/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/to-array/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/pipes/to-array/to-array.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/viewport.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/i18n.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/viewport.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/animation.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/clamp.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/clone.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/cookie.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/equal.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/media-query-observable.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/rxjs.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/smart-block-scroll-strategy.utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/viewport.util.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/is-array-not-empty.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/is-email.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/must-match.validator.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/validators/public-api.mjs +0 -0
|
@@ -1,168 +0,0 @@
|
|
|
1
|
-
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import { BreakpointObserver } from '@angular/cdk/layout';
|
|
3
|
-
import { Inject, Injectable, Optional } from '@angular/core';
|
|
4
|
-
import { BehaviorSubject, combineLatest, map, shareReplay } from 'rxjs';
|
|
5
|
-
import { DEFAULT_VIEWPORT_CONFIG, VIEWPORT_CONFIG } from '../constants';
|
|
6
|
-
import { Memo } from '../decorators';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@angular/cdk/layout";
|
|
9
|
-
export class ViewportService {
|
|
10
|
-
get isXs$() {
|
|
11
|
-
return this._isXs$.asObservable();
|
|
12
|
-
}
|
|
13
|
-
get isXs() {
|
|
14
|
-
return this._isXs$.value;
|
|
15
|
-
}
|
|
16
|
-
get isSm$() {
|
|
17
|
-
return this._isSm$.asObservable();
|
|
18
|
-
}
|
|
19
|
-
get isSm() {
|
|
20
|
-
return this._isSm$.value;
|
|
21
|
-
}
|
|
22
|
-
get isMd$() {
|
|
23
|
-
return this._isMd$.asObservable();
|
|
24
|
-
}
|
|
25
|
-
get isMd() {
|
|
26
|
-
return this._isMd$.value;
|
|
27
|
-
}
|
|
28
|
-
get isLg$() {
|
|
29
|
-
return this._isLg$.asObservable();
|
|
30
|
-
}
|
|
31
|
-
get isLg() {
|
|
32
|
-
return this._isLg$.value;
|
|
33
|
-
}
|
|
34
|
-
get isXl$() {
|
|
35
|
-
return this._isXl$.asObservable();
|
|
36
|
-
}
|
|
37
|
-
get isXl() {
|
|
38
|
-
return this._isXl$.value;
|
|
39
|
-
}
|
|
40
|
-
get is2Xl$() {
|
|
41
|
-
return this._is2Xl$.asObservable();
|
|
42
|
-
}
|
|
43
|
-
get is2Xl() {
|
|
44
|
-
return this._is2Xl$.value;
|
|
45
|
-
}
|
|
46
|
-
get currentViewport() {
|
|
47
|
-
return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);
|
|
48
|
-
}
|
|
49
|
-
constructor(_viewportConfig, _breakpointObserver) {
|
|
50
|
-
this._breakpointObserver = _breakpointObserver;
|
|
51
|
-
this._isXs$ = new BehaviorSubject(false);
|
|
52
|
-
this._isSm$ = new BehaviorSubject(false);
|
|
53
|
-
this._isMd$ = new BehaviorSubject(false);
|
|
54
|
-
this._isLg$ = new BehaviorSubject(false);
|
|
55
|
-
this._isXl$ = new BehaviorSubject(false);
|
|
56
|
-
this._is2Xl$ = new BehaviorSubject(false);
|
|
57
|
-
this.currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(map((val) => this.getCurrentViewport(val)), shareReplay(1));
|
|
58
|
-
this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;
|
|
59
|
-
this._observeDefaultBreakpoints();
|
|
60
|
-
}
|
|
61
|
-
observe(options) {
|
|
62
|
-
const mediaQuery = this._buildMediaQuery(options);
|
|
63
|
-
return this._breakpointObserver.observe(mediaQuery).pipe(map((x) => x.matches), shareReplay(1));
|
|
64
|
-
}
|
|
65
|
-
isMatched(options) {
|
|
66
|
-
const mediaQuery = this._buildMediaQuery(options);
|
|
67
|
-
return this._breakpointObserver.isMatched(mediaQuery);
|
|
68
|
-
}
|
|
69
|
-
_observeDefaultBreakpoints() {
|
|
70
|
-
this.observe({ max: 'xs' }).subscribe(this._isXs$);
|
|
71
|
-
this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);
|
|
72
|
-
this.observe({ min: 'md', max: 'md' }).subscribe(this._isMd$);
|
|
73
|
-
this.observe({ min: 'lg', max: 'lg' }).subscribe(this._isLg$);
|
|
74
|
-
this.observe({ min: 'xl', max: 'xl' }).subscribe(this._isXl$);
|
|
75
|
-
this.observe({ min: '2xl' }).subscribe(this._is2Xl$);
|
|
76
|
-
}
|
|
77
|
-
_getViewportSize(type, option) {
|
|
78
|
-
const index = option === 'min' ? 0 : 1;
|
|
79
|
-
const size = this._viewportConfig.breakpoints[type][index];
|
|
80
|
-
if (size === Infinity || size === 0) {
|
|
81
|
-
return size;
|
|
82
|
-
}
|
|
83
|
-
if (option === 'min') {
|
|
84
|
-
return size;
|
|
85
|
-
}
|
|
86
|
-
// Due to scaling, the actual size of the viewport may be a decimal number.
|
|
87
|
-
// Eg. on Windows 11 with 150% scaling, the viewport size may be 1535.33px
|
|
88
|
-
// and thus not matching any of the default breakpoints.
|
|
89
|
-
return size + 0.9;
|
|
90
|
-
}
|
|
91
|
-
_buildMediaQuery(options) {
|
|
92
|
-
if (!options.min && !options.max) {
|
|
93
|
-
throw new Error('At least one of min or max must be defined');
|
|
94
|
-
}
|
|
95
|
-
const mediaQueryParts = [];
|
|
96
|
-
if (options.min) {
|
|
97
|
-
if (typeof options.min === 'number') {
|
|
98
|
-
mediaQueryParts.push(`(min-width: ${options.min}px)`);
|
|
99
|
-
}
|
|
100
|
-
else {
|
|
101
|
-
mediaQueryParts.push(`(min-width: ${this._getViewportSize(options.min, 'min')}px)`);
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
if (options.min && options.max) {
|
|
105
|
-
mediaQueryParts.push('and');
|
|
106
|
-
}
|
|
107
|
-
if (options.max) {
|
|
108
|
-
if (typeof options.max === 'number') {
|
|
109
|
-
mediaQueryParts.push(`(max-width: ${options.max}px)`);
|
|
110
|
-
}
|
|
111
|
-
else {
|
|
112
|
-
mediaQueryParts.push(`(max-width: ${this._getViewportSize(options.max, 'max')}px)`);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
return mediaQueryParts.join(' ');
|
|
116
|
-
}
|
|
117
|
-
getCurrentViewport([isXs, isSm, isMd, isLg, isXl, is2Xl]) {
|
|
118
|
-
if (isXs) {
|
|
119
|
-
return 'xs';
|
|
120
|
-
}
|
|
121
|
-
else if (isSm) {
|
|
122
|
-
return 'sm';
|
|
123
|
-
}
|
|
124
|
-
else if (isMd) {
|
|
125
|
-
return 'md';
|
|
126
|
-
}
|
|
127
|
-
else if (isLg) {
|
|
128
|
-
return 'lg';
|
|
129
|
-
}
|
|
130
|
-
else if (isXl) {
|
|
131
|
-
return 'xl';
|
|
132
|
-
}
|
|
133
|
-
else if (is2Xl) {
|
|
134
|
-
return '2xl';
|
|
135
|
-
}
|
|
136
|
-
return 'xs';
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
ViewportService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ViewportService, deps: [{ token: VIEWPORT_CONFIG, optional: true }, { token: i1.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
140
|
-
ViewportService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ViewportService, providedIn: 'root' });
|
|
141
|
-
__decorate([
|
|
142
|
-
Memo(),
|
|
143
|
-
__metadata("design:type", Function),
|
|
144
|
-
__metadata("design:paramtypes", [String, String]),
|
|
145
|
-
__metadata("design:returntype", void 0)
|
|
146
|
-
], ViewportService.prototype, "_getViewportSize", null);
|
|
147
|
-
__decorate([
|
|
148
|
-
Memo({
|
|
149
|
-
resolver: (v) => {
|
|
150
|
-
return `${v.min ?? ''}-${v.max ?? ''}`;
|
|
151
|
-
},
|
|
152
|
-
}),
|
|
153
|
-
__metadata("design:type", Function),
|
|
154
|
-
__metadata("design:paramtypes", [Object]),
|
|
155
|
-
__metadata("design:returntype", void 0)
|
|
156
|
-
], ViewportService.prototype, "_buildMediaQuery", null);
|
|
157
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: ViewportService, decorators: [{
|
|
158
|
-
type: Injectable,
|
|
159
|
-
args: [{
|
|
160
|
-
providedIn: 'root',
|
|
161
|
-
}]
|
|
162
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
163
|
-
type: Inject,
|
|
164
|
-
args: [VIEWPORT_CONFIG]
|
|
165
|
-
}, {
|
|
166
|
-
type: Optional
|
|
167
|
-
}] }, { type: i1.BreakpointObserver }]; }, propDecorators: { _getViewportSize: [], _buildMediaQuery: [] } });
|
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"viewport.service.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/services/viewport.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport { Inject, Injectable, Optional } from '@angular/core';\nimport { BehaviorSubject, combineLatest, map, Observable, shareReplay } from 'rxjs';\nimport { DEFAULT_VIEWPORT_CONFIG, VIEWPORT_CONFIG } from '../constants';\nimport { Memo } from '../decorators';\nimport { Breakpoint, ViewportConfig } from '../types';\nimport { BuildMediaQueryOptions } from './viewport.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class ViewportService {\n  private _viewportConfig: ViewportConfig;\n\n  private _isXs$ = new BehaviorSubject(false);\n  private _isSm$ = new BehaviorSubject(false);\n  private _isMd$ = new BehaviorSubject(false);\n  private _isLg$ = new BehaviorSubject(false);\n  private _isXl$ = new BehaviorSubject(false);\n  private _is2Xl$ = new BehaviorSubject(false);\n\n  get isXs$() {\n    return this._isXs$.asObservable();\n  }\n\n  get isXs() {\n    return this._isXs$.value;\n  }\n\n  get isSm$() {\n    return this._isSm$.asObservable();\n  }\n\n  get isSm() {\n    return this._isSm$.value;\n  }\n\n  get isMd$() {\n    return this._isMd$.asObservable();\n  }\n\n  get isMd() {\n    return this._isMd$.value;\n  }\n\n  get isLg$() {\n    return this._isLg$.asObservable();\n  }\n\n  get isLg() {\n    return this._isLg$.value;\n  }\n\n  get isXl$() {\n    return this._isXl$.asObservable();\n  }\n\n  get isXl() {\n    return this._isXl$.value;\n  }\n\n  get is2Xl$() {\n    return this._is2Xl$.asObservable();\n  }\n\n  get is2Xl() {\n    return this._is2Xl$.value;\n  }\n\n  currentViewport$ = combineLatest([this.isXs$, this.isSm$, this.isMd$, this.isLg$, this.isXl$, this.is2Xl$]).pipe(\n    map((val) => this.getCurrentViewport(val)),\n    shareReplay(1),\n  );\n\n  get currentViewport() {\n    return this.getCurrentViewport([this.isXs, this.isSm, this.isMd, this.isLg, this.isXl, this.is2Xl]);\n  }\n\n  constructor(\n    @Inject(VIEWPORT_CONFIG) @Optional() _viewportConfig: ViewportConfig | null,\n    private _breakpointObserver: BreakpointObserver,\n  ) {\n    this._viewportConfig = _viewportConfig || DEFAULT_VIEWPORT_CONFIG;\n    this._observeDefaultBreakpoints();\n  }\n\n  observe(options: { min?: number | Breakpoint; max?: number | Breakpoint }): Observable<boolean> {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.observe(mediaQuery).pipe(\n      map((x) => x.matches),\n      shareReplay(1),\n    );\n  }\n\n  isMatched(options: { min?: number | Breakpoint; max?: number | Breakpoint }): boolean {\n    const mediaQuery = this._buildMediaQuery(options);\n\n    return this._breakpointObserver.isMatched(mediaQuery);\n  }\n\n  private _observeDefaultBreakpoints() {\n    this.observe({ max: 'xs' }).subscribe(this._isXs$);\n    this.observe({ min: 'sm', max: 'sm' }).subscribe(this._isSm$);\n    this.observe({ min: 'md', max: 'md' }).subscribe(this._isMd$);\n    this.observe({ min: 'lg', max: 'lg' }).subscribe(this._isLg$);\n    this.observe({ min: 'xl', max: 'xl' }).subscribe(this._isXl$);\n    this.observe({ min: '2xl' }).subscribe(this._is2Xl$);\n  }\n\n  @Memo()\n  private _getViewportSize(type: Breakpoint, option: 'min' | 'max') {\n    const index = option === 'min' ? 0 : 1;\n    const size = this._viewportConfig.breakpoints[type][index];\n\n    if (size === Infinity || size === 0) {\n      return size;\n    }\n\n    if (option === 'min') {\n      return size;\n    }\n\n    // Due to scaling, the actual size of the viewport may be a decimal number.\n    // Eg. on Windows 11 with 150% scaling, the viewport size may be 1535.33px\n    // and thus not matching any of the default breakpoints.\n    return size + 0.9;\n  }\n\n  @Memo({\n    resolver: (v: BuildMediaQueryOptions) => {\n      return `${v.min ?? ''}-${v.max ?? ''}`;\n    },\n  })\n  private _buildMediaQuery(options: BuildMediaQueryOptions) {\n    if (!options.min && !options.max) {\n      throw new Error('At least one of min or max must be defined');\n    }\n\n    const mediaQueryParts: string[] = [];\n\n    if (options.min) {\n      if (typeof options.min === 'number') {\n        mediaQueryParts.push(`(min-width: ${options.min}px)`);\n      } else {\n        mediaQueryParts.push(`(min-width: ${this._getViewportSize(options.min, 'min')}px)`);\n      }\n    }\n\n    if (options.min && options.max) {\n      mediaQueryParts.push('and');\n    }\n\n    if (options.max) {\n      if (typeof options.max === 'number') {\n        mediaQueryParts.push(`(max-width: ${options.max}px)`);\n      } else {\n        mediaQueryParts.push(`(max-width: ${this._getViewportSize(options.max, 'max')}px)`);\n      }\n    }\n\n    return mediaQueryParts.join(' ');\n  }\n\n  private getCurrentViewport([isXs, isSm, isMd, isLg, isXl, is2Xl]: [\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n    boolean,\n  ]): Breakpoint {\n    if (isXs) {\n      return 'xs';\n    } else if (isSm) {\n      return 'sm';\n    } else if (isMd) {\n      return 'md';\n    } else if (isLg) {\n      return 'lg';\n    } else if (isXl) {\n      return 'xl';\n    } else if (is2Xl) {\n      return '2xl';\n    }\n\n    return 'xs';\n  }\n}\n"]}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import { QueryList } from '@angular/core';
|
|
3
|
-
export class TypedQueryList extends QueryList {
|
|
4
|
-
constructor() {
|
|
5
|
-
super(...arguments);
|
|
6
|
-
this[_a] = () => {
|
|
7
|
-
return super[Symbol.iterator]();
|
|
8
|
-
};
|
|
9
|
-
}
|
|
10
|
-
get changes() {
|
|
11
|
-
return super.changes;
|
|
12
|
-
}
|
|
13
|
-
toArray() {
|
|
14
|
-
return super.toArray();
|
|
15
|
-
}
|
|
16
|
-
forEach(fn) {
|
|
17
|
-
super.forEach(fn);
|
|
18
|
-
}
|
|
19
|
-
filter(fn) {
|
|
20
|
-
return super.filter(fn);
|
|
21
|
-
}
|
|
22
|
-
map(fn) {
|
|
23
|
-
return super.map(fn);
|
|
24
|
-
}
|
|
25
|
-
reduce(fn, initialValue) {
|
|
26
|
-
return super.reduce(fn, initialValue);
|
|
27
|
-
}
|
|
28
|
-
some(fn) {
|
|
29
|
-
return super.some(fn);
|
|
30
|
-
}
|
|
31
|
-
find(fn) {
|
|
32
|
-
return super.find(fn);
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
_a = Symbol.iterator;
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3R5cGVzL2FuZ3VsYXIudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFzQmhELE1BQU0sT0FBTyxjQUFrQixTQUFRLFNBQXdCO0lBQS9EOztRQUNXLFFBQWlCLEdBQXNCLEdBQUcsRUFBRTtZQUNuRCxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEVBQWlCLENBQUM7UUFDakQsQ0FBQyxDQUFDO0lBdUNKLENBQUM7SUFyQ0MsSUFBYSxPQUFPO1FBQ2xCLE9BQU8sS0FBSyxDQUFDLE9BQXdDLENBQUM7SUFDeEQsQ0FBQztJQUVRLE9BQU87UUFDZCxPQUFPLEtBQUssQ0FBQyxPQUFPLEVBQVMsQ0FBQztJQUNoQyxDQUFDO0lBRVEsT0FBTyxDQUFDLEVBQWdEO1FBQy9ELEtBQUssQ0FBQyxPQUFPLENBQUMsRUFBNEUsQ0FBQyxDQUFDO0lBQzlGLENBQUM7SUFFUSxNQUFNLENBQUMsRUFBbUQ7UUFDakUsT0FBTyxLQUFLLENBQUMsTUFBTSxDQUFDLEVBQStFLENBQVEsQ0FBQztJQUM5RyxDQUFDO0lBRVEsR0FBRyxDQUFJLEVBQTZDO1FBQzNELE9BQU8sS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUF5RSxDQUFDLENBQUM7SUFDOUYsQ0FBQztJQUVRLE1BQU0sQ0FDYixFQUE4RSxFQUM5RSxZQUFlO1FBRWYsT0FBTyxLQUFLLENBQUMsTUFBTSxDQUNqQixFQUEwRyxFQUMxRyxZQUFZLENBQ2IsQ0FBQztJQUNKLENBQUM7SUFFUSxJQUFJLENBQUMsRUFBb0Q7UUFDaEUsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQWdGLENBQUMsQ0FBQztJQUN0RyxDQUFDO0lBRVEsSUFBSSxDQUFDLEVBQW9EO1FBQ2hFLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFnRixDQUFDLENBQUM7SUFDdEcsQ0FBQztDQUNGO0tBekNXLE1BQU0sQ0FBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVlcnlMaXN0LCBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbmV4cG9ydCB0eXBlIE5nQ2xhc3NUeXBlID1cbiAgfCBzdHJpbmdcbiAgfCBzdHJpbmdbXVxuICB8IFNldDxzdHJpbmc+XG4gIHwge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICAgIFtrbGFzczogc3RyaW5nXTogYW55O1xuICAgIH1cbiAgfCBudWxsXG4gIHwgdW5kZWZpbmVkO1xuXG5leHBvcnQgdHlwZSBIb3N0RGlyZWN0aXZlID1cbiAgfCBUeXBlPHVua25vd24+XG4gIHwge1xuICAgICAgZGlyZWN0aXZlOiBUeXBlPHVua25vd24+O1xuICAgICAgaW5wdXRzPzogc3RyaW5nW107XG4gICAgICBvdXRwdXRzPzogc3RyaW5nW107XG4gICAgfTtcblxuZXhwb3J0IGNsYXNzIFR5cGVkUXVlcnlMaXN0PFQ+IGV4dGVuZHMgUXVlcnlMaXN0PFQgfCB1bmRlZmluZWQ+IHtcbiAgb3ZlcnJpZGUgW1N5bWJvbC5pdGVyYXRvcl06ICgpID0+IEl0ZXJhdG9yPFQ+ID0gKCkgPT4ge1xuICAgIHJldHVybiBzdXBlcltTeW1ib2wuaXRlcmF0b3JdKCkgYXMgSXRlcmF0b3I8VD47XG4gIH07XG5cbiAgb3ZlcnJpZGUgZ2V0IGNoYW5nZXMoKTogT2JzZXJ2YWJsZTxUeXBlZFF1ZXJ5TGlzdDxUPj4ge1xuICAgIHJldHVybiBzdXBlci5jaGFuZ2VzIGFzIE9ic2VydmFibGU8VHlwZWRRdWVyeUxpc3Q8VD4+O1xuICB9XG5cbiAgb3ZlcnJpZGUgdG9BcnJheSgpOiBUW10ge1xuICAgIHJldHVybiBzdXBlci50b0FycmF5KCkgYXMgVFtdO1xuICB9XG5cbiAgb3ZlcnJpZGUgZm9yRWFjaChmbjogKGl0ZW06IFQsIGluZGV4OiBudW1iZXIsIGFycmF5OiBUW10pID0+IHZvaWQpOiB2b2lkIHtcbiAgICBzdXBlci5mb3JFYWNoKGZuIGFzIChpdGVtOiBUIHwgdW5kZWZpbmVkLCBpbmRleDogbnVtYmVyLCBhcnJheTogKFQgfCB1bmRlZmluZWQpW10pID0+IHZvaWQpO1xuICB9XG5cbiAgb3ZlcnJpZGUgZmlsdGVyKGZuOiAoaXRlbTogVCwgaW5kZXg6IG51bWJlciwgYXJyYXk6IFRbXSkgPT4gYm9vbGVhbik6IFRbXSB7XG4gICAgcmV0dXJuIHN1cGVyLmZpbHRlcihmbiBhcyAoaXRlbTogVCB8IHVuZGVmaW5lZCwgaW5kZXg6IG51bWJlciwgYXJyYXk6IChUIHwgdW5kZWZpbmVkKVtdKSA9PiBib29sZWFuKSBhcyBUW107XG4gIH1cblxuICBvdmVycmlkZSBtYXA8VT4oZm46IChpdGVtOiBULCBpbmRleDogbnVtYmVyLCBhcnJheTogVFtdKSA9PiBVKTogVVtdIHtcbiAgICByZXR1cm4gc3VwZXIubWFwKGZuIGFzIChpdGVtOiBUIHwgdW5kZWZpbmVkLCBpbmRleDogbnVtYmVyLCBhcnJheTogKFQgfCB1bmRlZmluZWQpW10pID0+IFUpO1xuICB9XG5cbiAgb3ZlcnJpZGUgcmVkdWNlPFU+KFxuICAgIGZuOiAocHJldmlvdXNWYWx1ZTogVSwgY3VycmVudFZhbHVlOiBULCBjdXJyZW50SW5kZXg6IG51bWJlciwgYXJyYXk6IFRbXSkgPT4gVSxcbiAgICBpbml0aWFsVmFsdWU6IFUsXG4gICk6IFUge1xuICAgIHJldHVybiBzdXBlci5yZWR1Y2UoXG4gICAgICBmbiBhcyAocHJldmlvdXNWYWx1ZTogVSwgY3VycmVudFZhbHVlOiBUIHwgdW5kZWZpbmVkLCBjdXJyZW50SW5kZXg6IG51bWJlciwgYXJyYXk6IChUIHwgdW5kZWZpbmVkKVtdKSA9PiBVLFxuICAgICAgaW5pdGlhbFZhbHVlLFxuICAgICk7XG4gIH1cblxuICBvdmVycmlkZSBzb21lKGZuOiAodmFsdWU6IFQsIGluZGV4OiBudW1iZXIsIGFycmF5OiBUW10pID0+IGJvb2xlYW4pOiBib29sZWFuIHtcbiAgICByZXR1cm4gc3VwZXIuc29tZShmbiBhcyAodmFsdWU6IFQgfCB1bmRlZmluZWQsIGluZGV4OiBudW1iZXIsIGFycmF5OiAoVCB8IHVuZGVmaW5lZClbXSkgPT4gYm9vbGVhbik7XG4gIH1cblxuICBvdmVycmlkZSBmaW5kKGZuOiAodmFsdWU6IFQsIGluZGV4OiBudW1iZXIsIGFycmF5OiBUW10pID0+IGJvb2xlYW4pOiBUIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gc3VwZXIuZmluZChmbiBhcyAodmFsdWU6IFQgfCB1bmRlZmluZWQsIGluZGV4OiBudW1iZXIsIGFycmF5OiAoVCB8IHVuZGVmaW5lZClbXSkgPT4gYm9vbGVhbik7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export * from './animation.utils';
|
|
2
|
-
export * from './clamp.util';
|
|
3
|
-
export * from './clone.util';
|
|
4
|
-
export * from './cookie.util';
|
|
5
|
-
export * from './equal.util';
|
|
6
|
-
export * from './media-query-observable.util';
|
|
7
|
-
export * from './reactive-binding.util';
|
|
8
|
-
export * from './rxjs.utils';
|
|
9
|
-
export * from './scrollable.utils';
|
|
10
|
-
export * from './smart-block-scroll-strategy.utils';
|
|
11
|
-
export * from './viewport.util';
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FuaW1hdGlvbi51dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL2NsYW1wLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9jbG9uZS51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vY29va2llLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9lcXVhbC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vbWVkaWEtcXVlcnktb2JzZXJ2YWJsZS51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vcmVhY3RpdmUtYmluZGluZy51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vcnhqcy51dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbGFibGUudXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9zbWFydC1ibG9jay1zY3JvbGwtc3RyYXRlZ3kudXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi92aWV3cG9ydC51dGlsJztcbiJdfQ==
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { ElementRef, inject } from '@angular/core';
|
|
2
|
-
import { distinctUntilChanged, takeUntil } from 'rxjs';
|
|
3
|
-
import { DestroyService } from '../services';
|
|
4
|
-
const isAttributeRenderBinding = (value) => typeof value === 'boolean';
|
|
5
|
-
const isAttributeValueBinding = (value) => typeof value === 'object';
|
|
6
|
-
export const createReactiveBindings = (...values) => {
|
|
7
|
-
const rootElementRef = inject(ElementRef);
|
|
8
|
-
const destroy$ = inject(DestroyService, { host: true }).destroy$;
|
|
9
|
-
const subscriptions = [];
|
|
10
|
-
const pushedAttributes = [];
|
|
11
|
-
const defaults = {};
|
|
12
|
-
const push = (value) => {
|
|
13
|
-
const { attribute, observable, elementRef } = value;
|
|
14
|
-
const elRef = elementRef || rootElementRef;
|
|
15
|
-
const attributes = Array.isArray(attribute) ? attribute : [attribute];
|
|
16
|
-
pushedAttributes.push(attributes);
|
|
17
|
-
for (const attribute of attributes) {
|
|
18
|
-
if (!defaults[attribute]) {
|
|
19
|
-
defaults[attribute] = elRef.nativeElement.getAttribute(attribute) || undefined;
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
const subscription = observable
|
|
23
|
-
.pipe(takeUntil(destroy$), distinctUntilChanged((a, b) => {
|
|
24
|
-
if (isAttributeRenderBinding(a) && isAttributeRenderBinding(b)) {
|
|
25
|
-
return a === b;
|
|
26
|
-
}
|
|
27
|
-
else if (isAttributeValueBinding(a) && isAttributeValueBinding(b)) {
|
|
28
|
-
return a.render === b.render && a.value === b.value;
|
|
29
|
-
}
|
|
30
|
-
return false;
|
|
31
|
-
}))
|
|
32
|
-
.subscribe((value) => {
|
|
33
|
-
const currentAttributes = pushedAttributes.find((s) => s.some((current) => attributes.includes(current))) || [];
|
|
34
|
-
for (const attribute of currentAttributes) {
|
|
35
|
-
const isSingleClassMutation = attribute.startsWith('class.');
|
|
36
|
-
const isMultipleClassMutation = attribute === 'class';
|
|
37
|
-
const render = isAttributeRenderBinding(value) ? value : value.render;
|
|
38
|
-
if (isSingleClassMutation) {
|
|
39
|
-
const className = attribute.replace('class.', '');
|
|
40
|
-
if (!className) {
|
|
41
|
-
continue;
|
|
42
|
-
}
|
|
43
|
-
if (!render) {
|
|
44
|
-
elRef.nativeElement.classList.remove(className);
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
elRef.nativeElement.classList.add(className);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
else if (isMultipleClassMutation) {
|
|
51
|
-
const classes = isAttributeRenderBinding(value) ? '' : `${value.value}`;
|
|
52
|
-
if (!classes) {
|
|
53
|
-
continue;
|
|
54
|
-
}
|
|
55
|
-
if (!render) {
|
|
56
|
-
elRef.nativeElement.classList.remove(...classes.split(' '));
|
|
57
|
-
}
|
|
58
|
-
else {
|
|
59
|
-
elRef.nativeElement.classList.add(...classes.split(' '));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
const attributeValue = isAttributeRenderBinding(value) ? true : `${value.value}`;
|
|
64
|
-
if (!attribute) {
|
|
65
|
-
continue;
|
|
66
|
-
}
|
|
67
|
-
if (!render) {
|
|
68
|
-
elRef.nativeElement.removeAttribute(attribute);
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
elRef.nativeElement.setAttribute(attribute, `${attributeValue}`);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
subscriptions.push({ attributes, subscription });
|
|
77
|
-
};
|
|
78
|
-
const remove = (...attributes) => {
|
|
79
|
-
for (const attribute of attributes) {
|
|
80
|
-
const sub = subscriptions.find((s) => s.attributes.includes(attribute));
|
|
81
|
-
const attributeStack = pushedAttributes.find((a) => a.includes(attribute));
|
|
82
|
-
if (sub) {
|
|
83
|
-
sub.attributes = sub.attributes.filter((a) => a !== attribute);
|
|
84
|
-
attributeStack?.splice(attributeStack.indexOf(attribute), 1);
|
|
85
|
-
if (sub.attributes.length === 0) {
|
|
86
|
-
sub.subscription.unsubscribe();
|
|
87
|
-
subscriptions.splice(subscriptions.indexOf(sub), 1);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
const reset = () => {
|
|
93
|
-
for (const attribute in defaults) {
|
|
94
|
-
if (defaults[attribute] === undefined) {
|
|
95
|
-
rootElementRef.nativeElement.removeAttribute(attribute);
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
rootElementRef.nativeElement.setAttribute(attribute, defaults[attribute]);
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
};
|
|
102
|
-
for (const value of values) {
|
|
103
|
-
push(value);
|
|
104
|
-
}
|
|
105
|
-
return {
|
|
106
|
-
push,
|
|
107
|
-
remove,
|
|
108
|
-
reset,
|
|
109
|
-
};
|
|
110
|
-
};
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reactive-binding.util.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/reactive-binding.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, inject } from '@angular/core';\nimport { distinctUntilChanged, Observable, Subscription, takeUntil } from 'rxjs';\nimport { DestroyService } from '../services';\n\ntype AttributeValueBinding = {\n  render: boolean;\n  value: boolean | string | number;\n};\n\ntype AttributeRenderBinding = boolean;\n\nexport type ReactiveAttributes = {\n  attribute: string | string[];\n  observable: Observable<AttributeValueBinding | AttributeRenderBinding>;\n  elementRef?: ElementRef<HTMLElement>;\n};\n\nconst isAttributeRenderBinding = (\n  value: AttributeValueBinding | AttributeRenderBinding,\n): value is AttributeRenderBinding => typeof value === 'boolean';\nconst isAttributeValueBinding = (\n  value: AttributeValueBinding | AttributeRenderBinding,\n): value is AttributeValueBinding => typeof value === 'object';\n\nexport interface ReactiveBindingResult {\n  reset: () => void;\n  remove: (...attributes: string[]) => void;\n  push: (value: ReactiveAttributes) => void;\n}\n\nexport const createReactiveBindings = (...values: ReactiveAttributes[]): ReactiveBindingResult => {\n  const rootElementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  const destroy$ = inject(DestroyService, { host: true }).destroy$;\n\n  const subscriptions: { attributes: string[]; subscription: Subscription }[] = [];\n  const pushedAttributes: string[][] = [];\n\n  const defaults: Record<string, string | undefined> = {};\n\n  const push = (value: ReactiveAttributes) => {\n    const { attribute, observable, elementRef } = value;\n    const elRef = elementRef || rootElementRef;\n    const attributes = Array.isArray(attribute) ? attribute : [attribute];\n    pushedAttributes.push(attributes);\n\n    for (const attribute of attributes) {\n      if (!defaults[attribute]) {\n        defaults[attribute] = elRef.nativeElement.getAttribute(attribute) || undefined;\n      }\n    }\n\n    const subscription = observable\n      .pipe(\n        takeUntil(destroy$),\n        distinctUntilChanged((a, b) => {\n          if (isAttributeRenderBinding(a) && isAttributeRenderBinding(b)) {\n            return a === b;\n          } else if (isAttributeValueBinding(a) && isAttributeValueBinding(b)) {\n            return a.render === b.render && a.value === b.value;\n          }\n\n          return false;\n        }),\n      )\n      .subscribe((value) => {\n        const currentAttributes = pushedAttributes.find((s) => s.some((current) => attributes.includes(current))) || [];\n\n        for (const attribute of currentAttributes) {\n          const isSingleClassMutation = attribute.startsWith('class.');\n          const isMultipleClassMutation = attribute === 'class';\n\n          const render = isAttributeRenderBinding(value) ? value : value.render;\n\n          if (isSingleClassMutation) {\n            const className = attribute.replace('class.', '');\n\n            if (!className) {\n              continue;\n            }\n\n            if (!render) {\n              elRef.nativeElement.classList.remove(className);\n            } else {\n              elRef.nativeElement.classList.add(className);\n            }\n          } else if (isMultipleClassMutation) {\n            const classes = isAttributeRenderBinding(value) ? '' : `${value.value}`;\n\n            if (!classes) {\n              continue;\n            }\n\n            if (!render) {\n              elRef.nativeElement.classList.remove(...classes.split(' '));\n            } else {\n              elRef.nativeElement.classList.add(...classes.split(' '));\n            }\n          } else {\n            const attributeValue = isAttributeRenderBinding(value) ? true : `${value.value}`;\n\n            if (!attribute) {\n              continue;\n            }\n\n            if (!render) {\n              elRef.nativeElement.removeAttribute(attribute);\n            } else {\n              elRef.nativeElement.setAttribute(attribute, `${attributeValue}`);\n            }\n          }\n        }\n      });\n\n    subscriptions.push({ attributes, subscription });\n  };\n\n  const remove = (...attributes: string[]) => {\n    for (const attribute of attributes) {\n      const sub = subscriptions.find((s) => s.attributes.includes(attribute));\n      const attributeStack = pushedAttributes.find((a) => a.includes(attribute));\n\n      if (sub) {\n        sub.attributes = sub.attributes.filter((a) => a !== attribute);\n        attributeStack?.splice(attributeStack.indexOf(attribute), 1);\n\n        if (sub.attributes.length === 0) {\n          sub.subscription.unsubscribe();\n          subscriptions.splice(subscriptions.indexOf(sub), 1);\n        }\n      }\n    }\n  };\n\n  const reset = () => {\n    for (const attribute in defaults) {\n      if (defaults[attribute] === undefined) {\n        rootElementRef.nativeElement.removeAttribute(attribute);\n      } else {\n        rootElementRef.nativeElement.setAttribute(attribute, defaults[attribute] as string);\n      }\n    }\n  };\n\n  for (const value of values) {\n    push(value);\n  }\n\n  return {\n    push,\n    remove,\n    reset,\n  };\n};\n"]}
|
|
@@ -1,85 +0,0 @@
|
|
|
1
|
-
export const elementCanScroll = (element) => {
|
|
2
|
-
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
3
|
-
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
4
|
-
};
|
|
5
|
-
export const isElementVisible = (options) => {
|
|
6
|
-
let { container } = options;
|
|
7
|
-
const { element } = options;
|
|
8
|
-
if (!element || container === null) {
|
|
9
|
-
return null;
|
|
10
|
-
}
|
|
11
|
-
container || (container = document.documentElement);
|
|
12
|
-
const canScroll = elementCanScroll(container);
|
|
13
|
-
if (!canScroll) {
|
|
14
|
-
return { inline: true, block: true };
|
|
15
|
-
}
|
|
16
|
-
const elementRect = element.getBoundingClientRect();
|
|
17
|
-
const containerRect = container.getBoundingClientRect();
|
|
18
|
-
const elementInlineStart = elementRect.left;
|
|
19
|
-
const elementBlockStart = elementRect.top;
|
|
20
|
-
const containerInlineStart = containerRect.left;
|
|
21
|
-
const containerBlockStart = containerRect.top;
|
|
22
|
-
const elementInlineEnd = elementInlineStart + elementRect.width;
|
|
23
|
-
const elementBlockEnd = elementBlockStart + elementRect.height;
|
|
24
|
-
const containerInlineEnd = containerInlineStart + containerRect.width;
|
|
25
|
-
const containerBlockEnd = containerBlockStart + containerRect.height;
|
|
26
|
-
const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;
|
|
27
|
-
const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;
|
|
28
|
-
return { inline: isElementInlineVisible, block: isElementBlockVisible };
|
|
29
|
-
};
|
|
30
|
-
export const scrollToElement = (options) => {
|
|
31
|
-
let { container } = options;
|
|
32
|
-
const { element, direction, behavior = 'smooth', origin = 'nearest', scrollBlockMargin = 0, scrollInlineMargin = 0, } = options;
|
|
33
|
-
if (!element || container === null) {
|
|
34
|
-
return;
|
|
35
|
-
}
|
|
36
|
-
container || (container = document.documentElement);
|
|
37
|
-
const canScroll = elementCanScroll(container);
|
|
38
|
-
if (!canScroll) {
|
|
39
|
-
return;
|
|
40
|
-
}
|
|
41
|
-
const elementRect = element.getBoundingClientRect();
|
|
42
|
-
const containerRect = container.getBoundingClientRect();
|
|
43
|
-
const elementInlineSize = elementRect.width;
|
|
44
|
-
const elementBlockSize = elementRect.height;
|
|
45
|
-
const containerInlineSize = containerRect.width;
|
|
46
|
-
const containerBlockSize = containerRect.height;
|
|
47
|
-
const elementInlineStart = elementRect.left;
|
|
48
|
-
const elementBlockStart = elementRect.top;
|
|
49
|
-
const containerInlineStart = containerRect.left;
|
|
50
|
-
const containerBlockStart = containerRect.top;
|
|
51
|
-
const elementInlineEnd = elementInlineStart + elementInlineSize;
|
|
52
|
-
const elementBlockEnd = elementBlockStart + elementBlockSize;
|
|
53
|
-
const containerInlineEnd = containerInlineStart + containerInlineSize;
|
|
54
|
-
const containerBlockEnd = containerBlockStart + containerBlockSize;
|
|
55
|
-
const elementInlineCenter = elementInlineStart + elementInlineSize / 2;
|
|
56
|
-
const elementBlockCenter = elementBlockStart + elementBlockSize / 2;
|
|
57
|
-
const containerInlineCenter = containerInlineStart + containerInlineSize / 2;
|
|
58
|
-
const containerBlockCenter = containerBlockStart + containerBlockSize / 2;
|
|
59
|
-
const elementInlineOrigin = origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;
|
|
60
|
-
const elementBlockOrigin = origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;
|
|
61
|
-
const containerInlineOrigin = origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;
|
|
62
|
-
const containerBlockOrigin = origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;
|
|
63
|
-
const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;
|
|
64
|
-
const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;
|
|
65
|
-
let inlineScroll = direction === 'block' ? undefined : inlineOffset;
|
|
66
|
-
let blockScroll = direction === 'inline' ? undefined : blockOffset;
|
|
67
|
-
if (origin === 'nearest') {
|
|
68
|
-
const elVisible = isElementVisible({ element, container });
|
|
69
|
-
if (elVisible?.inline && elVisible?.block) {
|
|
70
|
-
return;
|
|
71
|
-
}
|
|
72
|
-
if (elVisible?.inline) {
|
|
73
|
-
inlineScroll = undefined;
|
|
74
|
-
}
|
|
75
|
-
if (elVisible?.block) {
|
|
76
|
-
blockScroll = undefined;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
container.scrollTo({
|
|
80
|
-
left: inlineScroll,
|
|
81
|
-
top: blockScroll,
|
|
82
|
-
behavior,
|
|
83
|
-
});
|
|
84
|
-
};
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.utils.js","sourceRoot":"","sources":["../../../../../../libs/core/src/lib/utils/scrollable.utils.ts"],"names":[],"mappings":"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","sourcesContent":["export const elementCanScroll = (element: HTMLElement) => {\n  const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;\n\n  return scrollHeight > clientHeight || scrollWidth > clientWidth;\n};\n\nexport interface IsElementVisibleOptions {\n  /**\n   * The element to check if it is visible inside a container.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The container to check if the element is visible inside.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n}\n\nexport interface CurrentElementVisibility {\n  /**\n   * Whether the element is visible in the inline direction.\n   */\n  inline: boolean;\n\n  /**\n   * Whether the element is visible in the block direction.\n   */\n  block: boolean;\n}\n\nexport const isElementVisible = (options: IsElementVisibleOptions): CurrentElementVisibility | null => {\n  let { container } = options;\n  const { element } = options;\n\n  if (!element || container === null) {\n    return null;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return { inline: true, block: true };\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = container.getBoundingClientRect();\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementRect.width;\n  const elementBlockEnd = elementBlockStart + elementRect.height;\n\n  const containerInlineEnd = containerInlineStart + containerRect.width;\n  const containerBlockEnd = containerBlockStart + containerRect.height;\n\n  const isElementInlineVisible = elementInlineStart >= containerInlineStart && elementInlineEnd <= containerInlineEnd;\n  const isElementBlockVisible = elementBlockStart >= containerBlockStart && elementBlockEnd <= containerBlockEnd;\n\n  return { inline: isElementInlineVisible, block: isElementBlockVisible };\n};\n\nexport interface ScrollToElementOptions {\n  /**\n   * The element to scroll to.\n   */\n  element?: HTMLElement | null;\n\n  /**\n   * The scroll container to scroll to the element in.\n   * @default document.documentElement\n   */\n  container?: HTMLElement | null;\n\n  /**\n   * The direction to scroll in.\n   * @default 'both'\n   */\n  direction?: 'inline' | 'block' | 'both';\n\n  /**\n   * The origin of the element to scroll to.\n   * @default 'nearest'\n   */\n  origin?: 'start' | 'end' | 'center' | 'nearest';\n\n  /**\n   * The scroll behavior.\n   * @default 'smooth'\n   */\n  behavior?: ScrollBehavior;\n\n  /**\n   * The scroll inline-margin\n   * @default 0\n   */\n  scrollInlineMargin?: number;\n\n  /**\n   * The scroll block-margin\n   * @default 0\n   */\n  scrollBlockMargin?: number;\n}\n\nexport const scrollToElement = (options: ScrollToElementOptions) => {\n  let { container } = options;\n  const {\n    element,\n    direction,\n    behavior = 'smooth',\n    origin = 'nearest',\n    scrollBlockMargin = 0,\n    scrollInlineMargin = 0,\n  } = options;\n\n  if (!element || container === null) {\n    return;\n  }\n\n  container ||= document.documentElement;\n\n  const canScroll = elementCanScroll(container);\n\n  if (!canScroll) {\n    return;\n  }\n\n  const elementRect = element.getBoundingClientRect();\n  const containerRect = container.getBoundingClientRect();\n\n  const elementInlineSize = elementRect.width;\n  const elementBlockSize = elementRect.height;\n\n  const containerInlineSize = containerRect.width;\n  const containerBlockSize = containerRect.height;\n\n  const elementInlineStart = elementRect.left;\n  const elementBlockStart = elementRect.top;\n\n  const containerInlineStart = containerRect.left;\n  const containerBlockStart = containerRect.top;\n\n  const elementInlineEnd = elementInlineStart + elementInlineSize;\n  const elementBlockEnd = elementBlockStart + elementBlockSize;\n\n  const containerInlineEnd = containerInlineStart + containerInlineSize;\n  const containerBlockEnd = containerBlockStart + containerBlockSize;\n\n  const elementInlineCenter = elementInlineStart + elementInlineSize / 2;\n  const elementBlockCenter = elementBlockStart + elementBlockSize / 2;\n\n  const containerInlineCenter = containerInlineStart + containerInlineSize / 2;\n  const containerBlockCenter = containerBlockStart + containerBlockSize / 2;\n\n  const elementInlineOrigin =\n    origin === 'center' ? elementInlineCenter : origin === 'end' ? elementInlineEnd : elementInlineStart;\n  const elementBlockOrigin =\n    origin === 'center' ? elementBlockCenter : origin === 'end' ? elementBlockEnd : elementBlockStart;\n\n  const containerInlineOrigin =\n    origin === 'center' ? containerInlineCenter : origin === 'end' ? containerInlineEnd : containerInlineStart;\n  const containerBlockOrigin =\n    origin === 'center' ? containerBlockCenter : origin === 'end' ? containerBlockEnd : containerBlockStart;\n\n  const inlineOffset = elementInlineOrigin - containerInlineOrigin - scrollInlineMargin;\n  const blockOffset = elementBlockOrigin - containerBlockOrigin - scrollBlockMargin;\n\n  let inlineScroll: number | undefined = direction === 'block' ? undefined : inlineOffset;\n  let blockScroll: number | undefined = direction === 'inline' ? undefined : blockOffset;\n\n  if (origin === 'nearest') {\n    const elVisible = isElementVisible({ element, container });\n\n    if (elVisible?.inline && elVisible?.block) {\n      return;\n    }\n\n    if (elVisible?.inline) {\n      inlineScroll = undefined;\n    }\n\n    if (elVisible?.block) {\n      blockScroll = undefined;\n    }\n  }\n\n  container.scrollTo({\n    left: inlineScroll,\n    top: blockScroll,\n    behavior,\n  });\n};\n"]}
|