@firestitch/chip 12.0.0 → 13.0.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.
@@ -1,51 +1,52 @@
1
- import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import { FsChipsService } from '../../services/chips.service';
4
- import * as i0 from "@angular/core";
5
- export declare class FsChipComponent implements OnInit, OnDestroy {
6
- private _cdRef;
7
- private _chips;
8
- fsChip: boolean;
9
- _outlined: boolean;
10
- _selectable: boolean;
11
- _image: boolean;
12
- _selected: boolean;
13
- _removable: boolean;
14
- styleBackgroundColor: string;
15
- styleColor: string;
16
- styleBorderColor: string;
17
- classSmall: boolean;
18
- classTiny: boolean;
19
- classMicro: boolean;
20
- set setSize(value: any);
21
- click(): void;
22
- value: any;
23
- set backgroundColor(value: any);
24
- set borderColor(value: any);
25
- set color(value: string);
26
- get color(): string;
27
- set outlined(value: boolean);
28
- get outlined(): boolean;
29
- set removable(value: boolean);
30
- get removable(): boolean;
31
- set selectable(value: boolean);
32
- get selectable(): boolean;
33
- set selected(value: boolean);
34
- get selected(): boolean;
35
- set image(value: boolean);
36
- get image(): boolean;
37
- selectedToggled: EventEmitter<any>;
38
- removed: EventEmitter<any>;
39
- $destroy: Subject<unknown>;
40
- private _backgroundColor;
41
- private _color;
42
- private _size;
43
- constructor(_cdRef: ChangeDetectorRef, _chips: FsChipsService);
44
- ngOnInit(): void;
45
- ngOnDestroy(): void;
46
- remove(event: any): void;
47
- private isContrastYIQBlack;
48
- private updateStyles;
49
- static ɵfac: i0.ɵɵFactoryDeclaration<FsChipComponent, [null, { optional: true; }]>;
50
- static ɵcmp: i0.ɵɵComponentDeclaration<FsChipComponent, "fs-chip", never, { "setSize": "size"; "value": "value"; "backgroundColor": "backgroundColor"; "borderColor": "borderColor"; "color": "color"; "outlined": "outlined"; "removable": "removable"; "selectable": "selectable"; "selected": "selected"; "image": "image"; }, { "selectedToggled": "selectedToggled"; "removed": "removed"; }, never, ["*"]>;
51
- }
1
+ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { FsChipsService } from '../../services/chips.service';
4
+ import * as i0 from "@angular/core";
5
+ export declare class FsChipComponent implements OnInit, OnDestroy {
6
+ private _cdRef;
7
+ private _chips;
8
+ fsChip: boolean;
9
+ _outlined: boolean;
10
+ _selectable: boolean;
11
+ _image: boolean;
12
+ _selected: boolean;
13
+ _removable: boolean;
14
+ styleBackgroundColor: string;
15
+ styleColor: string;
16
+ styleBorderColor: string;
17
+ classSmall: boolean;
18
+ classTiny: boolean;
19
+ classMicro: boolean;
20
+ set setSize(value: any);
21
+ click(): void;
22
+ value: any;
23
+ icon: any;
24
+ set backgroundColor(value: any);
25
+ set borderColor(value: any);
26
+ set color(value: string);
27
+ get color(): string;
28
+ set outlined(value: boolean);
29
+ get outlined(): boolean;
30
+ set removable(value: boolean);
31
+ get removable(): boolean;
32
+ set selectable(value: boolean);
33
+ get selectable(): boolean;
34
+ set selected(value: boolean);
35
+ get selected(): boolean;
36
+ set image(value: boolean);
37
+ get image(): boolean;
38
+ selectedToggled: EventEmitter<any>;
39
+ removed: EventEmitter<any>;
40
+ $destroy: Subject<unknown>;
41
+ private _backgroundColor;
42
+ private _color;
43
+ private _size;
44
+ constructor(_cdRef: ChangeDetectorRef, _chips: FsChipsService);
45
+ ngOnInit(): void;
46
+ ngOnDestroy(): void;
47
+ remove(event: any): void;
48
+ private isContrastYIQBlack;
49
+ private updateStyles;
50
+ static ɵfac: i0.ɵɵFactoryDeclaration<FsChipComponent, [null, { optional: true; }]>;
51
+ static ɵcmp: i0.ɵɵComponentDeclaration<FsChipComponent, "fs-chip", never, { "setSize": "size"; "value": "value"; "icon": "icon"; "backgroundColor": "backgroundColor"; "borderColor": "borderColor"; "color": "color"; "outlined": "outlined"; "removable": "removable"; "selectable": "selectable"; "selected": "selected"; "image": "image"; }, { "selectedToggled": "selectedToggled"; "removed": "removed"; }, never, ["*"]>;
52
+ }
@@ -1,36 +1,36 @@
1
- import { ChangeDetectorRef, OnDestroy } from '@angular/core';
2
- import { ControlValueAccessor } from '@angular/forms';
3
- import { FsChipsService } from '../../services/chips.service';
4
- import * as i0 from "@angular/core";
5
- export declare class FsChipsComponent implements OnDestroy, ControlValueAccessor {
6
- private _cdRef;
7
- private _chipsService;
8
- classFsChips: boolean;
9
- classHasChips: boolean;
10
- compare: any;
11
- multiple: boolean;
12
- onChange: any;
13
- onTouch: any;
14
- private _value;
15
- private _destroy$;
16
- constructor(_cdRef: ChangeDetectorRef, _chipsService: FsChipsService);
17
- get chips(): any[];
18
- set value(value: any[]);
19
- get value(): any[];
20
- ngOnDestroy(): void;
21
- writeValue(value: any): void;
22
- registerOnChange(fn: any): void;
23
- registerOnTouched(fn: any): void;
24
- /**
25
- * Update ngModel value when selection changed
26
- */
27
- private subscribeToSelectionChange;
28
- /**
29
- * Update selection if item was added or removed
30
- */
31
- private subscribeToItemsChange;
32
- private compareFn;
33
- private updateChips;
34
- static ɵfac: i0.ɵɵFactoryDeclaration<FsChipsComponent, never>;
35
- static ɵcmp: i0.ɵɵComponentDeclaration<FsChipsComponent, "fs-chips", never, { "compare": "compare"; "multiple": "multiple"; }, {}, never, ["*"]>;
36
- }
1
+ import { ChangeDetectorRef, OnDestroy } from '@angular/core';
2
+ import { ControlValueAccessor } from '@angular/forms';
3
+ import { FsChipsService } from '../../services/chips.service';
4
+ import * as i0 from "@angular/core";
5
+ export declare class FsChipsComponent implements OnDestroy, ControlValueAccessor {
6
+ private _cdRef;
7
+ private _chipsService;
8
+ classFsChips: boolean;
9
+ classHasChips: boolean;
10
+ compare: any;
11
+ multiple: boolean;
12
+ onChange: (value: any) => void;
13
+ onTouch: (value: any) => void;
14
+ private _value;
15
+ private _destroy$;
16
+ constructor(_cdRef: ChangeDetectorRef, _chipsService: FsChipsService);
17
+ get chips(): any[];
18
+ set value(value: any[]);
19
+ get value(): any[];
20
+ ngOnDestroy(): void;
21
+ writeValue(value: any): void;
22
+ registerOnChange(fn: any): void;
23
+ registerOnTouched(fn: any): void;
24
+ /**
25
+ * Update ngModel value when selection changed
26
+ */
27
+ private _subscribeToSelectionChange;
28
+ /**
29
+ * Update selection if item was added or removed
30
+ */
31
+ private _subscribeToItemsChange;
32
+ private _compareFn;
33
+ private _updateChips;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<FsChipsComponent, never>;
35
+ static ɵcmp: i0.ɵɵComponentDeclaration<FsChipsComponent, "fs-chips", never, { "compare": "compare"; "multiple": "multiple"; }, {}, never, ["*"]>;
36
+ }
@@ -1,13 +1,13 @@
1
- import { ModuleWithProviders } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "./components/chips/chips.component";
4
- import * as i2 from "./components/chip/chip.component";
5
- import * as i3 from "@angular/common";
6
- import * as i4 from "@angular/material/icon";
7
- import * as i5 from "@firestitch/label";
8
- export declare class FsChipModule {
9
- static forRoot(): ModuleWithProviders<FsChipModule>;
10
- static ɵfac: i0.ɵɵFactoryDeclaration<FsChipModule, never>;
11
- static ɵmod: i0.ɵɵNgModuleDeclaration<FsChipModule, [typeof i1.FsChipsComponent, typeof i2.FsChipComponent], [typeof i3.CommonModule, typeof i4.MatIconModule, typeof i5.FsLabelModule], [typeof i1.FsChipsComponent, typeof i2.FsChipComponent]>;
12
- static ɵinj: i0.ɵɵInjectorDeclaration<FsChipModule>;
13
- }
1
+ import { ModuleWithProviders } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "./components/chips/chips.component";
4
+ import * as i2 from "./components/chip/chip.component";
5
+ import * as i3 from "@angular/common";
6
+ import * as i4 from "@angular/material/icon";
7
+ import * as i5 from "@firestitch/label";
8
+ export declare class FsChipModule {
9
+ static forRoot(): ModuleWithProviders<FsChipModule>;
10
+ static ɵfac: i0.ɵɵFactoryDeclaration<FsChipModule, never>;
11
+ static ɵmod: i0.ɵɵNgModuleDeclaration<FsChipModule, [typeof i1.FsChipsComponent, typeof i2.FsChipComponent], [typeof i3.CommonModule, typeof i4.MatIconModule, typeof i5.FsLabelModule], [typeof i1.FsChipsComponent, typeof i2.FsChipComponent]>;
12
+ static ɵinj: i0.ɵɵInjectorDeclaration<FsChipModule>;
13
+ }
@@ -1,17 +1,17 @@
1
- import { OnDestroy } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class FsChipsService implements OnDestroy {
4
- chips: any[];
5
- private _chipItemsChanged$;
6
- private _selectionChanged$;
7
- private _destroy$;
8
- constructor();
9
- get selectionChanged$(): import("rxjs").Observable<unknown>;
10
- get chipItemsChanged$(): import("rxjs").Observable<unknown>;
11
- ngOnDestroy(): void;
12
- selectionChanged(selected: boolean, value: any): void;
13
- register(chip: any): void;
14
- destroy(chip: any): void;
15
- static ɵfac: i0.ɵɵFactoryDeclaration<FsChipsService, never>;
16
- static ɵprov: i0.ɵɵInjectableDeclaration<FsChipsService>;
17
- }
1
+ import { OnDestroy } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class FsChipsService implements OnDestroy {
4
+ chips: any[];
5
+ private _chipItemsChanged$;
6
+ private _selectionChanged$;
7
+ private _destroy$;
8
+ constructor();
9
+ get selectionChanged$(): import("rxjs").Observable<unknown>;
10
+ get chipItemsChanged$(): import("rxjs").Observable<unknown>;
11
+ ngOnDestroy(): void;
12
+ selectionChanged(selected: boolean, value: any): void;
13
+ register(chip: any): void;
14
+ destroy(chip: any): void;
15
+ static ɵfac: i0.ɵɵFactoryDeclaration<FsChipsService, never>;
16
+ static ɵprov: i0.ɵɵInjectableDeclaration<FsChipsService>;
17
+ }
@@ -0,0 +1,221 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostBinding, HostListener, Input, Optional, Output, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { FsChipsService } from '../../services/chips.service';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/chips.service";
6
+ import * as i2 from "@angular/material/icon";
7
+ import * as i3 from "@angular/common";
8
+ export class FsChipComponent {
9
+ constructor(_cdRef, _chips) {
10
+ this._cdRef = _cdRef;
11
+ this._chips = _chips;
12
+ this.fsChip = true;
13
+ this._outlined = false;
14
+ this._selectable = false;
15
+ this._image = false;
16
+ this._selected = false;
17
+ this._removable = false;
18
+ this.styleBackgroundColor = '';
19
+ this.styleColor = '';
20
+ this.styleBorderColor = '';
21
+ this.classSmall = false;
22
+ this.classTiny = false;
23
+ this.classMicro = false;
24
+ this.selectedToggled = new EventEmitter();
25
+ this.removed = new EventEmitter();
26
+ this.$destroy = new Subject();
27
+ this._backgroundColor = '';
28
+ this._color = '';
29
+ }
30
+ set setSize(value) {
31
+ this._size = value;
32
+ this.classSmall = value === 'small';
33
+ this.classTiny = value === 'tiny';
34
+ this.classMicro = value === 'micro';
35
+ }
36
+ ;
37
+ click() {
38
+ if (this.selectable) {
39
+ this.selected = !this.selected;
40
+ this.selectedToggled.emit({ value: this.value, selected: this.selected });
41
+ if (this._chips) {
42
+ this._chips.selectionChanged(this.selected, this.value);
43
+ }
44
+ }
45
+ }
46
+ set backgroundColor(value) {
47
+ this._backgroundColor = value;
48
+ this.updateStyles();
49
+ }
50
+ ;
51
+ set borderColor(value) {
52
+ this.styleBorderColor = value;
53
+ this.updateStyles();
54
+ }
55
+ set color(value) {
56
+ this._color = value;
57
+ this.updateStyles();
58
+ }
59
+ get color() {
60
+ return this._color;
61
+ }
62
+ set outlined(value) {
63
+ this._outlined = value;
64
+ this.updateStyles();
65
+ }
66
+ ;
67
+ get outlined() {
68
+ return this._outlined;
69
+ }
70
+ set removable(value) {
71
+ this._removable = value;
72
+ this._cdRef.markForCheck();
73
+ }
74
+ ;
75
+ get removable() {
76
+ return this._removable;
77
+ }
78
+ set selectable(value) {
79
+ this._selectable = value;
80
+ }
81
+ ;
82
+ get selectable() {
83
+ return this._selectable;
84
+ }
85
+ set selected(value) {
86
+ this._selected = value;
87
+ this._cdRef.markForCheck();
88
+ }
89
+ ;
90
+ get selected() {
91
+ return this._selected;
92
+ }
93
+ set image(value) {
94
+ this._image = value;
95
+ this._cdRef.markForCheck();
96
+ }
97
+ ;
98
+ get image() {
99
+ return this._image;
100
+ }
101
+ ngOnInit() {
102
+ if (this._chips) {
103
+ this._chips.register(this);
104
+ }
105
+ }
106
+ ngOnDestroy() {
107
+ if (this._chips) {
108
+ this._chips.destroy(this);
109
+ }
110
+ this.$destroy.next();
111
+ this.$destroy.complete();
112
+ }
113
+ remove(event) {
114
+ this.removed.next(event);
115
+ }
116
+ isContrastYIQBlack(hexcolor) {
117
+ if (!hexcolor) {
118
+ return true;
119
+ }
120
+ hexcolor = hexcolor.replace('#', '');
121
+ const r = parseInt(hexcolor.substr(0, 2), 16);
122
+ const g = parseInt(hexcolor.substr(2, 2), 16);
123
+ const b = parseInt(hexcolor.substr(4, 2), 16);
124
+ const yiq = ((r * 299) + (g * 587) + (b * 114)) / 1000;
125
+ return yiq >= 200;
126
+ }
127
+ updateStyles() {
128
+ this.styleBackgroundColor = this._backgroundColor;
129
+ if (this._color) {
130
+ this.styleColor = this._color;
131
+ }
132
+ else if (!this._outlined) {
133
+ this.styleColor = this.isContrastYIQBlack(this.styleBackgroundColor) ? '#474747' : '#fff';
134
+ }
135
+ if (this._outlined) {
136
+ this.styleBackgroundColor = '';
137
+ if (this._color) {
138
+ this.styleBorderColor = this._color;
139
+ }
140
+ }
141
+ this._cdRef.markForCheck();
142
+ }
143
+ }
144
+ FsChipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsChipComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FsChipsService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
145
+ FsChipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FsChipComponent, selector: "fs-chip", inputs: { setSize: ["size", "setSize"], value: "value", icon: "icon", backgroundColor: "backgroundColor", borderColor: "borderColor", color: "color", outlined: "outlined", removable: "removable", selectable: "selectable", selected: "selected", image: "image" }, outputs: { selectedToggled: "selectedToggled", removed: "removed" }, host: { listeners: { "click": "click()" }, properties: { "class.fs-chip": "this.fsChip", "class.outlined": "this._outlined", "class.selectable": "this._selectable", "class.imaged": "this._image", "class.selected": "this._selected", "class.removable": "this._removable", "style.backgroundColor": "this.styleBackgroundColor", "style.color": "this.styleColor", "style.borderColor": "this.styleBorderColor", "class.small": "this.classSmall", "class.tiny": "this.classTiny", "class.micro": "this.classMicro", "class.iconed": "this.icon" } }, ngImport: i0, template: "<img *ngIf=\"image\" [src]=\"image\" class=\"image\" alt=\"\">\n<ng-container *ngIf=\"icon\">\n <mat-icon class=\"icon\">{{icon}}</mat-icon>\n</ng-container>\n<div class=\"fs-chip-content\">\n <ng-content></ng-content>\n</div>\n<div class=\"selected-check\" *ngIf=\"selected\">\n <mat-icon [style.color]=\"styleColor\">check</mat-icon>\n</div>\n<a *ngIf=\"removable\" class=\"remove\" (click)=\"remove($event)\">\n <mat-icon [style.color]=\"styleColor\">cancel</mat-icon>\n</a>\n", styles: [":host{-webkit-user-select:none;user-select:none;transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:inline-flex;padding:0 12px;border-radius:16px;align-items:center;cursor:default;height:30px;background-color:#e0e0e0;overflow:hidden}:host.imaged{overflow:visible;padding-left:0}:host.imaged.outlined .image{margin-left:-2px}:host.iconed:not(.imaged){padding-left:5px}:host.removable,:host.selected{padding-right:3px}:host.selectable{cursor:pointer}:host.outlined{background-color:transparent;border:1px solid #e0e0e0;box-sizing:border-box}:host .icon{margin-right:5px}:host .image{height:30px;width:30px;border-radius:50%;object-fit:cover;margin-left:-1px;margin-right:8px}:host .fs-chip-content{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host .selected-check{margin:0 5px;display:flex}:host .remove{display:flex;margin-left:5px;cursor:pointer}:host.micro{padding:0 5px;height:16px;line-height:normal}:host.micro .fs-chip-content{font-size:65%}:host.micro .image{height:100%;width:16px;margin-right:2px}:host.micro .remove{margin-left:1px}:host.micro .selected-check{margin:0 1px 0 0}:host.micro.imaged{padding-left:0}:host.micro.removable,:host.micro.selected{padding-right:0}:host.micro mat-icon{width:12px;height:12px;font-size:11px}:host.tiny{padding:0 6px;height:18px;line-height:normal}:host.tiny .fs-chip-content{font-size:75%}:host.tiny .image{height:18px;width:18px;margin-right:3px}:host.tiny.iconed:not(.imaged){padding-left:3px}:host.tiny .remove{margin-left:2px}:host.tiny .selected-check{margin:0 1px 0 0}:host.tiny.imaged{padding-left:0}:host.tiny.removable,:host.tiny.selected{padding-right:0}:host.tiny mat-icon{height:15px;width:15px;font-size:15px}:host.small{padding:0 8px;font-size:85%;height:25px;line-height:normal}:host.small .image{height:25px;width:25px;margin-right:5px}:host.small.iconed:not(.imaged){padding-left:4px}:host.small.imaged{padding-left:0}:host.small .remove{margin-left:3px}:host.small .selected-check{margin:0 2px 0 0}:host.small .selected-check mat-icon{transform:scale(.7)}:host.small.removable,:host.small.selected{padding-right:0}:host.small mat-icon{height:22px;width:22px;font-size:20px}\n"], components: [{ type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
146
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsChipComponent, decorators: [{
147
+ type: Component,
148
+ args: [{ selector: 'fs-chip', changeDetection: ChangeDetectionStrategy.OnPush, template: "<img *ngIf=\"image\" [src]=\"image\" class=\"image\" alt=\"\">\n<ng-container *ngIf=\"icon\">\n <mat-icon class=\"icon\">{{icon}}</mat-icon>\n</ng-container>\n<div class=\"fs-chip-content\">\n <ng-content></ng-content>\n</div>\n<div class=\"selected-check\" *ngIf=\"selected\">\n <mat-icon [style.color]=\"styleColor\">check</mat-icon>\n</div>\n<a *ngIf=\"removable\" class=\"remove\" (click)=\"remove($event)\">\n <mat-icon [style.color]=\"styleColor\">cancel</mat-icon>\n</a>\n", styles: [":host{-webkit-user-select:none;user-select:none;transition:box-shadow .28s cubic-bezier(.4,0,.2,1);display:inline-flex;padding:0 12px;border-radius:16px;align-items:center;cursor:default;height:30px;background-color:#e0e0e0;overflow:hidden}:host.imaged{overflow:visible;padding-left:0}:host.imaged.outlined .image{margin-left:-2px}:host.iconed:not(.imaged){padding-left:5px}:host.removable,:host.selected{padding-right:3px}:host.selectable{cursor:pointer}:host.outlined{background-color:transparent;border:1px solid #e0e0e0;box-sizing:border-box}:host .icon{margin-right:5px}:host .image{height:30px;width:30px;border-radius:50%;object-fit:cover;margin-left:-1px;margin-right:8px}:host .fs-chip-content{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host .selected-check{margin:0 5px;display:flex}:host .remove{display:flex;margin-left:5px;cursor:pointer}:host.micro{padding:0 5px;height:16px;line-height:normal}:host.micro .fs-chip-content{font-size:65%}:host.micro .image{height:100%;width:16px;margin-right:2px}:host.micro .remove{margin-left:1px}:host.micro .selected-check{margin:0 1px 0 0}:host.micro.imaged{padding-left:0}:host.micro.removable,:host.micro.selected{padding-right:0}:host.micro mat-icon{width:12px;height:12px;font-size:11px}:host.tiny{padding:0 6px;height:18px;line-height:normal}:host.tiny .fs-chip-content{font-size:75%}:host.tiny .image{height:18px;width:18px;margin-right:3px}:host.tiny.iconed:not(.imaged){padding-left:3px}:host.tiny .remove{margin-left:2px}:host.tiny .selected-check{margin:0 1px 0 0}:host.tiny.imaged{padding-left:0}:host.tiny.removable,:host.tiny.selected{padding-right:0}:host.tiny mat-icon{height:15px;width:15px;font-size:15px}:host.small{padding:0 8px;font-size:85%;height:25px;line-height:normal}:host.small .image{height:25px;width:25px;margin-right:5px}:host.small.iconed:not(.imaged){padding-left:4px}:host.small.imaged{padding-left:0}:host.small .remove{margin-left:3px}:host.small .selected-check{margin:0 2px 0 0}:host.small .selected-check mat-icon{transform:scale(.7)}:host.small.removable,:host.small.selected{padding-right:0}:host.small mat-icon{height:22px;width:22px;font-size:20px}\n"] }]
149
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.FsChipsService, decorators: [{
150
+ type: Optional
151
+ }] }]; }, propDecorators: { fsChip: [{
152
+ type: HostBinding,
153
+ args: ['class.fs-chip']
154
+ }], _outlined: [{
155
+ type: HostBinding,
156
+ args: ['class.outlined']
157
+ }], _selectable: [{
158
+ type: HostBinding,
159
+ args: ['class.selectable']
160
+ }], _image: [{
161
+ type: HostBinding,
162
+ args: ['class.imaged']
163
+ }], _selected: [{
164
+ type: HostBinding,
165
+ args: ['class.selected']
166
+ }], _removable: [{
167
+ type: HostBinding,
168
+ args: ['class.removable']
169
+ }], styleBackgroundColor: [{
170
+ type: HostBinding,
171
+ args: ['style.backgroundColor']
172
+ }], styleColor: [{
173
+ type: HostBinding,
174
+ args: ['style.color']
175
+ }], styleBorderColor: [{
176
+ type: HostBinding,
177
+ args: ['style.borderColor']
178
+ }], classSmall: [{
179
+ type: HostBinding,
180
+ args: ['class.small']
181
+ }], classTiny: [{
182
+ type: HostBinding,
183
+ args: ['class.tiny']
184
+ }], classMicro: [{
185
+ type: HostBinding,
186
+ args: ['class.micro']
187
+ }], setSize: [{
188
+ type: Input,
189
+ args: ['size']
190
+ }], click: [{
191
+ type: HostListener,
192
+ args: ['click']
193
+ }], value: [{
194
+ type: Input
195
+ }], icon: [{
196
+ type: Input
197
+ }, {
198
+ type: HostBinding,
199
+ args: ['class.iconed']
200
+ }], backgroundColor: [{
201
+ type: Input
202
+ }], borderColor: [{
203
+ type: Input
204
+ }], color: [{
205
+ type: Input
206
+ }], outlined: [{
207
+ type: Input
208
+ }], removable: [{
209
+ type: Input
210
+ }], selectable: [{
211
+ type: Input
212
+ }], selected: [{
213
+ type: Input
214
+ }], image: [{
215
+ type: Input
216
+ }], selectedToggled: [{
217
+ type: Output
218
+ }], removed: [{
219
+ type: Output
220
+ }] } });
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip.component.js","sourceRoot":"","sources":["../../../../../src/app/components/chip/chip.component.ts","../../../../../src/app/components/chip/chip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy, ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { FsChipsService } from '../../services/chips.service';\n\n\n@Component({\n  selector: 'fs-chip',\n  templateUrl: 'chip.component.html',\n  styleUrls: ['chip.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsChipComponent implements OnInit, OnDestroy {\n\n  @HostBinding('class.fs-chip') fsChip = true;\n  @HostBinding('class.outlined') _outlined = false;\n  @HostBinding('class.selectable') _selectable = false;\n  @HostBinding('class.imaged') _image = false;\n  @HostBinding('class.selected') _selected = false;\n  @HostBinding('class.removable') _removable = false;\n  @HostBinding('style.backgroundColor') styleBackgroundColor = '';\n  @HostBinding('style.color') styleColor = '';\n  @HostBinding('style.borderColor') styleBorderColor = '';\n\n  @HostBinding('class.small') classSmall = false;\n  @HostBinding('class.tiny') classTiny = false;\n  @HostBinding('class.micro') classMicro = false;\n\n  @Input('size') set setSize(value) {\n    this._size = value;\n    this.classSmall = value === 'small';\n    this.classTiny = value === 'tiny';\n    this.classMicro = value === 'micro';\n  };\n\n  @HostListener('click')\n  public click() {\n\n    if (this.selectable) {\n      this.selected = !this.selected;\n      this.selectedToggled.emit({ value: this.value, selected: this.selected });\n\n      if (this._chips) {\n        this._chips.selectionChanged(this.selected, this.value);\n      }\n    }\n  }\n\n  @Input() public value;\n  \n  @Input() \n  @HostBinding('class.iconed') \n  public icon;\n\n  @Input() set backgroundColor(value) {\n    this._backgroundColor = value;\n    this.updateStyles();\n  };\n\n  @Input() set borderColor(value) {\n    this.styleBorderColor = value;\n    this.updateStyles();\n  }\n  @Input() set color(value) {\n    this._color = value;\n    this.updateStyles();\n  }\n\n  get color() {\n    return this._color;\n  }\n\n  @Input() set outlined(value) {\n    this._outlined = value;\n    this.updateStyles();\n  };\n\n  get outlined() {\n    return this._outlined;\n  }\n\n  @Input() set removable(value) {\n    this._removable = value;\n\n    this._cdRef.markForCheck();\n  };\n\n  get removable() {\n    return this._removable;\n  }\n\n  @Input() set selectable(value) {\n    this._selectable = value;\n  };\n\n  get selectable() {\n    return this._selectable;\n  }\n\n  @Input() set selected(value) {\n    this._selected = value;\n\n    this._cdRef.markForCheck();\n  };\n\n  get selected() {\n    return this._selected;\n  }\n\n  @Input() set image(value) {\n    this._image = value;\n\n    this._cdRef.markForCheck();\n  };\n\n  get image() {\n    return this._image;\n  }\n\n  @Output() public selectedToggled = new EventEmitter();\n  @Output() public removed = new EventEmitter();\n\n  public $destroy = new Subject();\n\n  private _backgroundColor = '';\n  private _color = '';\n  private _size;\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    @Optional() private _chips: FsChipsService\n  ) {}\n\n  public ngOnInit() {\n    if (this._chips) {\n      this._chips.register(this);\n    }\n  }\n\n  public ngOnDestroy() {\n    if (this._chips) {\n      this._chips.destroy(this);\n    }\n\n    this.$destroy.next();\n    this.$destroy.complete();\n  }\n\n  public remove(event) {\n    this.removed.next(event);\n  }\n\n  private isContrastYIQBlack(hexcolor) {\n    if (!hexcolor) {\n      return true;\n    }\n\n    hexcolor = hexcolor.replace('#', '');\n    const r = parseInt(hexcolor.substr(0, 2), 16);\n    const g = parseInt(hexcolor.substr(2, 2), 16);\n    const b = parseInt(hexcolor.substr(4, 2), 16);\n    const yiq = ((r * 299) + (g * 587) + (b * 114)) / 1000;\n\n    return yiq >= 200;\n  }\n\n  private updateStyles() {\n    this.styleBackgroundColor = this._backgroundColor;\n\n    if (this._color) {\n      this.styleColor = this._color;\n    } else if (!this._outlined) {\n      this.styleColor = this.isContrastYIQBlack(this.styleBackgroundColor) ? '#474747' : '#fff';\n    }\n\n    if (this._outlined) {\n      this.styleBackgroundColor = '';\n\n      if (this._color) {\n        this.styleBorderColor = this._color;\n      }\n    }\n\n    this._cdRef.markForCheck();\n  }\n}\n","<img *ngIf=\"image\" [src]=\"image\" class=\"image\" alt=\"\">\n<ng-container *ngIf=\"icon\">\n  <mat-icon class=\"icon\">{{icon}}</mat-icon>\n</ng-container>\n<div class=\"fs-chip-content\">\n  <ng-content></ng-content>\n</div>\n<div class=\"selected-check\" *ngIf=\"selected\">\n  <mat-icon [style.color]=\"styleColor\">check</mat-icon>\n</div>\n<a *ngIf=\"removable\" class=\"remove\" (click)=\"remove($event)\">\n  <mat-icon [style.color]=\"styleColor\">cancel</mat-icon>\n</a>\n"]}
@@ -0,0 +1,132 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, HostBinding, Input, } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import { find } from 'lodash-es';
6
+ import { FsChipsService } from '../../services/chips.service';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "../../services/chips.service";
9
+ export class FsChipsComponent {
10
+ constructor(_cdRef, _chipsService) {
11
+ this._cdRef = _cdRef;
12
+ this._chipsService = _chipsService;
13
+ this.classFsChips = true;
14
+ this.classHasChips = false;
15
+ this.multiple = true;
16
+ this._value = [];
17
+ this._destroy$ = new Subject();
18
+ this._subscribeToItemsChange();
19
+ this._subscribeToSelectionChange();
20
+ }
21
+ get chips() {
22
+ return this._chipsService.chips;
23
+ }
24
+ set value(value) {
25
+ if (this._value !== value) {
26
+ this._value = value;
27
+ this.onChange(this._value);
28
+ this.onTouch(this._value);
29
+ }
30
+ }
31
+ get value() {
32
+ return this._value;
33
+ }
34
+ ngOnDestroy() {
35
+ this._destroy$.next();
36
+ this._destroy$.complete();
37
+ }
38
+ writeValue(value) {
39
+ if (value !== this.value) {
40
+ this._value = value;
41
+ }
42
+ this._updateChips();
43
+ }
44
+ registerOnChange(fn) {
45
+ this.onChange = fn;
46
+ }
47
+ registerOnTouched(fn) {
48
+ this.onTouch = fn;
49
+ }
50
+ /**
51
+ * Update ngModel value when selection changed
52
+ */
53
+ _subscribeToSelectionChange() {
54
+ this._chipsService.selectionChanged$
55
+ .pipe(takeUntil(this._destroy$))
56
+ .subscribe(({ selected, value }) => {
57
+ if (!selected) {
58
+ const valueIndex = this.value.findIndex((item) => {
59
+ return this._compareFn(item, value);
60
+ });
61
+ if (valueIndex > -1) {
62
+ this.value.splice(valueIndex, 1);
63
+ this.onChange(this._value);
64
+ this.onTouch(this._value);
65
+ }
66
+ }
67
+ else {
68
+ this.value.push(value);
69
+ this.onChange(this._value);
70
+ this.onTouch(this._value);
71
+ }
72
+ });
73
+ }
74
+ /**
75
+ * Update selection if item was added or removed
76
+ */
77
+ _subscribeToItemsChange() {
78
+ this._chipsService.chipItemsChanged$
79
+ .pipe(takeUntil(this._destroy$))
80
+ .subscribe(() => {
81
+ this.classHasChips = !!this._chipsService.chips.length;
82
+ this._updateChips();
83
+ });
84
+ }
85
+ _compareFn(o1, o2) {
86
+ if (this.compare) {
87
+ return this.compare(o1, o2);
88
+ }
89
+ return o1 === o2;
90
+ }
91
+ _updateChips() {
92
+ if (this.multiple && Array.isArray(this.value) && this.chips) {
93
+ this.chips.forEach((chip) => {
94
+ chip.selected = find(this.value, (o) => {
95
+ return this._compareFn(o, chip.value);
96
+ }) !== undefined;
97
+ });
98
+ }
99
+ this._cdRef.markForCheck();
100
+ }
101
+ }
102
+ FsChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsChipsComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.FsChipsService }], target: i0.ɵɵFactoryTarget.Component });
103
+ FsChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FsChipsComponent, selector: "fs-chips", inputs: { compare: "compare", multiple: "multiple" }, host: { properties: { "class.fs-chips": "this.classFsChips", "class.has-chips": "this.classHasChips" } }, providers: [
104
+ {
105
+ provide: NG_VALUE_ACCESSOR,
106
+ useExisting: forwardRef(() => FsChipsComponent),
107
+ multi: true,
108
+ },
109
+ FsChipsService,
110
+ ], ngImport: i0, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;flex-wrap:wrap}:host.has-chips{margin-top:-5px}:host ::ng-deep .fs-chip{margin-right:5px;margin-top:5px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
111
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FsChipsComponent, decorators: [{
112
+ type: Component,
113
+ args: [{ selector: 'fs-chips', providers: [
114
+ {
115
+ provide: NG_VALUE_ACCESSOR,
116
+ useExisting: forwardRef(() => FsChipsComponent),
117
+ multi: true,
118
+ },
119
+ FsChipsService,
120
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;flex-wrap:wrap}:host.has-chips{margin-top:-5px}:host ::ng-deep .fs-chip{margin-right:5px;margin-top:5px}\n"] }]
121
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.FsChipsService }]; }, propDecorators: { classFsChips: [{
122
+ type: HostBinding,
123
+ args: ['class.fs-chips']
124
+ }], classHasChips: [{
125
+ type: HostBinding,
126
+ args: ['class.has-chips']
127
+ }], compare: [{
128
+ type: Input
129
+ }], multiple: [{
130
+ type: Input
131
+ }] } });
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chips.component.js","sourceRoot":"","sources":["../../../../../src/app/components/chips/chips.component.ts","../../../../../src/app/components/chips/chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy, ChangeDetectorRef,\n  Component,\n  forwardRef,\n  HostBinding,\n  Input,\n  OnDestroy,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { find } from 'lodash-es';\n\nimport { FsChipsService } from '../../services/chips.service';\n\n\n@Component({\n  selector: 'fs-chips',\n  templateUrl: './chips.component.html',\n  styleUrls: ['./chips.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FsChipsComponent),\n      multi: true,\n    },\n    FsChipsService,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsChipsComponent implements OnDestroy, ControlValueAccessor {\n\n  @HostBinding('class.fs-chips') public classFsChips = true;\n  @HostBinding('class.has-chips') public classHasChips = false;\n\n  @Input() public compare;\n\n  @Input() public multiple = true;\n\n  public onChange: (value) => void;\n  public onTouch: (value) => void;\n\n  private _value = [];\n  private _destroy$ = new Subject();\n\n  constructor(\n    private _cdRef: ChangeDetectorRef,\n    private _chipsService: FsChipsService,\n  ) {\n    this._subscribeToItemsChange();\n    this._subscribeToSelectionChange();\n  }\n\n  public get chips() {\n    return this._chipsService.chips;\n  }\n\n  public set value(value) {\n    if (this._value !== value) {\n      this._value = value;\n\n      this.onChange(this._value);\n      this.onTouch(this._value);\n    }\n  }\n\n  public get value() {\n    return this._value;\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  public writeValue(value: any) {\n    if (value !== this.value) {\n      this._value = value;\n    }\n\n    this._updateChips();\n  }\n\n  public registerOnChange(fn) {\n    this.onChange = fn;\n  }\n  public registerOnTouched(fn) {\n    this.onTouch = fn;\n  }\n\n  /**\n   * Update ngModel value when selection changed\n   */\n  private _subscribeToSelectionChange() {\n    this._chipsService.selectionChanged$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe(({ selected, value }) => {\n        if (!selected) {\n          const valueIndex = this.value.findIndex((item) => {\n            return this._compareFn(item, value);\n          });\n\n          if (valueIndex > -1) {\n            this.value.splice(valueIndex, 1);\n\n            this.onChange(this._value);\n            this.onTouch(this._value);\n          }\n        } else {\n          this.value.push(value);\n\n          this.onChange(this._value);\n          this.onTouch(this._value);\n        }\n      });\n  }\n\n  /**\n   * Update selection if item was added or removed\n   */\n  private _subscribeToItemsChange() {\n    this._chipsService.chipItemsChanged$\n      .pipe(takeUntil(this._destroy$))\n      .subscribe(() => {\n        this.classHasChips = !!this._chipsService.chips.length;\n        this._updateChips();\n      });\n  }\n\n  private _compareFn(o1, o2) {\n    if (this.compare) {\n      return this.compare(o1, o2);\n    }\n\n    return o1 === o2;\n  }\n\n  private _updateChips() {\n    if (this.multiple && Array.isArray(this.value) && this.chips) {\n      this.chips.forEach((chip) => {\n\n        chip.selected = find(this.value, (o) => {\n          return this._compareFn(o, chip.value);\n        }) !== undefined;\n      });\n    }\n\n    this._cdRef.markForCheck();\n  }\n}\n","<ng-content></ng-content>\n"]}