ngx-ntk-icon-picker 18.26.2 → 20.25.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.
Files changed (39) hide show
  1. package/README.md +63 -24
  2. package/{fesm2020 → fesm2022}/ngx-ntk-icon-picker.mjs +44973 -44974
  3. package/fesm2022/ngx-ntk-icon-picker.mjs.map +1 -0
  4. package/index.d.ts +154 -5
  5. package/package.json +8 -16
  6. package/esm2020/lib/icon-picker.component.mjs +0 -204
  7. package/esm2020/lib/icon-picker.directive.mjs +0 -131
  8. package/esm2020/lib/icon-picker.module.mjs +0 -43
  9. package/esm2020/lib/icon-picker.service.mjs +0 -68
  10. package/esm2020/lib/icon.mjs +0 -11
  11. package/esm2020/lib/icons-pack.mjs +0 -2
  12. package/esm2020/lib/index.mjs +0 -6
  13. package/esm2020/lib/pack/font-awesome4-icons-pack.mjs +0 -4791
  14. package/esm2020/lib/pack/font-awesome5-icons-pack.mjs +0 -18193
  15. package/esm2020/lib/pack/font-awesome6-icons-pack.mjs +0 -16828
  16. package/esm2020/lib/pack/material-icons-pack.mjs +0 -3735
  17. package/esm2020/lib/pack/prime-icons-pack.mjs +0 -951
  18. package/esm2020/lib/search-icon.pipe.mjs +0 -38
  19. package/esm2020/lib/text.directive.mjs +0 -27
  20. package/esm2020/ngx-ntk-icon-picker.mjs +0 -5
  21. package/esm2020/public-api.mjs +0 -5
  22. package/fesm2015/ngx-ntk-icon-picker.mjs +0 -45004
  23. package/fesm2015/ngx-ntk-icon-picker.mjs.map +0 -1
  24. package/fesm2020/ngx-ntk-icon-picker.mjs.map +0 -1
  25. package/lib/icon-picker.component.d.ts +0 -59
  26. package/lib/icon-picker.directive.d.ts +0 -40
  27. package/lib/icon-picker.module.d.ts +0 -12
  28. package/lib/icon-picker.service.d.ts +0 -15
  29. package/lib/icon.d.ts +0 -17
  30. package/lib/icons-pack.d.ts +0 -4
  31. package/lib/index.d.ts +0 -5
  32. package/lib/pack/font-awesome4-icons-pack.d.ts +0 -5
  33. package/lib/pack/font-awesome5-icons-pack.d.ts +0 -5
  34. package/lib/pack/font-awesome6-icons-pack.d.ts +0 -5
  35. package/lib/pack/material-icons-pack.d.ts +0 -5
  36. package/lib/pack/prime-icons-pack.d.ts +0 -5
  37. package/lib/search-icon.pipe.d.ts +0 -9
  38. package/lib/text.directive.d.ts +0 -9
  39. package/public-api.d.ts +0 -1
