@energycap/components 0.32.26 → 0.32.27

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.
@@ -442,4 +442,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
442
442
  type: ViewChild,
443
443
  args: ['checkAndLabel', { static: true }]
444
444
  }] } });
445
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/menu/menu.component.ts","../../../../../../projects/components/src/lib/controls/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, Output, Renderer2, TemplateRef, ViewChild } from '@angular/core';\r\n\r\nimport { ScrollService } from '../../core/scroll.service';\r\nimport { WindowService } from '../../core/window.service';\r\nimport { NavItem } from '../navigation/nav-item';\r\n\r\nexport type MenuTemplateType = \"label\" | \"iconAndLabel\" | \"checkAndLabel\";\r\n\r\nexport type MenuHostElementClasses = 'bg-transparent';\r\n\r\nexport interface MenuItem<TValue=any, SItems=any> extends NavItem {\r\n  // Label is optional in NavItem but was not in MenuItem,\r\n  // overriding to be required\r\n  label: string,\r\n\r\n  items?: MenuItem<SItems>[],\r\n  checked?: boolean,\r\n  display?: 'default'|'heading'|'divider',\r\n  value?:TValue,\r\n  classList?:string,\r\n  disabled?: boolean,\r\n  hidden?: boolean,\r\n  readonly?: boolean\r\n  target?: '_self' | '_blank' | '_parent' | '_top',\r\n  externalLink?: boolean\r\n};\r\n\r\nexport const menuAnimationSpeed = 350;\r\n\r\n/**\r\n * Primitive Menu component that encapsulates known templates\r\n *\r\n * @export\r\n */\r\n@Component({\r\n    selector: 'ec-menu',\r\n    templateUrl: './menu.component.html',\r\n    styleUrls: ['./menu.component.scss']\r\n})\r\nexport class MenuComponent implements AfterContentInit, OnDestroy {\r\n\r\n\r\n    /**\r\n     * Input for the menu's template id\r\n     */\r\n    @Input() public id?: string;\r\n\r\n\r\n    /**\r\n     * Id bound to the host element\r\n     */\r\n    @HostBinding('attr.id') public attrId?: string;\r\n\r\n\r\n    /**\r\n     * Array of items to display\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public items: Array<MenuItem> = [];\r\n\r\n\r\n    /**\r\n     *  Selected item; annotates the item\r\n     *  when displayed with 'selected' class\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public selected: MenuItem | null = null;\r\n\r\n\r\n    /**\r\n     * The parent menu item. If defined, a header with the parent's label and a\r\n     * back button will be displayed.\r\n     */\r\n    @Input() public parent?: MenuItem;\r\n\r\n\r\n    /**\r\n     * Display template\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public templateType: MenuTemplateType = 'label';\r\n\r\n\t/**\r\n     * Optional custom template for the menu items. Must declare a template\r\n\t * input variable called \"item\" like so: <ng-template #templateName let-item>,\r\n\t * where item represents the menuItem.\r\n     * Will override the choice for templateType if provided.\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public customMenuTemplate?: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * The menu's title\r\n     */\r\n    @Input() public title?:string;\r\n\r\n\r\n    /**\r\n     * Show message when there are no items\r\n     */\r\n    @Input() public showNoItems?:boolean = false;\r\n\r\n    /**\r\n     * Text to show when menu is empty and showNoItems is true\r\n     */\r\n    @Input() public noDataText: string = 'NoItems_TC';\r\n\r\n\r\n    /**\r\n     * Controls whether keyboard navigation is enabled\r\n     */\r\n    @Input() public enableKeyNav?: boolean = false;\r\n\r\n\r\n    /**\r\n     * Item currently highlighted by keyboard navigation\r\n     */\r\n    @Input() public highlightedItem: MenuItem | null = null;\r\n\r\n    /**\r\n     * Tells the menu to maintain the selected/lastSelected item. Turning this off is useful for\r\n     * action type menus that are displayed on the screen at all times and you do not\r\n     * want the item to be selected when clicked.\r\n     */\r\n    @Input() public maintainSelectedItem: boolean = true;\r\n\r\n    /**\r\n     * Will prevent text-wrapping of menu items and truncate instead. Also turns on a tooltip for the menu item. Default: false;\r\n     */\r\n    @Input() public truncateItems: boolean = false;\r\n\r\n    /**\r\n     * When true, the space for the icon is preserved for menu items that do not have icons.\r\n     * Only applicable for iconAndLabel menus.\r\n     */\r\n    @Input() public preserveIconSpace: boolean = false;\r\n\r\n    /**\r\n     * Reference to the toggle button.  Set when menu is used as part of a DropdownComponent.\r\n     */\r\n    @Input() public dropdownToggleButton?: ElementRef;\r\n\r\n    /**\r\n     * Emitted when `selected` is changed. Emits the referenced object.\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Output() public selectedChanged: EventEmitter<MenuItem> = new EventEmitter<MenuItem>();\r\n\r\n\r\n    /**\r\n     * Emitted when the menu has a parent and back is clicked\r\n     * @memberof MenuComponent\r\n     */\r\n    @Output() public menuClosed: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n\r\n    /**\r\n     * The item template that is loaded into the component template\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    public internalizedTemplate!: TemplateRef<any>;\r\n\r\n    /**\r\n     * Index of the item currently highlighted using keyboard nav\r\n     */\r\n    public highlightedItemIndex: number = -1;\r\n\r\n\r\n    /**\r\n     * A reference to the menu label template\r\n     */\r\n     @ViewChild('label', { static: true }) private labelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * A reference to the menu icon and label template\r\n     */\r\n    @ViewChild('iconAndLabel', { static: true }) private iconAndLabelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * A reference to the menu check and label template\r\n     */\r\n    @ViewChild('checkAndLabel', { static: true }) private checkAndLabelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * Contains the function used to remove the even listener from the renderer\r\n     */\r\n    private removeKeydownListener?: () => void;\r\n\r\n    /**\r\n     * Last item this.selected was set to via selectItem().\r\n     * This isn't necessarily the same as this.selected, because this.selected is an input property\r\n     * and could have been changed by a consumer through some means other than selectItem().\r\n     * This allows us to prevent double-calls to selectItem() with the same input.\r\n     */\r\n    private lastSelected: MenuItem | null = null;\r\n\r\n\r\n    constructor(\r\n        private el: ElementRef,\r\n        private renderer: Renderer2,\r\n        private windowService: WindowService,\r\n        private scrollService: ScrollService\r\n    ){\r\n    }\r\n\r\n    /**\r\n     * Sets & displays the interalized template based on\r\n     * the set template.\r\n     * @see { @link https://angular.io/guide/lifecycle-hooks|Angular Lifecycle Hooks}\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    public ngAfterContentInit(): void {\r\n        switch (this.templateType) {\r\n            case (\"label\"):\r\n                this.internalizedTemplate = this.iconAndLabelTemplate;\r\n                break;\r\n            case (\"iconAndLabel\"):\r\n                this.internalizedTemplate = this.iconAndLabelTemplate;\r\n                break;\r\n            case (\"checkAndLabel\"):\r\n                this.internalizedTemplate = this.checkAndLabelTemplate;\r\n                break;\r\n            default:\r\n                throw new Error(`Invalid templateType for MenuComponent. Please use either: 'label', 'iconAndLabel' or 'checkAndLabel'`)\r\n        }\r\n\r\n        //if the consumer provided a menuItemTemplate, override the internalizedTemplate with that.\r\n        if(this.customMenuTemplate) {\r\n            this.internalizedTemplate = this.customMenuTemplate;\r\n        }\r\n\r\n        if (this.id) {\r\n            this.attrId = this.id;\r\n        }\r\n\r\n        this.setItemIds();\r\n\r\n        if (this.highlightedItem && this.items.length) {\r\n            this.highlightedItemIndex = this.items.findIndex(item => { return this.highlightedItem === item});\r\n        }\r\n\r\n        this.addKeydownListener();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        // Remove the listener when the component is destroyed\r\n        if (this.removeKeydownListener) {\r\n            this.removeKeydownListener();\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * When a menu item is selected, open a child menu if the item has items, call\r\n     * the item's click method if defined, or emit the selected item.\r\n     *\r\n     * @param item The selected item\r\n     * @memberof MenuComponent\r\n     */\r\n    public selectItem(event: Event, item: MenuItem, isKeyEvent?: boolean): void {\r\n        event.stopPropagation();\r\n\r\n        //In the case that the user clicks an item, selectItem() will be called from the click handler\r\n        //and through onRouterLinkActivated. Only one of these will make it through this if statement\r\n        //because the first one will set this.lastSelected = item.\r\n        if(!item.disabled && !item.readonly && this.lastSelected !== item) {\r\n\r\n            if (!item.url) {\r\n                if (item.onClick) {\r\n                    item.onClick(item, false);\r\n                }\r\n\r\n                if (item.items) {\r\n                    this.toggleChildMenu(true);\r\n                } else {\r\n                    this.onSelection(item);\r\n                }\r\n            // We need to manually handle the url navigation if the keyboard was used\r\n            } else if (isKeyEvent || (<Element>event.target)?.tagName === 'LI') {\r\n                if (item.target) {\r\n                    window.open(item.url, item.target);\r\n                } else {\r\n                    this.windowService.navigateToUrl(item.url);\r\n                }\r\n                // Emit so upstream components know an item was selected\r\n                this.onSelection(item);\r\n            } else {\r\n                this.onSelection(item);\r\n            }\r\n\r\n            if (this.maintainSelectedItem) {\r\n                this.selected = item;\r\n                this.lastSelected = item;\r\n            } else {\r\n                this.selected = null;\r\n                this.lastSelected = null;\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Close the current menu and open the parent menu\r\n     * @memberof MenuComponent\r\n     */\r\n    public back(event: Event): void {\r\n        event.stopPropagation();\r\n        if (this.parent && this.parent.onClick) {\r\n            this.parent.onClick(null, true);\r\n        }\r\n        this.menuClosed.emit();\r\n    }\r\n\r\n\r\n    /**\r\n     * Emit the selected item\r\n     * @param item The selected item\r\n     */\r\n    public onSelection(item: MenuItem): void {\r\n        if (item.display !== 'heading') {\r\n            this.selectedChanged.emit(item);\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Open or close the child menu. When the child menu closes, the selected\r\n     * item is reset.\r\n     * @memberof MenuComponent\r\n     */\r\n    public toggleChildMenu(open:boolean):void {\r\n        let navEl = this.el.nativeElement.querySelector('nav');\r\n\r\n        if (open) {\r\n            // Remove the listener on the parent menu when a child menu is opened\r\n            // This is to avoid interference between the parent and child menus\r\n            if (this.removeKeydownListener) {\r\n                this.removeKeydownListener();\r\n            }\r\n\r\n            let height:number = navEl.offsetHeight;\r\n            let width:number = navEl.offsetWidth;\r\n\r\n            // In order to animate the child menu, we need to set height on the nav element\r\n            // so we can absolutely position the two menus and maintain the current menu's height\r\n            this.renderer.setStyle(navEl, 'height', `${height}px`);\r\n            this.renderer.setStyle(navEl, 'width', `${width}px`);\r\n\r\n            this.renderer.addClass(this.el.nativeElement, 'open');\r\n            setTimeout(() => {\r\n                this.renderer.addClass(this.el.nativeElement, 'open-active');\r\n            })\r\n        } else {\r\n            // Re-add the listener once the child menu closes\r\n            this.addKeydownListener();\r\n\r\n            this.renderer.removeClass(this.el.nativeElement, 'open-active');\r\n            setTimeout(() => {\r\n                this.renderer.removeClass(this.el.nativeElement, 'open');\r\n\r\n                // Reset the nav element's height to auto\r\n                this.renderer.setStyle(navEl, 'height', '100%');\r\n                this.selected = null;\r\n            }, menuAnimationSpeed)\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Handle key presses to navigate the menu\r\n     */\r\n    public keyNavigate(event: KeyboardEvent) {\r\n        if (this.enableKeyNav && event.target === this.dropdownToggleButton?.nativeElement) {\r\n            switch (event.key) {\r\n                case 'ArrowUp':\r\n                case 'Up':\r\n                case 'ArrowDown':\r\n                case 'Down':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    this.moveHighlightedUpOrDown(event);\r\n                    break;\r\n\r\n                case 'ArrowRight':\r\n                case 'Right':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    // Select the item if it has child items\r\n                    if (this.highlightedItem && this.highlightedItem.items) {\r\n                        this.selectItem(event, this.highlightedItem, true);\r\n                    }\r\n                    break;\r\n\r\n                case 'ArrowLeft':\r\n                case 'Left':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    // Close the menu if it is a child menu\r\n                    if (this.parent) {\r\n                        this.back(event);\r\n                    }\r\n                    break;\r\n\r\n                case ' ':\r\n                case 'Spacebar':\r\n                case 'Enter':\r\n                    // Prevent 'enter' from doing whatever it does on the currently focused element\r\n                    event.preventDefault();\r\n\r\n                    if (this.highlightedItemIndex > -1 && this.highlightedItem) {\r\n                        this.selectItem(event, this.highlightedItem, true);\r\n                    // If the header is highlighted\r\n                    } else if (this.highlightedItemIndex === -1) {\r\n\r\n                        // Close the menu if it's a child\r\n                        if (this.parent) {\r\n                            this.back(event);\r\n                        }\r\n                    }\r\n                    break;\r\n\r\n                default:\r\n                    return;\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Scroll to the item currently marked as 'is-selected'. Wait a tick for the\r\n     * NgClassDirecitve or NavItemActiveDirective to respond to the model changes\r\n     * and update the view.\r\n     */\r\n    public scrollToSelectedItem(): void {\r\n        window.setTimeout(() => {\r\n            const linkSelector = `li.is-selected`;\r\n            this.scrollService.scrollToItem(`#${this.id}_list`, linkSelector);\r\n        });\r\n    }\r\n\r\n    private moveHighlightedUpOrDown(event: KeyboardEvent) {\r\n        switch (event.key) {\r\n            case 'ArrowUp':\r\n            case 'Up':\r\n                if (this.highlightedItemIndex > -1) {\r\n                    this.highlightedItemIndex--;\r\n                    // Skip any in-menu heading items\r\n                    if (this.highlightedItemIndex > -1 && this.items[this.highlightedItemIndex].display === 'heading') {\r\n                        this.highlightedItemIndex--;\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case 'ArrowDown':\r\n            case 'Down':\r\n                if (this.highlightedItemIndex < this.items.length - 1) {\r\n                    this.highlightedItemIndex++;\r\n                    // Skip any in-menu heading items\r\n                    if (this.highlightedItemIndex < this.items.length - 1 && this.items[this.highlightedItemIndex].display === 'heading') {\r\n                        this.highlightedItemIndex++;\r\n                    }\r\n                }\r\n                break;\r\n\r\n            default:\r\n                return;\r\n        }\r\n\r\n        if (this.highlightedItemIndex > -1) {\r\n            // Store the item at the current highlight index\r\n            this.highlightedItem = this.items[this.highlightedItemIndex];\r\n        } else {\r\n            this.highlightedItem = null;\r\n        }\r\n        this.scrollToHighlightedItem();\r\n    }\r\n\r\n    /**\r\n\t * Scroll to the specified menu item.\r\n   * If no item is provided, it will scroll to the first item.\r\n\t *\r\n   * @param item The menu item to scroll to.\r\n\t * @memberof MenuComponent\r\n\t */\r\n\tprivate scrollMenu(item?: MenuItem | null): void {\r\n\t\tif (this.items.length > 0) {\r\n            item = item ? item : this.items[0];\r\n            let itemIndex = this.findItemIndex(item);\r\n\r\n\t\t\tif (this.id) {\r\n                let itemSelector = item.id ? `#${item.id}` : `#${this.id}_item${itemIndex}`;\r\n\t\t\t\tthis.scrollService.scrollItemCentered(`#${this.id}_list`, itemSelector);\r\n\t\t\t}\r\n\t\t}\r\n    }\r\n\r\n    private scrollToHighlightedItem(): void {\r\n        this.scrollMenu(this.highlightedItem);\r\n    }\r\n\r\n    /**\r\n\t * Find a given item's index in the filtered items array.\r\n\t *\r\n\t * Returns -1 if not found\r\n\t * @param itemToFind The matching item to find in the items array.\r\n\t * @memberof MenuComponent\r\n\t */\r\n\tprivate findItemIndex(itemToFind?: MenuItem | null): number {\r\n        if (itemToFind) {\r\n            return this.items.findIndex(item => {\r\n                return item.label === (<MenuItem>itemToFind).label;\r\n            });\r\n        } else {\r\n            return -1;\r\n        }\r\n    }\r\n\r\n    private addKeydownListener(): void {\r\n        // Only attempt to add the listener if keyboard nav is enabled\r\n        if (this.enableKeyNav) {\r\n            // renderer.listen adds the listener and returns a function to remove it from the renderer.\r\n            // The listener remains active until this function is called.\r\n            this.removeKeydownListener = this.renderer.listen('document', 'keydown', (event: KeyboardEvent) => this.keyNavigate(event));\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the menu item ids using its index if item doesn't already have one\r\n     */\r\n    private setItemIds(): void {\r\n        if (this.items) {\r\n            this.items.forEach((item, index) => {\r\n                item.id = item.id ? item.id : this.id + '_item' + index;\r\n            });\r\n        }\r\n    }\r\n}\r\n","<nav>\r\n    <div class=\"parent\"\r\n         [class.no-data]=\"showNoItems && (!items || items.length === 0)\">\r\n        <header id=\"{{id}}_header\"\r\n                class=\"text-heading-3 p-1\"\r\n                [class.is-selected]=\"highlightedItemIndex === -1\"\r\n                *ngIf=\"parent\"\r\n                (click)=\"back($event)\">\r\n            <div class=\"item-wrapper\">\r\n                <i class=\"ec-icon icon-angle-down rotate-90 flex-shrink\"></i>\r\n                <span class=\"label text-truncate flex-grow\">{{parent?.label}}</span>\r\n            </div>\r\n        </header>\r\n\r\n        <ul id=\"{{id}}_list\" class=\"py-1\">\r\n            <li *ngFor=\"let item of items; index as i\"\r\n                id=\"{{item.id || id + '_item' + i}}\"\r\n                class=\"{{item.display || 'item'}} {{item.classList}}\"\r\n                [attr.disabled]=\"item.disabled\"\r\n                [hidden]=\"item.hidden\"\r\n                ecNavItemActive=\"is-selected\"\r\n                [ecNavItemActiveQueryParams]=\"item.queryParams\"\r\n                [ecNavItemActiveUrl]=\"item.url\"\r\n                [ecNavItemActiveExactMatch]='item.isActiveExactMatch'\r\n                (routerLinkActivated)=\"selectItem($event, item)\"\r\n                [ngClass]=\"{'is-highlighted':(selected === item && item?.display !== 'heading') || highlightedItem === item, 'is-link': item.url, 'is-disabled': item.disabled, 'is-readonly': item.readonly, 'is-checked': item.checked, 'text-heading-3': item?.display === 'heading'}\"\r\n                (click)=\"selectItem($event, item)\">\r\n\r\n                <a *ngIf=\"item.url && !item.externalLink\"\r\n                   id=\"{{item.id}}_link\"\r\n                   title=\"{{truncateItems ? item.label : ''}}\"\r\n                   class=\"item-wrapper\"\r\n                   [routerLink]=\"item.url\"\r\n                   [queryParams]=\"item.queryParams || null\"\r\n                   target=\"{{item.target || '_self'}}\">\r\n\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </a>\r\n\r\n                <a *ngIf=\"item.url && item.externalLink\"\r\n                   id=\"{{item.id}}_link\"\r\n                   title=\"{{truncateItems ? item.label : ''}}\"\r\n                   class=\"item-wrapper\"\r\n                   href=\"{{item.url}}\"\r\n                   target=\"{{item.target || '_self'}}\">\r\n\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </a>\r\n\r\n                <div *ngIf=\"!item.url\"\r\n                     title=\"{{truncateItems ? item.label : ''}}\"\r\n                     class=\"item-wrapper\">\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </div>\r\n            </li>\r\n        </ul>\r\n\r\n        <p class=\"no-data-message\">{{noDataText | translate}}</p>\r\n    </div>\r\n\r\n    <!-- Child menu (Rendered to the right) -->\r\n    <ec-menu *ngIf=\"selected?.items\"\r\n             id=\"{{id}}_child\"\r\n             class=\"child\"\r\n             [parent]=\"selected\"\r\n             [items]=\"selected?.items\"\r\n             [showNoItems]=\"true\"\r\n             [templateType]=\"templateType\"\r\n             [enableKeyNav]=\"true\"\r\n             [truncateItems]=\"truncateItems\"\r\n             (selectedChanged)=\"onSelection($event)\"\r\n             (menuClosed)=\"toggleChildMenu(false)\">\r\n    </ec-menu>\r\n</nav>\r\n\r\n<!-- 'label' Item Template -->\r\n<ng-template #label\r\n             let-item>\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>\r\n\r\n<!-- 'checkAndLabel' Item Template -->\r\n<ng-template #checkAndLabel\r\n             let-item>\r\n\r\n    <i class=\"ec-icon icon-check ec-icon-sm\" *ngIf=\"item.display !== 'heading'\"></i>\r\n\r\n    <i class=\"ec-icon {{item.icon}} ml-2\" *ngIf=\"item.icon\"></i>\r\n\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>\r\n\r\n<!-- 'iconAndLabel' Item Template -->\r\n<ng-template #iconAndLabel\r\n             let-item>\r\n    <!-- If menuItem.icon exists and is not blank, show the icon in the menu -->\r\n    <i class=\"ec-icon {{item.icon}}\" *ngIf=\"(item.icon && item.icon !== '') || preserveIconSpace\"></i>\r\n\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>"]}
445
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/controls/menu/menu.component.ts","../../../../../../projects/components/src/lib/controls/menu/menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAc,YAAY,EAAE,WAAW,EAAE,KAAK,EAAa,MAAM,EAA0B,SAAS,EAAE,MAAM,eAAe,CAAC;;;;;;;;AA0B/J,CAAC;AAEF,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAG,CAAC;AAEtC;;;;GAIG;AAMH,MAAM,OAAO,aAAa;IAwKtB,YACY,EAAc,EACd,QAAmB,EACnB,aAA4B,EAC5B,aAA4B;QAH5B,OAAE,GAAF,EAAE,CAAY;QACd,aAAQ,GAAR,QAAQ,CAAW;QACnB,kBAAa,GAAb,aAAa,CAAe;QAC5B,kBAAa,GAAb,aAAa,CAAe;QA7JxC;;;;WAIG;QACa,UAAK,GAAoB,EAAE,CAAC;QAG5C;;;;;WAKG;QACa,aAAQ,GAAoB,IAAI,CAAC;QAUjD;;;;WAIG;QACa,iBAAY,GAAqB,OAAO,CAAC;QAmBzD;;WAEG;QACa,gBAAW,GAAY,KAAK,CAAC;QAE7C;;WAEG;QACa,eAAU,GAAW,YAAY,CAAC;QAGlD;;WAEG;QACa,iBAAY,GAAa,KAAK,CAAC;QAG/C;;WAEG;QACa,oBAAe,GAAoB,IAAI,CAAC;QAExD;;;;WAIG;QACa,yBAAoB,GAAY,IAAI,CAAC;QAErD;;WAEG;QACa,kBAAa,GAAY,KAAK,CAAC;QAE/C;;;WAGG;QACa,sBAAiB,GAAY,KAAK,CAAC;QAOnD;;;;WAIG;QACc,oBAAe,GAA2B,IAAI,YAAY,EAAY,CAAC;QAGxF;;;WAGG;QACc,eAAU,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAU3E;;WAEG;QACI,yBAAoB,GAAW,CAAC,CAAC,CAAC;QA0BzC;;;;;WAKG;QACK,iBAAY,GAAoB,IAAI,CAAC;IAS7C,CAAC;IAED;;;;;;OAMG;IACI,kBAAkB;QACrB,QAAQ,IAAI,CAAC,YAAY,EAAE;YACvB,KAAK,CAAC,OAAO,CAAC;gBACV,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBACtD,MAAM;YACV,KAAK,CAAC,cAAc,CAAC;gBACjB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBACtD,MAAM;YACV,KAAK,CAAC,eAAe,CAAC;gBAClB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,qBAAqB,CAAC;gBACvD,MAAM;YACV;gBACI,MAAM,IAAI,KAAK,CAAC,uGAAuG,CAAC,CAAA;SAC/H;QAED,2FAA2F;QAC3F,IAAG,IAAI,CAAC,kBAAkB,EAAE;YACxB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,kBAAkB,CAAC;SACvD;QAED,IAAI,IAAI,CAAC,EAAE,EAAE;YACT,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC;SACzB;QAED,IAAI,CAAC,UAAU,EAAE,CAAC;QAElB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YAC3C,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,GAAG,OAAO,IAAI,CAAC,eAAe,KAAK,IAAI,CAAA,CAAA,CAAC,CAAC,CAAC;SACrG;QAED,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAEM,WAAW;QACd,sDAAsD;QACtD,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAChC;IACL,CAAC;IAGD;;;;;;OAMG;IACI,UAAU,CAAC,KAAY,EAAE,IAAc,EAAE,UAAoB;QAChE,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,8FAA8F;QAC9F,6FAA6F;QAC7F,0DAA0D;QAC1D,IAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,EAAE;YAE/D,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;gBACX,IAAI,IAAI,CAAC,OAAO,EAAE;oBACd,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;iBAC7B;gBAED,IAAI,IAAI,CAAC,KAAK,EAAE;oBACZ,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;iBAC9B;qBAAM;oBACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;iBAC1B;gBACL,yEAAyE;aACxE;iBAAM,IAAI,UAAU,IAAc,KAAK,CAAC,MAAO,EAAE,OAAO,KAAK,IAAI,EAAE;gBAChE,IAAI,IAAI,CAAC,MAAM,EAAE;oBACb,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;iBACtC;qBAAM;oBACH,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC9C;gBACD,wDAAwD;gBACxD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aAC1B;iBAAM;gBACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aAC1B;YAED,IAAI,IAAI,CAAC,oBAAoB,EAAE;gBAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC5B;iBAAM;gBACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC5B;SACJ;IACL,CAAC;IAED;;;OAGG;IACI,IAAI,CAAC,KAAY;QACpB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE;YACpC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD;;;OAGG;IACI,WAAW,CAAC,IAAc;QAC7B,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACnC;IACL,CAAC;IAGD;;;;OAIG;IACI,eAAe,CAAC,IAAY;QAC/B,IAAI,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAEvD,IAAI,IAAI,EAAE;YACN,qEAAqE;YACrE,mEAAmE;YACnE,IAAI,IAAI,CAAC,qBAAqB,EAAE;gBAC5B,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAChC;YAED,IAAI,MAAM,GAAU,KAAK,CAAC,YAAY,CAAC;YACvC,IAAI,KAAK,GAAU,KAAK,CAAC,WAAW,CAAC;YAErC,+EAA+E;YAC/E,qFAAqF;YACrF,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,IAAI,CAAC,CAAC;YACvD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC,CAAC;YAErD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;YACtD,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YACjE,CAAC,CAAC,CAAA;SACL;aAAM;YACH,iDAAiD;YACjD,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAE1B,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;YAChE,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;gBAEzD,yCAAyC;gBACzC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;gBAChD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACzB,CAAC,EAAE,kBAAkB,CAAC,CAAA;SACzB;IACL,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAoB;QACnC,IAAI,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,oBAAoB,EAAE,aAAa,EAAE;YAChF,QAAQ,KAAK,CAAC,GAAG,EAAE;gBACf,KAAK,SAAS,CAAC;gBACf,KAAK,IAAI,CAAC;gBACV,KAAK,WAAW,CAAC;gBACjB,KAAK,MAAM;oBACP,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;oBACpC,MAAM;gBAEV,KAAK,YAAY,CAAC;gBAClB,KAAK,OAAO;oBACR,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,wCAAwC;oBACxC,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE;wBACpD,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;qBACtD;oBACD,MAAM;gBAEV,KAAK,WAAW,CAAC;gBACjB,KAAK,MAAM;oBACP,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,uCAAuC;oBACvC,IAAI,IAAI,CAAC,MAAM,EAAE;wBACb,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBACpB;oBACD,MAAM;gBAEV,KAAK,GAAG,CAAC;gBACT,KAAK,UAAU,CAAC;gBAChB,KAAK,OAAO;oBACR,+EAA+E;oBAC/E,KAAK,CAAC,cAAc,EAAE,CAAC;oBAEvB,IAAI,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,eAAe,EAAE;wBACxD,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;wBACvD,+BAA+B;qBAC9B;yBAAM,IAAI,IAAI,CAAC,oBAAoB,KAAK,CAAC,CAAC,EAAE;wBAEzC,iCAAiC;wBACjC,IAAI,IAAI,CAAC,MAAM,EAAE;4BACb,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;yBACpB;qBACJ;oBACD,MAAM;gBAEV;oBACI,OAAO;aACd;SACJ;IACL,CAAC;IAED;;;;OAIG;IACI,oBAAoB;QACvB,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YACnB,MAAM,YAAY,GAAG,gBAAgB,CAAC;YACtC,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,uBAAuB,CAAC,KAAoB;QAChD,QAAQ,KAAK,CAAC,GAAG,EAAE;YACf,KAAK,SAAS,CAAC;YACf,KAAK,IAAI;gBACL,IAAI,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,EAAE;oBAChC,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC5B,iCAAiC;oBACjC,IAAI,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,OAAO,KAAK,SAAS,EAAE;wBAC/F,IAAI,CAAC,oBAAoB,EAAE,CAAC;qBAC/B;iBACJ;gBACD,MAAM;YAEV,KAAK,WAAW,CAAC;YACjB,KAAK,MAAM;gBACP,IAAI,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;oBACnD,IAAI,CAAC,oBAAoB,EAAE,CAAC;oBAC5B,iCAAiC;oBACjC,IAAI,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,OAAO,KAAK,SAAS,EAAE;wBAClH,IAAI,CAAC,oBAAoB,EAAE,CAAC;qBAC/B;iBACJ;gBACD,MAAM;YAEV;gBACI,OAAO;SACd;QAED,IAAI,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,EAAE;YAChC,gDAAgD;YAChD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;SAChE;aAAM;YACH,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC/B;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACnC,CAAC;IAED;;;;;;OAMA;IACK,UAAU,CAAC,IAAsB;QACxC,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACjB,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAElD,IAAI,IAAI,CAAC,EAAE,EAAE;gBACA,IAAI,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAE,QAAQ,SAAS,EAAE,CAAC;gBACxF,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,IAAI,CAAC,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;aACxE;SACD;IACC,CAAC;IAEO,uBAAuB;QAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC1C,CAAC;IAED;;;;;;OAMA;IACK,aAAa,CAAC,UAA4B;QAC3C,IAAI,UAAU,EAAE;YACZ,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAC/B,OAAO,IAAI,CAAC,KAAK,KAAgB,UAAW,CAAC,KAAK,CAAC;YACvD,CAAC,CAAC,CAAC;SACN;aAAM;YACH,OAAO,CAAC,CAAC,CAAC;SACb;IACL,CAAC;IAEO,kBAAkB;QACtB,8DAA8D;QAC9D,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,2FAA2F;YAC3F,6DAA6D;YAC7D,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,KAAoB,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;SAC/H;IACL,CAAC;IAED;;OAEG;IACK,UAAU;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBAC/B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,OAAO,GAAG,KAAK,CAAC;YAC5D,CAAC,CAAC,CAAC;SACN;IACL,CAAC;;0GAxfQ,aAAa;8FAAb,aAAa,k9BCxC1B,08JA+Gc,upIDvED,aAAa;2FAAb,aAAa;kBALzB,SAAS;+BACI,SAAS;iLAUH,EAAE;sBAAjB,KAAK;gBAMyB,MAAM;sBAApC,WAAW;uBAAC,SAAS;gBAQN,KAAK;sBAApB,KAAK;gBASU,QAAQ;sBAAvB,KAAK;gBAOU,MAAM;sBAArB,KAAK;gBAQU,YAAY;sBAA3B,KAAK;gBAUU,kBAAkB;sBAAjC,KAAK;gBAMU,KAAK;sBAApB,KAAK;gBAMU,WAAW;sBAA1B,KAAK;gBAKU,UAAU;sBAAzB,KAAK;gBAMU,YAAY;sBAA3B,KAAK;gBAMU,eAAe;sBAA9B,KAAK;gBAOU,oBAAoB;sBAAnC,KAAK;gBAKU,aAAa;sBAA5B,KAAK;gBAMU,iBAAiB;sBAAhC,KAAK;gBAKU,oBAAoB;sBAAnC,KAAK;gBAOW,eAAe;sBAA/B,MAAM;gBAOU,UAAU;sBAA1B,MAAM;gBAmBwC,aAAa;sBAA1D,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAMgB,oBAAoB;sBAAxE,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAMW,qBAAqB;sBAA1E,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { AfterContentInit, Component, ElementRef, EventEmitter, HostBinding, Input, OnDestroy, Output, Renderer2, TemplateRef, ViewChild } from '@angular/core';\r\n\r\nimport { ScrollService } from '../../core/scroll.service';\r\nimport { WindowService } from '../../core/window.service';\r\nimport { LinkTarget } from '../../display/tags/tag';\r\nimport { NavItem } from '../navigation/nav-item';\r\n\r\nexport type MenuTemplateType = \"label\" | \"iconAndLabel\" | \"checkAndLabel\";\r\n\r\nexport type MenuHostElementClasses = 'bg-transparent';\r\n\r\nexport interface MenuItem<TValue=any, SItems=any> extends NavItem {\r\n  // Label is optional in NavItem but was not in MenuItem,\r\n  // overriding to be required\r\n  label: string,\r\n\r\n  items?: MenuItem<SItems>[],\r\n  checked?: boolean,\r\n  display?: 'default'|'heading'|'divider',\r\n  value?:TValue,\r\n  classList?:string,\r\n  disabled?: boolean,\r\n  hidden?: boolean,\r\n  readonly?: boolean\r\n  target?: LinkTarget,\r\n  externalLink?: boolean\r\n};\r\n\r\nexport const menuAnimationSpeed = 350;\r\n\r\n/**\r\n * Primitive Menu component that encapsulates known templates\r\n *\r\n * @export\r\n */\r\n@Component({\r\n    selector: 'ec-menu',\r\n    templateUrl: './menu.component.html',\r\n    styleUrls: ['./menu.component.scss']\r\n})\r\nexport class MenuComponent implements AfterContentInit, OnDestroy {\r\n\r\n\r\n    /**\r\n     * Input for the menu's template id\r\n     */\r\n    @Input() public id?: string;\r\n\r\n\r\n    /**\r\n     * Id bound to the host element\r\n     */\r\n    @HostBinding('attr.id') public attrId?: string;\r\n\r\n\r\n    /**\r\n     * Array of items to display\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public items: Array<MenuItem> = [];\r\n\r\n\r\n    /**\r\n     *  Selected item; annotates the item\r\n     *  when displayed with 'selected' class\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public selected: MenuItem | null = null;\r\n\r\n\r\n    /**\r\n     * The parent menu item. If defined, a header with the parent's label and a\r\n     * back button will be displayed.\r\n     */\r\n    @Input() public parent?: MenuItem;\r\n\r\n\r\n    /**\r\n     * Display template\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public templateType: MenuTemplateType = 'label';\r\n\r\n\t/**\r\n     * Optional custom template for the menu items. Must declare a template\r\n\t * input variable called \"item\" like so: <ng-template #templateName let-item>,\r\n\t * where item represents the menuItem.\r\n     * Will override the choice for templateType if provided.\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Input() public customMenuTemplate?: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * The menu's title\r\n     */\r\n    @Input() public title?:string;\r\n\r\n\r\n    /**\r\n     * Show message when there are no items\r\n     */\r\n    @Input() public showNoItems?:boolean = false;\r\n\r\n    /**\r\n     * Text to show when menu is empty and showNoItems is true\r\n     */\r\n    @Input() public noDataText: string = 'NoItems_TC';\r\n\r\n\r\n    /**\r\n     * Controls whether keyboard navigation is enabled\r\n     */\r\n    @Input() public enableKeyNav?: boolean = false;\r\n\r\n\r\n    /**\r\n     * Item currently highlighted by keyboard navigation\r\n     */\r\n    @Input() public highlightedItem: MenuItem | null = null;\r\n\r\n    /**\r\n     * Tells the menu to maintain the selected/lastSelected item. Turning this off is useful for\r\n     * action type menus that are displayed on the screen at all times and you do not\r\n     * want the item to be selected when clicked.\r\n     */\r\n    @Input() public maintainSelectedItem: boolean = true;\r\n\r\n    /**\r\n     * Will prevent text-wrapping of menu items and truncate instead. Also turns on a tooltip for the menu item. Default: false;\r\n     */\r\n    @Input() public truncateItems: boolean = false;\r\n\r\n    /**\r\n     * When true, the space for the icon is preserved for menu items that do not have icons.\r\n     * Only applicable for iconAndLabel menus.\r\n     */\r\n    @Input() public preserveIconSpace: boolean = false;\r\n\r\n    /**\r\n     * Reference to the toggle button.  Set when menu is used as part of a DropdownComponent.\r\n     */\r\n    @Input() public dropdownToggleButton?: ElementRef;\r\n\r\n    /**\r\n     * Emitted when `selected` is changed. Emits the referenced object.\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    @Output() public selectedChanged: EventEmitter<MenuItem> = new EventEmitter<MenuItem>();\r\n\r\n\r\n    /**\r\n     * Emitted when the menu has a parent and back is clicked\r\n     * @memberof MenuComponent\r\n     */\r\n    @Output() public menuClosed: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n\r\n    /**\r\n     * The item template that is loaded into the component template\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    public internalizedTemplate!: TemplateRef<any>;\r\n\r\n    /**\r\n     * Index of the item currently highlighted using keyboard nav\r\n     */\r\n    public highlightedItemIndex: number = -1;\r\n\r\n\r\n    /**\r\n     * A reference to the menu label template\r\n     */\r\n     @ViewChild('label', { static: true }) private labelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * A reference to the menu icon and label template\r\n     */\r\n    @ViewChild('iconAndLabel', { static: true }) private iconAndLabelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * A reference to the menu check and label template\r\n     */\r\n    @ViewChild('checkAndLabel', { static: true }) private checkAndLabelTemplate!: TemplateRef<any>;\r\n\r\n\r\n    /**\r\n     * Contains the function used to remove the even listener from the renderer\r\n     */\r\n    private removeKeydownListener?: () => void;\r\n\r\n    /**\r\n     * Last item this.selected was set to via selectItem().\r\n     * This isn't necessarily the same as this.selected, because this.selected is an input property\r\n     * and could have been changed by a consumer through some means other than selectItem().\r\n     * This allows us to prevent double-calls to selectItem() with the same input.\r\n     */\r\n    private lastSelected: MenuItem | null = null;\r\n\r\n\r\n    constructor(\r\n        private el: ElementRef,\r\n        private renderer: Renderer2,\r\n        private windowService: WindowService,\r\n        private scrollService: ScrollService\r\n    ){\r\n    }\r\n\r\n    /**\r\n     * Sets & displays the interalized template based on\r\n     * the set template.\r\n     * @see { @link https://angular.io/guide/lifecycle-hooks|Angular Lifecycle Hooks}\r\n     *\r\n     * @memberof MenuComponent\r\n     */\r\n    public ngAfterContentInit(): void {\r\n        switch (this.templateType) {\r\n            case (\"label\"):\r\n                this.internalizedTemplate = this.iconAndLabelTemplate;\r\n                break;\r\n            case (\"iconAndLabel\"):\r\n                this.internalizedTemplate = this.iconAndLabelTemplate;\r\n                break;\r\n            case (\"checkAndLabel\"):\r\n                this.internalizedTemplate = this.checkAndLabelTemplate;\r\n                break;\r\n            default:\r\n                throw new Error(`Invalid templateType for MenuComponent. Please use either: 'label', 'iconAndLabel' or 'checkAndLabel'`)\r\n        }\r\n\r\n        //if the consumer provided a menuItemTemplate, override the internalizedTemplate with that.\r\n        if(this.customMenuTemplate) {\r\n            this.internalizedTemplate = this.customMenuTemplate;\r\n        }\r\n\r\n        if (this.id) {\r\n            this.attrId = this.id;\r\n        }\r\n\r\n        this.setItemIds();\r\n\r\n        if (this.highlightedItem && this.items.length) {\r\n            this.highlightedItemIndex = this.items.findIndex(item => { return this.highlightedItem === item});\r\n        }\r\n\r\n        this.addKeydownListener();\r\n    }\r\n\r\n    public ngOnDestroy(): void {\r\n        // Remove the listener when the component is destroyed\r\n        if (this.removeKeydownListener) {\r\n            this.removeKeydownListener();\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * When a menu item is selected, open a child menu if the item has items, call\r\n     * the item's click method if defined, or emit the selected item.\r\n     *\r\n     * @param item The selected item\r\n     * @memberof MenuComponent\r\n     */\r\n    public selectItem(event: Event, item: MenuItem, isKeyEvent?: boolean): void {\r\n        event.stopPropagation();\r\n\r\n        //In the case that the user clicks an item, selectItem() will be called from the click handler\r\n        //and through onRouterLinkActivated. Only one of these will make it through this if statement\r\n        //because the first one will set this.lastSelected = item.\r\n        if(!item.disabled && !item.readonly && this.lastSelected !== item) {\r\n\r\n            if (!item.url) {\r\n                if (item.onClick) {\r\n                    item.onClick(item, false);\r\n                }\r\n\r\n                if (item.items) {\r\n                    this.toggleChildMenu(true);\r\n                } else {\r\n                    this.onSelection(item);\r\n                }\r\n            // We need to manually handle the url navigation if the keyboard was used\r\n            } else if (isKeyEvent || (<Element>event.target)?.tagName === 'LI') {\r\n                if (item.target) {\r\n                    window.open(item.url, item.target);\r\n                } else {\r\n                    this.windowService.navigateToUrl(item.url);\r\n                }\r\n                // Emit so upstream components know an item was selected\r\n                this.onSelection(item);\r\n            } else {\r\n                this.onSelection(item);\r\n            }\r\n\r\n            if (this.maintainSelectedItem) {\r\n                this.selected = item;\r\n                this.lastSelected = item;\r\n            } else {\r\n                this.selected = null;\r\n                this.lastSelected = null;\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Close the current menu and open the parent menu\r\n     * @memberof MenuComponent\r\n     */\r\n    public back(event: Event): void {\r\n        event.stopPropagation();\r\n        if (this.parent && this.parent.onClick) {\r\n            this.parent.onClick(null, true);\r\n        }\r\n        this.menuClosed.emit();\r\n    }\r\n\r\n\r\n    /**\r\n     * Emit the selected item\r\n     * @param item The selected item\r\n     */\r\n    public onSelection(item: MenuItem): void {\r\n        if (item.display !== 'heading') {\r\n            this.selectedChanged.emit(item);\r\n        }\r\n    }\r\n\r\n\r\n    /**\r\n     * Open or close the child menu. When the child menu closes, the selected\r\n     * item is reset.\r\n     * @memberof MenuComponent\r\n     */\r\n    public toggleChildMenu(open:boolean):void {\r\n        let navEl = this.el.nativeElement.querySelector('nav');\r\n\r\n        if (open) {\r\n            // Remove the listener on the parent menu when a child menu is opened\r\n            // This is to avoid interference between the parent and child menus\r\n            if (this.removeKeydownListener) {\r\n                this.removeKeydownListener();\r\n            }\r\n\r\n            let height:number = navEl.offsetHeight;\r\n            let width:number = navEl.offsetWidth;\r\n\r\n            // In order to animate the child menu, we need to set height on the nav element\r\n            // so we can absolutely position the two menus and maintain the current menu's height\r\n            this.renderer.setStyle(navEl, 'height', `${height}px`);\r\n            this.renderer.setStyle(navEl, 'width', `${width}px`);\r\n\r\n            this.renderer.addClass(this.el.nativeElement, 'open');\r\n            setTimeout(() => {\r\n                this.renderer.addClass(this.el.nativeElement, 'open-active');\r\n            })\r\n        } else {\r\n            // Re-add the listener once the child menu closes\r\n            this.addKeydownListener();\r\n\r\n            this.renderer.removeClass(this.el.nativeElement, 'open-active');\r\n            setTimeout(() => {\r\n                this.renderer.removeClass(this.el.nativeElement, 'open');\r\n\r\n                // Reset the nav element's height to auto\r\n                this.renderer.setStyle(navEl, 'height', '100%');\r\n                this.selected = null;\r\n            }, menuAnimationSpeed)\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Handle key presses to navigate the menu\r\n     */\r\n    public keyNavigate(event: KeyboardEvent) {\r\n        if (this.enableKeyNav && event.target === this.dropdownToggleButton?.nativeElement) {\r\n            switch (event.key) {\r\n                case 'ArrowUp':\r\n                case 'Up':\r\n                case 'ArrowDown':\r\n                case 'Down':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    this.moveHighlightedUpOrDown(event);\r\n                    break;\r\n\r\n                case 'ArrowRight':\r\n                case 'Right':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    // Select the item if it has child items\r\n                    if (this.highlightedItem && this.highlightedItem.items) {\r\n                        this.selectItem(event, this.highlightedItem, true);\r\n                    }\r\n                    break;\r\n\r\n                case 'ArrowLeft':\r\n                case 'Left':\r\n                    event.stopPropagation();\r\n                    event.preventDefault();\r\n                    // Close the menu if it is a child menu\r\n                    if (this.parent) {\r\n                        this.back(event);\r\n                    }\r\n                    break;\r\n\r\n                case ' ':\r\n                case 'Spacebar':\r\n                case 'Enter':\r\n                    // Prevent 'enter' from doing whatever it does on the currently focused element\r\n                    event.preventDefault();\r\n\r\n                    if (this.highlightedItemIndex > -1 && this.highlightedItem) {\r\n                        this.selectItem(event, this.highlightedItem, true);\r\n                    // If the header is highlighted\r\n                    } else if (this.highlightedItemIndex === -1) {\r\n\r\n                        // Close the menu if it's a child\r\n                        if (this.parent) {\r\n                            this.back(event);\r\n                        }\r\n                    }\r\n                    break;\r\n\r\n                default:\r\n                    return;\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Scroll to the item currently marked as 'is-selected'. Wait a tick for the\r\n     * NgClassDirecitve or NavItemActiveDirective to respond to the model changes\r\n     * and update the view.\r\n     */\r\n    public scrollToSelectedItem(): void {\r\n        window.setTimeout(() => {\r\n            const linkSelector = `li.is-selected`;\r\n            this.scrollService.scrollToItem(`#${this.id}_list`, linkSelector);\r\n        });\r\n    }\r\n\r\n    private moveHighlightedUpOrDown(event: KeyboardEvent) {\r\n        switch (event.key) {\r\n            case 'ArrowUp':\r\n            case 'Up':\r\n                if (this.highlightedItemIndex > -1) {\r\n                    this.highlightedItemIndex--;\r\n                    // Skip any in-menu heading items\r\n                    if (this.highlightedItemIndex > -1 && this.items[this.highlightedItemIndex].display === 'heading') {\r\n                        this.highlightedItemIndex--;\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case 'ArrowDown':\r\n            case 'Down':\r\n                if (this.highlightedItemIndex < this.items.length - 1) {\r\n                    this.highlightedItemIndex++;\r\n                    // Skip any in-menu heading items\r\n                    if (this.highlightedItemIndex < this.items.length - 1 && this.items[this.highlightedItemIndex].display === 'heading') {\r\n                        this.highlightedItemIndex++;\r\n                    }\r\n                }\r\n                break;\r\n\r\n            default:\r\n                return;\r\n        }\r\n\r\n        if (this.highlightedItemIndex > -1) {\r\n            // Store the item at the current highlight index\r\n            this.highlightedItem = this.items[this.highlightedItemIndex];\r\n        } else {\r\n            this.highlightedItem = null;\r\n        }\r\n        this.scrollToHighlightedItem();\r\n    }\r\n\r\n    /**\r\n\t * Scroll to the specified menu item.\r\n   * If no item is provided, it will scroll to the first item.\r\n\t *\r\n   * @param item The menu item to scroll to.\r\n\t * @memberof MenuComponent\r\n\t */\r\n\tprivate scrollMenu(item?: MenuItem | null): void {\r\n\t\tif (this.items.length > 0) {\r\n            item = item ? item : this.items[0];\r\n            let itemIndex = this.findItemIndex(item);\r\n\r\n\t\t\tif (this.id) {\r\n                let itemSelector = item.id ? `#${item.id}` : `#${this.id}_item${itemIndex}`;\r\n\t\t\t\tthis.scrollService.scrollItemCentered(`#${this.id}_list`, itemSelector);\r\n\t\t\t}\r\n\t\t}\r\n    }\r\n\r\n    private scrollToHighlightedItem(): void {\r\n        this.scrollMenu(this.highlightedItem);\r\n    }\r\n\r\n    /**\r\n\t * Find a given item's index in the filtered items array.\r\n\t *\r\n\t * Returns -1 if not found\r\n\t * @param itemToFind The matching item to find in the items array.\r\n\t * @memberof MenuComponent\r\n\t */\r\n\tprivate findItemIndex(itemToFind?: MenuItem | null): number {\r\n        if (itemToFind) {\r\n            return this.items.findIndex(item => {\r\n                return item.label === (<MenuItem>itemToFind).label;\r\n            });\r\n        } else {\r\n            return -1;\r\n        }\r\n    }\r\n\r\n    private addKeydownListener(): void {\r\n        // Only attempt to add the listener if keyboard nav is enabled\r\n        if (this.enableKeyNav) {\r\n            // renderer.listen adds the listener and returns a function to remove it from the renderer.\r\n            // The listener remains active until this function is called.\r\n            this.removeKeydownListener = this.renderer.listen('document', 'keydown', (event: KeyboardEvent) => this.keyNavigate(event));\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the menu item ids using its index if item doesn't already have one\r\n     */\r\n    private setItemIds(): void {\r\n        if (this.items) {\r\n            this.items.forEach((item, index) => {\r\n                item.id = item.id ? item.id : this.id + '_item' + index;\r\n            });\r\n        }\r\n    }\r\n}\r\n","<nav>\r\n    <div class=\"parent\"\r\n         [class.no-data]=\"showNoItems && (!items || items.length === 0)\">\r\n        <header id=\"{{id}}_header\"\r\n                class=\"text-heading-3 p-1\"\r\n                [class.is-selected]=\"highlightedItemIndex === -1\"\r\n                *ngIf=\"parent\"\r\n                (click)=\"back($event)\">\r\n            <div class=\"item-wrapper\">\r\n                <i class=\"ec-icon icon-angle-down rotate-90 flex-shrink\"></i>\r\n                <span class=\"label text-truncate flex-grow\">{{parent?.label}}</span>\r\n            </div>\r\n        </header>\r\n\r\n        <ul id=\"{{id}}_list\" class=\"py-1\">\r\n            <li *ngFor=\"let item of items; index as i\"\r\n                id=\"{{item.id || id + '_item' + i}}\"\r\n                class=\"{{item.display || 'item'}} {{item.classList}}\"\r\n                [attr.disabled]=\"item.disabled\"\r\n                [hidden]=\"item.hidden\"\r\n                ecNavItemActive=\"is-selected\"\r\n                [ecNavItemActiveQueryParams]=\"item.queryParams\"\r\n                [ecNavItemActiveUrl]=\"item.url\"\r\n                [ecNavItemActiveExactMatch]='item.isActiveExactMatch'\r\n                (routerLinkActivated)=\"selectItem($event, item)\"\r\n                [ngClass]=\"{'is-highlighted':(selected === item && item?.display !== 'heading') || highlightedItem === item, 'is-link': item.url, 'is-disabled': item.disabled, 'is-readonly': item.readonly, 'is-checked': item.checked, 'text-heading-3': item?.display === 'heading'}\"\r\n                (click)=\"selectItem($event, item)\">\r\n\r\n                <a *ngIf=\"item.url && !item.externalLink\"\r\n                   id=\"{{item.id}}_link\"\r\n                   title=\"{{truncateItems ? item.label : ''}}\"\r\n                   class=\"item-wrapper\"\r\n                   [routerLink]=\"item.url\"\r\n                   [queryParams]=\"item.queryParams || null\"\r\n                   target=\"{{item.target || '_self'}}\">\r\n\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </a>\r\n\r\n                <a *ngIf=\"item.url && item.externalLink\"\r\n                   id=\"{{item.id}}_link\"\r\n                   title=\"{{truncateItems ? item.label : ''}}\"\r\n                   class=\"item-wrapper\"\r\n                   href=\"{{item.url}}\"\r\n                   target=\"{{item.target || '_self'}}\">\r\n\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </a>\r\n\r\n                <div *ngIf=\"!item.url\"\r\n                     title=\"{{truncateItems ? item.label : ''}}\"\r\n                     class=\"item-wrapper\">\r\n                    <ng-container *ngTemplateOutlet=\"internalizedTemplate; context: {$implicit: item}\"></ng-container>\r\n                </div>\r\n            </li>\r\n        </ul>\r\n\r\n        <p class=\"no-data-message\">{{noDataText | translate}}</p>\r\n    </div>\r\n\r\n    <!-- Child menu (Rendered to the right) -->\r\n    <ec-menu *ngIf=\"selected?.items\"\r\n             id=\"{{id}}_child\"\r\n             class=\"child\"\r\n             [parent]=\"selected\"\r\n             [items]=\"selected?.items\"\r\n             [showNoItems]=\"true\"\r\n             [templateType]=\"templateType\"\r\n             [enableKeyNav]=\"true\"\r\n             [truncateItems]=\"truncateItems\"\r\n             (selectedChanged)=\"onSelection($event)\"\r\n             (menuClosed)=\"toggleChildMenu(false)\">\r\n    </ec-menu>\r\n</nav>\r\n\r\n<!-- 'label' Item Template -->\r\n<ng-template #label\r\n             let-item>\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>\r\n\r\n<!-- 'checkAndLabel' Item Template -->\r\n<ng-template #checkAndLabel\r\n             let-item>\r\n\r\n    <i class=\"ec-icon icon-check ec-icon-sm\" *ngIf=\"item.display !== 'heading'\"></i>\r\n\r\n    <i class=\"ec-icon {{item.icon}} ml-2\" *ngIf=\"item.icon\"></i>\r\n\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>\r\n\r\n<!-- 'iconAndLabel' Item Template -->\r\n<ng-template #iconAndLabel\r\n             let-item>\r\n    <!-- If menuItem.icon exists and is not blank, show the icon in the menu -->\r\n    <i class=\"ec-icon {{item.icon}}\" *ngIf=\"(item.icon && item.icon !== '') || preserveIconSpace\"></i>\r\n\r\n    <span id=\"{{item.id}}_label\"\r\n          class=\"label\"\r\n          [class.text-truncate]=\"truncateItems\">{{item.label}}</span>\r\n\r\n    <i class=\"ec-icon icon-angle-down rotate-270\" *ngIf=\"item?.items\"></i>\r\n</ng-template>"]}
@@ -78,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
78
78
  }], target: [{
79
79
  type: Input
80
80
  }] } });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS1kaXNwbGF5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9kaXNwbGF5L2l0ZW0tZGlzcGxheS9pdGVtLWRpc3BsYXkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvaXRlbS1kaXNwbGF5L2l0ZW0tZGlzcGxheS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztBQXNCOUQsTUFBTSxPQUFPLG9CQUFvQjtJQUxqQztRQU9FLG1EQUFtRDtRQUVuQyxPQUFFLEdBQVcsRUFBRSxDQUFDO1FBMEJ6QixrQkFBYSxHQUFpQixFQUFDLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQztRQWNqRDs7V0FFRztRQUNJLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRXJCLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFFbEM7OztXQUdHO1FBQ2EsV0FBTSxHQUE0QyxPQUFPLENBQUM7S0FDM0U7SUEvQ0MsSUFBYSxnQkFBZ0IsQ0FBQyxnQkFBd0Q7UUFDcEYsSUFBRyxPQUFPLGdCQUFnQixLQUFLLFFBQVEsRUFBRTtZQUN2QyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQztTQUNyRDthQUFNO1lBQ0wsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGdCQUFnQixDQUFDO1NBQzNDO0lBQ0gsQ0FBQztJQUNELElBQUksZ0JBQWdCO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDO0lBQ2hDLENBQUM7SUFHRCxJQUFhLEtBQUssQ0FBQyxLQUF3QztRQUN6RCxJQUFHLE9BQU8sS0FBSyxLQUFLLFFBQVEsRUFBRTtZQUM1QixJQUFJLENBQUMsYUFBYSxHQUFHLEVBQUMsS0FBSyxFQUFFLEtBQUssRUFBQyxDQUFDO1NBQ3JDO2FBQU0sSUFBSSxLQUFLLEVBQUU7WUFDaEIsSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7U0FDNUI7YUFBTTtZQUNMLElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBQyxLQUFLLEVBQUUsRUFBRSxFQUFDLENBQUM7U0FDbEM7SUFDSCxDQUFDO0lBQUEsQ0FBQztJQUdGOztPQUVHO0lBQ0gsSUFBYSxHQUFHLENBQUMsS0FBeUI7UUFDeEMsSUFBSSxDQUFDLFlBQVksR0FBRyxDQUFDLEtBQUssRUFBRSxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7UUFDL0QsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUFBLENBQUM7SUFDRixJQUFJLEdBQUc7UUFDTCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDbkIsQ0FBQzs7aUhBekNVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHlQQ3RCakMsbTlDQXFDQTsyRkRmYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0UsaUJBQWlCOzhCQVFYLEVBQUU7c0JBRGpCLFdBQVc7dUJBQUMsU0FBUzs7c0JBQ3JCLEtBQUs7Z0JBRVUsS0FBSztzQkFBcEIsS0FBSztnQkFHTyxnQkFBZ0I7c0JBQTVCLEtBQUs7Z0JBWU8sS0FBSztzQkFBakIsS0FBSztnQkFjTyxHQUFHO3NCQUFmLEtBQUs7Z0JBY1UsU0FBUztzQkFBeEIsS0FBSztnQkFNVSxNQUFNO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgSG9zdEJpbmRpbmcgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUG9wb3ZlckNvbnRlbnRQb3NpdGlvbiB9IGZyb20gJy4uLy4uL2NvbnRyb2xzL3BvcG92ZXIvcG9wb3Zlci5jb21wb25lbnQnO1xyXG5cclxuZXhwb3J0IHR5cGUgRGlzcGxheVZhbHVlID0ge1xyXG4gIHZhbHVlOnN0cmluZyxcclxuICBjbGFzc25hbWVzPzpzdHJpbmcsXHJcbiAgaWNvbj86c3RyaW5nLFxyXG4gIG5vVmFsdWVUZXh0PzpzdHJpbmcsXHJcbiAgdG9vbHRpcD86IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBIZWxwUG9wb3ZlckNvbmZpZyA9IHtcclxuICB0ZXh0OiBzdHJpbmc7XHJcbiAgY29udGVudFBvc2l0aW9uPzogUG9wb3ZlckNvbnRlbnRQb3NpdGlvbjtcclxuICBtYXhXaWR0aD86IHN0cmluZztcclxufVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdlYy1pdGVtLWRpc3BsYXknLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9pdGVtLWRpc3BsYXkuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2l0ZW0tZGlzcGxheS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJdGVtRGlzcGxheUNvbXBvbmVudCB7XHJcblxyXG4gIC8qKiBUaGUgdmFsdWUgb2YgdGhlIGhvc3QgZWxlbWVudCdzIGlkIGF0dHJpYnV0ZSAqL1xyXG4gIEBIb3N0QmluZGluZygnYXR0ci5pZCcpXHJcbiAgQElucHV0KCkgcHVibGljIGlkOiBzdHJpbmcgPSAnJztcclxuXHJcbiAgQElucHV0KCkgcHVibGljIGxhYmVsITogc3RyaW5nO1xyXG5cclxuICBwcml2YXRlIF9sYWJlbEhlbHBQb3BvdmVyPzogSGVscFBvcG92ZXJDb25maWc7XHJcbiAgQElucHV0KCkgc2V0IGxhYmVsSGVscFBvcG92ZXIobGFiZWxIZWxwUG9wb3Zlcjogc3RyaW5nIHwgSGVscFBvcG92ZXJDb25maWcgfCB1bmRlZmluZWQpIHtcclxuICAgIGlmKHR5cGVvZiBsYWJlbEhlbHBQb3BvdmVyID09PSAnc3RyaW5nJykge1xyXG4gICAgICB0aGlzLl9sYWJlbEhlbHBQb3BvdmVyID0geyB0ZXh0OiBsYWJlbEhlbHBQb3BvdmVyIH07XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLl9sYWJlbEhlbHBQb3BvdmVyID0gbGFiZWxIZWxwUG9wb3ZlcjtcclxuICAgIH1cclxuICB9XHJcbiAgZ2V0IGxhYmVsSGVscFBvcG92ZXIoKTogSGVscFBvcG92ZXJDb25maWcgfCB1bmRlZmluZWQge1xyXG4gICAgcmV0dXJuIHRoaXMuX2xhYmVsSGVscFBvcG92ZXI7XHJcbiAgfVxyXG5cclxuXHJcbiAgQElucHV0KCkgc2V0IHZhbHVlKHZhbHVlOiBzdHJpbmcgfCBEaXNwbGF5VmFsdWUgfCB1bmRlZmluZWQpIHtcclxuICAgIGlmKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcclxuICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0ge3ZhbHVlOiB2YWx1ZX07XHJcbiAgICB9IGVsc2UgaWYgKHZhbHVlKSB7XHJcbiAgICAgIHRoaXMuaW50ZXJuYWxWYWx1ZSA9IHZhbHVlO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0ge3ZhbHVlOiAnJ307XHJcbiAgICB9XHJcbiAgfTtcclxuICBwdWJsaWMgaW50ZXJuYWxWYWx1ZTogRGlzcGxheVZhbHVlID0ge3ZhbHVlOiAnJ307XHJcblxyXG4gIC8qKlxyXG4gICAqIFdoZW4gcHJvdmlkZWQsIGRpc3BsYXlzIHRoZSB2YWx1ZSBhcyBhIGxpbmtcclxuICAgKi9cclxuICBASW5wdXQoKSBzZXQgdXJsKHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcclxuICAgIHRoaXMuZXh0ZXJuYWxMaW5rID0gKHZhbHVlPy5zdGFydHNXaXRoKCdodHRwJykpID8gdHJ1ZSA6IGZhbHNlO1xyXG4gICAgdGhpcy5fdXJsID0gdmFsdWU7XHJcbiAgfTtcclxuICBnZXQgdXJsKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XHJcbiAgICByZXR1cm4gdGhpcy5fdXJsO1xyXG4gIH1cclxuICBwcml2YXRlIF91cmw/OiBzdHJpbmc7XHJcblxyXG4gIC8qKlxyXG4gICAqIFNldCBsaW5rIGFzIGFuIGhyZWYgb3Igcm91dGVyTGlua1xyXG4gICAqL1xyXG4gIHB1YmxpYyBleHRlcm5hbExpbms6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQElucHV0KCkgcHVibGljIGNvbmRlbnNlZCA9IGZhbHNlO1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgbGluayB0YXJnZXQgd2hlbiB1cmwgaXMgcHJvdmlkZWQuIERlZmF1bHRzIHRvIF9zZWxmIChzYW1lIHdpbmRvdylcclxuICAgKiBAc2VlIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0hUTUwvRWxlbWVudC9hXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIHRhcmdldDogJ19zZWxmJyB8ICdfYmxhbmsnIHwgJ19wYXJlbnQnIHwgJ190b3AnID0gJ19zZWxmJztcclxufVxyXG4iLCI8ZGl2IGlkPVwie3tpZH19X2xhYmVsXzBcIlxyXG4gICAgIGNsYXNzPVwidGV4dC1jYXB0aW9uLTEgZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlclwiPlxyXG4gIDxzcGFuPnt7bGFiZWwgfCB0cmFuc2xhdGV9fTwvc3Bhbj5cclxuICA8ZWMtaGVscC1wb3BvdmVyICpuZ0lmPVwibGFiZWxIZWxwUG9wb3ZlclwiXHJcbiAgICAgICAgICAgICAgICAgICBjbGFzcz1cIm14LW4xIG15LW4yXCJcclxuICAgICAgICAgICAgICAgICAgIFt0ZXh0XT1cImxhYmVsSGVscFBvcG92ZXIudGV4dFwiXHJcbiAgICAgICAgICAgICAgICAgICBbY29udGVudFBvc2l0aW9uXT1cImxhYmVsSGVscFBvcG92ZXI/LmNvbnRlbnRQb3NpdGlvbiA/PyAndG9wLWxlZnQnXCJcclxuICAgICAgICAgICAgICAgICAgIFttYXhXaWR0aF09XCJsYWJlbEhlbHBQb3BvdmVyPy5tYXhXaWR0aCA/PyAnMTVyZW0nXCI+XHJcbiAgPC9lYy1oZWxwLXBvcG92ZXI+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiBpZD1cInt7aWR9fV92YWx1ZV8wXCIgY2xhc3M9XCJ7e2NvbmRlbnNlZCA/ICd0ZXh0LWJvZHktMicgOiAndGV4dC1kaXNwbGF5LTEnfX0ge3tpbnRlcm5hbFZhbHVlLmNsYXNzbmFtZXN9fVwiXHJcbiAgICAgW2NsYXNzLmZvbnQtY29sb3ItaGludF09XCIhaW50ZXJuYWxWYWx1ZS52YWx1ZSAmJiBpbnRlcm5hbFZhbHVlLm5vVmFsdWVUZXh0XCJcclxuICAgICB0aXRsZT1cInt7aW50ZXJuYWxWYWx1ZS50b29sdGlwfX1cIj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInVybCBlbHNlIGNvbnRlbnRcIj5cclxuICAgIDxhICpuZ0lmPVwiIWV4dGVybmFsTGlua1wiXHJcbiAgICAgICAgaWQ9XCJ7e2lkfX1fbGlua1wiXHJcbiAgICAgICAgcm91dGVyTGluaz1cInt7dXJsfX1cIlxyXG4gICAgICAgIHRhcmdldD1cInt7dGFyZ2V0fX1cIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvYT5cclxuICAgIDxhICpuZ0lmPVwiZXh0ZXJuYWxMaW5rXCJcclxuICAgICAgICBpZD1cInt7aWR9fV9saW5rXCJcclxuICAgICAgICBocmVmPVwie3t1cmx9fVwiXHJcbiAgICAgICAgdGFyZ2V0PVwie3t0YXJnZXR9fVwiPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudFwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9hPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L2Rpdj5cclxuXHJcblxyXG48bmctdGVtcGxhdGUgI2NvbnRlbnQ+XHJcbiAgPGkgKm5nSWY9XCJpbnRlcm5hbFZhbHVlPy5pY29uXCIgY2xhc3M9XCJlYy1pY29uIHt7aW50ZXJuYWxWYWx1ZT8uaWNvbn19XCI+PC9pPlxyXG4gIDxzcGFuPnt7KGludGVybmFsVmFsdWU/LnZhbHVlIHx8IGludGVybmFsVmFsdWU/Lm5vVmFsdWVUZXh0KSB8IHRyYW5zbGF0ZX19PC9zcGFuPlxyXG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS1kaXNwbGF5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9kaXNwbGF5L2l0ZW0tZGlzcGxheS9pdGVtLWRpc3BsYXkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvaXRlbS1kaXNwbGF5L2l0ZW0tZGlzcGxheS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztBQXVCOUQsTUFBTSxPQUFPLG9CQUFvQjtJQUxqQztRQU9FLG1EQUFtRDtRQUVuQyxPQUFFLEdBQVcsRUFBRSxDQUFDO1FBMEJ6QixrQkFBYSxHQUFpQixFQUFDLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQztRQWNqRDs7V0FFRztRQUNJLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRXJCLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFFbEM7OztXQUdHO1FBQ2EsV0FBTSxHQUFlLE9BQU8sQ0FBQztLQUM5QztJQS9DQyxJQUFhLGdCQUFnQixDQUFDLGdCQUF3RDtRQUNwRixJQUFHLE9BQU8sZ0JBQWdCLEtBQUssUUFBUSxFQUFFO1lBQ3ZDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxDQUFDO1NBQ3JEO2FBQU07WUFDTCxJQUFJLENBQUMsaUJBQWlCLEdBQUcsZ0JBQWdCLENBQUM7U0FDM0M7SUFDSCxDQUFDO0lBQ0QsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQztJQUdELElBQWEsS0FBSyxDQUFDLEtBQXdDO1FBQ3pELElBQUcsT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFO1lBQzVCLElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBQyxLQUFLLEVBQUUsS0FBSyxFQUFDLENBQUM7U0FDckM7YUFBTSxJQUFJLEtBQUssRUFBRTtZQUNoQixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztTQUM1QjthQUFNO1lBQ0wsSUFBSSxDQUFDLGFBQWEsR0FBRyxFQUFDLEtBQUssRUFBRSxFQUFFLEVBQUMsQ0FBQztTQUNsQztJQUNILENBQUM7SUFBQSxDQUFDO0lBR0Y7O09BRUc7SUFDSCxJQUFhLEdBQUcsQ0FBQyxLQUF5QjtRQUN4QyxJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztRQUMvRCxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQztJQUNwQixDQUFDO0lBQUEsQ0FBQztJQUNGLElBQUksR0FBRztRQUNMLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQztJQUNuQixDQUFDOztpSEF6Q1Usb0JBQW9CO3FHQUFwQixvQkFBb0IseVBDdkJqQyxtOUNBcUNBOzJGRGRhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxpQkFBaUI7OEJBUVgsRUFBRTtzQkFEakIsV0FBVzt1QkFBQyxTQUFTOztzQkFDckIsS0FBSztnQkFFVSxLQUFLO3NCQUFwQixLQUFLO2dCQUdPLGdCQUFnQjtzQkFBNUIsS0FBSztnQkFZTyxLQUFLO3NCQUFqQixLQUFLO2dCQWNPLEdBQUc7c0JBQWYsS0FBSztnQkFjVSxTQUFTO3NCQUF4QixLQUFLO2dCQU1VLE1BQU07c0JBQXJCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBQb3BvdmVyQ29udGVudFBvc2l0aW9uIH0gZnJvbSAnLi4vLi4vY29udHJvbHMvcG9wb3Zlci9wb3BvdmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IExpbmtUYXJnZXQgfSBmcm9tICcuLi90YWdzL3RhZyc7XHJcblxyXG5leHBvcnQgdHlwZSBEaXNwbGF5VmFsdWUgPSB7XHJcbiAgdmFsdWU6c3RyaW5nLFxyXG4gIGNsYXNzbmFtZXM/OnN0cmluZyxcclxuICBpY29uPzpzdHJpbmcsXHJcbiAgbm9WYWx1ZVRleHQ/OnN0cmluZyxcclxuICB0b29sdGlwPzogc3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIEhlbHBQb3BvdmVyQ29uZmlnID0ge1xyXG4gIHRleHQ6IHN0cmluZztcclxuICBjb250ZW50UG9zaXRpb24/OiBQb3BvdmVyQ29udGVudFBvc2l0aW9uO1xyXG4gIG1heFdpZHRoPzogc3RyaW5nO1xyXG59XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjLWl0ZW0tZGlzcGxheScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2l0ZW0tZGlzcGxheS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vaXRlbS1kaXNwbGF5LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIEl0ZW1EaXNwbGF5Q29tcG9uZW50IHtcclxuXHJcbiAgLyoqIFRoZSB2YWx1ZSBvZiB0aGUgaG9zdCBlbGVtZW50J3MgaWQgYXR0cmlidXRlICovXHJcbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmlkJylcclxuICBASW5wdXQoKSBwdWJsaWMgaWQ6IHN0cmluZyA9ICcnO1xyXG5cclxuICBASW5wdXQoKSBwdWJsaWMgbGFiZWwhOiBzdHJpbmc7XHJcblxyXG4gIHByaXZhdGUgX2xhYmVsSGVscFBvcG92ZXI/OiBIZWxwUG9wb3ZlckNvbmZpZztcclxuICBASW5wdXQoKSBzZXQgbGFiZWxIZWxwUG9wb3ZlcihsYWJlbEhlbHBQb3BvdmVyOiBzdHJpbmcgfCBIZWxwUG9wb3ZlckNvbmZpZyB8IHVuZGVmaW5lZCkge1xyXG4gICAgaWYodHlwZW9mIGxhYmVsSGVscFBvcG92ZXIgPT09ICdzdHJpbmcnKSB7XHJcbiAgICAgIHRoaXMuX2xhYmVsSGVscFBvcG92ZXIgPSB7IHRleHQ6IGxhYmVsSGVscFBvcG92ZXIgfTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuX2xhYmVsSGVscFBvcG92ZXIgPSBsYWJlbEhlbHBQb3BvdmVyO1xyXG4gICAgfVxyXG4gIH1cclxuICBnZXQgbGFiZWxIZWxwUG9wb3ZlcigpOiBIZWxwUG9wb3ZlckNvbmZpZyB8IHVuZGVmaW5lZCB7XHJcbiAgICByZXR1cm4gdGhpcy5fbGFiZWxIZWxwUG9wb3ZlcjtcclxuICB9XHJcblxyXG5cclxuICBASW5wdXQoKSBzZXQgdmFsdWUodmFsdWU6IHN0cmluZyB8IERpc3BsYXlWYWx1ZSB8IHVuZGVmaW5lZCkge1xyXG4gICAgaWYodHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xyXG4gICAgICB0aGlzLmludGVybmFsVmFsdWUgPSB7dmFsdWU6IHZhbHVlfTtcclxuICAgIH0gZWxzZSBpZiAodmFsdWUpIHtcclxuICAgICAgdGhpcy5pbnRlcm5hbFZhbHVlID0gdmFsdWU7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmludGVybmFsVmFsdWUgPSB7dmFsdWU6ICcnfTtcclxuICAgIH1cclxuICB9O1xyXG4gIHB1YmxpYyBpbnRlcm5hbFZhbHVlOiBEaXNwbGF5VmFsdWUgPSB7dmFsdWU6ICcnfTtcclxuXHJcbiAgLyoqXHJcbiAgICogV2hlbiBwcm92aWRlZCwgZGlzcGxheXMgdGhlIHZhbHVlIGFzIGEgbGlua1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHNldCB1cmwodmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZCkge1xyXG4gICAgdGhpcy5leHRlcm5hbExpbmsgPSAodmFsdWU/LnN0YXJ0c1dpdGgoJ2h0dHAnKSkgPyB0cnVlIDogZmFsc2U7XHJcbiAgICB0aGlzLl91cmwgPSB2YWx1ZTtcclxuICB9O1xyXG4gIGdldCB1cmwoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcclxuICAgIHJldHVybiB0aGlzLl91cmw7XHJcbiAgfVxyXG4gIHByaXZhdGUgX3VybD86IHN0cmluZztcclxuXHJcbiAgLyoqXHJcbiAgICogU2V0IGxpbmsgYXMgYW4gaHJlZiBvciByb3V0ZXJMaW5rXHJcbiAgICovXHJcbiAgcHVibGljIGV4dGVybmFsTGluazogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKSBwdWJsaWMgY29uZGVuc2VkID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIFRoZSBsaW5rIHRhcmdldCB3aGVuIHVybCBpcyBwcm92aWRlZC4gRGVmYXVsdHMgdG8gX3NlbGYgKHNhbWUgd2luZG93KVxyXG4gICAqIEBzZWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvSFRNTC9FbGVtZW50L2FcclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgdGFyZ2V0OiBMaW5rVGFyZ2V0ID0gJ19zZWxmJztcclxufVxyXG4iLCI8ZGl2IGlkPVwie3tpZH19X2xhYmVsXzBcIlxyXG4gICAgIGNsYXNzPVwidGV4dC1jYXB0aW9uLTEgZC1mbGV4IGFsaWduLWl0ZW1zLWNlbnRlclwiPlxyXG4gIDxzcGFuPnt7bGFiZWwgfCB0cmFuc2xhdGV9fTwvc3Bhbj5cclxuICA8ZWMtaGVscC1wb3BvdmVyICpuZ0lmPVwibGFiZWxIZWxwUG9wb3ZlclwiXHJcbiAgICAgICAgICAgICAgICAgICBjbGFzcz1cIm14LW4xIG15LW4yXCJcclxuICAgICAgICAgICAgICAgICAgIFt0ZXh0XT1cImxhYmVsSGVscFBvcG92ZXIudGV4dFwiXHJcbiAgICAgICAgICAgICAgICAgICBbY29udGVudFBvc2l0aW9uXT1cImxhYmVsSGVscFBvcG92ZXI/LmNvbnRlbnRQb3NpdGlvbiA/PyAndG9wLWxlZnQnXCJcclxuICAgICAgICAgICAgICAgICAgIFttYXhXaWR0aF09XCJsYWJlbEhlbHBQb3BvdmVyPy5tYXhXaWR0aCA/PyAnMTVyZW0nXCI+XHJcbiAgPC9lYy1oZWxwLXBvcG92ZXI+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiBpZD1cInt7aWR9fV92YWx1ZV8wXCIgY2xhc3M9XCJ7e2NvbmRlbnNlZCA/ICd0ZXh0LWJvZHktMicgOiAndGV4dC1kaXNwbGF5LTEnfX0ge3tpbnRlcm5hbFZhbHVlLmNsYXNzbmFtZXN9fVwiXHJcbiAgICAgW2NsYXNzLmZvbnQtY29sb3ItaGludF09XCIhaW50ZXJuYWxWYWx1ZS52YWx1ZSAmJiBpbnRlcm5hbFZhbHVlLm5vVmFsdWVUZXh0XCJcclxuICAgICB0aXRsZT1cInt7aW50ZXJuYWxWYWx1ZS50b29sdGlwfX1cIj5cclxuXHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInVybCBlbHNlIGNvbnRlbnRcIj5cclxuICAgIDxhICpuZ0lmPVwiIWV4dGVybmFsTGlua1wiXHJcbiAgICAgICAgaWQ9XCJ7e2lkfX1fbGlua1wiXHJcbiAgICAgICAgcm91dGVyTGluaz1cInt7dXJsfX1cIlxyXG4gICAgICAgIHRhcmdldD1cInt7dGFyZ2V0fX1cIj5cclxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cclxuICAgIDwvYT5cclxuICAgIDxhICpuZ0lmPVwiZXh0ZXJuYWxMaW5rXCJcclxuICAgICAgICBpZD1cInt7aWR9fV9saW5rXCJcclxuICAgICAgICBocmVmPVwie3t1cmx9fVwiXHJcbiAgICAgICAgdGFyZ2V0PVwie3t0YXJnZXR9fVwiPlxyXG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudFwiPjwvbmctY29udGFpbmVyPlxyXG4gICAgPC9hPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L2Rpdj5cclxuXHJcblxyXG48bmctdGVtcGxhdGUgI2NvbnRlbnQ+XHJcbiAgPGkgKm5nSWY9XCJpbnRlcm5hbFZhbHVlPy5pY29uXCIgY2xhc3M9XCJlYy1pY29uIHt7aW50ZXJuYWxWYWx1ZT8uaWNvbn19XCI+PC9pPlxyXG4gIDxzcGFuPnt7KGludGVybmFsVmFsdWU/LnZhbHVlIHx8IGludGVybmFsVmFsdWU/Lm5vVmFsdWVUZXh0KSB8IHRyYW5zbGF0ZX19PC9zcGFuPlxyXG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
