@datarailsshared/datarailsshared 1.6.216 → 1.6.220
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.6.220.tgz +0 -0
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +5 -1
- package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +10 -4
- package/esm2022/lib/emoji-picker/emoji-picker.component.mjs +87 -25
- package/esm2022/local-api.mjs +176 -0
- package/esm2022/public-api.mjs +4 -177
- package/fesm2022/datarailsshared-datarailsshared.mjs +261 -214
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.d.ts +2 -1
- package/lib/emoji-picker/emoji-picker.component.d.ts +14 -5
- package/local-api.d.ts +173 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -174
- package/datarailsshared-datarailsshared-1.6.216.tgz +0 -0
- package/esm2022/lib/emoji-picker/emoji-data.service.mjs +0 -29
- package/lib/emoji-picker/emoji-data.service.d.ts +0 -13
|
Binary file
|
|
@@ -223,6 +223,10 @@ export class DrSelectComponent {
|
|
|
223
223
|
}
|
|
224
224
|
this.onChange(selectedItem);
|
|
225
225
|
this.change.emit(selectedItem);
|
|
226
|
+
this.ngSelect.blur();
|
|
227
|
+
if (this.searchable) {
|
|
228
|
+
this.ngSelect.searchInput.nativeElement.blur();
|
|
229
|
+
}
|
|
226
230
|
}
|
|
227
231
|
onTabKeypress(e) {
|
|
228
232
|
if (this.selectOnTabKeyPress && this.ngSelect) {
|
|
@@ -461,4 +465,4 @@ export class DrSelectComponent {
|
|
|
461
465
|
type: HostBinding,
|
|
462
466
|
args: ['class.textView']
|
|
463
467
|
}] }); })();
|
|
464
|
-
//# 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    OnDestroy,\n    Output,\n    Renderer2,\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';\nimport { Subject } from 'rxjs';\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    open: () => 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, OnDestroy {\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() compareWith: (o1: any, o2: any) => boolean;\n\n    @Input() searchable: boolean;\n    @Input() isDisplayingSearchInHeader: boolean;\n    @Input() minItemsToDisplaySearchInHeader = 11;\n\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() maxSelectedItems: number;\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    @HostBinding('attr.id') hostId = null;\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    @Input() selectOnTabKeyPress = false;\n    @Input() virtualScroll = false;\n    @Input() typeahead!: Subject<string>;\n\n    @Output() search = new EventEmitter<{\n        term: string;\n        items: any[];\n    }>();\n    @Output() scrollToEnd = new EventEmitter<any>();\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('multiLabelTemplate') multiLabelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @ContentChild('notFoundTemplate') notFoundTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n    backdropElement: HTMLElement | null = null;\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n    ) {\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    openDropdown(): void {\n        this.ngSelect.open();\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        setTimeout(() => {\n            this.createBackdrop();\n            const classesToAdd = [];\n            if (this.asTextView) {\n                classesToAdd.push('textView');\n            }\n            if (typeof this.dropdownClass === 'string') {\n                classesToAdd.push(...this.dropdownClass.split(' '));\n            }\n            if (this.isDisplayingSearchInHeader && !this.optionHeaderTemplate) {\n                classesToAdd.push('ng-dropdown-panel--with-search');\n            }\n            const dropdown = document.querySelector('.ng-dropdown-panel');\n            if (dropdown) {\n                dropdown.classList.add(...classesToAdd);\n            }\n        }, 0);\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    onTabKeypress(e) {\n        if (this.selectOnTabKeyPress && this.ngSelect) {\n            e.preventDefault();\n        }\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n        this.removeBackdrop();\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        } else if (this.isDisplayingSearchInHeader) {\n            this.ngSelect.searchTerm = null;\n            this.ngSelect.itemsList.filter(null);\n        }\n    }\n\n    createBackdrop(): void {\n        this.renderer.addClass(document.body, 'no-scroll');\n        this.backdropElement = this.renderer.createElement('div');\n        this.renderer.addClass(this.backdropElement, 'custom-backdrop');\n        this.renderer.appendChild(document.body, this.backdropElement);\n    }\n\n    removeBackdrop(): void {\n        if (this.backdropElement) {\n            this.renderer.removeClass(document.body, 'no-scroll');\n            this.renderer.removeChild(document.body, this.backdropElement);\n            this.backdropElement = null;\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    ngOnDestroy(): void {\n        this.removeBackdrop();\n        this.ngSelect?.close();\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    [labelForId]=\"id\"\n    [maxSelectedItems]=\"maxSelectedItems\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    [selectOnTab]=\"selectOnTabKeyPress\"\n    [virtualScroll]=\"virtualScroll\"\n    [typeahead]=\"typeahead\"\n    (search)=\"search.emit($event)\"\n    (scrollToEnd)=\"scrollToEnd.emit($event)\"\n    (keydown.tab)=\"onTabKeypress($event)\"\n    [compareWith]=\"compareWith\"\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\n        ng-header-tmp\n        *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n        let-item=\"item\">\n        <dr-input\n            class=\"dr-select__search\"\n            [ngModel]=\"selectComponent.searchTerm\"\n            (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n            type=\"search\">\n        </dr-input>\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=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n        </ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, 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-template *ngIf=\"notFoundTemplate\" ng-notfound-tmp>\n        <ng-container [ngTemplateOutlet]=\"notFoundTemplate\"></ng-container>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
|
|
468
|
+
//# 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    OnDestroy,\n    Output,\n    Renderer2,\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';\nimport { Subject } from 'rxjs';\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    open: () => void;\n    writeValue: (value: any) => void;\n    blur: () => void;\n    itemsList: ItemsList;\n    searchTerm: string;\n    searchInput: ElementRef;\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, OnDestroy {\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() compareWith: (o1: any, o2: any) => boolean;\n\n    @Input() searchable: boolean;\n    @Input() isDisplayingSearchInHeader: boolean;\n    @Input() minItemsToDisplaySearchInHeader = 11;\n\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() maxSelectedItems: number;\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    @HostBinding('attr.id') hostId = null;\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    @Input() selectOnTabKeyPress = false;\n    @Input() virtualScroll = false;\n    @Input() typeahead!: Subject<string>;\n\n    @Output() search = new EventEmitter<{\n        term: string;\n        items: any[];\n    }>();\n    @Output() scrollToEnd = new EventEmitter<any>();\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('multiLabelTemplate') multiLabelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @ContentChild('notFoundTemplate') notFoundTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n    backdropElement: HTMLElement | null = null;\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n    ) {\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    openDropdown(): void {\n        this.ngSelect.open();\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        setTimeout(() => {\n            this.createBackdrop();\n            const classesToAdd = [];\n            if (this.asTextView) {\n                classesToAdd.push('textView');\n            }\n            if (typeof this.dropdownClass === 'string') {\n                classesToAdd.push(...this.dropdownClass.split(' '));\n            }\n            if (this.isDisplayingSearchInHeader && !this.optionHeaderTemplate) {\n                classesToAdd.push('ng-dropdown-panel--with-search');\n            }\n            const dropdown = document.querySelector('.ng-dropdown-panel');\n            if (dropdown) {\n                dropdown.classList.add(...classesToAdd);\n            }\n        }, 0);\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        this.ngSelect.blur();\n\n        if (this.searchable) {\n            this.ngSelect.searchInput.nativeElement.blur();\n        }\n    }\n\n    onTabKeypress(e) {\n        if (this.selectOnTabKeyPress && this.ngSelect) {\n            e.preventDefault();\n        }\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n        this.removeBackdrop();\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        } else if (this.isDisplayingSearchInHeader) {\n            this.ngSelect.searchTerm = null;\n            this.ngSelect.itemsList.filter(null);\n        }\n    }\n\n    createBackdrop(): void {\n        this.renderer.addClass(document.body, 'no-scroll');\n        this.backdropElement = this.renderer.createElement('div');\n        this.renderer.addClass(this.backdropElement, 'custom-backdrop');\n        this.renderer.appendChild(document.body, this.backdropElement);\n    }\n\n    removeBackdrop(): void {\n        if (this.backdropElement) {\n            this.renderer.removeClass(document.body, 'no-scroll');\n            this.renderer.removeChild(document.body, this.backdropElement);\n            this.backdropElement = null;\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    ngOnDestroy(): void {\n        this.removeBackdrop();\n        this.ngSelect?.close();\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    [labelForId]=\"id\"\n    [maxSelectedItems]=\"maxSelectedItems\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    [selectOnTab]=\"selectOnTabKeyPress\"\n    [virtualScroll]=\"virtualScroll\"\n    [typeahead]=\"typeahead\"\n    (search)=\"search.emit($event)\"\n    (scrollToEnd)=\"scrollToEnd.emit($event)\"\n    (keydown.tab)=\"onTabKeypress($event)\"\n    [compareWith]=\"compareWith\"\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\n        ng-header-tmp\n        *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n        let-item=\"item\">\n        <dr-input\n            class=\"dr-select__search\"\n            [ngModel]=\"selectComponent.searchTerm\"\n            (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n            type=\"search\">\n        </dr-input>\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=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n        </ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, 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-template *ngIf=\"notFoundTemplate\" ng-notfound-tmp>\n        <ng-container [ngTemplateOutlet]=\"notFoundTemplate\"></ng-container>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
|
|
@@ -12,7 +12,7 @@ const _c0 = ["dynamicInputRef"];
|
|
|
12
12
|
function DrSelectAddItemComponent_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
13
13
|
const _r3 = i0.ɵɵgetCurrentView();
|
|
14
14
|
i0.ɵɵelementStart(0, "div", 3);
|
|
15
|
-
i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_1_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.onDynamicAdding()); });
|
|
15
|
+
i0.ɵɵlistener("click", function DrSelectAddItemComponent_div_1_Template_div_click_0_listener() { i0.ɵɵrestoreView(_r3); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.instantAddValue ? ctx_r2.onDynamicAdd(ctx_r2.instantAddValue) : ctx_r2.onDynamicAdding()); });
|
|
16
16
|
i0.ɵɵelement(1, "i", 4);
|
|
17
17
|
i0.ɵɵelementStart(2, "p", 5);
|
|
18
18
|
i0.ɵɵtext(3);
|
|
@@ -71,6 +71,7 @@ export class DrSelectAddItemComponent {
|
|
|
71
71
|
this.dynamicAddLabel = 'Add new';
|
|
72
72
|
this.values = [];
|
|
73
73
|
this.showOnlyInput = false;
|
|
74
|
+
this.instantAddValue = '';
|
|
74
75
|
this.dynamicValueAdded = new EventEmitter();
|
|
75
76
|
}
|
|
76
77
|
ngOnChanges(changes) {
|
|
@@ -94,6 +95,9 @@ export class DrSelectAddItemComponent {
|
|
|
94
95
|
}
|
|
95
96
|
onDynamicAdd(value, keydownEvent) {
|
|
96
97
|
this.isDirty = true;
|
|
98
|
+
if (this.instantAddValue) {
|
|
99
|
+
this.dynamicValue = this.instantAddValue;
|
|
100
|
+
}
|
|
97
101
|
if (!this.isDynamicValueValid())
|
|
98
102
|
return;
|
|
99
103
|
if (keydownEvent && keydownEvent.key !== 'Enter')
|
|
@@ -116,7 +120,7 @@ export class DrSelectAddItemComponent {
|
|
|
116
120
|
} if (rf & 2) {
|
|
117
121
|
let _t;
|
|
118
122
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.inputRef = _t.first);
|
|
119
|
-
} }, inputs: { dynamicAddLabel: "dynamicAddLabel", bindValue: "bindValue", values: "values", alertMsg: "alertMsg", showOnlyInput: "showOnlyInput" }, outputs: { dynamicValueAdded: "dynamicValueAdded" }, features: [i0.ɵɵNgOnChangesFeature], decls: 3, vars: 2, consts: [[1, "dr-select__dynamic-add", "dynamic-add"], ["class", "dynamic-add__add-item", 3, "click", 4, "ngIf"], ["class", "dynamic-add__field", 4, "ngIf"], [1, "dynamic-add__add-item", 3, "click"], [1, "dr-icon-add"], [1, "dynamic-add__add-item__text"], [1, "dynamic-add__field"], ["class", "dynamic-add__field__alert", 4, "ngIf"], ["placeholder", "Type...", 1, "dynamic-add__field__input", 3, "ngModel", "ngModelChange", "keydown"], ["dynamicInputRef", ""], [1, "dynamic-add__field__buttons"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click", 4, "ngIf"], ["theme", "icon", "icon", "dr-icon-exit", "iconSize", "18px", 3, "click"], [1, "dynamic-add__field__alert"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click"]], template: function DrSelectAddItemComponent_Template(rf, ctx) { if (rf & 1) {
|
|
123
|
+
} }, inputs: { dynamicAddLabel: "dynamicAddLabel", bindValue: "bindValue", values: "values", alertMsg: "alertMsg", showOnlyInput: "showOnlyInput", instantAddValue: "instantAddValue" }, outputs: { dynamicValueAdded: "dynamicValueAdded" }, features: [i0.ɵɵNgOnChangesFeature], decls: 3, vars: 2, consts: [[1, "dr-select__dynamic-add", "dynamic-add"], ["class", "dynamic-add__add-item", 3, "click", 4, "ngIf"], ["class", "dynamic-add__field", 4, "ngIf"], [1, "dynamic-add__add-item", 3, "click"], [1, "dr-icon-add"], [1, "dynamic-add__add-item__text"], [1, "dynamic-add__field"], ["class", "dynamic-add__field__alert", 4, "ngIf"], ["placeholder", "Type...", 1, "dynamic-add__field__input", 3, "ngModel", "ngModelChange", "keydown"], ["dynamicInputRef", ""], [1, "dynamic-add__field__buttons"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click", 4, "ngIf"], ["theme", "icon", "icon", "dr-icon-exit", "iconSize", "18px", 3, "click"], [1, "dynamic-add__field__alert"], ["theme", "icon", "icon", "dr-icon-approve", "iconSize", "18px", 3, "click"]], template: function DrSelectAddItemComponent_Template(rf, ctx) { if (rf & 1) {
|
|
120
124
|
i0.ɵɵelementStart(0, "div", 0);
|
|
121
125
|
i0.ɵɵtemplate(1, DrSelectAddItemComponent_div_1_Template, 4, 1, "div", 1);
|
|
122
126
|
i0.ɵɵtemplate(2, DrSelectAddItemComponent_div_2_Template, 7, 5, "div", 2);
|
|
@@ -130,7 +134,7 @@ export class DrSelectAddItemComponent {
|
|
|
130
134
|
}
|
|
131
135
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrSelectAddItemComponent, [{
|
|
132
136
|
type: Component,
|
|
133
|
-
args: [{ selector: 'dr-select-add-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dr-select__dynamic-add dynamic-add\">\n <div
|
|
137
|
+
args: [{ selector: 'dr-select-add-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"dr-select__dynamic-add dynamic-add\">\n <div\n *ngIf=\"!(showOnlyInput && isDynamicAdding)\"\n class=\"dynamic-add__add-item\"\n (click)=\"instantAddValue ? onDynamicAdd(instantAddValue) : onDynamicAdding()\">\n <i class=\"dr-icon-add\"></i>\n <p class=\"dynamic-add__add-item__text\">{{ dynamicAddLabel }}</p>\n </div>\n <div *ngIf=\"isDynamicAdding\" class=\"dynamic-add__field\">\n <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\" class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n <dr-input\n #dynamicInputRef\n class=\"dynamic-add__field__input\"\n [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n [(ngModel)]=\"dynamicValue\"\n (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n placeholder=\"Type...\"></dr-input>\n <div class=\"dynamic-add__field__buttons\">\n <dr-button\n *ngIf=\"dynamicValue && isDynamicValueValid()\"\n theme=\"icon\"\n icon=\"dr-icon-approve\"\n iconSize=\"18px\"\n (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n </div>\n </div>\n</div>\n", styles: [".dynamic-add__add-item{cursor:pointer;display:flex;align-items:center;border-bottom:1px solid #dfe0e3;padding:6px}.dynamic-add__add-item:hover{background:#f9f7ff}.dynamic-add__add-item__text{font-size:14px;line-height:22px;margin:0;color:#6d6e6f}.dynamic-add__add-item .dr-icon-add{color:#6d6e6f}.dynamic-add__field{position:relative}.dynamic-add__field__buttons{position:absolute;top:0;right:0;bottom:0;display:flex;align-items:center}.dynamic-add__field__alert{font-size:12px;position:absolute;color:#bf1d30;z-index:100;right:30px}::ng-deep .ng-dropdown-panel .ng-dropdown-footer:has(.dynamic-add),::ng-deep .ng-dropdown-panel .ng-dropdown-header:has(.dynamic-add){padding:0;border:none}::ng-deep .ng-dropdown-panel .ng-dropdown-footer .dynamic-add__add-item{border-bottom:none}::ng-deep .dynamic-add__field__input{padding-left:12px!important;height:36px!important;border:none!important;background:#f9f7ff!important;border-radius:0!important}::ng-deep .dynamic-add__field__input>input{background:#f9f7ff}::ng-deep .dynamic-add__field__input>input::placeholder{line-height:22px;font-size:14px;font-weight:400;color:#9ea1aa}::ng-deep .dynamic-add__field__input--error{background:#ffdfe4!important}::ng-deep .dynamic-add__field__input--error>input{background:#ffdfe4}\n"] }]
|
|
134
138
|
}], function () { return [{ type: i1.DrSelectComponent }]; }, { dynamicAddLabel: [{
|
|
135
139
|
type: Input
|
|
136
140
|
}], bindValue: [{
|
|
@@ -141,10 +145,12 @@ export class DrSelectAddItemComponent {
|
|
|
141
145
|
type: Input
|
|
142
146
|
}], showOnlyInput: [{
|
|
143
147
|
type: Input
|
|
148
|
+
}], instantAddValue: [{
|
|
149
|
+
type: Input
|
|
144
150
|
}], dynamicValueAdded: [{
|
|
145
151
|
type: Output
|
|
146
152
|
}], inputRef: [{
|
|
147
153
|
type: ViewChild,
|
|
148
154
|
args: ['dynamicInputRef']
|
|
149
155
|
}] }); })();
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select-add-item.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { DrSelectComponent } from '../dr-select/dr-select.component';\nimport { reduce as _reduce } from 'lodash';\nimport { DrInputComponent } from '../dr-input/dr-input.component';\n\n@Component({\n    selector: 'dr-select-add-item',\n    templateUrl: './dr-select-add-item.component.html',\n    styleUrls: ['./dr-select-add-item.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrSelectAddItemComponent implements OnInit, OnChanges {\n    public isDynamicAdding: boolean;\n    public dynamicValue: string;\n    public currentValues: any[] = [];\n    public isDirty: boolean;\n\n    @Input() public dynamicAddLabel = 'Add new';\n    @Input() public bindValue: string;\n    @Input() private values: any[] = [];\n    @Input() public alertMsg: string;\n    @Input() public showOnlyInput: boolean = false;\n    @Input() public instantAddValue: string = '';\n    @Output() private dynamicValueAdded: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('dynamicInputRef') set inputRef(input: DrInputComponent) {\n        if (!input) return;\n        input.focus();\n    }\n\n    constructor(private drSelect: DrSelectComponent) {}\n\n    public ngOnChanges(changes: SimpleChanges) {\n        this.calculateCurrentValues();\n    }\n\n    public ngOnInit(): void {\n        this.calculateCurrentValues();\n    }\n\n    public onDynamicAdding(): void {\n        this.isDynamicAdding = true;\n    }\n\n    public onDynamicAddingClose(): void {\n        this.isDynamicAdding = false;\n        this.dynamicValue = '';\n    }\n\n    public isDynamicValueValid(): boolean {\n        const trimmedValue = this.dynamicValue?.trim();\n        if (!trimmedValue) return false;\n        return !this.currentValues.includes(trimmedValue);\n    }\n\n    public onDynamicAdd(value: string, keydownEvent?: KeyboardEvent): void {\n        this.isDirty = true;\n\n        if (this.instantAddValue) {\n            this.dynamicValue = this.instantAddValue;\n        }\n\n        if (!this.isDynamicValueValid()) return;\n        if (keydownEvent && keydownEvent.key !== 'Enter') return;\n\n        this.onDynamicAddingClose();\n        this.drSelect.close();\n        this.dynamicValueAdded.emit(value?.trim());\n    }\n\n    private calculateCurrentValues(): void {\n        this.currentValues = this.bindValue\n            ? _reduce(\n                  this.values,\n                  (acc, curr) => {\n                      acc.push(curr[this.bindValue]);\n                      return acc;\n                  },\n                  [],\n              )\n            : this.values;\n    }\n}\n","<div class=\"dr-select__dynamic-add dynamic-add\">\n    <div\n        *ngIf=\"!(showOnlyInput && isDynamicAdding)\"\n        class=\"dynamic-add__add-item\"\n        (click)=\"instantAddValue ? onDynamicAdd(instantAddValue) : onDynamicAdding()\">\n        <i class=\"dr-icon-add\"></i>\n        <p class=\"dynamic-add__add-item__text\">{{ dynamicAddLabel }}</p>\n    </div>\n    <div *ngIf=\"isDynamicAdding\" class=\"dynamic-add__field\">\n        <p *ngIf=\"alertMsg && !isDynamicValueValid() && isDirty\" class=\"dynamic-add__field__alert\">{{ alertMsg }}</p>\n        <dr-input\n            #dynamicInputRef\n            class=\"dynamic-add__field__input\"\n            [class.dynamic-add__field__input--error]=\"!isDynamicValueValid() && isDirty\"\n            [(ngModel)]=\"dynamicValue\"\n            (keydown)=\"onDynamicAdd(dynamicValue, $event)\"\n            placeholder=\"Type...\"></dr-input>\n        <div class=\"dynamic-add__field__buttons\">\n            <dr-button\n                *ngIf=\"dynamicValue && isDynamicValueValid()\"\n                theme=\"icon\"\n                icon=\"dr-icon-approve\"\n                iconSize=\"18px\"\n                (click)=\"onDynamicAdd(dynamicValue)\"></dr-button>\n            <dr-button theme=\"icon\" icon=\"dr-icon-exit\" iconSize=\"18px\" (click)=\"onDynamicAddingClose()\"></dr-button>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { PickerComponent } from '@ctrl/ngx-emoji-mart';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef, } from '@angular/core';
|
|
3
2
|
import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';
|
|
4
3
|
import { DrButtonComponent } from '../dr-inputs/button/button.component';
|
|
5
4
|
import { EmojiPickerMode } from './emoji-picker.types';
|
|
6
5
|
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
7
|
+
const _c0 = ["pickerContainer"];
|
|
8
8
|
function EmojiPickerComponent_ng_container_0_ng_template_4_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
9
9
|
i0.ɵɵelementContainer(0);
|
|
10
10
|
} }
|
|
@@ -25,55 +25,117 @@ function EmojiPickerComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
|
|
|
25
25
|
i0.ɵɵlistener("click", function EmojiPickerComponent_ng_container_0_Template_dr_button_click_1_listener() { i0.ɵɵrestoreView(_r8); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.toggleEmojiPicker()); });
|
|
26
26
|
i0.ɵɵelementEnd();
|
|
27
27
|
i0.ɵɵtemplate(4, EmojiPickerComponent_ng_container_0_ng_template_4_Template, 2, 1, "ng-template", 4);
|
|
28
|
-
i0.ɵɵlistener("backdropClick", function EmojiPickerComponent_ng_container_0_Template_ng_template_backdropClick_4_listener() { i0.ɵɵrestoreView(_r8); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.
|
|
28
|
+
i0.ɵɵlistener("backdropClick", function EmojiPickerComponent_ng_container_0_Template_ng_template_backdropClick_4_listener() { i0.ɵɵrestoreView(_r8); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.destroyEmojiPicker()); });
|
|
29
29
|
i0.ɵɵelementContainerEnd();
|
|
30
30
|
} if (rf & 2) {
|
|
31
31
|
const _r4 = i0.ɵɵreference(3);
|
|
32
32
|
const ctx_r0 = i0.ɵɵnextContext();
|
|
33
33
|
i0.ɵɵadvance(4);
|
|
34
|
-
i0.ɵɵproperty("cdkConnectedOverlayOrigin", _r4)("cdkConnectedOverlayOpen", ctx_r0.
|
|
34
|
+
i0.ɵɵproperty("cdkConnectedOverlayOrigin", _r4)("cdkConnectedOverlayOpen", ctx_r0.emojiOverlayOpened)("cdkConnectedOverlayPositions", ctx_r0.positions)("cdkConnectedOverlayPush", true)("cdkConnectedOverlayViewportMargin", 16)("cdkConnectedOverlayHasBackdrop", true)("cdkConnectedOverlayBackdropClass", "emoji-modal-backdrop");
|
|
35
35
|
} }
|
|
36
36
|
function EmojiPickerComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
|
|
37
|
-
|
|
38
|
-
i0.ɵɵelementStart(0, "emoji-mart", 7);
|
|
39
|
-
i0.ɵɵlistener("emojiSelect", function EmojiPickerComponent_ng_template_1_Template_emoji_mart_emojiSelect_0_listener($event) { i0.ɵɵrestoreView(_r11); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.onEmojiSelected($event)); });
|
|
40
|
-
i0.ɵɵelementEnd();
|
|
41
|
-
} if (rf & 2) {
|
|
42
|
-
i0.ɵɵproperty("darkMode", false);
|
|
37
|
+
i0.ɵɵelementContainer(0, null, 7);
|
|
43
38
|
} }
|
|
44
39
|
export class EmojiPickerComponent {
|
|
45
|
-
constructor() {
|
|
40
|
+
constructor(cdr) {
|
|
41
|
+
this.cdr = cdr;
|
|
46
42
|
this.mode = EmojiPickerMode.BUTTON;
|
|
47
43
|
this.emojiSelected = new EventEmitter();
|
|
48
|
-
this.
|
|
44
|
+
this.emojiOverlayOpened = false;
|
|
49
45
|
this.EmojiPickerMode = EmojiPickerMode;
|
|
46
|
+
this.positions = [
|
|
47
|
+
{
|
|
48
|
+
originX: 'start',
|
|
49
|
+
originY: 'top',
|
|
50
|
+
overlayX: 'start',
|
|
51
|
+
overlayY: 'bottom',
|
|
52
|
+
offsetY: -8,
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
originX: 'start',
|
|
56
|
+
originY: 'bottom',
|
|
57
|
+
overlayX: 'start',
|
|
58
|
+
overlayY: 'top',
|
|
59
|
+
offsetY: 8,
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
originX: 'end',
|
|
63
|
+
originY: 'top',
|
|
64
|
+
overlayX: 'end',
|
|
65
|
+
overlayY: 'bottom',
|
|
66
|
+
offsetY: -8,
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
originX: 'end',
|
|
70
|
+
originY: 'bottom',
|
|
71
|
+
overlayX: 'end',
|
|
72
|
+
overlayY: 'top',
|
|
73
|
+
offsetY: 8,
|
|
74
|
+
},
|
|
75
|
+
];
|
|
50
76
|
}
|
|
51
|
-
|
|
52
|
-
this.
|
|
77
|
+
async ngAfterViewInit() {
|
|
78
|
+
if (this.mode === EmojiPickerMode.FLAT) {
|
|
79
|
+
await this.renderEmojiPicker();
|
|
80
|
+
}
|
|
53
81
|
}
|
|
54
|
-
|
|
55
|
-
this.
|
|
82
|
+
async toggleEmojiPicker() {
|
|
83
|
+
this.emojiOverlayOpened = !this.emojiOverlayOpened;
|
|
84
|
+
if (this.emojiOverlayOpened && !this.pickerComponentRef) {
|
|
85
|
+
// Wait for the overlay to render the template
|
|
86
|
+
setTimeout(async () => {
|
|
87
|
+
await this.renderEmojiPicker();
|
|
88
|
+
this.cdr.markForCheck();
|
|
89
|
+
}, 0);
|
|
90
|
+
}
|
|
56
91
|
}
|
|
57
92
|
onEmojiSelected(event) {
|
|
58
93
|
const emojiReaction = { id: event.emoji.id, emoji: event.emoji.native };
|
|
59
94
|
this.emojiSelected.emit(emojiReaction);
|
|
60
|
-
this.
|
|
95
|
+
if (this.mode === EmojiPickerMode.BUTTON) {
|
|
96
|
+
this.destroyEmojiPicker();
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
destroyEmojiPicker() {
|
|
100
|
+
this.emojiOverlayOpened = false;
|
|
101
|
+
this.pickerComponentRef?.destroy();
|
|
102
|
+
this.pickerComponentRef = null;
|
|
61
103
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
104
|
+
async renderEmojiPicker() {
|
|
105
|
+
if (!this.PickerComponent) {
|
|
106
|
+
// See details here: https://github.com/scttcper/ngx-emoji-mart
|
|
107
|
+
this.PickerComponent = await import('@ctrl/ngx-emoji-mart').then((m) => m.PickerComponent);
|
|
108
|
+
}
|
|
109
|
+
this.pickerComponentRef = this.pickerContainer.createComponent(this.PickerComponent);
|
|
110
|
+
this.pickerComponentRef.instance.emoji = 'thumbsup';
|
|
111
|
+
this.pickerComponentRef.instance.darkMode = false;
|
|
112
|
+
this.pickerComponentRef.instance.color = '#0D99FF';
|
|
113
|
+
this.pickerComponentRef.instance.emojiSelect.subscribe((event) => this.onEmojiSelected(event));
|
|
114
|
+
this.cdr.detectChanges();
|
|
115
|
+
}
|
|
116
|
+
/** @nocollapse */ static { this.ɵfac = function EmojiPickerComponent_Factory(t) { return new (t || EmojiPickerComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
|
|
117
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: EmojiPickerComponent, selectors: [["dr-emoji-picker"]], viewQuery: function EmojiPickerComponent_Query(rf, ctx) { if (rf & 1) {
|
|
118
|
+
i0.ɵɵviewQuery(_c0, 5, ViewContainerRef);
|
|
119
|
+
} if (rf & 2) {
|
|
120
|
+
let _t;
|
|
121
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.pickerContainer = _t.first);
|
|
122
|
+
} }, inputs: { mode: "mode" }, outputs: { emojiSelected: "emojiSelected" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 2, consts: [[4, "ngIf", "ngIfElse"], ["flatTpl", ""], ["theme", "icon", "icon", "dr-icon-emoji-smiley", "cdkOverlayOrigin", "", 3, "click"], ["emojiButton", "", "trigger", "cdkOverlayOrigin"], ["cdkConnectedOverlay", "", 3, "cdkConnectedOverlayOrigin", "cdkConnectedOverlayOpen", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPush", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayBackdropClass", "backdropClick"], [1, "emoji-picker-popup"], [4, "ngTemplateOutlet"], ["pickerContainer", ""]], template: function EmojiPickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
123
|
+
i0.ɵɵtemplate(0, EmojiPickerComponent_ng_container_0_Template, 5, 7, "ng-container", 0);
|
|
124
|
+
i0.ɵɵtemplate(1, EmojiPickerComponent_ng_template_1_Template, 2, 0, "ng-template", null, 1, i0.ɵɵtemplateRefExtractor);
|
|
66
125
|
} if (rf & 2) {
|
|
67
126
|
const _r1 = i0.ɵɵreference(2);
|
|
68
127
|
i0.ɵɵproperty("ngIf", ctx.mode === ctx.EmojiPickerMode.BUTTON)("ngIfElse", _r1);
|
|
69
|
-
} }, dependencies: [DrButtonComponent,
|
|
128
|
+
} }, dependencies: [DrButtonComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], styles: [".emoji-picker-popup[_ngcontent-%COMP%]{position:relative;overflow:hidden;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px;width:352px;height:435px;background:#fff;animation:_ngcontent-%COMP%_fadeIn .2s ease-in-out}.emoji-picker-popup[_ngcontent-%COMP%] section.emoji-mart{border-color:transparent;height:100%;overflow-y:auto}.emoji-picker-popup[_ngcontent-%COMP%] .emoji-picker-section[_ngcontent-%COMP%]{display:block;height:100%}.emoji-picker-popup[_ngcontent-%COMP%] .emoji-picker-section[_ngcontent-%COMP%] section.emoji-mart{border-color:transparent}@keyframes _ngcontent-%COMP%_fadeIn{0%{opacity:0}to{opacity:1}}"], changeDetection: 0 }); }
|
|
70
129
|
}
|
|
71
130
|
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(EmojiPickerComponent, [{
|
|
72
131
|
type: Component,
|
|
73
|
-
args: [{ selector: 'dr-emoji-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [DrButtonComponent,
|
|
74
|
-
}],
|
|
132
|
+
args: [{ selector: 'dr-emoji-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [DrButtonComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet], template: "<ng-container *ngIf=\"mode === EmojiPickerMode.BUTTON; else flatTpl\">\n <dr-button\n #emojiButton\n theme=\"icon\"\n icon=\"dr-icon-emoji-smiley\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n (click)=\"toggleEmojiPicker()\"></dr-button>\n <ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"emojiOverlayOpened\"\n [cdkConnectedOverlayPositions]=\"positions\"\n [cdkConnectedOverlayPush]=\"true\"\n [cdkConnectedOverlayViewportMargin]=\"16\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayBackdropClass]=\"'emoji-modal-backdrop'\"\n (backdropClick)=\"destroyEmojiPicker()\">\n <div class=\"emoji-picker-popup\">\n <ng-container *ngTemplateOutlet=\"flatTpl\"></ng-container>\n </div>\n </ng-template>\n</ng-container>\n\n<ng-template #flatTpl>\n <!-- Placeholder where the emoji picker will be rendered -->\n <ng-container #pickerContainer></ng-container>\n</ng-template>\n", styles: [".emoji-picker-popup{position:relative;overflow:hidden;z-index:1000;box-shadow:0 2px 36px #00000026;border-radius:12px;width:352px;height:435px;background:#fff;animation:fadeIn .2s ease-in-out}.emoji-picker-popup ::ng-deep section.emoji-mart{border-color:transparent;height:100%;overflow-y:auto}.emoji-picker-popup .emoji-picker-section{display:block;height:100%}.emoji-picker-popup .emoji-picker-section ::ng-deep section.emoji-mart{border-color:transparent}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}\n"] }]
|
|
133
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }]; }, { mode: [{
|
|
75
134
|
type: Input
|
|
76
135
|
}], emojiSelected: [{
|
|
77
136
|
type: Output
|
|
137
|
+
}], pickerContainer: [{
|
|
138
|
+
type: ViewChild,
|
|
139
|
+
args: ['pickerContainer', { read: ViewContainerRef }]
|
|
78
140
|
}] }); })();
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktcGlja2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2Vtb2ppLXBpY2tlci9lbW9qaS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZW1vamktcGlja2VyL2Vtb2ppLXBpY2tlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hHLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZUFBZSxFQUFrQixNQUFNLHNCQUFzQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0lDVzdDLHdCQUF5RDs7O0lBRDdELDhCQUFnQztJQUM1QixvSEFBeUQ7SUFDN0QsaUJBQU07Ozs7SUFEYSxlQUF5QjtJQUF6QixzQ0FBeUI7Ozs7SUFoQnBELDZCQUFvRTtJQUNoRSx1Q0FNa0M7SUFBOUIsNktBQVMsZUFBQSwwQkFBbUIsQ0FBQSxJQUFDO0lBQUMsaUJBQVk7SUFDOUMsb0dBVWM7SUFKViwrTEFBaUIsZUFBQSx5QkFBa0IsQ0FBQSxJQUFDO0lBSzVDLDBCQUFlOzs7O0lBVFAsZUFBcUM7SUFBckMsK0NBQXFDLGdEQUFBLHdDQUFBLDREQUFBOzs7O0lBYXpDLHFDQUtpQztJQUQ3QixpTUFBZSxlQUFBLCtCQUF1QixDQUFBLElBQUM7SUFDVixpQkFBYTs7SUFGMUMsZ0NBQWtCOztBRFgxQixNQUFNLE9BQU8sb0JBQW9CO0lBUmpDO1FBU2EsU0FBSSxHQUFvQixlQUFlLENBQUMsTUFBTSxDQUFDO1FBRTlDLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQWtCLENBQUM7UUFFN0QsaUJBQVksR0FBWSxLQUFLLENBQUM7UUFDWCxvQkFBZSxHQUFHLGVBQWUsQ0FBQztLQWV4RDtJQWJHLGlCQUFpQjtRQUNiLElBQUksQ0FBQyxZQUFZLEdBQUcsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzNDLENBQUM7SUFFRCxnQkFBZ0I7UUFDWixJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztJQUM5QixDQUFDO0lBRUQsZUFBZSxDQUFDLEtBQXlEO1FBQ3JFLE1BQU0sYUFBYSxHQUFtQixFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQUUsRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN4RixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN2QyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUM1QixDQUFDO3dHQXBCUSxvQkFBb0I7bUdBQXBCLG9CQUFvQjtZQ2ZqQyx1RkFtQmU7WUFFZixzSEFRYzs7O1lBN0JDLDhEQUF1QyxpQkFBQTs0QkRheEMsaUJBQWlCLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixFQUFFLElBQUksRUFBRSxnQkFBZ0I7O3VGQUVsRyxvQkFBb0I7Y0FSaEMsU0FBUzsyQkFDSSxpQkFBaUIsbUJBR1YsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsbUJBQW1CLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixDQUFDO2dCQUduRyxJQUFJO2tCQUFaLEtBQUs7WUFFSSxhQUFhO2tCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQaWNrZXJDb21wb25lbnQgfSBmcm9tICdAY3RybC9uZ3gtZW1vamktbWFydCc7XG5pbXBvcnQgeyBDZGtDb25uZWN0ZWRPdmVybGF5LCBDZGtPdmVybGF5T3JpZ2luIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgRHJCdXR0b25Db21wb25lbnQgfSBmcm9tICcuLi9kci1pbnB1dHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRW1vamlQaWNrZXJNb2RlLCBJRW1vamlSZWFjdGlvbiB9IGZyb20gJy4vZW1vamktcGlja2VyLnR5cGVzJztcbmltcG9ydCB7IE5nSWYsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLWVtb2ppLXBpY2tlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Vtb2ppLXBpY2tlci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZW1vamktcGlja2VyLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbRHJCdXR0b25Db21wb25lbnQsIFBpY2tlckNvbXBvbmVudCwgQ2RrT3ZlcmxheU9yaWdpbiwgQ2RrQ29ubmVjdGVkT3ZlcmxheSwgTmdJZiwgTmdUZW1wbGF0ZU91dGxldF0sXG59KVxuZXhwb3J0IGNsYXNzIEVtb2ppUGlja2VyQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBtb2RlOiBFbW9qaVBpY2tlck1vZGUgPSBFbW9qaVBpY2tlck1vZGUuQlVUVE9OO1xuXG4gICAgQE91dHB1dCgpIGVtb2ppU2VsZWN0ZWQgPSBuZXcgRXZlbnRFbWl0dGVyPElFbW9qaVJlYWN0aW9uPigpO1xuXG4gICAgZW1vamlzT3BlbmVkOiBib29sZWFuID0gZmFsc2U7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IEVtb2ppUGlja2VyTW9kZSA9IEVtb2ppUGlja2VyTW9kZTtcblxuICAgIHRvZ2dsZUVtb2ppUGlja2VyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmVtb2ppc09wZW5lZCA9ICF0aGlzLmVtb2ppc09wZW5lZDtcbiAgICB9XG5cbiAgICBjbG9zZUVtb2ppUGlja2VyKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmVtb2ppc09wZW5lZCA9IGZhbHNlO1xuICAgIH1cblxuICAgIG9uRW1vamlTZWxlY3RlZChldmVudDogeyBlbW9qaTogeyBuYXRpdmU6IHN0cmluZzsgaWQ6IHN0cmluZyB8IG51bWJlciB9IH0pOiB2b2lkIHtcbiAgICAgICAgY29uc3QgZW1vamlSZWFjdGlvbjogSUVtb2ppUmVhY3Rpb24gPSB7IGlkOiBldmVudC5lbW9qaS5pZCwgZW1vamk6IGV2ZW50LmVtb2ppLm5hdGl2ZSB9O1xuICAgICAgICB0aGlzLmVtb2ppU2VsZWN0ZWQuZW1pdChlbW9qaVJlYWN0aW9uKTtcbiAgICAgICAgdGhpcy5jbG9zZUVtb2ppUGlja2VyKCk7XG4gICAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cIm1vZGUgPT09IEVtb2ppUGlja2VyTW9kZS5CVVRUT047IGVsc2UgZmxhdFRwbFwiPlxuICAgIDxkci1idXR0b25cbiAgICAgICAgI2Vtb2ppQnV0dG9uXG4gICAgICAgIHRoZW1lPVwiaWNvblwiXG4gICAgICAgIGljb249XCJkci1pY29uLWVtb2ppLXNtaWxleVwiXG4gICAgICAgIGNka092ZXJsYXlPcmlnaW5cbiAgICAgICAgI3RyaWdnZXI9XCJjZGtPdmVybGF5T3JpZ2luXCJcbiAgICAgICAgKGNsaWNrKT1cInRvZ2dsZUVtb2ppUGlja2VyKClcIj48L2RyLWJ1dHRvbj5cbiAgICA8bmctdGVtcGxhdGVcbiAgICAgICAgY2RrQ29ubmVjdGVkT3ZlcmxheVxuICAgICAgICBbY2RrQ29ubmVjdGVkT3ZlcmxheU9yaWdpbl09XCJ0cmlnZ2VyXCJcbiAgICAgICAgW2Nka0Nvbm5lY3RlZE92ZXJsYXlPcGVuXT1cImVtb2ppc09wZW5lZFwiXG4gICAgICAgIFtjZGtDb25uZWN0ZWRPdmVybGF5SGFzQmFja2Ryb3BdPVwidHJ1ZVwiXG4gICAgICAgIFtjZGtDb25uZWN0ZWRPdmVybGF5QmFja2Ryb3BDbGFzc109XCInZW1vamktbW9kYWwtYmFja2Ryb3AnXCJcbiAgICAgICAgKGJhY2tkcm9wQ2xpY2spPVwiY2xvc2VFbW9qaVBpY2tlcigpXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJlbW9qaS1waWNrZXItcG9wdXBcIj5cbiAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJmbGF0VHBsXCI+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvbmctdGVtcGxhdGU+XG48L25nLWNvbnRhaW5lcj5cblxuPG5nLXRlbXBsYXRlICNmbGF0VHBsPlxuICAgIDwhLS0gU2VlIGRldGFpbHMgaGVyZTogaHR0cHM6Ly9naXRodWIuY29tL3NjdHRjcGVyL25neC1lbW9qaS1tYXJ0IC0tPlxuICAgIDxlbW9qaS1tYXJ0XG4gICAgICAgIGVtb2ppPVwidGh1bWJzdXBcIlxuICAgICAgICBjb2xvcj1cIiMwRDk5RkZcIlxuICAgICAgICBbZGFya01vZGVdPVwiZmFsc2VcIlxuICAgICAgICAoZW1vamlTZWxlY3QpPVwib25FbW9qaVNlbGVjdGVkKCRldmVudClcIlxuICAgICAgICBjbGFzcz1cImVtb2ppLXBpY2tlci1zZWN0aW9uXCI+PC9lbW9qaS1tYXJ0PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji-picker.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/emoji-picker/emoji-picker.component.ts","../../../../../projects/datarailsshared/src/lib/emoji-picker/emoji-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\nimport { CdkConnectedOverlay, CdkOverlayOrigin, ConnectionPositionPair } from '@angular/cdk/overlay';\nimport { DrButtonComponent } from '../dr-inputs/button/button.component';\nimport { EmojiPickerMode, IEmojiReaction } from './emoji-picker.types';\nimport { NgIf, NgTemplateOutlet } from '@angular/common';\n\n@Component({\n    selector: 'dr-emoji-picker',\n    templateUrl: './emoji-picker.component.html',\n    styleUrls: ['./emoji-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [DrButtonComponent, CdkOverlayOrigin, CdkConnectedOverlay, NgIf, NgTemplateOutlet],\n})\nexport class EmojiPickerComponent implements AfterViewInit {\n    @Input() mode: EmojiPickerMode = EmojiPickerMode.BUTTON;\n\n    @Output() emojiSelected = new EventEmitter<IEmojiReaction>();\n\n    @ViewChild('pickerContainer', { read: ViewContainerRef }) pickerContainer?: ViewContainerRef;\n\n    emojiOverlayOpened: boolean = false;\n\n    protected readonly EmojiPickerMode = EmojiPickerMode;\n    protected readonly positions: ConnectionPositionPair[] = [\n        {\n            originX: 'start',\n            originY: 'top',\n            overlayX: 'start',\n            overlayY: 'bottom',\n            offsetY: -8,\n        },\n        {\n            originX: 'start',\n            originY: 'bottom',\n            overlayX: 'start',\n            overlayY: 'top',\n            offsetY: 8,\n        },\n        {\n            originX: 'end',\n            originY: 'top',\n            overlayX: 'end',\n            overlayY: 'bottom',\n            offsetY: -8,\n        },\n        {\n            originX: 'end',\n            originY: 'bottom',\n            overlayX: 'end',\n            overlayY: 'top',\n            offsetY: 8,\n        },\n    ];\n\n    private pickerComponentRef?: ComponentRef<any>;\n    private PickerComponent;\n\n    constructor(private readonly cdr: ChangeDetectorRef) {}\n\n    async ngAfterViewInit() {\n        if (this.mode === EmojiPickerMode.FLAT) {\n            await this.renderEmojiPicker();\n        }\n    }\n\n    async toggleEmojiPicker(): Promise<void> {\n        this.emojiOverlayOpened = !this.emojiOverlayOpened;\n        if (this.emojiOverlayOpened && !this.pickerComponentRef) {\n            // Wait for the overlay to render the template\n            setTimeout(async () => {\n                await this.renderEmojiPicker();\n                this.cdr.markForCheck();\n            }, 0);\n        }\n    }\n\n    onEmojiSelected(event: { emoji: { native: string; id: string | number } }): void {\n        const emojiReaction: IEmojiReaction = { id: event.emoji.id, emoji: event.emoji.native };\n        this.emojiSelected.emit(emojiReaction);\n\n        if (this.mode === EmojiPickerMode.BUTTON) {\n            this.destroyEmojiPicker();\n        }\n    }\n\n    destroyEmojiPicker(): void {\n        this.emojiOverlayOpened = false;\n        this.pickerComponentRef?.destroy();\n        this.pickerComponentRef = null;\n    }\n\n    private async renderEmojiPicker() {\n        if (!this.PickerComponent) {\n            // See details here: https://github.com/scttcper/ngx-emoji-mart\n            this.PickerComponent = await import('@ctrl/ngx-emoji-mart').then((m) => m.PickerComponent);\n        }\n\n        this.pickerComponentRef = this.pickerContainer.createComponent(this.PickerComponent);\n        this.pickerComponentRef.instance.emoji = 'thumbsup';\n        this.pickerComponentRef.instance.darkMode = false;\n        this.pickerComponentRef.instance.color = '#0D99FF';\n        this.pickerComponentRef.instance.emojiSelect.subscribe((event: any) => this.onEmojiSelected(event));\n        this.cdr.detectChanges();\n    }\n}\n","<ng-container *ngIf=\"mode === EmojiPickerMode.BUTTON; else flatTpl\">\n    <dr-button\n        #emojiButton\n        theme=\"icon\"\n        icon=\"dr-icon-emoji-smiley\"\n        cdkOverlayOrigin\n        #trigger=\"cdkOverlayOrigin\"\n        (click)=\"toggleEmojiPicker()\"></dr-button>\n    <ng-template\n        cdkConnectedOverlay\n        [cdkConnectedOverlayOrigin]=\"trigger\"\n        [cdkConnectedOverlayOpen]=\"emojiOverlayOpened\"\n        [cdkConnectedOverlayPositions]=\"positions\"\n        [cdkConnectedOverlayPush]=\"true\"\n        [cdkConnectedOverlayViewportMargin]=\"16\"\n        [cdkConnectedOverlayHasBackdrop]=\"true\"\n        [cdkConnectedOverlayBackdropClass]=\"'emoji-modal-backdrop'\"\n        (backdropClick)=\"destroyEmojiPicker()\">\n        <div class=\"emoji-picker-popup\">\n            <ng-container *ngTemplateOutlet=\"flatTpl\"></ng-container>\n        </div>\n    </ng-template>\n</ng-container>\n\n<ng-template #flatTpl>\n    <!-- Placeholder where the emoji picker will be rendered -->\n    <ng-container #pickerContainer></ng-container>\n</ng-template>\n"]}
|