@festo-ui/angular 3.1.0-pre-20220214.3 → 3.1.0-pre-20220301.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.
- package/esm2020/lib/components/components.module.mjs +27 -3
- package/esm2020/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.mjs +27 -0
- package/esm2020/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.mjs +43 -0
- package/esm2020/lib/components/mobile-flyout/mobile-flyout.component.mjs +41 -0
- package/esm2020/lib/components/search-input/safe-html.pipe.mjs +21 -0
- package/esm2020/lib/components/search-input/search-input.component.mjs +29 -7
- package/fesm2015/festo-ui-angular.mjs +172 -19
- package/fesm2015/festo-ui-angular.mjs.map +1 -1
- package/fesm2020/festo-ui-angular.mjs +172 -19
- package/fesm2020/festo-ui-angular.mjs.map +1 -1
- package/lib/components/components.module.d.ts +14 -6
- package/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.d.ts +10 -0
- package/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.d.ts +15 -0
- package/lib/components/mobile-flyout/mobile-flyout.component.d.ts +11 -0
- package/lib/components/search-input/safe-html.pipe.d.ts +10 -0
- package/lib/components/search-input/search-input.component.d.ts +22 -5
- package/package.json +1 -1
- package/scss/base/components/search-input/search-input.component.scss +4 -0
|
@@ -25,6 +25,10 @@ import { PaginationComponent } from './pagination/pagination.component';
|
|
|
25
25
|
import { ScrollableDirective } from './scroll/scrollable.directive';
|
|
26
26
|
import { SearchInputComponent } from './search-input/search-input.component';
|
|
27
27
|
import { ClickOutsideDirective } from './click-outside.directive';
|
|
28
|
+
import { MobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';
|
|
29
|
+
import { MobileFlyoutPageComponent } from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';
|
|
30
|
+
import { MobileFlyoutItemComponent } from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';
|
|
31
|
+
import { SafeHtmlPipe } from './search-input/safe-html.pipe';
|
|
28
32
|
import * as i0 from "@angular/core";
|
|
29
33
|
export * from './buttons/button/button.component';
|
|
30
34
|
export * from './buttons/link-button/link-button.component';
|
|
@@ -48,7 +52,11 @@ export * from './tabs/tab-pane/tab-pane.component';
|
|
|
48
52
|
export * from './pagination/pagination.component';
|
|
49
53
|
export * from './scroll';
|
|
50
54
|
export * from './search-input/search-input.component';
|
|
55
|
+
export * from './search-input/safe-html.pipe';
|
|
51
56
|
export * from './click-outside.directive';
|
|
57
|
+
export * from './mobile-flyout/mobile-flyout.component';
|
|
58
|
+
export * from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';
|
|
59
|
+
export * from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';
|
|
52
60
|
export class FestoAngularComponentsModule {
|
|
53
61
|
}
|
|
54
62
|
FestoAngularComponentsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FestoAngularComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
@@ -73,6 +81,10 @@ FestoAngularComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.
|
|
|
73
81
|
TabPaneComponent,
|
|
74
82
|
ScrollableDirective,
|
|
75
83
|
SearchInputComponent,
|
|
84
|
+
MobileFlyoutComponent,
|
|
85
|
+
MobileFlyoutPageComponent,
|
|
86
|
+
MobileFlyoutItemComponent,
|
|
87
|
+
SafeHtmlPipe,
|
|
76
88
|
ClickOutsideDirective], imports: [RouterModule, CommonModule, OverlayModule, PortalModule], exports: [ButtonComponent,
|
|
77
89
|
LinkButtonComponent,
|
|
78
90
|
BreadcrumbComponent,
|
|
@@ -94,7 +106,11 @@ FestoAngularComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.
|
|
|
94
106
|
TabPaneComponent,
|
|
95
107
|
ScrollableDirective,
|
|
96
108
|
SearchInputComponent,
|
|
97
|
-
|
|
109
|
+
SafeHtmlPipe,
|
|
110
|
+
ClickOutsideDirective,
|
|
111
|
+
MobileFlyoutComponent,
|
|
112
|
+
MobileFlyoutPageComponent,
|
|
113
|
+
MobileFlyoutItemComponent] });
|
|
98
114
|
FestoAngularComponentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FestoAngularComponentsModule, providers: [], imports: [[RouterModule, CommonModule, OverlayModule, PortalModule]] });
|
|
99
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: FestoAngularComponentsModule, decorators: [{
|
|
100
116
|
type: NgModule,
|
|
@@ -121,6 +137,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
121
137
|
TabPaneComponent,
|
|
122
138
|
ScrollableDirective,
|
|
123
139
|
SearchInputComponent,
|
|
140
|
+
MobileFlyoutComponent,
|
|
141
|
+
MobileFlyoutPageComponent,
|
|
142
|
+
MobileFlyoutItemComponent,
|
|
143
|
+
SafeHtmlPipe,
|
|
124
144
|
ClickOutsideDirective
|
|
125
145
|
],
|
|
126
146
|
imports: [RouterModule, CommonModule, OverlayModule, PortalModule],
|
|
@@ -146,10 +166,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
146
166
|
TabPaneComponent,
|
|
147
167
|
ScrollableDirective,
|
|
148
168
|
SearchInputComponent,
|
|
149
|
-
|
|
169
|
+
SafeHtmlPipe,
|
|
170
|
+
ClickOutsideDirective,
|
|
171
|
+
MobileFlyoutComponent,
|
|
172
|
+
MobileFlyoutPageComponent,
|
|
173
|
+
MobileFlyoutItemComponent
|
|
150
174
|
],
|
|
151
175
|
providers: [],
|
|
152
176
|
bootstrap: [PopoverComponent]
|
|
153
177
|
}]
|
|
154
178
|
}] });
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterModule } from '@angular/router';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { PortalModule } from '@angular/cdk/portal';\n\nimport { ButtonComponent } from './buttons/button/button.component';\nimport { LinkButtonComponent } from './buttons/link-button/link-button.component';\nimport { BreadcrumbComponent } from './breadcrumb/breadcrumb.component';\nimport { LoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';\nimport { ChipContainerComponent } from './chips/chip-container/chip-container.component';\nimport { ChipComponent } from './chips/chip/chip.component';\nimport { TableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';\nimport { StepperComponent } from './stepper/stepper.component';\nimport { PopoverComponent } from './popovers/popover/popover.component';\nimport { PopoverMenuComponent } from './popovers/popover-menu/popover-menu.component';\nimport { TooltipDirective } from './popovers/tooltip/tooltip.directive';\nimport { PopoverContentComponent } from './popovers/popover-content/popover-content.component';\nimport { PopoverContentDirective } from './popovers/popover-content/popover-content.directive';\nimport { LegendComponent } from './popovers/legend/legend.component';\nimport { LegendDirective } from './popovers/legend/legend.directive';\nimport { ProgressComponent } from './progress/progress.component';\nimport { TabsComponent } from './tabs/tabs.component';\nimport { TabPaneComponent } from './tabs/tab-pane/tab-pane.component';\nimport { PaginationComponent } from './pagination/pagination.component';\nimport { ScrollableDirective } from './scroll/scrollable.directive';\nimport { SearchInputComponent } from './search-input/search-input.component';\nimport { ClickOutsideDirective } from './click-outside.directive';\n\nexport * from './buttons/button/button.component';\nexport * from './buttons/link-button/link-button.component';\nexport * from './breadcrumb/breadcrumb.component';\nexport * from './loading-indicator/loading-indicator.component';\nexport * from './chips/chip/chip.component';\nexport * from './chips/chip-container/chip-container.component';\nexport * from './table-header-cell/table-header-cell.directive';\nexport * from './stepper/stepper.component';\nexport * from './popovers/popover/popover.component';\nexport * from './popovers/popover-menu/popover-menu.component';\nexport * from './popovers/tooltip/tooltip.directive';\nexport * from './popovers/popover-content/popover-content.component';\nexport * from './popovers/popover-content/popover-content.directive';\nexport * from './popovers/legend/legend.component';\nexport * from './popovers/legend/legend.directive';\nexport * from './popovers/popover.models';\nexport * from './progress/progress.component';\nexport * from './tabs/tabs.component';\nexport * from './tabs/tab-pane/tab-pane.component';\nexport * from './pagination/pagination.component';\nexport * from './scroll';\nexport * from './search-input/search-input.component';\nexport * from './click-outside.directive';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    LinkButtonComponent,\n    BreadcrumbComponent,\n    LoadingIndicatorComponent,\n    ChipContainerComponent,\n    ChipComponent,\n    PaginationComponent,\n    TableHeaderCellDirective,\n    StepperComponent,\n    PopoverComponent,\n    PopoverMenuComponent,\n    TooltipDirective,\n    PopoverContentComponent,\n    PopoverContentDirective,\n    LegendComponent,\n    LegendDirective,\n    ProgressComponent,\n    TabsComponent,\n    TabPaneComponent,\n    ScrollableDirective,\n    SearchInputComponent,\n    ClickOutsideDirective\n  ],\n  imports: [RouterModule, CommonModule, OverlayModule, PortalModule],\n  exports: [\n    ButtonComponent,\n    LinkButtonComponent,\n    BreadcrumbComponent,\n    LoadingIndicatorComponent,\n    ChipContainerComponent,\n    ChipComponent,\n    PaginationComponent,\n    TableHeaderCellDirective,\n    StepperComponent,\n    PopoverComponent,\n    PopoverMenuComponent,\n    TooltipDirective,\n    PopoverContentComponent,\n    PopoverContentDirective,\n    LegendComponent,\n    LegendDirective,\n    ProgressComponent,\n    TabsComponent,\n    TabPaneComponent,\n    ScrollableDirective,\n    SearchInputComponent,\n    ClickOutsideDirective\n  ],\n  providers: [],\n  bootstrap: [PopoverComponent]\n})\nexport class FestoAngularComponentsModule {}\n"]}
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"components.module.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/components/components.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterModule } from '@angular/router';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { PortalModule } from '@angular/cdk/portal';\n\nimport { ButtonComponent } from './buttons/button/button.component';\nimport { LinkButtonComponent } from './buttons/link-button/link-button.component';\nimport { BreadcrumbComponent } from './breadcrumb/breadcrumb.component';\nimport { LoadingIndicatorComponent } from './loading-indicator/loading-indicator.component';\nimport { ChipContainerComponent } from './chips/chip-container/chip-container.component';\nimport { ChipComponent } from './chips/chip/chip.component';\nimport { TableHeaderCellDirective } from './table-header-cell/table-header-cell.directive';\nimport { StepperComponent } from './stepper/stepper.component';\nimport { PopoverComponent } from './popovers/popover/popover.component';\nimport { PopoverMenuComponent } from './popovers/popover-menu/popover-menu.component';\nimport { TooltipDirective } from './popovers/tooltip/tooltip.directive';\nimport { PopoverContentComponent } from './popovers/popover-content/popover-content.component';\nimport { PopoverContentDirective } from './popovers/popover-content/popover-content.directive';\nimport { LegendComponent } from './popovers/legend/legend.component';\nimport { LegendDirective } from './popovers/legend/legend.directive';\nimport { ProgressComponent } from './progress/progress.component';\nimport { TabsComponent } from './tabs/tabs.component';\nimport { TabPaneComponent } from './tabs/tab-pane/tab-pane.component';\nimport { PaginationComponent } from './pagination/pagination.component';\nimport { ScrollableDirective } from './scroll/scrollable.directive';\nimport { SearchInputComponent } from './search-input/search-input.component';\nimport { ClickOutsideDirective } from './click-outside.directive';\nimport { MobileFlyoutComponent } from './mobile-flyout/mobile-flyout.component';\nimport { MobileFlyoutPageComponent } from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';\nimport { MobileFlyoutItemComponent } from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';\nimport { SafeHtmlPipe } from './search-input/safe-html.pipe';\n\nexport * from './buttons/button/button.component';\nexport * from './buttons/link-button/link-button.component';\nexport * from './breadcrumb/breadcrumb.component';\nexport * from './loading-indicator/loading-indicator.component';\nexport * from './chips/chip/chip.component';\nexport * from './chips/chip-container/chip-container.component';\nexport * from './table-header-cell/table-header-cell.directive';\nexport * from './stepper/stepper.component';\nexport * from './popovers/popover/popover.component';\nexport * from './popovers/popover-menu/popover-menu.component';\nexport * from './popovers/tooltip/tooltip.directive';\nexport * from './popovers/popover-content/popover-content.component';\nexport * from './popovers/popover-content/popover-content.directive';\nexport * from './popovers/legend/legend.component';\nexport * from './popovers/legend/legend.directive';\nexport * from './popovers/popover.models';\nexport * from './progress/progress.component';\nexport * from './tabs/tabs.component';\nexport * from './tabs/tab-pane/tab-pane.component';\nexport * from './pagination/pagination.component';\nexport * from './scroll';\nexport * from './search-input/search-input.component';\nexport * from './search-input/safe-html.pipe';\nexport * from './click-outside.directive';\nexport * from './mobile-flyout/mobile-flyout.component';\nexport * from './mobile-flyout/mobile-flyout-page/mobile-flyout-page.component';\nexport * from './mobile-flyout/mobile-flyout-item/mobile-flyout-item.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    LinkButtonComponent,\n    BreadcrumbComponent,\n    LoadingIndicatorComponent,\n    ChipContainerComponent,\n    ChipComponent,\n    PaginationComponent,\n    TableHeaderCellDirective,\n    StepperComponent,\n    PopoverComponent,\n    PopoverMenuComponent,\n    TooltipDirective,\n    PopoverContentComponent,\n    PopoverContentDirective,\n    LegendComponent,\n    LegendDirective,\n    ProgressComponent,\n    TabsComponent,\n    TabPaneComponent,\n    ScrollableDirective,\n    SearchInputComponent,\n    MobileFlyoutComponent,\n    MobileFlyoutPageComponent,\n    MobileFlyoutItemComponent,\n    SafeHtmlPipe,\n    ClickOutsideDirective\n  ],\n  imports: [RouterModule, CommonModule, OverlayModule, PortalModule],\n  exports: [\n    ButtonComponent,\n    LinkButtonComponent,\n    BreadcrumbComponent,\n    LoadingIndicatorComponent,\n    ChipContainerComponent,\n    ChipComponent,\n    PaginationComponent,\n    TableHeaderCellDirective,\n    StepperComponent,\n    PopoverComponent,\n    PopoverMenuComponent,\n    TooltipDirective,\n    PopoverContentComponent,\n    PopoverContentDirective,\n    LegendComponent,\n    LegendDirective,\n    ProgressComponent,\n    TabsComponent,\n    TabPaneComponent,\n    ScrollableDirective,\n    SearchInputComponent,\n    SafeHtmlPipe,\n    ClickOutsideDirective,\n    MobileFlyoutComponent,\n    MobileFlyoutPageComponent,\n    MobileFlyoutItemComponent\n  ],\n  providers: [],\n  bootstrap: [PopoverComponent]\n})\nexport class FestoAngularComponentsModule {}\n"]}
|
package/esm2020/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.mjs
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/router";
|
|
5
|
+
export class MobileFlyoutItemComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.icon = '';
|
|
8
|
+
this.pageLink = '';
|
|
9
|
+
this.lastElement = false;
|
|
10
|
+
}
|
|
11
|
+
onClick() {
|
|
12
|
+
if (this.onNavigateCallback) {
|
|
13
|
+
this.onNavigateCallback(this.pageLink);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
MobileFlyoutItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
MobileFlyoutItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MobileFlyoutItemComponent, selector: "fng-mobile-flyout-item", inputs: { icon: "icon", pageLink: "pageLink" }, ngImport: i0, template: "<a class=\"fwe-mobile-flyout-item\" [class.fwe-bb]=\"!lastElement\" (click)=\"onClick()\">\n <i *ngIf=\"icon\" [class]=\"'fwe-mr-xs fwe-icon fwe-icon-' + icon\"></i>\n <div class=\"fwe-flex-grow-1\" routerLinkActive=\"fwe-color-hero\">\n <ng-content></ng-content>\n </div>\n <i *ngIf=\"pageLink\" class=\"fwe-icon fwe-icon-arrows-right-2\"></i>\n</a>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }] });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutItemComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{ selector: 'fng-mobile-flyout-item', template: "<a class=\"fwe-mobile-flyout-item\" [class.fwe-bb]=\"!lastElement\" (click)=\"onClick()\">\n <i *ngIf=\"icon\" [class]=\"'fwe-mr-xs fwe-icon fwe-icon-' + icon\"></i>\n <div class=\"fwe-flex-grow-1\" routerLinkActive=\"fwe-color-hero\">\n <ng-content></ng-content>\n </div>\n <i *ngIf=\"pageLink\" class=\"fwe-icon fwe-icon-arrows-right-2\"></i>\n</a>\n" }]
|
|
22
|
+
}], propDecorators: { icon: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}], pageLink: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}] } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9iaWxlLWZseW91dC1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvbW9iaWxlLWZseW91dC9tb2JpbGUtZmx5b3V0LWl0ZW0vbW9iaWxlLWZseW91dC1pdGVtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvbW9iaWxlLWZseW91dC9tb2JpbGUtZmx5b3V0LWl0ZW0vbW9iaWxlLWZseW91dC1pdGVtLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBTWpELE1BQU0sT0FBTyx5QkFBeUI7SUFKdEM7UUFLVyxTQUFJLEdBQVcsRUFBRSxDQUFDO1FBRWxCLGFBQVEsR0FBVyxFQUFFLENBQUM7UUFFeEIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7S0FTNUI7SUFMQyxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDM0IsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUN4QztJQUNILENBQUM7O3NIQWJVLHlCQUF5QjswR0FBekIseUJBQXlCLDhHQ050Qyx5V0FPQTsyRkREYSx5QkFBeUI7a0JBSnJDLFNBQVM7K0JBQ0Usd0JBQXdCOzhCQUl6QixJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm5nLW1vYmlsZS1mbHlvdXQtaXRlbScsXG4gIHRlbXBsYXRlVXJsOiAnLi9tb2JpbGUtZmx5b3V0LWl0ZW0uY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIE1vYmlsZUZseW91dEl0ZW1Db21wb25lbnQge1xuICBASW5wdXQoKSBpY29uOiBzdHJpbmcgPSAnJztcblxuICBASW5wdXQoKSBwYWdlTGluazogc3RyaW5nID0gJyc7XG5cbiAgcHVibGljIGxhc3RFbGVtZW50ID0gZmFsc2U7XG5cbiAgcHVibGljIG9uTmF2aWdhdGVDYWxsYmFjazogKChwYWdlTmFtZTogc3RyaW5nKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcblxuICBvbkNsaWNrKCkge1xuICAgIGlmICh0aGlzLm9uTmF2aWdhdGVDYWxsYmFjaykge1xuICAgICAgdGhpcy5vbk5hdmlnYXRlQ2FsbGJhY2sodGhpcy5wYWdlTGluayk7XG4gICAgfVxuICB9XG59XG4iLCI8YSBjbGFzcz1cImZ3ZS1tb2JpbGUtZmx5b3V0LWl0ZW1cIiBbY2xhc3MuZndlLWJiXT1cIiFsYXN0RWxlbWVudFwiIChjbGljayk9XCJvbkNsaWNrKClcIj5cbiAgPGkgKm5nSWY9XCJpY29uXCIgW2NsYXNzXT1cIidmd2UtbXIteHMgZndlLWljb24gZndlLWljb24tJyArIGljb25cIj48L2k+XG4gIDxkaXYgY2xhc3M9XCJmd2UtZmxleC1ncm93LTFcIiByb3V0ZXJMaW5rQWN0aXZlPVwiZndlLWNvbG9yLWhlcm9cIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuICA8aSAqbmdJZj1cInBhZ2VMaW5rXCIgY2xhc3M9XCJmd2UtaWNvbiBmd2UtaWNvbi1hcnJvd3MtcmlnaHQtMlwiPjwvaT5cbjwvYT5cbiJdfQ==
|
package/esm2020/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.mjs
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Component, ContentChildren, Input, QueryList } from '@angular/core';
|
|
2
|
+
import { MobileFlyoutItemComponent } from '../mobile-flyout-item/mobile-flyout-item.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class MobileFlyoutPageComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.name = '';
|
|
8
|
+
this.isfirstelement = false;
|
|
9
|
+
this.visible = false;
|
|
10
|
+
}
|
|
11
|
+
ngAfterContentInit() {
|
|
12
|
+
if (!this.itemComponents) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
// register click-callbacks
|
|
16
|
+
this.itemComponents.forEach(s => {
|
|
17
|
+
s.onNavigateCallback = pageName => this.onNavigate(pageName);
|
|
18
|
+
});
|
|
19
|
+
if (this.itemComponents.last) {
|
|
20
|
+
this.itemComponents.last.lastElement = true;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
onNavigate(pageName) {
|
|
24
|
+
if (this.onNavigateCallback) {
|
|
25
|
+
this.onNavigateCallback(pageName);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
onBack() {
|
|
29
|
+
this.visible = false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
MobileFlyoutPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutPageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
MobileFlyoutPageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MobileFlyoutPageComponent, selector: "fng-mobile-flyout-page", inputs: { name: "name" }, queries: [{ propertyName: "itemComponents", predicate: MobileFlyoutItemComponent }], ngImport: i0, template: "<div class=\"fwe-mobile-flyout-page\" [class.fwe-opened]=\"visible\">\n <div class=\"fwe-page-back\" *ngIf=\"!isfirstelement\" (click)=\"onBack()\">\n <i></i>\n <div>Back</div>\n </div>\n <div class=\"fwe-mobile-flyout-item-container\">\n <ng-content></ng-content>\n </div>\n</div>\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutPageComponent, decorators: [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{ selector: 'fng-mobile-flyout-page', template: "<div class=\"fwe-mobile-flyout-page\" [class.fwe-opened]=\"visible\">\n <div class=\"fwe-page-back\" *ngIf=\"!isfirstelement\" (click)=\"onBack()\">\n <i></i>\n <div>Back</div>\n </div>\n <div class=\"fwe-mobile-flyout-item-container\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
|
|
37
|
+
}], propDecorators: { itemComponents: [{
|
|
38
|
+
type: ContentChildren,
|
|
39
|
+
args: [MobileFlyoutItemComponent]
|
|
40
|
+
}], name: [{
|
|
41
|
+
type: Input
|
|
42
|
+
}] } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9iaWxlLWZseW91dC1wYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvbW9iaWxlLWZseW91dC9tb2JpbGUtZmx5b3V0LXBhZ2UvbW9iaWxlLWZseW91dC1wYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvbW9iaWxlLWZseW91dC9tb2JpbGUtZmx5b3V0LXBhZ2UvbW9iaWxlLWZseW91dC1wYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBb0IsU0FBUyxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9GLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDOzs7QUFNL0YsTUFBTSxPQUFPLHlCQUF5QjtJQUp0QztRQU9XLFNBQUksR0FBVyxFQUFFLENBQUM7UUFFcEIsbUJBQWMsR0FBRyxLQUFLLENBQUM7UUFDdkIsWUFBTyxHQUFHLEtBQUssQ0FBQztLQTBCeEI7SUF2QkMsa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFO1lBQ3hCLE9BQU87U0FDUjtRQUVELDJCQUEyQjtRQUMzQixJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUM5QixDQUFDLENBQUMsa0JBQWtCLEdBQUcsUUFBUSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQy9ELENBQUMsQ0FBQyxDQUFDO1FBQ0gsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRTtZQUM1QixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO1NBQzdDO0lBQ0gsQ0FBQztJQUVELFVBQVUsQ0FBQyxRQUFnQjtRQUN6QixJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMzQixJQUFJLENBQUMsa0JBQWtCLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDbkM7SUFDSCxDQUFDO0lBRUQsTUFBTTtRQUNKLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLENBQUM7O3NIQS9CVSx5QkFBeUI7MEdBQXpCLHlCQUF5Qix1SEFDbkIseUJBQXlCLDZCQ1I1QywwU0FTQTsyRkRGYSx5QkFBeUI7a0JBSnJDLFNBQVM7K0JBQ0Usd0JBQXdCOzhCQUlVLGNBQWM7c0JBQXpELGVBQWU7dUJBQUMseUJBQXlCO2dCQUVqQyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlckNvbnRlbnRJbml0LCBDb21wb25lbnQsIENvbnRlbnRDaGlsZHJlbiwgSW5wdXQsIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTW9iaWxlRmx5b3V0SXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL21vYmlsZS1mbHlvdXQtaXRlbS9tb2JpbGUtZmx5b3V0LWl0ZW0uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm5nLW1vYmlsZS1mbHlvdXQtcGFnZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9tb2JpbGUtZmx5b3V0LXBhZ2UuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIE1vYmlsZUZseW91dFBhZ2VDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlckNvbnRlbnRJbml0IHtcbiAgQENvbnRlbnRDaGlsZHJlbihNb2JpbGVGbHlvdXRJdGVtQ29tcG9uZW50KSBpdGVtQ29tcG9uZW50cyE6IFF1ZXJ5TGlzdDxNb2JpbGVGbHlvdXRJdGVtQ29tcG9uZW50PjtcblxuICBASW5wdXQoKSBuYW1lOiBzdHJpbmcgPSAnJztcblxuICBwdWJsaWMgaXNmaXJzdGVsZW1lbnQgPSBmYWxzZTtcbiAgcHVibGljIHZpc2libGUgPSBmYWxzZTtcbiAgcHVibGljIG9uTmF2aWdhdGVDYWxsYmFjazogKChwYWdlTmFtZTogc3RyaW5nKSA9PiB2b2lkKSB8IHVuZGVmaW5lZDtcblxuICBuZ0FmdGVyQ29udGVudEluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLml0ZW1Db21wb25lbnRzKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgLy8gcmVnaXN0ZXIgY2xpY2stY2FsbGJhY2tzXG4gICAgdGhpcy5pdGVtQ29tcG9uZW50cy5mb3JFYWNoKHMgPT4ge1xuICAgICAgcy5vbk5hdmlnYXRlQ2FsbGJhY2sgPSBwYWdlTmFtZSA9PiB0aGlzLm9uTmF2aWdhdGUocGFnZU5hbWUpO1xuICAgIH0pO1xuICAgIGlmICh0aGlzLml0ZW1Db21wb25lbnRzLmxhc3QpIHtcbiAgICAgIHRoaXMuaXRlbUNvbXBvbmVudHMubGFzdC5sYXN0RWxlbWVudCA9IHRydWU7XG4gICAgfVxuICB9XG5cbiAgb25OYXZpZ2F0ZShwYWdlTmFtZTogc3RyaW5nKSB7XG4gICAgaWYgKHRoaXMub25OYXZpZ2F0ZUNhbGxiYWNrKSB7XG4gICAgICB0aGlzLm9uTmF2aWdhdGVDYWxsYmFjayhwYWdlTmFtZSk7XG4gICAgfVxuICB9XG5cbiAgb25CYWNrKCkge1xuICAgIHRoaXMudmlzaWJsZSA9IGZhbHNlO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZndlLW1vYmlsZS1mbHlvdXQtcGFnZVwiIFtjbGFzcy5md2Utb3BlbmVkXT1cInZpc2libGVcIj5cbiAgPGRpdiBjbGFzcz1cImZ3ZS1wYWdlLWJhY2tcIiAqbmdJZj1cIiFpc2ZpcnN0ZWxlbWVudFwiIChjbGljayk9XCJvbkJhY2soKVwiPlxuICAgIDxpPjwvaT5cbiAgICA8ZGl2PkJhY2s8L2Rpdj5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJmd2UtbW9iaWxlLWZseW91dC1pdGVtLWNvbnRhaW5lclwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Component, ContentChildren, QueryList } from '@angular/core';
|
|
2
|
+
import { MobileFlyoutPageComponent } from './mobile-flyout-page/mobile-flyout-page.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../click-outside.directive";
|
|
5
|
+
export class MobileFlyoutComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.isOpen = false;
|
|
8
|
+
}
|
|
9
|
+
ngAfterContentInit() {
|
|
10
|
+
if (!this.pageComponents) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
// register click-callbacks and open the first element
|
|
14
|
+
this.pageComponents.forEach((s, i) => {
|
|
15
|
+
s.onNavigateCallback = pageName => this.onNavigate(pageName);
|
|
16
|
+
s.isfirstelement = i === 0;
|
|
17
|
+
s.visible = i === 0;
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
onNavigate(pageName) {
|
|
21
|
+
// handle clicks on router links
|
|
22
|
+
if (!pageName) {
|
|
23
|
+
this.isOpen = false;
|
|
24
|
+
}
|
|
25
|
+
// handle page-navigation clicks
|
|
26
|
+
const nextPage = this.pageComponents.find(p => p.name === pageName);
|
|
27
|
+
if (nextPage) {
|
|
28
|
+
nextPage.visible = true;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
MobileFlyoutComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
+
MobileFlyoutComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MobileFlyoutComponent, selector: "fng-mobile-flyout", queries: [{ propertyName: "pageComponents", predicate: MobileFlyoutPageComponent }], ngImport: i0, template: "<div class=\"fwe-mobile-flyout\" (clickOutside)=\"isOpen = false\" fngClickOutside>\n <button [class.fwe-burger-button]=\"!isOpen\" [class.fwe-close-button]=\"isOpen\" (click)=\"isOpen = !isOpen\"></button>\n\n <div class=\"fwe-mobile-flyout-container\" [class.fwe-opened]=\"isOpen\">\n <ng-content></ng-content>\n </div>\n</div>\n", directives: [{ type: i1.ClickOutsideDirective, selector: "[fngClickOutside]", outputs: ["clickOutside"] }] });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MobileFlyoutComponent, decorators: [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{ selector: 'fng-mobile-flyout', template: "<div class=\"fwe-mobile-flyout\" (clickOutside)=\"isOpen = false\" fngClickOutside>\n <button [class.fwe-burger-button]=\"!isOpen\" [class.fwe-close-button]=\"isOpen\" (click)=\"isOpen = !isOpen\"></button>\n\n <div class=\"fwe-mobile-flyout-container\" [class.fwe-opened]=\"isOpen\">\n <ng-content></ng-content>\n </div>\n</div>\n" }]
|
|
37
|
+
}], propDecorators: { pageComponents: [{
|
|
38
|
+
type: ContentChildren,
|
|
39
|
+
args: [MobileFlyoutPageComponent]
|
|
40
|
+
}] } });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9iaWxlLWZseW91dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL21vYmlsZS1mbHlvdXQvbW9iaWxlLWZseW91dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL21vYmlsZS1mbHlvdXQvbW9iaWxlLWZseW91dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFNBQVMsRUFBRSxlQUFlLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG1EQUFtRCxDQUFDOzs7QUFNOUYsTUFBTSxPQUFPLHFCQUFxQjtJQUpsQztRQU9FLFdBQU0sR0FBRyxLQUFLLENBQUM7S0EyQmhCO0lBekJDLGtCQUFrQjtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUN4QixPQUFPO1NBQ1I7UUFFRCxzREFBc0Q7UUFDdEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDbkMsQ0FBQyxDQUFDLGtCQUFrQixHQUFHLFFBQVEsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3RCxDQUFDLENBQUMsY0FBYyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDM0IsQ0FBQyxDQUFDLE9BQU8sR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxRQUFnQjtRQUN6QixnQ0FBZ0M7UUFDaEMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNiLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1NBQ3JCO1FBRUQsZ0NBQWdDO1FBQ2hDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxRQUFRLENBQUMsQ0FBQztRQUNwRSxJQUFJLFFBQVEsRUFBRTtZQUNaLFFBQVEsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQzs7a0hBN0JVLHFCQUFxQjtzR0FBckIscUJBQXFCLHdGQUNmLHlCQUF5Qiw2QkNSNUMsbVZBT0E7MkZEQWEscUJBQXFCO2tCQUpqQyxTQUFTOytCQUNFLG1CQUFtQjs4QkFJZSxjQUFjO3NCQUF6RCxlQUFlO3VCQUFDLHlCQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyQ29udGVudEluaXQsIENvbXBvbmVudCwgQ29udGVudENoaWxkcmVuLCBRdWVyeUxpc3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1vYmlsZUZseW91dFBhZ2VDb21wb25lbnQgfSBmcm9tICcuL21vYmlsZS1mbHlvdXQtcGFnZS9tb2JpbGUtZmx5b3V0LXBhZ2UuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZm5nLW1vYmlsZS1mbHlvdXQnLFxuICB0ZW1wbGF0ZVVybDogJy4vbW9iaWxlLWZseW91dC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgTW9iaWxlRmx5b3V0Q29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG4gIEBDb250ZW50Q2hpbGRyZW4oTW9iaWxlRmx5b3V0UGFnZUNvbXBvbmVudCkgcGFnZUNvbXBvbmVudHMhOiBRdWVyeUxpc3Q8TW9iaWxlRmx5b3V0UGFnZUNvbXBvbmVudD47XG5cbiAgaXNPcGVuID0gZmFsc2U7XG5cbiAgbmdBZnRlckNvbnRlbnRJbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5wYWdlQ29tcG9uZW50cykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIHJlZ2lzdGVyIGNsaWNrLWNhbGxiYWNrcyBhbmQgb3BlbiB0aGUgZmlyc3QgZWxlbWVudFxuICAgIHRoaXMucGFnZUNvbXBvbmVudHMuZm9yRWFjaCgocywgaSkgPT4ge1xuICAgICAgcy5vbk5hdmlnYXRlQ2FsbGJhY2sgPSBwYWdlTmFtZSA9PiB0aGlzLm9uTmF2aWdhdGUocGFnZU5hbWUpO1xuICAgICAgcy5pc2ZpcnN0ZWxlbWVudCA9IGkgPT09IDA7XG4gICAgICBzLnZpc2libGUgPSBpID09PSAwO1xuICAgIH0pO1xuICB9XG5cbiAgb25OYXZpZ2F0ZShwYWdlTmFtZTogc3RyaW5nKSB7XG4gICAgLy8gaGFuZGxlIGNsaWNrcyBvbiByb3V0ZXIgbGlua3NcbiAgICBpZiAoIXBhZ2VOYW1lKSB7XG4gICAgICB0aGlzLmlzT3BlbiA9IGZhbHNlO1xuICAgIH1cblxuICAgIC8vIGhhbmRsZSBwYWdlLW5hdmlnYXRpb24gY2xpY2tzXG4gICAgY29uc3QgbmV4dFBhZ2UgPSB0aGlzLnBhZ2VDb21wb25lbnRzLmZpbmQocCA9PiBwLm5hbWUgPT09IHBhZ2VOYW1lKTtcbiAgICBpZiAobmV4dFBhZ2UpIHtcbiAgICAgIG5leHRQYWdlLnZpc2libGUgPSB0cnVlO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImZ3ZS1tb2JpbGUtZmx5b3V0XCIgKGNsaWNrT3V0c2lkZSk9XCJpc09wZW4gPSBmYWxzZVwiIGZuZ0NsaWNrT3V0c2lkZT5cbiAgPGJ1dHRvbiBbY2xhc3MuZndlLWJ1cmdlci1idXR0b25dPVwiIWlzT3BlblwiIFtjbGFzcy5md2UtY2xvc2UtYnV0dG9uXT1cImlzT3BlblwiIChjbGljayk9XCJpc09wZW4gPSAhaXNPcGVuXCI+PC9idXR0b24+XG5cbiAgPGRpdiBjbGFzcz1cImZ3ZS1tb2JpbGUtZmx5b3V0LWNvbnRhaW5lclwiIFtjbGFzcy5md2Utb3BlbmVkXT1cImlzT3BlblwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
5
|
+
export class SafeHtmlPipe {
|
|
6
|
+
constructor(sanitizer) {
|
|
7
|
+
this.sanitizer = sanitizer;
|
|
8
|
+
}
|
|
9
|
+
transform(value) {
|
|
10
|
+
return this.sanitizer.bypassSecurityTrustHtml(value);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
SafeHtmlPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: SafeHtmlPipe, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
14
|
+
SafeHtmlPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: SafeHtmlPipe, name: "safeHtml" });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: SafeHtmlPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'safeHtml'
|
|
19
|
+
}]
|
|
20
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; } });
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS1odG1sLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL3NlYXJjaC1pbnB1dC9zYWZlLWh0bWwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUM7OztBQUtuRSxNQUFNLE9BQU8sWUFBWTtJQUN2QixZQUFzQixTQUF1QjtRQUF2QixjQUFTLEdBQVQsU0FBUyxDQUFjO0lBQUcsQ0FBQztJQUUxQyxTQUFTLENBQUMsS0FBVTtRQUN6QixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsdUJBQXVCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdkQsQ0FBQzs7eUdBTFUsWUFBWTt1R0FBWixZQUFZOzJGQUFaLFlBQVk7a0JBSHhCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLFVBQVU7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyLCBTYWZlSHRtbCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdzYWZlSHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgU2FmZUh0bWxQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBzYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cblxuICBwdWJsaWMgdHJhbnNmb3JtKHZhbHVlOiBhbnkpOiBTYWZlSHRtbCB7XG4gICAgcmV0dXJuIHRoaXMuc2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RIdG1sKHZhbHVlKTtcbiAgfVxufVxuIl19
|
|
@@ -3,6 +3,28 @@ import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../click-outside.directive";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "./safe-html.pipe";
|
|
7
|
+
export class SearchSuggestion {
|
|
8
|
+
/**
|
|
9
|
+
* Creates a basic Suggestion from a string. The first query match is highlighted by bold tags.
|
|
10
|
+
* @param suggestionString The suggested string (should contain the whole query)
|
|
11
|
+
* @param query The current query. This string will be highlighted.
|
|
12
|
+
* @returns a html-string.
|
|
13
|
+
*/
|
|
14
|
+
static basicSuggestion(suggestionString, query) {
|
|
15
|
+
const i = suggestionString.toLocaleLowerCase().indexOf(query.toLocaleLowerCase());
|
|
16
|
+
let template = suggestionString;
|
|
17
|
+
if (i != -1) {
|
|
18
|
+
const boldStart = i;
|
|
19
|
+
const boldEnd = i + query.length;
|
|
20
|
+
const part1 = suggestionString.substring(0, boldStart);
|
|
21
|
+
const part2 = suggestionString.substring(boldStart, boldEnd);
|
|
22
|
+
const part3 = suggestionString.substring(boldEnd, suggestionString.length);
|
|
23
|
+
template = part1 + '<b>' + part2 + '</b>' + part3;
|
|
24
|
+
}
|
|
25
|
+
return { value: suggestionString, template };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
6
28
|
/**
|
|
7
29
|
* A custom form element for search inputs.
|
|
8
30
|
*/
|
|
@@ -77,7 +99,7 @@ export class SearchInputComponent {
|
|
|
77
99
|
else {
|
|
78
100
|
this.selectedSuggestionIndex = this.cappedSuggestions.length - 1;
|
|
79
101
|
}
|
|
80
|
-
this.value = this.cappedSuggestions[this.selectedSuggestionIndex];
|
|
102
|
+
this.value = this.cappedSuggestions[this.selectedSuggestionIndex].value;
|
|
81
103
|
}
|
|
82
104
|
if (event.key === 'ArrowDown') {
|
|
83
105
|
if (this.selectedSuggestionIndex >= this.cappedSuggestions.length - 1) {
|
|
@@ -86,7 +108,7 @@ export class SearchInputComponent {
|
|
|
86
108
|
else {
|
|
87
109
|
this.selectedSuggestionIndex++;
|
|
88
110
|
}
|
|
89
|
-
this.value = this.cappedSuggestions[this.selectedSuggestionIndex];
|
|
111
|
+
this.value = this.cappedSuggestions[this.selectedSuggestionIndex].value;
|
|
90
112
|
}
|
|
91
113
|
}
|
|
92
114
|
onClickOutside() {
|
|
@@ -110,12 +132,12 @@ export class SearchInputComponent {
|
|
|
110
132
|
}
|
|
111
133
|
onSuggestionClick(suggestion) {
|
|
112
134
|
this.selectedSuggestionIndex = -1;
|
|
113
|
-
this.value = suggestion;
|
|
135
|
+
this.value = suggestion.value;
|
|
114
136
|
this.fngSearch.emit(this.value);
|
|
115
137
|
this.hideSuggestionList = true;
|
|
116
138
|
this.inputRef.nativeElement.blur();
|
|
117
139
|
}
|
|
118
|
-
|
|
140
|
+
clearQuery() {
|
|
119
141
|
this.selectedSuggestionIndex = -1;
|
|
120
142
|
this.value = '';
|
|
121
143
|
this.fngSearch.emit(this.value);
|
|
@@ -124,10 +146,10 @@ export class SearchInputComponent {
|
|
|
124
146
|
}
|
|
125
147
|
}
|
|
126
148
|
SearchInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: SearchInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
127
|
-
SearchInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: SearchInputComponent, selector: "fng-search-input", inputs: { label: "label", disabled: "disabled", value: "value", suggestions: "suggestions" }, outputs: { fngChange: "fngChange", fngSearch: "fngSearch" }, host: { listeners: { "document:keydown": "keyhandler($event)" } }, viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n <input\n class=\"fwe-w-100\"\n #inputElement\n [attr.disabled]=\"disabled ? '' : null\"\n [placeholder]=\"label\"\n (focus)=\"onFocus()\"\n type=\"search\"\n (input)=\"onInput($event)\"\n (search)=\"onSearch($event)\"\n [value]=\"innerValue\"\n />\n <div class=\"fwe-search-icon\"></div>\n <div class=\"fwe-clear-icon\" (click)=\"
|
|
149
|
+
SearchInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: SearchInputComponent, selector: "fng-search-input", inputs: { label: "label", disabled: "disabled", value: "value", suggestions: "suggestions" }, outputs: { fngChange: "fngChange", fngSearch: "fngSearch" }, host: { listeners: { "document:keydown": "keyhandler($event)" } }, viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n <input\n class=\"fwe-w-100\"\n #inputElement\n [attr.disabled]=\"disabled ? '' : null\"\n [placeholder]=\"label\"\n (focus)=\"onFocus()\"\n type=\"search\"\n (input)=\"onInput($event)\"\n (search)=\"onSearch($event)\"\n [value]=\"innerValue\"\n />\n <div class=\"fwe-search-icon\"></div>\n <div class=\"fwe-clear-icon\" (click)=\"clearQuery()\"></div>\n <div class=\"fwe-search-suggestions\" *ngIf=\"innerSuggestions?.length && !hideSuggestionList\">\n <div\n *ngFor=\"let suggestion of cappedSuggestions; let i = index\"\n (click)=\"onSuggestionClick(suggestion)\"\n [class.fwe-selected]=\"selectedSuggestionIndex === i\"\n class=\"fwe-search-suggestion\"\n >\n <div [innerHTML]=\"suggestion.template | safeHtml\"></div>\n </div>\n <div class=\"fwe-ml-xxs\" *ngIf=\"innerSuggestions.length > 10\">...</div>\n </div>\n</div>\n", styles: [".fwe-w-100{width:100%}.fwe-search-suggestion{height:40px}\n"], directives: [{ type: i1.ClickOutsideDirective, selector: "[fngClickOutside]", outputs: ["clickOutside"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "safeHtml": i3.SafeHtmlPipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
128
150
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: SearchInputComponent, decorators: [{
|
|
129
151
|
type: Component,
|
|
130
|
-
args: [{ selector: 'fng-search-input', encapsulation: ViewEncapsulation.None, template: "<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n <input\n class=\"fwe-w-100\"\n #inputElement\n [attr.disabled]=\"disabled ? '' : null\"\n [placeholder]=\"label\"\n (focus)=\"onFocus()\"\n type=\"search\"\n (input)=\"onInput($event)\"\n (search)=\"onSearch($event)\"\n [value]=\"innerValue\"\n />\n <div class=\"fwe-search-icon\"></div>\n <div class=\"fwe-clear-icon\" (click)=\"
|
|
152
|
+
args: [{ selector: 'fng-search-input', encapsulation: ViewEncapsulation.None, template: "<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n <input\n class=\"fwe-w-100\"\n #inputElement\n [attr.disabled]=\"disabled ? '' : null\"\n [placeholder]=\"label\"\n (focus)=\"onFocus()\"\n type=\"search\"\n (input)=\"onInput($event)\"\n (search)=\"onSearch($event)\"\n [value]=\"innerValue\"\n />\n <div class=\"fwe-search-icon\"></div>\n <div class=\"fwe-clear-icon\" (click)=\"clearQuery()\"></div>\n <div class=\"fwe-search-suggestions\" *ngIf=\"innerSuggestions?.length && !hideSuggestionList\">\n <div\n *ngFor=\"let suggestion of cappedSuggestions; let i = index\"\n (click)=\"onSuggestionClick(suggestion)\"\n [class.fwe-selected]=\"selectedSuggestionIndex === i\"\n class=\"fwe-search-suggestion\"\n >\n <div [innerHTML]=\"suggestion.template | safeHtml\"></div>\n </div>\n <div class=\"fwe-ml-xxs\" *ngIf=\"innerSuggestions.length > 10\">...</div>\n </div>\n</div>\n", styles: [".fwe-w-100{width:100%}.fwe-search-suggestion{height:40px}\n"] }]
|
|
131
153
|
}], propDecorators: { inputRef: [{
|
|
132
154
|
type: ViewChild,
|
|
133
155
|
args: ['inputElement']
|
|
@@ -147,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
147
169
|
type: HostListener,
|
|
148
170
|
args: ['document:keydown', ['$event']]
|
|
149
171
|
}] } });
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-input.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/lib/components/search-input/search-input.component.ts","../../../../../../../libs/angular/src/lib/components/search-input/search-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, ViewEncapsulation, Output, EventEmitter, HostListener } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\n/**\n * A custom form element for search inputs.\n */\n@Component({\n  selector: 'fng-search-input',\n  templateUrl: './search-input.component.html',\n  styleUrls: ['./search-input.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class SearchInputComponent {\n  @ViewChild('inputElement')\n  inputRef!: ElementRef<HTMLInputElement>;\n\n  /**\n   * the querrry was changed, update the suggetion list\n   */\n  @Output()\n  readonly fngChange = new EventEmitter<string>();\n\n  /**\n   * Start search on this event\n   */\n  @Output()\n  readonly fngSearch = new EventEmitter<string>();\n\n  /**\n   * The search input label.\n   */\n  @Input() label: string = '';\n\n  /**\n   * When true the control's disabled attribute is set\n   * and it gets addeed the .disabled css class.\n   */\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n  protected innerDisabled = false;\n\n  innerValue: string = '';\n\n  /**\n   * The getter for value.\n   */\n  get value(): string {\n    return this.innerValue;\n  }\n\n  /**\n   * The setter for value.\n   */\n  @Input()\n  set value(value: string) {\n    if (value != null) {\n      value = '' + value;\n    }\n    this.innerValue = value;\n  }\n\n  /**\n   * The list of suggestions\n   */\n  @Input()\n  set suggestions(value: string[]) {\n    this.selectedSuggestionIndex = -1;\n    this.innerSuggestions = value;\n  }\n\n  /**\n   * The list of suggestions capped by 10 entries\n   */\n  get cappedSuggestions(): string[] {\n    return this.innerSuggestions.slice(0, 10);\n  }\n\n  innerSuggestions: string[] = [];\n  hideSuggestionList: boolean = false;\n\n  // This is the index of the selected element in dhe suggestion list.\n  selectedSuggestionIndex = -1;\n\n  @HostListener('document:keydown', ['$event'])\n  keyhandler(event: KeyboardEvent) {\n    if (!this.cappedSuggestions || !this.cappedSuggestions.length) {\n      return;\n    }\n\n    // navigate inside the suggestion list\n    if (event.key === 'ArrowUp') {\n      if (this.selectedSuggestionIndex > 0) {\n        this.selectedSuggestionIndex--;\n      } else {\n        this.selectedSuggestionIndex = this.cappedSuggestions.length - 1;\n      }\n      this.value = this.cappedSuggestions[this.selectedSuggestionIndex];\n    }\n\n    if (event.key === 'ArrowDown') {\n      if (this.selectedSuggestionIndex >= this.cappedSuggestions.length - 1) {\n        this.selectedSuggestionIndex = 0;\n      } else {\n        this.selectedSuggestionIndex++;\n      }\n      this.value = this.cappedSuggestions[this.selectedSuggestionIndex];\n    }\n  }\n\n  onClickOutside(): void {\n    this.hideSuggestionList = true;\n  }\n\n  onFocus() {\n    this.hideSuggestionList = false;\n  }\n\n  onInput(event: any) {\n    this.selectedSuggestionIndex = -1;\n    this.value = event.target.value;\n    this.fngChange.emit(this.value);\n  }\n\n  // also triggert on \"Enter\" and \"Escape\"\n  onSearch(event: any): void {\n    event.stopPropagation();\n    this.selectedSuggestionIndex = -1;\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n\n  onSuggestionClick(suggestion: string) {\n    this.selectedSuggestionIndex = -1;\n    this.value = suggestion;\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n\n  clearQuerry(): void {\n    this.selectedSuggestionIndex = -1;\n    this.value = '';\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n}\n","<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n  <input\n    class=\"fwe-w-100\"\n    #inputElement\n    [attr.disabled]=\"disabled ? '' : null\"\n    [placeholder]=\"label\"\n    (focus)=\"onFocus()\"\n    type=\"search\"\n    (input)=\"onInput($event)\"\n    (search)=\"onSearch($event)\"\n    [value]=\"innerValue\"\n  />\n  <div class=\"fwe-search-icon\"></div>\n  <div class=\"fwe-clear-icon\" (click)=\"clearQuerry()\"></div>\n  <div class=\"fwe-search-suggestions\" *ngIf=\"innerSuggestions?.length && !hideSuggestionList\">\n    <div\n      *ngFor=\"let suggestion of cappedSuggestions; let i = index\"\n      (click)=\"onSuggestionClick(suggestion)\"\n      [class.fwe-selected]=\"selectedSuggestionIndex === i\"\n      class=\"fwe-search-suggestion\"\n    >\n      {{ suggestion }}\n    </div>\n    <div class=\"fwe-ml-xxs\" *ngIf=\"innerSuggestions.length > 10\">...</div>\n  </div>\n</div>\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-input.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/lib/components/search-input/search-input.component.ts","../../../../../../../libs/angular/src/lib/components/search-input/search-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, ViewEncapsulation, Output, EventEmitter, HostListener } from '@angular/core';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\n\nexport class SearchSuggestion {\n  /**\n   * a html-string. e.g.: '<b> hello </b>'\n   */\n  template: string;\n\n  /**\n   * This Value will be used as new query when the user selects the suggestion.\n   */\n  value: string;\n\n  /**\n   * Creates a basic Suggestion from a string. The first query match is highlighted by bold tags.\n   * @param suggestionString The suggested string (should contain the whole query)\n   * @param query The current query. This string will be highlighted.\n   * @returns a html-string.\n   */\n  static basicSuggestion(suggestionString: string, query: string): SearchSuggestion {\n    const i = suggestionString.toLocaleLowerCase().indexOf(query.toLocaleLowerCase());\n    let template = suggestionString;\n    if (i != -1) {\n      const  boldStart = i;\n      const boldEnd = i + query.length;\n      const part1 = suggestionString.substring(0, boldStart);\n      const part2 = suggestionString.substring(boldStart, boldEnd);\n      const part3 = suggestionString.substring(boldEnd, suggestionString.length);\n      template = part1 + '<b>' + part2 + '</b>' + part3;\n    }\n    return { value: suggestionString, template };\n  }\n}\n\n/**\n * A custom form element for search inputs.\n */\n@Component({\n  selector: 'fng-search-input',\n  templateUrl: './search-input.component.html',\n  styleUrls: ['./search-input.component.scss'],\n  encapsulation: ViewEncapsulation.None\n})\nexport class SearchInputComponent {\n  @ViewChild('inputElement')\n  inputRef!: ElementRef<HTMLInputElement>;\n\n  /**\n   * the querrry was changed, update the suggetion list\n   */\n  @Output()\n  readonly fngChange = new EventEmitter<string>();\n\n  /**\n   * Start search on this event\n   */\n  @Output()\n  readonly fngSearch = new EventEmitter<string>();\n\n  /**\n   * The search input label.\n   */\n  @Input() label: string = '';\n\n  /**\n   * When true the control's disabled attribute is set\n   * and it gets addeed the .disabled css class.\n   */\n  @Input()\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n  protected innerDisabled = false;\n\n  innerValue: string = '';\n\n  /**\n   * The getter for value.\n   */\n  get value(): string {\n    return this.innerValue;\n  }\n\n  /**\n   * The setter for value.\n   */\n  @Input()\n  set value(value: string) {\n    if (value != null) {\n      value = '' + value;\n    }\n    this.innerValue = value;\n  }\n\n  /**\n   * The list of suggestions\n   */\n  @Input()\n  set suggestions(value: SearchSuggestion[]) {\n    this.selectedSuggestionIndex = -1;\n    this.innerSuggestions = value;\n  }\n\n  /**\n   * The list of suggestions capped by 10 entries\n   */\n  get cappedSuggestions(): SearchSuggestion[] {\n    return this.innerSuggestions.slice(0, 10);\n  }\n\n  innerSuggestions: SearchSuggestion[] = [];\n  hideSuggestionList: boolean = false;\n\n  // This is the index of the selected element in dhe suggestion list.\n  selectedSuggestionIndex = -1;\n\n  @HostListener('document:keydown', ['$event'])\n  keyhandler(event: KeyboardEvent) {\n    if (!this.cappedSuggestions || !this.cappedSuggestions.length) {\n      return;\n    }\n\n    // navigate inside the suggestion list\n    if (event.key === 'ArrowUp') {\n      if (this.selectedSuggestionIndex > 0) {\n        this.selectedSuggestionIndex--;\n      } else {\n        this.selectedSuggestionIndex = this.cappedSuggestions.length - 1;\n      }\n      this.value = this.cappedSuggestions[this.selectedSuggestionIndex].value;\n    }\n\n    if (event.key === 'ArrowDown') {\n      if (this.selectedSuggestionIndex >= this.cappedSuggestions.length - 1) {\n        this.selectedSuggestionIndex = 0;\n      } else {\n        this.selectedSuggestionIndex++;\n      }\n      this.value = this.cappedSuggestions[this.selectedSuggestionIndex].value;\n    }\n  }\n\n  onClickOutside(): void {\n    this.hideSuggestionList = true;\n  }\n\n  onFocus() {\n    this.hideSuggestionList = false;\n  }\n\n  onInput(event: any) {\n    this.selectedSuggestionIndex = -1;\n    this.value = event.target.value;\n    this.fngChange.emit(this.value);\n  }\n\n  // also triggert on \"Enter\" and \"Escape\"\n  onSearch(event: any): void {\n    event.stopPropagation();\n    this.selectedSuggestionIndex = -1;\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n\n  onSuggestionClick(suggestion: SearchSuggestion) {\n    this.selectedSuggestionIndex = -1;\n    this.value = suggestion.value;\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n\n  clearQuery(): void {\n    this.selectedSuggestionIndex = -1;\n    this.value = '';\n    this.fngSearch.emit(this.value);\n    this.hideSuggestionList = true;\n    this.inputRef.nativeElement.blur();\n  }\n}\n","<div class=\"fwe-search-input fwe-w-100\" (clickOutside)=\"onClickOutside()\" fngClickOutside>\n  <input\n    class=\"fwe-w-100\"\n    #inputElement\n    [attr.disabled]=\"disabled ? '' : null\"\n    [placeholder]=\"label\"\n    (focus)=\"onFocus()\"\n    type=\"search\"\n    (input)=\"onInput($event)\"\n    (search)=\"onSearch($event)\"\n    [value]=\"innerValue\"\n  />\n  <div class=\"fwe-search-icon\"></div>\n  <div class=\"fwe-clear-icon\" (click)=\"clearQuery()\"></div>\n  <div class=\"fwe-search-suggestions\" *ngIf=\"innerSuggestions?.length && !hideSuggestionList\">\n    <div\n      *ngFor=\"let suggestion of cappedSuggestions; let i = index\"\n      (click)=\"onSuggestionClick(suggestion)\"\n      [class.fwe-selected]=\"selectedSuggestionIndex === i\"\n      class=\"fwe-search-suggestion\"\n    >\n      <div [innerHTML]=\"suggestion.template | safeHtml\"></div>\n    </div>\n    <div class=\"fwe-ml-xxs\" *ngIf=\"innerSuggestions.length > 10\">...</div>\n  </div>\n</div>\n"]}
|