stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
224 lines (220 loc) • 23.6 kB
JavaScript
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 "../services/mouse.service";
import * as i3 from "../menu/menu.service";
import * as i4 from "./button.component";
export class DropDownListComponent {
constructor(model, mouseService, menuService) {
this.model = model;
this.mouseService = mouseService;
this.menuService = menuService;
this.showImage = false;
this.action = new EventEmitter();
this.over = false;
this._readOnly = false;
this._enabled = true;
this.mouseService.getDocumentMouseUp().subscribe(() => {
this.hideListMenu();
});
}
ngOnInit() { }
set readOnly(value) {
this._readOnly = value;
setTimeout(() => {
try {
this.input.nativeElement.setAttribute('unselectable', value ? 'on' : 'off');
this.input.nativeElement.setAttribute('onselectstart', value ? 'return false' : '');
this.input.nativeElement.readOnly = value;
}
catch (e) { }
});
}
get readOnly() {
return this._readOnly;
}
get enabled() {
return this._enabled;
}
set enabled(value) {
if (!value) {
this.over = false;
}
this._enabled = value;
}
get key() {
return this._key;
}
set key(key) {
if (this.items != null) {
this.items.forEach(i => i.selected = i.key === key);
}
this._key = key;
}
get inputValue() {
if (this.items != null) {
return this.items.find(i => i.key === this._key)?.caption || '';
}
return '';
}
get selected() {
const vm = this.menuService.getVerticalMenu();
return vm?.state === 'expanded' && vm?.parent === this.element;
}
get className() {
return this.selected ? 'stiJsViewerDropDownListOver' : (this.enabled ? (this.over ? 'stiJsViewerDropDownListOver' : 'stiJsViewerDropDownList') : 'stiJsViewerDropDownListDisabled');
}
mouseover() {
if (!this.enabled) {
return;
}
this.over = true;
}
mouseout() {
if (!this.enabled) {
return;
}
this.over = false;
}
inputClick() {
if (this.readOnly) {
this.showListMenu();
}
}
showListMenu() {
this.menuService.addMenu({
type: this.menuService.VERTICAL_MENU_NAME, name: this.menuService.VERTICAL_MENU_NAME, items: [], parent: this.element,
verticalItems: this.items, itemStyleName: 'stiJsViewerMenuStandartItem', menuStyleName: 'stiJsViewerDropdownMenu',
action: this.action, width: this.element.nativeElement.offsetWidth,
state: ''
});
setTimeout(() => {
this.menuService.showMenu(this.menuService.VERTICAL_MENU_NAME);
});
}
hideListMenu() {
if (this.menuService.getVerticalMenu()) {
this.menuService.getVerticalMenu().state = 'initialDown';
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DropDownListComponent, deps: [{ token: i1.ModelService }, { token: i2.MouseService }, { token: i3.MenuService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DropDownListComponent, selector: "sti-drop-down-list", inputs: { toolTip: "toolTip", showImage: "showImage", width: "width", margin: "margin", items: "items", styleDisplay: "styleDisplay", verticalAlign: "verticalAlign", readOnly: "readOnly", enabled: "enabled", key: "key" }, outputs: { action: "action" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: `
<table #element [class]="className" cellpadding="0" cellspacing="0"
[style.fontFamily]="model.options.toolbar.fontFamily"
[style.color]="model.options.toolbar.fontColor"
[style.margin]="margin"
[style.verticalAlign]="verticalAlign"
[style.display]="styleDisplay"
[attr.title]="toolTip"
(mouseover)="mouseover()"
(mouseout)="mouseout()">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles">
<input #input
[style.width.px]="width - (model.options.isTouchDevice ? 23 : 15) - (showImage ? 38 : 0)"
[style.border]="0"
[style.cursor]="readOnly ? 'default' : 'text'"
[style.fontFamily]="model.options.toolbar.fontFamily"
[style.color]="model.options.toolbar.fontColor"
[style.height]="model.options.isTouchDevice ? '23px' : '18px'"
[style.lineHeight]="model.options.isTouchDevice ? '23px' : '18px'"
[style.visibility]="enabled ? 'visible' : 'hidden'"
[value]="inputValue"
(click)="inputClick()"
class="stiJsViewerDropDownList_TextBox">
</td>
<td class="stiJsViewerClearAllStyles">
<sti-button [imageName]="'Arrows.' + (model.options.isTouchDevice ? 'Big' : 'Small') + 'ArrowDown.png'"
[styleName]="'stiJsViewerDropDownListButton'"
[imageSizesWidth]="model.options.isTouchDevice ? 16 : 8"
[imageSizesHeight]="model.options.isTouchDevice ? 16 : 8"
[height]="model.options.isTouchDevice ? '26px' : '21px'"
[enabled]="enabled"
[selected]="selected"
[margin]="'0'"
(action)="showListMenu()">
</sti-button>
</td>
</tr>
</tbody>
</table>
`, isInline: true, dependencies: [{ kind: "component", type: i4.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: DropDownListComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-drop-down-list',
template: `
<table #element [class]="className" cellpadding="0" cellspacing="0"
[style.fontFamily]="model.options.toolbar.fontFamily"
[style.color]="model.options.toolbar.fontColor"
[style.margin]="margin"
[style.verticalAlign]="verticalAlign"
[style.display]="styleDisplay"
[attr.title]="toolTip"
(mouseover)="mouseover()"
(mouseout)="mouseout()">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles">
<input #input
[style.width.px]="width - (model.options.isTouchDevice ? 23 : 15) - (showImage ? 38 : 0)"
[style.border]="0"
[style.cursor]="readOnly ? 'default' : 'text'"
[style.fontFamily]="model.options.toolbar.fontFamily"
[style.color]="model.options.toolbar.fontColor"
[style.height]="model.options.isTouchDevice ? '23px' : '18px'"
[style.lineHeight]="model.options.isTouchDevice ? '23px' : '18px'"
[style.visibility]="enabled ? 'visible' : 'hidden'"
[value]="inputValue"
(click)="inputClick()"
class="stiJsViewerDropDownList_TextBox">
</td>
<td class="stiJsViewerClearAllStyles">
<sti-button [imageName]="'Arrows.' + (model.options.isTouchDevice ? 'Big' : 'Small') + 'ArrowDown.png'"
[styleName]="'stiJsViewerDropDownListButton'"
[imageSizesWidth]="model.options.isTouchDevice ? 16 : 8"
[imageSizesHeight]="model.options.isTouchDevice ? 16 : 8"
[height]="model.options.isTouchDevice ? '26px' : '21px'"
[enabled]="enabled"
[selected]="selected"
[margin]="'0'"
(action)="showListMenu()">
</sti-button>
</td>
</tr>
</tbody>
</table>
`
}]
}], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.MouseService }, { type: i3.MenuService }], propDecorators: { input: [{
type: ViewChild,
args: ['input']
}], element: [{
type: ViewChild,
args: ['element']
}], toolTip: [{
type: Input
}], showImage: [{
type: Input
}], width: [{
type: Input
}], margin: [{
type: Input
}], items: [{
type: Input
}], styleDisplay: [{
type: Input
}], verticalAlign: [{
type: Input
}], action: [{
type: Output
}], readOnly: [{
type: Input
}], enabled: [{
type: Input
}], key: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down-list.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/controls/drop-down-list.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 { Item } from '../services/objects';\r\nimport { MouseService } from '../services/mouse.service';\r\nimport { MenuService } from '../menu/menu.service';\r\n\r\n@Component({\r\n  selector: 'sti-drop-down-list',\r\n  template: `\r\n        <table #element [class]=\"className\" cellpadding=\"0\" cellspacing=\"0\"\r\n              [style.fontFamily]=\"model.options.toolbar.fontFamily\"\r\n              [style.color]=\"model.options.toolbar.fontColor\"\r\n              [style.margin]=\"margin\"\r\n              [style.verticalAlign]=\"verticalAlign\"\r\n              [style.display]=\"styleDisplay\"\r\n              [attr.title]=\"toolTip\"\r\n              (mouseover)=\"mouseover()\"\r\n              (mouseout)=\"mouseout()\">\r\n          <tbody>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <input #input\r\n                [style.width.px]=\"width - (model.options.isTouchDevice ? 23 : 15) - (showImage ? 38 : 0)\"\r\n                [style.border]=\"0\"\r\n                [style.cursor]=\"readOnly ? 'default' : 'text'\"\r\n                [style.fontFamily]=\"model.options.toolbar.fontFamily\"\r\n                [style.color]=\"model.options.toolbar.fontColor\"\r\n                [style.height]=\"model.options.isTouchDevice ? '23px' : '18px'\"\r\n                [style.lineHeight]=\"model.options.isTouchDevice ? '23px' : '18px'\"\r\n                [style.visibility]=\"enabled ? 'visible' : 'hidden'\"\r\n                [value]=\"inputValue\"\r\n                (click)=\"inputClick()\"\r\n                class=\"stiJsViewerDropDownList_TextBox\">\r\n              </td>\r\n\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                  <sti-button [imageName]=\"'Arrows.' + (model.options.isTouchDevice ? 'Big' : 'Small') + 'ArrowDown.png'\"\r\n                     [styleName]=\"'stiJsViewerDropDownListButton'\"\r\n                     [imageSizesWidth]=\"model.options.isTouchDevice ? 16 : 8\"\r\n                     [imageSizesHeight]=\"model.options.isTouchDevice ? 16 : 8\"\r\n                     [height]=\"model.options.isTouchDevice ? '26px' : '21px'\"\r\n                     [enabled]=\"enabled\"\r\n                     [selected]=\"selected\"\r\n                     [margin]=\"'0'\"\r\n                     (action)=\"showListMenu()\">\r\n                  </sti-button>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n\r\n  `\r\n})\r\n\r\nexport class DropDownListComponent implements OnInit {\r\n\r\n  @ViewChild('input') input: ElementRef;\r\n  @ViewChild('element') element: ElementRef;\r\n\r\n  @Input() toolTip: string;\r\n  @Input() showImage = false;\r\n  @Input() width: number;\r\n  @Input() margin: string;\r\n  @Input() items: Item[];\r\n  @Input() styleDisplay: string;\r\n  @Input() verticalAlign: string;\r\n\r\n  @Output() action: EventEmitter<any> = new EventEmitter();\r\n\r\n  over = false;\r\n  private _readOnly = false;\r\n  private _enabled = true;\r\n  private _key: any;\r\n\r\n  constructor(public model: ModelService, public mouseService: MouseService, public menuService: MenuService) {\r\n    this.mouseService.getDocumentMouseUp().subscribe(() => {\r\n      this.hideListMenu();\r\n    });\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  set readOnly(value: boolean) {\r\n    this._readOnly = value;\r\n    setTimeout(() => {\r\n      try {\r\n        this.input.nativeElement.setAttribute('unselectable', value ? 'on' : 'off');\r\n        this.input.nativeElement.setAttribute('onselectstart', value ? 'return false' : '');\r\n        this.input.nativeElement.readOnly = value;\r\n      } catch (e) { }\r\n    });\r\n  }\r\n\r\n  @Input() get readOnly(): boolean {\r\n    return this._readOnly;\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  @Input() get key(): any {\r\n    return this._key;\r\n  }\r\n\r\n  set key(key: any) {\r\n    if (this.items != null) {\r\n      this.items.forEach(i => i.selected = i.key === key);\r\n    }\r\n    this._key = key;\r\n  }\r\n\r\n  get inputValue(): string {\r\n    if (this.items != null) {\r\n      return this.items.find(i => i.key === this._key)?.caption || '';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  get selected(): boolean {\r\n    const vm = this.menuService.getVerticalMenu();\r\n    return vm?.state === 'expanded' && vm?.parent === this.element;\r\n  }\r\n\r\n  get className(): string {\r\n    return this.selected ? 'stiJsViewerDropDownListOver' : (this.enabled ? (this.over ? 'stiJsViewerDropDownListOver' : 'stiJsViewerDropDownList') : 'stiJsViewerDropDownListDisabled');\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\r\n  mouseout() {\r\n    if (!this.enabled) {\r\n      return;\r\n    }\r\n    this.over = false;\r\n  }\r\n\r\n  inputClick() {\r\n    if (this.readOnly) {\r\n      this.showListMenu();\r\n    }\r\n  }\r\n\r\n  showListMenu() {\r\n    this.menuService.addMenu({\r\n      type: this.menuService.VERTICAL_MENU_NAME, name: this.menuService.VERTICAL_MENU_NAME, items: [], parent: this.element,\r\n      verticalItems: this.items, itemStyleName: 'stiJsViewerMenuStandartItem', menuStyleName: 'stiJsViewerDropdownMenu',\r\n      action: this.action, width: this.element.nativeElement.offsetWidth,\r\n      state: ''\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.menuService.showMenu(this.menuService.VERTICAL_MENU_NAME);\r\n    });\r\n  }\r\n\r\n  hideListMenu() {\r\n    if (this.menuService.getVerticalMenu()) {\r\n      this.menuService.getVerticalMenu().state = 'initialDown';\r\n    }\r\n  }\r\n\r\n}\r\n"]}