ngx-ntk-icon-picker 18.26.2 → 18.26.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (28) hide show
  1. package/esm2022/lib/icon-picker.component.mjs +240 -0
  2. package/esm2022/lib/icon-picker.directive.mjs +136 -0
  3. package/{esm2020 → esm2022}/lib/icon-picker.module.mjs +12 -12
  4. package/esm2022/lib/icon-picker.service.mjs +74 -0
  5. package/esm2022/lib/icon.mjs +18 -0
  6. package/{esm2020 → esm2022}/lib/search-icon.pipe.mjs +4 -4
  7. package/esm2022/lib/text.directive.mjs +26 -0
  8. package/{fesm2020 → fesm2022}/ngx-ntk-icon-picker.mjs +108 -55
  9. package/{fesm2020 → fesm2022}/ngx-ntk-icon-picker.mjs.map +1 -1
  10. package/lib/icon-picker.directive.d.ts +1 -1
  11. package/lib/text.directive.d.ts +1 -1
  12. package/package.json +5 -11
  13. package/esm2020/lib/icon-picker.component.mjs +0 -204
  14. package/esm2020/lib/icon-picker.directive.mjs +0 -131
  15. package/esm2020/lib/icon-picker.service.mjs +0 -68
  16. package/esm2020/lib/icon.mjs +0 -11
  17. package/esm2020/lib/text.directive.mjs +0 -27
  18. package/fesm2015/ngx-ntk-icon-picker.mjs +0 -45004
  19. package/fesm2015/ngx-ntk-icon-picker.mjs.map +0 -1
  20. /package/{esm2020 → esm2022}/lib/icons-pack.mjs +0 -0
  21. /package/{esm2020 → esm2022}/lib/index.mjs +0 -0
  22. /package/{esm2020 → esm2022}/lib/pack/font-awesome4-icons-pack.mjs +0 -0
  23. /package/{esm2020 → esm2022}/lib/pack/font-awesome5-icons-pack.mjs +0 -0
  24. /package/{esm2020 → esm2022}/lib/pack/font-awesome6-icons-pack.mjs +0 -0
  25. /package/{esm2020 → esm2022}/lib/pack/material-icons-pack.mjs +0 -0
  26. /package/{esm2020 → esm2022}/lib/pack/prime-icons-pack.mjs +0 -0
  27. /package/{esm2020 → esm2022}/ngx-ntk-icon-picker.mjs +0 -0
  28. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -0,0 +1,240 @@