@@ -1,15 +1,18 @@
1
1
  /** Tag contains a label and type. Type is default by default */
2
2
  export class Tag {
3
- constructor(label, type, classList, icon, isDismissable, tooltip) {
3
+ constructor(label, type, classList, icon, isDismissable, tooltip, url, target) {
4
+ this.target = '_self';
4
5
  this.label = label;
5
6
  this.type = type || 'info';
6
7
  this.icon = icon;
7
8
  this.isDismissable = isDismissable ?? false;
8
9
  this.tooltip = tooltip;
10
+ this.url = url;
11
+ this.target = target || '_self';
9
12
  if (classList) {
10
13
  this.classList = classList;
11
14
  }
12
15
  }
13
16
  }
14
17
  ;
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvdGFncy90YWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsZ0VBQWdFO0FBQ2hFLE1BQU0sT0FBTyxHQUFHO0lBY2QsWUFBWSxLQUFhLEVBQUUsSUFBYyxFQUFFLFNBQWtCLEVBQUUsSUFBYSxFQUFFLGFBQXVCLEVBQUUsT0FBZ0I7UUFDckgsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLElBQUksTUFBTSxDQUFDO1FBQzNCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxJQUFJLEtBQUssQ0FBQztRQUM1QyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUV2QixJQUFJLFNBQVMsRUFBRTtZQUNiLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztDQUNGO0FBQUEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBUYWcgdHlwZSB1c2VkIHRvIHN0eWxlIHRoZSB0YWcgKi9cclxuZXhwb3J0IHR5cGUgVGFnVHlwZSA9IFwiaW5mb1wiIHwgXCJzdWNjZXNzXCIgfCBcIndhcm5pbmdcIiB8IFwiZGFuZ2VyXCIgfCBcImFjY2VudFwiIHwgXCJjaGFyZ2ViYWNrXCIgfCBcImFjY3J1YWxcIiB8IFwiaW52ZXJ0ZWRcIjtcclxuXHJcbi8qKiBUYWcgY29udGFpbnMgYSBsYWJlbCBhbmQgdHlwZS4gVHlwZSBpcyBkZWZhdWx0IGJ5IGRlZmF1bHQgKi9cclxuZXhwb3J0IGNsYXNzIFRhZyB7XHJcbiAgcHVibGljIGxhYmVsOiBzdHJpbmc7XHJcblxyXG4gIHB1YmxpYyB0eXBlOiBUYWdUeXBlO1xyXG5cclxuICBwdWJsaWMgaWNvbj86IHN0cmluZztcclxuXHJcbiAgcHVibGljIGlzRGlzbWlzc2FibGU/OiBib29sZWFuO1xyXG5cclxuICAvKiogQ1NTIGNsYXNzZXMgdG8gYXBwbHkgdG8gdGFnIGZvciBjdXN0b20gc3R5bGluZyAqL1xyXG4gIHB1YmxpYyBjbGFzc0xpc3Q/OiBzdHJpbmc7XHJcblxyXG4gIHB1YmxpYyB0b29sdGlwPzogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3RvcihsYWJlbDogc3RyaW5nLCB0eXBlPzogVGFnVHlwZSwgY2xhc3NMaXN0Pzogc3RyaW5nLCBpY29uPzogc3RyaW5nLCBpc0Rpc21pc3NhYmxlPzogYm9vbGVhbiwgdG9vbHRpcD86IHN0cmluZykge1xyXG4gICAgdGhpcy5sYWJlbCA9IGxhYmVsO1xyXG4gICAgdGhpcy50eXBlID0gdHlwZSB8fCAnaW5mbyc7XHJcbiAgICB0aGlzLmljb24gPSBpY29uO1xyXG4gICAgdGhpcy5pc0Rpc21pc3NhYmxlID0gaXNEaXNtaXNzYWJsZSA/PyBmYWxzZTtcclxuICAgIHRoaXMudG9vbHRpcCA9IHRvb2x0aXA7XHJcblxyXG4gICAgaWYgKGNsYXNzTGlzdCkge1xyXG4gICAgICB0aGlzLmNsYXNzTGlzdCA9IGNsYXNzTGlzdDtcclxuICAgIH1cclxuICB9XHJcbn07Il19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvdGFncy90YWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsZ0VBQWdFO0FBQ2hFLE1BQU0sT0FBTyxHQUFHO0lBbUJkLFlBQVksS0FBYSxFQUFFLElBQWMsRUFBRSxTQUFrQixFQUFFLElBQWEsRUFBRSxhQUF1QixFQUFFLE9BQWdCLEVBQUUsR0FBWSxFQUFFLE1BQW1CO1FBRm5KLFdBQU0sR0FBZ0IsT0FBTyxDQUFDO1FBR25DLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxJQUFJLE1BQU0sQ0FBQztRQUMzQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsYUFBYSxHQUFHLGFBQWEsSUFBSSxLQUFLLENBQUM7UUFDNUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7UUFDdkIsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7UUFDZixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sSUFBSSxPQUFPLENBQUM7UUFFaEMsSUFBSSxTQUFTLEVBQUU7WUFDYixJQUFJLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQztTQUM1QjtJQUNILENBQUM7Q0FDRjtBQUFBLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogVGFnIHR5cGUgdXNlZCB0byBzdHlsZSB0aGUgdGFnICovXHJcbmV4cG9ydCB0eXBlIFRhZ1R5cGUgPSBcImluZm9cIiB8IFwic3VjY2Vzc1wiIHwgXCJ3YXJuaW5nXCIgfCBcImRhbmdlclwiIHwgXCJhY2NlbnRcIiB8IFwiY2hhcmdlYmFja1wiIHwgXCJhY2NydWFsXCIgfCBcImludmVydGVkXCI7XHJcblxyXG4vKiogTGluayB0YXJnZXQgb3B0aW9ucywgc2hhcmVkIGFtb25nc3QgdGFnLCBtZW51IGFuZCBpdGVtIGRpc3BsYXkgKi9cclxuZXhwb3J0IHR5cGUgTGlua1RhcmdldCA9ICdfc2VsZicgfCAnX2JsYW5rJyB8ICdfcGFyZW50JyB8ICdfdG9wJztcclxuXHJcbi8qKiBUYWcgY29udGFpbnMgYSBsYWJlbCBhbmQgdHlwZS4gVHlwZSBpcyBkZWZhdWx0IGJ5IGRlZmF1bHQgKi9cclxuZXhwb3J0IGNsYXNzIFRhZyB7XHJcbiAgcHVibGljIGxhYmVsOiBzdHJpbmc7XHJcblxyXG4gIHB1YmxpYyB0eXBlOiBUYWdUeXBlO1xyXG5cclxuICBwdWJsaWMgaWNvbj86IHN0cmluZztcclxuXHJcbiAgcHVibGljIGlzRGlzbWlzc2FibGU/OiBib29sZWFuO1xyXG5cclxuICAvKiogQ1NTIGNsYXNzZXMgdG8gYXBwbHkgdG8gdGFnIGZvciBjdXN0b20gc3R5bGluZyAqL1xyXG4gIHB1YmxpYyBjbGFzc0xpc3Q/OiBzdHJpbmc7XHJcblxyXG4gIHB1YmxpYyB0b29sdGlwPzogc3RyaW5nO1xyXG5cclxuICAvKiogV2hlbiBzZXQgYSBoeXBlcmxpbmsgd2lsbCBiZSBzaG93biBsaW5raW5nIHRvIHRoZSB2YWx1ZSBzZXQgKi9cclxuICBwdWJsaWMgdXJsPzogc3RyaW5nO1xyXG5cclxuICBwdWJsaWMgdGFyZ2V0PzogTGlua1RhcmdldCA9ICdfc2VsZic7XHJcblxyXG4gIGNvbnN0cnVjdG9yKGxhYmVsOiBzdHJpbmcsIHR5cGU/OiBUYWdUeXBlLCBjbGFzc0xpc3Q/OiBzdHJpbmcsIGljb24/OiBzdHJpbmcsIGlzRGlzbWlzc2FibGU/OiBib29sZWFuLCB0b29sdGlwPzogc3RyaW5nLCB1cmw/OiBzdHJpbmcsIHRhcmdldD86IExpbmtUYXJnZXQgKSB7XHJcbiAgICB0aGlzLmxhYmVsID0gbGFiZWw7XHJcbiAgICB0aGlzLnR5cGUgPSB0eXBlIHx8ICdpbmZvJztcclxuICAgIHRoaXMuaWNvbiA9IGljb247XHJcbiAgICB0aGlzLmlzRGlzbWlzc2FibGUgPSBpc0Rpc21pc3NhYmxlID8/IGZhbHNlO1xyXG4gICAgdGhpcy50b29sdGlwID0gdG9vbHRpcDtcclxuICAgIHRoaXMudXJsID0gdXJsO1xyXG4gICAgdGhpcy50YXJnZXQgPSB0YXJnZXQgfHwgJ19zZWxmJztcclxuXHJcbiAgICBpZiAoY2xhc3NMaXN0KSB7XHJcbiAgICAgIHRoaXMuY2xhc3NMaXN0ID0gY2xhc3NMaXN0O1xyXG4gICAgfVxyXG4gIH1cclxufTsiXX0=
@@ -59,10 +59,10 @@ export class TagsComponent {
59
59
  }
60
60
  }
