@ethlete/core 0.2.0-next.10 → 0.2.0-next.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/public-api.mjs +2 -0
- package/esm2020/lib/components/structured-data/public-api.mjs +2 -0
- package/esm2020/lib/components/structured-data/structured-data.component.mjs +37 -0
- package/esm2020/lib/public-api.mjs +2 -1
- package/esm2020/lib/types/angular.types.mjs +16 -2
- package/esm2020/lib/utils/public-api.mjs +3 -2
- package/esm2020/lib/utils/reactive-binding.util.mjs +102 -0
- package/fesm2015/ethlete-core.mjs +156 -8
- package/fesm2015/ethlete-core.mjs.map +1 -1
- package/fesm2020/ethlete-core.mjs +156 -8
- package/fesm2020/ethlete-core.mjs.map +1 -1
- package/lib/components/public-api.d.ts +1 -0
- package/lib/components/structured-data/public-api.d.ts +1 -0
- package/lib/components/structured-data/structured-data.component.d.ts +11 -0
- package/lib/public-api.d.ts +1 -0
- package/lib/types/angular.types.d.ts +7 -0
- package/lib/utils/public-api.d.ts +2 -1
- package/lib/utils/reactive-binding.util.d.ts +19 -0
- package/package.json +4 -4
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './structured-data/public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhCQUE4QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zdHJ1Y3R1cmVkLWRhdGEvcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './structured-data.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RydWN0dXJlZC1kYXRhL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3RydWN0dXJlZC1kYXRhLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,37 @@
|
|
|
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
|
+
export 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
|
+
}
|
|
17
|
+
StructuredDataComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
StructuredDataComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.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 });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: StructuredDataComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{
|
|
22
|
+
selector: 'et-structured-data',
|
|
23
|
+
standalone: true,
|
|
24
|
+
template: '',
|
|
25
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
26
|
+
encapsulation: ViewEncapsulation.None,
|
|
27
|
+
host: {
|
|
28
|
+
style: 'display: none',
|
|
29
|
+
},
|
|
30
|
+
}]
|
|
31
|
+
}], propDecorators: { data: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], jsonLD: [{
|
|
34
|
+
type: HostBinding,
|
|
35
|
+
args: ['innerHTML']
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RydWN0dXJlZC1kYXRhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL2NvbXBvbmVudHMvc3RydWN0dXJlZC1kYXRhL3N0cnVjdHVyZWQtZGF0YS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUM7O0FBYW5FLE1BQU0sT0FBTyx1QkFBdUI7SUFWcEM7UUFXbUIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztLQWVwRDtJQWJDLElBQ0ksSUFBSSxDQUFDLFlBQWdGO1FBQ3ZGLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBS0QsV0FBVyxDQUFDLEtBQXlFO1FBQ25GLE1BQU0sSUFBSSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUMvRixNQUFNLElBQUksR0FBRyxzQ0FBc0MsSUFBSSxXQUFXLENBQUM7UUFDbkUsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3ZELENBQUM7O29IQWZVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLCtMQVB4QixFQUFFOzJGQU9ELHVCQUF1QjtrQkFWbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0JBQW9CO29CQUM5QixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxJQUFJLEVBQUU7d0JBQ0osS0FBSyxFQUFFLGVBQWU7cUJBQ3ZCO2lCQUNGOzhCQUtLLElBQUk7c0JBRFAsS0FBSztnQkFNTixNQUFNO3NCQURMLFdBQVc7dUJBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBpbmplY3QsIElucHV0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyLCBTYWZlSHRtbCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgSnNvbkxEIH0gZnJvbSAnQGV0aGxldGUvdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdldC1zdHJ1Y3R1cmVkLWRhdGEnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICB0ZW1wbGF0ZTogJycsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBob3N0OiB7XG4gICAgc3R5bGU6ICdkaXNwbGF5OiBub25lJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgU3RydWN0dXJlZERhdGFDb21wb25lbnQge1xuICBwcml2YXRlIHJlYWRvbmx5IF9zYW5pdGl6ZXIgPSBpbmplY3QoRG9tU2FuaXRpemVyKTtcblxuICBASW5wdXQoKVxuICBzZXQgZGF0YShjdXJyZW50VmFsdWU6IEpzb25MRC5XaXRoQ29udGV4dDxKc29uTEQuVGhpbmc+IHwgSnNvbkxELkdyYXBoIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xuICAgIHRoaXMuanNvbkxEID0gdGhpcy5nZXRTYWZlSFRNTChjdXJyZW50VmFsdWUpO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKCdpbm5lckhUTUwnKVxuICBqc29uTEQ/OiBTYWZlSHRtbDtcblxuICBnZXRTYWZlSFRNTCh2YWx1ZTogSnNvbkxELldpdGhDb250ZXh0PEpzb25MRC5UaGluZz4gfCBKc29uTEQuR3JhcGggfCBudWxsIHwgdW5kZWZpbmVkKSB7XG4gICAgY29uc3QganNvbiA9IHZhbHVlID8gSlNPTi5zdHJpbmdpZnkodmFsdWUsIG51bGwsIDIpLnJlcGxhY2UoLzxcXC9zY3JpcHQ+L2csICc8XFxcXC9zY3JpcHQ+JykgOiAnJztcbiAgICBjb25zdCBodG1sID0gYDxzY3JpcHQgdHlwZT1cImFwcGxpY2F0aW9uL2xkK2pzb25cIj4ke2pzb259PC9zY3JpcHQ+YDtcbiAgICByZXR1cm4gdGhpcy5fc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RIdG1sKGh0bWwpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
export * from './components/public-api';
|
|
1
2
|
export * from './constants/public-api';
|
|
2
3
|
export * from './decorators/public-api';
|
|
3
4
|
export * from './directives/public-api';
|
|
@@ -5,4 +6,4 @@ export * from './pipes/public-api';
|
|
|
5
6
|
export * from './services/public-api';
|
|
6
7
|
export * from './types/public-api';
|
|
7
8
|
export * from './utils/public-api';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9jb25zdGFudHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RlY29yYXRvcnMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL3B1YmxpYy1hcGknO1xuIl19
|
|
@@ -1,2 +1,16 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { QueryList } from '@angular/core';
|
|
2
|
+
export class TypedQueryList extends QueryList {
|
|
3
|
+
constructor() {
|
|
4
|
+
super(...arguments);
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
6
|
+
// @ts-ignore
|
|
7
|
+
this.first = super.first;
|
|
8
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
9
|
+
// @ts-ignore
|
|
10
|
+
this.last = super.last;
|
|
11
|
+
}
|
|
12
|
+
get changes() {
|
|
13
|
+
return super.changes;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3R5cGVzL2FuZ3VsYXIudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQWMxQyxNQUFNLE9BQU8sY0FBa0IsU0FBUSxTQUFZO0lBQW5EOztRQUtFLDZEQUE2RDtRQUM3RCxhQUFhO1FBQ0ssVUFBSyxHQUFHLEtBQUssQ0FBQyxLQUFzQixDQUFDO1FBRXZELDZEQUE2RDtRQUM3RCxhQUFhO1FBQ0ssU0FBSSxHQUFHLEtBQUssQ0FBQyxJQUFxQixDQUFDO0lBQ3ZELENBQUM7SUFYQyxJQUFhLE9BQU87UUFDbEIsT0FBTyxLQUFLLENBQUMsT0FBd0MsQ0FBQztJQUN4RCxDQUFDO0NBU0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IHR5cGUgTmdDbGFzc1R5cGUgPVxuICB8IHN0cmluZ1xuICB8IHN0cmluZ1tdXG4gIHwgU2V0PHN0cmluZz5cbiAgfCB7XG4gICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICAgICAgW2tsYXNzOiBzdHJpbmddOiBhbnk7XG4gICAgfVxuICB8IG51bGxcbiAgfCB1bmRlZmluZWQ7XG5cbmV4cG9ydCBjbGFzcyBUeXBlZFF1ZXJ5TGlzdDxUPiBleHRlbmRzIFF1ZXJ5TGlzdDxUPiB7XG4gIG92ZXJyaWRlIGdldCBjaGFuZ2VzKCk6IE9ic2VydmFibGU8VHlwZWRRdWVyeUxpc3Q8VD4+IHtcbiAgICByZXR1cm4gc3VwZXIuY2hhbmdlcyBhcyBPYnNlcnZhYmxlPFR5cGVkUXVlcnlMaXN0PFQ+PjtcbiAgfVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXRzLWNvbW1lbnRcbiAgLy8gQHRzLWlnbm9yZVxuICBvdmVycmlkZSByZWFkb25seSBmaXJzdCA9IHN1cGVyLmZpcnN0IGFzIFQgfCB1bmRlZmluZWQ7XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHMtY29tbWVudFxuICAvLyBAdHMtaWdub3JlXG4gIG92ZXJyaWRlIHJlYWRvbmx5IGxhc3QgPSBzdXBlci5sYXN0IGFzIFQgfCB1bmRlZmluZWQ7XG59XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export * from './viewport.util';
|
|
2
1
|
export * from './clamp.util';
|
|
2
|
+
export * from './reactive-binding.util';
|
|
3
3
|
export * from './scrollable.utils';
|
|
4
|
-
|
|
4
|
+
export * from './viewport.util';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NsYW1wLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWFjdGl2ZS1iaW5kaW5nLnV0aWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zY3JvbGxhYmxlLnV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vdmlld3BvcnQudXRpbCc7XG4iXX0=
|
|
@@ -0,0 +1,102 @@
|
|
|
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).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 (!render) {
|
|
41
|
+
elRef.nativeElement.classList.remove(className);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
elRef.nativeElement.classList.add(className);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else if (isMultipleClassMutation) {
|
|
48
|
+
const classes = isAttributeRenderBinding(value) ? '' : `${value.value}`;
|
|
49
|
+
if (!render) {
|
|
50
|
+
elRef.nativeElement.classList.remove(...classes.split(' '));
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
elRef.nativeElement.classList.add(...classes.split(' '));
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
const attributeValue = isAttributeRenderBinding(value) ? true : `${value.value}`;
|
|
58
|
+
if (!render) {
|
|
59
|
+
elRef.nativeElement.removeAttribute(attribute);
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
elRef.nativeElement.setAttribute(attribute, `${attributeValue}`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
subscriptions.push({ attributes, subscription });
|
|
68
|
+
};
|
|
69
|
+
const remove = (...attributes) => {
|
|
70
|
+
for (const attribute of attributes) {
|
|
71
|
+
const sub = subscriptions.find((s) => s.attributes.includes(attribute));
|
|
72
|
+
const attributeStack = pushedAttributes.find((a) => a.includes(attribute));
|
|
73
|
+
if (sub) {
|
|
74
|
+
sub.attributes = sub.attributes.filter((a) => a !== attribute);
|
|
75
|
+
attributeStack?.splice(attributeStack.indexOf(attribute), 1);
|
|
76
|
+
if (sub.attributes.length === 0) {
|
|
77
|
+
sub.subscription.unsubscribe();
|
|
78
|
+
subscriptions.splice(subscriptions.indexOf(sub), 1);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
const reset = () => {
|
|
84
|
+
for (const attribute in defaults) {
|
|
85
|
+
if (defaults[attribute] === undefined) {
|
|
86
|
+
rootElementRef.nativeElement.removeAttribute(attribute);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
rootElementRef.nativeElement.setAttribute(attribute, defaults[attribute]);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
for (const value of values) {
|
|
94
|
+
push(value);
|
|
95
|
+
}
|
|
96
|
+
return {
|
|
97
|
+
push,
|
|
98
|
+
remove,
|
|
99
|
+
reset,
|
|
100
|
+
};
|
|
101
|
+
};
|
|
102
|
+
//# 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>(DestroyService).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 (!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 (!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 (!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,12 +1,46 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { InjectionToken, Injectable,
|
|
2
|
+
import { inject, Component, ChangeDetectionStrategy, ViewEncapsulation, Input, HostBinding, InjectionToken, Injectable, Inject, Optional, ElementRef, EventEmitter, Directive, Output, NgZone, Pipe, QueryList } from '@angular/core';
|
|
3
|
+
import { DomSanitizer, Meta, Title } from '@angular/platform-browser';
|
|
3
4
|
import { coerceElement, coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
|
|
4
|
-
import { fromEvent, Observable, Subject, BehaviorSubject, combineLatest, map, shareReplay, startWith, debounceTime, tap,
|
|
5
|
+
import { fromEvent, Observable, Subject, BehaviorSubject, combineLatest, map, shareReplay, takeUntil, distinctUntilChanged, startWith, debounceTime, tap, take } from 'rxjs';
|
|
5
6
|
import { DOCUMENT } from '@angular/common';
|
|
6
7
|
import { __decorate, __metadata } from 'tslib';
|
|
7
8
|
import * as i1 from '@angular/cdk/layout';
|
|
8
9
|
import { debounceTime as debounceTime$1 } from 'rxjs/operators';
|
|
9
|
-
|
|
10
|
+
|
|
11
|
+
class StructuredDataComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
this._sanitizer = inject(DomSanitizer);
|
|
14
|
+
}
|
|
15
|
+
set data(currentValue) {
|
|
16
|
+
this.jsonLD = this.getSafeHTML(currentValue);
|
|
17
|
+
}
|
|
18
|
+
getSafeHTML(value) {
|
|
19
|
+
const json = value ? JSON.stringify(value, null, 2).replace(/<\/script>/g, '<\\/script>') : '';
|
|
20
|
+
const html = `<script type="application/ld+json">${json}</script>`;
|
|
21
|
+
return this._sanitizer.bypassSecurityTrustHtml(html);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
StructuredDataComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: StructuredDataComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
+
StructuredDataComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.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 });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: StructuredDataComponent, decorators: [{
|
|
27
|
+
type: Component,
|
|
28
|
+
args: [{
|
|
29
|
+
selector: 'et-structured-data',
|
|
30
|
+
standalone: true,
|
|
31
|
+
template: '',
|
|
32
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
33
|
+
encapsulation: ViewEncapsulation.None,
|
|
34
|
+
host: {
|
|
35
|
+
style: 'display: none',
|
|
36
|
+
},
|
|
37
|
+
}]
|
|
38
|
+
}], propDecorators: { data: [{
|
|
39
|
+
type: Input
|
|
40
|
+
}], jsonLD: [{
|
|
41
|
+
type: HostBinding,
|
|
42
|
+
args: ['innerHTML']
|
|
43
|
+
}] } });
|
|
10
44
|
|
|
11
45
|
const VIEWPORT_CONFIG = new InjectionToken('ViewportConfig');
|
|
12
46
|
/**
|
|
@@ -511,19 +545,118 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
511
545
|
type: Output
|
|
512
546
|
}] } });
|
|
513
547
|
|
|
514
|
-
const provideViewportConfig = (viewportConfig) => {
|
|
515
|
-
return { provide: VIEWPORT_CONFIG, useValue: viewportConfig };
|
|
516
|
-
};
|
|
517
|
-
|
|
518
548
|
const clamp = (value, min = 0, max = 100) => {
|
|
519
549
|
return Math.max(min, Math.min(max, value));
|
|
520
550
|
};
|
|
521
551
|
|
|
552
|
+
const isAttributeRenderBinding = (value) => typeof value === 'boolean';
|
|
553
|
+
const isAttributeValueBinding = (value) => typeof value === 'object';
|
|
554
|
+
const createReactiveBindings = (...values) => {
|
|
555
|
+
const rootElementRef = inject(ElementRef);
|
|
556
|
+
const destroy$ = inject(DestroyService).destroy$;
|
|
557
|
+
const subscriptions = [];
|
|
558
|
+
const pushedAttributes = [];
|
|
559
|
+
const defaults = {};
|
|
560
|
+
const push = (value) => {
|
|
561
|
+
const { attribute, observable, elementRef } = value;
|
|
562
|
+
const elRef = elementRef || rootElementRef;
|
|
563
|
+
const attributes = Array.isArray(attribute) ? attribute : [attribute];
|
|
564
|
+
pushedAttributes.push(attributes);
|
|
565
|
+
for (const attribute of attributes) {
|
|
566
|
+
if (!defaults[attribute]) {
|
|
567
|
+
defaults[attribute] = elRef.nativeElement.getAttribute(attribute) || undefined;
|
|
568
|
+
}
|
|
569
|
+
}
|
|
570
|
+
const subscription = observable
|
|
571
|
+
.pipe(takeUntil(destroy$), distinctUntilChanged((a, b) => {
|
|
572
|
+
if (isAttributeRenderBinding(a) && isAttributeRenderBinding(b)) {
|
|
573
|
+
return a === b;
|
|
574
|
+
}
|
|
575
|
+
else if (isAttributeValueBinding(a) && isAttributeValueBinding(b)) {
|
|
576
|
+
return a.render === b.render && a.value === b.value;
|
|
577
|
+
}
|
|
578
|
+
return false;
|
|
579
|
+
}))
|
|
580
|
+
.subscribe((value) => {
|
|
581
|
+
const currentAttributes = pushedAttributes.find((s) => s.some((current) => attributes.includes(current))) || [];
|
|
582
|
+
for (const attribute of currentAttributes) {
|
|
583
|
+
const isSingleClassMutation = attribute.startsWith('class.');
|
|
584
|
+
const isMultipleClassMutation = attribute === 'class';
|
|
585
|
+
const render = isAttributeRenderBinding(value) ? value : value.render;
|
|
586
|
+
if (isSingleClassMutation) {
|
|
587
|
+
const className = attribute.replace('class.', '');
|
|
588
|
+
if (!render) {
|
|
589
|
+
elRef.nativeElement.classList.remove(className);
|
|
590
|
+
}
|
|
591
|
+
else {
|
|
592
|
+
elRef.nativeElement.classList.add(className);
|
|
593
|
+
}
|
|
594
|
+
}
|
|
595
|
+
else if (isMultipleClassMutation) {
|
|
596
|
+
const classes = isAttributeRenderBinding(value) ? '' : `${value.value}`;
|
|
597
|
+
if (!render) {
|
|
598
|
+
elRef.nativeElement.classList.remove(...classes.split(' '));
|
|
599
|
+
}
|
|
600
|
+
else {
|
|
601
|
+
elRef.nativeElement.classList.add(...classes.split(' '));
|
|
602
|
+
}
|
|
603
|
+
}
|
|
604
|
+
else {
|
|
605
|
+
const attributeValue = isAttributeRenderBinding(value) ? true : `${value.value}`;
|
|
606
|
+
if (!render) {
|
|
607
|
+
elRef.nativeElement.removeAttribute(attribute);
|
|
608
|
+
}
|
|
609
|
+
else {
|
|
610
|
+
elRef.nativeElement.setAttribute(attribute, `${attributeValue}`);
|
|
611
|
+
}
|
|
612
|
+
}
|
|
613
|
+
}
|
|
614
|
+
});
|
|
615
|
+
subscriptions.push({ attributes, subscription });
|
|
616
|
+
};
|
|
617
|
+
const remove = (...attributes) => {
|
|
618
|
+
for (const attribute of attributes) {
|
|
619
|
+
const sub = subscriptions.find((s) => s.attributes.includes(attribute));
|
|
620
|
+
const attributeStack = pushedAttributes.find((a) => a.includes(attribute));
|
|
621
|
+
if (sub) {
|
|
622
|
+
sub.attributes = sub.attributes.filter((a) => a !== attribute);
|
|
623
|
+
attributeStack === null || attributeStack === void 0 ? void 0 : attributeStack.splice(attributeStack.indexOf(attribute), 1);
|
|
624
|
+
if (sub.attributes.length === 0) {
|
|
625
|
+
sub.subscription.unsubscribe();
|
|
626
|
+
subscriptions.splice(subscriptions.indexOf(sub), 1);
|
|
627
|
+
}
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
};
|
|
631
|
+
const reset = () => {
|
|
632
|
+
for (const attribute in defaults) {
|
|
633
|
+
if (defaults[attribute] === undefined) {
|
|
634
|
+
rootElementRef.nativeElement.removeAttribute(attribute);
|
|
635
|
+
}
|
|
636
|
+
else {
|
|
637
|
+
rootElementRef.nativeElement.setAttribute(attribute, defaults[attribute]);
|
|
638
|
+
}
|
|
639
|
+
}
|
|
640
|
+
};
|
|
641
|
+
for (const value of values) {
|
|
642
|
+
push(value);
|
|
643
|
+
}
|
|
644
|
+
return {
|
|
645
|
+
push,
|
|
646
|
+
remove,
|
|
647
|
+
reset,
|
|
648
|
+
};
|
|
649
|
+
};
|
|
650
|
+
|
|
522
651
|
const elementCanScroll = (element) => {
|
|
523
652
|
const { scrollHeight, clientHeight, scrollWidth, clientWidth } = element;
|
|
524
653
|
return scrollHeight > clientHeight || scrollWidth > clientWidth;
|
|
525
654
|
};
|
|
526
655
|
|
|
656
|
+
const provideViewportConfig = (viewportConfig) => {
|
|
657
|
+
return { provide: VIEWPORT_CONFIG, useValue: viewportConfig };
|
|
658
|
+
};
|
|
659
|
+
|
|
527
660
|
const CURSOR_DRAG_SCROLLING_CLASS = 'et-cursor-drag-scroll--scrolling';
|
|
528
661
|
const CURSOR_DRAG_SCROLLING_PREPARED_CLASS = 'et-cursor-drag-scroll--prepared';
|
|
529
662
|
|
|
@@ -1620,9 +1753,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1620
1753
|
args: [{ name: 'toArray', standalone: true }]
|
|
1621
1754
|
}] });
|
|
1622
1755
|
|
|
1756
|
+
class TypedQueryList extends QueryList {
|
|
1757
|
+
constructor() {
|
|
1758
|
+
super(...arguments);
|
|
1759
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
1760
|
+
// @ts-ignore
|
|
1761
|
+
this.first = super.first;
|
|
1762
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
1763
|
+
// @ts-ignore
|
|
1764
|
+
this.last = super.last;
|
|
1765
|
+
}
|
|
1766
|
+
get changes() {
|
|
1767
|
+
return super.changes;
|
|
1768
|
+
}
|
|
1769
|
+
}
|
|
1770
|
+
|
|
1623
1771
|
/**
|
|
1624
1772
|
* Generated bundle index. Do not edit.
|
|
1625
1773
|
*/
|
|
1626
1774
|
|
|
1627
|
-
export { ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, LetContext, LetDirective, Memo, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, ToArrayPipe, VIEWPORT_CONFIG, ViewportService, clamp, elementCanScroll, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, isGroupMatch, isKnockoutMatch, mergeSeoConfig, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, toArray, toArrayTrackByFn };
|
|
1775
|
+
export { ClickObserverFactory, ClickObserverService, ClickOutsideDirective, ContentObserverService, CursorDragScrollDirective, DEFAULT_VIEWPORT_CONFIG, DestroyService, FocusVisibleService, LetContext, LetDirective, Memo, MutationObserverFactory, NormalizeGameResultTypePipe, NormalizeMatchParticipantsPipe, NormalizeMatchScorePipe, NormalizeMatchStatePipe, NormalizeMatchTypePipe, OBSERVE_SCROLL_STATE, ObserveContentDirective, ObserveResizeDirective, ObserveScrollStateDirective, RepeatDirective, ResizeObserverFactory, ResizeObserverService, SCROLL_OBSERVER_FIRST_ELEMENT_CLASS, SCROLL_OBSERVER_IGNORE_TARGET_CLASS, SCROLL_OBSERVER_LAST_ELEMENT_CLASS, SEO_DIRECTIVE_TOKEN, ScrollObserverFirstElementDirective, ScrollObserverIgnoreTargetDirective, ScrollObserverLastElementDirective, SeoDirective, StructuredDataComponent, ToArrayPipe, TypedQueryList, VIEWPORT_CONFIG, ViewportService, clamp, createReactiveBindings, elementCanScroll, getGroupMatchPoints, getGroupMatchScore, getKnockoutMatchScore, getMatchScoreSubLine, isGroupMatch, isKnockoutMatch, mergeSeoConfig, normalizeGameResultType, normalizeMatchParticipant, normalizeMatchParticipants, normalizeMatchScore, normalizeMatchState, normalizeMatchType, provideViewportConfig, toArray, toArrayTrackByFn };
|
|
1628
1776
|
//# sourceMappingURL=ethlete-core.mjs.map
|