package/index.d.ts CHANGED
@@ -1,5 +1,154 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- /// <amd-module name="ngx-ntk-icon-picker" />
5
- export * from './public-api';
1
+ import { IconName } from '@fortawesome/fontawesome-svg-core';
2
+ import * as i0 from '@angular/core';
3
+ import { OnInit, ElementRef, ChangeDetectorRef, OnChanges, EventEmitter, ViewContainerRef, PipeTransform } from '@angular/core';
4
+ import * as i2 from '@fortawesome/angular-fontawesome';
5
+ import { FaIconLibrary } from '@fortawesome/angular-fontawesome';
6
+ import * as i1 from '@angular/common';
7
+
8
+ declare class Icon {
9
+ name: string;
10
+ id: string;
11
+ filter?: string[];
12
+ aliases?: string[];
13
+ type?: IconType;
14
+ iconName?: IconName;
15
+ prefix?: string;
16
+ }
17
+ declare enum IconType {
18
+ FontAwesome = 0,
19
+ FontAwesome5 = 2,
20
+ Material = 3,
21
+ FontAwesome6 = 4,
22
+ PrimeIcons = 5
23
+ }
24
+
25
+ declare class IconPickerService {
26
+ protected faIconLibrary: FaIconLibrary;
27
+ private fa4IconsPack;
28
+ private fa5IconsPack;
29
+ private fa6IconsPack;
30
+ private matIconsPack;
31
+ private primeIconsPack;
32
+ constructor(faIconLibrary: FaIconLibrary);
33
+ getIcons(ipIconPacks: string[]): Icon[];
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<IconPickerService, never>;
35
+ static ɵprov: i0.ɵɵInjectableDeclaration<IconPickerService>;
36
+ }
37
+
38
+ declare class IconPickerComponent implements OnInit {
39
+ private el;
40
+ private cdr;
41
+ private service;
42
+ dialogElement: any;
43
+ ipPosition: string;
44
+ ipHeight: number;
45
+ ipMaxHeight: number;
46
+ ipWidth: number;
47
+ ipIconSize: number;
48
+ ipIconVerticalPadding: number;
49
+ ipIconHorizontalPadding: number;
50
+ ipButtonStyleClass: string;
51
+ ipInputSearchStyleClass: string;
52
+ ipDivSearchStyleClass: string;
53
+ ipUseRootViewContainer: boolean;
54
+ ipKeepSearchFilter: boolean;
55
+ ipPlaceHolder: string;
56
+ ipFallbackIcon: string;
57
+ ipIconPack: string[];
58
+ show: boolean;
59
+ hidden: boolean;
60
+ top: number;
61
+ left: number;
62
+ position: string;
63
+ arrowTop: number;
64
+ selectedIcon: Icon;
65
+ iconType: typeof IconType;
66
+ buttonWidth: number;
67
+ buttonHeight: number;
68
+ icons: Icon[];
69
+ search: string;
70
+ private directiveInstance;
71
+ private initialIcon;
72
+ private directiveElementRef;
73
+ private listenerMouseDown;
74
+ private listenerResize;
75
+ private dialogArrowSize;
76
+ constructor(el: ElementRef, cdr: ChangeDetectorRef, service: IconPickerService);
77
+ setDialog(instance: any, elementRef: ElementRef, icon: string, ipPosition: string, ipHeight: string, ipMaxHeight: string, ipWidth: string, ipPlaceHolder: string, ipFallbackIcon: string, ipIconPack: string[], ipIconSize: string, ipIconVerticalPadding: string, ipIconHorizontalPadding: string, ipButtonStyleClass: string, ipDivSearchStyleClass: string, ipInputSearchStyleClass: string, ipKeepSearchFilter: string, ipUseRootViewContainer?: boolean): void;
78
+ ngOnInit(): void;
79
+ setInitialIcon(icon: string): void;
80
+ openDialog(icon: string): void;
81
+ setSearch(val: string): void;
82
+ selectIcon(icon: Icon): void;
83
+ onMouseDown(event: any): void;
84
+ openIconPicker(): void;
85
+ closeIconPicker(): void;
86
+ onResize(): void;
87
+ setDialogPosition(): void;
88
+ isDescendant(parent: any, child: any): boolean;
89
+ createBox(element: any, offset: boolean): any;
90
+ static ɵfac: i0.ɵɵFactoryDeclaration<IconPickerComponent, never>;
91
+ static ɵcmp: i0.ɵɵComponentDeclaration<IconPickerComponent, "icon-picker", never, {}, {}, never, never, true, never>;
92
+ }
93
+
94
+ declare class IconPickerDirective implements OnInit, OnChanges {
95
+ private vcRef;
96
+ private el;
97
+ iconPicker: string;
98
+ ipPlaceHolder: string;
99
+ ipPosition: string;
100
+ ipFallbackIcon: string;
101
+ ipHeight: string;
102
+ ipMaxHeight: string;
103
+ ipWidth: string;
104
+ ipIconSize: string;
105
+ ipIconVerticalPadding: string;
106
+ ipIconHorizontalPadding: string;
107
+ ipIconPack: string[];
108
+ ipKeepSearchFilter: string;
109
+ ipUseRootViewContainer: boolean;
110
+ ipButtonStyleClass: string;
111
+ ipDivSearchStyleClass: string;
112
+ ipInputSearchStyleClass: string;
113
+ iconPickerSelect: EventEmitter<string>;
114
+ iconPickerOpen: EventEmitter<void>;
115
+ iconPickerClose: EventEmitter<void>;
116
+ iconPickerFocus: EventEmitter<void>;
117
+ handleFocus(): void;
118
+ private dialog;
119
+ private created;
120
+ private ignoreChanges;
121
+ constructor(vcRef: ViewContainerRef, el: ElementRef);
122
+ onClick(): void;
123
+ ngOnChanges(changes: any): void;
124
+ ngOnInit(): void;
125
+ openDialog(): void;
126
+ iconSelected(icon: string): void;
127
+ stateChanged(state: boolean): void;
128
+ elementFocus(): void;
129
+ static ɵfac: i0.ɵɵFactoryDeclaration<IconPickerDirective, never>;
130
+ static ɵdir: i0.ɵɵDirectiveDeclaration<IconPickerDirective, "[iconPicker]", never, { "iconPicker": { "alias": "iconPicker"; "required": false; }; "ipPlaceHolder": { "alias": "ipPlaceHolder"; "required": false; }; "ipPosition": { "alias": "ipPosition"; "required": false; }; "ipFallbackIcon": { "alias": "ipFallbackIcon"; "required": false; }; "ipHeight": { "alias": "ipHeight"; "required": false; }; "ipMaxHeight": { "alias": "ipMaxHeight"; "required": false; }; "ipWidth": { "alias": "ipWidth"; "required": false; }; "ipIconSize": { "alias": "ipIconSize"; "required": false; }; "ipIconVerticalPadding": { "alias": "ipIconVerticalPadding"; "required": false; }; "ipIconHorizontalPadding": { "alias": "ipIconHorizontalPadding"; "required": false; }; "ipIconPack": { "alias": "ipIconPack"; "required": false; }; "ipKeepSearchFilter": { "alias": "ipKeepSearchFilter"; "required": false; }; "ipUseRootViewContainer": { "alias": "ipUseRootViewContainer"; "required": false; }; "ipButtonStyleClass": { "alias": "ipButtonStyleClass"; "required": false; }; "ipDivSearchStyleClass": { "alias": "ipDivSearchStyleClass"; "required": false; }; "ipInputSearchStyleClass": { "alias": "ipInputSearchStyleClass"; "required": false; }; }, { "iconPickerSelect": "iconPickerSelect"; "iconPickerOpen": "iconPickerOpen"; "iconPickerClose": "iconPickerClose"; "iconPickerFocus": "iconPickerFocus"; }, never, never, true, never>;
131
+ }
132
+
133
+ declare class TextDirective {
134
+ newValue: EventEmitter<string>;
135
+ text: string;
136
+ changeInput(value: string): void;
137
+ static ɵfac: i0.ɵɵFactoryDeclaration<TextDirective, never>;
138
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TextDirective, "[text]", never, { "text": { "alias": "text"; "required": false; }; }, { "newValue": "newValue"; }, never, never, true, never>;
139
+ }
140
+
141
+ declare class SearchIconPipe implements PipeTransform {
142
+ transform(value: Icon[], search: string): Icon[];
143
+ clean(value: string): string;
144
+ static ɵfac: i0.ɵɵFactoryDeclaration<SearchIconPipe, never>;
145
+ static ɵpipe: i0.ɵɵPipeDeclaration<SearchIconPipe, "searchIcon", true>;
146
+ }
147
+
148
+ declare class IconPickerModule {
149
+ static ɵfac: i0.ɵɵFactoryDeclaration<IconPickerModule, never>;
150
+ static ɵmod: i0.ɵɵNgModuleDeclaration<IconPickerModule, never, [typeof i1.CommonModule, typeof i2.FontAwesomeModule, typeof IconPickerComponent, typeof IconPickerDirective, typeof TextDirective, typeof SearchIconPipe], never>;
151
+ static ɵinj: i0.ɵɵInjectorDeclaration<IconPickerModule>;
152
+ }
153
+
154
+ export { Icon, IconPickerComponent, IconPickerDirective, IconPickerModule, IconPickerService, IconType };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ngx-ntk-icon-picker",
3
- "version": "18.26.2",
3
+ "version": "20.25.1",
4
4
  "description": "Ntk Cms Api And Model For Typscript",