61
61
  TagsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TagsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
62
- TagsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TagsComponent, selector: "ec-tags", inputs: { id: "id", tags: "tags", wrap: "wrap", isCondensed: "isCondensed" }, outputs: { tagClosed: "tagClosed" }, usesOnChanges: true, ngImport: i0, template: "<ul class=\"tags\" [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\" class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n {{tag.label | translate}}\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag .ec-icon:before,.tag .ec-icon:after{width:auto;height:auto}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
62
+ TagsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TagsComponent, selector: "ec-tags", inputs: { id: "id", tags: "tags", wrap: "wrap", isCondensed: "isCondensed" }, outputs: { tagClosed: "tagClosed" }, usesOnChanges: true, ngImport: i0, template: "<ul class=\"tags\"\r\n [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable, 'is-link': tag.url}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\"\r\n class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n <span *ngIf=\"!tag.url\">{{tag.label | translate}}</span>\r\n\r\n <a *ngIf=\"tag.url\"\r\n id=\"{{id}}_tag_{{i}}_link\"\r\n class=\"font-weight-bold\"\r\n href=\"{{tag.url}}\"\r\n target=\"{{tag.target}}\">{{tag.label | translate}}</a>\r\n\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":root{--ec-font-size-icon: 1rem;--ec-color-icon: rgba(26, 26, 35, .66)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}.is-link a:after{opacity:1;margin-left:.1875rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
63
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TagsComponent, decorators: [{
64
64
  type: Component,
65
- args: [{ selector: 'ec-tags', template: "<ul class=\"tags\" [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\" class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n {{tag.label | translate}}\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag .ec-icon:before,.tag .ec-icon:after{width:auto;height:auto}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}\n"] }]
65
+ args: [{ selector: 'ec-tags', template: "<ul class=\"tags\"\r\n [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable, 'is-link': tag.url}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\"\r\n class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n <span *ngIf=\"!tag.url\">{{tag.label | translate}}</span>\r\n\r\n <a *ngIf=\"tag.url\"\r\n id=\"{{id}}_tag_{{i}}_link\"\r\n class=\"font-weight-bold\"\r\n href=\"{{tag.url}}\"\r\n target=\"{{tag.target}}\">{{tag.label | translate}}</a>\r\n\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":root{--ec-font-size-icon: 1rem;--ec-color-icon: rgba(26, 26, 35, .66)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}.is-link a:after{opacity:1;margin-left:.1875rem}\n"] }]
66
66
  }], ctorParameters: function () { return []; }, propDecorators: { id: [{
67
67
  type: Input
68
68
  }], tags: [{
@@ -74,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
74
74
  }], tagClosed: [{
75
75
  type: Output
76
76
  }] } });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvZGlzcGxheS90YWdzL3RhZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvdGFncy90YWdzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWEsS0FBSyxFQUFpQixNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUWpHLE1BQU0sT0FBTyxhQUFhO0lBdUN4QjtRQXJDQSxnQ0FBZ0M7UUFDaEIsT0FBRSxHQUFXLEVBQUUsQ0FBQztRQVVoQzs7Ozs7V0FLRztRQUNhLFNBQUksR0FBWSxJQUFJLENBQUM7UUFFckM7O1dBRUc7UUFDYSxnQkFBVyxHQUFZLEtBQUssQ0FBQztRQUU3Qzs7V0FFRztRQUNjLGNBQVMsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUV4RTs7Ozs7V0FLRztRQUNJLGNBQVMsR0FBVSxFQUFFLENBQUM7SUFFYixDQUFDO0lBRWpCOzs7Ozs7T0FNRztJQUNILFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDaEIsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO2dCQUNiLDhFQUE4RTtnQkFDOUUsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO2lCQUM1QjtxQkFBTTtvQkFDTCxJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2lCQUM5QjthQUNGO2lCQUFNO2dCQUNMLHdDQUF3QztnQkFDeEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7YUFDckI7U0FDRjtJQUNILENBQUM7SUFFTSxRQUFRLENBQUMsR0FBUTtRQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzNCLENBQUM7OzBHQW5FVSxhQUFhOzhGQUFiLGFBQWEsdUxDUjFCLDJ1QkFjSzsyRkROUSxhQUFhO2tCQUx6QixTQUFTOytCQUNFLFNBQVM7MEVBT0gsRUFBRTtzQkFBakIsS0FBSztnQkFRVSxJQUFJO3NCQUFuQixLQUFLO2dCQVFVLElBQUk7c0JBQW5CLEtBQUs7Z0JBS1UsV0FBVztzQkFBMUIsS0FBSztnQkFLVyxTQUFTO3NCQUF6QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkNoYW5nZXMsIElucHV0LCBTaW1wbGVDaGFuZ2VzLCBPdXRwdXQsIEV2ZW50RW1pdHRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUYWcgfSBmcm9tICcuL3RhZyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjLXRhZ3MnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi90YWdzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi90YWdzLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFRhZ3NDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG5cclxuICAvKipUaGUgSUQgb2YgdGhpcyBzZXQgb2YgdGFncyAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBpZDogc3RyaW5nID0gJyc7XHJcblxyXG4gIC8qKlxyXG4gICAqIE9uZSBvciBtb3JlIHRhZ3NcclxuICAgKiBcclxuICAgKiBAdHlwZSB7KFRhZyB8IFRhZ1tdKX1cclxuICAgKiBAbWVtYmVyb2YgVGFnc0NvbXBvbmVudFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyB0YWdzPzogVGFnIHwgVGFnW107XHJcblxyXG4gIC8qKlxyXG4gICAqIERldGVybWluZXMgd2hldGhlciB0aGUgdGFncyB3aWxsIHdyYXAgb3Igbm90XHJcbiAgICogXHJcbiAgICogQHR5cGUge2Jvb2xlYW59XHJcbiAgICogQG1lbWJlcm9mIFRhZ3NDb21wb25lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgd3JhcDogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIC8qKlxyXG4gICAqIERpc3BsYXlzIHRoZSB0YWdzIGluIGNvbmRlbnNlZCBtb2RlXHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIGlzQ29uZGVuc2VkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIEVtaXRzIHRoZSB0YWcgaXRlbSB3aGVuIHRoZSB0YWcncyBjbG9zZSBidXR0b24gaXMgY2xpY2tlZFxyXG4gICAqL1xyXG4gIEBPdXRwdXQoKSBwdWJsaWMgdGFnQ2xvc2VkOiBFdmVudEVtaXR0ZXI8VGFnPiA9IG5ldyBFdmVudEVtaXR0ZXI8VGFnPigpO1xyXG5cclxuICAvKipcclxuICAgKiBUYWdzIHRvIGJlIGRpc3BsYXllZFxyXG4gICAqIFxyXG4gICAqIEB0eXBlIHtUYWdbXX1cclxuICAgKiBAbWVtYmVyb2YgVGFnc0NvbXBvbmVudFxyXG4gICAqL1xyXG4gIHB1YmxpYyB0YWdzQXJyYXk6IFRhZ1tdID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEFuZ3VsYXIgb25DaGFuZ2VzIGxpZmVjeWNsZSBob29rXHJcbiAgICogQHNlZSB7QGxpbmsgaHR0cHM6Ly9hbmd1bGFyLmlvL2d1aWRlL2xpZmVjeWNsZS1ob29rcyB8IExpZmUtY3ljbGUgaG9va3N9XHJcbiAgICogXHJcbiAgICogQHBhcmFtIHtTaW1wbGVDaGFuZ2VzfSBjaGFuZ2VzIFxyXG4gICAqIEBtZW1iZXJvZiBUYWdzQ29tcG9uZW50XHJcbiAgICovXHJcbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xyXG4gICAgaWYgKGNoYW5nZXMudGFncykge1xyXG4gICAgICBpZiAodGhpcy50YWdzKSB7XHJcbiAgICAgICAgLy8gSWYgb25seSBnaXZlbiBhIHNpbmdsZSBpdGVtLCBwdXQgaXQgaW4gYW4gYXJyYXkgc28gaXQgd29ya3MgaW4gdGhlIHRlbXBsYXRlXHJcbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy50YWdzKSkge1xyXG4gICAgICAgICAgdGhpcy50YWdzQXJyYXkgPSB0aGlzLnRhZ3M7XHJcbiAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgIHRoaXMudGFnc0FycmF5ID0gW3RoaXMudGFnc107XHJcbiAgICAgICAgfVxyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIC8vIHJlc2V0IGFycmF5IGlmIHRhZ3MgYmVjb21lcyB1bmRlZmluZWRcclxuICAgICAgICB0aGlzLnRhZ3NBcnJheSA9IFtdO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2xvc2VUYWcodGFnOiBUYWcpIHtcclxuICAgIHRoaXMudGFnc0FycmF5ID0gdGhpcy50YWdzQXJyYXkuZmlsdGVyKHQgPT4gdCAhPT0gdGFnKTtcclxuICAgIHRoaXMudGFnQ2xvc2VkLmVtaXQodGFnKTtcclxuICB9XHJcbn1cclxuIiwiPHVsIGNsYXNzPVwidGFnc1wiIFtjbGFzcy5pcy13cmFwcGVkXT1cIndyYXBcIj5cclxuICA8bGkgKm5nRm9yPVwibGV0IHRhZyBvZiB0YWdzQXJyYXk7IGluZGV4IGFzIGlcIlxyXG4gICAgICBpZD1cInt7aWR9fV90YWdfe3tpfX1cIlxyXG4gICAgICBjbGFzcz1cInRhZyBpcy17e3RhZy50eXBlfX0ge3t0YWcuY2xhc3NMaXN0fX0gbXItMVwiXHJcbiAgICAgIFtuZ0NsYXNzXT1cInsndGV4dC1jYXB0aW9uLTEnOiAhaXNDb25kZW5zZWQsICd0ZXh0LWNhcHRpb24tMic6IGlzQ29uZGVuc2VkLCAnaXMtY29uZGVuc2VkJzogaXNDb25kZW5zZWQsICdwci0wJzogdGFnLmlzRGlzbWlzc2FibGV9XCJcclxuICAgICAgdGl0bGU9XCJ7e3RhZy50b29sdGlwIHwgdHJhbnNsYXRlfX1cIj5cclxuICAgIDxpICpuZ0lmPVwidGFnLmljb25cIiBjbGFzcz1cImVjLWljb24ge3t0YWcuaWNvbn19IGZvbnQtY29sb3ItbXV0ZWQgZWMtaWNvbi1zbVwiPjwvaT5cclxuICAgIHt7dGFnLmxhYmVsIHwgdHJhbnNsYXRlfX1cclxuICAgIDxidXR0b24gaWQ9XCJ7e2lkfX1fdGFnX3t7aX19X2Rpc21pc3NCdXR0b25cIlxyXG4gICAgICAgICAgICAqbmdJZj1cInRhZy5pc0Rpc21pc3NhYmxlXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlVGFnKHRhZylcIj5cclxuICAgICAgPGkgY2xhc3M9XCJlYy1pY29uIGVjLWljb24tc20gaWNvbi1jYW5jZWxcIj48L2k+XHJcbiAgICA8L2J1dHRvbj5cclxuICA8L2xpPlxyXG48L3VsPiJdfQ==
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21wb25lbnRzL3NyYy9saWIvZGlzcGxheS90YWdzL3RhZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvbGliL2Rpc3BsYXkvdGFncy90YWdzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWEsS0FBSyxFQUFpQixNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUWpHLE1BQU0sT0FBTyxhQUFhO0lBdUN4QjtRQXJDQSxnQ0FBZ0M7UUFDaEIsT0FBRSxHQUFXLEVBQUUsQ0FBQztRQVVoQzs7Ozs7V0FLRztRQUNhLFNBQUksR0FBWSxJQUFJLENBQUM7UUFFckM7O1dBRUc7UUFDYSxnQkFBVyxHQUFZLEtBQUssQ0FBQztRQUU3Qzs7V0FFRztRQUNjLGNBQVMsR0FBc0IsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUV4RTs7Ozs7V0FLRztRQUNJLGNBQVMsR0FBVSxFQUFFLENBQUM7SUFFYixDQUFDO0lBRWpCOzs7Ozs7T0FNRztJQUNILFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDaEIsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFO2dCQUNiLDhFQUE4RTtnQkFDOUUsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRTtvQkFDNUIsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO2lCQUM1QjtxQkFBTTtvQkFDTCxJQUFJLENBQUMsU0FBUyxHQUFHLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO2lCQUM5QjthQUNGO2lCQUFNO2dCQUNMLHdDQUF3QztnQkFDeEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7YUFDckI7U0FDRjtJQUNILENBQUM7SUFFTSxRQUFRLENBQUMsR0FBUTtRQUN0QixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZELElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzNCLENBQUM7OzBHQW5FVSxhQUFhOzhGQUFiLGFBQWEsdUxDUjFCLGtpQ0F1Qks7MkZEZlEsYUFBYTtrQkFMekIsU0FBUzsrQkFDRSxTQUFTOzBFQU9ILEVBQUU7c0JBQWpCLEtBQUs7Z0JBUVUsSUFBSTtzQkFBbkIsS0FBSztnQkFRVSxJQUFJO3NCQUFuQixLQUFLO2dCQUtVLFdBQVc7c0JBQTFCLEtBQUs7Z0JBS1csU0FBUztzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25DaGFuZ2VzLCBJbnB1dCwgU2ltcGxlQ2hhbmdlcywgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVGFnIH0gZnJvbSAnLi90YWcnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdlYy10YWdzJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGFncy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGFncy5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWdzQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcclxuXHJcbiAgLyoqVGhlIElEIG9mIHRoaXMgc2V0IG9mIHRhZ3MgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgaWQ6IHN0cmluZyA9ICcnO1xyXG5cclxuICAvKipcclxuICAgKiBPbmUgb3IgbW9yZSB0YWdzXHJcbiAgICogXHJcbiAgICogQHR5cGUgeyhUYWcgfCBUYWdbXSl9XHJcbiAgICogQG1lbWJlcm9mIFRhZ3NDb21wb25lbnRcclxuICAgKi9cclxuICBASW5wdXQoKSBwdWJsaWMgdGFncz86IFRhZyB8IFRhZ1tdO1xyXG5cclxuICAvKipcclxuICAgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdGhlIHRhZ3Mgd2lsbCB3cmFwIG9yIG5vdFxyXG4gICAqIFxyXG4gICAqIEB0eXBlIHtib29sZWFufVxyXG4gICAqIEBtZW1iZXJvZiBUYWdzQ29tcG9uZW50XHJcbiAgICovXHJcbiAgQElucHV0KCkgcHVibGljIHdyYXA6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICAvKipcclxuICAgKiBEaXNwbGF5cyB0aGUgdGFncyBpbiBjb25kZW5zZWQgbW9kZVxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHB1YmxpYyBpc0NvbmRlbnNlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAvKipcclxuICAgKiBFbWl0cyB0aGUgdGFnIGl0ZW0gd2hlbiB0aGUgdGFnJ3MgY2xvc2UgYnV0dG9uIGlzIGNsaWNrZWRcclxuICAgKi9cclxuICBAT3V0cHV0KCkgcHVibGljIHRhZ0Nsb3NlZDogRXZlbnRFbWl0dGVyPFRhZz4gPSBuZXcgRXZlbnRFbWl0dGVyPFRhZz4oKTtcclxuXHJcbiAgLyoqXHJcbiAgICogVGFncyB0byBiZSBkaXNwbGF5ZWRcclxuICAgKiBcclxuICAgKiBAdHlwZSB7VGFnW119XHJcbiAgICogQG1lbWJlcm9mIFRhZ3NDb21wb25lbnRcclxuICAgKi9cclxuICBwdWJsaWMgdGFnc0FycmF5OiBUYWdbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICAvKipcclxuICAgKiBBbmd1bGFyIG9uQ2hhbmdlcyBsaWZlY3ljbGUgaG9va1xyXG4gICAqIEBzZWUge0BsaW5rIGh0dHBzOi8vYW5ndWxhci5pby9ndWlkZS9saWZlY3ljbGUtaG9va3MgfCBMaWZlLWN5Y2xlIGhvb2tzfVxyXG4gICAqIFxyXG4gICAqIEBwYXJhbSB7U2ltcGxlQ2hhbmdlc30gY2hhbmdlcyBcclxuICAgKiBAbWVtYmVyb2YgVGFnc0NvbXBvbmVudFxyXG4gICAqL1xyXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcclxuICAgIGlmIChjaGFuZ2VzLnRhZ3MpIHtcclxuICAgICAgaWYgKHRoaXMudGFncykge1xyXG4gICAgICAgIC8vIElmIG9ubHkgZ2l2ZW4gYSBzaW5nbGUgaXRlbSwgcHV0IGl0IGluIGFuIGFycmF5IHNvIGl0IHdvcmtzIGluIHRoZSB0ZW1wbGF0ZVxyXG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KHRoaXMudGFncykpIHtcclxuICAgICAgICAgIHRoaXMudGFnc0FycmF5ID0gdGhpcy50YWdzO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICB0aGlzLnRhZ3NBcnJheSA9IFt0aGlzLnRhZ3NdO1xyXG4gICAgICAgIH1cclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICAvLyByZXNldCBhcnJheSBpZiB0YWdzIGJlY29tZXMgdW5kZWZpbmVkXHJcbiAgICAgICAgdGhpcy50YWdzQXJyYXkgPSBbXTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGNsb3NlVGFnKHRhZzogVGFnKSB7XHJcbiAgICB0aGlzLnRhZ3NBcnJheSA9IHRoaXMudGFnc0FycmF5LmZpbHRlcih0ID0+IHQgIT09IHRhZyk7XHJcbiAgICB0aGlzLnRhZ0Nsb3NlZC5lbWl0KHRhZyk7XHJcbiAgfVxyXG59XHJcbiIsIjx1bCBjbGFzcz1cInRhZ3NcIlxyXG4gICAgW2NsYXNzLmlzLXdyYXBwZWRdPVwid3JhcFwiPlxyXG4gICA8bGkgKm5nRm9yPVwibGV0IHRhZyBvZiB0YWdzQXJyYXk7IGluZGV4IGFzIGlcIlxyXG4gICAgICAgaWQ9XCJ7e2lkfX1fdGFnX3t7aX19XCJcclxuICAgICAgIGNsYXNzPVwidGFnIGlzLXt7dGFnLnR5cGV9fSB7e3RhZy5jbGFzc0xpc3R9fSBtci0xXCJcclxuICAgICAgIFtuZ0NsYXNzXT1cInsndGV4dC1jYXB0aW9uLTEnOiAhaXNDb25kZW5zZWQsICd0ZXh0LWNhcHRpb24tMic6IGlzQ29uZGVuc2VkLCAnaXMtY29uZGVuc2VkJzogaXNDb25kZW5zZWQsICdwci0wJzogdGFnLmlzRGlzbWlzc2FibGUsICdpcy1saW5rJzogdGFnLnVybH1cIlxyXG4gICAgICAgdGl0bGU9XCJ7e3RhZy50b29sdGlwIHwgdHJhbnNsYXRlfX1cIj5cclxuICAgICAgPGkgKm5nSWY9XCJ0YWcuaWNvblwiXHJcbiAgICAgICAgIGNsYXNzPVwiZWMtaWNvbiB7e3RhZy5pY29ufX0gZm9udC1jb2xvci1tdXRlZCBlYy1pY29uLXNtXCI+PC9pPlxyXG4gICAgICA8c3BhbiAqbmdJZj1cIiF0YWcudXJsXCI+e3t0YWcubGFiZWwgfCB0cmFuc2xhdGV9fTwvc3Bhbj5cclxuXHJcbiAgICAgIDxhICpuZ0lmPVwidGFnLnVybFwiXHJcbiAgICAgICAgIGlkPVwie3tpZH19X3RhZ197e2l9fV9saW5rXCJcclxuICAgICAgICAgY2xhc3M9XCJmb250LXdlaWdodC1ib2xkXCJcclxuICAgICAgICAgaHJlZj1cInt7dGFnLnVybH19XCJcclxuICAgICAgICAgdGFyZ2V0PVwie3t0YWcudGFyZ2V0fX1cIj57e3RhZy5sYWJlbCB8IHRyYW5zbGF0ZX19PC9hPlxyXG5cclxuICAgICAgPGJ1dHRvbiBpZD1cInt7aWR9fV90YWdfe3tpfX1fZGlzbWlzc0J1dHRvblwiXHJcbiAgICAgICAgICAgICAgKm5nSWY9XCJ0YWcuaXNEaXNtaXNzYWJsZVwiXHJcbiAgICAgICAgICAgICAgKGNsaWNrKT1cImNsb3NlVGFnKHRhZylcIj5cclxuICAgICAgICAgPGkgY2xhc3M9XCJlYy1pY29uIGVjLWljb24tc20gaWNvbi1jYW5jZWxcIj48L2k+XHJcbiAgICAgIDwvYnV0dG9uPlxyXG4gICA8L2xpPlxyXG48L3VsPiJdfQ==
@@ -4430,10 +4430,10 @@ class TagsComponent {
4430
4430
  }
