@spartan-ng/brain 0.0.1-alpha.412 → 0.0.1-alpha.414
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/select/index.mjs +15 -5
- package/esm2022/select/lib/brn-select-content.component.mjs +64 -45
- package/esm2022/select/lib/brn-select-content.token.mjs +9 -0
- package/esm2022/select/lib/brn-select-option.directive.mjs +49 -45
- package/esm2022/select/lib/brn-select-placeholder.directive.mjs +16 -0
- package/esm2022/select/lib/brn-select-trigger.directive.mjs +67 -0
- package/esm2022/select/lib/brn-select-value.component.mjs +58 -36
- package/esm2022/select/lib/brn-select-value.directive.mjs +16 -0
- package/esm2022/select/lib/brn-select.component.mjs +104 -178
- package/esm2022/select/lib/brn-select.token.mjs +9 -0
- package/fesm2022/spartan-ng-brain-select.mjs +378 -497
- package/fesm2022/spartan-ng-brain-select.mjs.map +1 -1
- package/package.json +1 -1
- package/select/index.d.ts +11 -5
- package/select/lib/brn-select-content.component.d.ts +17 -19
- package/select/lib/brn-select-content.token.d.ts +4 -0
- package/select/lib/brn-select-option.directive.d.ts +19 -19
- package/select/lib/brn-select-placeholder.directive.d.ts +8 -0
- package/select/lib/brn-select-trigger.directive.d.ts +20 -0
- package/select/lib/brn-select-value.component.d.ts +13 -6
- package/select/lib/brn-select-value.directive.d.ts +11 -0
- package/select/lib/brn-select.component.d.ts +38 -49
- package/select/lib/brn-select.token.d.ts +4 -0
- package/esm2022/select/lib/brn-select.service.mjs +0 -207
- package/select/lib/brn-select.service.d.ts +0 -71
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { BooleanInput, NumberInput } from '@angular/cdk/coercion';
|
|
2
2
|
import { CdkConnectedOverlay, type ConnectedOverlayPositionChange, type ConnectedPosition } from '@angular/cdk/overlay';
|
|
3
|
-
import {
|
|
3
|
+
import { type DoCheck, type Signal } from '@angular/core';
|
|
4
4
|
import { type ControlValueAccessor, NgControl } from '@angular/forms';
|
|
5
5
|
import { type ExposesSide, type ExposesState } from '@spartan-ng/brain/core';
|
|
6
6
|
import { BrnFormFieldControl } from '@spartan-ng/brain/form-field';
|
|
@@ -8,72 +8,61 @@ import { ChangeFn, ErrorStateTracker, TouchFn } from '@spartan-ng/brain/forms';
|
|
|
8
8
|
import { BrnLabelDirective } from '@spartan-ng/brain/label';
|
|
9
9
|
import { Subject } from 'rxjs';
|
|
10
10
|
import { BrnSelectContentComponent } from './brn-select-content.component';
|
|
11
|
+
import { BrnSelectOptionDirective } from './brn-select-option.directive';
|
|
12
|
+
import { BrnSelectTriggerDirective } from './brn-select-trigger.directive';
|
|
11
13
|
import * as i0 from "@angular/core";
|
|
12
14
|
export type BrnReadDirection = 'ltr' | 'rtl';
|
|
13
|
-
export declare class BrnSelectComponent<T = unknown> implements ControlValueAccessor,
|
|
14
|
-
private readonly
|
|
15
|
-
readonly
|
|
16
|
-
readonly
|
|
15
|
+
export declare class BrnSelectComponent<T = unknown> implements ControlValueAccessor, DoCheck, ExposesSide, ExposesState, BrnFormFieldControl {
|
|
16
|
+
private readonly _defaultErrorStateMatcher;
|
|
17
|
+
private readonly _parentForm;
|
|
18
|
+
private readonly _injector;
|
|
19
|
+
private readonly _parentFormGroup;
|
|
20
|
+
readonly ngControl: NgControl | null;
|
|
21
|
+
readonly id: import("@angular/core").InputSignal<string>;
|
|
22
|
+
readonly multiple: import("@angular/core").InputSignalWithTransform<boolean, BooleanInput>;
|
|
17
23
|
readonly placeholder: import("@angular/core").InputSignal<string>;
|
|
18
|
-
readonly disabled: import("@angular/core").
|
|
24
|
+
readonly disabled: import("@angular/core").InputSignalWithTransform<boolean, BooleanInput>;
|
|
19
25
|
readonly dir: import("@angular/core").InputSignal<BrnReadDirection>;
|
|
20
|
-
|
|
21
|
-
|
|
26
|
+
readonly closeDelay: import("@angular/core").InputSignalWithTransform<number, NumberInput>;
|
|
27
|
+
readonly open: import("@angular/core").ModelSignal<boolean>;
|
|
28
|
+
readonly value: import("@angular/core").ModelSignal<T | T[] | undefined>;
|
|
29
|
+
readonly compareWith: import("@angular/core").InputSignal<(o1: T, o2: T) => boolean>;
|
|
30
|
+
readonly _formDisabled: import("@angular/core").WritableSignal<boolean>;
|
|
31
|
+
/** Label provided by the consumer. */
|
|
32
|
+
protected readonly selectLabel: Signal<BrnLabelDirective | undefined>;
|
|
22
33
|
/** Overlay pane containing the options. */
|
|
23
|
-
protected selectContent: Signal<BrnSelectContentComponent
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
34
|
+
protected readonly selectContent: Signal<BrnSelectContentComponent<any>>;
|
|
35
|
+
/** @internal */
|
|
36
|
+
readonly options: Signal<readonly BrnSelectOptionDirective<any>[]>;
|
|
37
|
+
/** @internal Derive the selected options to filter out the unselected options */
|
|
38
|
+
readonly selectedOptions: Signal<BrnSelectOptionDirective<any>[]>;
|
|
27
39
|
/** Overlay pane containing the options. */
|
|
28
|
-
protected _overlayDir: Signal<CdkConnectedOverlay
|
|
29
|
-
readonly
|
|
30
|
-
readonly
|
|
40
|
+
protected readonly _overlayDir: Signal<CdkConnectedOverlay>;
|
|
41
|
+
readonly trigger: import("@angular/core").WritableSignal<BrnSelectTriggerDirective<T> | null>;
|
|
42
|
+
readonly triggerWidth: import("@angular/core").WritableSignal<number>;
|
|
31
43
|
protected readonly _delayedExpanded: Signal<boolean>;
|
|
32
44
|
readonly state: Signal<"open" | "closed">;
|
|
33
|
-
readonly openedChange: import("@angular/core").OutputEmitterRef<boolean>;
|
|
34
|
-
readonly valueChange: import("@angular/core").OutputEmitterRef<T>;
|
|
35
45
|
protected readonly _positionChanges$: Subject<ConnectedOverlayPositionChange>;
|
|
36
46
|
readonly side: Signal<'top' | 'bottom' | 'left' | 'right'>;
|
|
37
|
-
readonly
|
|
38
|
-
readonly labelProvided: import("@angular/core").WritableSignal<boolean>;
|
|
39
|
-
readonly ngControl: NgControl | null;
|
|
47
|
+
readonly labelId: Signal<string | import("@angular/core").InputSignal<string>>;
|
|
40
48
|
private _onChange;
|
|
41
49
|
private _onTouched;
|
|
42
|
-
private readonly _shouldEmitValueChange;
|
|
43
50
|
protected _positions: ConnectedPosition[];
|
|
44
51
|
errorStateTracker: ErrorStateTracker;
|
|
45
|
-
|
|
46
|
-
private readonly _parentForm;
|
|
47
|
-
private readonly _parentFormGroup;
|
|
48
|
-
errorState: Signal<boolean>;
|
|
49
|
-
writeValue$: Subject<T>;
|
|
52
|
+
readonly errorState: Signal<boolean>;
|
|
50
53
|
constructor();
|
|
51
|
-
ngAfterContentInit(): void;
|
|
52
54
|
ngDoCheck(): void;
|
|
53
55
|
toggle(): void;
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
protected _canOpen(): boolean;
|
|
57
|
-
private _moveFocusToCDKList;
|
|
56
|
+
show(): void;
|
|
57
|
+
hide(): void;
|
|
58
58
|
writeValue(value: T): void;
|
|
59
|
-
registerOnChange(fn: ChangeFn<T>): void;
|
|
59
|
+
registerOnChange(fn: ChangeFn<T | T[]>): void;
|
|
60
60
|
registerOnTouched(fn: TouchFn): void;
|
|
61
61
|
setDisabledState(isDisabled: boolean): void;
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
private handleInitialOptionSelect;
|
|
67
|
-
/**
|
|
68
|
-
* When options change, our current selected options may become invalid
|
|
69
|
-
* Here we will automatically update our current selected options so that they are always inline with the possibleOptions
|
|
70
|
-
* @private
|
|
71
|
-
*/
|
|
72
|
-
private handleOptionChanges;
|
|
73
|
-
/**
|
|
74
|
-
* Check that our "selectedOptions" are still valid when "possibleOptions" is about to be updated
|
|
75
|
-
*/
|
|
76
|
-
private handleInvalidOptions;
|
|
62
|
+
selectOption(value: T): void;
|
|
63
|
+
deselectOption(value: T): void;
|
|
64
|
+
toggleSelect(value: T): void;
|
|
65
|
+
isSelected(value: T): boolean;
|
|
77
66
|
static ɵfac: i0.ɵɵFactoryDeclaration<BrnSelectComponent<any>, never>;
|
|
78
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<BrnSelectComponent<any>, "brn-select, hlm-select", never, { "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "dir": { "alias": "dir"; "required": false; "isSignal": true; }; "closeDelay": { "alias": "closeDelay"; "required": false; "isSignal": true; }; }, { "
|
|
67
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<BrnSelectComponent<any>, "brn-select, hlm-select", never, { "id": { "alias": "id"; "required": false; "isSignal": true; }; "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; "placeholder": { "alias": "placeholder"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "dir": { "alias": "dir"; "required": false; "isSignal": true; }; "closeDelay": { "alias": "closeDelay"; "required": false; "isSignal": true; }; "open": { "alias": "open"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "compareWith": { "alias": "compareWith"; "required": false; "isSignal": true; }; }, { "open": "openChange"; "value": "valueChange"; }, ["selectLabel", "selectContent", "options"], ["label[hlmLabel],label[brnLabel]", "hlm-select-trigger,[brnSelectTrigger]", "*"], true, never>;
|
|
79
68
|
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { ExistingProvider, Type } from '@angular/core';
|
|
2
|
+
import type { BrnSelectComponent } from './brn-select.component';
|
|
3
|
+
export declare function injectBrnSelect<T>(): BrnSelectComponent<T>;
|
|
4
|
+
export declare function provideBrnSelect(select: Type<BrnSelectComponent>): ExistingProvider;
|
|
@@ -1,207 +0,0 @@
|
|
|
1
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
2
|
-
import { Directive, ElementRef, Injectable, PLATFORM_ID, computed, inject, signal, } from '@angular/core';
|
|
3
|
-
import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
|
|
4
|
-
import { NgControl } from '@angular/forms';
|
|
5
|
-
import { Subject } from 'rxjs';
|
|
6
|
-
import { skip } from 'rxjs/operators';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export class BrnSelectTriggerDirective {
|
|
9
|
-
_el = inject(ElementRef);
|
|
10
|
-
_selectService = inject(BrnSelectService);
|
|
11
|
-
_ngControl = inject(NgControl, { optional: true });
|
|
12
|
-
_platform = inject(PLATFORM_ID);
|
|
13
|
-
isExpanded = this._selectService.isExpanded;
|
|
14
|
-
selectTriggerId = computed(() => `${this._selectService.id()}--trigger`);
|
|
15
|
-
selectContentId = computed(() => `${this._selectService.id()}--content`);
|
|
16
|
-
selectDisable = computed(() => this._selectService.disabled());
|
|
17
|
-
selectTriggerLabelledBy = computed(() => {
|
|
18
|
-
if (this._selectService.value() && this._selectService.value().length > 0) {
|
|
19
|
-
return `${this._selectService.labelId()} ${this._selectService.id()}--value`;
|
|
20
|
-
}
|
|
21
|
-
return this._selectService.labelId();
|
|
22
|
-
});
|
|
23
|
-
_resizeObserver;
|
|
24
|
-
constructor() {
|
|
25
|
-
if (!this._selectService)
|
|
26
|
-
return;
|
|
27
|
-
this._selectService._setSelectTrigger(this);
|
|
28
|
-
}
|
|
29
|
-
ngAfterViewInit() {
|
|
30
|
-
this._selectService.setTriggerWidth(this._el.nativeElement.offsetWidth);
|
|
31
|
-
// if we are on the client, listen for element resize events
|
|
32
|
-
if (isPlatformBrowser(this._platform)) {
|
|
33
|
-
this._resizeObserver = new ResizeObserver(() => this._selectService.setTriggerWidth(this._el.nativeElement.offsetWidth));
|
|
34
|
-
this._resizeObserver.observe(this._el.nativeElement);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
ngOnDestroy() {
|
|
38
|
-
this._resizeObserver?.disconnect();
|
|
39
|
-
}
|
|
40
|
-
focus() {
|
|
41
|
-
this._el.nativeElement.focus();
|
|
42
|
-
}
|
|
43
|
-
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: BrnSelectTriggerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
44
|
-
/** @nocollapse */ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.5", type: BrnSelectTriggerDirective, isStandalone: true, selector: "[brnSelectTrigger]", host: { attributes: { "role": "combobox", "aria-autocomplete": "none", "type": "button" }, properties: { "attr.id": "selectTriggerId()", "disabled": "selectDisable()", "attr.aria-expanded": "isExpanded()", "attr.aria-controls": "selectContentId() + ''", "attr.aria-labelledBy": "selectTriggerLabelledBy()", "attr.dir": "_selectService.dir()", "class.ng-invalid": "this._ngControl?.invalid || null", "class.ng-dirty": "this._ngControl?.dirty || null", "class.ng-valid": "this._ngControl?.valid || null", "class.ng-touched": "this._ngControl?.touched || null", "class.ng-untouched": "this._ngControl?.untouched || null", "class.ng-pristine": "this._ngControl?.pristine || null" } }, ngImport: i0 });
|
|
45
|
-
}
|
|
46
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: BrnSelectTriggerDirective, decorators: [{
|
|
47
|
-
type: Directive,
|
|
48
|
-
args: [{
|
|
49
|
-
selector: '[brnSelectTrigger]',
|
|
50
|
-
standalone: true,
|
|
51
|
-
host: {
|
|
52
|
-
role: 'combobox',
|
|
53
|
-
'[attr.id]': 'selectTriggerId()',
|
|
54
|
-
'[disabled]': 'selectDisable()',
|
|
55
|
-
'[attr.aria-expanded]': 'isExpanded()',
|
|
56
|
-
'[attr.aria-controls]': "selectContentId() + ''",
|
|
57
|
-
'[attr.aria-labelledBy]': 'selectTriggerLabelledBy()',
|
|
58
|
-
'aria-autocomplete': 'none',
|
|
59
|
-
'[attr.dir]': '_selectService.dir()',
|
|
60
|
-
'[class.ng-invalid]': 'this._ngControl?.invalid || null',
|
|
61
|
-
'[class.ng-dirty]': 'this._ngControl?.dirty || null',
|
|
62
|
-
'[class.ng-valid]': 'this._ngControl?.valid || null',
|
|
63
|
-
'[class.ng-touched]': 'this._ngControl?.touched || null',
|
|
64
|
-
'[class.ng-untouched]': 'this._ngControl?.untouched || null',
|
|
65
|
-
'[class.ng-pristine]': 'this._ngControl?.pristine || null',
|
|
66
|
-
type: 'button',
|
|
67
|
-
},
|
|
68
|
-
}]
|
|
69
|
-
}], ctorParameters: () => [] });
|
|
70
|
-
export class BrnSelectService {
|
|
71
|
-
state = signal({
|
|
72
|
-
id: '',
|
|
73
|
-
labelId: '',
|
|
74
|
-
panelId: '',
|
|
75
|
-
isExpanded: false,
|
|
76
|
-
placeholder: signal(''),
|
|
77
|
-
multiple: signal(false),
|
|
78
|
-
disabled: signal(false),
|
|
79
|
-
disabledBySetDisabled: signal(false),
|
|
80
|
-
dir: signal('ltr'),
|
|
81
|
-
selectedOptions: [],
|
|
82
|
-
possibleOptions: [],
|
|
83
|
-
value: '',
|
|
84
|
-
triggerWidth: 0,
|
|
85
|
-
});
|
|
86
|
-
id = computed(() => this.state().id);
|
|
87
|
-
labelId = computed(() => this.state().labelId);
|
|
88
|
-
panelId = computed(() => this.state().panelId);
|
|
89
|
-
placeholder = computed(() => this.state().placeholder());
|
|
90
|
-
disabled = computed(() => this.state().disabled() || this.state().disabledBySetDisabled());
|
|
91
|
-
isExpanded = computed(() => this.state().isExpanded);
|
|
92
|
-
multiple = computed(() => this.state().multiple());
|
|
93
|
-
dir = computed(() => this.state().dir());
|
|
94
|
-
selectedOptions = computed(() => this.state().selectedOptions);
|
|
95
|
-
value = computed(() => this.state().value);
|
|
96
|
-
triggerWidth = computed(() => this.state().triggerWidth);
|
|
97
|
-
possibleOptions = computed(() => this.state().possibleOptions);
|
|
98
|
-
_multiple$ = toObservable(this.multiple);
|
|
99
|
-
listBoxValueChangeEvent$ = new Subject();
|
|
100
|
-
_selectTrigger;
|
|
101
|
-
get selectTrigger() {
|
|
102
|
-
return this._selectTrigger;
|
|
103
|
-
}
|
|
104
|
-
constructor() {
|
|
105
|
-
this.listBoxValueChangeEvent$.pipe(takeUntilDestroyed()).subscribe((listBoxChange) => {
|
|
106
|
-
const updatedSelections = this.multiple() ? this.getUpdatedOptions(listBoxChange) : [listBoxChange.option];
|
|
107
|
-
const value = this.multiple() ? listBoxChange.value : listBoxChange.value[0];
|
|
108
|
-
this.state.update((state) => ({
|
|
109
|
-
...state,
|
|
110
|
-
selectedOptions: [...updatedSelections],
|
|
111
|
-
value: value,
|
|
112
|
-
}));
|
|
113
|
-
});
|
|
114
|
-
// We need to skip the first value because we don't want to deselect all options when the component is initialized with a preselected value e.g. by the form control
|
|
115
|
-
this._multiple$.pipe(skip(1), takeUntilDestroyed()).subscribe((multiple) => {
|
|
116
|
-
if (!multiple && this.value().length > 1) {
|
|
117
|
-
this.deselectAllOptions();
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
}
|
|
121
|
-
setTriggerWidth(triggerWidth) {
|
|
122
|
-
this.state.update((s) => ({ ...s, triggerWidth }));
|
|
123
|
-
}
|
|
124
|
-
getUpdatedOptions(latestListboxChange) {
|
|
125
|
-
const isNewSelection = latestListboxChange.value.findIndex((value) => value === latestListboxChange.option?.value);
|
|
126
|
-
if (isNewSelection === -1) {
|
|
127
|
-
const removedOptionIndex = this.selectedOptions().findIndex((option) => latestListboxChange.option === option);
|
|
128
|
-
const options = this.selectedOptions();
|
|
129
|
-
options.splice(removedOptionIndex, 1);
|
|
130
|
-
return options;
|
|
131
|
-
}
|
|
132
|
-
return [...this.selectedOptions(), latestListboxChange.option];
|
|
133
|
-
}
|
|
134
|
-
deselectAllOptions() {
|
|
135
|
-
this.state.update((state) => ({
|
|
136
|
-
...state,
|
|
137
|
-
selectedOptions: [],
|
|
138
|
-
value: [],
|
|
139
|
-
}));
|
|
140
|
-
}
|
|
141
|
-
// Needed due to https://github.com/angular/angular/issues/20810
|
|
142
|
-
_setSelectTrigger(trigger) {
|
|
143
|
-
this._selectTrigger = trigger;
|
|
144
|
-
}
|
|
145
|
-
setInitialSelectedOptions(value) {
|
|
146
|
-
this.selectOptionByValue(value);
|
|
147
|
-
this.state.update((state) => ({
|
|
148
|
-
...state,
|
|
149
|
-
value: value,
|
|
150
|
-
initialSelectedOptions: this.selectedOptions(),
|
|
151
|
-
selectedOptions: this.selectedOptions(),
|
|
152
|
-
}));
|
|
153
|
-
}
|
|
154
|
-
/**
|
|
155
|
-
* Sync the updated options with "possibleOptions" in the select service
|
|
156
|
-
*/
|
|
157
|
-
updatePossibleOptions(options) {
|
|
158
|
-
this.state.update((state) => ({
|
|
159
|
-
...state,
|
|
160
|
-
possibleOptions: options,
|
|
161
|
-
}));
|
|
162
|
-
}
|
|
163
|
-
selectOptionByValue(value) {
|
|
164
|
-
const options = this.possibleOptions();
|
|
165
|
-
if (value === null || value === undefined) {
|
|
166
|
-
const nullOrUndefinedOption = options.find((o) => o && o.value === value);
|
|
167
|
-
if (!nullOrUndefinedOption) {
|
|
168
|
-
this.state.update((state) => ({
|
|
169
|
-
...state,
|
|
170
|
-
selectedOptions: [],
|
|
171
|
-
value: this.multiple() ? [] : '',
|
|
172
|
-
}));
|
|
173
|
-
return;
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
if (this.multiple()) {
|
|
177
|
-
const selectedOptions = options.filter((option) => {
|
|
178
|
-
if (Array.isArray(value)) {
|
|
179
|
-
return value.includes(option?.value);
|
|
180
|
-
}
|
|
181
|
-
return value === option?.value;
|
|
182
|
-
});
|
|
183
|
-
this.state.update((state) => ({
|
|
184
|
-
...state,
|
|
185
|
-
selectedOptions,
|
|
186
|
-
value: value,
|
|
187
|
-
}));
|
|
188
|
-
}
|
|
189
|
-
else {
|
|
190
|
-
const selectedOption = options.find((option) => option?.value === value);
|
|
191
|
-
if (!selectedOption) {
|
|
192
|
-
return;
|
|
193
|
-
}
|
|
194
|
-
this.state.update((state) => ({
|
|
195
|
-
...state,
|
|
196
|
-
selectedOptions: [selectedOption],
|
|
197
|
-
value: selectedOption.value,
|
|
198
|
-
}));
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: BrnSelectService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
202
|
-
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: BrnSelectService });
|
|
203
|
-
}
|
|
204
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: BrnSelectService, decorators: [{
|
|
205
|
-
type: Injectable
|
|
206
|
-
}], ctorParameters: () => [] });
|
|
207
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"brn-select.service.js","sourceRoot":"","sources":["../../../../../../libs/brain/select/src/lib/brn-select.service.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CdkOption, ListboxValueChangeEvent } from '@angular/cdk/listbox';\nimport { isPlatformBrowser } from '@angular/common';\nimport {\n\ttype AfterViewInit,\n\tDirective,\n\tElementRef,\n\tInjectable,\n\tOnDestroy,\n\tPLATFORM_ID,\n\tSignal,\n\tcomputed,\n\tinject,\n\tsignal,\n} from '@angular/core';\nimport { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';\nimport { NgControl } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { skip } from 'rxjs/operators';\n\n@Directive({\n\tselector: '[brnSelectTrigger]',\n\tstandalone: true,\n\thost: {\n\t\trole: 'combobox',\n\t\t'[attr.id]': 'selectTriggerId()',\n\t\t'[disabled]': 'selectDisable()',\n\t\t'[attr.aria-expanded]': 'isExpanded()',\n\t\t'[attr.aria-controls]': \"selectContentId() + ''\",\n\t\t'[attr.aria-labelledBy]': 'selectTriggerLabelledBy()',\n\t\t'aria-autocomplete': 'none',\n\t\t'[attr.dir]': '_selectService.dir()',\n\t\t'[class.ng-invalid]': 'this._ngControl?.invalid || null',\n\t\t'[class.ng-dirty]': 'this._ngControl?.dirty || null',\n\t\t'[class.ng-valid]': 'this._ngControl?.valid || null',\n\t\t'[class.ng-touched]': 'this._ngControl?.touched || null',\n\t\t'[class.ng-untouched]': 'this._ngControl?.untouched || null',\n\t\t'[class.ng-pristine]': 'this._ngControl?.pristine || null',\n\t\ttype: 'button',\n\t},\n})\nexport class BrnSelectTriggerDirective implements AfterViewInit, OnDestroy {\n\tprivate readonly _el = inject(ElementRef);\n\tprotected readonly _selectService = inject(BrnSelectService);\n\tprotected readonly _ngControl = inject(NgControl, { optional: true });\n\tprivate readonly _platform = inject(PLATFORM_ID);\n\tpublic readonly isExpanded = this._selectService.isExpanded;\n\tpublic readonly selectTriggerId = computed(() => `${this._selectService.id()}--trigger`);\n\tpublic readonly selectContentId = computed(() => `${this._selectService.id()}--content`);\n\tpublic readonly selectDisable = computed(() => this._selectService.disabled());\n\tpublic readonly selectTriggerLabelledBy = computed(() => {\n\t\tif (this._selectService.value() && this._selectService.value().length > 0) {\n\t\t\treturn `${this._selectService.labelId()} ${this._selectService.id()}--value`;\n\t\t}\n\t\treturn this._selectService.labelId();\n\t});\n\n\tprivate _resizeObserver?: ResizeObserver;\n\n\tconstructor() {\n\t\tif (!this._selectService) return;\n\t\tthis._selectService._setSelectTrigger(this);\n\t}\n\n\tngAfterViewInit() {\n\t\tthis._selectService.setTriggerWidth(this._el.nativeElement.offsetWidth);\n\n\t\t// if we are on the client, listen for element resize events\n\t\tif (isPlatformBrowser(this._platform)) {\n\t\t\tthis._resizeObserver = new ResizeObserver(() =>\n\t\t\t\tthis._selectService.setTriggerWidth(this._el.nativeElement.offsetWidth),\n\t\t\t);\n\n\t\t\tthis._resizeObserver.observe(this._el.nativeElement);\n\t\t}\n\t}\n\n\tngOnDestroy(): void {\n\t\tthis._resizeObserver?.disconnect();\n\t}\n\n\tpublic focus() {\n\t\tthis._el.nativeElement.focus();\n\t}\n}\n\ntype BrnReadDirection = 'ltr' | 'rtl';\n\n@Injectable()\nexport class BrnSelectService {\n\tpublic readonly state = signal<{\n\t\tid: string;\n\t\tlabelId: string;\n\t\tpanelId: string;\n\t\tplaceholder: Signal<string>;\n\t\tisExpanded: boolean;\n\t\tmultiple: Signal<boolean>;\n\t\tdisabled: Signal<boolean>;\n\t\tdisabledBySetDisabled: Signal<boolean>;\n\t\tdir: Signal<BrnReadDirection>;\n\t\tselectedOptions: Array<CdkOption | null>;\n\t\tpossibleOptions: Array<CdkOption | null>;\n\t\tvalue: string | string[];\n\t\ttriggerWidth: number;\n\t}>({\n\t\tid: '',\n\t\tlabelId: '',\n\t\tpanelId: '',\n\t\tisExpanded: false,\n\t\tplaceholder: signal(''),\n\t\tmultiple: signal(false),\n\t\tdisabled: signal(false),\n\t\tdisabledBySetDisabled: signal(false),\n\t\tdir: signal('ltr' as BrnReadDirection),\n\t\tselectedOptions: [],\n\t\tpossibleOptions: [],\n\t\tvalue: '',\n\t\ttriggerWidth: 0,\n\t});\n\n\tpublic readonly id = computed(() => this.state().id);\n\tpublic readonly labelId = computed(() => this.state().labelId);\n\tpublic readonly panelId = computed(() => this.state().panelId);\n\tpublic readonly placeholder = computed(() => this.state().placeholder());\n\tpublic readonly disabled = computed(() => this.state().disabled() || this.state().disabledBySetDisabled());\n\tpublic readonly isExpanded = computed(() => this.state().isExpanded);\n\tpublic readonly multiple = computed(() => this.state().multiple());\n\tpublic readonly dir = computed(() => this.state().dir());\n\tpublic readonly selectedOptions = computed(() => this.state().selectedOptions);\n\tpublic readonly value = computed(() => this.state().value);\n\tpublic readonly triggerWidth = computed(() => this.state().triggerWidth);\n\tpublic readonly possibleOptions = computed(() => this.state().possibleOptions);\n\n\tprivate readonly _multiple$ = toObservable(this.multiple);\n\n\tpublic readonly listBoxValueChangeEvent$ = new Subject<ListboxValueChangeEvent<unknown>>();\n\n\tprivate _selectTrigger?: BrnSelectTriggerDirective;\n\tpublic get selectTrigger() {\n\t\treturn this._selectTrigger;\n\t}\n\n\tconstructor() {\n\t\tthis.listBoxValueChangeEvent$.pipe(takeUntilDestroyed()).subscribe((listBoxChange) => {\n\t\t\tconst updatedSelections = this.multiple() ? this.getUpdatedOptions(listBoxChange) : [listBoxChange.option];\n\t\t\tconst value = this.multiple() ? listBoxChange.value : listBoxChange.value[0];\n\t\t\tthis.state.update((state) => ({\n\t\t\t\t...state,\n\t\t\t\tselectedOptions: [...updatedSelections],\n\t\t\t\tvalue: value as string | string[],\n\t\t\t}));\n\t\t});\n\n\t\t// We need to skip the first value because we don't want to deselect all options when the component is initialized with a preselected value e.g. by the form control\n\t\tthis._multiple$.pipe(skip(1), takeUntilDestroyed()).subscribe((multiple) => {\n\t\t\tif (!multiple && this.value().length > 1) {\n\t\t\t\tthis.deselectAllOptions();\n\t\t\t}\n\t\t});\n\t}\n\n\tpublic setTriggerWidth(triggerWidth: number) {\n\t\tthis.state.update((s) => ({ ...s, triggerWidth }));\n\t}\n\n\tpublic getUpdatedOptions(latestListboxChange: ListboxValueChangeEvent<unknown>): Array<CdkOption | null> {\n\t\tconst isNewSelection = latestListboxChange.value.findIndex((value) => value === latestListboxChange.option?.value);\n\t\tif (isNewSelection === -1) {\n\t\t\tconst removedOptionIndex = this.selectedOptions().findIndex((option) => latestListboxChange.option === option);\n\t\t\tconst options = this.selectedOptions();\n\t\t\toptions.splice(removedOptionIndex, 1);\n\t\t\treturn options;\n\t\t}\n\t\treturn [...this.selectedOptions(), latestListboxChange.option];\n\t}\n\n\tpublic deselectAllOptions() {\n\t\tthis.state.update((state) => ({\n\t\t\t...state,\n\t\t\tselectedOptions: [],\n\t\t\tvalue: [],\n\t\t}));\n\t}\n\n\t// Needed due to https://github.com/angular/angular/issues/20810\n\tpublic _setSelectTrigger(trigger: BrnSelectTriggerDirective) {\n\t\tthis._selectTrigger = trigger;\n\t}\n\n\tpublic setInitialSelectedOptions(value: unknown) {\n\t\tthis.selectOptionByValue(value);\n\t\tthis.state.update((state) => ({\n\t\t\t...state,\n\t\t\tvalue: value as string | string[],\n\t\t\tinitialSelectedOptions: this.selectedOptions(),\n\t\t\tselectedOptions: this.selectedOptions(),\n\t\t}));\n\t}\n\n\t/**\n\t * Sync the updated options with \"possibleOptions\" in the select service\n\t */\n\tpublic updatePossibleOptions(options: readonly CdkOption[]) {\n\t\tthis.state.update((state) => ({\n\t\t\t...state,\n\t\t\tpossibleOptions: options as CdkOption[],\n\t\t}));\n\t}\n\n\tprivate selectOptionByValue(value: unknown) {\n\t\tconst options = this.possibleOptions();\n\t\tif (value === null || value === undefined) {\n\t\t\tconst nullOrUndefinedOption = options.find((o) => o && o.value === value);\n\t\t\tif (!nullOrUndefinedOption) {\n\t\t\t\tthis.state.update((state) => ({\n\t\t\t\t\t...state,\n\t\t\t\t\tselectedOptions: [],\n\t\t\t\t\tvalue: this.multiple() ? [] : '',\n\t\t\t\t}));\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\n\t\tif (this.multiple()) {\n\t\t\tconst selectedOptions = options.filter((option) => {\n\t\t\t\tif (Array.isArray(value)) {\n\t\t\t\t\treturn value.includes(option?.value as string);\n\t\t\t\t}\n\t\t\t\treturn value === option?.value;\n\t\t\t});\n\t\t\tthis.state.update((state) => ({\n\t\t\t\t...state,\n\t\t\t\tselectedOptions,\n\t\t\t\tvalue: value as string[],\n\t\t\t}));\n\t\t} else {\n\t\t\tconst selectedOption = options.find((option) => option?.value === value);\n\t\t\tif (!selectedOption) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.state.update((state) => ({\n\t\t\t\t...state,\n\t\t\t\tselectedOptions: [selectedOption as CdkOption | null],\n\t\t\t\tvalue: selectedOption.value as string,\n\t\t\t}));\n\t\t}\n\t}\n}\n"]}
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import type { CdkOption, ListboxValueChangeEvent } from '@angular/cdk/listbox';
|
|
2
|
-
import { type AfterViewInit, OnDestroy, Signal } from '@angular/core';
|
|
3
|
-
import { NgControl } from '@angular/forms';
|
|
4
|
-
import { Subject } from 'rxjs';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class BrnSelectTriggerDirective implements AfterViewInit, OnDestroy {
|
|
7
|
-
private readonly _el;
|
|
8
|
-
protected readonly _selectService: BrnSelectService;
|
|
9
|
-
protected readonly _ngControl: NgControl | null;
|
|
10
|
-
private readonly _platform;
|
|
11
|
-
readonly isExpanded: Signal<boolean>;
|
|
12
|
-
readonly selectTriggerId: Signal<string>;
|
|
13
|
-
readonly selectContentId: Signal<string>;
|
|
14
|
-
readonly selectDisable: Signal<boolean>;
|
|
15
|
-
readonly selectTriggerLabelledBy: Signal<string>;
|
|
16
|
-
private _resizeObserver?;
|
|
17
|
-
constructor();
|
|
18
|
-
ngAfterViewInit(): void;
|
|
19
|
-
ngOnDestroy(): void;
|
|
20
|
-
focus(): void;
|
|
21
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<BrnSelectTriggerDirective, never>;
|
|
22
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<BrnSelectTriggerDirective, "[brnSelectTrigger]", never, {}, {}, never, never, true, never>;
|
|
23
|
-
}
|
|
24
|
-
type BrnReadDirection = 'ltr' | 'rtl';
|
|
25
|
-
export declare class BrnSelectService {
|
|
26
|
-
readonly state: import("@angular/core").WritableSignal<{
|
|
27
|
-
id: string;
|
|
28
|
-
labelId: string;
|
|
29
|
-
panelId: string;
|
|
30
|
-
placeholder: Signal<string>;
|
|
31
|
-
isExpanded: boolean;
|
|
32
|
-
multiple: Signal<boolean>;
|
|
33
|
-
disabled: Signal<boolean>;
|
|
34
|
-
disabledBySetDisabled: Signal<boolean>;
|
|
35
|
-
dir: Signal<BrnReadDirection>;
|
|
36
|
-
selectedOptions: Array<CdkOption | null>;
|
|
37
|
-
possibleOptions: Array<CdkOption | null>;
|
|
38
|
-
value: string | string[];
|
|
39
|
-
triggerWidth: number;
|
|
40
|
-
}>;
|
|
41
|
-
readonly id: Signal<string>;
|
|
42
|
-
readonly labelId: Signal<string>;
|
|
43
|
-
readonly panelId: Signal<string>;
|
|
44
|
-
readonly placeholder: Signal<string>;
|
|
45
|
-
readonly disabled: Signal<boolean>;
|
|
46
|
-
readonly isExpanded: Signal<boolean>;
|
|
47
|
-
readonly multiple: Signal<boolean>;
|
|
48
|
-
readonly dir: Signal<BrnReadDirection>;
|
|
49
|
-
readonly selectedOptions: Signal<(CdkOption<unknown> | null)[]>;
|
|
50
|
-
readonly value: Signal<string | string[]>;
|
|
51
|
-
readonly triggerWidth: Signal<number>;
|
|
52
|
-
readonly possibleOptions: Signal<(CdkOption<unknown> | null)[]>;
|
|
53
|
-
private readonly _multiple$;
|
|
54
|
-
readonly listBoxValueChangeEvent$: Subject<ListboxValueChangeEvent<unknown>>;
|
|
55
|
-
private _selectTrigger?;
|
|
56
|
-
get selectTrigger(): BrnSelectTriggerDirective | undefined;
|
|
57
|
-
constructor();
|
|
58
|
-
setTriggerWidth(triggerWidth: number): void;
|
|
59
|
-
getUpdatedOptions(latestListboxChange: ListboxValueChangeEvent<unknown>): Array<CdkOption | null>;
|
|
60
|
-
deselectAllOptions(): void;
|
|
61
|
-
_setSelectTrigger(trigger: BrnSelectTriggerDirective): void;
|
|
62
|
-
setInitialSelectedOptions(value: unknown): void;
|
|
63
|
-
/**
|
|
64
|
-
* Sync the updated options with "possibleOptions" in the select service
|
|
65
|
-
*/
|
|
66
|
-
updatePossibleOptions(options: readonly CdkOption[]): void;
|
|
67
|
-
private selectOptionByValue;
|
|
68
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<BrnSelectService, never>;
|
|
69
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<BrnSelectService>;
|
|
70
|
-
}
|
|
71
|
-
export {};
|