5
5
  "author": "Alireza-Karavi",
6
6
  "license": "ISC",
@@ -12,21 +12,18 @@
12
12
  "api"
13
13
  ],
14
14
  "peerDependencies": {
15
- "@angular/common": ">=10.0.0",
16
- "@angular/core": ">=10.0.0",
15
+ "@angular/common": "^20.1.0",
16
+ "@angular/core": "^20.1.0",
17
17
  "@fortawesome/angular-fontawesome": ">=0.10.2",
18
18
  "@fortawesome/fontawesome-svg-core": ">=6.1.1",
19
19
  "@fortawesome/free-solid-svg-icons": ">=6.1.1",
20
20
  "primeicons": ">=5.0.0"
21
21
  },
22
22
  "dependencies": {
23
- "tslib": "^2.5.0"
23
+ "tslib": "^2.3.0"
24
24
  },
25
- "module": "fesm2015/ngx-ntk-icon-picker.mjs",
26
- "es2020": "fesm2020/ngx-ntk-icon-picker.mjs",
27
- "esm2020": "esm2020/ngx-ntk-icon-picker.mjs",
28
- "fesm2020": "fesm2020/ngx-ntk-icon-picker.mjs",
29
- "fesm2015": "fesm2015/ngx-ntk-icon-picker.mjs",
25
+ "sideEffects": false,
26
+ "module": "fesm2022/ngx-ntk-icon-picker.mjs",
30
27
  "typings": "index.d.ts",
