ngx-ntk-icon-picker 18.26.4 → 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.
- package/README.md +63 -24
- package/fesm2022/ngx-ntk-icon-picker.mjs +44973 -45027
- package/fesm2022/ngx-ntk-icon-picker.mjs.map +1 -1
- package/index.d.ts +154 -5
- package/package.json +6 -8
- package/esm2022/lib/icon-picker.component.mjs +0 -240
- package/esm2022/lib/icon-picker.directive.mjs +0 -136
- package/esm2022/lib/icon-picker.module.mjs +0 -43
- package/esm2022/lib/icon-picker.service.mjs +0 -74
- package/esm2022/lib/icon.mjs +0 -18
- package/esm2022/lib/icons-pack.mjs +0 -2
- package/esm2022/lib/index.mjs +0 -6
- package/esm2022/lib/pack/font-awesome4-icons-pack.mjs +0 -4791
- package/esm2022/lib/pack/font-awesome5-icons-pack.mjs +0 -18193
- package/esm2022/lib/pack/font-awesome6-icons-pack.mjs +0 -16828
- package/esm2022/lib/pack/material-icons-pack.mjs +0 -3735
- package/esm2022/lib/pack/prime-icons-pack.mjs +0 -951
- package/esm2022/lib/search-icon.pipe.mjs +0 -38
- package/esm2022/lib/text.directive.mjs +0 -26
- package/esm2022/ngx-ntk-icon-picker.mjs +0 -5
- package/esm2022/public-api.mjs +0 -5
- package/lib/icon-picker.component.d.ts +0 -59
- package/lib/icon-picker.directive.d.ts +0 -40
- package/lib/icon-picker.module.d.ts +0 -12
- package/lib/icon-picker.service.d.ts +0 -15
- package/lib/icon.d.ts +0 -17
- package/lib/icons-pack.d.ts +0 -4
- package/lib/index.d.ts +0 -5
- package/lib/pack/font-awesome4-icons-pack.d.ts +0 -5
- package/lib/pack/font-awesome5-icons-pack.d.ts +0 -5
- package/lib/pack/font-awesome6-icons-pack.d.ts +0 -5
- package/lib/pack/material-icons-pack.d.ts +0 -5
- package/lib/pack/prime-icons-pack.d.ts +0 -5
- package/lib/search-icon.pipe.d.ts +0 -9
- package/lib/text.directive.d.ts +0 -9
- package/public-api.d.ts +0 -1
package/index.d.ts
CHANGED
|
@@ -1,5 +1,154 @@
|
|
|
1
|
-
|
|
2
|
-
*
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
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": "
|
|
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,16 +12,17 @@
|
|
|
12
12
|
"api"
|
|
13
13
|
],
|
|
14
14
|
"peerDependencies": {
|
|
15
|
-
"@angular/common": "
|
|
16
|
-
"@angular/core": "
|
|
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.
|
|
23
|
+
"tslib": "^2.3.0"
|
|
24
24
|
},
|
|
25
|
+
"sideEffects": false,
|
|
25
26
|
"module": "fesm2022/ngx-ntk-icon-picker.mjs",
|
|
26
27
|
"typings": "index.d.ts",
|
|
27
28
|
"exports": {
|
|
@@ -30,10 +31,7 @@
|
|
|
30
31
|
},
|
|
31
32
|
".": {
|
|
32
33
|
"types": "./index.d.ts",
|
|
33
|
-
"esm2022": "./esm2022/ngx-ntk-icon-picker.mjs",
|
|
34
|
-
"esm": "./esm2022/ngx-ntk-icon-picker.mjs",
|
|
35
34
|
"default": "./fesm2022/ngx-ntk-icon-picker.mjs"
|
|
36
35
|
}
|
|
37
|
-
}
|
|
38
|
-
"sideEffects": false
|
|
36
|
+
}
|
|
39
37
|
}
|
|
@@ -1,240 +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
|
-
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"]}
|