@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
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, HostBinding, inject, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class StructuredDataComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this._sanitizer = inject(DomSanitizer);
|
|
7
|
+
}
|
|
8
|
+
set data(currentValue) {
|
|
9
|
+
this.jsonLD = this.getSafeHTML(currentValue);
|
|
10
|
+
}
|
|
11
|
+
getSafeHTML(value) {
|
|
12
|
+
const json = value ? JSON.stringify(value, null, 2).replace(/<\/script>/g, '<\\/script>') : '';
|
|
13
|
+
const html = `<script type="application/ld+json">${json}</script>`;
|
|
14
|
+
return this._sanitizer.bypassSecurityTrustHtml(html);
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: StructuredDataComponent, isStandalone: true, selector: "et-structured-data", inputs: { data: "data" }, host: { properties: { "innerHTML": "this.jsonLD" }, styleAttribute: "display: none" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
18
|
+
}
|
|
19
|
+
export { StructuredDataComponent };
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: StructuredDataComponent, decorators: [{
|
|
21
|
+
type: Component,
|
|
22
|
+
args: [{
|
|
23
|
+
selector: 'et-structured-data',
|
|
24
|
+
standalone: true,
|
|
25
|
+
template: '',
|
|
26
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
27
|
+
encapsulation: ViewEncapsulation.None,
|
|
28
|
+
host: {
|
|
29
|
+
style: 'display: none',
|
|
30
|
+
},
|
|
31
|
+
}]
|
|
32
|
+
}], propDecorators: { data: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], jsonLD: [{
|
|
35
|
+
type: HostBinding,
|
|
36
|
+
args: ['innerHTML']
|
|
37
|
+
}] } });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1kYXRhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RydWN0dXJlZC1kYXRhL3N0cnVjdHVyZWQtZGF0YS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUM7O0FBR25FLE1BVWEsdUJBQXVCO0lBVnBDO1FBV21CLGVBQVUsR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7S0FlcEQ7SUFiQyxJQUNJLElBQUksQ0FBQyxZQUFnRjtRQUN2RixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDL0MsQ0FBQztJQUtELFdBQVcsQ0FBQyxLQUF5RTtRQUNuRixNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsYUFBYSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDL0YsTUFBTSxJQUFJLEdBQUcsc0NBQXNDLElBQUksV0FBVyxDQUFDO1FBQ25FLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyx1QkFBdUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2RCxDQUFDOzhHQWZVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLCtMQVB4QixFQUFFOztTQU9ELHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQVZuQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsRUFBRTtvQkFDWixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUsZUFBZTtxQkFDdkI7aUJBQ0Y7OEJBS0ssSUFBSTtzQkFEUCxLQUFLO2dCQU1OLE1BQU07c0JBREwsV0FBVzt1QkFBQyxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIGluamVjdCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBKc29uTEQgfSBmcm9tICdAZXRobGV0ZS90eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2V0LXN0cnVjdHVyZWQtZGF0YScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHRlbXBsYXRlOiAnJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGhvc3Q6IHtcbiAgICBzdHlsZTogJ2Rpc3BsYXk6IG5vbmUnLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBTdHJ1Y3R1cmVkRGF0YUNvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX3Nhbml0aXplciA9IGluamVjdChEb21TYW5pdGl6ZXIpO1xuXG4gIEBJbnB1dCgpXG4gIHNldCBkYXRhKGN1cnJlbnRWYWx1ZTogSnNvbkxELldpdGhDb250ZXh0PEpzb25MRC5UaGluZz4gfCBKc29uTEQuR3JhcGggfCBudWxsIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy5qc29uTEQgPSB0aGlzLmdldFNhZmVIVE1MKGN1cnJlbnRWYWx1ZSk7XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ2lubmVySFRNTCcpXG4gIGpzb25MRD86IFNhZmVIdG1sO1xuXG4gIGdldFNhZmVIVE1MKHZhbHVlOiBKc29uTEQuV2l0aENvbnRleHQ8SnNvbkxELlRoaW5nPiB8IEpzb25MRC5HcmFwaCB8IG51bGwgfCB1bmRlZmluZWQpIHtcbiAgICBjb25zdCBqc29uID0gdmFsdWUgPyBKU09OLnN0cmluZ2lmeSh2YWx1ZSwgbnVsbCwgMikucmVwbGFjZSgvPFxcL3NjcmlwdD4vZywgJzxcXFxcL3NjcmlwdD4nKSA6ICcnO1xuICAgIGNvbnN0IGh0bWwgPSBgPHNjcmlwdCB0eXBlPVwiYXBwbGljYXRpb24vbGQranNvblwiPiR7anNvbn08L3NjcmlwdD5gO1xuICAgIHJldHVybiB0aGlzLl9zYW5pdGl6ZXIuYnlwYXNzU2VjdXJpdHlUcnVzdEh0bWwoaHRtbCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, debounceTime, filter, fromEvent, map, merge, skip, Subject, takeUntil, tap, } from 'rxjs';
|
|
3
|
+
import { createDestroy } from '../../utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export const ANIMATABLE_TOKEN = new InjectionToken('ANIMATABLE_DIRECTIVE_TOKEN');
|
|
6
|
+
class AnimatableDirective {
|
|
7
|
+
constructor() {
|
|
8
|
+
this._didEmitStart = false;
|
|
9
|
+
this._parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });
|
|
10
|
+
this._destroy$ = createDestroy();
|
|
11
|
+
this._elementRef = inject(ElementRef);
|
|
12
|
+
this._animationStart$ = new Subject();
|
|
13
|
+
this._animationEnd$ = new Subject();
|
|
14
|
+
this._animatedElement$ = new BehaviorSubject(this._elementRef.nativeElement);
|
|
15
|
+
this.animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));
|
|
16
|
+
this.animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));
|
|
17
|
+
this._hostActiveAnimationCount$ = new BehaviorSubject(0);
|
|
18
|
+
this._totalActiveAnimationCount$ = new BehaviorSubject(0);
|
|
19
|
+
this.isAnimating$ = this._totalActiveAnimationCount$.pipe(map((count) => count > 0), debounceTime(0));
|
|
20
|
+
}
|
|
21
|
+
set animatedElement(value) {
|
|
22
|
+
let newElement = null;
|
|
23
|
+
if (value === null || value === undefined) {
|
|
24
|
+
newElement = this._elementRef.nativeElement;
|
|
25
|
+
}
|
|
26
|
+
else if (typeof value === 'string') {
|
|
27
|
+
const el = document.querySelector(value);
|
|
28
|
+
if (el) {
|
|
29
|
+
newElement = el;
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
if (isDevMode()) {
|
|
33
|
+
console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);
|
|
34
|
+
}
|
|
35
|
+
newElement = this._elementRef.nativeElement;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
newElement = value;
|
|
40
|
+
}
|
|
41
|
+
if (this._animatedElement$.value !== newElement) {
|
|
42
|
+
this._animatedElement$.next(newElement);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
ngOnInit() {
|
|
46
|
+
this._animatedElement$
|
|
47
|
+
.pipe(tap((el) => {
|
|
48
|
+
this._totalActiveAnimationCount$.next(this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value);
|
|
49
|
+
this._hostActiveAnimationCount$.next(0);
|
|
50
|
+
merge(fromEvent(el, 'animationstart'), fromEvent(el, 'transitionstart'))
|
|
51
|
+
.pipe(filter((e) => e.target === el), // skip events from children
|
|
52
|
+
tap(() => {
|
|
53
|
+
const count = this._hostActiveAnimationCount$.value + 1;
|
|
54
|
+
this._hostActiveAnimationCount$.next(count);
|
|
55
|
+
this._totalActiveAnimationCount$.next(count);
|
|
56
|
+
}), takeUntil(this._destroy$), takeUntil(this._animatedElement$.pipe(skip(1))))
|
|
57
|
+
.subscribe();
|
|
58
|
+
merge(fromEvent(el, 'animationend'), fromEvent(el, 'animationcancel'), fromEvent(el, 'transitionend'), fromEvent(el, 'transitioncancel'))
|
|
59
|
+
.pipe(filter((e) => e.target === el), // skip events from children
|
|
60
|
+
tap(() => {
|
|
61
|
+
const count = this._hostActiveAnimationCount$.value - 1;
|
|
62
|
+
this._hostActiveAnimationCount$.next(count);
|
|
63
|
+
this._totalActiveAnimationCount$.next(count);
|
|
64
|
+
}), takeUntil(this._destroy$), takeUntil(this._animatedElement$.pipe(skip(1))))
|
|
65
|
+
.subscribe();
|
|
66
|
+
}), takeUntil(this._destroy$))
|
|
67
|
+
.subscribe();
|
|
68
|
+
this._totalActiveAnimationCount$
|
|
69
|
+
.pipe(tap((count) => {
|
|
70
|
+
if (count > 0 && !this._didEmitStart) {
|
|
71
|
+
this._animationStart$.next();
|
|
72
|
+
this._didEmitStart = true;
|
|
73
|
+
}
|
|
74
|
+
else if (count === 0) {
|
|
75
|
+
this._animationEnd$.next();
|
|
76
|
+
this._didEmitStart = false;
|
|
77
|
+
}
|
|
78
|
+
}), takeUntil(this._destroy$))
|
|
79
|
+
.subscribe();
|
|
80
|
+
if (this._parent) {
|
|
81
|
+
this._parent._hostActiveAnimationCount$
|
|
82
|
+
.pipe(takeUntil(this._destroy$), tap((count) => {
|
|
83
|
+
this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);
|
|
84
|
+
}))
|
|
85
|
+
.subscribe();
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
89
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatableDirective, isStandalone: true, selector: "[etAnimatable]", inputs: { animatedElement: ["etAnimatable", "animatedElement"] }, providers: [
|
|
90
|
+
{
|
|
91
|
+
provide: ANIMATABLE_TOKEN,
|
|
92
|
+
useExisting: AnimatableDirective,
|
|
93
|
+
},
|
|
94
|
+
], exportAs: ["etAnimatable"], ngImport: i0 }); }
|
|
95
|
+
}
|
|
96
|
+
export { AnimatableDirective };
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatableDirective, decorators: [{
|
|
98
|
+
type: Directive,
|
|
99
|
+
args: [{
|
|
100
|
+
selector: '[etAnimatable]',
|
|
101
|
+
exportAs: 'etAnimatable',
|
|
102
|
+
standalone: true,
|
|
103
|
+
providers: [
|
|
104
|
+
{
|
|
105
|
+
provide: ANIMATABLE_TOKEN,
|
|
106
|
+
useExisting: AnimatableDirective,
|
|
107
|
+
},
|
|
108
|
+
],
|
|
109
|
+
}]
|
|
110
|
+
}], propDecorators: { animatedElement: [{
|
|
111
|
+
type: Input,
|
|
112
|
+
args: ['etAnimatable']
|
|
113
|
+
}] } });
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animatable.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animatable/animatable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, Input, isDevMode, OnInit } from '@angular/core';\nimport {\n  BehaviorSubject,\n  debounceTime,\n  filter,\n  fromEvent,\n  map,\n  merge,\n  Observable,\n  skip,\n  Subject,\n  takeUntil,\n  tap,\n} from 'rxjs';\nimport { createDestroy } from '../../utils';\n\nexport const ANIMATABLE_TOKEN = new InjectionToken<AnimatableDirective>('ANIMATABLE_DIRECTIVE_TOKEN');\n\n@Directive({\n  selector: '[etAnimatable]',\n  exportAs: 'etAnimatable',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATABLE_TOKEN,\n      useExisting: AnimatableDirective,\n    },\n  ],\n})\nexport class AnimatableDirective implements OnInit {\n  private _didEmitStart = false;\n\n  private readonly _parent = inject(ANIMATABLE_TOKEN, { optional: true, skipSelf: true });\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _animationStart$ = new Subject<void>();\n  private readonly _animationEnd$ = new Subject<void>();\n\n  @Input('etAnimatable')\n  set animatedElement(value: string | HTMLElement | null | undefined) {\n    let newElement: HTMLElement | null = null;\n    if (value === null || value === undefined) {\n      newElement = this._elementRef.nativeElement;\n    } else if (typeof value === 'string') {\n      const el = document.querySelector(value) as HTMLElement;\n\n      if (el) {\n        newElement = el;\n      } else {\n        if (isDevMode()) {\n          console.warn(`Element with selector ${value} not found. Animatable directive will use host element.`);\n        }\n\n        newElement = this._elementRef.nativeElement;\n      }\n    } else {\n      newElement = value;\n    }\n\n    if (this._animatedElement$.value !== newElement) {\n      this._animatedElement$.next(newElement);\n    }\n  }\n  private _animatedElement$ = new BehaviorSubject<HTMLElement>(this._elementRef.nativeElement);\n\n  readonly animationStart$ = this._animationStart$.asObservable().pipe(debounceTime(0));\n  readonly animationEnd$ = this._animationEnd$.asObservable().pipe(debounceTime(0));\n\n  private readonly _hostActiveAnimationCount$ = new BehaviorSubject<number>(0);\n  private readonly _totalActiveAnimationCount$ = new BehaviorSubject<number>(0);\n\n  readonly isAnimating$: Observable<boolean> = this._totalActiveAnimationCount$.pipe(\n    map((count) => count > 0),\n    debounceTime(0),\n  );\n\n  ngOnInit(): void {\n    this._animatedElement$\n      .pipe(\n        tap((el) => {\n          this._totalActiveAnimationCount$.next(\n            this._totalActiveAnimationCount$.value - this._hostActiveAnimationCount$.value,\n          );\n          this._hostActiveAnimationCount$.next(0);\n\n          merge(fromEvent<AnimationEvent>(el, 'animationstart'), fromEvent<TransitionEvent>(el, 'transitionstart'))\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value + 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n\n          merge(\n            fromEvent<AnimationEvent>(el, 'animationend'),\n            fromEvent<AnimationEvent>(el, 'animationcancel'),\n            fromEvent<TransitionEvent>(el, 'transitionend'),\n            fromEvent<TransitionEvent>(el, 'transitioncancel'),\n          )\n            .pipe(\n              filter((e) => e.target === el), // skip events from children\n              tap(() => {\n                const count = this._hostActiveAnimationCount$.value - 1;\n                this._hostActiveAnimationCount$.next(count);\n                this._totalActiveAnimationCount$.next(count);\n              }),\n              takeUntil(this._destroy$),\n              takeUntil(this._animatedElement$.pipe(skip(1))),\n            )\n            .subscribe();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._totalActiveAnimationCount$\n      .pipe(\n        tap((count) => {\n          if (count > 0 && !this._didEmitStart) {\n            this._animationStart$.next();\n            this._didEmitStart = true;\n          } else if (count === 0) {\n            this._animationEnd$.next();\n            this._didEmitStart = false;\n          }\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    if (this._parent) {\n      this._parent._hostActiveAnimationCount$\n        .pipe(\n          takeUntil(this._destroy$),\n          tap((count) => {\n            this._totalActiveAnimationCount$.next(count + this._hostActiveAnimationCount$.value);\n          }),\n        )\n        .subscribe();\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Directive, ElementRef, inject, InjectionToken, isDevMode } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject, map, switchMap, take, takeUntil, tap } from 'rxjs';
|
|
3
|
+
import { createDestroy, createReactiveBindings, forceReflow, fromNextFrame } from '../../utils';
|
|
4
|
+
import { ANIMATABLE_TOKEN, AnimatableDirective } from '../animatable';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../animatable/animatable.directive";
|
|
7
|
+
export const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken('ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN');
|
|
8
|
+
const ANIMATION_CLASSES = {
|
|
9
|
+
enterFrom: 'et-animation-enter-from',
|
|
10
|
+
enterActive: 'et-animation-enter-active',
|
|
11
|
+
enterTo: 'et-animation-enter-to',
|
|
12
|
+
leaveFrom: 'et-animation-leave-from',
|
|
13
|
+
leaveActive: 'et-animation-leave-active',
|
|
14
|
+
leaveTo: 'et-animation-leave-to',
|
|
15
|
+
};
|
|
16
|
+
class AnimatedLifecycleDirective {
|
|
17
|
+
constructor() {
|
|
18
|
+
this._destroy$ = createDestroy();
|
|
19
|
+
this._elementRef = inject(ElementRef);
|
|
20
|
+
this._animatable = inject(ANIMATABLE_TOKEN);
|
|
21
|
+
this._classList = this._elementRef.nativeElement.classList;
|
|
22
|
+
this._state$ = new BehaviorSubject('init');
|
|
23
|
+
this.state$ = this._state$.asObservable();
|
|
24
|
+
this._bindings = createReactiveBindings({
|
|
25
|
+
attribute: 'class.et-force-invisible',
|
|
26
|
+
observable: this._state$.pipe(map((state) => state === 'init')),
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
get state() {
|
|
30
|
+
return this._state$.value;
|
|
31
|
+
}
|
|
32
|
+
enter(config) {
|
|
33
|
+
if (this.state !== 'init' && this.state !== 'left' && isDevMode()) {
|
|
34
|
+
console.warn('Tried to enter but the element is not in the initial state. This may result in unexpected behavior.', this);
|
|
35
|
+
}
|
|
36
|
+
this._state$.next('entering');
|
|
37
|
+
if (!config?.onlyTransition) {
|
|
38
|
+
this._classList.add(ANIMATION_CLASSES.enterFrom);
|
|
39
|
+
}
|
|
40
|
+
forceReflow();
|
|
41
|
+
this._classList.add(ANIMATION_CLASSES.enterActive);
|
|
42
|
+
fromNextFrame()
|
|
43
|
+
.pipe(tap(() => {
|
|
44
|
+
if (!config?.onlyTransition) {
|
|
45
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
46
|
+
this._classList.add(ANIMATION_CLASSES.enterTo);
|
|
47
|
+
}
|
|
48
|
+
}), switchMap(() => this._animatable.animationEnd$), tap(() => {
|
|
49
|
+
this._state$.next('entered');
|
|
50
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
51
|
+
if (!config?.onlyTransition) {
|
|
52
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
53
|
+
}
|
|
54
|
+
}), takeUntil(this._destroy$), take(1))
|
|
55
|
+
.subscribe();
|
|
56
|
+
}
|
|
57
|
+
leave(config) {
|
|
58
|
+
if (this.state !== 'entered' && this.state !== 'entering' && isDevMode()) {
|
|
59
|
+
console.warn('Tried to leave while already leaving or left. This may result in unexpected behavior.', this);
|
|
60
|
+
}
|
|
61
|
+
if (this._classList.contains(ANIMATION_CLASSES.enterFrom) ||
|
|
62
|
+
this._classList.contains(ANIMATION_CLASSES.enterActive) ||
|
|
63
|
+
this._classList.contains(ANIMATION_CLASSES.enterTo)) {
|
|
64
|
+
this._classList.remove(ANIMATION_CLASSES.enterFrom);
|
|
65
|
+
this._classList.remove(ANIMATION_CLASSES.enterActive);
|
|
66
|
+
this._classList.remove(ANIMATION_CLASSES.enterTo);
|
|
67
|
+
}
|
|
68
|
+
this._state$.next('leaving');
|
|
69
|
+
if (!config?.onlyTransition) {
|
|
70
|
+
this._classList.add(ANIMATION_CLASSES.leaveFrom);
|
|
71
|
+
}
|
|
72
|
+
forceReflow();
|
|
73
|
+
this._classList.add(ANIMATION_CLASSES.leaveActive);
|
|
74
|
+
fromNextFrame()
|
|
75
|
+
.pipe(tap(() => {
|
|
76
|
+
if (!config?.onlyTransition) {
|
|
77
|
+
this._classList.remove(ANIMATION_CLASSES.leaveFrom);
|
|
78
|
+
this._classList.add(ANIMATION_CLASSES.leaveTo);
|
|
79
|
+
}
|
|
80
|
+
}), switchMap(() => this._animatable.animationEnd$), tap(() => {
|
|
81
|
+
this._state$.next('left');
|
|
82
|
+
this._classList.remove(ANIMATION_CLASSES.leaveActive);
|
|
83
|
+
if (!config?.onlyTransition) {
|
|
84
|
+
this._classList.remove(ANIMATION_CLASSES.leaveTo);
|
|
85
|
+
}
|
|
86
|
+
}), takeUntil(this._destroy$), take(1))
|
|
87
|
+
.subscribe();
|
|
88
|
+
}
|
|
89
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedLifecycleDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
90
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatedLifecycleDirective, isStandalone: true, selector: "[etAnimatedLifecycle]", providers: [
|
|
91
|
+
{
|
|
92
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
93
|
+
useExisting: AnimatedLifecycleDirective,
|
|
94
|
+
},
|
|
95
|
+
], exportAs: ["etAnimatedLifecycle"], hostDirectives: [{ directive: i1.AnimatableDirective }], ngImport: i0 }); }
|
|
96
|
+
}
|
|
97
|
+
export { AnimatedLifecycleDirective };
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedLifecycleDirective, decorators: [{
|
|
99
|
+
type: Directive,
|
|
100
|
+
args: [{
|
|
101
|
+
selector: '[etAnimatedLifecycle]',
|
|
102
|
+
exportAs: 'etAnimatedLifecycle',
|
|
103
|
+
standalone: true,
|
|
104
|
+
providers: [
|
|
105
|
+
{
|
|
106
|
+
provide: ANIMATED_LIFECYCLE_TOKEN,
|
|
107
|
+
useExisting: AnimatedLifecycleDirective,
|
|
108
|
+
},
|
|
109
|
+
],
|
|
110
|
+
hostDirectives: [AnimatableDirective],
|
|
111
|
+
}]
|
|
112
|
+
}] });
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-lifecycle.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-lifecycle/animated-lifecycle.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, inject, InjectionToken, isDevMode } from '@angular/core';\nimport { BehaviorSubject, map, switchMap, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, createReactiveBindings, forceReflow, fromNextFrame } from '../../utils';\nimport { ANIMATABLE_TOKEN, AnimatableDirective } from '../animatable';\n\nexport const ANIMATED_LIFECYCLE_TOKEN = new InjectionToken<AnimatedLifecycleDirective>(\n  'ANIMATED_LIFECYCLE_DIRECTIVE_TOKEN',\n);\n\nconst ANIMATION_CLASSES = {\n  enterFrom: 'et-animation-enter-from',\n  enterActive: 'et-animation-enter-active',\n  enterTo: 'et-animation-enter-to',\n  leaveFrom: 'et-animation-leave-from',\n  leaveActive: 'et-animation-leave-active',\n  leaveTo: 'et-animation-leave-to',\n} as const;\n\n@Directive({\n  selector: '[etAnimatedLifecycle]',\n  exportAs: 'etAnimatedLifecycle',\n  standalone: true,\n  providers: [\n    {\n      provide: ANIMATED_LIFECYCLE_TOKEN,\n      useExisting: AnimatedLifecycleDirective,\n    },\n  ],\n  hostDirectives: [AnimatableDirective],\n})\nexport class AnimatedLifecycleDirective {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _animatable = inject(ANIMATABLE_TOKEN);\n  private readonly _classList = this._elementRef.nativeElement.classList;\n\n  private _state$ = new BehaviorSubject<'entering' | 'entered' | 'leaving' | 'left' | 'init'>('init');\n  readonly state$ = this._state$.asObservable();\n\n  get state() {\n    return this._state$.value;\n  }\n\n  private readonly _bindings = createReactiveBindings({\n    attribute: 'class.et-force-invisible',\n    observable: this._state$.pipe(map((state) => state === 'init')),\n  });\n\n  enter(config?: { onlyTransition?: boolean }) {\n    if (this.state !== 'init' && this.state !== 'left' && isDevMode()) {\n      console.warn(\n        'Tried to enter but the element is not in the initial state. This may result in unexpected behavior.',\n        this,\n      );\n    }\n\n    this._state$.next('entering');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.enterFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.enterActive);\n\n    fromNextFrame()\n      .pipe(\n        tap(() => {\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.enterFrom);\n            this._classList.add(ANIMATION_CLASSES.enterTo);\n          }\n        }),\n        switchMap(() => this._animatable.animationEnd$),\n        tap(() => {\n          this._state$.next('entered');\n          this._classList.remove(ANIMATION_CLASSES.enterActive);\n\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.enterTo);\n          }\n        }),\n        takeUntil(this._destroy$),\n        take(1),\n      )\n      .subscribe();\n  }\n\n  leave(config?: { onlyTransition?: boolean }) {\n    if (this.state !== 'entered' && this.state !== 'entering' && isDevMode()) {\n      console.warn('Tried to leave while already leaving or left. This may result in unexpected behavior.', this);\n    }\n\n    if (\n      this._classList.contains(ANIMATION_CLASSES.enterFrom) ||\n      this._classList.contains(ANIMATION_CLASSES.enterActive) ||\n      this._classList.contains(ANIMATION_CLASSES.enterTo)\n    ) {\n      this._classList.remove(ANIMATION_CLASSES.enterFrom);\n      this._classList.remove(ANIMATION_CLASSES.enterActive);\n      this._classList.remove(ANIMATION_CLASSES.enterTo);\n    }\n\n    this._state$.next('leaving');\n\n    if (!config?.onlyTransition) {\n      this._classList.add(ANIMATION_CLASSES.leaveFrom);\n    }\n\n    forceReflow();\n    this._classList.add(ANIMATION_CLASSES.leaveActive);\n\n    fromNextFrame()\n      .pipe(\n        tap(() => {\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.leaveFrom);\n            this._classList.add(ANIMATION_CLASSES.leaveTo);\n          }\n        }),\n        switchMap(() => this._animatable.animationEnd$),\n        tap(() => {\n          this._state$.next('left');\n          this._classList.remove(ANIMATION_CLASSES.leaveActive);\n\n          if (!config?.onlyTransition) {\n            this._classList.remove(ANIMATION_CLASSES.leaveTo);\n          }\n        }),\n        takeUntil(this._destroy$),\n        take(1),\n      )\n      .subscribe();\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2FuaW1hdGVkLWxpZmVjeWNsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
+
import { Directive, ElementRef, Injector, Input, NgZone, ViewContainerRef, inject, } from '@angular/core';
|
|
4
|
+
import { createPopper } from '@popperjs/core';
|
|
5
|
+
import { Subject, filter, take, takeUntil, tap } from 'rxjs';
|
|
6
|
+
import { createDestroy, nextFrame } from '../../utils';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
class AnimatedOverlayDirective {
|
|
9
|
+
constructor() {
|
|
10
|
+
this._destroy$ = createDestroy();
|
|
11
|
+
this._overlayService = inject(Overlay);
|
|
12
|
+
this._injector = inject(Injector);
|
|
13
|
+
this._viewContainerRef = inject(ViewContainerRef);
|
|
14
|
+
this._zone = inject(NgZone);
|
|
15
|
+
this._elementRef = inject(ElementRef);
|
|
16
|
+
this._portal = null;
|
|
17
|
+
this._overlayRef = null;
|
|
18
|
+
this._componentRef = null;
|
|
19
|
+
this._popper = null;
|
|
20
|
+
this._beforeOpened = null;
|
|
21
|
+
this._afterOpened = null;
|
|
22
|
+
this._beforeClosed = null;
|
|
23
|
+
this._afterClosed = null;
|
|
24
|
+
/**
|
|
25
|
+
* The placement of the tooltip.
|
|
26
|
+
* @default 'auto'
|
|
27
|
+
*/
|
|
28
|
+
this.placement = 'auto';
|
|
29
|
+
/**
|
|
30
|
+
* The offset of the tooltip.
|
|
31
|
+
* @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1
|
|
32
|
+
*/
|
|
33
|
+
this.offset = null;
|
|
34
|
+
/**
|
|
35
|
+
* The arrow padding.
|
|
36
|
+
* @see https://popper.js.org/docs/v2/modifiers/arrow/#padding
|
|
37
|
+
* @default 4
|
|
38
|
+
*/
|
|
39
|
+
this.arrowPadding = null;
|
|
40
|
+
}
|
|
41
|
+
get isMounted() {
|
|
42
|
+
return !!this._componentRef;
|
|
43
|
+
}
|
|
44
|
+
get portal() {
|
|
45
|
+
return this._portal;
|
|
46
|
+
}
|
|
47
|
+
get overlayRef() {
|
|
48
|
+
return this._overlayRef;
|
|
49
|
+
}
|
|
50
|
+
get componentRef() {
|
|
51
|
+
return this._componentRef;
|
|
52
|
+
}
|
|
53
|
+
get popper() {
|
|
54
|
+
return this._popper;
|
|
55
|
+
}
|
|
56
|
+
mount(config) {
|
|
57
|
+
const { component, providers, data } = config;
|
|
58
|
+
this._beforeOpened?.next();
|
|
59
|
+
const injector = Injector.create({
|
|
60
|
+
parent: this._injector,
|
|
61
|
+
providers: providers ?? [],
|
|
62
|
+
});
|
|
63
|
+
this._overlayRef = this._overlayService.create();
|
|
64
|
+
this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);
|
|
65
|
+
this._componentRef = this._overlayRef.attach(this._portal);
|
|
66
|
+
if (data) {
|
|
67
|
+
Object.assign(this._componentRef.instance, data);
|
|
68
|
+
}
|
|
69
|
+
this._componentRef.instance._markForCheck?.();
|
|
70
|
+
this._zone.runOutsideAngular(() => {
|
|
71
|
+
if (!this._componentRef) {
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {
|
|
75
|
+
placement: this.placement,
|
|
76
|
+
modifiers: [
|
|
77
|
+
...(this.offset
|
|
78
|
+
? [
|
|
79
|
+
{
|
|
80
|
+
name: 'offset',
|
|
81
|
+
options: {
|
|
82
|
+
offset: this.offset,
|
|
83
|
+
},
|
|
84
|
+
},
|
|
85
|
+
]
|
|
86
|
+
: []),
|
|
87
|
+
...(this.arrowPadding
|
|
88
|
+
? [
|
|
89
|
+
{
|
|
90
|
+
name: 'arrow',
|
|
91
|
+
options: {
|
|
92
|
+
padding: this.arrowPadding,
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
]
|
|
96
|
+
: []),
|
|
97
|
+
],
|
|
98
|
+
});
|
|
99
|
+
// We need to wait for the tooltip content to be rendered
|
|
100
|
+
nextFrame(() => {
|
|
101
|
+
if (!this._componentRef) {
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
this._popper?.update();
|
|
105
|
+
this._componentRef.instance._animatedLifecycle?.enter();
|
|
106
|
+
this._componentRef.instance._animatedLifecycle?.state$
|
|
107
|
+
.pipe(tap((s) => {
|
|
108
|
+
if (s === 'entered') {
|
|
109
|
+
this._afterOpened?.next();
|
|
110
|
+
}
|
|
111
|
+
}), take(1), takeUntil(this._destroy$))
|
|
112
|
+
.subscribe();
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
unmount() {
|
|
117
|
+
if (!this._componentRef) {
|
|
118
|
+
return;
|
|
119
|
+
}
|
|
120
|
+
this._beforeClosed?.next();
|
|
121
|
+
this._componentRef.instance._animatedLifecycle?.leave();
|
|
122
|
+
this._componentRef.instance._animatedLifecycle?.state$
|
|
123
|
+
.pipe(filter((s) => s === 'left'), take(1))
|
|
124
|
+
.subscribe(() => this._destroy());
|
|
125
|
+
}
|
|
126
|
+
beforeOpened() {
|
|
127
|
+
if (!this._beforeOpened) {
|
|
128
|
+
this._beforeOpened = new Subject();
|
|
129
|
+
}
|
|
130
|
+
return this._beforeOpened;
|
|
131
|
+
}
|
|
132
|
+
afterOpened() {
|
|
133
|
+
if (!this._afterOpened) {
|
|
134
|
+
this._afterOpened = new Subject();
|
|
135
|
+
}
|
|
136
|
+
return this._afterOpened;
|
|
137
|
+
}
|
|
138
|
+
beforeClosed() {
|
|
139
|
+
if (!this._beforeClosed) {
|
|
140
|
+
this._beforeClosed = new Subject();
|
|
141
|
+
}
|
|
142
|
+
return this._beforeClosed;
|
|
143
|
+
}
|
|
144
|
+
afterClosed() {
|
|
145
|
+
if (!this._afterClosed) {
|
|
146
|
+
this._afterClosed = new Subject();
|
|
147
|
+
}
|
|
148
|
+
return this._afterClosed;
|
|
149
|
+
}
|
|
150
|
+
_destroy() {
|
|
151
|
+
this._zone.runOutsideAngular(() => {
|
|
152
|
+
this._popper?.destroy();
|
|
153
|
+
this._popper = null;
|
|
154
|
+
});
|
|
155
|
+
if (this._overlayRef) {
|
|
156
|
+
this._overlayRef.dispose();
|
|
157
|
+
this._overlayRef = null;
|
|
158
|
+
}
|
|
159
|
+
if (this._componentRef) {
|
|
160
|
+
this._componentRef.destroy();
|
|
161
|
+
this._componentRef = null;
|
|
162
|
+
}
|
|
163
|
+
this._afterClosed?.next();
|
|
164
|
+
}
|
|
165
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedOverlayDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
166
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: AnimatedOverlayDirective, isStandalone: true, inputs: { placement: "placement", offset: "offset", arrowPadding: "arrowPadding" }, ngImport: i0 }); }
|
|
167
|
+
}
|
|
168
|
+
export { AnimatedOverlayDirective };
|
|
169
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: AnimatedOverlayDirective, decorators: [{
|
|
170
|
+
type: Directive,
|
|
171
|
+
args: [{
|
|
172
|
+
standalone: true,
|
|
173
|
+
}]
|
|
174
|
+
}], propDecorators: { placement: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], offset: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], arrowPadding: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}] } });
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"animated-overlay.directive.js","sourceRoot":"","sources":["../../../../../../../libs/core/src/lib/directives/animated-overlay/animated-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal, ComponentType } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  StaticProvider,\n  ViewContainerRef,\n  inject,\n} from '@angular/core';\nimport { Instance as PopperInstance, Placement as PopperPlacement, createPopper } from '@popperjs/core';\nimport { Options as ArrowOptions } from '@popperjs/core/lib/modifiers/arrow';\nimport { Options as OffsetOptions } from '@popperjs/core/lib/modifiers/offset';\nimport { Subject, filter, take, takeUntil, tap } from 'rxjs';\nimport { createDestroy, nextFrame } from '../../utils';\nimport { AnimatedLifecycleDirective } from '../animated-lifecycle';\n\n@Directive({\n  standalone: true,\n})\nexport class AnimatedOverlayDirective<\n  T extends { _animatedLifecycle?: AnimatedLifecycleDirective; _markForCheck?: () => void },\n> {\n  private readonly _destroy$ = createDestroy();\n  private readonly _overlayService = inject(Overlay);\n  private readonly _injector = inject(Injector);\n  private readonly _viewContainerRef = inject(ViewContainerRef);\n  private readonly _zone = inject(NgZone);\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private _portal: ComponentPortal<T> | null = null;\n  private _overlayRef: OverlayRef | null = null;\n  private _componentRef: ComponentRef<T> | null = null;\n  private _popper: PopperInstance | null = null;\n\n  private _beforeOpened: Subject<void> | null = null;\n  private _afterOpened: Subject<void> | null = null;\n  private _beforeClosed: Subject<void> | null = null;\n  private _afterClosed: Subject<void> | null = null;\n\n  /**\n   * The placement of the tooltip.\n   * @default 'auto'\n   */\n  @Input()\n  placement: PopperPlacement = 'auto';\n\n  /**\n   * The offset of the tooltip.\n   * @see https://popper.js.org/docs/v2/modifiers/offset/#offset-1\n   */\n  @Input()\n  offset: OffsetOptions['offset'] | Readonly<OffsetOptions['offset']> | null = null;\n\n  /**\n   * The arrow padding.\n   * @see https://popper.js.org/docs/v2/modifiers/arrow/#padding\n   * @default 4\n   */\n  @Input()\n  arrowPadding: ArrowOptions['padding'] | null = null;\n\n  get isMounted() {\n    return !!this._componentRef;\n  }\n\n  get portal() {\n    return this._portal;\n  }\n\n  get overlayRef() {\n    return this._overlayRef;\n  }\n\n  get componentRef() {\n    return this._componentRef;\n  }\n\n  get popper() {\n    return this._popper;\n  }\n\n  mount(config: { component: ComponentType<T>; providers?: StaticProvider[]; data?: Partial<T> }) {\n    const { component, providers, data } = config;\n\n    this._beforeOpened?.next();\n\n    const injector = Injector.create({\n      parent: this._injector,\n      providers: providers ?? [],\n    });\n\n    this._overlayRef = this._overlayService.create();\n\n    this._portal = this._portal ?? new ComponentPortal(component, this._viewContainerRef, injector);\n    this._componentRef = this._overlayRef.attach(this._portal);\n\n    if (data) {\n      Object.assign(this._componentRef.instance, data);\n    }\n\n    this._componentRef.instance._markForCheck?.();\n\n    this._zone.runOutsideAngular(() => {\n      if (!this._componentRef) {\n        return;\n      }\n      this._popper = createPopper(this._elementRef.nativeElement, this._componentRef.location.nativeElement, {\n        placement: this.placement,\n        modifiers: [\n          ...(this.offset\n            ? [\n                {\n                  name: 'offset',\n                  options: {\n                    offset: this.offset,\n                  },\n                },\n              ]\n            : []),\n          ...(this.arrowPadding\n            ? [\n                {\n                  name: 'arrow',\n                  options: {\n                    padding: this.arrowPadding,\n                  },\n                },\n              ]\n            : []),\n        ],\n      });\n\n      // We need to wait for the tooltip content to be rendered\n      nextFrame(() => {\n        if (!this._componentRef) {\n          return;\n        }\n\n        this._popper?.update();\n        this._componentRef.instance._animatedLifecycle?.enter();\n\n        this._componentRef.instance._animatedLifecycle?.state$\n          .pipe(\n            tap((s) => {\n              if (s === 'entered') {\n                this._afterOpened?.next();\n              }\n            }),\n            take(1),\n            takeUntil(this._destroy$),\n          )\n          .subscribe();\n      });\n    });\n  }\n\n  unmount() {\n    if (!this._componentRef) {\n      return;\n    }\n\n    this._beforeClosed?.next();\n\n    this._componentRef.instance._animatedLifecycle?.leave();\n\n    this._componentRef.instance._animatedLifecycle?.state$\n      .pipe(\n        filter((s) => s === 'left'),\n        take(1),\n      )\n      .subscribe(() => this._destroy());\n  }\n\n  beforeOpened() {\n    if (!this._beforeOpened) {\n      this._beforeOpened = new Subject();\n    }\n\n    return this._beforeOpened;\n  }\n\n  afterOpened() {\n    if (!this._afterOpened) {\n      this._afterOpened = new Subject();\n    }\n\n    return this._afterOpened;\n  }\n\n  beforeClosed() {\n    if (!this._beforeClosed) {\n      this._beforeClosed = new Subject();\n    }\n\n    return this._beforeClosed;\n  }\n\n  afterClosed() {\n    if (!this._afterClosed) {\n      this._afterClosed = new Subject();\n    }\n\n    return this._afterClosed;\n  }\n\n  _destroy() {\n    this._zone.runOutsideAngular(() => {\n      this._popper?.destroy();\n      this._popper = null;\n    });\n\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    if (this._componentRef) {\n      this._componentRef.destroy();\n      this._componentRef = null;\n    }\n\n    this._afterClosed?.next();\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './animated-overlay.directive';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2RpcmVjdGl2ZXMvYW5pbWF0ZWQtb3ZlcmxheS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FuaW1hdGVkLW92ZXJsYXkuZGlyZWN0aXZlJztcbiJdfQ==
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, inject, Output } from '@angular/core';
|
|
2
|
+
import { ClickObserverService } from '../../services';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
class ClickOutsideDirective {
|
|
5
|
+
constructor() {
|
|
6
|
+
this._elementRef = inject(ElementRef);
|
|
7
|
+
this._clickObserverService = inject(ClickObserverService);
|
|
8
|
+
this._subscription = null;
|
|
9
|
+
this.etClickOutside = new EventEmitter();
|
|
10
|
+
}
|
|
11
|
+
ngOnInit() {
|
|
12
|
+
setTimeout(() => {
|
|
13
|
+
this._subscription = this._clickObserverService.observe(this._elementRef.nativeElement).subscribe((event) => {
|
|
14
|
+
const activeElement = event.target;
|
|
15
|
+
const isInside = this._elementRef.nativeElement.contains(activeElement);
|
|
16
|
+
if (!isInside) {
|
|
17
|
+
this.etClickOutside.emit(event);
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
ngOnDestroy() {
|
|
23
|
+
this._subscription?.unsubscribe();
|
|
24
|
+
}
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ClickOutsideDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
26
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0", type: ClickOutsideDirective, isStandalone: true, selector: "[etClickOutside]", outputs: { etClickOutside: "etClickOutside" }, ngImport: i0 }); }
|
|
27
|
+
}
|
|
28
|
+
export { ClickOutsideDirective };
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: ClickOutsideDirective, decorators: [{
|
|
30
|
+
type: Directive,
|
|
31
|
+
args: [{
|
|
32
|
+
selector: '[etClickOutside]',
|
|
33
|
+
standalone: true,
|
|
34
|
+
}]
|
|
35
|
+
}], propDecorators: { etClickOutside: [{
|
|
36
|
+
type: Output
|
|
37
|
+
}] } });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvcmUvc3JjL2xpYi9kaXJlY3RpdmVzL2NsaWNrLW91dHNpZGUvY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBcUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQUV0RCxNQUlhLHFCQUFxQjtJQUpsQztRQUtVLGdCQUFXLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2pDLDBCQUFxQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1FBRXJELGtCQUFhLEdBQXdCLElBQUksQ0FBQztRQUdsRCxtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7S0FrQmpEO0lBaEJDLFFBQVE7UUFDTixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQzFHLE1BQU0sYUFBYSxHQUFHLEtBQUssQ0FBQyxNQUFxQixDQUFDO2dCQUNsRCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUM7Z0JBRXhFLElBQUksQ0FBQyxRQUFRLEVBQUU7b0JBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7aUJBQ2pDO1lBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGFBQWEsRUFBRSxXQUFXLEVBQUUsQ0FBQztJQUNwQyxDQUFDOzhHQXhCVSxxQkFBcUI7a0dBQXJCLHFCQUFxQjs7U0FBckIscUJBQXFCOzJGQUFyQixxQkFBcUI7a0JBSmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQVFDLGNBQWM7c0JBRGIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBpbmplY3QsIE9uRGVzdHJveSwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ2xpY2tPYnNlcnZlclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tldENsaWNrT3V0c2lkZV0nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBDbGlja091dHNpZGVEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIHByaXZhdGUgX2VsZW1lbnRSZWYgPSBpbmplY3QoRWxlbWVudFJlZik7XG4gIHByaXZhdGUgX2NsaWNrT2JzZXJ2ZXJTZXJ2aWNlID0gaW5qZWN0KENsaWNrT2JzZXJ2ZXJTZXJ2aWNlKTtcblxuICBwcml2YXRlIF9zdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbiB8IG51bGwgPSBudWxsO1xuXG4gIEBPdXRwdXQoKVxuICBldENsaWNrT3V0c2lkZSA9IG5ldyBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4oKTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHRoaXMuX3N1YnNjcmlwdGlvbiA9IHRoaXMuX2NsaWNrT2JzZXJ2ZXJTZXJ2aWNlLm9ic2VydmUodGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50KS5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IGFjdGl2ZUVsZW1lbnQgPSBldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XG4gICAgICAgIGNvbnN0IGlzSW5zaWRlID0gdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKGFjdGl2ZUVsZW1lbnQpO1xuXG4gICAgICAgIGlmICghaXNJbnNpZGUpIHtcbiAgICAgICAgICB0aGlzLmV0Q2xpY2tPdXRzaWRlLmVtaXQoZXZlbnQpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIHRoaXMuX3N1YnNjcmlwdGlvbj8udW5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
|