1
+ import { Component, ViewChild } from '@angular/core';
2
+ import { IconType } from './icon';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./icon-picker.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@fortawesome/angular-fontawesome";
7
+ import * as i4 from "./text.directive";
8
+ import * as i5 from "./search-icon.pipe";
9
+ export class IconPickerComponent {
10
+ el;
11
+ cdr;
12
+ service;
13
+ dialogElement;
14
+ // Popover
15
+ ipPosition;
16
+ ipHeight;
17
+ ipMaxHeight;
18
+ ipWidth;
19
+ // Icon css
20
+ ipIconSize;
21
+ ipIconVerticalPadding;
22
+ ipIconHorizontalPadding;
23
+ // Item Style ie input and button
24
+ ipButtonStyleClass;
25
+ ipInputSearchStyleClass;
26
+ ipDivSearchStyleClass;
27
+ ipUseRootViewContainer = false;
28
+ // Icon and behaviors
29
+ ipKeepSearchFilter;
30
+ ipPlaceHolder;
31
+ ipFallbackIcon;
32
+ ipIconPack;
33
+ show;
34
+ hidden;
35
+ top;
36
+ left;
37
+ position;
38
+ arrowTop;
39
+ selectedIcon;
40
+ iconType = IconType;
41
+ buttonWidth;
42
+ buttonHeight;
43
+ icons = [];
44
+ search = '';
45
+ directiveInstance;
46
+ initialIcon;
47
+ directiveElementRef;
48
+ listenerMouseDown;
49
+ listenerResize;
50
+ dialogArrowSize = 10;
51
+ constructor(el, cdr, service) {
52
+ this.el = el;
53
+ this.cdr = cdr;
54
+ this.service = service;
55
+ }
56
+ setDialog(instance, elementRef, icon, ipPosition, ipHeight, ipMaxHeight, ipWidth, ipPlaceHolder, ipFallbackIcon, ipIconPack, ipIconSize, ipIconVerticalPadding, ipIconHorizontalPadding, ipButtonStyleClass, ipDivSearchStyleClass, ipInputSearchStyleClass, ipKeepSearchFilter, ipUseRootViewContainer) {
57
+ this.directiveInstance = instance;
58
+ this.setInitialIcon(icon);
59
+ this.directiveElementRef = elementRef;
60
+ this.ipPosition = ipPosition;
61
+ this.ipHeight = parseInt(ipHeight, 10);
62
+ this.ipMaxHeight = parseInt(ipMaxHeight, 10);
63
+ this.ipWidth = parseInt(ipWidth, 10);
64
+ if (!this.ipWidth) {
65
+ this.ipWidth = elementRef.nativeElement.offsetWidth;
66
+ }
67
+ this.ipIconSize = parseInt(ipIconSize, 10);
68
+ this.ipIconVerticalPadding = parseInt(ipIconVerticalPadding, 10);
69
+ this.ipIconHorizontalPadding = parseInt(ipIconHorizontalPadding, 10);
70
+ this.ipKeepSearchFilter = JSON.parse(ipKeepSearchFilter);
71
+ this.ipPlaceHolder = ipPlaceHolder;
72
+ this.ipFallbackIcon = ipFallbackIcon;
73
+ this.ipIconPack = ipIconPack;
74
+ this.ipButtonStyleClass = ipButtonStyleClass;
75
+ this.ipInputSearchStyleClass = ipInputSearchStyleClass;
76
+ this.ipDivSearchStyleClass = ipDivSearchStyleClass;
77
+ this.ipUseRootViewContainer = ipUseRootViewContainer;
78
+ this.buttonHeight = this.ipIconSize + 2 * this.ipIconVerticalPadding;
79
+ this.buttonWidth = this.ipIconSize + 2 * this.ipIconHorizontalPadding;
80
+ }
81
+ ngOnInit() {
82
+ this.icons = this.service.getIcons(this.ipIconPack);
83
+ this.listenerMouseDown = (event) => this.onMouseDown(event);
84
+ this.listenerResize = () => this.onResize();
85
+ this.openDialog(this.initialIcon);
86
+ }
87
+ setInitialIcon(icon) {
88
+ this.initialIcon = icon;
89
+ this.selectedIcon = this.icons.find(el => el ?
90
+ `fa fa-${el.id}` === icon || `pi pi-${el.id}` === icon || `${el.id}` === icon :
91
+ false);
92
+ if (this.ipKeepSearchFilter && this.selectedIcon && icon !== this.ipFallbackIcon) {
93
+ this.search = this.selectedIcon.id;
94
+ }
95
+ else {
96
+ this.search = '';
97
+ }
98
+ }
99
+ openDialog(icon) {
100
+ this.setInitialIcon(icon);
101
+ this.openIconPicker();
102
+ }
103
+ setSearch(val) {
104
+ this.search = val;
105
+ }
106
+ selectIcon(icon) {
107
+ if (icon.type === IconType.FontAwesome) {
108
+ this.directiveInstance.iconSelected(`fa fa-${icon.id}`);
109
+ }
110
+ else if (icon.type === IconType.FontAwesome5) {
111
+ this.directiveInstance.iconSelected(`${icon.id}`);
112
+ }
113
+ else if (icon.type === IconType.FontAwesome6) {
114
+ this.directiveInstance.iconSelected(`${icon.id}`);
115
+ }
116
+ else if (icon.type === IconType.Material) {
117
+ this.directiveInstance.iconSelected(`${icon.id}`);
118
+ }
119
+ else if (icon.type === IconType.PrimeIcons) {
120
+ this.directiveInstance.iconSelected(`pi pi-${icon.id}`);
121
+ }
122
+ this.closeIconPicker();
123
+ }
124
+ onMouseDown(event) {
125
+ if (!this.isDescendant(this.el.nativeElement, event.target) && event.target !== this.directiveElementRef.nativeElement) {
126
+ this.closeIconPicker();
127
+ }
128
+ }
129
+ openIconPicker() {
130
+ if (!this.show) {
131
+ this.show = true;
132
+ this.hidden = true;
133
+ setTimeout(() => {
134
+ this.setDialogPosition();
135
+ this.hidden = false;
136
+ this.cdr.detectChanges();
137
+ }, 0);
138
+ this.directiveInstance.stateChanged(true);
139
+ document.addEventListener('mousedown', this.listenerMouseDown);
140
+ window.addEventListener('resize', this.listenerResize);
141
+ }
142
+ }
143
+ closeIconPicker() {
144
+ if (this.show) {
145
+ this.show = false;
146
+ this.directiveInstance.stateChanged(false);
147
+ document.removeEventListener('mousedown', this.listenerMouseDown);
148
+ window.removeEventListener('resize', this.listenerResize);
149
+ this.cdr.detectChanges();
150
+ }
151
+ }
152
+ onResize() {
153
+ if (this.position === 'fixed') {
154
+ this.setDialogPosition();
155
+ }
156
+ }
157
+ setDialogPosition() {
158
+ const dialogHeight = this.dialogElement.nativeElement.offsetHeight;
159
+ let node = this.directiveElementRef.nativeElement;
160
+ let position = 'static';
161
+ let transform = '';
162
+ let parentNode = null;
163
+ let transformNode = null;
164
+ let style = null;
165
+ while (node !== null && node.tagName !== 'HTML') {
166
+ style = window.getComputedStyle(node);
167
+ position = style.getPropertyValue('position');
168
+ transform = style.getPropertyValue('transform');
169
+ if (position !== 'static' && parentNode === null) {
170
+ parentNode = node;
171
+ }
172
+ if (transform && transform !== 'none' && transformNode === null) {
173
+ transformNode = node;
174
+ }
175
+ if (position === 'fixed') {
176
+ parentNode = transformNode;
177
+ break;
178
+ }
179
+ node = node.parentNode;
180
+ }
181
+ const boxDirective = this.createBox(this.directiveElementRef.nativeElement, (position !== 'fixed'));
182
+ if (this.ipUseRootViewContainer || (position === 'fixed' &&
183
+ (!parentNode || parentNode instanceof HTMLUnknownElement))) {
184
+ this.top = boxDirective.top;
185
+ this.left = boxDirective.left;
186
+ }
187
+ else {
188
+ if (parentNode === null) {
189
+ parentNode = node;
190
+ }
191
+ const boxParent = this.createBox(parentNode, (position !== 'fixed'));
192
+ this.top = boxDirective.top - boxParent.top;
193
+ this.left = boxDirective.left - boxParent.left;
194
+ }
195
+ if (position === 'fixed') {
196
+ this.position = 'fixed';
197
+ }
198
+ if (this.ipPosition === 'left') {
199
+ this.left -= this.ipWidth + this.dialogArrowSize - 2;
200
+ }
201
+ else if (this.ipPosition === 'top') {
202
+ this.top -= dialogHeight + this.dialogArrowSize;
203
+ this.arrowTop = dialogHeight - 1;
204
+ }
205
+ else if (this.ipPosition === 'bottom') {
206
+ this.top += boxDirective.height + this.dialogArrowSize;
207
+ }
208
+ else {
209
+ this.left += boxDirective.width + this.dialogArrowSize - 2;
210
+ }
211
+ }
212
+ isDescendant(parent, child) {
213
+ let node = child.parentNode;
214
+ while (node !== null) {
215
+ if (node === parent) {
216
+ return true;
217
+ }
218
+ node = node.parentNode;
219
+ }
220
+ return false;
221
+ }
222
+ createBox(element, offset) {
223
+ return {
224
+ top: element.getBoundingClientRect().top + (offset ? window.pageYOffset : 0),
225
+ left: element.getBoundingClientRect().left + (offset ? window.pageXOffset : 0),
226
+ width: element.offsetWidth,
227
+ height: element.offsetHeight
228
+ };
229
+ }
230
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.IconPickerService }], target: i0.ɵɵFactoryTarget.Component });
231
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: IconPickerComponent, selector: "icon-picker", viewQueries: [{ propertyName: "dialogElement", first: true, predicate: ["dialogPopup"], descendants: true }], ngImport: i0, template: "<div class=\"icon-picker\" #dialogPopup\r\n [hidden]=\"!show\"\r\n [style.visibility]=\"this.hidden ? 'hidden' : 'visible'\"\r\n [style.height.px]=\"ipHeight\"\r\n [style.width.px]=\"ipWidth\"\r\n [style.top.px]=\"top\"\r\n [style.left.px]=\"left\"\r\n [style.position]=\"position\">\r\n\r\n <div class=\"arrow arrow-{{ipPosition}}\" [style.top.px]=\"arrowTop\"></div>\r\n\r\n <div class=\"icon-search {{ipDivSearchStyleClass}}\">\r\n <input type=\"text\" class=\"{{ipInputSearchStyleClass}}\" [text] [value]=\"search\" (newValue)=\"setSearch($event)\"\r\n [placeholder]=\"ipPlaceHolder\">\r\n </div>\r\n <div class=\"icon-grid\" [ngStyle]=\"{'max-height.px': ipMaxHeight}\">\r\n <div *ngFor=\"let icon of icons | searchIcon:search\">\r\n <button *ngIf=\"icon\" class=\"ip-button-icon {{ipButtonStyleClass}}\" type=\"button\" title=\"{{ icon.name }}\"\r\n [ngClass]=\"{active : icon === selectedIcon}\"\r\n [style.width.px]=\"buttonWidth\"\r\n [style.height.px]=\"buttonHeight\"\r\n [style.padding-top.px]=\"ipIconVerticalPadding\"\r\n [style.padding-bottom.px]=\"ipIconVerticalPadding\"\r\n [style.padding-left.px]=\"ipIconHorizontalPadding\"\r\n [style.padding-right.px]=\"ipIconHorizontalPadding\"\r\n (click)=\"selectIcon(icon)\">\r\n <span *ngIf=\"icon.type === iconType.FontAwesome\" class=\"fa fa-{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n <span *ngIf=\"icon.type === iconType.FontAwesome5\" class=\"{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n <span *ngIf=\"icon.type === iconType.FontAwesome6\" [style.font-size.px]=\"ipIconSize\">\r\n <fa-icon [icon]=\"['fas', icon.iconName]\"></fa-icon>\r\n </span>\r\n <span *ngIf=\"icon.type === iconType.Material\" class=\"material-icons\"\r\n [style.font-size.px]=\"ipIconSize\">{{icon.id}}</span>\r\n <span *ngIf=\"icon.type === iconType.PrimeIcons\" class=\"pi pi-{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n", styles: [".icon-picker{box-sizing:border-box;margin:0;position:absolute;z-index:100000;top:250px;left:30px;width:230px;height:auto;border:#777 solid 1px;cursor:default;background-color:#fff;-webkit-user-select:none;user-select:none}.icon-picker i{position:relative;cursor:default}.icon-picker .arrow{position:absolute;z-index:999999;width:0;height:0;border-style:solid}.icon-picker .arrow-right{top:10px;left:-20px;border-width:5px 10px;border-color:rgba(0,0,0,0) #777 rgba(0,0,0,0) rgba(0,0,0,0)}.icon-picker .arrow-left{top:10px;left:100%;border-width:5px 10px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0) #777}.icon-picker .arrow-bottom{top:-20px;left:10px;border-width:10px 5px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) #777 rgba(0,0,0,0)}.icon-picker .arrow-top{left:10px;border-width:10px 5px;border-color:#777 rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0)}.icon-picker div.icon-search{padding:5px}.icon-picker div.icon-grid{display:flex;overflow-y:auto;flex-direction:row;flex-wrap:wrap;padding:5px}.icon-picker div.icon-grid div{margin:2px}.icon-picker div.cursor-sv{position:relative;width:15px;height:15px;border-radius:50%;border:#ddd solid 1px;cursor:default}.icon-picker div.cursor{position:relative;width:16px;height:16px;border-radius:50%;border:#222 solid 2px;cursor:default}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "directive", type: i4.TextDirective, selector: "[text]", inputs: ["text"], outputs: ["newValue"] }, { kind: "pipe", type: i5.SearchIconPipe, name: "searchIcon" }] });
232
+ }
233
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerComponent, decorators: [{
234
+ type: Component,
235
+ args: [{ selector: 'icon-picker', template: "<div class=\"icon-picker\" #dialogPopup\r\n [hidden]=\"!show\"\r\n [style.visibility]=\"this.hidden ? 'hidden' : 'visible'\"\r\n [style.height.px]=\"ipHeight\"\r\n [style.width.px]=\"ipWidth\"\r\n [style.top.px]=\"top\"\r\n [style.left.px]=\"left\"\r\n [style.position]=\"position\">\r\n\r\n <div class=\"arrow arrow-{{ipPosition}}\" [style.top.px]=\"arrowTop\"></div>\r\n\r\n <div class=\"icon-search {{ipDivSearchStyleClass}}\">\r\n <input type=\"text\" class=\"{{ipInputSearchStyleClass}}\" [text] [value]=\"search\" (newValue)=\"setSearch($event)\"\r\n [placeholder]=\"ipPlaceHolder\">\r\n </div>\r\n <div class=\"icon-grid\" [ngStyle]=\"{'max-height.px': ipMaxHeight}\">\r\n <div *ngFor=\"let icon of icons | searchIcon:search\">\r\n <button *ngIf=\"icon\" class=\"ip-button-icon {{ipButtonStyleClass}}\" type=\"button\" title=\"{{ icon.name }}\"\r\n [ngClass]=\"{active : icon === selectedIcon}\"\r\n [style.width.px]=\"buttonWidth\"\r\n [style.height.px]=\"buttonHeight\"\r\n [style.padding-top.px]=\"ipIconVerticalPadding\"\r\n [style.padding-bottom.px]=\"ipIconVerticalPadding\"\r\n [style.padding-left.px]=\"ipIconHorizontalPadding\"\r\n [style.padding-right.px]=\"ipIconHorizontalPadding\"\r\n (click)=\"selectIcon(icon)\">\r\n <span *ngIf=\"icon.type === iconType.FontAwesome\" class=\"fa fa-{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n <span *ngIf=\"icon.type === iconType.FontAwesome5\" class=\"{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n <span *ngIf=\"icon.type === iconType.FontAwesome6\" [style.font-size.px]=\"ipIconSize\">\r\n <fa-icon [icon]=\"['fas', icon.iconName]\"></fa-icon>\r\n </span>\r\n <span *ngIf=\"icon.type === iconType.Material\" class=\"material-icons\"\r\n [style.font-size.px]=\"ipIconSize\">{{icon.id}}</span>\r\n <span *ngIf=\"icon.type === iconType.PrimeIcons\" class=\"pi pi-{{icon.id}}\"\r\n [style.font-size.px]=\"ipIconSize\"></span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n</div>\r\n", styles: [".icon-picker{box-sizing:border-box;margin:0;position:absolute;z-index:100000;top:250px;left:30px;width:230px;height:auto;border:#777 solid 1px;cursor:default;background-color:#fff;-webkit-user-select:none;user-select:none}.icon-picker i{position:relative;cursor:default}.icon-picker .arrow{position:absolute;z-index:999999;width:0;height:0;border-style:solid}.icon-picker .arrow-right{top:10px;left:-20px;border-width:5px 10px;border-color:rgba(0,0,0,0) #777 rgba(0,0,0,0) rgba(0,0,0,0)}.icon-picker .arrow-left{top:10px;left:100%;border-width:5px 10px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0) #777}.icon-picker .arrow-bottom{top:-20px;left:10px;border-width:10px 5px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) #777 rgba(0,0,0,0)}.icon-picker .arrow-top{left:10px;border-width:10px 5px;border-color:#777 rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0)}.icon-picker div.icon-search{padding:5px}.icon-picker div.icon-grid{display:flex;overflow-y:auto;flex-direction:row;flex-wrap:wrap;padding:5px}.icon-picker div.icon-grid div{margin:2px}.icon-picker div.cursor-sv{position:relative;width:15px;height:15px;border-radius:50%;border:#ddd solid 1px;cursor:default}.icon-picker div.cursor{position:relative;width:16px;height:16px;border-radius:50%;border:#222 solid 2px;cursor:default}\n"] }]
236
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.IconPickerService }]; }, propDecorators: { dialogElement: [{
237
+ type: ViewChild,
238
+ args: ['dialogPopup']
239
+ }] } });
240
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-picker.component.js","sourceRoot":"","sources":["../../../../projects/ngx-ntk-icon-picker/src/lib/icon-picker.component.ts","../../../../projects/ngx-ntk-icon-picker/src/lib/icon-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\r\n\r\nimport { IconPickerService } from './icon-picker.service';\r\nimport { Icon, IconType } from './icon';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'icon-picker',\r\n  templateUrl: './icon-picker.component.html',\r\n  styleUrls: ['./icon-picker.component.scss']\r\n})\r\n\r\nexport class IconPickerComponent implements OnInit {\r\n  @ViewChild('dialogPopup') dialogElement: any;\r\n\r\n  // Popover\r\n  public ipPosition: string;\r\n  public ipHeight: number;\r\n  public ipMaxHeight: number;\r\n  public ipWidth: number;\r\n  // Icon css\r\n  public ipIconSize: number;\r\n  public ipIconVerticalPadding: number;\r\n  public ipIconHorizontalPadding: number;\r\n  // Item Style ie input and button\r\n  public ipButtonStyleClass: string;\r\n  public ipInputSearchStyleClass: string;\r\n  public ipDivSearchStyleClass: string;\r\n  public ipUseRootViewContainer: boolean = false;\r\n  // Icon and behaviors\r\n  public ipKeepSearchFilter: boolean;\r\n  public ipPlaceHolder: string;\r\n  public ipFallbackIcon: string;\r\n  public ipIconPack: string[];\r\n\r\n  public show: boolean;\r\n  public hidden: boolean;\r\n  public top: number;\r\n  public left: number;\r\n  public position: string;\r\n  public arrowTop: number;\r\n  public selectedIcon: Icon;\r\n  public iconType = IconType;\r\n  public buttonWidth: number;\r\n  public buttonHeight: number;\r\n\r\n  icons: Icon[] = [];\r\n  search = '';\r\n\r\n  private directiveInstance: any;\r\n  private initialIcon: string;\r\n  private directiveElementRef: ElementRef;\r\n\r\n  private listenerMouseDown: any;\r\n  private listenerResize: any;\r\n\r\n  private dialogArrowSize = 10;\r\n\r\n  constructor(\r\n    private el: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private service: IconPickerService) {\r\n  }\r\n\r\n  setDialog(instance: any, elementRef: ElementRef, icon: string, ipPosition: string, ipHeight: string, ipMaxHeight: string,\r\n            ipWidth: string, ipPlaceHolder: string, ipFallbackIcon: string, ipIconPack: string[], ipIconSize: string,\r\n            ipIconVerticalPadding: string, ipIconHorizontalPadding: string, ipButtonStyleClass: string, ipDivSearchStyleClass: string,\r\n            ipInputSearchStyleClass: string, ipKeepSearchFilter: string, ipUseRootViewContainer?: boolean) {\r\n    this.directiveInstance = instance;\r\n    this.setInitialIcon(icon);\r\n    this.directiveElementRef = elementRef;\r\n    this.ipPosition = ipPosition;\r\n    this.ipHeight = parseInt(ipHeight, 10);\r\n    this.ipMaxHeight = parseInt(ipMaxHeight, 10);\r\n    this.ipWidth = parseInt(ipWidth, 10);\r\n    if (!this.ipWidth) {\r\n      this.ipWidth = elementRef.nativeElement.offsetWidth;\r\n    }\r\n    this.ipIconSize = parseInt(ipIconSize, 10);\r\n    this.ipIconVerticalPadding = parseInt(ipIconVerticalPadding, 10);\r\n    this.ipIconHorizontalPadding = parseInt(ipIconHorizontalPadding, 10);\r\n    this.ipKeepSearchFilter = JSON.parse(ipKeepSearchFilter);\r\n    this.ipPlaceHolder = ipPlaceHolder;\r\n    this.ipFallbackIcon = ipFallbackIcon;\r\n    this.ipIconPack = ipIconPack;\r\n    this.ipButtonStyleClass = ipButtonStyleClass;\r\n    this.ipInputSearchStyleClass = ipInputSearchStyleClass;\r\n    this.ipDivSearchStyleClass = ipDivSearchStyleClass;\r\n    this.ipUseRootViewContainer = ipUseRootViewContainer;\r\n\r\n\r\n    this.buttonHeight = this.ipIconSize + 2 * this.ipIconVerticalPadding;\r\n    this.buttonWidth = this.ipIconSize + 2 * this.ipIconHorizontalPadding;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.icons = this.service.getIcons(this.ipIconPack);\r\n    this.listenerMouseDown = (event: any) => this.onMouseDown(event);\r\n    this.listenerResize = () => this.onResize();\r\n    this.openDialog(this.initialIcon);\r\n  }\r\n\r\n  setInitialIcon(icon: string) {\r\n    this.initialIcon = icon;\r\n    this.selectedIcon = this.icons.find(el => el ?\r\n      `fa fa-${el.id}` === icon || `pi pi-${el.id}` === icon || `${el.id}` === icon :\r\n      false\r\n    );\r\n    if (this.ipKeepSearchFilter && this.selectedIcon && icon !== this.ipFallbackIcon) {\r\n      this.search = this.selectedIcon.id;\r\n    } else {\r\n      this.search = '';\r\n    }\r\n  }\r\n\r\n  openDialog(icon: string) {\r\n    this.setInitialIcon(icon);\r\n    this.openIconPicker();\r\n  }\r\n\r\n  setSearch(val: string) {\r\n    this.search = val;\r\n  }\r\n\r\n  selectIcon(icon: Icon): void {\r\n    if (icon.type === IconType.FontAwesome) {\r\n      this.directiveInstance.iconSelected(`fa fa-${icon.id}`);\r\n    } else if (icon.type === IconType.FontAwesome5) {\r\n      this.directiveInstance.iconSelected(`${icon.id}`);\r\n    } else if (icon.type === IconType.FontAwesome6) {\r\n      this.directiveInstance.iconSelected(`${icon.id}`);\r\n    } else if (icon.type === IconType.Material) {\r\n      this.directiveInstance.iconSelected(`${icon.id}`);\r\n    } else if (icon.type === IconType.PrimeIcons) {\r\n      this.directiveInstance.iconSelected(`pi pi-${icon.id}`);\r\n    }\r\n    this.closeIconPicker();\r\n  }\r\n\r\n  onMouseDown(event: any) {\r\n    if (!this.isDescendant(this.el.nativeElement, event.target) && event.target !== this.directiveElementRef.nativeElement) {\r\n      this.closeIconPicker();\r\n    }\r\n  }\r\n\r\n  openIconPicker() {\r\n    if (!this.show) {\r\n      this.show = true;\r\n      this.hidden = true;\r\n      setTimeout(() => {\r\n        this.setDialogPosition();\r\n        this.hidden = false;\r\n        this.cdr.detectChanges();\r\n      }, 0);\r\n      this.directiveInstance.stateChanged(true);\r\n      document.addEventListener('mousedown', this.listenerMouseDown);\r\n      window.addEventListener('resize', this.listenerResize);\r\n    }\r\n  }\r\n\r\n  closeIconPicker() {\r\n    if (this.show) {\r\n      this.show = false;\r\n      this.directiveInstance.stateChanged(false);\r\n      document.removeEventListener('mousedown', this.listenerMouseDown);\r\n      window.removeEventListener('resize', this.listenerResize);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  onResize() {\r\n    if (this.position === 'fixed') {\r\n      this.setDialogPosition();\r\n    }\r\n  }\r\n\r\n  setDialogPosition() {\r\n    const dialogHeight = this.dialogElement.nativeElement.offsetHeight;\r\n    let node = this.directiveElementRef.nativeElement;\r\n    let position = 'static';\r\n    let transform = '';\r\n    let parentNode: any = null;\r\n    let transformNode: any = null;\r\n    let style: any = null;\r\n    while (node !== null && node.tagName !== 'HTML') {\r\n      style = window.getComputedStyle(node);\r\n      position = style.getPropertyValue('position');\r\n      transform = style.getPropertyValue('transform');\r\n      if (position !== 'static' && parentNode === null) {\r\n        parentNode = node;\r\n      }\r\n      if (transform && transform !== 'none' && transformNode === null) {\r\n        transformNode = node;\r\n      }\r\n      if (position === 'fixed') {\r\n        parentNode = transformNode;\r\n        break;\r\n      }\r\n      node = node.parentNode;\r\n    }\r\n    const boxDirective = this.createBox(this.directiveElementRef.nativeElement, (position !== 'fixed'));\r\n    if (this.ipUseRootViewContainer || (position === 'fixed' &&\r\n      (!parentNode || parentNode instanceof HTMLUnknownElement))) {\r\n      this.top = boxDirective.top;\r\n      this.left = boxDirective.left;\r\n    } else {\r\n      if (parentNode === null) {\r\n        parentNode = node;\r\n      }\r\n\r\n      const boxParent = this.createBox(parentNode, (position !== 'fixed'));\r\n\r\n      this.top = boxDirective.top - boxParent.top;\r\n      this.left = boxDirective.left - boxParent.left;\r\n    }\r\n\r\n    if (position === 'fixed') {\r\n      this.position = 'fixed';\r\n    }\r\n    if (this.ipPosition === 'left') {\r\n      this.left -= this.ipWidth + this.dialogArrowSize - 2;\r\n    } else if (this.ipPosition === 'top') {\r\n      this.top -= dialogHeight + this.dialogArrowSize;\r\n      this.arrowTop = dialogHeight - 1;\r\n    } else if (this.ipPosition === 'bottom') {\r\n      this.top += boxDirective.height + this.dialogArrowSize;\r\n    } else {\r\n      this.left += boxDirective.width + this.dialogArrowSize - 2;\r\n    }\r\n  }\r\n\r\n  isDescendant(parent: any, child: any): boolean {\r\n    let node: any = child.parentNode;\r\n    while (node !== null) {\r\n      if (node === parent) {\r\n        return true;\r\n      }\r\n      node = node.parentNode;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  createBox(element: any, offset: boolean): any {\r\n    return {\r\n      top: element.getBoundingClientRect().top + (offset ? window.pageYOffset : 0),\r\n      left: element.getBoundingClientRect().left + (offset ? window.pageXOffset : 0),\r\n      width: element.offsetWidth,\r\n      height: element.offsetHeight\r\n    };\r\n  }\r\n}\r\n","<div class=\"icon-picker\" #dialogPopup\r\n     [hidden]=\"!show\"\r\n     [style.visibility]=\"this.hidden ? 'hidden' : 'visible'\"\r\n     [style.height.px]=\"ipHeight\"\r\n     [style.width.px]=\"ipWidth\"\r\n     [style.top.px]=\"top\"\r\n     [style.left.px]=\"left\"\r\n     [style.position]=\"position\">\r\n\r\n  <div class=\"arrow arrow-{{ipPosition}}\" [style.top.px]=\"arrowTop\"></div>\r\n\r\n  <div class=\"icon-search {{ipDivSearchStyleClass}}\">\r\n    <input type=\"text\" class=\"{{ipInputSearchStyleClass}}\" [text] [value]=\"search\" (newValue)=\"setSearch($event)\"\r\n           [placeholder]=\"ipPlaceHolder\">\r\n  </div>\r\n  <div class=\"icon-grid\" [ngStyle]=\"{'max-height.px': ipMaxHeight}\">\r\n    <div *ngFor=\"let icon of icons | searchIcon:search\">\r\n      <button *ngIf=\"icon\" class=\"ip-button-icon {{ipButtonStyleClass}}\" type=\"button\" title=\"{{ icon.name }}\"\r\n              [ngClass]=\"{active : icon === selectedIcon}\"\r\n              [style.width.px]=\"buttonWidth\"\r\n              [style.height.px]=\"buttonHeight\"\r\n              [style.padding-top.px]=\"ipIconVerticalPadding\"\r\n              [style.padding-bottom.px]=\"ipIconVerticalPadding\"\r\n              [style.padding-left.px]=\"ipIconHorizontalPadding\"\r\n              [style.padding-right.px]=\"ipIconHorizontalPadding\"\r\n              (click)=\"selectIcon(icon)\">\r\n        <span *ngIf=\"icon.type === iconType.FontAwesome\" class=\"fa fa-{{icon.id}}\"\r\n              [style.font-size.px]=\"ipIconSize\"></span>\r\n        <span *ngIf=\"icon.type === iconType.FontAwesome5\" class=\"{{icon.id}}\"\r\n              [style.font-size.px]=\"ipIconSize\"></span>\r\n        <span *ngIf=\"icon.type === iconType.FontAwesome6\" [style.font-size.px]=\"ipIconSize\">\r\n          <fa-icon [icon]=\"['fas', icon.iconName]\"></fa-icon>\r\n        </span>\r\n        <span *ngIf=\"icon.type === iconType.Material\" class=\"material-icons\"\r\n              [style.font-size.px]=\"ipIconSize\">{{icon.id}}</span>\r\n        <span *ngIf=\"icon.type === iconType.PrimeIcons\" class=\"pi pi-{{icon.id}}\"\r\n              [style.font-size.px]=\"ipIconSize\"></span>\r\n      </button>\r\n    </div>\r\n  </div>\r\n\r\n</div>\r\n"]}
@@ -0,0 +1,136 @@
1
+ import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
2
+ import { IconPickerComponent } from './icon-picker.component';
3
+ import * as i0 from "@angular/core";
4
+ export class IconPickerDirective {
5
+ vcRef;
6
+ el;
7
+ iconPicker;
8
+ ipPlaceHolder = 'Search icon...';
9
+ ipPosition = 'right';
10
+ ipFallbackIcon = 'fas fa-user';
11
+ ipHeight = 'auto';
12
+ ipMaxHeight = '200px';
13
+ ipWidth = '230px';
14
+ ipIconSize = '16px';
15
+ ipIconVerticalPadding = '6px'; // Top / Bottom
16
+ ipIconHorizontalPadding = '10px'; // Left / Right
17
+ ipIconPack = ['fa5'];
18
+ ipKeepSearchFilter = 'false';
19
+ ipUseRootViewContainer = false;
20
+ // Default design with bootstrap
21
+ ipButtonStyleClass = 'btn btn-default';
22
+ ipDivSearchStyleClass = '';
23
+ ipInputSearchStyleClass = 'form-control input-sm';
24
+ iconPickerSelect = new EventEmitter(true);
25
+ iconPickerOpen = new EventEmitter(true);
26
+ iconPickerClose = new EventEmitter(true);
27
+ iconPickerFocus = new EventEmitter(true);
28
+ handleFocus() {
29
+ this.elementFocus();
30
+ }
31
+ dialog;
32
+ created;
33
+ ignoreChanges = false;
34
+ constructor(vcRef, el) {
35
+ this.vcRef = vcRef;
36
+ this.el = el;
37
+ this.created = false;
38
+ }
39
+ onClick() {
40
+ this.openDialog();
41
+ }
42
+ ngOnChanges(changes) {
43
+ if (changes.iconPicker) {
44
+ this.ignoreChanges = false;
45
+ }
46
+ }
47
+ ngOnInit() {
48
+ this.iconPicker = this.iconPicker || this.ipFallbackIcon || 'fa fa-user-plus';
49
+ this.iconPickerSelect.emit(this.iconPicker);
50
+ }
51
+ openDialog() {
52
+ if (!this.created) {
53
+ this.created = true;
54
+ const vcRef = this.vcRef;
55
+ const cmpRef = vcRef.createComponent(IconPickerComponent);
56
+ cmpRef.instance.setDialog(this, this.el, this.iconPicker, this.ipPosition, this.ipHeight, this.ipMaxHeight, this.ipWidth, this.ipPlaceHolder, this.ipFallbackIcon, this.ipIconPack, this.ipIconSize, this.ipIconVerticalPadding, this.ipIconHorizontalPadding, this.ipButtonStyleClass, this.ipDivSearchStyleClass, this.ipInputSearchStyleClass, this.ipKeepSearchFilter, this.ipUseRootViewContainer);
57
+ this.dialog = cmpRef.instance;
58
+ if (this.vcRef !== vcRef) {
59
+ cmpRef.changeDetectorRef.detectChanges();
60
+ }
61
+ }
62
+ else if (this.dialog) {
63
+ this.dialog.openDialog(this.iconPicker);
64
+ }
65
+ }
66
+ iconSelected(icon) {
67
+ this.iconPickerSelect.emit(icon);
68
+ }
69
+ stateChanged(state) {
70
+ if (state) {
71
+ this.iconPickerOpen.emit();
72
+ }
73
+ else {
74
+ this.iconPickerClose.emit();
75
+ }
76
+ }
77
+ elementFocus() {
78
+ this.iconPickerFocus.emit();
79
+ }
80
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
81
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: IconPickerDirective, selector: "[iconPicker]", inputs: { iconPicker: "iconPicker", ipPlaceHolder: "ipPlaceHolder", ipPosition: "ipPosition", ipFallbackIcon: "ipFallbackIcon", ipHeight: "ipHeight", ipMaxHeight: "ipMaxHeight", ipWidth: "ipWidth", ipIconSize: "ipIconSize", ipIconVerticalPadding: "ipIconVerticalPadding", ipIconHorizontalPadding: "ipIconHorizontalPadding", ipIconPack: "ipIconPack", ipKeepSearchFilter: "ipKeepSearchFilter", ipUseRootViewContainer: "ipUseRootViewContainer", ipButtonStyleClass: "ipButtonStyleClass", ipDivSearchStyleClass: "ipDivSearchStyleClass", ipInputSearchStyleClass: "ipInputSearchStyleClass" }, outputs: { iconPickerSelect: "iconPickerSelect", iconPickerOpen: "iconPickerOpen", iconPickerClose: "iconPickerClose", iconPickerFocus: "iconPickerFocus" }, host: { listeners: { "focus": "handleFocus()", "click": "onClick()" } }, usesOnChanges: true, ngImport: i0 });
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerDirective, decorators: [{
84
+ type: Directive,
85
+ args: [{
86
+ // eslint-disable-next-line @angular-eslint/directive-selector
87
+ selector: '[iconPicker]'
88
+ }]
89
+ }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ElementRef }]; }, propDecorators: { iconPicker: [{
90
+ type: Input
91
+ }], ipPlaceHolder: [{
92
+ type: Input
93
+ }], ipPosition: [{
94
+ type: Input
95
+ }], ipFallbackIcon: [{
96
+ type: Input
97
+ }], ipHeight: [{
98
+ type: Input
99
+ }], ipMaxHeight: [{
100
+ type: Input
101
+ }], ipWidth: [{
102
+ type: Input
103
+ }], ipIconSize: [{
104
+ type: Input
105
+ }], ipIconVerticalPadding: [{
106
+ type: Input
107
+ }], ipIconHorizontalPadding: [{
108
+ type: Input
109
+ }], ipIconPack: [{
110
+ type: Input
111
+ }], ipKeepSearchFilter: [{
112
+ type: Input
113
+ }], ipUseRootViewContainer: [{
114
+ type: Input
115
+ }], ipButtonStyleClass: [{
116
+ type: Input
117
+ }], ipDivSearchStyleClass: [{
118
+ type: Input
119
+ }], ipInputSearchStyleClass: [{
120
+ type: Input
121
+ }], iconPickerSelect: [{
122
+ type: Output
123
+ }], iconPickerOpen: [{
124
+ type: Output
125
+ }], iconPickerClose: [{
126
+ type: Output
127
+ }], iconPickerFocus: [{
128
+ type: Output
129
+ }], handleFocus: [{
130
+ type: HostListener,
131
+ args: ['focus']
132
+ }], onClick: [{
133
+ type: HostListener,
134
+ args: ['click']
135
+ }] } });
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon-picker.directive.js","sourceRoot":"","sources":["../../../../projects/ngx-ntk-icon-picker/src/lib/icon-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\n\r\nimport { IconPickerComponent } from './icon-picker.component';\r\n\r\n@Directive({\r\n  // eslint-disable-next-line @angular-eslint/directive-selector\r\n  selector: '[iconPicker]'\r\n})\r\nexport class IconPickerDirective implements OnInit, OnChanges {\r\n  @Input() iconPicker: string;\r\n  @Input() ipPlaceHolder = 'Search icon...';\r\n  @Input() ipPosition = 'right';\r\n  @Input() ipFallbackIcon = 'fas fa-user';\r\n  @Input() ipHeight = 'auto';\r\n  @Input() ipMaxHeight = '200px';\r\n  @Input() ipWidth = '230px';\r\n  @Input() ipIconSize = '16px';\r\n  @Input() ipIconVerticalPadding = '6px'; // Top / Bottom\r\n  @Input() ipIconHorizontalPadding = '10px'; // Left / Right\r\n  @Input() ipIconPack = ['fa5'];\r\n  @Input() ipKeepSearchFilter = 'false';\r\n  @Input() ipUseRootViewContainer = false;\r\n  // Default design with bootstrap\r\n  @Input() ipButtonStyleClass = 'btn btn-default';\r\n  @Input() ipDivSearchStyleClass = '';\r\n  @Input() ipInputSearchStyleClass = 'form-control input-sm';\r\n\r\n  @Output() iconPickerSelect = new EventEmitter<string>(true);\r\n  @Output() iconPickerOpen = new EventEmitter<void>(true);\r\n  @Output() iconPickerClose = new EventEmitter<void>(true);\r\n  @Output() iconPickerFocus = new EventEmitter<void>(true);\r\n\r\n  @HostListener('focus') handleFocus(): void {\r\n    this.elementFocus();\r\n  }\r\n\r\n  private dialog: any;\r\n  private created: boolean;\r\n  private ignoreChanges = false;\r\n\r\n  constructor(\r\n    private vcRef: ViewContainerRef,\r\n    private el: ElementRef) {\r\n    this.created = false;\r\n  }\r\n\r\n  @HostListener('click')\r\n  onClick() {\r\n    this.openDialog();\r\n  }\r\n\r\n  ngOnChanges(changes: any): void {\r\n    if (changes.iconPicker) {\r\n      this.ignoreChanges = false;\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.iconPicker = this.iconPicker || this.ipFallbackIcon || 'fa fa-user-plus';\r\n    this.iconPickerSelect.emit(this.iconPicker);\r\n  }\r\n\r\n  openDialog() {\r\n    if (!this.created) {\r\n      this.created = true;\r\n      const vcRef = this.vcRef;\r\n      const cmpRef = vcRef.createComponent(IconPickerComponent);\r\n      cmpRef.instance.setDialog(this, this.el, this.iconPicker, this.ipPosition, this.ipHeight, this.ipMaxHeight,\r\n        this.ipWidth, this.ipPlaceHolder, this.ipFallbackIcon, this.ipIconPack, this.ipIconSize,\r\n        this.ipIconVerticalPadding, this.ipIconHorizontalPadding, this.ipButtonStyleClass, this.ipDivSearchStyleClass,\r\n        this.ipInputSearchStyleClass, this.ipKeepSearchFilter, this.ipUseRootViewContainer);\r\n      this.dialog = cmpRef.instance;\r\n\r\n      if (this.vcRef !== vcRef) {\r\n        cmpRef.changeDetectorRef.detectChanges();\r\n      }\r\n    } else if (this.dialog) {\r\n      this.dialog.openDialog(this.iconPicker);\r\n    }\r\n  }\r\n\r\n  iconSelected(icon: string) {\r\n    this.iconPickerSelect.emit(icon);\r\n  }\r\n\r\n  public stateChanged(state: boolean): void {\r\n    if (state) {\r\n      this.iconPickerOpen.emit();\r\n    } else {\r\n      this.iconPickerClose.emit();\r\n    }\r\n  }\r\n\r\n  public elementFocus(): void {\r\n    this.iconPickerFocus.emit();\r\n  }\r\n}\r\n"]}
@@ -8,18 +8,18 @@ import { TextDirective } from './text.directive';
8
8
  import { SearchIconPipe } from './search-icon.pipe';
9
9
  import * as i0 from "@angular/core";
10
10
  export class IconPickerModule {
11
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: IconPickerModule, declarations: [IconPickerComponent,
13
+ IconPickerDirective,
14
+ TextDirective,
15
+ SearchIconPipe], imports: [CommonModule,
16
+ FontAwesomeModule], exports: [IconPickerDirective] });
17
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerModule, providers: [
18
+ IconPickerService
19
+ ], imports: [CommonModule,
20
+ FontAwesomeModule] });
11
21
  }
