UNPKG

stimulsoft-viewer-angular

Version:
359 lines (353 loc) 38 kB
import { Component, Input, ViewChild, Output, EventEmitter } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../menu/menu.service"; import * as i3 from "../services/tooltip.service"; import * as i4 from "../services/helper.service"; import * as i5 from "@angular/common"; export class ButtonComponent { constructor(model, menuService, tooltipService, helper) { this.model = model; this.menuService = menuService; this.tooltipService = tooltipService; this.helper = helper; this.margin = '1px'; this.height = '23px'; this.selected = false; this.imageCellTextAlign = 'center'; this.imageSizesWidth = 16; this.imageSizesHeight = 16; this.closeButton = false; this.resourceButton = false; this.navagationPanelTooltip = false; this.helpLink = 'user-manual/index.html?viewer_reports.htm'; this.action = new EventEmitter(); this.closeButtonAction = new EventEmitter(); this.over = false; this.showMenu = false; this.closeButtonPressed = false; this.resourceButtonPressed = false; this._enabled = true; this.canShowTooltip = true; } ngOnInit() { if (this.menuItems) { setTimeout(() => { this.menuObj = { type: 'buttonMenu', name: this.actionName, items: this.menuItems, parent: !this.resourceButton ? this.button : this.resButtonEl, state: '' }; this.menuService.addMenu(this.menuObj); }, 500); } } get styleName() { return this._styleName || 'stiJsViewerStandartSmallButton'; } set styleName(value) { this._styleName = value; } get enabled() { return this._enabled; } set enabled(value) { if (!value) { this.over = false; } this._enabled = value; } mouseover() { if (!this.enabled) { return; } this.over = true; if (this.model.options.toolbar.showMenuMode === 'Hover' && ['Print', 'Save', 'SendEmail', 'Zoom', 'ViewMode'].some(a => a === this.actionName)) { this.tooltipService.hideImmediately(); this.menuService.showMenu(this.actionName); } else if (this.tooltip && !this.menuService.menus.some(e => e.state === 'expanded') && this.canShowTooltip) { const top = !this.navagationPanelTooltip ? this.model.controls.toolbar.offsetHeight + this.model.controls.dashboardsPanel.offsetHeight : this.helper.findPosY(this.model.controls.navigatePanel.el.nativeElement, 'stiJsViewerMainPanel'); const tooltip = this.tooltip === true ? (this.model.localization[this.actionName + 'ToolTip'] != null ? this.model.loc(this.actionName + 'ToolTip') : this.model.loc(this.actionName)) : this.tooltip; this.tooltipService.show(this.helper.findPosX(this.button.nativeElement, 'stiJsViewerMainPanel'), top, tooltip, !this.navagationPanelTooltip, this.helpLink); } } mouseout() { if (!this.enabled) { return; } this.over = false; this.tooltipService.hide(); setTimeout(() => { this.canShowTooltip = true; }, 1000); } click() { if (this.enabled && !this.closeButtonPressed) { this.tooltipService.hideImmediately(); if (this.menuItems == null || (this.resourceButton && !this.resourceButtonPressed)) { this.action.emit(); } else { this.menuService.showMenu(this.actionName); } } this.canShowTooltip = false; this.closeButtonPressed = false; this.resourceButtonPressed = false; } get className() { return this.styleName ? this.styleName + ' ' + (this.enabled ? (this.styleName + ((this.selected || this.menuObj?.state === 'expanded') ? 'Selected' : (this.over ? 'Over' : 'Default'))) : this.styleName + 'Disabled') : ''; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.ModelService }, { token: i2.MenuService }, { token: i3.TooltipService }, { token: i4.HelperService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ButtonComponent, selector: "sti-button", inputs: { caption: "caption", caption2: "caption2", captionAlign: "captionAlign", captionPadding: "captionPadding", captionPaddingLeft: "captionPaddingLeft", captionWhiteSpace: "captionWhiteSpace", captionOverflow: "captionOverflow", captionTextOverflow: "captionTextOverflow", captionWidth: "captionWidth", captionMaxWidth: "captionMaxWidth", captionLineHeight: "captionLineHeight", imageName: "imageName", arrow: "arrow", arrowMarginTop: "arrowMarginTop", margin: "margin", height: "height", selected: "selected", minWidth: "minWidth", innerTableWidth: "innerTableWidth", menuItems: "menuItems", actionName: "actionName", tooltip: "tooltip", imageCellTextAlign: "imageCellTextAlign", imageCellWidth: "imageCellWidth", imageCellPadding: "imageCellPadding", imageSizesWidth: "imageSizesWidth", imageSizesHeight: "imageSizesHeight", imageMargin: "imageMargin", width: "width", display: "display", closeButton: "closeButton", resourceButton: "resourceButton", styleColors: "styleColors", boxSizing: "boxSizing", navagationPanelTooltip: "navagationPanelTooltip", cursor: "cursor", fontSize: "fontSize", helpLink: "helpLink", borderColor: "borderColor", styleName: "styleName", enabled: "enabled" }, outputs: { action: "action", closeButtonAction: "closeButtonAction" }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }, { propertyName: "resButtonEl", first: true, predicate: ["resButtonEl"], descendants: true }], ngImport: i0, template: ` <div #button [style.fontFamily]="model.options.toolbar.fontFamily" [style.cursor]="cursor" [style.borderColor]="borderColor" [class]="className" [style.height]="helper.val(height, '23px')" [style.boxSizing]="helper.val(boxSizing, 'content-box')" [style.margin]="helper.val(margin, '1px')" [style.minWidth]="minWidth" [style.width]="width" [style.display]="display" [style.fontSize]="fontSize" (mouseover)="mouseover()" (mouseout)="mouseout()" (click)="click()" > <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.height]="'100%'" [style.width]="innerTableWidth"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td *ngIf="imageName != null" [style.lineHeight]="0" [style.padding]="helper.val(imageCellPadding, '0 3px')" [style.textAlign]="imageCellTextAlign" [style.width]="imageCellWidth" class="stiJsViewerClearAllStyles"> <img src="{{model.img(imageName)}}" [style.opacity]="enabled ? '1' : '0.5'" [style.width.px]="imageSizesWidth" [style.height.px]="imageSizesHeight" [style.margin]="imageMargin"> </td> <td *ngIf="caption != null" [style.whiteSpace]="'nowrap'" [style.textAlign]="captionAlign || 'left'" [style.padding]="captionPadding || ((arrow ? '1px 0' : '1px 5px') + (imageName ? ' 0 0' : ' 0 5px'))" [style.width]="captionWidth" [style.maxWidth]="captionMaxWidth" [style.lineHeight]="captionLineHeight" [style.paddingLeft]="captionPaddingLeft" [style.whiteSpace]="captionWhiteSpace" [style.overflow]="captionOverflow" [style.textOverflow]="captionTextOverflow" class="stiJsViewerClearAllStyles"> {{caption}} <div *ngIf="caption2 != null"> {{caption2}} </div> </td> <td *ngIf="arrow" class="stiJsViewerClearAllStyles"> <img src="{{arrow == 'Up' || arrow == 'Down' ? model.img('Arrows.SmallArrow' + arrow + (arrow == 'Down' && styleColors && styleColors.isDarkStyle ? 'White.png' : '.png')) : model.img(arrow)}}" [style]="{lineHeight:'0', width:'8px', height:'8px', verticalAlign:'baseline', padding:caption ? '0 5px 0 5px' : '0 5px 0 2px', marginTop: arrowMarginTop}" [style.opacity]="enabled ? '1' : '0.5'"/> </td> <td *ngIf="closeButton" class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'CloseForm.png'" [imageMargin]="'1px 0 0 -1px'" [margin]="'0 2px 0 0'" [imageCellPadding]="'0'" [width]="model.options.isTouchDevice ? '22px' : '17px'" [height]="model.options.isTouchDevice ? '22px' : '17px'" (action)="closeButtonPressed = true; closeButtonAction.emit()"> </sti-button> </td> <td #resButtonEl *ngIf="resourceButton" [style.width.px]="1"> <sti-button [imageName]="'Arrows.SmallArrowDown.png'" [styleName]="'stiJsViewerResourceDropDownButton'" [innerTableWidth]="'100%'" [margin]="'0 7px 0 3px'" [imageCellTextAlign]="'center'" [imageSizesWidth]="8" [imageSizesHeight]="8" [height]="model.options.isTouchDevice ? '23px' : '17px'" [width]="model.options.isTouchDevice ? '23px' : '17px'" (action)="resourceButtonPressed = true;">> </sti-button> </td> </tr> </tbody> </table> </div> `, isInline: true, dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "sti-button", inputs: ["caption", "caption2", "captionAlign", "captionPadding", "captionPaddingLeft", "captionWhiteSpace", "captionOverflow", "captionTextOverflow", "captionWidth", "captionMaxWidth", "captionLineHeight", "imageName", "arrow", "arrowMarginTop", "margin", "height", "selected", "minWidth", "innerTableWidth", "menuItems", "actionName", "tooltip", "imageCellTextAlign", "imageCellWidth", "imageCellPadding", "imageSizesWidth", "imageSizesHeight", "imageMargin", "width", "display", "closeButton", "resourceButton", "styleColors", "boxSizing", "navagationPanelTooltip", "cursor", "fontSize", "helpLink", "borderColor", "styleName", "enabled"], outputs: ["action", "closeButtonAction"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonComponent, decorators: [{ type: Component, args: [{ selector: 'sti-button', template: ` <div #button [style.fontFamily]="model.options.toolbar.fontFamily" [style.cursor]="cursor" [style.borderColor]="borderColor" [class]="className" [style.height]="helper.val(height, '23px')" [style.boxSizing]="helper.val(boxSizing, 'content-box')" [style.margin]="helper.val(margin, '1px')" [style.minWidth]="minWidth" [style.width]="width" [style.display]="display" [style.fontSize]="fontSize" (mouseover)="mouseover()" (mouseout)="mouseout()" (click)="click()" > <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.height]="'100%'" [style.width]="innerTableWidth"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td *ngIf="imageName != null" [style.lineHeight]="0" [style.padding]="helper.val(imageCellPadding, '0 3px')" [style.textAlign]="imageCellTextAlign" [style.width]="imageCellWidth" class="stiJsViewerClearAllStyles"> <img src="{{model.img(imageName)}}" [style.opacity]="enabled ? '1' : '0.5'" [style.width.px]="imageSizesWidth" [style.height.px]="imageSizesHeight" [style.margin]="imageMargin"> </td> <td *ngIf="caption != null" [style.whiteSpace]="'nowrap'" [style.textAlign]="captionAlign || 'left'" [style.padding]="captionPadding || ((arrow ? '1px 0' : '1px 5px') + (imageName ? ' 0 0' : ' 0 5px'))" [style.width]="captionWidth" [style.maxWidth]="captionMaxWidth" [style.lineHeight]="captionLineHeight" [style.paddingLeft]="captionPaddingLeft" [style.whiteSpace]="captionWhiteSpace" [style.overflow]="captionOverflow" [style.textOverflow]="captionTextOverflow" class="stiJsViewerClearAllStyles"> {{caption}} <div *ngIf="caption2 != null"> {{caption2}} </div> </td> <td *ngIf="arrow" class="stiJsViewerClearAllStyles"> <img src="{{arrow == 'Up' || arrow == 'Down' ? model.img('Arrows.SmallArrow' + arrow + (arrow == 'Down' && styleColors && styleColors.isDarkStyle ? 'White.png' : '.png')) : model.img(arrow)}}" [style]="{lineHeight:'0', width:'8px', height:'8px', verticalAlign:'baseline', padding:caption ? '0 5px 0 5px' : '0 5px 0 2px', marginTop: arrowMarginTop}" [style.opacity]="enabled ? '1' : '0.5'"/> </td> <td *ngIf="closeButton" class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'CloseForm.png'" [imageMargin]="'1px 0 0 -1px'" [margin]="'0 2px 0 0'" [imageCellPadding]="'0'" [width]="model.options.isTouchDevice ? '22px' : '17px'" [height]="model.options.isTouchDevice ? '22px' : '17px'" (action)="closeButtonPressed = true; closeButtonAction.emit()"> </sti-button> </td> <td #resButtonEl *ngIf="resourceButton" [style.width.px]="1"> <sti-button [imageName]="'Arrows.SmallArrowDown.png'" [styleName]="'stiJsViewerResourceDropDownButton'" [innerTableWidth]="'100%'" [margin]="'0 7px 0 3px'" [imageCellTextAlign]="'center'" [imageSizesWidth]="8" [imageSizesHeight]="8" [height]="model.options.isTouchDevice ? '23px' : '17px'" [width]="model.options.isTouchDevice ? '23px' : '17px'" (action)="resourceButtonPressed = true;">> </sti-button> </td> </tr> </tbody> </table> </div> ` }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.MenuService }, { type: i3.TooltipService }, { type: i4.HelperService }], propDecorators: { caption: [{ type: Input }], caption2: [{ type: Input }], captionAlign: [{ type: Input }], captionPadding: [{ type: Input }], captionPaddingLeft: [{ type: Input }], captionWhiteSpace: [{ type: Input }], captionOverflow: [{ type: Input }], captionTextOverflow: [{ type: Input }], captionWidth: [{ type: Input }], captionMaxWidth: [{ type: Input }], captionLineHeight: [{ type: Input }], imageName: [{ type: Input }], arrow: [{ type: Input }], arrowMarginTop: [{ type: Input }], margin: [{ type: Input }], height: [{ type: Input }], selected: [{ type: Input }], minWidth: [{ type: Input }], innerTableWidth: [{ type: Input }], menuItems: [{ type: Input }], actionName: [{ type: Input }], tooltip: [{ type: Input }], imageCellTextAlign: [{ type: Input }], imageCellWidth: [{ type: Input }], imageCellPadding: [{ type: Input }], imageSizesWidth: [{ type: Input }], imageSizesHeight: [{ type: Input }], imageMargin: [{ type: Input }], width: [{ type: Input }], display: [{ type: Input }], closeButton: [{ type: Input }], resourceButton: [{ type: Input }], styleColors: [{ type: Input }], boxSizing: [{ type: Input }], navagationPanelTooltip: [{ type: Input }], cursor: [{ type: Input }], fontSize: [{ type: Input }], helpLink: [{ type: Input }], borderColor: [{ type: Input }], action: [{ type: Output }], closeButtonAction: [{ type: Output }], button: [{ type: ViewChild, args: ['button'] }], resButtonEl: [{ type: ViewChild, args: ['resButtonEl'] }], styleName: [{ type: Input }], enabled: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/controls/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef, Output, EventEmitter } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { MenuService, Menu } from '../menu/menu.service';\r\nimport { TooltipService } from '../services/tooltip.service';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { MenuItem } from '../menu/meni-item.component';\r\n\r\n@Component({\r\n  selector: 'sti-button',\r\n  template: `\r\n  <div #button\r\n    [style.fontFamily]=\"model.options.toolbar.fontFamily\"\r\n    [style.cursor]=\"cursor\"\r\n    [style.borderColor]=\"borderColor\"\r\n    [class]=\"className\"\r\n    [style.height]=\"helper.val(height, '23px')\"\r\n    [style.boxSizing]=\"helper.val(boxSizing, 'content-box')\"\r\n    [style.margin]=\"helper.val(margin, '1px')\"\r\n    [style.minWidth]=\"minWidth\"\r\n    [style.width]=\"width\"\r\n    [style.display]=\"display\"\r\n    [style.fontSize]=\"fontSize\"\r\n    (mouseover)=\"mouseover()\"\r\n    (mouseout)=\"mouseout()\"\r\n    (click)=\"click()\" >\r\n    <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\" [style.height]=\"'100%'\" [style.width]=\"innerTableWidth\">\r\n      <tbody>\r\n        <tr class=\"stiJsViewerClearAllStyles\">\r\n          <td *ngIf=\"imageName != null\" [style.lineHeight]=\"0\" [style.padding]=\"helper.val(imageCellPadding, '0 3px')\" [style.textAlign]=\"imageCellTextAlign\"\r\n          [style.width]=\"imageCellWidth\" class=\"stiJsViewerClearAllStyles\">\r\n            <img src=\"{{model.img(imageName)}}\"\r\n                [style.opacity]=\"enabled ? '1' : '0.5'\"\r\n                [style.width.px]=\"imageSizesWidth\"\r\n                [style.height.px]=\"imageSizesHeight\"\r\n                [style.margin]=\"imageMargin\">\r\n          </td>\r\n          <td *ngIf=\"caption != null\"\r\n             [style.whiteSpace]=\"'nowrap'\"\r\n             [style.textAlign]=\"captionAlign || 'left'\"\r\n             [style.padding]=\"captionPadding || ((arrow ? '1px 0' : '1px 5px') + (imageName ? ' 0 0' : ' 0 5px'))\"\r\n             [style.width]=\"captionWidth\"\r\n             [style.maxWidth]=\"captionMaxWidth\"\r\n             [style.lineHeight]=\"captionLineHeight\"\r\n             [style.paddingLeft]=\"captionPaddingLeft\"\r\n             [style.whiteSpace]=\"captionWhiteSpace\"\r\n             [style.overflow]=\"captionOverflow\"\r\n             [style.textOverflow]=\"captionTextOverflow\"\r\n             class=\"stiJsViewerClearAllStyles\">\r\n            {{caption}}\r\n            <div *ngIf=\"caption2 != null\">\r\n            {{caption2}}\r\n            </div>\r\n          </td>\r\n          <td *ngIf=\"arrow\" class=\"stiJsViewerClearAllStyles\">\r\n            <img src=\"{{arrow == 'Up' || arrow == 'Down' ? model.img('Arrows.SmallArrow' + arrow + (arrow == 'Down' && styleColors && styleColors.isDarkStyle ? 'White.png' : '.png')) : model.img(arrow)}}\"\r\n            [style]=\"{lineHeight:'0', width:'8px', height:'8px', verticalAlign:'baseline', padding:caption ? '0 5px 0 5px' : '0 5px 0 2px', marginTop: arrowMarginTop}\"\r\n            [style.opacity]=\"enabled ? '1' : '0.5'\"/>\r\n          </td>\r\n\r\n          <td *ngIf=\"closeButton\" class=\"stiJsViewerClearAllStyles\">\r\n            <sti-button [imageName]=\"'CloseForm.png'\"\r\n              [imageMargin]=\"'1px 0 0 -1px'\"\r\n              [margin]=\"'0 2px 0 0'\"\r\n              [imageCellPadding]=\"'0'\"\r\n              [width]=\"model.options.isTouchDevice ? '22px' : '17px'\"\r\n              [height]=\"model.options.isTouchDevice ? '22px' : '17px'\"\r\n              (action)=\"closeButtonPressed = true; closeButtonAction.emit()\">\r\n            </sti-button>\r\n          </td>\r\n\r\n          <td #resButtonEl *ngIf=\"resourceButton\" [style.width.px]=\"1\">\r\n            <sti-button [imageName]=\"'Arrows.SmallArrowDown.png'\"\r\n              [styleName]=\"'stiJsViewerResourceDropDownButton'\"\r\n              [innerTableWidth]=\"'100%'\"\r\n              [margin]=\"'0 7px 0 3px'\"\r\n              [imageCellTextAlign]=\"'center'\"\r\n              [imageSizesWidth]=\"8\"\r\n              [imageSizesHeight]=\"8\"\r\n              [height]=\"model.options.isTouchDevice ? '23px' : '17px'\"\r\n              [width]=\"model.options.isTouchDevice ? '23px' : '17px'\"\r\n              (action)=\"resourceButtonPressed = true;\">>\r\n            </sti-button>\r\n          </td>\r\n\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n  </div>\r\n  `\r\n})\r\nexport class ButtonComponent implements OnInit {\r\n\r\n  @Input() caption: string;\r\n  @Input() caption2: string;\r\n  @Input() captionAlign: string;\r\n  @Input() captionPadding: string;\r\n  @Input() captionPaddingLeft: string;\r\n  @Input() captionWhiteSpace: string;\r\n  @Input() captionOverflow: string;\r\n  @Input() captionTextOverflow: string;\r\n  @Input() captionWidth: string;\r\n  @Input() captionMaxWidth: string;\r\n  @Input() captionLineHeight: string;\r\n  @Input() imageName: string;\r\n  @Input() arrow: string;\r\n  @Input() arrowMarginTop: string;\r\n  @Input() margin = '1px';\r\n  @Input() height = '23px';\r\n  @Input() selected = false;\r\n  @Input() minWidth: string;\r\n  @Input() innerTableWidth: string;\r\n  @Input() menuItems: MenuItem[];\r\n  @Input() actionName: string;\r\n  @Input() tooltip: any;\r\n  @Input() imageCellTextAlign = 'center';\r\n  @Input() imageCellWidth: string;\r\n  @Input() imageCellPadding: string;\r\n  @Input() imageSizesWidth = 16;\r\n  @Input() imageSizesHeight = 16;\r\n  @Input() imageMargin: string;\r\n  @Input() width: string;\r\n  @Input() display: string;\r\n  @Input() closeButton = false;\r\n  @Input() resourceButton = false;\r\n  @Input() styleColors: any;\r\n  @Input() boxSizing: string;\r\n  @Input() navagationPanelTooltip = false;\r\n  @Input() cursor: string;\r\n  @Input() fontSize: string;\r\n  @Input() helpLink = 'user-manual/index.html?viewer_reports.htm';\r\n  @Input() borderColor;\r\n\r\n  @Output() action: EventEmitter<any> = new EventEmitter();\r\n  @Output() closeButtonAction: EventEmitter<any> = new EventEmitter();\r\n  @ViewChild('button') button: ElementRef;\r\n  @ViewChild('resButtonEl') resButtonEl: ElementRef;\r\n\r\n  over = false;\r\n  showMenu = false;\r\n  closeButtonPressed = false;\r\n  resourceButtonPressed = false;\r\n  private _enabled = true;\r\n  private _styleName: string;\r\n  private menuObj: Menu;\r\n  private canShowTooltip = true;\r\n\r\n  constructor(public model: ModelService, public menuService: MenuService, private tooltipService: TooltipService,\r\n    public helper: HelperService) { }\r\n\r\n  ngOnInit(): void {\r\n    if (this.menuItems) {\r\n      setTimeout(() => {\r\n        this.menuObj = { type: 'buttonMenu', name: this.actionName, items: this.menuItems, parent: !this.resourceButton ? this.button : this.resButtonEl, state: '' };\r\n        this.menuService.addMenu(this.menuObj);\r\n      }, 500);\r\n    }\r\n  }\r\n\r\n  @Input() get styleName(): string {\r\n    return this._styleName || 'stiJsViewerStandartSmallButton';\r\n  }\r\n\r\n  set styleName(value: string) {\r\n    this._styleName = value;\r\n  }\r\n\r\n  @Input() get enabled(): boolean {\r\n    return this._enabled;\r\n  }\r\n\r\n  set enabled(value: boolean) {\r\n    if (!value) {\r\n      this.over = false;\r\n    }\r\n    this._enabled = value;\r\n  }\r\n\r\n  mouseover() {\r\n    if (!this.enabled) {\r\n      return;\r\n    }\r\n    this.over = true;\r\n\r\n    if (this.model.options.toolbar.showMenuMode === 'Hover' && ['Print', 'Save', 'SendEmail', 'Zoom', 'ViewMode'].some(a => a === this.actionName)) {\r\n      this.tooltipService.hideImmediately();\r\n      this.menuService.showMenu(this.actionName);\r\n    } else if (this.tooltip && !this.menuService.menus.some(e => e.state === 'expanded') && this.canShowTooltip) {\r\n      const top = !this.navagationPanelTooltip ? this.model.controls.toolbar.offsetHeight + this.model.controls.dashboardsPanel.offsetHeight :\r\n        this.helper.findPosY(this.model.controls.navigatePanel.el.nativeElement, 'stiJsViewerMainPanel');\r\n      const tooltip = this.tooltip === true ? (this.model.localization[this.actionName + 'ToolTip'] != null ? this.model.loc(this.actionName + 'ToolTip') : this.model.loc(this.actionName)) : this.tooltip;\r\n      this.tooltipService.show(this.helper.findPosX(this.button.nativeElement, 'stiJsViewerMainPanel'),\r\n        top, tooltip, !this.navagationPanelTooltip, this.helpLink);\r\n    }\r\n  }\r\n\r\n  mouseout() {\r\n    if (!this.enabled) {\r\n      return;\r\n    }\r\n    this.over = false;\r\n    this.tooltipService.hide();\r\n    setTimeout(() => {\r\n      this.canShowTooltip = true;\r\n    }, 1000);\r\n  }\r\n\r\n  click() {\r\n    if (this.enabled && !this.closeButtonPressed) {\r\n      this.tooltipService.hideImmediately();\r\n      if (this.menuItems == null || (this.resourceButton && !this.resourceButtonPressed)) {\r\n        this.action.emit();\r\n      } else {\r\n        this.menuService.showMenu(this.actionName);\r\n      }\r\n    }\r\n    this.canShowTooltip = false;\r\n    this.closeButtonPressed = false;\r\n    this.resourceButtonPressed = false;\r\n  }\r\n\r\n  get className(): string {\r\n    return this.styleName ? this.styleName + ' ' + (this.enabled ? (this.styleName + ((this.selected || this.menuObj?.state === 'expanded') ? 'Selected' : (this.over ? 'Over' : 'Default'))) : this.styleName + 'Disabled') : '';\r\n  }\r\n}\r\n"]}