stimulsoft-viewer-angular
Version:
The Viewer component is designed to view reports and dashboards in the web browser.
165 lines • 26.3 kB
JavaScript
import { Injectable } from '@angular/core';
import { Subject } from 'rxjs';
import * as i0 from "@angular/core";
import * as i1 from "../services/helper.service";
import * as i2 from "../services/model.service";
import * as i3 from "../services/mouse.service";
export class Menu {
constructor() { }
get state() {
return this._state;
}
set state(value) {
let oldState = this._state;
this._state = value;
if (oldState != 'initialDown' && oldState != '' && value == 'initialDown' && this.onCloseEvent) {
this.onCloseEvent();
}
}
}
export class MenuService {
constructor(helper, model, mouseService) {
this.helper = helper;
this.model = model;
this.mouseService = mouseService;
this.VERTICAL_MENU_NAME = 'verticalMenu';
this.menuMouseUp = '';
this._menus = {};
this.subject = new Subject();
this.mouseService.getDocumentMouseUp().subscribe((event) => {
if (this.menuMouseUp === '') {
this.closeAllMenus();
}
else if (this.menuMouseUp !== 'datePickerMenu' && this.menuMouseUp !== this.VERTICAL_MENU_NAME) {
const datePicker = Object.values(this._menus).find(m => m.type === 'datePickerMenu');
if (datePicker != null) {
datePicker.state = 'initialDown';
}
}
this.menuMouseUp = '';
});
}
getVisibility() {
return this.subject.asObservable();
}
addMenu(menu) {
let inMenu = new Menu();
for (let key in menu) {
inMenu[key] = menu[key];
}
this._menus[menu.name] = inMenu;
}
closeAllMenus() {
Object.values(this._menus).forEach((m) => m.state = m.type === 'buttonMenu' && this.model.options.isMobileDevice ? 'initialLeft' : 'initialDown');
}
isMenuVisible() {
return Object.values(this._menus).find(m => m.state === 'expanded') != null;
}
showMenu(menuName) {
const menu = this._menus[menuName];
if (menu?.type !== 'datePickerMenu' && menu?.type !== this.VERTICAL_MENU_NAME) {
this.closeAllMenus();
}
if (menu) {
menu.sizeStyle = 'opacity: 0;';
if (this.model.options.isMobileDevice && menu.type === 'buttonMenu') {
setTimeout(() => {
const innerContent = menu.innerContent.nativeElement;
menu.left = 0;
menu.top = 0;
menu.width = innerContent.offsetWidth;
menu.height = innerContent.offsetHeight;
menu.state = 'initialLeft';
menu.sizeStyle = null;
setTimeout(() => {
menu.state = 'expanded';
});
});
}
else {
setTimeout(() => {
menu.sizeStyle = null;
this.showMenuInternal(menu);
});
}
this.subject.next(menu);
}
}
showMenuInternal(menu) {
const isVertMenu = true;
const parentButton = menu.parent.nativeElement;
const innerContent = menu.innerContent.nativeElement;
const offsetHeight = menu.menuEl.nativeElement.offsetHeight;
const style = menu.menuEl.nativeElement.style;
const coords = this.getMenuCoordinates(parentButton, innerContent, offsetHeight, style, isVertMenu);
menu.left = coords.left;
menu.top = coords.top;
menu.width = menu.width || coords.width;
menu.height = coords.height;
menu.state = coords.state;
setTimeout(() => {
menu.state = 'expanded';
});
}
getMenuCoordinates(parentButton, innerContent, offsetHeight, style, isVertMenu) {
const menu = {};
const browserWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;
const browserHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
const rightAlign = false;
const mainClassName = 'stiJsViewerMainPanel';
let animDirect = 'Down';
const leftOffset = 0;
let left = (isVertMenu)
? (this.model.options.appearance.rightToLeft || rightAlign
? (this.helper.findPosX(parentButton, mainClassName) - innerContent.offsetWidth + parentButton.offsetWidth) - (leftOffset || 0)
: this.helper.findPosX(parentButton, mainClassName) - (leftOffset || 0))
: ((animDirect === 'Right')
? (this.helper.findPosX(parentButton, mainClassName) + parentButton.offsetWidth + 2)
: (this.helper.findPosX(parentButton, mainClassName) - parentButton.offsetWidth - 2));
if (left + innerContent.offsetWidth > browserWidth) {
left = browserWidth - innerContent.offsetWidth - 15;
}
if (left < 0) {
left = 10;
}
menu.left = left;
if (animDirect === 'Down' &&
this.helper.findPosY(parentButton) + parentButton.offsetHeight + innerContent.offsetHeight > browserHeight &&
this.helper.findPosY(parentButton) - innerContent.offsetHeight > 0) {
animDirect = 'Up';
}
menu.top = (isVertMenu)
? ((animDirect === 'Down')
? (this.helper.findPosY(parentButton, mainClassName) + parentButton.offsetHeight + 2)
: (this.helper.findPosY(parentButton, mainClassName) - offsetHeight))
: (this.helper.findPosY(parentButton, mainClassName) + parentButton.offsetHeight + innerContent.offsetHeight > browserHeight &&
(browserHeight - innerContent.offsetHeight - 10) > 0)
? (browserHeight - innerContent.offsetHeight - 10)
: this.helper.findPosY(parentButton, mainClassName);
menu.width = innerContent.offsetWidth;
menu.height = innerContent.offsetHeight;
if (menu.top + innerContent.offsetHeight > browserHeight) {
menu.top = (browserHeight - innerContent.offsetHeight - 10);
}
if (menu.top < 0) {
menu.top = 10;
}
menu.state = animDirect === 'Down' ? 'initialDown' : 'initialUp';
return menu;
}
get menus() {
return Object.values(this._menus);
}
getVerticalMenu() {
return this._menus[this.VERTICAL_MENU_NAME];
}
getMenu(name) {
return this._menus[name];
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MenuService, deps: [{ token: i1.HelperService }, { token: i2.ModelService }, { token: i3.MouseService }], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MenuService }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MenuService, decorators: [{
type: Injectable
}], ctorParameters: () => [{ type: i1.HelperService }, { type: i2.ModelService }, { type: i3.MouseService }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.service.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/menu/menu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ElementRef, EventEmitter } from '@angular/core';\r\nimport { MenuItem } from './meni-item.component';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { ModelService } from '../services/model.service';\r\nimport { MouseService } from '../services/mouse.service';\r\nimport { Variable, Item } from '../services/objects';\r\nimport { Subject, Observable } from 'rxjs';\r\n\r\nexport class Menu {\r\n\r\n  private _state?: string;\r\n  public name: string;\r\n  public items: MenuItem[];\r\n  public parent: ElementRef;\r\n  public type: string;\r\n  public menuEl?: ElementRef;\r\n  public top?: number;\r\n  public left?: number;\r\n  public innerContent?: ElementRef;\r\n  public width?: number;\r\n  public height?: number;\r\n  public menuStyleName?: string;\r\n  public params?: Variable;\r\n  public verticalItems?: Item[];\r\n  public action?: EventEmitter<any>;\r\n  public itemStyleName?: string;\r\n  public value?: any;\r\n  public sizeStyle?: string;\r\n  public onCloseEvent?: any;\r\n\r\n  constructor() { }\r\n\r\n  public get state(): string {\r\n    return this._state;\r\n  }\r\n\r\n  public set state(value: string) {\r\n    let oldState = this._state;\r\n    this._state = value;\r\n    if (oldState != 'initialDown' && oldState != '' && value == 'initialDown' && this.onCloseEvent) {\r\n      this.onCloseEvent();\r\n    }\r\n  }\r\n\r\n}\r\n\r\n@Injectable()\r\nexport class MenuService {\r\n  public VERTICAL_MENU_NAME = 'verticalMenu';\r\n\r\n  public menuMouseUp = '';\r\n\r\n  private _menus: {} = {};\r\n  private subject = new Subject<Menu>();\r\n\r\n  constructor(private helper: HelperService, private model: ModelService, private mouseService: MouseService) {\r\n    this.mouseService.getDocumentMouseUp().subscribe((event) => {\r\n      if (this.menuMouseUp === '') {\r\n        this.closeAllMenus();\r\n      } else if (this.menuMouseUp !== 'datePickerMenu' && this.menuMouseUp !== this.VERTICAL_MENU_NAME) {\r\n        const datePicker = Object.values(this._menus).find(m => (m as Menu).type === 'datePickerMenu') as Menu;\r\n        if (datePicker != null) {\r\n          datePicker.state = 'initialDown';\r\n        }\r\n      }\r\n      this.menuMouseUp = '';\r\n    });\r\n  }\r\n\r\n  public getVisibility(): Observable<Menu> {\r\n    return this.subject.asObservable();\r\n  }\r\n\r\n  public addMenu(menu: Menu): void {\r\n    let inMenu = new Menu();\r\n    for (let key in menu) {\r\n      inMenu[key] = menu[key];\r\n    }\r\n    this._menus[menu.name] = inMenu;\r\n  }\r\n\r\n  public closeAllMenus() {\r\n    Object.values(this._menus).forEach((m: Menu) => m.state = m.type === 'buttonMenu' && this.model.options.isMobileDevice ? 'initialLeft' : 'initialDown');\r\n  }\r\n\r\n  public isMenuVisible(): boolean {\r\n    return Object.values(this._menus).find(m => (m as Menu).state === 'expanded') != null;\r\n  }\r\n\r\n  public showMenu(menuName: string) {\r\n    const menu: Menu = this._menus[menuName];\r\n\r\n    if (menu?.type !== 'datePickerMenu' && menu?.type !== this.VERTICAL_MENU_NAME) {\r\n      this.closeAllMenus();\r\n    }\r\n\r\n    if (menu) {\r\n      menu.sizeStyle = 'opacity: 0;';\r\n      if (this.model.options.isMobileDevice && menu.type === 'buttonMenu') {\r\n        setTimeout(() => {\r\n          const innerContent = menu.innerContent.nativeElement;\r\n          menu.left = 0;\r\n          menu.top = 0;\r\n          menu.width = innerContent.offsetWidth;\r\n          menu.height = innerContent.offsetHeight;\r\n          menu.state = 'initialLeft';\r\n          menu.sizeStyle = null;\r\n\r\n          setTimeout(() => {\r\n            menu.state = 'expanded';\r\n          });\r\n        });\r\n      } else {\r\n        setTimeout(() => {\r\n          menu.sizeStyle = null;\r\n          this.showMenuInternal(menu);\r\n        });\r\n      }\r\n      this.subject.next(menu);\r\n    }\r\n  }\r\n\r\n  private showMenuInternal(menu: Menu) {\r\n    const isVertMenu = true;\r\n\r\n    const parentButton = menu.parent.nativeElement;\r\n    const innerContent = menu.innerContent.nativeElement;\r\n    const offsetHeight = menu.menuEl.nativeElement.offsetHeight;\r\n    const style = menu.menuEl.nativeElement.style;\r\n\r\n    const coords = this.getMenuCoordinates(parentButton, innerContent, offsetHeight, style, isVertMenu);\r\n\r\n    menu.left = coords.left;\r\n    menu.top = coords.top;\r\n    menu.width = menu.width || coords.width;\r\n    menu.height = coords.height;\r\n    menu.state = coords.state;\r\n\r\n    setTimeout(() => {\r\n      menu.state = 'expanded';\r\n    });\r\n  }\r\n\r\n  public getMenuCoordinates(parentButton: any, innerContent: any, offsetHeight: number, style: any, isVertMenu: boolean): any {\r\n    const menu: any = {};\r\n    const browserWidth = window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth;\r\n    const browserHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;\r\n    const rightAlign = false;\r\n    const mainClassName = 'stiJsViewerMainPanel';\r\n    let animDirect = 'Down';\r\n    const leftOffset = 0;\r\n\r\n    let left = (isVertMenu)\r\n      ? (this.model.options.appearance.rightToLeft || rightAlign\r\n        ? (this.helper.findPosX(parentButton, mainClassName) - innerContent.offsetWidth + parentButton.offsetWidth) - (leftOffset || 0)\r\n        : this.helper.findPosX(parentButton, mainClassName) - (leftOffset || 0))\r\n      : ((animDirect === 'Right')\r\n        ? (this.helper.findPosX(parentButton, mainClassName) + parentButton.offsetWidth + 2)\r\n        : (this.helper.findPosX(parentButton, mainClassName) - parentButton.offsetWidth - 2));\r\n\r\n    if (left + innerContent.offsetWidth > browserWidth) {\r\n      left = browserWidth - innerContent.offsetWidth - 15;\r\n    }\r\n    if (left < 0) {\r\n      left = 10;\r\n    }\r\n    menu.left = left;\r\n\r\n    if (animDirect === 'Down' &&\r\n      this.helper.findPosY(parentButton) + parentButton.offsetHeight + innerContent.offsetHeight > browserHeight &&\r\n      this.helper.findPosY(parentButton) - innerContent.offsetHeight > 0) {\r\n      animDirect = 'Up';\r\n    }\r\n\r\n    menu.top = (isVertMenu)\r\n      ? ((animDirect === 'Down')\r\n        ? (this.helper.findPosY(parentButton, mainClassName) + parentButton.offsetHeight + 2)\r\n        : (this.helper.findPosY(parentButton, mainClassName) - offsetHeight))\r\n      : (this.helper.findPosY(parentButton, mainClassName) + parentButton.offsetHeight + innerContent.offsetHeight > browserHeight &&\r\n        (browserHeight - innerContent.offsetHeight - 10) > 0)\r\n        ? (browserHeight - innerContent.offsetHeight - 10)\r\n        : this.helper.findPosY(parentButton, mainClassName);\r\n\r\n    menu.width = innerContent.offsetWidth;\r\n    menu.height = innerContent.offsetHeight;\r\n\r\n    if (menu.top + innerContent.offsetHeight > browserHeight) {\r\n      menu.top = (browserHeight - innerContent.offsetHeight - 10);\r\n    }\r\n\r\n    if (menu.top < 0) {\r\n      menu.top = 10;\r\n    }\r\n\r\n    menu.state = animDirect === 'Down' ? 'initialDown' : 'initialUp';\r\n\r\n    return menu;\r\n  }\r\n\r\n  get menus(): Menu[] {\r\n    return Object.values(this._menus);\r\n  }\r\n\r\n  getVerticalMenu(): Menu {\r\n    return this._menus[this.VERTICAL_MENU_NAME];\r\n  }\r\n\r\n  getMenu(name: string): Menu {\r\n    return this._menus[name];\r\n  }\r\n\r\n}\r\n"]}