@datarailsshared/datarailsshared 1.5.399 → 1.5.404
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/datarailsshared-datarailsshared-1.5.404.tgz +0 -0
- package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +7 -1
- package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +6 -2
- package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +19 -7
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +2 -2
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +8 -2
- package/esm2022/lib/models/dropdown.mjs +1 -1
- package/esm2022/lib/utils/data-analytics.service.mjs +21 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/datarailsshared-datarailsshared.mjs +53 -9
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-dropdown/dr-dropdown.component.d.ts +2 -0
- package/lib/dr-dropdown/dr-dropdown.directive.d.ts +2 -1
- package/lib/dr-inputs/checkbox/checkbox.component.d.ts +6 -2
- package/lib/dr-inputs/dr-select/dr-select.component.d.ts +2 -1
- package/lib/models/dropdown.d.ts +1 -0
- package/lib/utils/data-analytics.service.d.ts +8 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/datarailsshared-datarailsshared-1.5.399.tgz +0 -0
|
Binary file
|
|
@@ -12,6 +12,7 @@ import { DrPopoverRef } from '../models/popover';
|
|
|
12
12
|
import { first, merge, Subject, takeUntil } from 'rxjs';
|
|
13
13
|
import { DropdownInstanceService } from './dr-dropdown.service';
|
|
14
14
|
import { Debounce } from '../utils/decorators';
|
|
15
|
+
import { DataAnalyticsService } from '../utils/data-analytics.service';
|
|
15
16
|
import * as i0 from "@angular/core";
|
|
16
17
|
const _c0 = ["menuContainer"];
|
|
17
18
|
function DrDropdownComponent_dr_dropdown_item_4_ng_container_1_i_1_Template(rf, ctx) { if (rf & 1) {
|
|
@@ -94,6 +95,7 @@ export class DrDropdownComponent {
|
|
|
94
95
|
if (data) {
|
|
95
96
|
this.drDropdownInHover = data.drDropdownInHover;
|
|
96
97
|
this.containerClass = data.class;
|
|
98
|
+
this.dataAnalytics = data.dataAnalytics;
|
|
97
99
|
this.list = data.list || [];
|
|
98
100
|
this.list.forEach((item) => {
|
|
99
101
|
if (item.children?.length) {
|
|
@@ -116,6 +118,7 @@ export class DrDropdownComponent {
|
|
|
116
118
|
}
|
|
117
119
|
constructor() {
|
|
118
120
|
this.cdr = inject(ChangeDetectorRef);
|
|
121
|
+
this.dataAnalyticsService = inject(DataAnalyticsService);
|
|
119
122
|
this.popoverRef = inject(DrPopoverRef, { optional: true });
|
|
120
123
|
this.dropdownInstanceService = inject(DropdownInstanceService, { optional: true });
|
|
121
124
|
this.destroy$ = new Subject();
|
|
@@ -167,6 +170,9 @@ export class DrDropdownComponent {
|
|
|
167
170
|
return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;
|
|
168
171
|
}
|
|
169
172
|
action(act) {
|
|
173
|
+
if (this.dataAnalytics) {
|
|
174
|
+
this.dataAnalyticsService.track(`${this.dataAnalytics}_${act.title.toLowerCase().replace(/ /g, '_')}`);
|
|
175
|
+
}
|
|
170
176
|
if (!this.disabled(act)) {
|
|
171
177
|
if (act.action) {
|
|
172
178
|
act.action(act.data);
|
|
@@ -232,4 +238,4 @@ __decorate([
|
|
|
232
238
|
type: Output,
|
|
233
239
|
args: ['action']
|
|
234
240
|
}], onMouseleave: [] }); })();
|
|
235
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { IDropdown, IDropdownAction, IDropdownActionIcon, IDropdownItem } from '../models/dropdown';\nimport { DrPopoverRef } from '../models/popover';\nimport { first, merge, Subject, takeUntil } from 'rxjs';\nimport { DropdownInstanceRef, DropdownInstanceService } from './dr-dropdown.service';\nimport { Debounce } from '../utils/decorators';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent implements DropdownInstanceRef {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly popoverRef = inject(DrPopoverRef, { optional: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService, { optional: true });\n\n    private readonly destroy$ = new Subject<void>();\n\n    private _active = true;\n\n    @ViewChild('menuContainer', { static: true })\n    menuContainer: ElementRef<HTMLDivElement>;\n\n    drDropdownInHover: boolean;\n    private readonly drDropdownInHoverChange$ = new Subject<void>();\n    list: IDropdownItem<unknown>[] = [];\n    containerClass: string;\n    wasHovered = false;\n    asChild = false;\n\n    @Input()\n    set options(data: IDropdown<IDropdownItem<unknown>>) {\n        if (data) {\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        class: item?.childOptions?.class || '',\n                        position: item?.childOptions?.position || 'left-top',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n\n            if (this.drDropdownInHover) {\n                this.dropdownInstanceService\n                    .inactive(this)\n                    .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))\n                    .subscribe(() => {\n                        this.popoverRef.close();\n                    });\n            }\n        }\n    }\n\n    @Output('action')\n    onAction = new EventEmitter<IDropdownAction<unknown>>();\n\n    constructor() {\n        if (!this.dropdownInstanceService) return;\n\n        this.dropdownInstanceService.register(this);\n        inject(DestroyRef).onDestroy(() => {\n            this.dropdownInstanceService.unregister(this);\n            this.destroy$.next();\n            this.destroy$.next();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes?.drDropdownInHover?.isFirstChange()) {\n            this.drDropdownInHoverChange$.next();\n        }\n    }\n\n    disabled(act: IDropdownItem<unknown>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    action(act: IDropdownItem<unknown>) {\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                const event = { event: act.event || act.title || 'default', data: act.data };\n                this.onAction.emit(event);\n            }\n        }\n    }\n\n    onActionIconClick($event: MouseEvent, actionIcon: IDropdownActionIcon<unknown>, data: unknown) {\n        $event.stopPropagation();\n        actionIcon.action(data);\n    }\n\n    hasChildren(item: IDropdownItem<unknown>): boolean {\n        return !!item.children?.length;\n    }\n\n    onMouseenter(): void {\n        this.wasHovered = true;\n        this._active = true;\n    }\n\n    @Debounce(200)\n    onMouseleave(): void {\n        this._active = false;\n    }\n\n    active(): boolean {\n        return this._active;\n    }\n}\n","<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n        <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n        <dr-dropdown-item\n            *ngFor=\"let act of list | drDropdownItemShowPipe\"\n            (mousedown)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"'left'\"\n            [drTooltipOptions]=\"{ withoutArrow: true }\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            [drDropdown]=\"hasChildren(act) && act.children\"\n            [drDropdownClass]=\"act.childOptions?.class\"\n            [drDropdownInHover]=\"true\"\n            [drDropdownPosition]=\"act.childOptions?.position\"\n            drDropdownChild\n            [disabled]=\"disabled(act)\"\n            [selected]=\"selected(act)\"\n            [divider]=\"act.separateLine\"\n            role=\"option\"\n            tabindex=\"0\">\n            <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n                <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n                <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n            </ng-container>\n\n            <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n                <i\n                    *ngFor=\"let actionIcon of act.actionIcons\"\n                    [class]=\"actionIcon.icon\"\n                    [class.showOnHover]=\"actionIcon.showOnHover\"\n                    (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n                <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n            </ng-container>\n\n            <ng-container\n                *ngIf=\"act.templateRef\"\n                dropdownItemContent\n                [ngTemplateOutlet]=\"act.templateRef\"\n                [ngTemplateOutletContext]=\"{ $implicit: act }\">\n            </ng-container>\n        </dr-dropdown-item>\n    </div>\n</div>\n"]}
|
|
241
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.ts","../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DestroyRef,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { IDropdown, IDropdownAction, IDropdownActionIcon, IDropdownItem } from '../models/dropdown';\nimport { DrPopoverRef } from '../models/popover';\nimport { first, merge, Subject, takeUntil } from 'rxjs';\nimport { DropdownInstanceRef, DropdownInstanceService } from './dr-dropdown.service';\nimport { Debounce } from '../utils/decorators';\nimport { DataAnalyticsService } from '../utils/data-analytics.service';\n\n@Component({\n    selector: 'dr-dropdown',\n    templateUrl: './dr-dropdown.component.html',\n    styleUrls: ['./dr-dropdown.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrDropdownComponent implements DropdownInstanceRef {\n    private readonly cdr = inject(ChangeDetectorRef);\n    private readonly dataAnalyticsService = inject(DataAnalyticsService);\n    private readonly popoverRef = inject(DrPopoverRef, { optional: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService, { optional: true });\n\n    private readonly destroy$ = new Subject<void>();\n\n    private _active = true;\n\n    @ViewChild('menuContainer', { static: true })\n    menuContainer: ElementRef<HTMLDivElement>;\n\n    drDropdownInHover: boolean;\n    private readonly drDropdownInHoverChange$ = new Subject<void>();\n    list: IDropdownItem<unknown>[] = [];\n    containerClass: string;\n    wasHovered = false;\n    asChild = false;\n    dataAnalytics: string;\n\n    @Input()\n    set options(data: IDropdown<IDropdownItem<unknown>>) {\n        if (data) {\n            this.drDropdownInHover = data.drDropdownInHover;\n            this.containerClass = data.class;\n            this.dataAnalytics = data.dataAnalytics;\n            this.list = data.list || [];\n            this.list.forEach((item) => {\n                if (item.children?.length) {\n                    item.childOptions = {\n                        class: item?.childOptions?.class || '',\n                        position: item?.childOptions?.position || 'left-top',\n                    };\n                }\n            });\n            this.cdr.markForCheck();\n\n            if (this.drDropdownInHover) {\n                this.dropdownInstanceService\n                    .inactive(this)\n                    .pipe(first(), takeUntil(merge(this.destroy$, this.drDropdownInHoverChange$)))\n                    .subscribe(() => {\n                        this.popoverRef.close();\n                    });\n            }\n        }\n    }\n\n    @Output('action')\n    onAction = new EventEmitter<IDropdownAction<unknown>>();\n\n    constructor() {\n        if (!this.dropdownInstanceService) return;\n\n        this.dropdownInstanceService.register(this);\n        inject(DestroyRef).onDestroy(() => {\n            this.dropdownInstanceService.unregister(this);\n            this.destroy$.next();\n            this.destroy$.next();\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (!changes?.drDropdownInHover?.isFirstChange()) {\n            this.drDropdownInHoverChange$.next();\n        }\n    }\n\n    disabled(act: IDropdownItem<unknown>): boolean {\n        if (!act.disabled) {\n            return false;\n        }\n        if (typeof act.disabled === 'boolean') {\n            return act.disabled;\n        } else {\n            return act.disabled(act.data);\n        }\n    }\n\n    selected(act: IDropdownItem<unknown>): boolean {\n        if (!act.selected) {\n            return false;\n        }\n        if (typeof act.selected === 'boolean') {\n            return act.selected;\n        } else {\n            return act.selected(act.data);\n        }\n    }\n\n    tooltipToShow(act: IDropdownItem<unknown>): string {\n        if (act.toolTipIfDisabled && !this.disabled(act)) return '';\n        return act.customTooltip ? act.customTooltip(act.data) : act.toolTip;\n    }\n\n    action(act: IDropdownItem<unknown>) {\n        if (this.dataAnalytics) {\n            this.dataAnalyticsService.track(`${this.dataAnalytics}_${act.title.toLowerCase().replace(/ /g, '_')}`);\n        }\n        if (!this.disabled(act)) {\n            if (act.action) {\n                act.action(act.data);\n            } else {\n                const event = { event: act.event || act.title || 'default', data: act.data };\n                this.onAction.emit(event);\n            }\n        }\n    }\n\n    onActionIconClick($event: MouseEvent, actionIcon: IDropdownActionIcon<unknown>, data: unknown) {\n        $event.stopPropagation();\n        actionIcon.action(data);\n    }\n\n    hasChildren(item: IDropdownItem<unknown>): boolean {\n        return !!item.children?.length;\n    }\n\n    onMouseenter(): void {\n        this.wasHovered = true;\n        this._active = true;\n    }\n\n    @Debounce(200)\n    onMouseleave(): void {\n        this._active = false;\n    }\n\n    active(): boolean {\n        return this._active;\n    }\n}\n","<div #menuContainer [class]=\"containerClass\" class=\"dr-dropdown\">\n    <div class=\"dr-dropdown__container\" (mouseenter)=\"onMouseenter()\" (mouseleave)=\"onMouseleave()\" tabindex=\"-1\" role=\"listbox\">\n        <ng-content select=\"dr-dropdown-item\"></ng-content>\n\n        <dr-dropdown-item\n            *ngFor=\"let act of list | drDropdownItemShowPipe\"\n            (mousedown)=\"action(act)\"\n            [drTooltip]=\"tooltipToShow(act)\"\n            [drTooltipPosition]=\"'left'\"\n            [drTooltipOptions]=\"{ withoutArrow: true }\"\n            [drTooltipClass]=\"'dr-dropdown__tooltip'\"\n            [drDropdown]=\"hasChildren(act) && act.children\"\n            [drDropdownClass]=\"act.childOptions?.class\"\n            [drDropdownInHover]=\"true\"\n            [drDropdownPosition]=\"act.childOptions?.position\"\n            drDropdownChild\n            [disabled]=\"disabled(act)\"\n            [selected]=\"selected(act)\"\n            [divider]=\"act.separateLine\"\n            role=\"option\"\n            tabindex=\"0\">\n            <ng-container dropdownItemContent *ngIf=\"!act.templateRef\">\n                <i *ngIf=\"act.icon\" [class]=\"act.icon\"></i>\n                <span class=\"dr-dropdown__text\">{{ act.title }}</span>\n            </ng-container>\n\n            <ng-container dropdownItemActions *ngIf=\"!act.templateRef\">\n                <i\n                    *ngFor=\"let actionIcon of act.actionIcons\"\n                    [class]=\"actionIcon.icon\"\n                    [class.showOnHover]=\"actionIcon.showOnHover\"\n                    (mousedown)=\"onActionIconClick($event, actionIcon, act.data)\"></i>\n                <i *ngIf=\"hasChildren(act)\" class=\"dr-icon-arrow-right\"></i>\n            </ng-container>\n\n            <ng-container\n                *ngIf=\"act.templateRef\"\n                dropdownItemContent\n                [ngTemplateOutlet]=\"act.templateRef\"\n                [ngTemplateOutletContext]=\"{ $implicit: act }\">\n            </ng-container>\n        </dr-dropdown-item>\n    </div>\n</div>\n"]}
|
|
@@ -50,6 +50,7 @@ export class DrDropdownDirective {
|
|
|
50
50
|
position: this.drDropdownPosition,
|
|
51
51
|
list: this.drDropdown,
|
|
52
52
|
class: this.drDropdownClass,
|
|
53
|
+
dataAnalytics: this.dataAnalytics,
|
|
53
54
|
},
|
|
54
55
|
});
|
|
55
56
|
}
|
|
@@ -65,7 +66,7 @@ export class DrDropdownDirective {
|
|
|
65
66
|
/** @nocollapse */ static { this.ɵfac = function DrDropdownDirective_Factory(t) { return new (t || DrDropdownDirective)(); }; }
|
|
66
67
|
/** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrDropdownDirective, selectors: [["", "drDropdown", ""]], hostBindings: function DrDropdownDirective_HostBindings(rf, ctx) { if (rf & 1) {
|
|
67
68
|
i0.ɵɵlistener("mouseenter", function DrDropdownDirective_mouseenter_HostBindingHandler() { return ctx.elementHover(); })("click", function DrDropdownDirective_click_HostBindingHandler() { return ctx.elementClick(); })("mouseleave", function DrDropdownDirective_mouseleave_HostBindingHandler() { return ctx.leaveDropdownTriggerElement(); })("mouseup", function DrDropdownDirective_mouseup_HostBindingHandler() { return ctx.documentClick(); }, false, i0.ɵɵresolveDocument);
|
|
68
|
-
} }, inputs: { drDropdown: "drDropdown", drDropdownPosition: "drDropdownPosition", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover" }, outputs: { drDropdownAction: "drDropdownAction" }, features: [i0.ɵɵProvidersFeature([
|
|
69
|
+
} }, inputs: { drDropdown: "drDropdown", drDropdownPosition: "drDropdownPosition", drDropdownClass: "drDropdownClass", drDropdownInHover: "drDropdownInHover", dataAnalytics: ["data-analytics", "dataAnalytics"] }, outputs: { drDropdownAction: "drDropdownAction" }, features: [i0.ɵɵProvidersFeature([
|
|
69
70
|
{
|
|
70
71
|
provide: DropdownInstanceService,
|
|
71
72
|
useFactory: ((injector) => {
|
|
@@ -100,6 +101,9 @@ export class DrDropdownDirective {
|
|
|
100
101
|
type: Input
|
|
101
102
|
}], drDropdownInHover: [{
|
|
102
103
|
type: Input
|
|
104
|
+
}], dataAnalytics: [{
|
|
105
|
+
type: Input,
|
|
106
|
+
args: [{ alias: 'data-analytics' }]
|
|
103
107
|
}], drDropdownAction: [{
|
|
104
108
|
type: Output
|
|
105
109
|
}], elementHover: [{
|
|
@@ -125,4 +129,4 @@ export class DrDropdownChildDirective {
|
|
|
125
129
|
selector: '[drDropdownChild]',
|
|
126
130
|
}]
|
|
127
131
|
}], null, null); })();
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-dropdown/dr-dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, inject, Injector, Input, OnDestroy, Output } from '@angular/core';\nimport { ElPosition, IDropdownAction, IDropdownItem } from '../models/dropdown';\nimport { DrDropdownService, DropdownInstanceService } from './dr-dropdown.service';\nimport { DrDropdownComponent } from './dr-dropdown.component';\nimport { DrPopoverRef } from '../models/popover';\n\n@Directive({\n    selector: '[drDropdown]',\n    providers: [\n        {\n            provide: DropdownInstanceService,\n            useFactory: (injector: Injector) => {\n                const service = injector.get(DropdownInstanceService, null, { skipSelf: true });\n                return service ?? new DropdownInstanceService(injector);\n            },\n            deps: [Injector],\n        },\n    ],\n})\nexport class DrDropdownDirective<T> implements OnDestroy {\n    private readonly elementRef = inject(ElementRef<HTMLElement>);\n    private readonly service = inject(DrDropdownService);\n    private readonly child = inject(DrDropdownChildDirective, { optional: true, self: true });\n    private readonly dropdownInstanceService = inject(DropdownInstanceService);\n\n    @Input({ required: true })\n    drDropdown: IDropdownItem<T>[];\n    @Input()\n    drDropdownPosition: ElPosition = 'left-top';\n    @Input()\n    drDropdownClass: string;\n    @Input()\n    drDropdownInHover: boolean;\n    @Input({ alias: 'data-analytics' })\n    dataAnalytics: string;\n\n    @Output()\n    drDropdownAction = new EventEmitter<IDropdownAction<T>>();\n\n    private ref: DrPopoverRef<DrDropdownComponent>;\n\n    private readonly mouseleaveTimeout = 200;\n\n    @HostListener('mouseenter')\n    elementHover() {\n        if (!this.drDropdownInHover) return;\n        this.openDropdown();\n    }\n\n    @HostListener('click')\n    elementClick() {\n        this.openDropdown();\n    }\n\n    @HostListener('mouseleave')\n    leaveDropdownTriggerElement() {\n        if (this.drDropdownInHover) {\n            setTimeout(() => {\n                if (this.ref && !this.ref.instance.wasHovered) {\n                    this.close();\n                }\n            }, this.mouseleaveTimeout);\n        }\n    }\n\n    @HostListener('document:mouseup')\n    documentClick() {\n        this.close();\n    }\n\n    private openDropdown(): void {\n        if (!this.drDropdown?.length) {\n            return;\n        }\n\n        if (this.ref) {\n            this.close();\n            return;\n        }\n\n        this.ref = this.service.open({\n            hostRef: this.elementRef,\n            position: this.drDropdownPosition,\n            asChild: !!this.child,\n            providers: [{ provide: DropdownInstanceService, useValue: this.dropdownInstanceService }],\n            action$: this.drDropdownAction,\n            options: {\n                drDropdownInHover: this.drDropdownInHover,\n                position: this.drDropdownPosition,\n                list: this.drDropdown,\n                class: this.drDropdownClass,\n                dataAnalytics: this.dataAnalytics,\n            },\n        });\n    }\n\n    private close(): void {\n        if (this.ref) {\n            this.ref.close();\n            this.ref = null;\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.close();\n    }\n}\n\n@Directive({\n    selector: '[drDropdownChild]',\n})\nexport class DrDropdownChildDirective {}\n"]}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { DataAnalyticsService } from '../../utils/data-analytics.service';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../../
|
|
5
|
+
import * as i1 from "../../utils/data-analytics.service";
|
|
6
|
+
import * as i2 from "../../dr-tooltip/dr-tooltip.directive";
|
|
5
7
|
const _c0 = ["checkboxContent"];
|
|
6
8
|
const _c1 = ["*"];
|
|
7
9
|
export class CheckboxComponent {
|
|
@@ -12,8 +14,9 @@ export class CheckboxComponent {
|
|
|
12
14
|
this._indeterminate = !!value;
|
|
13
15
|
this.cdr.markForCheck();
|
|
14
16
|
}
|
|
15
|
-
constructor(cdr) {
|
|
17
|
+
constructor(cdr, dataAnalyticsService) {
|
|
16
18
|
this.cdr = cdr;
|
|
19
|
+
this.dataAnalyticsService = dataAnalyticsService;
|
|
17
20
|
this.disabled = false;
|
|
18
21
|
this.icon = '';
|
|
19
22
|
this._indeterminate = false;
|
|
@@ -47,8 +50,11 @@ export class CheckboxComponent {
|
|
|
47
50
|
this.onChange(this.checkedStatus);
|
|
48
51
|
this.indeterminate = input.indeterminate;
|
|
49
52
|
this.onTouched();
|
|
53
|
+
if (this.dataAnalytics) {
|
|
54
|
+
this.dataAnalyticsService.track(this.dataAnalytics, { state: this.checkedStatus, ...this.dataAnalyticsDetails });
|
|
55
|
+
}
|
|
50
56
|
}
|
|
51
|
-
/** @nocollapse */ static { this.ɵfac = function CheckboxComponent_Factory(t) { return new (t || CheckboxComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
|
|
57
|
+
/** @nocollapse */ static { this.ɵfac = function CheckboxComponent_Factory(t) { return new (t || CheckboxComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.DataAnalyticsService)); }; }
|
|
52
58
|
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CheckboxComponent, selectors: [["dr-checkbox"]], viewQuery: function CheckboxComponent_Query(rf, ctx) { if (rf & 1) {
|
|
53
59
|
i0.ɵɵviewQuery(_c0, 5);
|
|
54
60
|
} if (rf & 2) {
|
|
@@ -56,7 +62,7 @@ export class CheckboxComponent {
|
|
|
56
62
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.checkboxContent = _t.first);
|
|
57
63
|
} }, hostVars: 4, hostBindings: function CheckboxComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
58
64
|
i0.ɵɵclassProp("disabled", ctx.disabled)("text-nowrap", ctx.textNowrap);
|
|
59
|
-
} }, inputs: { checkedStatus: "checkedStatus", disabled: "disabled", icon: "icon", indeterminate: "indeterminate", textNowrap: "textNowrap" }, outputs: { checkedChange: "checkedChange" }, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: CheckboxComponent, multi: true }])], ngContentSelectors: _c1, decls: 5, vars: 8, consts: [["type", "checkbox", 3, "checked", "disabled", "change", "click"], [3, "drTooltip"], ["checkboxContent", ""]], template: function CheckboxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
65
|
+
} }, inputs: { checkedStatus: "checkedStatus", disabled: "disabled", icon: "icon", indeterminate: "indeterminate", textNowrap: "textNowrap", dataAnalytics: ["data-analytics", "dataAnalytics"], dataAnalyticsDetails: ["data-analytics-details", "dataAnalyticsDetails"] }, outputs: { checkedChange: "checkedChange" }, features: [i0.ɵɵProvidersFeature([{ provide: NG_VALUE_ACCESSOR, useExisting: CheckboxComponent, multi: true }])], ngContentSelectors: _c1, decls: 5, vars: 8, consts: [["type", "checkbox", 3, "checked", "disabled", "change", "click"], [3, "drTooltip"], ["checkboxContent", ""]], template: function CheckboxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
60
66
|
i0.ɵɵprojectionDef();
|
|
61
67
|
i0.ɵɵelementStart(0, "label")(1, "input", 0);
|
|
62
68
|
i0.ɵɵlistener("change", function CheckboxComponent_Template_input_change_1_listener($event) { return ctx.setValue($event); })("click", function CheckboxComponent_Template_input_click_1_listener($event) { return $event.stopPropagation(); });
|
|
@@ -72,12 +78,12 @@ export class CheckboxComponent {
|
|
|
72
78
|
i0.ɵɵclassMap(ctx.icon);
|
|
73
79
|
i0.ɵɵclassProp("indeterminate", ctx.indeterminate);
|
|
74
80
|
i0.ɵɵproperty("drTooltip", ctx.tooltip);
|
|
75
|
-
} }, dependencies: [
|
|
81
|
+
} }, dependencies: [i2.DrTooltipDirective], styles: ["input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]{vertical-align:middle;line-height:30px}input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%], input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]:before{box-sizing:content-box!important;-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important}input[_ngcontent-%COMP%]{visibility:hidden;position:absolute;width:0}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]{position:relative;z-index:19;display:inline-block;margin:0 5px 0 0;line-height:17px;min-height:14px;min-width:14px}.text-nowrap[_nghost-%COMP%] label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]{white-space:nowrap;overflow:hidden;max-width:100%;text-overflow:ellipsis;line-height:20px}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]:hover{cursor:pointer}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]:before{content:\"\";font-size:14px;border-radius:0;display:inline-block;text-align:center;vertical-align:middle;padding:1px;min-height:12px;line-height:12px;min-width:12px;margin-right:5px;border:1.5px solid #8f929e;background-color:#fff;font-weight:400;margin-top:-1px}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]:before, label[_ngcontent-%COMP%]:hover input[_ngcontent-%COMP%] + span[_ngcontent-%COMP%]:before{background-color:#fff;border-color:#8f929e;color:#4646ce;border-radius:2px}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:checked + span[_ngcontent-%COMP%]:before, label[_ngcontent-%COMP%]:hover input[_ngcontent-%COMP%]:checked + span[_ngcontent-%COMP%]:before{content:url('data:image/svg+xml; utf8, <svg width=\"12\" height=\"10\" viewBox=\"0 0 12 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"> <path d=\"M1 5L4.5 8.5L11 1.5\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/> </svg>');background:#4646ce;border-color:#4646ce;color:#fff}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:checked + span.cross[_ngcontent-%COMP%]:before, label[_ngcontent-%COMP%]:hover input[_ngcontent-%COMP%]:checked + span.cross[_ngcontent-%COMP%]:before{content:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.91786 4.99992L9.03356 1.88386C9.11927 1.79808 9.16654 1.68365 9.16668 1.56162C9.16668 1.43952 9.1194 1.32495 9.03356 1.23931L8.7605 0.966323C8.67466 0.880342 8.56026 0.833252 8.43811 0.833252C8.31615 0.833252 8.20169 0.880342 8.11585 0.966323L5.00016 4.08218L1.88431 0.966323C1.79861 0.880342 1.68407 0.833252 1.56199 0.833252C1.44004 0.833252 1.32559 0.880342 1.23988 0.966323L0.966677 1.23931C0.788899 1.4171 0.788899 1.70628 0.966677 1.88386L4.08245 4.99992L0.966677 8.11584C0.880904 8.20175 0.833707 8.31619 0.833707 8.43822C0.833707 8.56025 0.880904 8.67468 0.966677 8.76053L1.23981 9.03351C1.32551 9.11943 1.44003 9.16658 1.56191 9.16658C1.684 9.16658 1.79853 9.11943 1.88424 9.03351L5.00008 5.91759L8.11578 9.03351C8.20162 9.11943 8.31608 9.16658 8.43803 9.16658C8.56005 9.16658 8.67459 9.11943 8.76043 9.03351L9.03349 8.76053C9.11919 8.67475 9.16646 8.56025 9.16646 8.43822C9.16646 8.31619 9.11919 8.20175 9.03349 8.11591L5.91786 4.99992Z\" fill=\"white\"/></svg>')}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%] + span.indeterminate[_ngcontent-%COMP%]:before, label[_ngcontent-%COMP%]:hover input[_ngcontent-%COMP%] + span.indeterminate[_ngcontent-%COMP%]:before{content:url('data:image/svg+xml; utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"10\" viewBox=\"0 0 10 2\" fill=\"none\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M0.25 1C0.25 0.585786 0.585786 0.25 1 0.25L11 0.250001C11.4142 0.250001 11.75 0.585787 11.75 1C11.75 1.41421 11.4142 1.75 11 1.75L1 1.75C0.585786 1.75 0.25 1.41421 0.25 1Z\" fill=\"white\"/></svg>');background:#4646ce;border-color:#4646ce;color:#fff}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:disabled + span[_ngcontent-%COMP%]{color:#8f929e}label[_ngcontent-%COMP%] input[_ngcontent-%COMP%]:disabled + span[_ngcontent-%COMP%]:before{border-color:#dfe0e3;pointer-events:none}label[_ngcontent-%COMP%] input[disabled][_ngcontent-%COMP%]:checked + span[_ngcontent-%COMP%]:before{background:#8f929e;border-color:#8f929e;pointer-events:none}[_nghost-%COMP%]{font-family:Poppins,sans-serif;font-style:normal}[_nghost-%COMP%] label[_ngcontent-%COMP%]{position:relative}[_nghost-%COMP%] label[_ngcontent-%COMP%]:hover:after{content:\"\";width:24px;height:24px;background:#f2f2fb;border-radius:50%;position:absolute;left:-4px;top:.5px}.disabled[_nghost-%COMP%] label[_ngcontent-%COMP%]:hover:after{display:none}"], changeDetection: 0 }); }
|
|
76
82
|
}
|
|
77
83
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CheckboxComponent, [{
|
|
78
84
|
type: Component,
|
|
79
85
|
args: [{ selector: 'dr-checkbox', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: CheckboxComponent, multi: true }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<label>\n <input\n type=\"checkbox\"\n [attr.data-test]=\"checkedStatus ? 'checked' : 'unchecked'\"\n [checked]=\"checkedStatus\"\n [disabled]=\"disabled\"\n (change)=\"setValue($event)\"\n (click)=\"$event.stopPropagation()\" />\n <span #checkboxContent [class]=\"icon\" [class.indeterminate]=\"indeterminate\" [drTooltip]=\"tooltip\">\n <ng-content></ng-content>\n </span>\n</label>\n", styles: ["input+span{vertical-align:middle;line-height:30px}input+span,input+span:before{box-sizing:content-box!important;-webkit-box-sizing:content-box!important;-moz-box-sizing:content-box!important}input{visibility:hidden;position:absolute;width:0}label input+span{position:relative;z-index:19;display:inline-block;margin:0 5px 0 0;line-height:17px;min-height:14px;min-width:14px}:host.text-nowrap label input+span{white-space:nowrap;overflow:hidden;max-width:100%;text-overflow:ellipsis;line-height:20px}label input+span:hover{cursor:pointer}label input+span:before{content:\"\";font-size:14px;border-radius:0;display:inline-block;text-align:center;vertical-align:middle;padding:1px;min-height:12px;line-height:12px;min-width:12px;margin-right:5px;border:1.5px solid #8f929e;background-color:#fff;font-weight:400;margin-top:-1px}label input+span:before,label:hover input+span:before{background-color:#fff;border-color:#8f929e;color:#4646ce;border-radius:2px}label input:checked+span:before,label:hover input:checked+span:before{content:url('data:image/svg+xml; utf8, <svg width=\"12\" height=\"10\" viewBox=\"0 0 12 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"> <path d=\"M1 5L4.5 8.5L11 1.5\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/> </svg>');background:#4646ce;border-color:#4646ce;color:#fff}label input:checked+span.cross:before,label:hover input:checked+span.cross:before{content:url('data:image/svg+xml; utf8, <svg width=\"10\" height=\"10\" viewBox=\"0 0 10 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.91786 4.99992L9.03356 1.88386C9.11927 1.79808 9.16654 1.68365 9.16668 1.56162C9.16668 1.43952 9.1194 1.32495 9.03356 1.23931L8.7605 0.966323C8.67466 0.880342 8.56026 0.833252 8.43811 0.833252C8.31615 0.833252 8.20169 0.880342 8.11585 0.966323L5.00016 4.08218L1.88431 0.966323C1.79861 0.880342 1.68407 0.833252 1.56199 0.833252C1.44004 0.833252 1.32559 0.880342 1.23988 0.966323L0.966677 1.23931C0.788899 1.4171 0.788899 1.70628 0.966677 1.88386L4.08245 4.99992L0.966677 8.11584C0.880904 8.20175 0.833707 8.31619 0.833707 8.43822C0.833707 8.56025 0.880904 8.67468 0.966677 8.76053L1.23981 9.03351C1.32551 9.11943 1.44003 9.16658 1.56191 9.16658C1.684 9.16658 1.79853 9.11943 1.88424 9.03351L5.00008 5.91759L8.11578 9.03351C8.20162 9.11943 8.31608 9.16658 8.43803 9.16658C8.56005 9.16658 8.67459 9.11943 8.76043 9.03351L9.03349 8.76053C9.11919 8.67475 9.16646 8.56025 9.16646 8.43822C9.16646 8.31619 9.11919 8.20175 9.03349 8.11591L5.91786 4.99992Z\" fill=\"white\"/></svg>')}label input+span.indeterminate:before,label:hover input+span.indeterminate:before{content:url('data:image/svg+xml; utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"10\" viewBox=\"0 0 10 2\" fill=\"none\"><path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M0.25 1C0.25 0.585786 0.585786 0.25 1 0.25L11 0.250001C11.4142 0.250001 11.75 0.585787 11.75 1C11.75 1.41421 11.4142 1.75 11 1.75L1 1.75C0.585786 1.75 0.25 1.41421 0.25 1Z\" fill=\"white\"/></svg>');background:#4646ce;border-color:#4646ce;color:#fff}label input:disabled+span{color:#8f929e}label input:disabled+span:before{border-color:#dfe0e3;pointer-events:none}label input[disabled]:checked+span:before{background:#8f929e;border-color:#8f929e;pointer-events:none}:host{font-family:Poppins,sans-serif;font-style:normal}:host label{position:relative}:host label:hover:after{content:\"\";width:24px;height:24px;background:#f2f2fb;border-radius:50%;position:absolute;left:-4px;top:.5px}:host.disabled label:hover:after{display:none}\n"] }]
|
|
80
|
-
}], function () { return [{ type: i0.ChangeDetectorRef }]; }, { checkedStatus: [{
|
|
86
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DataAnalyticsService }]; }, { checkedStatus: [{
|
|
81
87
|
type: Input
|
|
82
88
|
}], disabled: [{
|
|
83
89
|
type: Input
|
|
@@ -93,10 +99,16 @@ export class CheckboxComponent {
|
|
|
93
99
|
}, {
|
|
94
100
|
type: HostBinding,
|
|
95
101
|
args: ['class.text-nowrap']
|
|
102
|
+
}], dataAnalytics: [{
|
|
103
|
+
type: Input,
|
|
104
|
+
args: [{ alias: 'data-analytics' }]
|
|
105
|
+
}], dataAnalyticsDetails: [{
|
|
106
|
+
type: Input,
|
|
107
|
+
args: [{ alias: 'data-analytics-details' }]
|
|
96
108
|
}], checkedChange: [{
|
|
97
109
|
type: Output
|
|
98
110
|
}], checkboxContent: [{
|
|
99
111
|
type: ViewChild,
|
|
100
112
|
args: ['checkboxContent']
|
|
101
113
|
}] }); })();
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/checkbox/checkbox.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DataAnalyticsService } from '../../utils/data-analytics.service';\n\n@Component({\n    selector: 'dr-checkbox',\n    templateUrl: './checkbox.component.html',\n    styleUrls: ['./checkbox.component.scss'],\n    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: CheckboxComponent, multi: true }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CheckboxComponent implements ControlValueAccessor, AfterViewInit {\n    public tooltip: string;\n    @Input() checkedStatus: boolean;\n    @Input()\n    @HostBinding('class.disabled')\n    disabled = false;\n    @Input() icon: 'cross' | '' = '';\n\n    @Input()\n    get indeterminate(): boolean {\n        return this._indeterminate;\n    }\n\n    @Input()\n    @HostBinding('class.text-nowrap')\n    textNowrap: boolean;\n\n    @Input({ alias: 'data-analytics' })\n    dataAnalytics: string;\n    @Input({ alias: 'data-analytics-details' })\n    dataAnalyticsDetails: any;\n\n    set indeterminate(value: boolean) {\n        this._indeterminate = !!value;\n        this.cdr.markForCheck();\n    }\n\n    private _indeterminate = false;\n    @Output() checkedChange = new EventEmitter();\n    @ViewChild('checkboxContent') checkboxContent: ElementRef;\n\n    onChange: (value: boolean) => void = () => {};\n    onTouched: () => void = () => {};\n\n    constructor(\n        private cdr: ChangeDetectorRef,\n        private dataAnalyticsService: DataAnalyticsService,\n    ) {}\n\n    ngAfterViewInit() {\n        const element = this.checkboxContent.nativeElement;\n        if (this.textNowrap && element.scrollWidth > element.clientWidth) {\n            this.tooltip = element.innerText;\n        }\n    }\n\n    writeValue(value: boolean) {\n        this.checkedStatus = value;\n        this.cdr.markForCheck();\n    }\n\n    registerOnChange(fn: any) {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any) {\n        this.onTouched = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    setValue(event) {\n        const input = event.target as HTMLInputElement;\n        this.checkedStatus = input.checked;\n        this.checkedChange.emit(this.checkedStatus);\n        this.onChange(this.checkedStatus);\n        this.indeterminate = input.indeterminate;\n        this.onTouched();\n        if (this.dataAnalytics) {\n            this.dataAnalyticsService.track(this.dataAnalytics, { state: this.checkedStatus, ...this.dataAnalyticsDetails });\n        }\n    }\n}\n","<label>\n    <input\n        type=\"checkbox\"\n        [attr.data-test]=\"checkedStatus ? 'checked' : 'unchecked'\"\n        [checked]=\"checkedStatus\"\n        [disabled]=\"disabled\"\n        (change)=\"setValue($event)\"\n        (click)=\"$event.stopPropagation()\" />\n    <span #checkboxContent [class]=\"icon\" [class.indeterminate]=\"indeterminate\" [drTooltip]=\"tooltip\">\n        <ng-content></ng-content>\n    </span>\n</label>\n"]}
|
|
@@ -221,7 +221,7 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
221
221
|
i0.ɵɵproperty("ngIf", !ctx.disabled);
|
|
222
222
|
i0.ɵɵadvance(1);
|
|
223
223
|
i0.ɵɵproperty("calendarHeaderComponent", ctx.customHeader)("panelClass", ctx.datePickerService.isUsingDateTagPresets ? "date-picker-preset-tag" : "dr-timeframe-datepicker");
|
|
224
|
-
} }, dependencies: [i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgModel, i4.NgIf, i4.NgTemplateOutlet, i5.MatDatepicker, i5.MatDatepickerInput, i6.DrTooltipDirective, i7.DrButtonComponent, i4.AsyncPipe], styles: ["[_nghost-%COMP%]{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}[_nghost-%COMP%]:hover{border-color:#9ea1aa}.active[_nghost-%COMP%], [_nghost-%COMP%]:focus-within{border-color:#4646ce!important;color:#333}.disabled[_nghost-%COMP%]{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}.disabled[_nghost-%COMP%]:after{color:#aeabac}.ng-valid.ng-dirty[_nghost-%COMP%]{border-color:#037c5a}.ng-invalid.ng-dirty[_nghost-%COMP%]:not(:focus-within){border-color:#bf1d30!important}.ng-untouched.ng-valid[_nghost-%COMP%]{border-color:#9ea1aa}[_nghost-%COMP%]:after, [_nghost-%COMP%]:before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}[_nghost-%COMP%]:after{font-family:DataRails!important;content:\"\\ea15\";font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}[_nghost-%COMP%] i[_ngcontent-%COMP%]{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}[_nghost-%COMP%] input[_ngcontent-%COMP%]{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}[_nghost-%COMP%] input.when-quarter[_ngcontent-%COMP%]{position:absolute;visibility:hidden}[_nghost-%COMP%] input[_ngcontent-%COMP%]:disabled{border:none;color:#aeabac;background:transparent}[_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-decoration, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-cancel-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-decoration{-webkit-appearance:none}[_nghost-%COMP%] input[_ngcontent-%COMP%]::placeholder{color:#6d6e6f;font-size:14px;line-height:18px} .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important} .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit} .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit} .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical), .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff} .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600} .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600} .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none} .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5} .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333} .mat-datepicker-popup .mat-calendar-table-header-divider{display:none} .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0} .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none}[_nghost-%COMP%]{border:none;display:flex;align-items:center}.disabled[_nghost-%COMP%]{background:transparent;color:#aeabac}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%]{border:none;padding:0 8px}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container__formatted-value-display[_ngcontent-%COMP%]{text-decoration:none;color:#aeabac;font-weight:400}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container[_ngcontent-%COMP%] i[_ngcontent-%COMP%]{color:#aeabac}.dr-date-picker-on-dashboard[_nghost-%COMP%]{width
|
|
224
|
+
} }, dependencies: [i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgModel, i4.NgIf, i4.NgTemplateOutlet, i5.MatDatepicker, i5.MatDatepickerInput, i6.DrTooltipDirective, i7.DrButtonComponent, i4.AsyncPipe], styles: ["[_nghost-%COMP%]{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}[_nghost-%COMP%]:hover{border-color:#9ea1aa}.active[_nghost-%COMP%], [_nghost-%COMP%]:focus-within{border-color:#4646ce!important;color:#333}.disabled[_nghost-%COMP%]{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}.disabled[_nghost-%COMP%]:after{color:#aeabac}.ng-valid.ng-dirty[_nghost-%COMP%]{border-color:#037c5a}.ng-invalid.ng-dirty[_nghost-%COMP%]:not(:focus-within){border-color:#bf1d30!important}.ng-untouched.ng-valid[_nghost-%COMP%]{border-color:#9ea1aa}[_nghost-%COMP%]:after, [_nghost-%COMP%]:before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}[_nghost-%COMP%]:after{font-family:DataRails!important;content:\"\\ea15\";font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}[_nghost-%COMP%] i[_ngcontent-%COMP%]{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}[_nghost-%COMP%] input[_ngcontent-%COMP%]{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}[_nghost-%COMP%] input.when-quarter[_ngcontent-%COMP%]{position:absolute;visibility:hidden}[_nghost-%COMP%] input[_ngcontent-%COMP%]:disabled{border:none;color:#aeabac;background:transparent}[_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-decoration, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-cancel-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-decoration{-webkit-appearance:none}[_nghost-%COMP%] input[_ngcontent-%COMP%]::placeholder{color:#6d6e6f;font-size:14px;line-height:18px} .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important} .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit} .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit} .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical), .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff} .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600} .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600} .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none} .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5} .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333} .mat-datepicker-popup .mat-calendar-table-header-divider{display:none} .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0} .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none}[_nghost-%COMP%]{border:none;display:flex;align-items:center}.disabled[_nghost-%COMP%]{background:transparent;color:#aeabac}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%]{border:none;padding:0 8px}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container__formatted-value-display[_ngcontent-%COMP%]{text-decoration:none;color:#aeabac;font-weight:400}.disabled.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container[_ngcontent-%COMP%] i[_ngcontent-%COMP%]{color:#aeabac}.dr-date-picker-on-dashboard[_nghost-%COMP%]{width:fit-content;justify-content:space-between}.dr-date-picker-on-dashboard[_nghost-%COMP%] mat-datepicker[_ngcontent-%COMP%]{position:absolute}.dr-date-picker-on-dashboard[_nghost-%COMP%]:after{visibility:hidden}.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:center;align-items:center;margin-left:-10px}.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container__formatted-value-display[_ngcontent-%COMP%]{font-weight:600;width:auto;margin-left:5px}.dr-date-picker-on-dashboard[_nghost-%COMP%] .dr-datepicker-input-container[_ngcontent-%COMP%] .dr-icon-date[_ngcontent-%COMP%]{display:block;position:relative;top:0;margin-right:8px;color:#4e566c}[_nghost-%COMP%] .dr-datepicker-input-container[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{visibility:hidden;position:absolute;width:100%}[_nghost-%COMP%] .dr-datepicker-input-container__formatted-value-display[_ngcontent-%COMP%]{width:90px;height:22px;padding-left:0;text-align:center;line-height:22px;color:#0c142b;text-decoration-line:underline}[_nghost-%COMP%] .dr-datepicker-input-container__formatted-value-display[_ngcontent-%COMP%]:hover{background-color:#f2f2fb;border-radius:5px;cursor:pointer;text-decoration-line:underline;color:#4646ce} .date-picker-preset-tag{width:386px!important} .date-picker-preset-tag .mat-calendar-content{padding-left:32px!important;padding-right:32px!important}"], changeDetection: 0 }); }
|
|
225
225
|
}
|
|
226
226
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrDatePickerWithTimeframeComponent, [{
|
|
227
227
|
type: Component,
|
|
@@ -229,7 +229,7 @@ export class DrDatePickerWithTimeframeComponent extends DrDatePickerComponent {
|
|
|
229
229
|
{ provide: NG_VALUE_ACCESSOR, useExisting: DrDatePickerWithTimeframeComponent, multi: true },
|
|
230
230
|
{ provide: DateAdapter, useClass: CustomDateAdapter },
|
|
231
231
|
{ provide: DrDatePickerService },
|
|
232
|
-
], template: "<dr-button\n [disabled]=\"isPrevDateDisabled\"\n *ngIf=\"!disabled\"\n theme=\"icon\"\n icon=\"dr-icon-arrow-left\"\n (click)=\"pagingClicked(false)\"></dr-button>\n<div\n [drTooltip]=\"datepickerTooltip\"\n [drTooltipPosition]=\"datepickerTooltipPosition\"\n [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n class=\"dr-datepicker-input-container\">\n <i *ngIf=\"isDashboardDatepicker\" class=\"dr-icon-date\"></i>\n\n <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n <ng-container\n [ngTemplateOutlet]=\"formattedValueTmpl\"\n [ngTemplateOutletContext]=\"{\n formattedValue: displayedFormattedValue$ | async\n }\">\n </ng-container>\n <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n <span>\n {{\n datePickerService.isUsingDateTagPresets && !!presetTagSelected\n ? presetTagSelected + ' (' + value + ')'\n : value\n }}\n </span>\n </ng-template>\n </div>\n <input\n #datepickerInput\n [ngModel]=\"displayValue$ | async\"\n (ngModelChange)=\"valueChangedInCalendar($event)\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\" />\n</div>\n<dr-button\n [disabled]=\"isNextDateDisabled\"\n *ngIf=\"!disabled\"\n theme=\"icon\"\n icon=\"dr-icon-arrow-right\"\n (click)=\"pagingClicked(true)\"></dr-button>\n<mat-datepicker\n #datePicker\n class=\"dr-timeframe-datepicker\"\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\"\n (opened)=\"onOpen()\"\n (closed)=\"onCLose()\"\n [panelClass]=\"datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker'\">\n</mat-datepicker>\n", styles: [":host{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}:host:hover{border-color:#9ea1aa}:host.active,:host:focus-within{border-color:#4646ce!important;color:#333}:host.disabled{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}:host.disabled:after{color:#aeabac}:host.ng-valid.ng-dirty{border-color:#037c5a}:host.ng-invalid.ng-dirty:not(:focus-within){border-color:#bf1d30!important}:host.ng-untouched.ng-valid{border-color:#9ea1aa}:host:after,:host:before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}:host:after{font-family:DataRails!important;content:\"\\ea15\";font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}:host i{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}:host input{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}:host input.when-quarter{position:absolute;visibility:hidden}:host input:disabled{border:none;color:#aeabac;background:transparent}:host input::-webkit-search-decoration,:host input::-webkit-search-cancel-button,:host input::-webkit-search-results-button,:host input::-webkit-search-results-decoration{-webkit-appearance:none}:host input::placeholder{color:#6d6e6f;font-size:14px;line-height:18px}::ng-deep .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit}::ng-deep .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical),::ng-deep .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff}::ng-deep .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none}::ng-deep .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333}::ng-deep .mat-datepicker-popup .mat-calendar-table-header-divider{display:none}::ng-deep .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0}::ng-deep .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none}:host{border:none;display:flex;align-items:center}:host.disabled{background:transparent;color:#aeabac}:host.disabled.dr-date-picker-on-dashboard{border:none;padding:0 8px}:host.disabled.dr-date-picker-on-dashboard .dr-datepicker-input-container__formatted-value-display{text-decoration:none;color:#aeabac;font-weight:400}:host.disabled.dr-date-picker-on-dashboard .dr-datepicker-input-container i{color:#aeabac}:host.dr-date-picker-on-dashboard{width
|
|
232
|
+
], template: "<dr-button\n [disabled]=\"isPrevDateDisabled\"\n *ngIf=\"!disabled\"\n theme=\"icon\"\n icon=\"dr-icon-arrow-left\"\n (click)=\"pagingClicked(false)\"></dr-button>\n<div\n [drTooltip]=\"datepickerTooltip\"\n [drTooltipPosition]=\"datepickerTooltipPosition\"\n [drTooltipMousleaveTimeout]=\"datepickerTooltipTimeout\"\n class=\"dr-datepicker-input-container\">\n <i *ngIf=\"isDashboardDatepicker\" class=\"dr-icon-date\"></i>\n\n <div class=\"dr-datepicker-input-container__formatted-value-display\" (click)=\"datepickerInput.click()\">\n <ng-container\n [ngTemplateOutlet]=\"formattedValueTmpl\"\n [ngTemplateOutletContext]=\"{\n formattedValue: displayedFormattedValue$ | async\n }\">\n </ng-container>\n <ng-template #formattedValueTmpl let-value=\"formattedValue\">\n <span>\n {{\n datePickerService.isUsingDateTagPresets && !!presetTagSelected\n ? presetTagSelected + ' (' + value + ')'\n : value\n }}\n </span>\n </ng-template>\n </div>\n <input\n #datepickerInput\n [ngModel]=\"displayValue$ | async\"\n (ngModelChange)=\"valueChangedInCalendar($event)\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\" />\n</div>\n<dr-button\n [disabled]=\"isNextDateDisabled\"\n *ngIf=\"!disabled\"\n theme=\"icon\"\n icon=\"dr-icon-arrow-right\"\n (click)=\"pagingClicked(true)\"></dr-button>\n<mat-datepicker\n #datePicker\n class=\"dr-timeframe-datepicker\"\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH)\"\n (opened)=\"onOpen()\"\n (closed)=\"onCLose()\"\n [panelClass]=\"datePickerService.isUsingDateTagPresets ? 'date-picker-preset-tag' : 'dr-timeframe-datepicker'\">\n</mat-datepicker>\n", styles: [":host{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}:host:hover{border-color:#9ea1aa}:host.active,:host:focus-within{border-color:#4646ce!important;color:#333}:host.disabled{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}:host.disabled:after{color:#aeabac}:host.ng-valid.ng-dirty{border-color:#037c5a}:host.ng-invalid.ng-dirty:not(:focus-within){border-color:#bf1d30!important}:host.ng-untouched.ng-valid{border-color:#9ea1aa}:host:after,:host:before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}:host:after{font-family:DataRails!important;content:\"\\ea15\";font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}:host i{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}:host input{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}:host input.when-quarter{position:absolute;visibility:hidden}:host input:disabled{border:none;color:#aeabac;background:transparent}:host input::-webkit-search-decoration,:host input::-webkit-search-cancel-button,:host input::-webkit-search-results-button,:host input::-webkit-search-results-decoration{-webkit-appearance:none}:host input::placeholder{color:#6d6e6f;font-size:14px;line-height:18px}::ng-deep .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit}::ng-deep .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical),::ng-deep .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff}::ng-deep .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none}::ng-deep .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333}::ng-deep .mat-datepicker-popup .mat-calendar-table-header-divider{display:none}::ng-deep .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0}::ng-deep .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none}:host{border:none;display:flex;align-items:center}:host.disabled{background:transparent;color:#aeabac}:host.disabled.dr-date-picker-on-dashboard{border:none;padding:0 8px}:host.disabled.dr-date-picker-on-dashboard .dr-datepicker-input-container__formatted-value-display{text-decoration:none;color:#aeabac;font-weight:400}:host.disabled.dr-date-picker-on-dashboard .dr-datepicker-input-container i{color:#aeabac}:host.dr-date-picker-on-dashboard{width:fit-content;justify-content:space-between}:host.dr-date-picker-on-dashboard mat-datepicker{position:absolute}:host.dr-date-picker-on-dashboard:after{visibility:hidden}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container{display:flex;flex-direction:row;justify-content:center;align-items:center;margin-left:-10px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container__formatted-value-display{font-weight:600;width:auto;margin-left:5px}:host.dr-date-picker-on-dashboard .dr-datepicker-input-container .dr-icon-date{display:block;position:relative;top:0;margin-right:8px;color:#4e566c}:host .dr-datepicker-input-container input{visibility:hidden;position:absolute;width:100%}:host .dr-datepicker-input-container__formatted-value-display{width:90px;height:22px;padding-left:0;text-align:center;line-height:22px;color:#0c142b;text-decoration-line:underline}:host .dr-datepicker-input-container__formatted-value-display:hover{background-color:#f2f2fb;border-radius:5px;cursor:pointer;text-decoration-line:underline;color:#4646ce}::ng-deep .date-picker-preset-tag{width:386px!important}::ng-deep .date-picker-preset-tag .mat-calendar-content{padding-left:32px!important;padding-right:32px!important}\n"] }]
|
|
233
233
|
}], function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DateAdapter }, { type: i2.DrDatePickerService }]; }, { isDashboardClassDisplayed: [{
|
|
234
234
|
type: HostBinding,
|
|
235
235
|
args: ['class.dr-date-picker-on-dashboard']
|
|
@@ -103,6 +103,7 @@ export class DrSelectComponent {
|
|
|
103
103
|
constructor(elementRef) {
|
|
104
104
|
this.elementRef = elementRef;
|
|
105
105
|
this.type = 'select';
|
|
106
|
+
this.clearInputTextAfterSelection = false;
|
|
106
107
|
this.items = [];
|
|
107
108
|
this.appendTo = 'body';
|
|
108
109
|
this.loadingText = 'Loading...';
|
|
@@ -154,6 +155,9 @@ export class DrSelectComponent {
|
|
|
154
155
|
}
|
|
155
156
|
}
|
|
156
157
|
onValueSelected(selectedItem) {
|
|
158
|
+
if (this.clearInputTextAfterSelection && this.ngSelect) {
|
|
159
|
+
this.ngSelect.searchTerm = null;
|
|
160
|
+
}
|
|
157
161
|
this.onChange(selectedItem);
|
|
158
162
|
this.change.emit(selectedItem);
|
|
159
163
|
}
|
|
@@ -190,7 +194,7 @@ export class DrSelectComponent {
|
|
|
190
194
|
} }, hostVars: 4, hostBindings: function DrSelectComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
191
195
|
i0.ɵɵclassMap(ctx.type);
|
|
192
196
|
i0.ɵɵclassProp("textView", ctx.asTextView);
|
|
193
|
-
} }, inputs: { type: "type", className: "className", items: "items", addTag: "addTag", appendTo: "appendTo", bindLabel: "bindLabel", bindValue: "bindValue", clearable: "clearable", searchable: "searchable", searchFn: "searchFn", multiple: "multiple", multipleHeightIncreased: "multipleHeightIncreased", hideSelected: "hideSelected", placeholder: "placeholder", loading: "loading", loadingText: "loadingText", readonly: "readonly", disabled: "disabled", groupBy: "groupBy", optionWithDescription: "optionWithDescription", id: "id", keyDownFn: "keyDownFn", selectedItem: "selectedItem", dropdownClass: "dropdownClass", closeOnSelect: "closeOnSelect", textView: "textView", autofocus: "autofocus", isOpen: "isOpen", noValuePadding: "noValuePadding" }, outputs: { change: "change", open: "open", closeUp: "closeUp" }, features: [i0.ɵɵProvidersFeature([
|
|
197
|
+
} }, inputs: { type: "type", clearInputTextAfterSelection: "clearInputTextAfterSelection", className: "className", items: "items", addTag: "addTag", appendTo: "appendTo", bindLabel: "bindLabel", bindValue: "bindValue", clearable: "clearable", searchable: "searchable", searchFn: "searchFn", multiple: "multiple", multipleHeightIncreased: "multipleHeightIncreased", hideSelected: "hideSelected", placeholder: "placeholder", loading: "loading", loadingText: "loadingText", readonly: "readonly", disabled: "disabled", groupBy: "groupBy", optionWithDescription: "optionWithDescription", id: "id", keyDownFn: "keyDownFn", selectedItem: "selectedItem", dropdownClass: "dropdownClass", closeOnSelect: "closeOnSelect", textView: "textView", autofocus: "autofocus", isOpen: "isOpen", noValuePadding: "noValuePadding" }, outputs: { change: "change", open: "open", closeUp: "closeUp" }, features: [i0.ɵɵProvidersFeature([
|
|
194
198
|
{
|
|
195
199
|
provide: NG_VALUE_ACCESSOR,
|
|
196
200
|
useExisting: DrSelectComponent,
|
|
@@ -243,6 +247,8 @@ export class DrSelectComponent {
|
|
|
243
247
|
}, {
|
|
244
248
|
type: HostBinding,
|
|
245
249
|
args: ['class']
|
|
250
|
+
}], clearInputTextAfterSelection: [{
|
|
251
|
+
type: Input
|
|
246
252
|
}], className: [{
|
|
247
253
|
type: Input
|
|
248
254
|
}], items: [{
|
|
@@ -324,4 +330,4 @@ export class DrSelectComponent {
|
|
|
324
330
|
type: HostBinding,
|
|
325
331
|
args: ['class.textView']
|
|
326
332
|
}] }); })();
|
|
327
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { ItemsList } from '@ng-select/ng-select/lib/items-list';\n\nconst SELECT_HOST_ATTRIBUTES = ['no-left-border', 'no-left-border-radius', 'no-right-border', 'no-right-border-radius'];\n\ninterface INgSelectComponentAccessor {\n    close: () => void;\n    writeValue: (value: any) => void;\n    blur: () => void;\n    itemsList: ItemsList;\n    searchTerm: string;\n}\n\n@Component({\n    selector: 'dr-select',\n    templateUrl: './dr-select.component.html',\n    styleUrls: ['./dr-select.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: DrSelectComponent,\n            multi: true,\n        },\n    ],\n})\nexport class DrSelectComponent implements ControlValueAccessor {\n    @Input()\n    @HostBinding('class')\n    type: 'select' | 'search-input' = 'select';\n\n    @Input() className: string;\n    @Input() items: Array<any> | Readonly<Array<any>> = [];\n    @Input() addTag: boolean | ((term: string) => any | Promise<any>);\n    @Input() appendTo = 'body';\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() clearable: boolean;\n    @Input() searchable: boolean;\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() placeholder: string;\n    @Input() loading: boolean;\n    @Input() loadingText: string = 'Loading...';\n    @Input() readonly: boolean;\n    @Input() disabled = false;\n    @Input() groupBy = null;\n    @Input() optionWithDescription = false;\n    @Input() id: string;\n    @Input() keyDownFn: ($event: KeyboardEvent) => boolean = () => true;\n    @Input() selectedItem: any;\n    @Input() dropdownClass: string;\n    @Input() closeOnSelect = true;\n\n    @Input() set textView(val: boolean) {\n        this.asTextView = val;\n    }\n\n    @Input() autofocus: boolean;\n    @Input() isOpen: boolean;\n    @Input() noValuePadding = false;\n\n    @Output() change: EventEmitter<any> = new EventEmitter<any>();\n    @Output() open: EventEmitter<any> = new EventEmitter<any>();\n    @Output() closeUp: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild(NgSelectComponent, { read: NgSelectComponent }) private readonly ngSelect: INgSelectComponentAccessor;\n    @ContentChild('labelTemplate') labelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n\n    constructor(private elementRef: ElementRef<HTMLElement>) {\n        for (const attr of SELECT_HOST_ATTRIBUTES) {\n            if (this.hasHostAttributes(attr)) {\n                this.getHostElement().classList.add(attr);\n            }\n        }\n    }\n\n    onChange: (value: boolean) => void = () => {};\n    onTouched: () => void = () => {};\n\n    writeValue(value: any): void {\n        this.selectedItem = value;\n        this.onChange(this.selectedItem);\n\n        if (this.type === 'search-input' && !this.selectedItem && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n\n        if (fn && this.selectedItem) {\n            this.onChange(this.selectedItem);\n        }\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        if (typeof this.dropdownClass === 'string') {\n            setTimeout(() => {\n                document.querySelector('.ng-dropdown-panel').classList.add(...this.dropdownClass.split(' '));\n            }, 0);\n        }\n    }\n\n    onValueSelected(selectedItem: any) {\n        this.onChange(selectedItem);\n        this.change.emit(selectedItem);\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n\n        if (this.type === 'search-input' && this.ngSelect.itemsList?.lastSelectedItem?.label) {\n            this.ngSelect.searchTerm = this.ngSelect.itemsList.lastSelectedItem.label;\n            this.ngSelect.itemsList.filter(this.ngSelect.searchTerm);\n        }\n    }\n\n    private getHostElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some((attribute) => this.getHostElement().hasAttribute(attribute));\n    }\n}\n","<ng-select\n    [(ngModel)]=\"selectedItem\"\n    [items]=\"items\"\n    [bindLabel]=\"bindLabel\"\n    [bindValue]=\"bindValue\"\n    [multiple]=\"multiple\"\n    [addTag]=\"addTag\"\n    [appendTo]=\"appendTo\"\n    [clearable]=\"clearable\"\n    [searchable]=\"searchable\"\n    [hideSelected]=\"hideSelected\"\n    [placeholder]=\"placeholder\"\n    [loading]=\"loading\"\n    [loadingText]=\"loadingText\"\n    [readonly]=\"readonly\"\n    [closeOnSelect]=\"closeOnSelect\"\n    [disabled]=\"disabled\"\n    [id]=\"id\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    (change)=\"onValueSelected(selectedItem)\"\n    (open)=\"open.emit($event); onDropdownOpen()\"\n    (close)=\"onClose($event)\"\n    class=\"dr-select\"\n    [class.ng-select--no-value-padding]=\"noValuePadding\"\n    [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n    #selectComponent>\n    <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n        <div class=\"dr-select__option-with-desc__wrapper\">\n            <div>{{ item.name }}</div>\n            <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n        </div>\n    </ng-template>\n    <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n        <ng-container\n            [ngTemplateOutlet]=\"optionFooterTemplate\"\n            [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n        {{ item[groupBy] }}\n    </ng-template>\n    <ng-template ng-loadingspinner-tmp>\n        <div\n            *ngIf=\"loading\"\n            class=\"dr-select__loading\"\n            [drSpinner]=\"loading\"\n            [drSpinnerType]=\"'circle'\"\n            [drSpinnerSize]=\"'small'\"\n            [drSpinnerNoOverlay]=\"true\"></div>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    Output,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { ItemsList } from '@ng-select/ng-select/lib/items-list';\n\nconst SELECT_HOST_ATTRIBUTES = ['no-left-border', 'no-left-border-radius', 'no-right-border', 'no-right-border-radius'];\n\ninterface INgSelectComponentAccessor {\n    close: () => void;\n    writeValue: (value: any) => void;\n    blur: () => void;\n    itemsList: ItemsList;\n    searchTerm: string;\n}\n\n@Component({\n    selector: 'dr-select',\n    templateUrl: './dr-select.component.html',\n    styleUrls: ['./dr-select.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: DrSelectComponent,\n            multi: true,\n        },\n    ],\n})\nexport class DrSelectComponent implements ControlValueAccessor {\n    @Input()\n    @HostBinding('class')\n    type: 'select' | 'search-input' = 'select';\n\n    @Input() clearInputTextAfterSelection = false;\n    @Input() className: string;\n    @Input() items: Array<any> | Readonly<Array<any>> = [];\n    @Input() addTag: boolean | ((term: string) => any | Promise<any>);\n    @Input() appendTo = 'body';\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() clearable: boolean;\n    @Input() searchable: boolean;\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() placeholder: string;\n    @Input() loading: boolean;\n    @Input() loadingText: string = 'Loading...';\n    @Input() readonly: boolean;\n    @Input() disabled = false;\n    @Input() groupBy = null;\n    @Input() optionWithDescription = false;\n    @Input() id: string;\n    @Input() keyDownFn: ($event: KeyboardEvent) => boolean = () => true;\n    @Input() selectedItem: any;\n    @Input() dropdownClass: string;\n    @Input() closeOnSelect = true;\n\n    @Input() set textView(val: boolean) {\n        this.asTextView = val;\n    }\n\n    @Input() autofocus: boolean;\n    @Input() isOpen: boolean;\n    @Input() noValuePadding = false;\n\n    @Output() change: EventEmitter<any> = new EventEmitter<any>();\n    @Output() open: EventEmitter<any> = new EventEmitter<any>();\n    @Output() closeUp: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild(NgSelectComponent, { read: NgSelectComponent }) private readonly ngSelect: INgSelectComponentAccessor;\n    @ContentChild('labelTemplate') labelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n\n    constructor(private elementRef: ElementRef<HTMLElement>) {\n        for (const attr of SELECT_HOST_ATTRIBUTES) {\n            if (this.hasHostAttributes(attr)) {\n                this.getHostElement().classList.add(attr);\n            }\n        }\n    }\n\n    onChange: (value: boolean) => void = () => {};\n    onTouched: () => void = () => {};\n\n    writeValue(value: any): void {\n        this.selectedItem = value;\n        this.onChange(this.selectedItem);\n\n        if (this.type === 'search-input' && !this.selectedItem && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n\n        if (fn && this.selectedItem) {\n            this.onChange(this.selectedItem);\n        }\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        if (typeof this.dropdownClass === 'string') {\n            setTimeout(() => {\n                document.querySelector('.ng-dropdown-panel').classList.add(...this.dropdownClass.split(' '));\n            }, 0);\n        }\n    }\n\n    onValueSelected(selectedItem: any) {\n        if (this.clearInputTextAfterSelection && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n\n        this.onChange(selectedItem);\n        this.change.emit(selectedItem);\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n\n        if (this.type === 'search-input' && this.ngSelect.itemsList?.lastSelectedItem?.label) {\n            this.ngSelect.searchTerm = this.ngSelect.itemsList.lastSelectedItem.label;\n            this.ngSelect.itemsList.filter(this.ngSelect.searchTerm);\n        }\n    }\n\n    private getHostElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some((attribute) => this.getHostElement().hasAttribute(attribute));\n    }\n}\n","<ng-select\n    [(ngModel)]=\"selectedItem\"\n    [items]=\"items\"\n    [bindLabel]=\"bindLabel\"\n    [bindValue]=\"bindValue\"\n    [multiple]=\"multiple\"\n    [addTag]=\"addTag\"\n    [appendTo]=\"appendTo\"\n    [clearable]=\"clearable\"\n    [searchable]=\"searchable\"\n    [hideSelected]=\"hideSelected\"\n    [placeholder]=\"placeholder\"\n    [loading]=\"loading\"\n    [loadingText]=\"loadingText\"\n    [readonly]=\"readonly\"\n    [closeOnSelect]=\"closeOnSelect\"\n    [disabled]=\"disabled\"\n    [id]=\"id\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    (change)=\"onValueSelected(selectedItem)\"\n    (open)=\"open.emit($event); onDropdownOpen()\"\n    (close)=\"onClose($event)\"\n    class=\"dr-select\"\n    [class.ng-select--no-value-padding]=\"noValuePadding\"\n    [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n    #selectComponent>\n    <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n        <div class=\"dr-select__option-with-desc__wrapper\">\n            <div>{{ item.name }}</div>\n            <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n        </div>\n    </ng-template>\n    <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n        <ng-container\n            [ngTemplateOutlet]=\"optionFooterTemplate\"\n            [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n        {{ item[groupBy] }}\n    </ng-template>\n    <ng-template ng-loadingspinner-tmp>\n        <div\n            *ngIf=\"loading\"\n            class=\"dr-select__loading\"\n            [drSpinner]=\"loading\"\n            [drSpinnerType]=\"'circle'\"\n            [drSpinnerSize]=\"'small'\"\n            [drSpinnerNoOverlay]=\"true\"></div>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9tb2RlbHMvZHJvcGRvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCB0eXBlIEVsUG9zaXRpb24gPVxuICAgIHwgJ2xlZnQnXG4gICAgfCAncmlnaHQnXG4gICAgfCAndG9wJ1xuICAgIHwgJ2JvdHRvbSdcbiAgICB8ICd0b3AtbGVmdCdcbiAgICB8ICd0b3AtcmlnaHQnXG4gICAgfCAnbGVmdC10b3AnXG4gICAgfCAnbGVmdC1ib3R0b20nXG4gICAgfCAnYm90dG9tLWxlZnQnXG4gICAgfCAncmlnaHQtYm90dG9tJ1xuICAgIHwgJ3JpZ2h0LXRvcCdcbiAgICB8ICdib3R0b20tcmlnaHQnO1xuXG4vLyBJQ29udGV4dE1lbnVcbmV4cG9ydCBpbnRlcmZhY2UgSURyb3Bkb3duPFQ+IHtcbiAgICBkckRyb3Bkb3duSW5Ib3Zlcj86IGJvb2xlYW47XG4gICAgcG9zaXRpb24/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9tb2RlbHMvZHJvcGRvd24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCB0eXBlIEVsUG9zaXRpb24gPVxuICAgIHwgJ2xlZnQnXG4gICAgfCAncmlnaHQnXG4gICAgfCAndG9wJ1xuICAgIHwgJ2JvdHRvbSdcbiAgICB8ICd0b3AtbGVmdCdcbiAgICB8ICd0b3AtcmlnaHQnXG4gICAgfCAnbGVmdC10b3AnXG4gICAgfCAnbGVmdC1ib3R0b20nXG4gICAgfCAnYm90dG9tLWxlZnQnXG4gICAgfCAncmlnaHQtYm90dG9tJ1xuICAgIHwgJ3JpZ2h0LXRvcCdcbiAgICB8ICdib3R0b20tcmlnaHQnO1xuXG4vLyBJQ29udGV4dE1lbnVcbmV4cG9ydCBpbnRlcmZhY2UgSURyb3Bkb3duPFQ+IHtcbiAgICBkckRyb3Bkb3duSW5Ib3Zlcj86IGJvb2xlYW47XG4gICAgcG9zaXRpb24/OiBFbFBvc2l0aW9uO1xuICAgIGxpc3Q6IElEcm9wZG93bkl0ZW08VD5bXTtcbiAgICBjbGFzcz86IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBkYXRhQW5hbHl0aWNzPzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkNoaWxkPFQ+IGV4dGVuZHMgT21pdDxJRHJvcGRvd248VD4sICdsaXN0Jz4ge31cblxuLy8gQWN0aW9uTWVudVxuZXhwb3J0IGludGVyZmFjZSBJRHJvcGRvd25JdGVtPFQ+IHtcbiAgICB0aXRsZT86IHN0cmluZztcbiAgICBpY29uPzogc3RyaW5nO1xuICAgIGN1c3RvbVRpdGxlPzogKHA6IGFueSkgPT4gc3RyaW5nO1xuICAgIGFjdGlvbj86IChwOiBUKSA9PiB2b2lkO1xuICAgIGV2ZW50Pzogc3RyaW5nO1xuICAgIGRhdGE/OiBUO1xuICAgIHNob3c/OiAocDogYW55KSA9PiBib29sZWFuO1xuICAgIGRpc2FibGVkPzogKChwOiBUKSA9PiBib29sZWFuKSB8IGJvb2xlYW47XG4gICAgdG9vbFRpcD86IHN0cmluZztcbiAgICBjdXN0b21Ub29sdGlwPzogKHA6IGFueSkgPT4gc3RyaW5nO1xuICAgIHRvb2xUaXBJZkRpc2FibGVkPzogYm9vbGVhbjtcbiAgICBjaGlsZHJlbj86IElEcm9wZG93bkl0ZW08VD5bXTtcbiAgICBjaGlsZE9wdGlvbnM/OiBJRHJvcGRvd25DaGlsZDxUPjtcbiAgICBhY3Rpb25JY29ucz86IElEcm9wZG93bkFjdGlvbkljb248VD5bXTtcbiAgICBzZWxlY3RlZD86ICgocDogVCkgPT4gYm9vbGVhbikgfCBib29sZWFuO1xuICAgIHNlcGFyYXRlTGluZT86IGJvb2xlYW47XG4gICAgY2xhc3M/OiBzdHJpbmcgfCBudWxsO1xuICAgIHRlbXBsYXRlUmVmPzogVGVtcGxhdGVSZWY8eyAkaW1wbGljaXQ6IFQgfT47XG59XG5cbi8vIE1lbnVBY3Rpb25JY29uXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkFjdGlvbkljb248VD4ge1xuICAgIGljb246IHN0cmluZztcbiAgICBhY3Rpb246IChwOiBUKSA9PiB2b2lkO1xuICAgIGRhdGE/OiBhbnk7XG4gICAgc2hvd09uSG92ZXI/OiBib29sZWFuO1xufVxuXG4vLyBDb250ZXh0TWVudUNsaWNrXG5leHBvcnQgaW50ZXJmYWNlIElEcm9wZG93bkFjdGlvbjxUPiB7XG4gICAgZXZlbnQ6IHN0cmluZztcbiAgICBkYXRhPzogVDtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class DataAnalyticsService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.heap = window.heap;
|
|
6
|
+
}
|
|
7
|
+
track(event, payload = {}) {
|
|
8
|
+
if (this.heap) {
|
|
9
|
+
this.heap.track(event, payload);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
/** @nocollapse */ static { this.ɵfac = function DataAnalyticsService_Factory(t) { return new (t || DataAnalyticsService)(); }; }
|
|
13
|
+
/** @nocollapse */ static { this.ɵprov = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjectable({ token: DataAnalyticsService, factory: DataAnalyticsService.ɵfac, providedIn: 'root' }); }
|
|
14
|
+
}
|
|
15
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DataAnalyticsService, [{
|
|
16
|
+
type: Injectable,
|
|
17
|
+
args: [{
|
|
18
|
+
providedIn: 'root',
|
|
19
|
+
}]
|
|
20
|
+
}], function () { return []; }, null); })();
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1hbmFseXRpY3Muc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL3V0aWxzL2RhdGEtYW5hbHl0aWNzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLG9CQUFvQjtJQUc3QjtRQUNJLElBQUksQ0FBQyxJQUFJLEdBQUksTUFBYyxDQUFDLElBQUksQ0FBQztJQUNyQyxDQUFDO0lBRUQsS0FBSyxDQUFDLEtBQWEsRUFBRSxVQUFlLEVBQUU7UUFDbEMsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO1lBQ1gsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1NBQ25DO0lBQ0wsQ0FBQzt3R0FYUSxvQkFBb0I7c0dBQXBCLG9CQUFvQixXQUFwQixvQkFBb0IsbUJBRmpCLE1BQU07O3VGQUVULG9CQUFvQjtjQUhoQyxVQUFVO2VBQUM7Z0JBQ1IsVUFBVSxFQUFFLE1BQU07YUFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIERhdGFBbmFseXRpY3NTZXJ2aWNlIHtcbiAgICBoZWFwOiBhbnk7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgdGhpcy5oZWFwID0gKHdpbmRvdyBhcyBhbnkpLmhlYXA7XG4gICAgfVxuXG4gICAgdHJhY2soZXZlbnQ6IHN0cmluZywgcGF5bG9hZDogYW55ID0ge30pIHtcbiAgICAgICAgaWYgKHRoaXMuaGVhcCkge1xuICAgICAgICAgICAgdGhpcy5oZWFwLnRyYWNrKGV2ZW50LCBwYXlsb2FkKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|