@ethlete/cdk 4.37.1 → 4.37.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
# @ethlete/cdk
|
|
2
2
|
|
|
3
|
+
## 4.37.2
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- [`2df2e5a`](https://github.com/ethlete-io/ethdk/commit/2df2e5a3d6ed600ddc6bfb8533675bfa14d314d4) Thanks [@TomTomB](https://github.com/TomTomB)! - Fix sortable state not updating if the bound form control value changes
|
|
8
|
+
|
|
3
9
|
## 4.37.1
|
|
4
10
|
|
|
5
11
|
### Patch Changes
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { Directive, EventEmitter, InjectionToken, Input, Output, booleanAttribute, inject, } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
-
import {
|
|
3
|
+
import { createDestroy } from '@ethlete/core';
|
|
4
|
+
import { Observable, Subject, takeUntil } from 'rxjs';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
export const SORT_DEFAULT_OPTIONS = new InjectionToken('SortDefaultOptions');
|
|
6
7
|
export class SortDirective {
|
|
7
8
|
constructor() {
|
|
9
|
+
this.destroy$ = createDestroy();
|
|
8
10
|
this._defaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });
|
|
9
11
|
this.sortables = new Map();
|
|
10
12
|
this._stateChanges = new Subject();
|
|
@@ -73,6 +75,49 @@ export class SortDirective {
|
|
|
73
75
|
this.active = this.sortByControl.value;
|
|
74
76
|
this.direction = this.sortDirectionControl.value;
|
|
75
77
|
}
|
|
78
|
+
if (this.sortControl) {
|
|
79
|
+
this.sortControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
80
|
+
if (value) {
|
|
81
|
+
if (this.active !== value.active) {
|
|
82
|
+
this.active = value.active;
|
|
83
|
+
}
|
|
84
|
+
if (this.direction !== value.direction) {
|
|
85
|
+
this.direction = value.direction;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
this.active = undefined;
|
|
90
|
+
this.direction = '';
|
|
91
|
+
}
|
|
92
|
+
this._stateChanges.next();
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
if (this.sortByControl) {
|
|
96
|
+
this.sortByControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
97
|
+
if (value) {
|
|
98
|
+
if (this.active !== value) {
|
|
99
|
+
this.active = value;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
this.active = undefined;
|
|
104
|
+
}
|
|
105
|
+
this._stateChanges.next();
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
if (this.sortDirectionControl) {
|
|
109
|
+
this.sortDirectionControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
110
|
+
if (value) {
|
|
111
|
+
if (this.direction !== value) {
|
|
112
|
+
this.direction = value;
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.direction = '';
|
|
117
|
+
}
|
|
118
|
+
this._stateChanges.next();
|
|
119
|
+
});
|
|
120
|
+
}
|
|
76
121
|
}
|
|
77
122
|
ngOnChanges() {
|
|
78
123
|
this._stateChanges.next();
|
|
@@ -136,4 +181,4 @@ function getSortDirectionCycle(start, disableClear) {
|
|
|
136
181
|
}
|
|
137
182
|
return sortOrder;
|
|
138
183
|
}
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort.directive.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/sort/partials/sort/sort.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  InjectionToken,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { Observable, Subject, Subscriber } from 'rxjs';\nimport { SortDirection } from '../../types';\nimport { Sort, SortDefaultOptions, Sortable } from './sort.types';\n\nexport const SORT_DEFAULT_OPTIONS = new InjectionToken<SortDefaultOptions>('SortDefaultOptions');\n\n@Directive({\n  selector: '[etSort]',\n  exportAs: 'etSort',\n  host: { class: 'et-sort' },\n  standalone: true,\n})\nexport class SortDirective implements OnChanges, OnDestroy, OnInit {\n  private readonly _defaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });\n\n  sortables = new Map<string, Sortable>();\n\n  readonly _stateChanges = new Subject<void>();\n\n  _isInitialized = false;\n\n  _pendingSubscribers: Subscriber<void>[] | null = [];\n\n  initialized = new Observable<void>((subscriber) => {\n    if (this._isInitialized) {\n      this._notifySubscriber(subscriber);\n    } else {\n      this._pendingSubscribers?.push(subscriber);\n    }\n  });\n\n  @Input({ alias: 'etSortDisabled', transform: booleanAttribute })\n  disabled = false;\n\n  @Input('etSortActive')\n  active?: string;\n\n  @Input('etSortStart')\n  start: SortDirection = 'asc';\n\n  @Input('etSortDirection')\n  get direction(): SortDirection {\n    return this._direction;\n  }\n  set direction(direction: SortDirection) {\n    this._direction = direction;\n  }\n  private _direction: SortDirection = '';\n\n  @Input({ alias: 'etSortDisableClear', transform: booleanAttribute })\n  disableClear = false;\n\n  @Input()\n  sortControl?: FormControl<Sort | null>;\n\n  @Input()\n  sortByControl?: FormControl<string | null>;\n\n  @Input()\n  sortDirectionControl?: FormControl<SortDirection | null>;\n\n  // eslint-disable-next-line @angular-eslint/no-output-rename\n  @Output('etSortChange')\n  readonly sortChange: EventEmitter<Sort> = new EventEmitter<Sort>();\n\n  register(sortable: Sortable): void {\n    this.sortables.set(sortable.id, sortable);\n  }\n\n  deregister(sortable: Sortable): void {\n    this.sortables.delete(sortable.id);\n  }\n\n  sort(sortable: Sortable): void {\n    if (this.active != sortable.id) {\n      this.active = sortable.id;\n      this.direction = sortable.start ? sortable.start : this.start;\n    } else {\n      this.direction = this.getNextSortDirection(sortable);\n    }\n\n    const sort: Sort = { active: this.active, direction: this.direction };\n\n    this.sortChange.emit(sort);\n    this.sortControl?.setValue(sort);\n    this.sortByControl?.setValue(sort.active);\n    this.sortDirectionControl?.setValue(sort.direction);\n  }\n\n  getNextSortDirection(sortable: Sortable): SortDirection {\n    if (!sortable) {\n      return '';\n    }\n\n    const disableClear = sortable?.disableClear ?? this.disableClear ?? !!this._defaultOptions?.disableClear;\n    const sortDirectionCycle = getSortDirectionCycle(sortable.start || this.start, disableClear);\n\n    let nextDirectionIndex = sortDirectionCycle.indexOf(this.direction) + 1;\n    if (nextDirectionIndex >= sortDirectionCycle.length) {\n      nextDirectionIndex = 0;\n    }\n    return sortDirectionCycle[nextDirectionIndex] as SortDirection;\n  }\n\n  ngOnInit() {\n    this._markInitialized();\n\n    if (this.sortControl?.value) {\n      this.active = this.sortControl.value.active;\n      this.direction = this.sortControl.value.direction;\n    } else if (this.sortByControl?.value && this.sortDirectionControl?.value) {\n      this.active = this.sortByControl.value;\n      this.direction = this.sortDirectionControl.value;\n    }\n  }\n\n  ngOnChanges() {\n    this._stateChanges.next();\n  }\n\n  ngOnDestroy() {\n    this._stateChanges.complete();\n  }\n\n  _markInitialized(): void {\n    this._isInitialized = true;\n\n    this._pendingSubscribers?.forEach(this._notifySubscriber);\n    this._pendingSubscribers = null;\n  }\n\n  _notifySubscriber(subscriber: Subscriber<void>): void {\n    subscriber.next();\n    subscriber.complete();\n  }\n}\n\n/** Returns the sort direction cycle to use given the provided parameters of order and clear. */\nfunction getSortDirectionCycle(start: SortDirection, disableClear: boolean): SortDirection[] {\n  const sortOrder: SortDirection[] = ['asc', 'desc'];\n  if (start == 'desc') {\n    sortOrder.reverse();\n  }\n  if (!disableClear) {\n    sortOrder.push('');\n  }\n\n  return sortOrder;\n}\n"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sort.directive.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/sort/partials/sort/sort.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  EventEmitter,\n  InjectionToken,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { createDestroy } from '@ethlete/core';\nimport { Observable, Subject, Subscriber, takeUntil } from 'rxjs';\nimport { SortDirection } from '../../types';\nimport { Sort, SortDefaultOptions, Sortable } from './sort.types';\n\nexport const SORT_DEFAULT_OPTIONS = new InjectionToken<SortDefaultOptions>('SortDefaultOptions');\n\n@Directive({\n  selector: '[etSort]',\n  exportAs: 'etSort',\n  host: { class: 'et-sort' },\n  standalone: true,\n})\nexport class SortDirective implements OnChanges, OnDestroy, OnInit {\n  destroy$ = createDestroy();\n  private readonly _defaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });\n\n  sortables = new Map<string, Sortable>();\n\n  readonly _stateChanges = new Subject<void>();\n\n  _isInitialized = false;\n\n  _pendingSubscribers: Subscriber<void>[] | null = [];\n\n  initialized = new Observable<void>((subscriber) => {\n    if (this._isInitialized) {\n      this._notifySubscriber(subscriber);\n    } else {\n      this._pendingSubscribers?.push(subscriber);\n    }\n  });\n\n  @Input({ alias: 'etSortDisabled', transform: booleanAttribute })\n  disabled = false;\n\n  @Input('etSortActive')\n  active?: string;\n\n  @Input('etSortStart')\n  start: SortDirection = 'asc';\n\n  @Input('etSortDirection')\n  get direction(): SortDirection {\n    return this._direction;\n  }\n  set direction(direction: SortDirection) {\n    this._direction = direction;\n  }\n  private _direction: SortDirection = '';\n\n  @Input({ alias: 'etSortDisableClear', transform: booleanAttribute })\n  disableClear = false;\n\n  @Input()\n  sortControl?: FormControl<Sort | null>;\n\n  @Input()\n  sortByControl?: FormControl<string | null>;\n\n  @Input()\n  sortDirectionControl?: FormControl<SortDirection | null>;\n\n  // eslint-disable-next-line @angular-eslint/no-output-rename\n  @Output('etSortChange')\n  readonly sortChange: EventEmitter<Sort> = new EventEmitter<Sort>();\n\n  register(sortable: Sortable): void {\n    this.sortables.set(sortable.id, sortable);\n  }\n\n  deregister(sortable: Sortable): void {\n    this.sortables.delete(sortable.id);\n  }\n\n  sort(sortable: Sortable): void {\n    if (this.active != sortable.id) {\n      this.active = sortable.id;\n      this.direction = sortable.start ? sortable.start : this.start;\n    } else {\n      this.direction = this.getNextSortDirection(sortable);\n    }\n\n    const sort: Sort = { active: this.active, direction: this.direction };\n\n    this.sortChange.emit(sort);\n    this.sortControl?.setValue(sort);\n    this.sortByControl?.setValue(sort.active);\n    this.sortDirectionControl?.setValue(sort.direction);\n  }\n\n  getNextSortDirection(sortable: Sortable): SortDirection {\n    if (!sortable) {\n      return '';\n    }\n\n    const disableClear = sortable?.disableClear ?? this.disableClear ?? !!this._defaultOptions?.disableClear;\n    const sortDirectionCycle = getSortDirectionCycle(sortable.start || this.start, disableClear);\n\n    let nextDirectionIndex = sortDirectionCycle.indexOf(this.direction) + 1;\n    if (nextDirectionIndex >= sortDirectionCycle.length) {\n      nextDirectionIndex = 0;\n    }\n    return sortDirectionCycle[nextDirectionIndex] as SortDirection;\n  }\n\n  ngOnInit() {\n    this._markInitialized();\n\n    if (this.sortControl?.value) {\n      this.active = this.sortControl.value.active;\n      this.direction = this.sortControl.value.direction;\n    } else if (this.sortByControl?.value && this.sortDirectionControl?.value) {\n      this.active = this.sortByControl.value;\n      this.direction = this.sortDirectionControl.value;\n    }\n\n    if (this.sortControl) {\n      this.sortControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {\n        if (value) {\n          if (this.active !== value.active) {\n            this.active = value.active;\n          }\n\n          if (this.direction !== value.direction) {\n            this.direction = value.direction;\n          }\n        } else {\n          this.active = undefined;\n          this.direction = '';\n        }\n\n        this._stateChanges.next();\n      });\n    }\n\n    if (this.sortByControl) {\n      this.sortByControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {\n        if (value) {\n          if (this.active !== value) {\n            this.active = value;\n          }\n        } else {\n          this.active = undefined;\n        }\n\n        this._stateChanges.next();\n      });\n    }\n\n    if (this.sortDirectionControl) {\n      this.sortDirectionControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {\n        if (value) {\n          if (this.direction !== value) {\n            this.direction = value;\n          }\n        } else {\n          this.direction = '';\n        }\n\n        this._stateChanges.next();\n      });\n    }\n  }\n\n  ngOnChanges() {\n    this._stateChanges.next();\n  }\n\n  ngOnDestroy() {\n    this._stateChanges.complete();\n  }\n\n  _markInitialized(): void {\n    this._isInitialized = true;\n\n    this._pendingSubscribers?.forEach(this._notifySubscriber);\n    this._pendingSubscribers = null;\n  }\n\n  _notifySubscriber(subscriber: Subscriber<void>): void {\n    subscriber.next();\n    subscriber.complete();\n  }\n}\n\n/** Returns the sort direction cycle to use given the provided parameters of order and clear. */\nfunction getSortDirectionCycle(start: SortDirection, disableClear: boolean): SortDirection[] {\n  const sortOrder: SortDirection[] = ['asc', 'desc'];\n  if (start == 'desc') {\n    sortOrder.reverse();\n  }\n  if (!disableClear) {\n    sortOrder.push('');\n  }\n\n  return sortOrder;\n}\n"]}
|
package/fesm2022/ethlete-cdk.mjs
CHANGED
|
@@ -15591,6 +15591,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
|
15591
15591
|
const SORT_DEFAULT_OPTIONS = new InjectionToken('SortDefaultOptions');
|
|
15592
15592
|
class SortDirective {
|
|
15593
15593
|
constructor() {
|
|
15594
|
+
this.destroy$ = createDestroy();
|
|
15594
15595
|
this._defaultOptions = inject(SORT_DEFAULT_OPTIONS, { optional: true });
|
|
15595
15596
|
this.sortables = new Map();
|
|
15596
15597
|
this._stateChanges = new Subject();
|
|
@@ -15659,6 +15660,49 @@ class SortDirective {
|
|
|
15659
15660
|
this.active = this.sortByControl.value;
|
|
15660
15661
|
this.direction = this.sortDirectionControl.value;
|
|
15661
15662
|
}
|
|
15663
|
+
if (this.sortControl) {
|
|
15664
|
+
this.sortControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
15665
|
+
if (value) {
|
|
15666
|
+
if (this.active !== value.active) {
|
|
15667
|
+
this.active = value.active;
|
|
15668
|
+
}
|
|
15669
|
+
if (this.direction !== value.direction) {
|
|
15670
|
+
this.direction = value.direction;
|
|
15671
|
+
}
|
|
15672
|
+
}
|
|
15673
|
+
else {
|
|
15674
|
+
this.active = undefined;
|
|
15675
|
+
this.direction = '';
|
|
15676
|
+
}
|
|
15677
|
+
this._stateChanges.next();
|
|
15678
|
+
});
|
|
15679
|
+
}
|
|
15680
|
+
if (this.sortByControl) {
|
|
15681
|
+
this.sortByControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
15682
|
+
if (value) {
|
|
15683
|
+
if (this.active !== value) {
|
|
15684
|
+
this.active = value;
|
|
15685
|
+
}
|
|
15686
|
+
}
|
|
15687
|
+
else {
|
|
15688
|
+
this.active = undefined;
|
|
15689
|
+
}
|
|
15690
|
+
this._stateChanges.next();
|
|
15691
|
+
});
|
|
15692
|
+
}
|
|
15693
|
+
if (this.sortDirectionControl) {
|
|
15694
|
+
this.sortDirectionControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe((value) => {
|
|
15695
|
+
if (value) {
|
|
15696
|
+
if (this.direction !== value) {
|
|
15697
|
+
this.direction = value;
|
|
15698
|
+
}
|
|
15699
|
+
}
|
|
15700
|
+
else {
|
|
15701
|
+
this.direction = '';
|
|
15702
|
+
}
|
|
15703
|
+
this._stateChanges.next();
|
|
15704
|
+
});
|
|
15705
|
+
}
|
|
15662
15706
|
}
|
|
15663
15707
|
ngOnChanges() {
|
|
15664
15708
|
this._stateChanges.next();
|