@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.
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9kZWNvcmF0b3JzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3R5cGVzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9wdWJsaWMtYXBpJztcbiJdfQ==
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9jb25zdGFudHMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RlY29yYXRvcnMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3B1YmxpYy1hcGknO1xuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9wdWJsaWMtYXBpJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMvcHVibGljLWFwaSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL3B1YmxpYy1hcGknO1xuIl19
@@ -1,2 +1,16 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3R5cGVzL2FuZ3VsYXIudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE5nQ2xhc3NUeXBlID1cbiAgfCBzdHJpbmdcbiAgfCBzdHJpbmdbXVxuICB8IFNldDxzdHJpbmc+XG4gIHwge1xuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICAgIFtrbGFzczogc3RyaW5nXTogYW55O1xuICAgIH1cbiAgfCBudWxsXG4gIHwgdW5kZWZpbmVkO1xuIl19
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29yZS9zcmMvbGliL3V0aWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi92aWV3cG9ydC51dGlsJztcbmV4cG9ydCAqIGZyb20gJy4vY2xhbXAudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL3Njcm9sbGFibGUudXRpbHMnO1xuIl19
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, inject, Inject, Optional, ElementRef, EventEmitter, Directive, Output, Input, NgZone, HostBinding, Pipe } from '@angular/core';
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, takeUntil, take } from 'rxjs';
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
- import { Meta, Title } from '@angular/platform-browser';
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