@flywheel-io/vision 1.16.2 → 1.17.0
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/components/button-group/button-group.component.d.ts +33 -0
- package/components/button-group/button-group.module.d.ts +10 -0
- package/components/button-toggle/button-toggle.component.d.ts +8 -9
- package/components/checkbox/checkbox.component.d.ts +9 -8
- package/components/number-input/number-input.component.d.ts +42 -0
- package/components/number-input/number-input.module.d.ts +10 -0
- package/components/wrapped-input/wrapped-input.component.d.ts +1 -1
- package/esm2020/components/button-group/button-group.component.mjs +131 -0
- package/esm2020/components/button-group/button-group.module.mjs +32 -0
- package/esm2020/components/button-toggle/button-toggle.component.mjs +11 -38
- package/esm2020/components/checkbox/checkbox.component.mjs +23 -27
- package/esm2020/components/contained-input/contained-input.component.mjs +1 -1
- package/esm2020/components/layouts/grid/grid.component.mjs +4 -4
- package/esm2020/components/menu/menu-item/menu-item.component.mjs +1 -1
- package/esm2020/components/number-input/number-input.component.mjs +122 -0
- package/esm2020/components/number-input/number-input.module.mjs +32 -0
- package/esm2020/components/wrapped-input/wrapped-input.component.mjs +3 -3
- package/esm2020/public-api.mjs +5 -1
- package/fesm2015/flywheel-io-vision.mjs +336 -71
- package/fesm2015/flywheel-io-vision.mjs.map +1 -1
- package/fesm2020/flywheel-io-vision.mjs +336 -71
- package/fesm2020/flywheel-io-vision.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { AfterContentInit, ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, QueryList, SimpleChanges } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
3
|
+
import { FwButtonToggleItemComponent } from '../button-toggle/button-toggle-item/button-toggle-item.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class FwButtonGroupComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {
|
|
6
|
+
private cdref;
|
|
7
|
+
get classes(): string;
|
|
8
|
+
layout?: 'basic' | 'compact';
|
|
9
|
+
size?: 'small' | 'medium' | 'large';
|
|
10
|
+
disabled?: boolean;
|
|
11
|
+
color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';
|
|
12
|
+
selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';
|
|
13
|
+
toggleButtons: QueryList<FwButtonToggleItemComponent>;
|
|
14
|
+
private subscriptions;
|
|
15
|
+
change: EventEmitter<string[]>;
|
|
16
|
+
private _value;
|
|
17
|
+
get value(): string[];
|
|
18
|
+
set value(newValue: string[]);
|
|
19
|
+
constructor(cdref: ChangeDetectorRef);
|
|
20
|
+
onChange: (value: string[]) => void;
|
|
21
|
+
onTouched: () => void;
|
|
22
|
+
registerOnChange(fn: (value: string[]) => void): void;
|
|
23
|
+
registerOnTouched(fn: () => void): void;
|
|
24
|
+
setDisabledState?(isDisabled: boolean): void;
|
|
25
|
+
writeValue(value: string[]): void;
|
|
26
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
27
|
+
ngOnDestroy(): void;
|
|
28
|
+
ngAfterContentInit(): void;
|
|
29
|
+
updateValue(value: string[]): void;
|
|
30
|
+
formatToggles(): void;
|
|
31
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FwButtonGroupComponent, never>;
|
|
32
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwButtonGroupComponent, "fw-button-group", never, { "layout": "layout"; "size": "size"; "disabled": "disabled"; "color": "color"; "selectedColor": "selectedColor"; "value": "value"; }, { "change": "change"; }, ["toggleButtons"], ["fw-button-toggle-item,fw-tooltip"], false>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./button-group.component";
|
|
3
|
+
import * as i2 from "../button/button.module";
|
|
4
|
+
import * as i3 from "../icon/icon.module";
|
|
5
|
+
import * as i4 from "../button-toggle/button-toggle.module";
|
|
6
|
+
export declare class FwButtonGroupModule {
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FwButtonGroupModule, never>;
|
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<FwButtonGroupModule, [typeof i1.FwButtonGroupComponent], [typeof i2.FwButtonModule, typeof i3.FwIconModule, typeof i4.FwButtonToggleModule], [typeof i1.FwButtonGroupComponent]>;
|
|
9
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<FwButtonGroupModule>;
|
|
10
|
+
}
|
|
@@ -7,28 +7,27 @@ export declare class FwButtonToggleComponent implements ControlValueAccessor, On
|
|
|
7
7
|
get classes(): string;
|
|
8
8
|
layout?: 'basic' | 'compact';
|
|
9
9
|
size?: 'small' | 'medium' | 'large';
|
|
10
|
-
multiple?: boolean;
|
|
11
10
|
disabled?: boolean;
|
|
12
11
|
color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';
|
|
13
12
|
selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';
|
|
14
13
|
toggleButtons: QueryList<FwButtonToggleItemComponent>;
|
|
15
14
|
private subscriptions;
|
|
16
|
-
change: EventEmitter<string
|
|
15
|
+
change: EventEmitter<string>;
|
|
17
16
|
private _value;
|
|
18
|
-
get value(): string
|
|
19
|
-
set value(newValue: string
|
|
17
|
+
get value(): string;
|
|
18
|
+
set value(newValue: string);
|
|
20
19
|
constructor(cdref: ChangeDetectorRef);
|
|
21
|
-
onChange: (value: string
|
|
20
|
+
onChange: (value: string) => void;
|
|
22
21
|
onTouched: () => void;
|
|
23
|
-
registerOnChange(fn: (value: string
|
|
22
|
+
registerOnChange(fn: (value: string) => void): void;
|
|
24
23
|
registerOnTouched(fn: () => void): void;
|
|
25
24
|
setDisabledState?(isDisabled: boolean): void;
|
|
26
|
-
writeValue(value: string
|
|
25
|
+
writeValue(value: string): void;
|
|
27
26
|
ngOnChanges(changes: SimpleChanges): void;
|
|
28
27
|
ngOnDestroy(): void;
|
|
29
28
|
ngAfterContentInit(): void;
|
|
30
|
-
updateValue(value: string
|
|
29
|
+
updateValue(value: string): void;
|
|
31
30
|
formatToggles(): void;
|
|
32
31
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwButtonToggleComponent, never>;
|
|
33
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwButtonToggleComponent, "fw-button-toggle", never, { "layout": "layout"; "size": "size"; "
|
|
32
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwButtonToggleComponent, "fw-button-toggle", never, { "layout": "layout"; "size": "size"; "disabled": "disabled"; "color": "color"; "selectedColor": "selectedColor"; "value": "value"; }, { "change": "change"; }, ["toggleButtons"], ["fw-button-toggle-item,fw-tooltip"], false>;
|
|
34
33
|
}
|
|
@@ -1,22 +1,23 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
1
2
|
import { ControlValueAccessor } from '@angular/forms';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class FwCheckboxComponent implements ControlValueAccessor {
|
|
4
|
-
|
|
5
|
-
set checked(value: boolean);
|
|
5
|
+
name?: string;
|
|
6
6
|
disabled: boolean;
|
|
7
7
|
size: 'medium' | 'compact';
|
|
8
8
|
color: 'primary' | 'secondary';
|
|
9
9
|
title: string;
|
|
10
10
|
focused: boolean;
|
|
11
11
|
get checkboxStyles(): string[];
|
|
12
|
-
|
|
12
|
+
checked?: boolean;
|
|
13
|
+
change: EventEmitter<boolean>;
|
|
13
14
|
onChange: (value: boolean) => void;
|
|
14
|
-
|
|
15
|
-
registerOnChange(fn:
|
|
16
|
-
registerOnTouched(fn:
|
|
17
|
-
onInputChange(e: Event): void;
|
|
15
|
+
onTouched: () => void;
|
|
16
|
+
registerOnChange(fn: (value: boolean) => void): void;
|
|
17
|
+
registerOnTouched(fn: () => void): void;
|
|
18
18
|
setDisabledState(isDisabled: boolean): void;
|
|
19
|
+
writeValue(checked: boolean): void;
|
|
19
20
|
handleClick(): void;
|
|
20
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwCheckboxComponent, never>;
|
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwCheckboxComponent, "fw-checkbox", never, { "
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwCheckboxComponent, "fw-checkbox", never, { "name": "name"; "disabled": "disabled"; "size": "size"; "color": "color"; "title": "title"; "focused": "focused"; "checked": "checked"; }, { "change": "change"; }, never, ["*"], false>;
|
|
22
23
|
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor, FormControl } from '@angular/forms';
|
|
3
|
+
import { IconType } from '../icon/icon.types';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class FwNumberInputComponent implements ControlValueAccessor {
|
|
6
|
+
disabled?: boolean;
|
|
7
|
+
useActionableIcons?: boolean;
|
|
8
|
+
leftIcon?: IconType;
|
|
9
|
+
leftIconAction?: EventEmitter<void>;
|
|
10
|
+
rightIcon?: string;
|
|
11
|
+
rightIconAction?: EventEmitter<void>;
|
|
12
|
+
prefix?: string;
|
|
13
|
+
context?: string;
|
|
14
|
+
placeholder?: string;
|
|
15
|
+
readOnly?: boolean;
|
|
16
|
+
size?: 'small' | 'medium' | 'large';
|
|
17
|
+
min?: number;
|
|
18
|
+
max?: number;
|
|
19
|
+
step?: number;
|
|
20
|
+
arrows?: 'native' | 'plus-minus' | 'none';
|
|
21
|
+
numberType?: 'integer' | 'float';
|
|
22
|
+
autofocus?: boolean;
|
|
23
|
+
autocomplete?: boolean;
|
|
24
|
+
numberInput: any;
|
|
25
|
+
error?: boolean;
|
|
26
|
+
value: number;
|
|
27
|
+
externalControl: FormControl;
|
|
28
|
+
onTouch: () => void;
|
|
29
|
+
onChange: (value: number) => void;
|
|
30
|
+
writeValue(obj: number): void;
|
|
31
|
+
registerOnChange(fn: any): void;
|
|
32
|
+
registerOnTouched(fn: any): void;
|
|
33
|
+
setDisabledState(isDisabled: boolean): void;
|
|
34
|
+
changeHandler(event: KeyboardEvent): void;
|
|
35
|
+
blurHandler(): void;
|
|
36
|
+
onLeftIconClick(): void;
|
|
37
|
+
onRightIconClick(): void;
|
|
38
|
+
handleDecrement(): void;
|
|
39
|
+
handleIncrement(): void;
|
|
40
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FwNumberInputComponent, never>;
|
|
41
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwNumberInputComponent, "fw-number-input", never, { "disabled": "disabled"; "useActionableIcons": "useActionableIcons"; "leftIcon": "leftIcon"; "rightIcon": "rightIcon"; "prefix": "prefix"; "context": "context"; "placeholder": "placeholder"; "readOnly": "readOnly"; "size": "size"; "min": "min"; "max": "max"; "step": "step"; "arrows": "arrows"; "numberType": "numberType"; "autofocus": "autofocus"; "autocomplete": "autocomplete"; "error": "error"; "value": "value"; }, { "leftIconAction": "leftIconAction"; "rightIconAction": "rightIconAction"; }, never, ["input", "*"], false>;
|
|
42
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./number-input.component";
|
|
3
|
+
import * as i2 from "@angular/common";
|
|
4
|
+
import * as i3 from "../icon/icon.module";
|
|
5
|
+
import * as i4 from "@angular/forms";
|
|
6
|
+
export declare class FwNumberInputModule {
|
|
7
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FwNumberInputModule, never>;
|
|
8
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<FwNumberInputModule, [typeof i1.FwNumberInputComponent], [typeof i2.CommonModule, typeof i3.FwIconModule, typeof i4.ReactiveFormsModule], [typeof i1.FwNumberInputComponent]>;
|
|
9
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<FwNumberInputModule>;
|
|
10
|
+
}
|
|
@@ -6,5 +6,5 @@ export declare class FwWrappedInputComponent {
|
|
|
6
6
|
errorText?: string;
|
|
7
7
|
get classes(): string;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<FwWrappedInputComponent, never>;
|
|
9
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<FwWrappedInputComponent, "fw-wrapped-input", never, { "title": "title"; "description": "description"; "helperText": "helperText"; "errorText": "errorText"; }, {}, never, ["fw-form-heading", "fw-button-toggle, fw-date-input, fw-text-input, fw-phone-input, fw-textarea-input, fw-select, fw-multi-select, fw-checkbox"], false>;
|
|
9
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FwWrappedInputComponent, "fw-wrapped-input", never, { "title": "title"; "description": "description"; "helperText": "helperText"; "errorText": "errorText"; }, {}, never, ["fw-form-heading", "fw-button-toggle, fw-date-input, fw-text-input, fw-number-input, fw-phone-input, fw-textarea-input, fw-select, fw-multi-select, fw-checkbox"], false>;
|
|
10
10
|
}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { Component, ContentChildren, EventEmitter, forwardRef, HostBinding, Input, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { FwButtonToggleItemComponent } from '../button-toggle/button-toggle-item/button-toggle-item.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class FwButtonGroupComponent {
|
|
6
|
+
constructor(cdref) {
|
|
7
|
+
this.cdref = cdref;
|
|
8
|
+
this.layout = 'basic';
|
|
9
|
+
this.size = 'medium';
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
this.subscriptions = [];
|
|
12
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
13
|
+
this.change = new EventEmitter();
|
|
14
|
+
this.onTouched = () => {
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
get classes() {
|
|
18
|
+
return ['fw-button-group', this.size, this.layout].filter(Boolean).join(' ');
|
|
19
|
+
}
|
|
20
|
+
;
|
|
21
|
+
get value() {
|
|
22
|
+
return this._value;
|
|
23
|
+
}
|
|
24
|
+
set value(newValue) {
|
|
25
|
+
this.updateValue(newValue);
|
|
26
|
+
}
|
|
27
|
+
registerOnChange(fn) {
|
|
28
|
+
this.onChange = fn;
|
|
29
|
+
}
|
|
30
|
+
registerOnTouched(fn) {
|
|
31
|
+
this.onTouched = fn;
|
|
32
|
+
}
|
|
33
|
+
setDisabledState(isDisabled) {
|
|
34
|
+
this.disabled = isDisabled;
|
|
35
|
+
}
|
|
36
|
+
writeValue(value) {
|
|
37
|
+
this.value = value;
|
|
38
|
+
}
|
|
39
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
40
|
+
ngOnChanges(changes) {
|
|
41
|
+
this.formatToggles();
|
|
42
|
+
}
|
|
43
|
+
ngOnDestroy() {
|
|
44
|
+
for (const subscription of this.subscriptions) {
|
|
45
|
+
subscription.unsubscribe();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
ngAfterContentInit() {
|
|
49
|
+
if (this.toggleButtons.length > 0) {
|
|
50
|
+
this.formatToggles();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
updateValue(value) {
|
|
54
|
+
this._value = value;
|
|
55
|
+
if (this.onChange) {
|
|
56
|
+
this.onChange(value);
|
|
57
|
+
}
|
|
58
|
+
this.change.emit(value);
|
|
59
|
+
}
|
|
60
|
+
formatToggles() {
|
|
61
|
+
if (this.toggleButtons) {
|
|
62
|
+
this.toggleButtons.forEach(toggle => {
|
|
63
|
+
if (this.value.indexOf(toggle.value) >= 0) {
|
|
64
|
+
toggle.selected = true;
|
|
65
|
+
}
|
|
66
|
+
toggle.size = this.size;
|
|
67
|
+
if (this.color) {
|
|
68
|
+
toggle.color = this.color;
|
|
69
|
+
}
|
|
70
|
+
if (this.selectedColor) {
|
|
71
|
+
toggle.selectedColor = this.selectedColor;
|
|
72
|
+
}
|
|
73
|
+
if (this.disabled) {
|
|
74
|
+
toggle.disabled = this.disabled;
|
|
75
|
+
}
|
|
76
|
+
const sub = toggle.click.subscribe(() => {
|
|
77
|
+
toggle.selected = !toggle.selected;
|
|
78
|
+
const vals = this.toggleButtons.map(tb => {
|
|
79
|
+
if (tb.selected) {
|
|
80
|
+
return tb.value;
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
}).filter(Boolean);
|
|
86
|
+
this.writeValue(vals);
|
|
87
|
+
});
|
|
88
|
+
this.subscriptions.push(sub);
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
FwButtonGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
+
FwButtonGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwButtonGroupComponent, selector: "fw-button-group", inputs: { layout: "layout", size: "size", disabled: "disabled", color: "color", selectedColor: "selectedColor", value: "value" }, outputs: { change: "change" }, host: { properties: { "attr.class": "this.classes" } }, providers: [
|
|
95
|
+
{
|
|
96
|
+
provide: NG_VALUE_ACCESSOR,
|
|
97
|
+
useExisting: forwardRef(() => FwButtonGroupComponent),
|
|
98
|
+
multi: true,
|
|
99
|
+
},
|
|
100
|
+
], queries: [{ propertyName: "toggleButtons", predicate: FwButtonToggleItemComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: '<ng-content select="fw-button-toggle-item,fw-tooltip"></ng-content>', isInline: true, styles: ["fw-button-group.fw-button-group{box-sizing:border-box;border-radius:8px;overflow:hidden;display:inline-flex;align-items:stretch}fw-button-group.fw-button-group .fw-button-toggle-item.no-title button{gap:0}fw-button-group.fw-button-group button{min-width:0;margin:0!important;border-radius:0;border:1px solid var(--separations-input);border-right-width:0!important}fw-button-group.fw-button-group>button:first-of-type{border-top-left-radius:8px;border-bottom-left-radius:8px}fw-button-group.fw-button-group>button:last-of-type{border-top-right-radius:8px;border-bottom-right-radius:8px;border-right-width:1px}fw-button-group.fw-button-group.compact button{line-height:24px;height:24px}fw-button-group.fw-button-group.small button{font-size:12px}fw-button-group.fw-button-group.medium button{font-size:14px}fw-button-group.fw-button-group.large button{font-size:18px}fw-button-group.fw-button-group>fw-button-toggle-item:last-of-type button{border-top-right-radius:8px;border-bottom-right-radius:8px;border-right-width:1px!important}fw-button-group.fw-button-group>fw-button-toggle-item:first-of-type button{border-top-left-radius:8px;border-bottom-left-radius:8px}fw-button-group.fw-button-group fw-tooltip fw-button-toggle-item button{border-radius:0!important;border-right-width:0!important}fw-button-group.fw-button-group fw-tooltip:last-of-type fw-button-toggle-item button{border-radius:0 8px 8px 0!important;border-right-width:1px!important}fw-button-group.fw-button-group fw-tooltip:first-of-type fw-button-toggle-item button{border-radius:8px 0 0 8px!important}\n"], encapsulation: i0.ViewEncapsulation.None });
|
|
101
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupComponent, decorators: [{
|
|
102
|
+
type: Component,
|
|
103
|
+
args: [{ selector: 'fw-button-group', template: '<ng-content select="fw-button-toggle-item,fw-tooltip"></ng-content>', encapsulation: ViewEncapsulation.None, providers: [
|
|
104
|
+
{
|
|
105
|
+
provide: NG_VALUE_ACCESSOR,
|
|
106
|
+
useExisting: forwardRef(() => FwButtonGroupComponent),
|
|
107
|
+
multi: true,
|
|
108
|
+
},
|
|
109
|
+
], styles: ["fw-button-group.fw-button-group{box-sizing:border-box;border-radius:8px;overflow:hidden;display:inline-flex;align-items:stretch}fw-button-group.fw-button-group .fw-button-toggle-item.no-title button{gap:0}fw-button-group.fw-button-group button{min-width:0;margin:0!important;border-radius:0;border:1px solid var(--separations-input);border-right-width:0!important}fw-button-group.fw-button-group>button:first-of-type{border-top-left-radius:8px;border-bottom-left-radius:8px}fw-button-group.fw-button-group>button:last-of-type{border-top-right-radius:8px;border-bottom-right-radius:8px;border-right-width:1px}fw-button-group.fw-button-group.compact button{line-height:24px;height:24px}fw-button-group.fw-button-group.small button{font-size:12px}fw-button-group.fw-button-group.medium button{font-size:14px}fw-button-group.fw-button-group.large button{font-size:18px}fw-button-group.fw-button-group>fw-button-toggle-item:last-of-type button{border-top-right-radius:8px;border-bottom-right-radius:8px;border-right-width:1px!important}fw-button-group.fw-button-group>fw-button-toggle-item:first-of-type button{border-top-left-radius:8px;border-bottom-left-radius:8px}fw-button-group.fw-button-group fw-tooltip fw-button-toggle-item button{border-radius:0!important;border-right-width:0!important}fw-button-group.fw-button-group fw-tooltip:last-of-type fw-button-toggle-item button{border-radius:0 8px 8px 0!important;border-right-width:1px!important}fw-button-group.fw-button-group fw-tooltip:first-of-type fw-button-toggle-item button{border-radius:8px 0 0 8px!important}\n"] }]
|
|
110
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { classes: [{
|
|
111
|
+
type: HostBinding,
|
|
112
|
+
args: ['attr.class']
|
|
113
|
+
}], layout: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], size: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], disabled: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], color: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], selectedColor: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], toggleButtons: [{
|
|
124
|
+
type: ContentChildren,
|
|
125
|
+
args: [FwButtonToggleItemComponent, { descendants: true }]
|
|
126
|
+
}], change: [{
|
|
127
|
+
type: Output
|
|
128
|
+
}], value: [{
|
|
129
|
+
type: Input
|
|
130
|
+
}] } });
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-group.component.js","sourceRoot":"","sources":["../../../../../src/components/button-group/button-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwButtonToggleItemComponent } from '../button-toggle/button-toggle-item/button-toggle-item.component';\n\n@Component({\n  selector: 'fw-button-group',\n  styleUrls: ['./button-group.component.scss'],\n  template: '<ng-content select=\"fw-button-toggle-item,fw-tooltip\"></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FwButtonGroupComponent),\n      multi: true,\n    },\n  ],\n})\nexport class FwButtonGroupComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-button-group', this.size, this.layout].filter(Boolean).join(' ');\n  };\n\n  @Input() layout?: 'basic' | 'compact' = 'basic';\n  @Input() size?: 'small' | 'medium' | 'large' = 'medium';\n  @Input() disabled?: boolean = false;\n  @Input() color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @Input() selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @ContentChildren(FwButtonToggleItemComponent, { descendants: true }) toggleButtons: QueryList<FwButtonToggleItemComponent>;\n  private subscriptions: Subscription[] = [];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change = new EventEmitter<string[]>();\n  private _value: string[];\n  @Input()\n  get value(): string[] {\n    return this._value;\n  }\n\n  set value(newValue: string[]) {\n    this.updateValue(newValue);\n  }\n\n  constructor(private cdref: ChangeDetectorRef) {\n  }\n\n  onChange: (value: string[]) => void;\n  onTouched = (): void => {\n  };\n\n  registerOnChange(fn: (value: string[]) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string[]): void {\n    this.value = value;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.formatToggles();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.toggleButtons.length > 0) {\n      this.formatToggles();\n    }\n  }\n\n  updateValue(value: string[]): void {\n    this._value = value;\n    if (this.onChange) {\n      this.onChange(value);\n    }\n    this.change.emit(value);\n  }\n\n  formatToggles(): void {\n    if (this.toggleButtons) {\n      this.toggleButtons.forEach(toggle => {\n        if (this.value.indexOf(toggle.value) >= 0) {\n          toggle.selected = true;\n        }\n        toggle.size = this.size;\n        if (this.color) {\n          toggle.color = this.color;\n        }\n        if (this.selectedColor) {\n          toggle.selectedColor = this.selectedColor;\n        }\n        if (this.disabled) {\n          toggle.disabled = this.disabled;\n        }\n        const sub = toggle.click.subscribe(() => {\n          toggle.selected = !toggle.selected;\n          const vals = this.toggleButtons.map(tb => {\n            if (tb.selected) {\n              return tb.value;\n            } else {\n              return null;\n            }\n          }).filter(Boolean);\n          this.writeValue(vals);\n        });\n        this.subscriptions.push(sub);\n      });\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { FwButtonModule } from '../button/button.module';
|
|
3
|
+
import { FwButtonToggleModule } from '../button-toggle/button-toggle.module';
|
|
4
|
+
import { FwIconModule } from '../icon/icon.module';
|
|
5
|
+
import { FwButtonGroupComponent } from './button-group.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class FwButtonGroupModule {
|
|
8
|
+
}
|
|
9
|
+
FwButtonGroupModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
FwButtonGroupModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupModule, declarations: [FwButtonGroupComponent], imports: [FwButtonModule,
|
|
11
|
+
FwIconModule,
|
|
12
|
+
FwButtonToggleModule], exports: [FwButtonGroupComponent] });
|
|
13
|
+
FwButtonGroupModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupModule, imports: [FwButtonModule,
|
|
14
|
+
FwIconModule,
|
|
15
|
+
FwButtonToggleModule] });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonGroupModule, decorators: [{
|
|
17
|
+
type: NgModule,
|
|
18
|
+
args: [{
|
|
19
|
+
exports: [
|
|
20
|
+
FwButtonGroupComponent,
|
|
21
|
+
],
|
|
22
|
+
declarations: [
|
|
23
|
+
FwButtonGroupComponent,
|
|
24
|
+
],
|
|
25
|
+
imports: [
|
|
26
|
+
FwButtonModule,
|
|
27
|
+
FwIconModule,
|
|
28
|
+
FwButtonToggleModule,
|
|
29
|
+
],
|
|
30
|
+
}]
|
|
31
|
+
}] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWdyb3VwLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2J1dHRvbi1ncm91cC9idXR0b24tZ3JvdXAubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFlbEUsTUFBTSxPQUFPLG1CQUFtQjs7Z0hBQW5CLG1CQUFtQjtpSEFBbkIsbUJBQW1CLGlCQVI1QixzQkFBc0IsYUFHdEIsY0FBYztRQUNkLFlBQVk7UUFDWixvQkFBb0IsYUFScEIsc0JBQXNCO2lIQVdiLG1CQUFtQixZQUw1QixjQUFjO1FBQ2QsWUFBWTtRQUNaLG9CQUFvQjsyRkFHWCxtQkFBbUI7a0JBYi9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLHNCQUFzQjtxQkFDdkI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjtxQkFDdkI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGNBQWM7d0JBQ2QsWUFBWTt3QkFDWixvQkFBb0I7cUJBQ3JCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRndCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24vYnV0dG9uLm1vZHVsZSc7XG5pbXBvcnQgeyBGd0J1dHRvblRvZ2dsZU1vZHVsZSB9IGZyb20gJy4uL2J1dHRvbi10b2dnbGUvYnV0dG9uLXRvZ2dsZS5tb2R1bGUnO1xuaW1wb3J0IHsgRndJY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZHVsZSc7XG5pbXBvcnQgeyBGd0J1dHRvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24tZ3JvdXAuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZXhwb3J0czogW1xuICAgIEZ3QnV0dG9uR3JvdXBDb21wb25lbnQsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIEZ3QnV0dG9uR3JvdXBDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBGd0J1dHRvbk1vZHVsZSxcbiAgICBGd0ljb25Nb2R1bGUsXG4gICAgRndCdXR0b25Ub2dnbGVNb2R1bGUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZ3QnV0dG9uR3JvdXBNb2R1bGUge1xufVxuIl19
|
|
@@ -60,15 +60,8 @@ export class FwButtonToggleComponent {
|
|
|
60
60
|
formatToggles() {
|
|
61
61
|
if (this.toggleButtons) {
|
|
62
62
|
this.toggleButtons.forEach(toggle => {
|
|
63
|
-
if (
|
|
64
|
-
|
|
65
|
-
toggle.selected = true;
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
if (toggle.value === this.value) {
|
|
70
|
-
toggle.selected = true;
|
|
71
|
-
}
|
|
63
|
+
if (toggle.value === this.value) {
|
|
64
|
+
toggle.selected = true;
|
|
72
65
|
}
|
|
73
66
|
toggle.size = this.size;
|
|
74
67
|
if (this.color) {
|
|
@@ -81,35 +74,17 @@ export class FwButtonToggleComponent {
|
|
|
81
74
|
toggle.disabled = this.disabled;
|
|
82
75
|
}
|
|
83
76
|
const sub = toggle.click.subscribe(() => {
|
|
84
|
-
if (this.
|
|
77
|
+
if (this.toggleButtons.length === 1) {
|
|
85
78
|
toggle.selected = !toggle.selected;
|
|
86
79
|
}
|
|
87
80
|
else {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
this.toggleButtons.forEach(t => {
|
|
93
|
-
t.selected = false;
|
|
94
|
-
});
|
|
95
|
-
toggle.selected = true;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
if (this.multiple) {
|
|
99
|
-
const vals = this.toggleButtons.map(tb => {
|
|
100
|
-
if (tb.selected) {
|
|
101
|
-
return tb.value;
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
return null;
|
|
105
|
-
}
|
|
106
|
-
}).filter(Boolean);
|
|
107
|
-
this.writeValue(vals);
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
const val = this.toggleButtons.find(t => t.selected)?.value;
|
|
111
|
-
this.writeValue(val);
|
|
81
|
+
this.toggleButtons.forEach(t => {
|
|
82
|
+
t.selected = false;
|
|
83
|
+
});
|
|
84
|
+
toggle.selected = true;
|
|
112
85
|
}
|
|
86
|
+
const val = this.toggleButtons.find(t => t.selected)?.value;
|
|
87
|
+
this.writeValue(val);
|
|
113
88
|
});
|
|
114
89
|
this.subscriptions.push(sub);
|
|
115
90
|
});
|
|
@@ -117,7 +92,7 @@ export class FwButtonToggleComponent {
|
|
|
117
92
|
}
|
|
118
93
|
}
|
|
119
94
|
FwButtonToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FwButtonToggleComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
120
|
-
FwButtonToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwButtonToggleComponent, selector: "fw-button-toggle", inputs: { layout: "layout", size: "size",
|
|
95
|
+
FwButtonToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FwButtonToggleComponent, selector: "fw-button-toggle", inputs: { layout: "layout", size: "size", disabled: "disabled", color: "color", selectedColor: "selectedColor", value: "value" }, outputs: { change: "change" }, host: { properties: { "attr.class": "this.classes" } }, providers: [
|
|
121
96
|
{
|
|
122
97
|
provide: NG_VALUE_ACCESSOR,
|
|
123
98
|
useExisting: forwardRef(() => FwButtonToggleComponent),
|
|
@@ -140,8 +115,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
140
115
|
type: Input
|
|
141
116
|
}], size: [{
|
|
142
117
|
type: Input
|
|
143
|
-
}], multiple: [{
|
|
144
|
-
type: Input
|
|
145
118
|
}], disabled: [{
|
|
146
119
|
type: Input
|
|
147
120
|
}], color: [{
|
|
@@ -156,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
156
129
|
}], value: [{
|
|
157
130
|
type: Input
|
|
158
131
|
}] } });
|
|
159
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle.component.js","sourceRoot":"","sources":["../../../../../src/components/button-toggle/button-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwButtonToggleItemComponent } from './button-toggle-item/button-toggle-item.component';\n\n@Component({\n  selector: 'fw-button-toggle',\n  styleUrls: ['./button-toggle.component.scss'],\n  template: '<ng-content select=\"fw-button-toggle-item,fw-tooltip\"></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FwButtonToggleComponent),\n      multi: true,\n    },\n  ],\n})\nexport class FwButtonToggleComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-button-toggle', this.size, this.layout].filter(Boolean).join(' ');\n  };\n\n  @Input() layout?: 'basic' | 'compact' = 'basic';\n  @Input() size?: 'small' | 'medium' | 'large' = 'medium';\n  @Input() multiple?: boolean;\n  @Input() disabled?: boolean = false;\n  @Input() color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @Input() selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @ContentChildren(FwButtonToggleItemComponent, { descendants: true }) toggleButtons: QueryList<FwButtonToggleItemComponent>;\n  private subscriptions: Subscription[] = [];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change = new EventEmitter<string | string[]>();\n  private _value: string | string[];\n  @Input()\n  get value(): string | string[] {\n    return this._value;\n  }\n\n  set value(newValue: string | string[]) {\n    this.updateValue(newValue);\n  }\n\n  constructor(private cdref: ChangeDetectorRef) {\n  }\n\n  onChange: (value: string | string[]) => void;\n  onTouched = (): void => {\n  };\n\n  registerOnChange(fn: (value: string | string[]) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string | string[]): void {\n    this.value = value;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.formatToggles();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.toggleButtons.length > 0) {\n      this.formatToggles();\n    }\n  }\n\n  updateValue(value: string | string[]): void {\n    this._value = value;\n    if (this.onChange) {\n      this.onChange(value);\n    }\n    this.change.emit(value);\n  }\n\n  formatToggles(): void {\n    if (this.toggleButtons) {\n      this.toggleButtons.forEach(toggle => {\n        if (this.multiple && Array.isArray(this.value)) {\n          if (this.value.indexOf(toggle.value) >= 0) {\n            toggle.selected = true;\n          }\n        } else {\n          if (toggle.value === this.value) {\n            toggle.selected = true;\n          }\n        }\n        toggle.size = this.size;\n        if (this.color) {\n          toggle.color = this.color;\n        }\n        if (this.selectedColor) {\n          toggle.selectedColor = this.selectedColor;\n        }\n        if (this.disabled) {\n          toggle.disabled = this.disabled;\n        }\n        const sub = toggle.click.subscribe(() => {\n          if (this.multiple && Array.isArray(this.value)) {\n            toggle.selected = !toggle.selected;\n          } else {\n            if (this.toggleButtons.length === 1) {\n              toggle.selected = !toggle.selected;\n            } else {\n              this.toggleButtons.forEach(t => {\n                t.selected = false;\n              });\n              toggle.selected = true;\n            }\n          }\n          if (this.multiple) {\n            const vals = this.toggleButtons.map(tb => {\n              if (tb.selected) {\n                return tb.value;\n              } else {\n                return null;\n              }\n            }).filter(Boolean);\n            this.writeValue(vals);\n          } else {\n            const val = this.toggleButtons.find(t => t.selected)?.value;\n            this.writeValue(val);\n          }\n        });\n        this.subscriptions.push(sub);\n      });\n    }\n  }\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle.component.js","sourceRoot":"","sources":["../../../../../src/components/button-toggle/button-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { FwButtonToggleItemComponent } from './button-toggle-item/button-toggle-item.component';\n\n@Component({\n  selector: 'fw-button-toggle',\n  styleUrls: ['./button-toggle.component.scss'],\n  template: '<ng-content select=\"fw-button-toggle-item,fw-tooltip\"></ng-content>',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FwButtonToggleComponent),\n      multi: true,\n    },\n  ],\n})\nexport class FwButtonToggleComponent implements ControlValueAccessor, OnChanges, OnDestroy, AfterContentInit {\n  @HostBinding('attr.class') get classes(): string {\n    return ['fw-button-toggle', this.size, this.layout].filter(Boolean).join(' ');\n  };\n\n  @Input() layout?: 'basic' | 'compact' = 'basic';\n  @Input() size?: 'small' | 'medium' | 'large' = 'medium';\n  @Input() disabled?: boolean = false;\n  @Input() color?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @Input() selectedColor?: 'primary' | 'secondary' | 'danger' | 'slate' | 'skeleton' | 'warning' | 'success';\n  @ContentChildren(FwButtonToggleItemComponent, { descendants: true }) toggleButtons: QueryList<FwButtonToggleItemComponent>;\n  private subscriptions: Subscription[] = [];\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() change = new EventEmitter<string>();\n  private _value: string;\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n\n  set value(newValue: string) {\n    this.updateValue(newValue);\n  }\n\n  constructor(private cdref: ChangeDetectorRef) {\n  }\n\n  onChange: (value: string) => void;\n  onTouched = (): void => {\n  };\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  ngOnChanges(changes: SimpleChanges): void {\n    this.formatToggles();\n  }\n\n  ngOnDestroy(): void {\n    for (const subscription of this.subscriptions) {\n      subscription.unsubscribe();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (this.toggleButtons.length > 0) {\n      this.formatToggles();\n    }\n  }\n\n  updateValue(value: string): void {\n    this._value = value;\n    if (this.onChange) {\n      this.onChange(value);\n    }\n    this.change.emit(value);\n  }\n\n  formatToggles(): void {\n    if (this.toggleButtons) {\n      this.toggleButtons.forEach(toggle => {\n        if (toggle.value === this.value) {\n          toggle.selected = true;\n        }\n        toggle.size = this.size;\n        if (this.color) {\n          toggle.color = this.color;\n        }\n        if (this.selectedColor) {\n          toggle.selectedColor = this.selectedColor;\n        }\n        if (this.disabled) {\n          toggle.disabled = this.disabled;\n        }\n        const sub = toggle.click.subscribe(() => {\n          if (this.toggleButtons.length === 1) {\n            toggle.selected = !toggle.selected;\n          } else {\n            this.toggleButtons.forEach(t => {\n              t.selected = false;\n            });\n            toggle.selected = true;\n          }\n          const val = this.toggleButtons.find(t => t.selected)?.value;\n          this.writeValue(val);\n        });\n        this.subscriptions.push(sub);\n      });\n    }\n  }\n}\n"]}
|