31
28
  "exports": {
32
29
  "./package.json": {
@@ -34,12 +31,7 @@
34
31
  },
35
32
  ".": {
36
33
  "types": "./index.d.ts",
37
- "esm2020": "./esm2020/ngx-ntk-icon-picker.mjs",
38
- "es2020": "./fesm2020/ngx-ntk-icon-picker.mjs",
39
- "es2015": "./fesm2015/ngx-ntk-icon-picker.mjs",
40
- "node": "./fesm2015/ngx-ntk-icon-picker.mjs",
41
- "default": "./fesm2020/ngx-ntk-icon-picker.mjs"
34
+ "default": "./fesm2022/ngx-ntk-icon-picker.mjs"
42
35
  }
43
- },
44
- "sideEffects": false
36
+ }
45
37
  }
@@ -1,204 +0,0 @@
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
- constructor(el, cdr, service) {
11
- this.el = el;
12
- this.cdr = cdr;
13
- this.service = service;
14
- this.ipUseRootViewContainer = false;
15
- this.iconType = IconType;
16
- this.icons = [];
17
- this.search = '';
18
- this.dialogArrowSize = 10;
19
- }
20
- setDialog(instance, elementRef, icon, ipPosition, ipHeight, ipMaxHeight, ipWidth, ipPlaceHolder, ipFallbackIcon, ipIconPack, ipIconSize, ipIconVerticalPadding, ipIconHorizontalPadding, ipButtonStyleClass, ipDivSearchStyleClass, ipInputSearchStyleClass, ipKeepSearchFilter, ipUseRootViewContainer) {
21
- this.directiveInstance = instance;
22
- this.setInitialIcon(icon);
23
- this.directiveElementRef = elementRef;
24
- this.ipPosition = ipPosition;
25
- this.ipHeight = parseInt(ipHeight, 10);
26
- this.ipMaxHeight = parseInt(ipMaxHeight, 10);
27
- this.ipWidth = parseInt(ipWidth, 10);
28
- if (!this.ipWidth) {
29
- this.ipWidth = elementRef.nativeElement.offsetWidth;
30
- }
31
- this.ipIconSize = parseInt(ipIconSize, 10);
32
- this.ipIconVerticalPadding = parseInt(ipIconVerticalPadding, 10);
33
- this.ipIconHorizontalPadding = parseInt(ipIconHorizontalPadding, 10);
34
- this.ipKeepSearchFilter = JSON.parse(ipKeepSearchFilter);
35
- this.ipPlaceHolder = ipPlaceHolder;
36
- this.ipFallbackIcon = ipFallbackIcon;
37
- this.ipIconPack = ipIconPack;
38
- this.ipButtonStyleClass = ipButtonStyleClass;
39
- this.ipInputSearchStyleClass = ipInputSearchStyleClass;
40
- this.ipDivSearchStyleClass = ipDivSearchStyleClass;
41
- this.ipUseRootViewContainer = ipUseRootViewContainer;
42
- this.buttonHeight = this.ipIconSize + 2 * this.ipIconVerticalPadding;
43
- this.buttonWidth = this.ipIconSize + 2 * this.ipIconHorizontalPadding;
44
- }
45
- ngOnInit() {
46
- this.icons = this.service.getIcons(this.ipIconPack);
47
- this.listenerMouseDown = (event) => this.onMouseDown(event);
48
- this.listenerResize = () => this.onResize();
49
- this.openDialog(this.initialIcon);
50
- }
51
- setInitialIcon(icon) {
52
- this.initialIcon = icon;
53
- this.selectedIcon = this.icons.find(el => el ?
54
- `fa fa-${el.id}` === icon || `pi pi-${el.id}` === icon || `${el.id}` === icon :
55
- false);
56
- if (this.ipKeepSearchFilter && this.selectedIcon && icon !== this.ipFallbackIcon) {
57
- this.search = this.selectedIcon.id;
58
- }
59
- else {
60
- this.search = '';
61
- }
62
- }
63
- openDialog(icon) {
64
- this.setInitialIcon(icon);
65
- this.openIconPicker();
66
- }
67
- setSearch(val) {
68
- this.search = val;
69
- }
70
- selectIcon(icon) {
71
- if (icon.type === IconType.FontAwesome) {
72
- this.directiveInstance.iconSelected(`fa fa-${icon.id}`);
73
- }
74
- else if (icon.type === IconType.FontAwesome5) {
75
- this.directiveInstance.iconSelected(`${icon.id}`);
76
- }
77
- else if (icon.type === IconType.FontAwesome6) {
78
- this.directiveInstance.iconSelected(`${icon.id}`);
79
- }
80
- else if (icon.type === IconType.Material) {
81
- this.directiveInstance.iconSelected(`${icon.id}`);
82
- }
83
- else if (icon.type === IconType.PrimeIcons) {
84
- this.directiveInstance.iconSelected(`pi pi-${icon.id}`);
85
- }
86
- this.closeIconPicker();
87
- }
88
- onMouseDown(event) {
89
- if (!this.isDescendant(this.el.nativeElement, event.target) && event.target !== this.directiveElementRef.nativeElement) {
90
- this.closeIconPicker();
91
- }
92
- }
93
- openIconPicker() {
94
- if (!this.show) {
95
- this.show = true;
96
- this.hidden = true;
97
- setTimeout(() => {
98
- this.setDialogPosition();
99
- this.hidden = false;
100
- this.cdr.detectChanges();
101
- }, 0);
102
- this.directiveInstance.stateChanged(true);
103
- document.addEventListener('mousedown', this.listenerMouseDown);
104
- window.addEventListener('resize', this.listenerResize);
105
- }
106
- }
107
- closeIconPicker() {
108
- if (this.show) {
109
- this.show = false;
110
- this.directiveInstance.stateChanged(false);
111
- document.removeEventListener('mousedown', this.listenerMouseDown);
112
- window.removeEventListener('resize', this.listenerResize);
113
- this.cdr.detectChanges();
114
- }
115
- }
116
- onResize() {
117
- if (this.position === 'fixed') {
118
- this.setDialogPosition();
119
- }
120
- }
121
- setDialogPosition() {
122
- const dialogHeight = this.dialogElement.nativeElement.offsetHeight;
123
- let node = this.directiveElementRef.nativeElement;
124
- let position = 'static';
125
- let transform = '';
126
- let parentNode = null;
127
- let transformNode = null;
128
- let style = null;
129
- while (node !== null && node.tagName !== 'HTML') {
130
- style = window.getComputedStyle(node);
131
- position = style.getPropertyValue('position');
132
- transform = style.getPropertyValue('transform');
133
- if (position !== 'static' && parentNode === null) {
134
- parentNode = node;
135
- }
136
- if (transform && transform !== 'none' && transformNode === null) {
137
- transformNode = node;
138
- }
139
- if (position === 'fixed') {
140
- parentNode = transformNode;
141
- break;
142
- }
143
- node = node.parentNode;
144
- }
145
- const boxDirective = this.createBox(this.directiveElementRef.nativeElement, (position !== 'fixed'));
146
- if (this.ipUseRootViewContainer || (position === 'fixed' &&
147
- (!parentNode || parentNode instanceof HTMLUnknownElement))) {
148
- this.top = boxDirective.top;
149
- this.left = boxDirective.left;
150
- }
151
- else {
152
- if (parentNode === null) {
153
- parentNode = node;
154
- }
155
- const boxParent = this.createBox(parentNode, (position !== 'fixed'));
156
- this.top = boxDirective.top - boxParent.top;
157
- this.left = boxDirective.left - boxParent.left;
158
- }
159
- if (position === 'fixed') {
160
- this.position = 'fixed';
161
- }
162
- if (this.ipPosition === 'left') {
163
- this.left -= this.ipWidth + this.dialogArrowSize - 2;
164
- }
165
- else if (this.ipPosition === 'top') {
166
- this.top -= dialogHeight + this.dialogArrowSize;
167
- this.arrowTop = dialogHeight - 1;
168
- }
169
- else if (this.ipPosition === 'bottom') {
170
- this.top += boxDirective.height + this.dialogArrowSize;
171
- }
172
- else {
173
- this.left += boxDirective.width + this.dialogArrowSize - 2;
174
- }
175
- }
176
- isDescendant(parent, child) {
177
- let node = child.parentNode;
178
- while (node !== null) {
179
- if (node === parent) {
180
- return true;
181
- }
182
- node = node.parentNode;
183
- }
184
- return false;
185
- }
186
- createBox(element, offset) {
187
- return {
188
- top: element.getBoundingClientRect().top + (offset ? window.pageYOffset : 0),
189
- left: element.getBoundingClientRect().left + (offset ? window.pageXOffset : 0),
190
- width: element.offsetWidth,
191
- height: element.offsetHeight
192
- };
193
- }
194
- }
195
- IconPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.IconPickerService }], target: i0.ɵɵFactoryTarget.Component });
196
- IconPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", 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" }] });
197
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerComponent, decorators: [{
198
- type: Component,
199
- 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"] }]
200
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.IconPickerService }]; }, propDecorators: { dialogElement: [{
201
- type: ViewChild,
202
- args: ['dialogPopup']
203
- }] } });
204
- //# 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"]}
@@ -1,131 +0,0 @@
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
- handleFocus() {
6
- this.elementFocus();
7
- }
8
- constructor(vcRef, el) {
9
- this.vcRef = vcRef;
10
- this.el = el;
11
- this.ipPlaceHolder = 'Search icon...';
12
- this.ipPosition = 'right';
13
- this.ipFallbackIcon = 'fas fa-user';
14
- this.ipHeight = 'auto';
15
- this.ipMaxHeight = '200px';
16
- this.ipWidth = '230px';
17
- this.ipIconSize = '16px';
18
- this.ipIconVerticalPadding = '6px'; // Top / Bottom
19
- this.ipIconHorizontalPadding = '10px'; // Left / Right
20
- this.ipIconPack = ['fa5'];
21
- this.ipKeepSearchFilter = 'false';
22
- this.ipUseRootViewContainer = false;
23
- // Default design with bootstrap
24
- this.ipButtonStyleClass = 'btn btn-default';
25
- this.ipDivSearchStyleClass = '';
26
- this.ipInputSearchStyleClass = 'form-control input-sm';
27
- this.iconPickerSelect = new EventEmitter(true);
28
- this.iconPickerOpen = new EventEmitter(true);
29
- this.iconPickerClose = new EventEmitter(true);
30
- this.iconPickerFocus = new EventEmitter(true);
31
- this.ignoreChanges = false;
32
- this.created = false;
33
- }
34
- onClick() {
35
- this.openDialog();
36
- }
37
- ngOnChanges(changes) {
38
- if (changes.iconPicker) {
39
- this.ignoreChanges = false;
40
- }
41
- }
42
- ngOnInit() {
43
- this.iconPicker = this.iconPicker || this.ipFallbackIcon || 'fa fa-user-plus';
44
- this.iconPickerSelect.emit(this.iconPicker);
45
- }
46
- openDialog() {
47
- if (!this.created) {
48
- this.created = true;
49
- const vcRef = this.vcRef;
50
- const cmpRef = vcRef.createComponent(IconPickerComponent);
51
- 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);
52
- this.dialog = cmpRef.instance;
53
- if (this.vcRef !== vcRef) {
54
- cmpRef.changeDetectorRef.detectChanges();
55
- }
56
- }
57
- else if (this.dialog) {
58
- this.dialog.openDialog(this.iconPicker);
59
- }
60
- }
61
- iconSelected(icon) {
62
- this.iconPickerSelect.emit(icon);
63
- }
64
- stateChanged(state) {
65
- if (state) {
66
- this.iconPickerOpen.emit();
67
- }
68
- else {
69
- this.iconPickerClose.emit();
70
- }
71
- }
72
- elementFocus() {
73
- this.iconPickerFocus.emit();
74
- }
75
- }
76
- IconPickerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
77
- IconPickerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", 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 });
78
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: IconPickerDirective, decorators: [{
79
- type: Directive,
80
- args: [{
81
- // eslint-disable-next-line @angular-eslint/directive-selector
82
- selector: '[iconPicker]'
83
- }]
84
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ElementRef }]; }, propDecorators: { iconPicker: [{
85
- type: Input
86
- }], ipPlaceHolder: [{
87
- type: Input
88
- }], ipPosition: [{
89
- type: Input
90
- }], ipFallbackIcon: [{
91
- type: Input
92
- }], ipHeight: [{
93
- type: Input
94
- }], ipMaxHeight: [{
95
- type: Input
96
- }], ipWidth: [{
97
- type: Input
98
- }], ipIconSize: [{
99
- type: Input
100
- }], ipIconVerticalPadding: [{
101
- type: Input
102
- }], ipIconHorizontalPadding: [{
103
- type: Input
104
- }], ipIconPack: [{
105
- type: Input
106
- }], ipKeepSearchFilter: [{
107
- type: Input
108
- }], ipUseRootViewContainer: [{
109
- type: Input
110
- }], ipButtonStyleClass: [{
111
- type: Input
112
- }], ipDivSearchStyleClass: [{
113
- type: Input
114
- }], ipInputSearchStyleClass: [{
115
- type: Input
116
- }], iconPickerSelect: [{
117
- type: Output
118
- }], iconPickerOpen: [{
119
- type: Output
120
- }], iconPickerClose: [{
121
- type: Output
122
- }], iconPickerFocus: [{
123
- type: Output
124
- }], handleFocus: [{
125
- type: HostListener,
126
- args: ['focus']
127
- }], onClick: [{
128
- type: HostListener,
129
- args: ['click']
130
- }] } });
131
- //# 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"]}