@ethlete/cdk 3.18.3 → 3.19.1

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.
Files changed (62) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/esm2022/lib/components/button/directives/button/button.directive.mjs +10 -25
  3. package/esm2022/lib/components/button/directives/query-button/query-button.directive.mjs +8 -17
  4. package/esm2022/lib/components/filter/rich-filter/components/rich-filter-host/rich-filter-host.component.mjs +5 -4
  5. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.mjs +7 -11
  6. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.mjs +17 -14
  7. package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.mjs +6 -13
  8. package/esm2022/lib/components/forms/components/error/components/error/error.component.mjs +7 -9
  9. package/esm2022/lib/components/forms/components/radio/directives/radio/radio.directive.mjs +6 -8
  10. package/esm2022/lib/components/forms/components/radio/directives/radio-field/radio-field.directive.mjs +14 -18
  11. package/esm2022/lib/components/forms/components/radio/directives/radio-group/radio-group.directive.mjs +5 -11
  12. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.mjs +6 -8
  13. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-field/segmented-button-field.directive.mjs +14 -18
  14. package/esm2022/lib/components/forms/components/segmented-button/directives/segmented-button-group/segmented-button-group.directive.mjs +6 -11
  15. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +14 -25
  16. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +13 -23
  17. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +11 -23
  18. package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +26 -22
  19. package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +7 -15
  20. package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +13 -14
  21. package/esm2022/lib/components/forms/components/select/directives/select-field/select-field.directive.mjs +3 -4
  22. package/esm2022/lib/components/forms/components/slide-toggle/directives/slide-toggle/slide-toggle.directive.mjs +6 -8
  23. package/esm2022/lib/components/forms/components/slider/components/slider/slider.component.mjs +18 -41
  24. package/esm2022/lib/components/forms/directives/input/input.directive.mjs +4 -1
  25. package/esm2022/lib/components/forms/directives/writeable-input/writeable-input.directive.mjs +10 -23
  26. package/esm2022/lib/components/forms/services/input-state.service.mjs +21 -4
  27. package/esm2022/lib/components/forms/utils/decorated-form-field.base.mjs +5 -8
  28. package/esm2022/lib/components/forms/utils/decorated-input.base.mjs +26 -23
  29. package/esm2022/lib/components/masonry/components/masonry/masonry.component.mjs +6 -8
  30. package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +4 -2
  31. package/fesm2022/ethlete-cdk.mjs +213 -346
  32. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  33. package/lib/components/button/directives/button/button.directive.d.ts +4 -1
  34. package/lib/components/button/directives/query-button/query-button.directive.d.ts +4 -1
  35. package/lib/components/filter/rich-filter/components/rich-filter-host/rich-filter-host.component.d.ts +1 -0
  36. package/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.d.ts +4 -1
  37. package/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.d.ts +11 -6
  38. package/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.d.ts +6 -4
  39. package/lib/components/forms/components/error/components/error/error.component.d.ts +4 -1
  40. package/lib/components/forms/components/radio/directives/radio/radio.directive.d.ts +4 -1
  41. package/lib/components/forms/components/radio/directives/radio-field/radio-field.directive.d.ts +12 -6
  42. package/lib/components/forms/components/radio/directives/radio-group/radio-group.directive.d.ts +4 -1
  43. package/lib/components/forms/components/segmented-button/directives/segmented-button/segmented-button.directive.d.ts +4 -1
  44. package/lib/components/forms/components/segmented-button/directives/segmented-button-field/segmented-button-field.directive.d.ts +12 -7
  45. package/lib/components/forms/components/segmented-button/directives/segmented-button-group/segmented-button-group.directive.d.ts +4 -1
  46. package/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.d.ts +9 -1
  47. package/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.d.ts +8 -1
  48. package/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.d.ts +8 -1
  49. package/lib/components/forms/components/select/components/select/directives/select/select.directive.d.ts +14 -3
  50. package/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.d.ts +4 -1
  51. package/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.d.ts +10 -1
  52. package/lib/components/forms/components/select/directives/select-field/select-field.directive.d.ts +2 -2
  53. package/lib/components/forms/components/slide-toggle/directives/slide-toggle/slide-toggle.directive.d.ts +4 -1
  54. package/lib/components/forms/components/slider/components/slider/slider.component.d.ts +8 -1
  55. package/lib/components/forms/directives/input/input.directive.d.ts +21 -19
  56. package/lib/components/forms/directives/writeable-input/writeable-input.directive.d.ts +4 -1
  57. package/lib/components/forms/services/input-state.service.d.ts +13 -6
  58. package/lib/components/forms/utils/decorated-form-field.base.d.ts +4 -1
  59. package/lib/components/forms/utils/decorated-input.base.d.ts +13 -6
  60. package/lib/components/masonry/components/masonry/masonry.component.d.ts +4 -1
  61. package/lib/components/pagination/components/pagination/pagination.component.d.ts +2 -2
  62. package/package.json +2 -2
@@ -1,6 +1,6 @@
1
1
  import { Injectable } from '@angular/core';
2
2
  import { toSignal } from '@angular/core/rxjs-interop';
3
- import { BehaviorSubject, combineLatest, filter, map, Subject } from 'rxjs';
3
+ import { BehaviorSubject, combineLatest, filter, map, Observable, of, Subject, switchMap } from 'rxjs';
4
4
  import * as i0 from "@angular/core";