4431
4431
  }
4432
4432
  TagsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TagsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
4433
- TagsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TagsComponent, selector: "ec-tags", inputs: { id: "id", tags: "tags", wrap: "wrap", isCondensed: "isCondensed" }, outputs: { tagClosed: "tagClosed" }, usesOnChanges: true, ngImport: i0, template: "<ul class=\"tags\" [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\" class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n {{tag.label | translate}}\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag .ec-icon:before,.tag .ec-icon:after{width:auto;height:auto}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
4433
+ TagsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TagsComponent, selector: "ec-tags", inputs: { id: "id", tags: "tags", wrap: "wrap", isCondensed: "isCondensed" }, outputs: { tagClosed: "tagClosed" }, usesOnChanges: true, ngImport: i0, template: "<ul class=\"tags\"\r\n [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable, 'is-link': tag.url}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\"\r\n class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n <span *ngIf=\"!tag.url\">{{tag.label | translate}}</span>\r\n\r\n <a *ngIf=\"tag.url\"\r\n id=\"{{id}}_tag_{{i}}_link\"\r\n class=\"font-weight-bold\"\r\n href=\"{{tag.url}}\"\r\n target=\"{{tag.target}}\">{{tag.label | translate}}</a>\r\n\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":root{--ec-font-size-icon: 1rem;--ec-color-icon: rgba(26, 26, 35, .66)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}.is-link a:after{opacity:1;margin-left:.1875rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
4434
4434
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TagsComponent, decorators: [{
4435
4435
  type: Component,
4436
- args: [{ selector: 'ec-tags', template: "<ul class=\"tags\" [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\" class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n {{tag.label | translate}}\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag .ec-icon:before,.tag .ec-icon:after{width:auto;height:auto}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}\n"] }]
4436
+ args: [{ selector: 'ec-tags', template: "<ul class=\"tags\"\r\n [class.is-wrapped]=\"wrap\">\r\n <li *ngFor=\"let tag of tagsArray; index as i\"\r\n id=\"{{id}}_tag_{{i}}\"\r\n class=\"tag is-{{tag.type}} {{tag.classList}} mr-1\"\r\n [ngClass]=\"{'text-caption-1': !isCondensed, 'text-caption-2': isCondensed, 'is-condensed': isCondensed, 'pr-0': tag.isDismissable, 'is-link': tag.url}\"\r\n title=\"{{tag.tooltip | translate}}\">\r\n <i *ngIf=\"tag.icon\"\r\n class=\"ec-icon {{tag.icon}} font-color-muted ec-icon-sm\"></i>\r\n <span *ngIf=\"!tag.url\">{{tag.label | translate}}</span>\r\n\r\n <a *ngIf=\"tag.url\"\r\n id=\"{{id}}_tag_{{i}}_link\"\r\n class=\"font-weight-bold\"\r\n href=\"{{tag.url}}\"\r\n target=\"{{tag.target}}\">{{tag.label | translate}}</a>\r\n\r\n <button id=\"{{id}}_tag_{{i}}_dismissButton\"\r\n *ngIf=\"tag.isDismissable\"\r\n (click)=\"closeTag(tag)\">\r\n <i class=\"ec-icon ec-icon-sm icon-cancel\"></i>\r\n </button>\r\n </li>\r\n</ul>", styles: [":root{--ec-font-size-icon: 1rem;--ec-color-icon: rgba(26, 26, 35, .66)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(1turn)}}:host{display:block}.tags{padding:0;margin:0;list-style:none;display:flex}.tags.is-wrapped{flex-wrap:wrap;margin-top:.25rem}.tags.is-wrapped>.tag{margin-bottom:.25rem}.tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:#acbcc340;border:2px solid rgb(172,188,195);display:inline-flex;align-items:center;border-radius:calc(var(--ec-border-radius, .25rem) * 3);height:1.5rem;line-height:1.25rem;padding:0 .4375rem;vertical-align:top}.tag>.ec-icon:first-child{margin-right:.1875rem}.tag .ec-icon{display:flex;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;width:auto;height:auto;min-width:1em;justify-content:center}.tag.is-inverted{background-color:var(--ec-background-color);border-color:var(--ec-background-color)}.tag.is-info{background-color:#acbcc340;border-color:#acbcc3}.tag.is-success{background-color:#c1cd2340;border-color:#c1cd23}.tag.is-warning{background-color:#f5d40040;border-color:#f5d400}.tag.is-danger{background-color:#e3343640;border-color:#e33436}.tag.is-accent{background-color:#906ea840;border-color:#906ea8}.tag.is-chargeback{background-color:#fa7b2e40;border-color:#fa7b2e}.tag.is-accrual{background-color:#23c3cd40;border-color:#23c3cd}button{background-color:transparent;border:0;display:flex;align-items:center;padding:0 .4375rem 0 .1875rem;height:100%;cursor:pointer}button:hover,button:focus{background-color:#1a1a231a;outline:none}.is-condensed{border-radius:var(--ec-border-radius);border:0;padding:0 .25rem;height:1.125rem;line-height:1.125rem;min-width:1.125rem;justify-content:center}.is-condensed>.ec-icon:first-child{margin-right:.125rem}.is-condensed button{padding-right:.25rem;padding-left:.125rem}.is-link a:after{opacity:1;margin-left:.1875rem}\n"] }]
4437
4437
  }], ctorParameters: function () { return []; }, propDecorators: { id: [{
4438
4438
  type: Input
4439
4439
  }], tags: [{
@@ -10180,12 +10180,15 @@ function safeToLower(item, prop) {
10180
10180
 
10181
10181
  /** Tag contains a label and type. Type is default by default */
10182
10182
  class Tag {
10183
- constructor(label, type, classList, icon, isDismissable, tooltip) {
10183
+ constructor(label, type, classList, icon, isDismissable, tooltip, url, target) {
10184
+ this.target = '_self';
10184
10185
  this.label = label;
10185
10186
  this.type = type || 'info';
10186
10187
  this.icon = icon;
10187
10188
  this.isDismissable = isDismissable !== null && isDismissable !== void 0 ? isDismissable : false;
10188
10189
  this.tooltip = tooltip;
10190
+ this.url = url;
10191
+ this.target = target || '_self';
10189
10192
  if (classList) {
10190
10193
  this.classList = classList;
10191
10194
  }