12
- IconPickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
13
- IconPickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: IconPickerModule, declarations: [IconPickerComponent,
14
- IconPickerDirective,
15
- TextDirective,
16
- SearchIconPipe], imports: [CommonModule,
17
- FontAwesomeModule], exports: [IconPickerDirective] });
18
- IconPickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerModule, providers: [
19
- IconPickerService
20
- ], imports: [CommonModule,
21
- FontAwesomeModule] });
22
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerModule, decorators: [{
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerModule, decorators: [{
23
23
  type: NgModule,
24
24
  args: [{
25
25
  imports: [
@@ -40,4 +40,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
40
40
  ]
41
41
  }]
42
42
  }] });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW50ay1pY29uLXBpY2tlci9zcmMvbGliL2ljb24tcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUVyRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQW9CcEQsTUFBTSxPQUFPLGdCQUFnQjs7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQVRyQixtQkFBbUI7UUFDbkIsbUJBQW1CO1FBQ25CLGFBQWE7UUFDYixjQUFjLGFBVmQsWUFBWTtRQUNaLGlCQUFpQixhQVlqQixtQkFBbUI7K0dBR2QsZ0JBQWdCLGFBYmQ7UUFDUCxpQkFBaUI7S0FDcEIsWUFMRyxZQUFZO1FBQ1osaUJBQWlCOzRGQWVaLGdCQUFnQjtrQkFsQjVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osaUJBQWlCO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNwQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1YsbUJBQW1CO3dCQUNuQixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsY0FBYztxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLG1CQUFtQjtxQkFDdEI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBGb250QXdlc29tZU1vZHVsZSB9IGZyb20gJ0Bmb3J0YXdlc29tZS9hbmd1bGFyLWZvbnRhd2Vzb21lJztcclxuXHJcbmltcG9ydCB7IEljb25QaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9pY29uLXBpY2tlci5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSWNvblBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vaWNvbi1waWNrZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSWNvblBpY2tlckRpcmVjdGl2ZSB9IGZyb20gJy4vaWNvbi1waWNrZXIuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgVGV4dERpcmVjdGl2ZSB9IGZyb20gJy4vdGV4dC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBTZWFyY2hJY29uUGlwZSB9IGZyb20gJy4vc2VhcmNoLWljb24ucGlwZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb250QXdlc29tZU1vZHVsZSxcclxuICAgIF0sXHJcbiAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICBJY29uUGlja2VyU2VydmljZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIEljb25QaWNrZXJDb21wb25lbnQsXHJcbiAgICAgICAgSWNvblBpY2tlckRpcmVjdGl2ZSxcclxuICAgICAgICBUZXh0RGlyZWN0aXZlLFxyXG4gICAgICAgIFNlYXJjaEljb25QaXBlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1xyXG4gICAgICAgIEljb25QaWNrZXJEaXJlY3RpdmVcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEljb25QaWNrZXJNb2R1bGUge1xyXG59XHJcbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW50ay1pY29uLXBpY2tlci9zcmMvbGliL2ljb24tcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUVyRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQW9CcEQsTUFBTSxPQUFPLGdCQUFnQjt3R0FBaEIsZ0JBQWdCO3lHQUFoQixnQkFBZ0IsaUJBVHJCLG1CQUFtQjtZQUNuQixtQkFBbUI7WUFDbkIsYUFBYTtZQUNiLGNBQWMsYUFWZCxZQUFZO1lBQ1osaUJBQWlCLGFBWWpCLG1CQUFtQjt5R0FHZCxnQkFBZ0IsYUFiZDtZQUNQLGlCQUFpQjtTQUNwQixZQUxHLFlBQVk7WUFDWixpQkFBaUI7OzRGQWVaLGdCQUFnQjtrQkFsQjVCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osaUJBQWlCO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNwQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1YsbUJBQW1CO3dCQUNuQixtQkFBbUI7d0JBQ25CLGFBQWE7d0JBQ2IsY0FBYztxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLG1CQUFtQjtxQkFDdEI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBGb250QXdlc29tZU1vZHVsZSB9IGZyb20gJ0Bmb3J0YXdlc29tZS9hbmd1bGFyLWZvbnRhd2Vzb21lJztcclxuXHJcbmltcG9ydCB7IEljb25QaWNrZXJTZXJ2aWNlIH0gZnJvbSAnLi9pY29uLXBpY2tlci5zZXJ2aWNlJztcclxuaW1wb3J0IHsgSWNvblBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vaWNvbi1waWNrZXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgSWNvblBpY2tlckRpcmVjdGl2ZSB9IGZyb20gJy4vaWNvbi1waWNrZXIuZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgVGV4dERpcmVjdGl2ZSB9IGZyb20gJy4vdGV4dC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBTZWFyY2hJY29uUGlwZSB9IGZyb20gJy4vc2VhcmNoLWljb24ucGlwZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb250QXdlc29tZU1vZHVsZSxcclxuICAgIF0sXHJcbiAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICBJY29uUGlja2VyU2VydmljZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIEljb25QaWNrZXJDb21wb25lbnQsXHJcbiAgICAgICAgSWNvblBpY2tlckRpcmVjdGl2ZSxcclxuICAgICAgICBUZXh0RGlyZWN0aXZlLFxyXG4gICAgICAgIFNlYXJjaEljb25QaXBlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogW1xyXG4gICAgICAgIEljb25QaWNrZXJEaXJlY3RpdmVcclxuICAgIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEljb25QaWNrZXJNb2R1bGUge1xyXG59XHJcbiJdfQ==