5
5
  export class InputStateService {
6
6
  constructor() {
@@ -27,8 +27,25 @@ export class InputStateService {
27
27
  this.valueIsTruthy = toSignal(this.valueIsTruthy$, { requireSync: true });
28
28
  this.valueIsFalsy$ = this.value$.pipe(map((value) => !value));
29
29
  this.valueIsFalsy = toSignal(this.valueIsFalsy$, { requireSync: true });
30
- this.valueIsEmpty$ = combineLatest([this.value$, this.autofilled$]).pipe(map(([value, autofilled]) => (value === null || value === undefined || value === '' || (Array.isArray(value) && !value.length)) &&
31
- !autofilled));
30
+ /**
31
+ * Selects might have a option that is "null".
32
+ * This helper can be used to enhance the detection of empty values.
33
+ * The input is empty if the helper returns a falsy value and the value itself is falsy or an empty array.
34
+ */
35
+ this.isEmptyHelper$ = new BehaviorSubject(undefined);
36
+ this.isEmptyHelper = toSignal(this.isEmptyHelper$, { requireSync: true });
37
+ this.valueIsEmpty$ = combineLatest([
38
+ this.value$,
39
+ this.autofilled$,
40
+ this.isEmptyHelper$.pipe(switchMap((isEmptyHelper) => (isEmptyHelper instanceof Observable ? isEmptyHelper : of(isEmptyHelper)))),
41
+ ]).pipe(map(([value, autofilled, isEmptyHelper]) => {
42
+ const defaultIsEmpty = (value === null || value === undefined || value === '' || (Array.isArray(value) && !value.length)) &&
43
+ !autofilled;
44
+ if (isEmptyHelper !== undefined) {
45
+ return !isEmptyHelper && defaultIsEmpty;
46
+ }
47
+ return defaultIsEmpty;
48
+ }));
32
49
  this.valueIsEmpty = toSignal(this.valueIsEmpty$, { requireSync: true });
33
50
  this.errors$ = new BehaviorSubject(null);
34
51
  this.errors = toSignal(this.errors$, { requireSync: true });
@@ -50,4 +67,4 @@ export class InputStateService {
50
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: InputStateService, decorators: [{
51
68
  type: Injectable
52
69
  }] });
53
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-state.service.js","sourceRoot":"","sources":["../../../../../../../../libs/cdk/src/lib/components/forms/services/input-state.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusOrigin } from '@angular/cdk/a11y';\nimport { Injectable } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { BehaviorSubject, combineLatest, filter, map, Subject } from 'rxjs';\nimport { NativeInputRefDirective } from '../directives';\nimport { InputTouchedFn, InputValueChangeFn, InputValueUpdateType, ValidatorErrors } from '../types';\n\n@Injectable()\nexport class InputStateService<\n  T = unknown,\n  J extends HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement | HTMLButtonElement = HTMLInputElement,\n> {\n  readonly lastUpdateType$ = new BehaviorSubject<InputValueUpdateType | null>(null);\n  readonly lastUpdateType = toSignal(this.lastUpdateType$, { requireSync: true });\n\n  readonly onInternalUpdate$ = this.lastUpdateType$.pipe(filter((type) => type === 'internal'));\n  readonly onExternalUpdate$ = this.lastUpdateType$.pipe(filter((type) => type === 'external'));\n\n  readonly value$ = new BehaviorSubject<T | null>(null);\n  readonly value = toSignal(this.value$, { requireSync: true });\n\n  readonly disabled$ = new BehaviorSubject<boolean>(false);\n  readonly disabled = toSignal(this.disabled$, { requireSync: true });\n\n  readonly required$ = new BehaviorSubject<boolean>(false);\n  readonly required = toSignal(this.required$, { requireSync: true });\n\n  readonly valueChange$ = new Subject<T>();\n  readonly disabledChange$ = new Subject<boolean>();\n  readonly requiredChange$ = new Subject<boolean>();\n\n  readonly usesImplicitControl$ = new BehaviorSubject<boolean>(false);\n  readonly usesImplicitControl = toSignal(this.usesImplicitControl$, { requireSync: true });\n\n  readonly nativeInputRef$ = new BehaviorSubject<NativeInputRefDirective<J> | null>(null);\n  readonly nativeInputRef = toSignal(this.nativeInputRef$, { requireSync: true });\n\n  readonly autofilled$ = new BehaviorSubject<boolean>(false);\n  readonly autofilled = toSignal(this.autofilled$, { requireSync: true });\n\n  readonly valueIsTruthy$ = this.value$.pipe(map((value) => !!value));\n  readonly valueIsTruthy = toSignal(this.valueIsTruthy$, { requireSync: true });\n\n  readonly valueIsFalsy$ = this.value$.pipe(map((value) => !value));\n  readonly valueIsFalsy = toSignal(this.valueIsFalsy$, { requireSync: true });\n\n  readonly valueIsEmpty$ = combineLatest([this.value$, this.autofilled$]).pipe(\n    map(\n      ([value, autofilled]) =>\n        (value === null || value === undefined || value === '' || (Array.isArray(value) && !value.length)) &&\n        !autofilled,\n    ),\n  );\n  readonly valueIsEmpty = toSignal(this.valueIsEmpty$, { requireSync: true });\n\n  readonly errors$ = new BehaviorSubject<ValidatorErrors | null>(null);\n  readonly errors = toSignal(this.errors$, { requireSync: true });\n\n  readonly shouldDisplayError$ = new BehaviorSubject<boolean>(false);\n  readonly shouldDisplayError = toSignal(this.shouldDisplayError$, { requireSync: true });\n\n  readonly isFocusedVia$ = new BehaviorSubject<FocusOrigin | null>(null);\n  readonly isFocusedVia = toSignal(this.isFocusedVia$, { requireSync: true });\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  _valueChange: InputValueChangeFn<T> = (value) => {\n    // stub\n  };\n  _touched: InputTouchedFn = () => {\n    // stub\n  };\n}\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-state.service.js","sourceRoot":"","sources":["../../../../../../../../libs/cdk/src/lib/components/forms/services/input-state.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusOrigin } from '@angular/cdk/a11y';\nimport { Injectable } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { BehaviorSubject, combineLatest, filter, map, Observable, of, Subject, switchMap } from 'rxjs';\nimport { NativeInputRefDirective } from '../directives';\nimport { InputTouchedFn, InputValueChangeFn, InputValueUpdateType, ValidatorErrors } from '../types';\n\n@Injectable()\nexport class InputStateService<\n  T = unknown,\n  J extends HTMLInputElement | HTMLSelectElement | HTMLTextAreaElement | HTMLButtonElement = HTMLInputElement,\n> {\n  readonly lastUpdateType$ = new BehaviorSubject<InputValueUpdateType | null>(null);\n  readonly lastUpdateType = toSignal(this.lastUpdateType$, { requireSync: true });\n\n  readonly onInternalUpdate$ = this.lastUpdateType$.pipe(filter((type) => type === 'internal'));\n  readonly onExternalUpdate$ = this.lastUpdateType$.pipe(filter((type) => type === 'external'));\n\n  readonly value$ = new BehaviorSubject<T | null>(null);\n  readonly value = toSignal(this.value$, { requireSync: true });\n\n  readonly disabled$ = new BehaviorSubject<boolean>(false);\n  readonly disabled = toSignal(this.disabled$, { requireSync: true });\n\n  readonly required$ = new BehaviorSubject<boolean>(false);\n  readonly required = toSignal(this.required$, { requireSync: true });\n\n  readonly valueChange$ = new Subject<T>();\n  readonly disabledChange$ = new Subject<boolean>();\n  readonly requiredChange$ = new Subject<boolean>();\n\n  readonly usesImplicitControl$ = new BehaviorSubject<boolean>(false);\n  readonly usesImplicitControl = toSignal(this.usesImplicitControl$, { requireSync: true });\n\n  readonly nativeInputRef$ = new BehaviorSubject<NativeInputRefDirective<J> | null>(null);\n  readonly nativeInputRef = toSignal(this.nativeInputRef$, { requireSync: true });\n\n  readonly autofilled$ = new BehaviorSubject<boolean>(false);\n  readonly autofilled = toSignal(this.autofilled$, { requireSync: true });\n\n  readonly valueIsTruthy$ = this.value$.pipe(map((value) => !!value));\n  readonly valueIsTruthy = toSignal(this.valueIsTruthy$, { requireSync: true });\n\n  readonly valueIsFalsy$ = this.value$.pipe(map((value) => !value));\n  readonly valueIsFalsy = toSignal(this.valueIsFalsy$, { requireSync: true });\n\n  /**\n   * Selects might have a option that is \"null\".\n   * This helper can be used to enhance the detection of empty values.\n   * The input is empty if the helper returns a falsy value and the value itself is falsy or an empty array.\n   */\n  readonly isEmptyHelper$ = new BehaviorSubject<unknown | Observable<unknown>>(undefined);\n  readonly isEmptyHelper = toSignal(this.isEmptyHelper$, { requireSync: true });\n\n  readonly valueIsEmpty$ = combineLatest([\n    this.value$,\n    this.autofilled$,\n    this.isEmptyHelper$.pipe(\n      switchMap((isEmptyHelper) => (isEmptyHelper instanceof Observable ? isEmptyHelper : of(isEmptyHelper))),\n    ),\n  ]).pipe(\n    map(([value, autofilled, isEmptyHelper]) => {\n      const defaultIsEmpty =\n        (value === null || value === undefined || value === '' || (Array.isArray(value) && !value.length)) &&\n        !autofilled;\n\n      if (isEmptyHelper !== undefined) {\n        return !isEmptyHelper && defaultIsEmpty;\n      }\n\n      return defaultIsEmpty;\n    }),\n  );\n  readonly valueIsEmpty = toSignal(this.valueIsEmpty$, { requireSync: true });\n\n  readonly errors$ = new BehaviorSubject<ValidatorErrors | null>(null);\n  readonly errors = toSignal(this.errors$, { requireSync: true });\n\n  readonly shouldDisplayError$ = new BehaviorSubject<boolean>(false);\n  readonly shouldDisplayError = toSignal(this.shouldDisplayError$, { requireSync: true });\n\n  readonly isFocusedVia$ = new BehaviorSubject<FocusOrigin | null>(null);\n  readonly isFocusedVia = toSignal(this.isFocusedVia$, { requireSync: true });\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  _valueChange: InputValueChangeFn<T> = (value) => {\n    // stub\n  };\n  _touched: InputTouchedFn = () => {\n    // stub\n  };\n}\n"]}
@@ -1,16 +1,13 @@
1
1
  import { Directive, inject } from '@angular/core';
2
- import { createReactiveBindings } from '@ethlete/core';
2
+ import { signalHostClasses } from '@ethlete/core';
3
3
  import { FormFieldStateService } from '../services';
4
4
  import * as i0 from "@angular/core";
5
5
  export class DecoratedFormFieldBase {
6
6
  constructor() {
7
7
  this._formFieldStateService = inject(FormFieldStateService);
8
- this._bindings = createReactiveBindings({
9
- attribute: 'class.et-form-field--has-prefix',
10
- observable: this._formFieldStateService.hasPrefix$,
11
- }, {
12
- attribute: 'class.et-form-field--has-suffix',
13
- observable: this._formFieldStateService.hasSuffix$,
8
+ this.hostClassBindings = signalHostClasses({
9
+ 'et-form-field--has-prefix': this._formFieldStateService.hasPrefix,
10
+ 'et-form-field--has-suffix': this._formFieldStateService.hasSuffix,
14
11
  });
15
12
  }
16
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DecoratedFormFieldBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
@@ -19,4 +16,4 @@ export class DecoratedFormFieldBase {
19
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DecoratedFormFieldBase, decorators: [{
20
17
  type: Directive
21
18
  }] });
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkLWZvcm0tZmllbGQuYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9mb3Jtcy91dGlscy9kZWNvcmF0ZWQtZm9ybS1maWVsZC5iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxhQUFhLENBQUM7O0FBR3BELE1BQU0sT0FBTyxzQkFBc0I7SUFEbkM7UUFFbUIsMkJBQXNCLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFL0QsY0FBUyxHQUFHLHNCQUFzQixDQUN6QztZQUNFLFNBQVMsRUFBRSxpQ0FBaUM7WUFDNUMsVUFBVSxFQUFFLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVO1NBQ25ELEVBQ0Q7WUFDRSxTQUFTLEVBQUUsaUNBQWlDO1lBQzVDLFVBQVUsRUFBRSxJQUFJLENBQUMsc0JBQXNCLENBQUMsVUFBVTtTQUNuRCxDQUNGLENBQUM7S0FDSDs4R0FiWSxzQkFBc0I7a0dBQXRCLHNCQUFzQjs7MkZBQXRCLHNCQUFzQjtrQkFEbEMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBjcmVhdGVSZWFjdGl2ZUJpbmRpbmdzIH0gZnJvbSAnQGV0aGxldGUvY29yZSc7XG5pbXBvcnQgeyBGb3JtRmllbGRTdGF0ZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcyc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGNsYXNzIERlY29yYXRlZEZvcm1GaWVsZEJhc2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IF9mb3JtRmllbGRTdGF0ZVNlcnZpY2UgPSBpbmplY3QoRm9ybUZpZWxkU3RhdGVTZXJ2aWNlKTtcblxuICByZWFkb25seSBfYmluZGluZ3MgPSBjcmVhdGVSZWFjdGl2ZUJpbmRpbmdzKFxuICAgIHtcbiAgICAgIGF0dHJpYnV0ZTogJ2NsYXNzLmV0LWZvcm0tZmllbGQtLWhhcy1wcmVmaXgnLFxuICAgICAgb2JzZXJ2YWJsZTogdGhpcy5fZm9ybUZpZWxkU3RhdGVTZXJ2aWNlLmhhc1ByZWZpeCQsXG4gICAgfSxcbiAgICB7XG4gICAgICBhdHRyaWJ1dGU6ICdjbGFzcy5ldC1mb3JtLWZpZWxkLS1oYXMtc3VmZml4JyxcbiAgICAgIG9ic2VydmFibGU6IHRoaXMuX2Zvcm1GaWVsZFN0YXRlU2VydmljZS5oYXNTdWZmaXgkLFxuICAgIH0sXG4gICk7XG59XG4iXX0=
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkLWZvcm0tZmllbGQuYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2RrL3NyYy9saWIvY29tcG9uZW50cy9mb3Jtcy91dGlscy9kZWNvcmF0ZWQtZm9ybS1maWVsZC5iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxhQUFhLENBQUM7O0FBR3BELE1BQU0sT0FBTyxzQkFBc0I7SUFEbkM7UUFFbUIsMkJBQXNCLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFL0Qsc0JBQWlCLEdBQUcsaUJBQWlCLENBQUM7WUFDN0MsMkJBQTJCLEVBQUUsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVM7WUFDbEUsMkJBQTJCLEVBQUUsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVM7U0FDbkUsQ0FBQyxDQUFDO0tBQ0o7OEdBUFksc0JBQXNCO2tHQUF0QixzQkFBc0I7OzJGQUF0QixzQkFBc0I7a0JBRGxDLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgc2lnbmFsSG9zdENsYXNzZXMgfSBmcm9tICdAZXRobGV0ZS9jb3JlJztcbmltcG9ydCB7IEZvcm1GaWVsZFN0YXRlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgRGVjb3JhdGVkRm9ybUZpZWxkQmFzZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Zvcm1GaWVsZFN0YXRlU2VydmljZSA9IGluamVjdChGb3JtRmllbGRTdGF0ZVNlcnZpY2UpO1xuXG4gIHJlYWRvbmx5IGhvc3RDbGFzc0JpbmRpbmdzID0gc2lnbmFsSG9zdENsYXNzZXMoe1xuICAgICdldC1mb3JtLWZpZWxkLS1oYXMtcHJlZml4JzogdGhpcy5fZm9ybUZpZWxkU3RhdGVTZXJ2aWNlLmhhc1ByZWZpeCxcbiAgICAnZXQtZm9ybS1maWVsZC0taGFzLXN1ZmZpeCc6IHRoaXMuX2Zvcm1GaWVsZFN0YXRlU2VydmljZS5oYXNTdWZmaXgsXG4gIH0pO1xufVxuIl19
@@ -1,44 +1,47 @@
1
1
  import { ContentChildren, Directive, inject } from '@angular/core';
2
- import { TypedQueryList, createDestroy, createReactiveBindings } from '@ethlete/core';
3
- import { map, startWith, takeUntil } from 'rxjs';
2
+ import { takeUntilDestroyed, toSignal } from '@angular/core/rxjs-interop';
3
+ import { TypedQueryList, createDestroy, signalHostClasses, switchQueryListChanges } from '@ethlete/core';
4
+ import { BehaviorSubject, map, tap } from 'rxjs';
4
5
  import { INPUT_PREFIX_TOKEN, INPUT_SUFFIX_TOKEN } from '../directives';
5
6
  import { FormFieldStateService } from '../services';
6
7
  import { InputBase } from './input.base';
7
8
  import * as i0 from "@angular/core";
8
9
  export class DecoratedInputBase extends InputBase {
10
+ set inputPrefix(inputPrefix) {
11
+ this.inputPrefix$.next(inputPrefix);
12
+ }
13
+ set inputSuffix(inputSuffix) {
14
+ this.inputSuffix$.next(inputSuffix);
15
+ }
9
16
  constructor() {
10
- super(...arguments);
17
+ super();
11
18
  this._formFieldStateService = inject(FormFieldStateService);
12
19
  this._destroy$ = createDestroy();
13
- this._bindings = createReactiveBindings({
14
- attribute: 'class.et-input--has-prefix',
15
- observable: this._formFieldStateService.hasPrefix$,
16
- }, {
17
- attribute: 'class.et-input--has-suffix',
18
- observable: this._formFieldStateService.hasSuffix$,
20
+ this.inputPrefix$ = new BehaviorSubject(null);
21
+ this.inputSuffix$ = new BehaviorSubject(null);
22
+ this.hasPrefix$ = this.inputPrefix$.pipe(switchQueryListChanges(), map((list) => !!list && list?.length > 0));
23
+ this.hasSuffix$ = this.inputSuffix$.pipe(switchQueryListChanges(), map((list) => !!list && list?.length > 0));
24
+ this.hostClassBindings = signalHostClasses({
25
+ 'et-input--has-prefix': toSignal(this.hasPrefix$),
26
+ 'et-input--has-suffix': toSignal(this.hasSuffix$),
19
27
  });
28
+ this.hasPrefix$
29
+ .pipe(takeUntilDestroyed(), tap((hasPrefix) => this._formFieldStateService.hasPrefix$.next(hasPrefix)))
30
+ .subscribe();
31
+ this.hasSuffix$
32
+ .pipe(takeUntilDestroyed(), tap((hasSuffix) => this._formFieldStateService.hasSuffix$.next(hasSuffix)))
33
+ .subscribe();
20
34
  }
21
- ngAfterContentInit() {
22
- if (!this.inputPrefix || !this.inputSuffix) {
23
- return;
24
- }
25
- this.inputPrefix.changes
26
- .pipe(takeUntil(this._destroy$), startWith(this.inputPrefix), map((list) => list.length > 0))
27
- .subscribe(this._formFieldStateService.hasPrefix$);
28
- this.inputSuffix.changes
29
- .pipe(takeUntil(this._destroy$), startWith(this.inputSuffix), map((list) => list.length > 0))
30
- .subscribe(this._formFieldStateService.hasSuffix$);
31
- }
32
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DecoratedInputBase, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
35
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DecoratedInputBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
33
36
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: DecoratedInputBase, queries: [{ propertyName: "inputPrefix", predicate: INPUT_PREFIX_TOKEN }, { propertyName: "inputSuffix", predicate: INPUT_SUFFIX_TOKEN }], usesInheritance: true, ngImport: i0 }); }
34
37
  }
35
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: DecoratedInputBase, decorators: [{
36
39
  type: Directive
37
- }], propDecorators: { inputPrefix: [{
40
+ }], ctorParameters: function () { return []; }, propDecorators: { inputPrefix: [{
38
41
  type: ContentChildren,
39
42
  args: [INPUT_PREFIX_TOKEN]
40
43
  }], inputSuffix: [{
41
44
  type: ContentChildren,
42
45
  args: [INPUT_SUFFIX_TOKEN]
43
46
  }] } });
44
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkLWlucHV0LmJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvdXRpbHMvZGVjb3JhdGVkLWlucHV0LmJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFvQixlQUFlLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRixPQUFPLEVBQUUsY0FBYyxFQUFFLGFBQWEsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUE4QyxNQUFNLGVBQWUsQ0FBQztBQUNuSCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDcEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFHekMsTUFBTSxPQUFPLGtCQUFtQixTQUFRLFNBQVM7SUFEakQ7O1FBRW1CLDJCQUFzQixHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQy9ELGNBQVMsR0FBRyxhQUFhLEVBQUUsQ0FBQztRQVE1QixjQUFTLEdBQUcsc0JBQXNCLENBQ3pDO1lBQ0UsU0FBUyxFQUFFLDRCQUE0QjtZQUN2QyxVQUFVLEVBQUUsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFVBQVU7U0FDbkQsRUFDRDtZQUNFLFNBQVMsRUFBRSw0QkFBNEI7WUFDdkMsVUFBVSxFQUFFLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVO1NBQ25ELENBQ0YsQ0FBQztLQXVCSDtJQXJCQyxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQzFDLE9BQU87U0FDUjtRQUVELElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTzthQUNyQixJQUFJLENBQ0gsU0FBUyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFDekIsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsRUFDM0IsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUMvQjthQUNBLFNBQVMsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFckQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPO2FBQ3JCLElBQUksQ0FDSCxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUN6QixTQUFTLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxFQUMzQixHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQy9CO2FBQ0EsU0FBUyxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN2RCxDQUFDOzhHQXpDVSxrQkFBa0I7a0dBQWxCLGtCQUFrQixzREFJWixrQkFBa0IsOENBR2xCLGtCQUFrQjs7MkZBUHhCLGtCQUFrQjtrQkFEOUIsU0FBUzs4QkFNVyxXQUFXO3NCQUQ3QixlQUFlO3VCQUFDLGtCQUFrQjtnQkFJaEIsV0FBVztzQkFEN0IsZUFBZTt1QkFBQyxrQkFBa0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlckNvbnRlbnRJbml0LCBDb250ZW50Q2hpbGRyZW4sIERpcmVjdGl2ZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUeXBlZFF1ZXJ5TGlzdCwgY3JlYXRlRGVzdHJveSwgY3JlYXRlUmVhY3RpdmVCaW5kaW5ncyB9IGZyb20gJ0BldGhsZXRlL2NvcmUnO1xuaW1wb3J0IHsgbWFwLCBzdGFydFdpdGgsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgSU5QVVRfUFJFRklYX1RPS0VOLCBJTlBVVF9TVUZGSVhfVE9LRU4sIElucHV0UHJlZml4RGlyZWN0aXZlLCBJbnB1dFN1ZmZpeERpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZXMnO1xuaW1wb3J0IHsgRm9ybUZpZWxkU3RhdGVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMnO1xuaW1wb3J0IHsgSW5wdXRCYXNlIH0gZnJvbSAnLi9pbnB1dC5iYXNlJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgRGVjb3JhdGVkSW5wdXRCYXNlIGV4dGVuZHMgSW5wdXRCYXNlIGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Zvcm1GaWVsZFN0YXRlU2VydmljZSA9IGluamVjdChGb3JtRmllbGRTdGF0ZVNlcnZpY2UpO1xuICByZWFkb25seSBfZGVzdHJveSQgPSBjcmVhdGVEZXN0cm95KCk7XG5cbiAgQENvbnRlbnRDaGlsZHJlbihJTlBVVF9QUkVGSVhfVE9LRU4pXG4gIHByb3RlY3RlZCByZWFkb25seSBpbnB1dFByZWZpeD86IFR5cGVkUXVlcnlMaXN0PElucHV0UHJlZml4RGlyZWN0aXZlPjtcblxuICBAQ29udGVudENoaWxkcmVuKElOUFVUX1NVRkZJWF9UT0tFTilcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGlucHV0U3VmZml4PzogVHlwZWRRdWVyeUxpc3Q8SW5wdXRTdWZmaXhEaXJlY3RpdmU+O1xuXG4gIHJlYWRvbmx5IF9iaW5kaW5ncyA9IGNyZWF0ZVJlYWN0aXZlQmluZGluZ3MoXG4gICAge1xuICAgICAgYXR0cmlidXRlOiAnY2xhc3MuZXQtaW5wdXQtLWhhcy1wcmVmaXgnLFxuICAgICAgb2JzZXJ2YWJsZTogdGhpcy5fZm9ybUZpZWxkU3RhdGVTZXJ2aWNlLmhhc1ByZWZpeCQsXG4gICAgfSxcbiAgICB7XG4gICAgICBhdHRyaWJ1dGU6ICdjbGFzcy5ldC1pbnB1dC0taGFzLXN1ZmZpeCcsXG4gICAgICBvYnNlcnZhYmxlOiB0aGlzLl9mb3JtRmllbGRTdGF0ZVNlcnZpY2UuaGFzU3VmZml4JCxcbiAgICB9LFxuICApO1xuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuaW5wdXRQcmVmaXggfHwgIXRoaXMuaW5wdXRTdWZmaXgpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLmlucHV0UHJlZml4LmNoYW5nZXNcbiAgICAgIC5waXBlKFxuICAgICAgICB0YWtlVW50aWwodGhpcy5fZGVzdHJveSQpLFxuICAgICAgICBzdGFydFdpdGgodGhpcy5pbnB1dFByZWZpeCksXG4gICAgICAgIG1hcCgobGlzdCkgPT4gbGlzdC5sZW5ndGggPiAwKSxcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUodGhpcy5fZm9ybUZpZWxkU3RhdGVTZXJ2aWNlLmhhc1ByZWZpeCQpO1xuXG4gICAgdGhpcy5pbnB1dFN1ZmZpeC5jaGFuZ2VzXG4gICAgICAucGlwZShcbiAgICAgICAgdGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSxcbiAgICAgICAgc3RhcnRXaXRoKHRoaXMuaW5wdXRTdWZmaXgpLFxuICAgICAgICBtYXAoKGxpc3QpID0+IGxpc3QubGVuZ3RoID4gMCksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKHRoaXMuX2Zvcm1GaWVsZFN0YXRlU2VydmljZS5oYXNTdWZmaXgkKTtcbiAgfVxufVxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdGVkLWlucHV0LmJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvdXRpbHMvZGVjb3JhdGVkLWlucHV0LmJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsY0FBYyxFQUFFLGFBQWEsRUFBRSxpQkFBaUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RyxPQUFPLEVBQUUsZUFBZSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGtCQUFrQixFQUE4QyxNQUFNLGVBQWUsQ0FBQztBQUNuSCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDcEQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQzs7QUFHekMsTUFBTSxPQUFPLGtCQUFtQixTQUFRLFNBQVM7SUFJL0MsSUFDSSxXQUFXLENBQUMsV0FBaUQ7UUFDL0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUdELElBQ0ksV0FBVyxDQUFDLFdBQWlEO1FBQy9ELElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFpQkQ7UUFDRSxLQUFLLEVBQUUsQ0FBQztRQTlCTywyQkFBc0IsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUMvRCxjQUFTLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFNbEIsaUJBQVksR0FBRyxJQUFJLGVBQWUsQ0FBOEMsSUFBSSxDQUFDLENBQUM7UUFNdEYsaUJBQVksR0FBRyxJQUFJLGVBQWUsQ0FBOEMsSUFBSSxDQUFDLENBQUM7UUFFaEcsZUFBVSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUMxQyxzQkFBc0IsRUFBRSxFQUN4QixHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksSUFBSSxFQUFFLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FDMUMsQ0FBQztRQUNPLGVBQVUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDMUMsc0JBQXNCLEVBQUUsRUFDeEIsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksRUFBRSxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQzFDLENBQUM7UUFFTyxzQkFBaUIsR0FBRyxpQkFBaUIsQ0FBQztZQUM3QyxzQkFBc0IsRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUNqRCxzQkFBc0IsRUFBRSxRQUFRLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztTQUNsRCxDQUFDLENBQUM7UUFLRCxJQUFJLENBQUMsVUFBVTthQUNaLElBQUksQ0FDSCxrQkFBa0IsRUFBRSxFQUNwQixHQUFHLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQzNFO2FBQ0EsU0FBUyxFQUFFLENBQUM7UUFFZixJQUFJLENBQUMsVUFBVTthQUNaLElBQUksQ0FDSCxrQkFBa0IsRUFBRSxFQUNwQixHQUFHLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQzNFO2FBQ0EsU0FBUyxFQUFFLENBQUM7SUFDakIsQ0FBQzs4R0E5Q1Usa0JBQWtCO2tHQUFsQixrQkFBa0Isc0RBSVosa0JBQWtCLDhDQU1sQixrQkFBa0I7OzJGQVZ4QixrQkFBa0I7a0JBRDlCLFNBQVM7MEVBTUosV0FBVztzQkFEZCxlQUFlO3VCQUFDLGtCQUFrQjtnQkFPL0IsV0FBVztzQkFEZCxlQUFlO3VCQUFDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnRlbnRDaGlsZHJlbiwgRGlyZWN0aXZlLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCwgdG9TaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQgeyBUeXBlZFF1ZXJ5TGlzdCwgY3JlYXRlRGVzdHJveSwgc2lnbmFsSG9zdENsYXNzZXMsIHN3aXRjaFF1ZXJ5TGlzdENoYW5nZXMgfSBmcm9tICdAZXRobGV0ZS9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgbWFwLCB0YXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IElOUFVUX1BSRUZJWF9UT0tFTiwgSU5QVVRfU1VGRklYX1RPS0VOLCBJbnB1dFByZWZpeERpcmVjdGl2ZSwgSW5wdXRTdWZmaXhEaXJlY3RpdmUgfSBmcm9tICcuLi9kaXJlY3RpdmVzJztcbmltcG9ydCB7IEZvcm1GaWVsZFN0YXRlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJztcbmltcG9ydCB7IElucHV0QmFzZSB9IGZyb20gJy4vaW5wdXQuYmFzZSc7XG5cbkBEaXJlY3RpdmUoKVxuZXhwb3J0IGNsYXNzIERlY29yYXRlZElucHV0QmFzZSBleHRlbmRzIElucHV0QmFzZSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Zvcm1GaWVsZFN0YXRlU2VydmljZSA9IGluamVjdChGb3JtRmllbGRTdGF0ZVNlcnZpY2UpO1xuICByZWFkb25seSBfZGVzdHJveSQgPSBjcmVhdGVEZXN0cm95KCk7XG5cbiAgQENvbnRlbnRDaGlsZHJlbihJTlBVVF9QUkVGSVhfVE9LRU4pXG4gIHNldCBpbnB1dFByZWZpeChpbnB1dFByZWZpeDogVHlwZWRRdWVyeUxpc3Q8SW5wdXRQcmVmaXhEaXJlY3RpdmU+KSB7XG4gICAgdGhpcy5pbnB1dFByZWZpeCQubmV4dChpbnB1dFByZWZpeCk7XG4gIH1cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGlucHV0UHJlZml4JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8VHlwZWRRdWVyeUxpc3Q8SW5wdXRQcmVmaXhEaXJlY3RpdmU+IHwgbnVsbD4obnVsbCk7XG5cbiAgQENvbnRlbnRDaGlsZHJlbihJTlBVVF9TVUZGSVhfVE9LRU4pXG4gIHNldCBpbnB1dFN1ZmZpeChpbnB1dFN1ZmZpeDogVHlwZWRRdWVyeUxpc3Q8SW5wdXRTdWZmaXhEaXJlY3RpdmU+KSB7XG4gICAgdGhpcy5pbnB1dFN1ZmZpeCQubmV4dChpbnB1dFN1ZmZpeCk7XG4gIH1cbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGlucHV0U3VmZml4JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8VHlwZWRRdWVyeUxpc3Q8SW5wdXRTdWZmaXhEaXJlY3RpdmU+IHwgbnVsbD4obnVsbCk7XG5cbiAgcmVhZG9ubHkgaGFzUHJlZml4JCA9IHRoaXMuaW5wdXRQcmVmaXgkLnBpcGUoXG4gICAgc3dpdGNoUXVlcnlMaXN0Q2hhbmdlcygpLFxuICAgIG1hcCgobGlzdCkgPT4gISFsaXN0ICYmIGxpc3Q/Lmxlbmd0aCA+IDApLFxuICApO1xuICByZWFkb25seSBoYXNTdWZmaXgkID0gdGhpcy5pbnB1dFN1ZmZpeCQucGlwZShcbiAgICBzd2l0Y2hRdWVyeUxpc3RDaGFuZ2VzKCksXG4gICAgbWFwKChsaXN0KSA9PiAhIWxpc3QgJiYgbGlzdD8ubGVuZ3RoID4gMCksXG4gICk7XG5cbiAgcmVhZG9ubHkgaG9zdENsYXNzQmluZGluZ3MgPSBzaWduYWxIb3N0Q2xhc3Nlcyh7XG4gICAgJ2V0LWlucHV0LS1oYXMtcHJlZml4JzogdG9TaWduYWwodGhpcy5oYXNQcmVmaXgkKSxcbiAgICAnZXQtaW5wdXQtLWhhcy1zdWZmaXgnOiB0b1NpZ25hbCh0aGlzLmhhc1N1ZmZpeCQpLFxuICB9KTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuXG4gICAgdGhpcy5oYXNQcmVmaXgkXG4gICAgICAucGlwZShcbiAgICAgICAgdGFrZVVudGlsRGVzdHJveWVkKCksXG4gICAgICAgIHRhcCgoaGFzUHJlZml4KSA9PiB0aGlzLl9mb3JtRmllbGRTdGF0ZVNlcnZpY2UuaGFzUHJlZml4JC5uZXh0KGhhc1ByZWZpeCkpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgpO1xuXG4gICAgdGhpcy5oYXNTdWZmaXgkXG4gICAgICAucGlwZShcbiAgICAgICAgdGFrZVVudGlsRGVzdHJveWVkKCksXG4gICAgICAgIHRhcCgoaGFzU3VmZml4KSA9PiB0aGlzLl9mb3JtRmllbGRTdGF0ZVNlcnZpY2UuaGFzU3VmZml4JC5uZXh0KGhhc1N1ZmZpeCkpLFxuICAgICAgKVxuICAgICAgLnN1YnNjcmliZSgpO1xuICB9XG59XG4iXX0=
@@ -1,5 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, forwardRef, inject, Input, numberAttribute, Output, ViewEncapsulation, } from '@angular/core';
2
- import { createDestroy, createReactiveBindings, DELAYABLE_TOKEN, ObserveResizeDirective, TypedQueryList, } from '@ethlete/core';
2
+ import { toSignal } from '@angular/core/rxjs-interop';
3
+ import { createDestroy, DELAYABLE_TOKEN, ObserveResizeDirective, signalHostClasses, TypedQueryList, } from '@ethlete/core';
3
4
  import { BehaviorSubject, combineLatest, debounceTime, of, startWith, switchMap, takeUntil, tap, timer } from 'rxjs';
4
5
  import { MASONRY_ITEM_TOKEN } from '../../partials';
5
6
  import * as i0 from "@angular/core";
@@ -15,12 +16,9 @@ export class MasonryComponent {
15
16
  this._didResize$ = new BehaviorSubject(false);
16
17
  this._didInitialize$ = new BehaviorSubject(false);
17
18
  this._hideOverflow$ = new BehaviorSubject(false);
18
- this._bindings = createReactiveBindings({
19
- attribute: 'class.et-masonry--initialized',
20
- observable: this._didInitialize$,
21
- }, {
22
- attribute: 'class.et-masonry--hide-overflow',
23
- observable: this._hideOverflow$,
19
+ this.hostClassBindings = signalHostClasses({
20
+ 'et-masonry--initialized': toSignal(this._didInitialize$),
21
+ 'et-masonry--hide-overflow': toSignal(this._hideOverflow$),
24
22
  });
25
23
  this._state = {
26
24
  preferredColumnWidth: 0,
@@ -203,4 +201,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
203
201
  }], initialized: [{
204
202
  type: Output
205
203
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"masonry.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/masonry/components/masonry/masonry.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  numberAttribute,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  createDestroy,\n  createReactiveBindings,\n  DELAYABLE_TOKEN,\n  ObserveResizeDirective,\n  TypedQueryList,\n} from '@ethlete/core';\nimport { BehaviorSubject, combineLatest, debounceTime, of, startWith, switchMap, takeUntil, tap, timer } from 'rxjs';\nimport { MASONRY_ITEM_TOKEN, MasonryItemComponent } from '../../partials';\n\ntype MasonryState = {\n  preferredColumnWidth: number;\n  columnWidth: number;\n  columns: number;\n  gridRowElHeights: number[][];\n  hostHeight: number;\n  hostDimensions: DOMRect | null;\n  gap: number;\n  isInitialized: boolean;\n  itemCount: number;\n};\n\n@Component({\n  selector: 'et-masonry',\n  template: `\n    <div (etObserveResize)=\"setResizeEvent()\"></div>\n    <ng-content select=\"[etMasonryItem], et-masonry-item, ng-container\" />\n  `,\n  styleUrls: ['./masonry.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'et-masonry',\n  },\n  imports: [ObserveResizeDirective],\n})\nexport class MasonryComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _delayable = inject(DELAYABLE_TOKEN, { optional: true });\n\n  @ContentChildren(forwardRef(() => MASONRY_ITEM_TOKEN), { descendants: true })\n  private readonly _items?: TypedQueryList<MasonryItemComponent>;\n\n  @Input()\n  get columWidth(): number {\n    return this._columWidth$.getValue() || 250;\n  }\n  set columWidth(value: unknown) {\n    this._columWidth$.next(numberAttribute(value, 250));\n  }\n  private _columWidth$ = new BehaviorSubject<number>(250);\n\n  @Input()\n  get gap(): number {\n    return this._gap$.getValue() || 0;\n  }\n  set gap(value: unknown) {\n    this._gap$.next(numberAttribute(value, 16));\n  }\n  private _gap$ = new BehaviorSubject<number>(16);\n\n  @Output()\n  readonly initializing = new EventEmitter();\n\n  @Output()\n  readonly initialized = new EventEmitter();\n\n  private readonly _didResize$ = new BehaviorSubject(false);\n  private readonly _didInitialize$ = new BehaviorSubject(false);\n  private readonly _hideOverflow$ = new BehaviorSubject(false);\n\n  readonly _bindings = createReactiveBindings(\n    {\n      attribute: 'class.et-masonry--initialized',\n      observable: this._didInitialize$,\n    },\n    {\n      attribute: 'class.et-masonry--hide-overflow',\n      observable: this._hideOverflow$,\n    },\n  );\n\n  private readonly _state: MasonryState = {\n    preferredColumnWidth: 0,\n    columnWidth: 0,\n    columns: 0,\n    gridRowElHeights: [],\n    hostHeight: 0,\n    hostDimensions: null,\n    gap: 0,\n    itemCount: 0,\n    isInitialized: false,\n  };\n\n  ngAfterContentInit(): void {\n    if (!this._items) {\n      return;\n    }\n\n    this._delayable?.enableDelayed();\n\n    combineLatest([this._items.changes.pipe(startWith(this._items)), this._didResize$, this._columWidth$, this._gap$])\n      .pipe(\n        debounceTime(1),\n        tap(([, didResize, colWidth, gap]) => {\n          if (didResize) {\n            this._didResize$.next(false);\n          }\n\n          const isCompleteInvalid =\n            didResize || colWidth !== this._state.preferredColumnWidth || gap !== this._state.gap;\n\n          this.invalidate({ partial: !isCompleteInvalid });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._didResize$\n      .pipe(\n        tap(() => this._hideOverflow$.next(true)),\n        switchMap(() => timer(150)),\n        tap(() => this._hideOverflow$.next(false)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._items.changes\n      .pipe(\n        startWith(this._items),\n        switchMap((items) =>\n          items.length\n            ? combineLatest(\n                items\n                  .toArray()\n                  .filter((i): i is MasonryItemComponent => !!i)\n                  .map((i) => i.isPositioned$),\n              )\n            : of([]),\n        ),\n        switchMap((positioned) => {\n          const allPositioned = positioned.every((i) => i);\n\n          if (!allPositioned) {\n            this._didInitialize$.next(allPositioned);\n            this.initializing.emit();\n            this._delayable?.enableDelayed();\n            return of(null);\n          }\n\n          return timer(100).pipe(\n            tap(() => {\n              this._didInitialize$.next(true);\n              this._delayable?.disableDelayed();\n              this.initialized.emit();\n            }),\n          );\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  invalidate(config?: { partial?: boolean }) {\n    const itemList = this._items;\n    const state = this._state;\n\n    if (!itemList) {\n      return;\n    }\n\n    const items = itemList.toArray().filter((i): i is MasonryItemComponent => !!i);\n\n    if (!config?.partial || !state.isInitialized) {\n      state.preferredColumnWidth = this.columWidth;\n      state.hostDimensions = this._getHostDimensions();\n      state.columns = Math.floor(state.hostDimensions.width / this.columWidth);\n      state.gap = this.gap;\n      state.itemCount = items.length;\n      state.columnWidth = (state.hostDimensions.width - (state.columns - 1) * state.gap) / state.columns;\n      this._setColumnWidth(state.columnWidth);\n\n      /**\n       * Data structure:\n       * [\n       *  [currentTotalHeightOfCol, itemHeight, itemHeight, itemHeight],\n       *  [currentTotalHeightOfCol, itemHeight, itemHeight, itemHeight],\n       * ]\n       */\n      state.gridRowElHeights = Array.from({ length: state.columns }).map(() => [0]);\n\n      this._paintMasonry(0, items);\n\n      state.isInitialized = true;\n    } else {\n      const fromIndex = items.findIndex((item) => !item.isPositioned);\n\n      // item count 20 fromIndex 20 + 1 -> 21 => partial invalidation\n      if (fromIndex + 1 > state.itemCount) {\n        state.itemCount = items.length;\n        this._paintMasonry(fromIndex, items);\n\n        return;\n      }\n\n      // do a full invalidation the fromIndex is not the first new item\n      this.invalidate();\n    }\n  }\n\n  private _paintMasonry(fromIndex = 0, items: MasonryItemComponent[]) {\n    const state = this._state;\n\n    for (let itemIndex = fromIndex; itemIndex < items.length; itemIndex++) {\n      const item = items[itemIndex];\n\n      if (!item) {\n        continue;\n      }\n\n      const initialItemDimensions = item.initialDimensions;\n      const updatedDimensions = item.dimensions;\n\n      if (!initialItemDimensions || !updatedDimensions) {\n        continue;\n      }\n\n      const { lowestColumnHeight, lowestColumnIndex } = this._getLowestColumn(state.gridRowElHeights);\n\n      const x = state.columnWidth * lowestColumnIndex + lowestColumnIndex * state.gap;\n\n      item.setPosition(x, lowestColumnHeight, updatedDimensions.height);\n\n      state.gridRowElHeights[lowestColumnIndex]!.push(updatedDimensions.height);\n      state.gridRowElHeights[lowestColumnIndex]![0] += updatedDimensions.height + state.gap;\n    }\n\n    state.hostHeight = this._getHighestColumn(state.gridRowElHeights).highestColumnHeight - state.gap;\n\n    this._elementRef.nativeElement.style.setProperty('height', `${state.hostHeight}px`);\n  }\n\n  protected setResizeEvent() {\n    this._didResize$.next(true);\n  }\n\n  private _getHostDimensions() {\n    return this._elementRef.nativeElement.getBoundingClientRect();\n  }\n\n  private _setColumnWidth(width: number) {\n    this._elementRef.nativeElement.style.setProperty('--et-masonry-column-width', `${width}px`);\n  }\n\n  private _getLowestColumn = (columnHeights: number[][]) => {\n    let lowestColumnHeight = columnHeights[0]?.[0] ?? 0;\n    let lowestColumnIndex = 0;\n\n    for (let i = 0; i < columnHeights.length; i++) {\n      const columnHeight = columnHeights[i]?.[0];\n\n      if (columnHeight !== undefined && columnHeight < lowestColumnHeight) {\n        lowestColumnHeight = columnHeight;\n        lowestColumnIndex = i;\n      }\n    }\n\n    return { lowestColumnHeight, lowestColumnIndex };\n  };\n\n  private _getHighestColumn = (columnHeights: number[][]) => {\n    let highestColumnHeight = columnHeights[0]?.[0] ?? 0;\n    let highestColumnIndex = 0;\n\n    for (let i = 0; i < columnHeights.length; i++) {\n      const columnHeight = columnHeights[i]?.[0];\n\n      if (columnHeight !== undefined && columnHeight >= highestColumnHeight) {\n        highestColumnHeight = columnHeight;\n        highestColumnIndex = i;\n      }\n    }\n\n    return { highestColumnHeight, highestColumnIndex };\n  };\n}\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"masonry.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/masonry/components/masonry/masonry.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  inject,\n  Input,\n  numberAttribute,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport {\n  createDestroy,\n  DELAYABLE_TOKEN,\n  ObserveResizeDirective,\n  signalHostClasses,\n  TypedQueryList,\n} from '@ethlete/core';\nimport { BehaviorSubject, combineLatest, debounceTime, of, startWith, switchMap, takeUntil, tap, timer } from 'rxjs';\nimport { MASONRY_ITEM_TOKEN, MasonryItemComponent } from '../../partials';\n\ntype MasonryState = {\n  preferredColumnWidth: number;\n  columnWidth: number;\n  columns: number;\n  gridRowElHeights: number[][];\n  hostHeight: number;\n  hostDimensions: DOMRect | null;\n  gap: number;\n  isInitialized: boolean;\n  itemCount: number;\n};\n\n@Component({\n  selector: 'et-masonry',\n  template: `\n    <div (etObserveResize)=\"setResizeEvent()\"></div>\n    <ng-content select=\"[etMasonryItem], et-masonry-item, ng-container\" />\n  `,\n  styleUrls: ['./masonry.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    class: 'et-masonry',\n  },\n  imports: [ObserveResizeDirective],\n})\nexport class MasonryComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n  private readonly _delayable = inject(DELAYABLE_TOKEN, { optional: true });\n\n  @ContentChildren(forwardRef(() => MASONRY_ITEM_TOKEN), { descendants: true })\n  private readonly _items?: TypedQueryList<MasonryItemComponent>;\n\n  @Input()\n  get columWidth(): number {\n    return this._columWidth$.getValue() || 250;\n  }\n  set columWidth(value: unknown) {\n    this._columWidth$.next(numberAttribute(value, 250));\n  }\n  private _columWidth$ = new BehaviorSubject<number>(250);\n\n  @Input()\n  get gap(): number {\n    return this._gap$.getValue() || 0;\n  }\n  set gap(value: unknown) {\n    this._gap$.next(numberAttribute(value, 16));\n  }\n  private _gap$ = new BehaviorSubject<number>(16);\n\n  @Output()\n  readonly initializing = new EventEmitter();\n\n  @Output()\n  readonly initialized = new EventEmitter();\n\n  private readonly _didResize$ = new BehaviorSubject(false);\n  private readonly _didInitialize$ = new BehaviorSubject(false);\n  private readonly _hideOverflow$ = new BehaviorSubject(false);\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-masonry--initialized': toSignal(this._didInitialize$),\n    'et-masonry--hide-overflow': toSignal(this._hideOverflow$),\n  });\n\n  private readonly _state: MasonryState = {\n    preferredColumnWidth: 0,\n    columnWidth: 0,\n    columns: 0,\n    gridRowElHeights: [],\n    hostHeight: 0,\n    hostDimensions: null,\n    gap: 0,\n    itemCount: 0,\n    isInitialized: false,\n  };\n\n  ngAfterContentInit(): void {\n    if (!this._items) {\n      return;\n    }\n\n    this._delayable?.enableDelayed();\n\n    combineLatest([this._items.changes.pipe(startWith(this._items)), this._didResize$, this._columWidth$, this._gap$])\n      .pipe(\n        debounceTime(1),\n        tap(([, didResize, colWidth, gap]) => {\n          if (didResize) {\n            this._didResize$.next(false);\n          }\n\n          const isCompleteInvalid =\n            didResize || colWidth !== this._state.preferredColumnWidth || gap !== this._state.gap;\n\n          this.invalidate({ partial: !isCompleteInvalid });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._didResize$\n      .pipe(\n        tap(() => this._hideOverflow$.next(true)),\n        switchMap(() => timer(150)),\n        tap(() => this._hideOverflow$.next(false)),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._items.changes\n      .pipe(\n        startWith(this._items),\n        switchMap((items) =>\n          items.length\n            ? combineLatest(\n                items\n                  .toArray()\n                  .filter((i): i is MasonryItemComponent => !!i)\n                  .map((i) => i.isPositioned$),\n              )\n            : of([]),\n        ),\n        switchMap((positioned) => {\n          const allPositioned = positioned.every((i) => i);\n\n          if (!allPositioned) {\n            this._didInitialize$.next(allPositioned);\n            this.initializing.emit();\n            this._delayable?.enableDelayed();\n            return of(null);\n          }\n\n          return timer(100).pipe(\n            tap(() => {\n              this._didInitialize$.next(true);\n              this._delayable?.disableDelayed();\n              this.initialized.emit();\n            }),\n          );\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  invalidate(config?: { partial?: boolean }) {\n    const itemList = this._items;\n    const state = this._state;\n\n    if (!itemList) {\n      return;\n    }\n\n    const items = itemList.toArray().filter((i): i is MasonryItemComponent => !!i);\n\n    if (!config?.partial || !state.isInitialized) {\n      state.preferredColumnWidth = this.columWidth;\n      state.hostDimensions = this._getHostDimensions();\n      state.columns = Math.floor(state.hostDimensions.width / this.columWidth);\n      state.gap = this.gap;\n      state.itemCount = items.length;\n      state.columnWidth = (state.hostDimensions.width - (state.columns - 1) * state.gap) / state.columns;\n      this._setColumnWidth(state.columnWidth);\n\n      /**\n       * Data structure:\n       * [\n       *  [currentTotalHeightOfCol, itemHeight, itemHeight, itemHeight],\n       *  [currentTotalHeightOfCol, itemHeight, itemHeight, itemHeight],\n       * ]\n       */\n      state.gridRowElHeights = Array.from({ length: state.columns }).map(() => [0]);\n\n      this._paintMasonry(0, items);\n\n      state.isInitialized = true;\n    } else {\n      const fromIndex = items.findIndex((item) => !item.isPositioned);\n\n      // item count 20 fromIndex 20 + 1 -> 21 => partial invalidation\n      if (fromIndex + 1 > state.itemCount) {\n        state.itemCount = items.length;\n        this._paintMasonry(fromIndex, items);\n\n        return;\n      }\n\n      // do a full invalidation the fromIndex is not the first new item\n      this.invalidate();\n    }\n  }\n\n  private _paintMasonry(fromIndex = 0, items: MasonryItemComponent[]) {\n    const state = this._state;\n\n    for (let itemIndex = fromIndex; itemIndex < items.length; itemIndex++) {\n      const item = items[itemIndex];\n\n      if (!item) {\n        continue;\n      }\n\n      const initialItemDimensions = item.initialDimensions;\n      const updatedDimensions = item.dimensions;\n\n      if (!initialItemDimensions || !updatedDimensions) {\n        continue;\n      }\n\n      const { lowestColumnHeight, lowestColumnIndex } = this._getLowestColumn(state.gridRowElHeights);\n\n      const x = state.columnWidth * lowestColumnIndex + lowestColumnIndex * state.gap;\n\n      item.setPosition(x, lowestColumnHeight, updatedDimensions.height);\n\n      state.gridRowElHeights[lowestColumnIndex]!.push(updatedDimensions.height);\n      state.gridRowElHeights[lowestColumnIndex]![0] += updatedDimensions.height + state.gap;\n    }\n\n    state.hostHeight = this._getHighestColumn(state.gridRowElHeights).highestColumnHeight - state.gap;\n\n    this._elementRef.nativeElement.style.setProperty('height', `${state.hostHeight}px`);\n  }\n\n  protected setResizeEvent() {\n    this._didResize$.next(true);\n  }\n\n  private _getHostDimensions() {\n    return this._elementRef.nativeElement.getBoundingClientRect();\n  }\n\n  private _setColumnWidth(width: number) {\n    this._elementRef.nativeElement.style.setProperty('--et-masonry-column-width', `${width}px`);\n  }\n\n  private _getLowestColumn = (columnHeights: number[][]) => {\n    let lowestColumnHeight = columnHeights[0]?.[0] ?? 0;\n    let lowestColumnIndex = 0;\n\n    for (let i = 0; i < columnHeights.length; i++) {\n      const columnHeight = columnHeights[i]?.[0];\n\n      if (columnHeight !== undefined && columnHeight < lowestColumnHeight) {\n        lowestColumnHeight = columnHeight;\n        lowestColumnIndex = i;\n      }\n    }\n\n    return { lowestColumnHeight, lowestColumnIndex };\n  };\n\n  private _getHighestColumn = (columnHeights: number[][]) => {\n    let highestColumnHeight = columnHeights[0]?.[0] ?? 0;\n    let highestColumnIndex = 0;\n\n    for (let i = 0; i < columnHeights.length; i++) {\n      const columnHeight = columnHeights[i]?.[0];\n\n      if (columnHeight !== undefined && columnHeight >= highestColumnHeight) {\n        highestColumnHeight = columnHeight;\n        highestColumnIndex = i;\n      }\n    }\n\n    return { highestColumnHeight, highestColumnIndex };\n  };\n}\n"]}
@@ -1,3 +1,4 @@
1
+ import { coerceElement } from '@angular/cdk/coercion';
1
2
  import { AsyncPipe, NgForOf, NgIf } from '@angular/common';
2
3
  import { ChangeDetectionStrategy, Component, Input, ViewEncapsulation, booleanAttribute, inject, numberAttribute, } from '@angular/core';
3
4
  import { BehaviorSubject, Subscription } from 'rxjs';
@@ -56,7 +57,8 @@ export class PaginationComponent {
56
57
  this.pageControl?.setValue(page.page);
57
58
  this._paginationHeadService._updateHead(page.page);
58
59
  if (this.pageChangeScrollAnchor) {
59
- this.pageChangeScrollAnchor.scrollIntoView();
60
+ const el = coerceElement(this.pageChangeScrollAnchor);
61
+ el?.scrollIntoView();
60
62
  }
61
63
  }
62
64
  _subscribeToPageControlChanges() {
@@ -102,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
102
104
  }], pageChangeScrollAnchor: [{
103
105
  type: Input
104
106
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/pagination/components/pagination/pagination.component.ts","../../../../../../../../../libs/cdk/src/lib/components/pagination/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n  TrackByFunction,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  numberAttribute,\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { PaginationLinkDirective } from '../../partials';\nimport { PaginationHeadService } from '../../services';\nimport { PaginationItem } from '../../types';\nimport { paginate } from '../../utils';\n\n@Component({\n  selector: 'et-pagination',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgForOf, AsyncPipe, NgIf, PaginationLinkDirective],\n  providers: [PaginationHeadService],\n  host: {\n    class: 'et-pagination',\n  },\n})\nexport class PaginationComponent implements OnInit, OnDestroy {\n  private _pageControlSubscription = Subscription.EMPTY;\n  private _paginationHeadService = inject(PaginationHeadService);\n\n  @Input()\n  get pageControl() {\n    return this._pageControl;\n  }\n  set pageControl(v: FormControl<number | null> | null) {\n    this._pageControl = v;\n    this._updatePages();\n    this._subscribeToPageControlChanges();\n  }\n  private _pageControl: FormControl<number | null> | null = null;\n\n  @Input()\n  get totalPages(): number {\n    return this._totalPages;\n  }\n  set totalPages(value: unknown) {\n    this._totalPages = numberAttribute(value, 0);\n    this._updatePages();\n  }\n  private _totalPages = 0;\n\n  @Input()\n  set headTitleTemplate(v: string | null) {\n    this._paginationHeadService.titleTemplate = v;\n    this._updateHead();\n  }\n\n  @Input()\n  set headFirstPageTitle(v: string | null) {\n    this._paginationHeadService.firstPageTitle = v;\n    this._updateHead();\n  }\n\n  @Input({ transform: booleanAttribute })\n  set headAddCanonicalTag(v: boolean) {\n    this._paginationHeadService.addCanonicalTag = v;\n    this._updateHead();\n  }\n\n  @Input()\n  ariaLabel = 'Pagination';\n\n  @Input()\n  pageChangeScrollAnchor: HTMLElement | null = null;\n\n  protected pages$ = new BehaviorSubject<PaginationItem[] | null>(null);\n\n  protected trackByPage: TrackByFunction<PaginationItem> = (index) => index;\n\n  ngOnInit(): void {\n    this._updateHead();\n  }\n\n  ngOnDestroy(): void {\n    this._pageControlSubscription.unsubscribe();\n  }\n\n  protected onPageClick(page: PaginationItem) {\n    if (page.disabled || page.current) {\n      return;\n    }\n\n    this.pageControl?.setValue(page.page);\n    this._paginationHeadService._updateHead(page.page);\n\n    if (this.pageChangeScrollAnchor) {\n      this.pageChangeScrollAnchor.scrollIntoView();\n    }\n  }\n\n  private _subscribeToPageControlChanges() {\n    this._pageControlSubscription.unsubscribe();\n\n    if (!this.pageControl) {\n      return;\n    }\n\n    this._pageControlSubscription = this.pageControl?.valueChanges.subscribe(() => this._updatePages());\n  }\n\n  private _updatePages() {\n    if (!this.pageControl?.value || !this.totalPages) {\n      this.pages$.next(null);\n      return;\n    }\n\n    this.pages$.next(paginate({ currentPage: this.pageControl.value, totalPageCount: this.totalPages }));\n  }\n\n  private _updateHead() {\n    if (this.pageControl?.value) {\n      this._paginationHeadService._updateHead(this.pageControl.value);\n    }\n  }\n}\n","<nav *ngIf=\"pages$ | async as pages\" [attr.aria-label]=\"ariaLabel\" class=\"et-pagination-nav\">\n  <ul class=\"et-pagination-list\">\n    <li\n      *ngFor=\"let page of pages; trackBy: trackByPage\"\n      [class.et-pagination-hot-link]=\"page.type === 'hotLink'\"\n      [class.et-pagination-page-link]=\"page.type === 'page'\"\n      [class.et-pagination-item-disabled]=\"page.disabled\"\n      class=\"et-pagination-list-item et-pagination-{{ page.explicitType }}\"\n    >\n      <a\n        [attr.aria-current]=\"page.current ? 'page' : null\"\n        [attr.aria-label]=\"page.ariaLabel\"\n        [attr.aria-disabled]=\"page.disabled ? 'true' : null\"\n        [etPaginationLink]=\"page\"\n        [href]=\"page.disabled ? '#' : page.url\"\n        (pageClick)=\"onPageClick($event)\"\n        class=\"et-pagination-anchor\"\n      >\n        <ng-container *ngIf=\"page.type === 'page'\">\n          {{ page.page }}\n        </ng-container>\n      </a>\n    </li>\n  </ul>\n</nav>\n"]}
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/pagination/components/pagination/pagination.component.ts","../../../../../../../../../libs/cdk/src/lib/components/pagination/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceElement } from '@angular/cdk/coercion';\nimport { AsyncPipe, NgForOf, NgIf } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  TrackByFunction,\n  ViewEncapsulation,\n  booleanAttribute,\n  inject,\n  numberAttribute,\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { PaginationLinkDirective } from '../../partials';\nimport { PaginationHeadService } from '../../services';\nimport { PaginationItem } from '../../types';\nimport { paginate } from '../../utils';\n\n@Component({\n  selector: 'et-pagination',\n  templateUrl: './pagination.component.html',\n  styleUrls: ['./pagination.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [NgForOf, AsyncPipe, NgIf, PaginationLinkDirective],\n  providers: [PaginationHeadService],\n  host: {\n    class: 'et-pagination',\n  },\n})\nexport class PaginationComponent implements OnInit, OnDestroy {\n  private _pageControlSubscription = Subscription.EMPTY;\n  private _paginationHeadService = inject(PaginationHeadService);\n\n  @Input()\n  get pageControl() {\n    return this._pageControl;\n  }\n  set pageControl(v: FormControl<number | null> | null) {\n    this._pageControl = v;\n    this._updatePages();\n    this._subscribeToPageControlChanges();\n  }\n  private _pageControl: FormControl<number | null> | null = null;\n\n  @Input()\n  get totalPages(): number {\n    return this._totalPages;\n  }\n  set totalPages(value: unknown) {\n    this._totalPages = numberAttribute(value, 0);\n    this._updatePages();\n  }\n  private _totalPages = 0;\n\n  @Input()\n  set headTitleTemplate(v: string | null) {\n    this._paginationHeadService.titleTemplate = v;\n    this._updateHead();\n  }\n\n  @Input()\n  set headFirstPageTitle(v: string | null) {\n    this._paginationHeadService.firstPageTitle = v;\n    this._updateHead();\n  }\n\n  @Input({ transform: booleanAttribute })\n  set headAddCanonicalTag(v: boolean) {\n    this._paginationHeadService.addCanonicalTag = v;\n    this._updateHead();\n  }\n\n  @Input()\n  ariaLabel = 'Pagination';\n\n  @Input()\n  pageChangeScrollAnchor: HTMLElement | ElementRef<HTMLElement> | null = null;\n\n  protected pages$ = new BehaviorSubject<PaginationItem[] | null>(null);\n\n  protected trackByPage: TrackByFunction<PaginationItem> = (index) => index;\n\n  ngOnInit(): void {\n    this._updateHead();\n  }\n\n  ngOnDestroy(): void {\n    this._pageControlSubscription.unsubscribe();\n  }\n\n  protected onPageClick(page: PaginationItem) {\n    if (page.disabled || page.current) {\n      return;\n    }\n\n    this.pageControl?.setValue(page.page);\n    this._paginationHeadService._updateHead(page.page);\n\n    if (this.pageChangeScrollAnchor) {\n      const el = coerceElement(this.pageChangeScrollAnchor);\n      el?.scrollIntoView();\n    }\n  }\n\n  private _subscribeToPageControlChanges() {\n    this._pageControlSubscription.unsubscribe();\n\n    if (!this.pageControl) {\n      return;\n    }\n\n    this._pageControlSubscription = this.pageControl?.valueChanges.subscribe(() => this._updatePages());\n  }\n\n  private _updatePages() {\n    if (!this.pageControl?.value || !this.totalPages) {\n      this.pages$.next(null);\n      return;\n    }\n\n    this.pages$.next(paginate({ currentPage: this.pageControl.value, totalPageCount: this.totalPages }));\n  }\n\n  private _updateHead() {\n    if (this.pageControl?.value) {\n      this._paginationHeadService._updateHead(this.pageControl.value);\n    }\n  }\n}\n","<nav *ngIf=\"pages$ | async as pages\" [attr.aria-label]=\"ariaLabel\" class=\"et-pagination-nav\">\n  <ul class=\"et-pagination-list\">\n    <li\n      *ngFor=\"let page of pages; trackBy: trackByPage\"\n      [class.et-pagination-hot-link]=\"page.type === 'hotLink'\"\n      [class.et-pagination-page-link]=\"page.type === 'page'\"\n      [class.et-pagination-item-disabled]=\"page.disabled\"\n      class=\"et-pagination-list-item et-pagination-{{ page.explicitType }}\"\n    >\n      <a\n        [attr.aria-current]=\"page.current ? 'page' : null\"\n        [attr.aria-label]=\"page.ariaLabel\"\n        [attr.aria-disabled]=\"page.disabled ? 'true' : null\"\n        [etPaginationLink]=\"page\"\n        [href]=\"page.disabled ? '#' : page.url\"\n        (pageClick)=\"onPageClick($event)\"\n        class=\"et-pagination-anchor\"\n      >\n        <ng-container *ngIf=\"page.type === 'page'\">\n          {{ page.page }}\n        </ng-container>\n      </a>\n    </li>\n  </ul>\n</nav>\n"]}