@@ -0,0 +1,74 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { IconType } from './icon';
3
+ import { FontAwesome4IconsPack } from './pack/font-awesome4-icons-pack';
4
+ import { FontAwesome5IconsPack } from './pack/font-awesome5-icons-pack';
5
+ import { FontAwesome6IconsPack } from './pack/font-awesome6-icons-pack';
6
+ import { MaterialIconsPack } from './pack/material-icons-pack';
7
+ import { fas } from '@fortawesome/free-solid-svg-icons';
8
+ import { PrimeIconsPack } from './pack/prime-icons-pack';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@fortawesome/angular-fontawesome";
11
+ export class IconPickerService {
12
+ faIconLibrary;
13
+ fa4IconsPack;
14
+ fa5IconsPack;
15
+ fa6IconsPack;
16
+ matIconsPack;
17
+ primeIconsPack;
18
+ constructor(faIconLibrary) {
19
+ this.faIconLibrary = faIconLibrary;
20
+ this.fa4IconsPack = new FontAwesome4IconsPack();
21
+ this.fa5IconsPack = new FontAwesome5IconsPack();
22
+ this.fa6IconsPack = new FontAwesome6IconsPack();
23
+ this.matIconsPack = new MaterialIconsPack();
24
+ this.primeIconsPack = new PrimeIconsPack();
25
+ }
26
+ getIcons(ipIconPacks) {
27
+ const icons = [];
28
+ ipIconPacks.forEach((ipIconPack) => {
29
+ if (ipIconPack === 'fa' || ipIconPack === 'all') {
30
+ const faIcons = this.fa4IconsPack.getIcons().map(icon => {
31
+ icon.type = IconType.FontAwesome;
32
+ return icon;
33
+ });
34
+ icons.push(...faIcons);
35
+ }
36
+ if (ipIconPack === 'fa5' || ipIconPack === 'all') {
37
+ const fa5Icons = this.fa5IconsPack.getIcons().map(icon => {
38
+ icon.type = IconType.FontAwesome5;
39
+ return icon;
40
+ });
41
+ icons.push(...fa5Icons);
42
+ }
43
+ if (ipIconPack === 'fa6' || ipIconPack === 'all') {
44
+ this.faIconLibrary.addIconPacks(fas);
45
+ const fa6Icons = this.fa6IconsPack.getIcons().map(icon => {
46
+ icon.type = IconType.FontAwesome6;
47
+ return icon;
48
+ });
49
+ icons.push(...fa6Icons);
50
+ }
51
+ if (ipIconPack === 'mat' || ipIconPack === 'all') {
52
+ const matIcons = this.matIconsPack.getIcons().map(icon => {
53
+ icon.type = IconType.Material;
54
+ return icon;
55
+ });
56
+ icons.push(...matIcons);
57
+ }
58
+ if (ipIconPack === 'pi' || ipIconPack === 'all') {
59
+ const primeIcons = this.primeIconsPack.getIcons().map(icon => {
60
+ icon.type = IconType.PrimeIcons;
61
+ return icon;
62
+ });
63
+ icons.push(...primeIcons);
64
+ }
65
+ });
66
+ return icons;
67
+ }
68
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerService, deps: [{ token: i1.FaIconLibrary }], target: i0.ɵɵFactoryTarget.Injectable });
69
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerService });
70
+ }
71
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: IconPickerService, decorators: [{
72
+ type: Injectable
73
+ }], ctorParameters: function () { return [{ type: i1.FaIconLibrary }]; } });
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1udGstaWNvbi1waWNrZXIvc3JjL2xpYi9pY29uLXBpY2tlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFPLFFBQVEsRUFBQyxNQUFNLFFBQVEsQ0FBQztBQUV0QyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN0RSxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUU3RCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDeEQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHlCQUF5QixDQUFDOzs7QUFHdkQsTUFBTSxPQUFPLGlCQUFpQjtJQU9OO0lBTmQsWUFBWSxDQUFZO0lBQ3hCLFlBQVksQ0FBWTtJQUN4QixZQUFZLENBQVk7SUFDeEIsWUFBWSxDQUFZO0lBQ3hCLGNBQWMsQ0FBWTtJQUVsQyxZQUFzQixhQUE0QjtRQUE1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUkscUJBQXFCLEVBQUUsQ0FBQztRQUNoRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksaUJBQWlCLEVBQUUsQ0FBQztRQUM1QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksY0FBYyxFQUFFLENBQUM7SUFDN0MsQ0FBQztJQUVELFFBQVEsQ0FBQyxXQUFxQjtRQUM1QixNQUFNLEtBQUssR0FBVyxFQUFFLENBQUM7UUFDekIsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ2pDLElBQUksVUFBVSxLQUFLLElBQUksSUFBSSxVQUFVLEtBQUssS0FBSyxFQUFFO2dCQUMvQyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDdEQsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUMsV0FBVyxDQUFDO29CQUNqQyxPQUFPLElBQUksQ0FBQztnQkFDZCxDQUFDLENBQUMsQ0FBQztnQkFDSCxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsT0FBTyxDQUFDLENBQUM7YUFDeEI7WUFDRCxJQUFJLFVBQVUsS0FBSyxLQUFLLElBQUksVUFBVSxLQUFLLEtBQUssRUFBRTtnQkFDaEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQ3ZELElBQUksQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDLFlBQVksQ0FBQztvQkFDbEMsT0FBTyxJQUFJLENBQUM7Z0JBQ2QsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDO2FBQ3pCO1lBQ0QsSUFBSSxVQUFVLEtBQUssS0FBSyxJQUFJLFVBQVUsS0FBSyxLQUFLLEVBQUU7Z0JBQ2hELElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUNyQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLFFBQVEsRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDdEQsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUMsWUFBWSxDQUFDO29CQUNuQyxPQUFPLElBQUksQ0FBQztnQkFDZCxDQUFDLENBQUMsQ0FBQztnQkFDSCxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUM7YUFDekI7WUFDRCxJQUFJLFVBQVUsS0FBSyxLQUFLLElBQUksVUFBVSxLQUFLLEtBQUssRUFBRTtnQkFDaEQsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7b0JBQ3ZELElBQUksQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQztvQkFDOUIsT0FBTyxJQUFJLENBQUM7Z0JBQ2QsQ0FBQyxDQUFDLENBQUM7Z0JBQ0gsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDO2FBQ3pCO1lBQ0QsSUFBSSxVQUFVLEtBQUssSUFBSSxJQUFJLFVBQVUsS0FBSyxLQUFLLEVBQUU7Z0JBQy9DLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO29CQUMzRCxJQUFJLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUM7b0JBQ2hDLE9BQU8sSUFBSSxDQUFDO2dCQUNkLENBQUMsQ0FBQyxDQUFDO2dCQUNILEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxVQUFVLENBQUMsQ0FBQzthQUMzQjtRQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO3dHQXhEVSxpQkFBaUI7NEdBQWpCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFEN0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7SWNvbiwgSWNvblR5cGV9IGZyb20gJy4vaWNvbic7XHJcbmltcG9ydCB7SWNvbnNQYWNrfSBmcm9tICcuL2ljb25zLXBhY2snO1xyXG5pbXBvcnQge0ZvbnRBd2Vzb21lNEljb25zUGFja30gZnJvbSAnLi9wYWNrL2ZvbnQtYXdlc29tZTQtaWNvbnMtcGFjayc7XHJcbmltcG9ydCB7Rm9udEF3ZXNvbWU1SWNvbnNQYWNrfSBmcm9tICcuL3BhY2svZm9udC1hd2Vzb21lNS1pY29ucy1wYWNrJztcclxuaW1wb3J0IHtGb250QXdlc29tZTZJY29uc1BhY2t9IGZyb20gJy4vcGFjay9mb250LWF3ZXNvbWU2LWljb25zLXBhY2snO1xyXG5pbXBvcnQge01hdGVyaWFsSWNvbnNQYWNrfSBmcm9tICcuL3BhY2svbWF0ZXJpYWwtaWNvbnMtcGFjayc7XHJcbmltcG9ydCB7IEZhSWNvbkxpYnJhcnkgfSBmcm9tICdAZm9ydGF3ZXNvbWUvYW5ndWxhci1mb250YXdlc29tZSc7XHJcbmltcG9ydCB7IGZhcyB9IGZyb20gJ0Bmb3J0YXdlc29tZS9mcmVlLXNvbGlkLXN2Zy1pY29ucyc7XHJcbmltcG9ydCB7UHJpbWVJY29uc1BhY2t9IGZyb20gJy4vcGFjay9wcmltZS1pY29ucy1wYWNrJztcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIEljb25QaWNrZXJTZXJ2aWNlIHtcclxuICBwcml2YXRlIGZhNEljb25zUGFjazogSWNvbnNQYWNrO1xyXG4gIHByaXZhdGUgZmE1SWNvbnNQYWNrOiBJY29uc1BhY2s7XHJcbiAgcHJpdmF0ZSBmYTZJY29uc1BhY2s6IEljb25zUGFjaztcclxuICBwcml2YXRlIG1hdEljb25zUGFjazogSWNvbnNQYWNrO1xyXG4gIHByaXZhdGUgcHJpbWVJY29uc1BhY2s6IEljb25zUGFjaztcclxuXHJcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIGZhSWNvbkxpYnJhcnk6IEZhSWNvbkxpYnJhcnkpIHtcclxuICAgIHRoaXMuZmE0SWNvbnNQYWNrID0gbmV3IEZvbnRBd2Vzb21lNEljb25zUGFjaygpO1xyXG4gICAgdGhpcy5mYTVJY29uc1BhY2sgPSBuZXcgRm9udEF3ZXNvbWU1SWNvbnNQYWNrKCk7XHJcbiAgICB0aGlzLmZhNkljb25zUGFjayA9IG5ldyBGb250QXdlc29tZTZJY29uc1BhY2soKTtcclxuICAgIHRoaXMubWF0SWNvbnNQYWNrID0gbmV3IE1hdGVyaWFsSWNvbnNQYWNrKCk7XHJcbiAgICB0aGlzLnByaW1lSWNvbnNQYWNrID0gbmV3IFByaW1lSWNvbnNQYWNrKCk7XHJcbiAgfVxyXG5cclxuICBnZXRJY29ucyhpcEljb25QYWNrczogc3RyaW5nW10pOiBJY29uW10ge1xyXG4gICAgY29uc3QgaWNvbnM6IEljb25bXSA9IFtdO1xyXG4gICAgaXBJY29uUGFja3MuZm9yRWFjaCgoaXBJY29uUGFjaykgPT4ge1xyXG4gICAgICBpZiAoaXBJY29uUGFjayA9PT0gJ2ZhJyB8fCBpcEljb25QYWNrID09PSAnYWxsJykge1xyXG4gICAgICAgIGNvbnN0IGZhSWNvbnMgPSB0aGlzLmZhNEljb25zUGFjay5nZXRJY29ucygpLm1hcChpY29uID0+IHtcclxuICAgICAgICAgIGljb24udHlwZSA9IEljb25UeXBlLkZvbnRBd2Vzb21lO1xyXG4gICAgICAgICAgcmV0dXJuIGljb247XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaWNvbnMucHVzaCguLi5mYUljb25zKTtcclxuICAgICAgfVxyXG4gICAgICBpZiAoaXBJY29uUGFjayA9PT0gJ2ZhNScgfHwgaXBJY29uUGFjayA9PT0gJ2FsbCcpIHtcclxuICAgICAgICBjb25zdCBmYTVJY29ucyA9IHRoaXMuZmE1SWNvbnNQYWNrLmdldEljb25zKCkubWFwKGljb24gPT4ge1xyXG4gICAgICAgICAgaWNvbi50eXBlID0gSWNvblR5cGUuRm9udEF3ZXNvbWU1O1xyXG4gICAgICAgICAgcmV0dXJuIGljb247XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaWNvbnMucHVzaCguLi5mYTVJY29ucyk7XHJcbiAgICAgIH1cclxuICAgICAgaWYgKGlwSWNvblBhY2sgPT09ICdmYTYnIHx8IGlwSWNvblBhY2sgPT09ICdhbGwnKSB7XHJcbiAgICAgICAgdGhpcy5mYUljb25MaWJyYXJ5LmFkZEljb25QYWNrcyhmYXMpO1xyXG4gICAgICAgIGNvbnN0IGZhNkljb25zID0gdGhpcy5mYTZJY29uc1BhY2suZ2V0SWNvbnMoKS5tYXAoaWNvbiA9PiB7XHJcbiAgICAgICAgICAgaWNvbi50eXBlID0gSWNvblR5cGUuRm9udEF3ZXNvbWU2O1xyXG4gICAgICAgICAgcmV0dXJuIGljb247XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaWNvbnMucHVzaCguLi5mYTZJY29ucyk7XHJcbiAgICAgIH1cclxuICAgICAgaWYgKGlwSWNvblBhY2sgPT09ICdtYXQnIHx8IGlwSWNvblBhY2sgPT09ICdhbGwnKSB7XHJcbiAgICAgICAgY29uc3QgbWF0SWNvbnMgPSB0aGlzLm1hdEljb25zUGFjay5nZXRJY29ucygpLm1hcChpY29uID0+IHtcclxuICAgICAgICAgIGljb24udHlwZSA9IEljb25UeXBlLk1hdGVyaWFsO1xyXG4gICAgICAgICAgcmV0dXJuIGljb247XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaWNvbnMucHVzaCguLi5tYXRJY29ucyk7XHJcbiAgICAgIH1cclxuICAgICAgaWYgKGlwSWNvblBhY2sgPT09ICdwaScgfHwgaXBJY29uUGFjayA9PT0gJ2FsbCcpIHtcclxuICAgICAgICBjb25zdCBwcmltZUljb25zID0gdGhpcy5wcmltZUljb25zUGFjay5nZXRJY29ucygpLm1hcChpY29uID0+IHtcclxuICAgICAgICAgIGljb24udHlwZSA9IEljb25UeXBlLlByaW1lSWNvbnM7XHJcbiAgICAgICAgICByZXR1cm4gaWNvbjtcclxuICAgICAgICB9KTtcclxuICAgICAgICBpY29ucy5wdXNoKC4uLnByaW1lSWNvbnMpO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICAgIHJldHVybiBpY29ucztcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,18 @@
1
+ export class Icon {
2
+ name;
3
+ id;
4
+ filter;
5
+ aliases;
6
+ type;
7
+ iconName;
8
+ prefix;
9
+ }
10
+ export var IconType;
11
+ (function (IconType) {
12
+ IconType[IconType["FontAwesome"] = 0] = "FontAwesome";
13
+ IconType[IconType["FontAwesome5"] = 2] = "FontAwesome5";
14
+ IconType[IconType["Material"] = 3] = "Material";
15
+ IconType[IconType["FontAwesome6"] = 4] = "FontAwesome6";
16
+ IconType[IconType["PrimeIcons"] = 5] = "PrimeIcons";
17
+ })(IconType || (IconType = {}));
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1udGstaWNvbi1waWNrZXIvc3JjL2xpYi9pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxJQUFJO0lBQ2YsSUFBSSxDQUFTO0lBQ2IsRUFBRSxDQUFTO0lBQ1gsTUFBTSxDQUFZO0lBQ2xCLE9BQU8sQ0FBWTtJQUNuQixJQUFJLENBQVk7SUFDaEIsUUFBUSxDQUFZO0lBQ3BCLE1BQU0sQ0FBUztDQUNoQjtBQUVELE1BQU0sQ0FBTixJQUFZLFFBTVg7QUFORCxXQUFZLFFBQVE7SUFDbEIscURBQVcsQ0FBQTtJQUNYLHVEQUFnQixDQUFBO0lBQ2hCLCtDQUFRLENBQUE7SUFDUix1REFBWSxDQUFBO0lBQ1osbURBQVUsQ0FBQTtBQUNaLENBQUMsRUFOVyxRQUFRLEtBQVIsUUFBUSxRQU1uQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25OYW1lIH0gZnJvbSAnQGZvcnRhd2Vzb21lL2ZvbnRhd2Vzb21lLXN2Zy1jb3JlJztcclxuXHJcbmV4cG9ydCBjbGFzcyBJY29uIHtcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgaWQ6IHN0cmluZztcclxuICBmaWx0ZXI/OiBzdHJpbmdbXTtcclxuICBhbGlhc2VzPzogc3RyaW5nW107XHJcbiAgdHlwZT86IEljb25UeXBlO1xyXG4gIGljb25OYW1lPzogSWNvbk5hbWU7XHJcbiAgcHJlZml4PzpzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIEljb25UeXBlIHtcclxuICBGb250QXdlc29tZSxcclxuICBGb250QXdlc29tZTUgPSAyLFxyXG4gIE1hdGVyaWFsLFxyXG4gIEZvbnRBd2Vzb21lNixcclxuICBQcmltZUljb25zXHJcbn1cclxuIl19