UNPKG

stimulsoft-viewer-angular

Version:

The Viewer component is designed to view reports and dashboards in the web browser.

185 lines 18.1 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 "@angular/common"; import * as i3 from "./parameters/parameter-checkbox.component"; export class TextBoxComponent { constructor(model) { this.model = model; this.enabled = true; this.focusOnCreate = false; this.action = new EventEmitter(); this.onchange = new EventEmitter(); this.onblur = new EventEmitter(); this.selected = false; this.focused = false; this.over = false; this._readOnly = false; this.styleName = 'stiJsViewerTextBox'; } ngAfterViewInit() { if (this.focusOnCreate) { setTimeout(() => { this.element.nativeElement.focus(); }); } } keypress(event) { if (!this.enabled) { return false; } if (event.keyCode === 13) { this.action.emit(event.target); } } onchanged(event) { this.onchange.emit(event.target); } get paddingInt() { return this.isNullableParam ? "0 0 0 22px" : this.padding; } focus() { this.oldValue = this.element.nativeElement.value; } get isNullableParam() { return this.variable?.basicType == 'NullableValue' || this.variable?.allowNullableString; } nullableAction(checked) { this.variable.isNull = !this.variable.isNull; } get height() { return this.model.options.isTouchDevice ? '26px' : '21px'; } get className() { if (this._readOnly) { return this.styleName + ' ' + this.styleName + 'Default'; } return this.styleName + ' ' + this.styleName + (this.selected ? 'Over' : (this.enabled ? (this.over ? 'Over' : 'Default') : 'Disabled')); } set readOnly(value) { this._readOnly = value; setTimeout(() => { try { this.element.nativeElement.setAttribute('unselectable', value ? 'on' : 'off'); this.element.nativeElement.setAttribute('onselectstart', value ? 'return false' : ''); this.element.nativeElement.readOnly = value; } catch (e) { } }); } get readOnly() { return this._readOnly; } ngOnInit() { } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TextBoxComponent, deps: [{ token: i1.ModelService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: TextBoxComponent, selector: "sti-text-box", inputs: { width: "width", actionLostFocus: "actionLostFocus", tooltip: "tooltip", enabled: "enabled", value: "value", margin: "margin", focusOnCreate: "focusOnCreate", maxLength: "maxLength", color: "color", type: "type", padding: "padding", border: "border", variable: "variable", textAlign: "textAlign", autocomplete: "autocomplete", readOnly: "readOnly" }, outputs: { action: "action", onchange: "onchange", onblur: "onblur" }, viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: ` <input #element [style]="{fontFamily:model.options.toolbar.fontFamily, height: height, lineHeight: height, boxSizing:'content-box'}" [style.color]="color ? color : (model.options.toolbar.fontColor != '' ? model.options.toolbar.fontColor : '')" [style.width]="width != null ? width + 'px' : ''" [style.margin]="margin" [style.cursor]="readOnly ? 'default' : ''" [style.padding]="paddingInt" [style.border]="border" [style.textAlign]="textAlign" [title]="tooltip || ''" [class]="className" [value]="value || ''" [attr.maxLength]="maxLength" [attr.type]="type" [autocomplete]="autocomplete" (mouseover)="over=true" (mouseleave)="over=false" (focused)="focused=true; selected=true" (blur)="focused=false; selected=false; onblur.emit($event.target)" (keypress)="keypress($event)" (keyup)="onchanged($event)" (focus)="focus()"/> <sti-parameter-checkbox *ngIf="isNullableParam" [style]="{left: '6px', top: 'calc(50% - 7px)', position: 'absolute'}" [params]="variable" [isEnabled]="variable.allowUserValues" (action)="nullableAction($event)" [paramNull]="true" > </sti-parameter-checkbox> `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ParameterCheckboxComponent, selector: "sti-parameter-checkbox", inputs: ["params", "captionText", "margin", "width", "imageBlockParentWidth", "isEnabled", "isMenuParameter", "paramNull", "nullable"], outputs: ["action"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: TextBoxComponent, decorators: [{ type: Component, args: [{ selector: 'sti-text-box', template: ` <input #element [style]="{fontFamily:model.options.toolbar.fontFamily, height: height, lineHeight: height, boxSizing:'content-box'}" [style.color]="color ? color : (model.options.toolbar.fontColor != '' ? model.options.toolbar.fontColor : '')" [style.width]="width != null ? width + 'px' : ''" [style.margin]="margin" [style.cursor]="readOnly ? 'default' : ''" [style.padding]="paddingInt" [style.border]="border" [style.textAlign]="textAlign" [title]="tooltip || ''" [class]="className" [value]="value || ''" [attr.maxLength]="maxLength" [attr.type]="type" [autocomplete]="autocomplete" (mouseover)="over=true" (mouseleave)="over=false" (focused)="focused=true; selected=true" (blur)="focused=false; selected=false; onblur.emit($event.target)" (keypress)="keypress($event)" (keyup)="onchanged($event)" (focus)="focus()"/> <sti-parameter-checkbox *ngIf="isNullableParam" [style]="{left: '6px', top: 'calc(50% - 7px)', position: 'absolute'}" [params]="variable" [isEnabled]="variable.allowUserValues" (action)="nullableAction($event)" [paramNull]="true" > </sti-parameter-checkbox> ` }] }], ctorParameters: () => [{ type: i1.ModelService }], propDecorators: { element: [{ type: ViewChild, args: ['element'] }], width: [{ type: Input }], actionLostFocus: [{ type: Input }], tooltip: [{ type: Input }], enabled: [{ type: Input }], value: [{ type: Input }], margin: [{ type: Input }], focusOnCreate: [{ type: Input }], maxLength: [{ type: Input }], color: [{ type: Input }], type: [{ type: Input }], padding: [{ type: Input }], border: [{ type: Input }], variable: [{ type: Input }], textAlign: [{ type: Input }], autocomplete: [{ type: Input }], action: [{ type: Output }], onchange: [{ type: Output }], onblur: [{ type: Output }], readOnly: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-box.componet.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/controls/text-box.componet.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef, Output, EventEmitter, AfterViewInit } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { Variable } from '../services/objects';\r\n\r\n@Component({\r\n  selector: 'sti-text-box',\r\n  template: `\r\n    <input #element\r\n    [style]=\"{fontFamily:model.options.toolbar.fontFamily, height: height, lineHeight: height, boxSizing:'content-box'}\"\r\n    [style.color]=\"color ? color : (model.options.toolbar.fontColor != '' ? model.options.toolbar.fontColor : '')\"\r\n    [style.width]=\"width != null ? width + 'px' : ''\"\r\n    [style.margin]=\"margin\"\r\n    [style.cursor]=\"readOnly ? 'default' : ''\"\r\n    [style.padding]=\"paddingInt\"\r\n    [style.border]=\"border\"\r\n    [style.textAlign]=\"textAlign\"\r\n    [title]=\"tooltip || ''\"\r\n    [class]=\"className\"\r\n    [value]=\"value || ''\"\r\n    [attr.maxLength]=\"maxLength\"\r\n    [attr.type]=\"type\"\r\n    [autocomplete]=\"autocomplete\"\r\n    (mouseover)=\"over=true\"\r\n    (mouseleave)=\"over=false\"\r\n    (focused)=\"focused=true; selected=true\"\r\n    (blur)=\"focused=false; selected=false; onblur.emit($event.target)\"\r\n    (keypress)=\"keypress($event)\"\r\n    (keyup)=\"onchanged($event)\"\r\n    (focus)=\"focus()\"/>\r\n    <sti-parameter-checkbox *ngIf=\"isNullableParam\"\r\n      [style]=\"{left: '6px', top: 'calc(50% - 7px)', position: 'absolute'}\"\r\n      [params]=\"variable\"\r\n      [isEnabled]=\"variable.allowUserValues\"\r\n      (action)=\"nullableAction($event)\"\r\n      [paramNull]=\"true\" >\r\n    </sti-parameter-checkbox>\r\n  `\r\n})\r\n\r\nexport class TextBoxComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n\r\n  @Input() width: number;\r\n  @Input() actionLostFocus: any;\r\n  @Input() tooltip: string;\r\n  @Input() enabled = true;\r\n  @Input() value: string;\r\n  @Input() margin: string;\r\n  @Input() focusOnCreate = false;\r\n  @Input() maxLength: number;\r\n  @Input() color: string;\r\n  @Input() type: string;\r\n  @Input() padding: string;\r\n  @Input() border: string;\r\n  @Input() variable: Variable;\r\n  @Input() textAlign: string;\r\n  @Input() autocomplete: string;\r\n\r\n  @Output() action: EventEmitter<any> = new EventEmitter();\r\n  @Output() onchange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onblur: EventEmitter<any> = new EventEmitter();\r\n\r\n  public oldValue: string;\r\n\r\n  selected = false;\r\n  focused = false;\r\n  over = false;\r\n  _readOnly = false;\r\n\r\n  styleName = 'stiJsViewerTextBox';\r\n\r\n  constructor(public model: ModelService) { }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.focusOnCreate) {\r\n      setTimeout(() => {\r\n        this.element.nativeElement.focus();\r\n      });\r\n    }\r\n  }\r\n\r\n  keypress(event: KeyboardEvent) {\r\n    if (!this.enabled) {\r\n      return false;\r\n    }\r\n    if (event.keyCode === 13) {\r\n      this.action.emit(event.target);\r\n    }\r\n  }\r\n\r\n  onchanged(event: KeyboardEvent) {\r\n    this.onchange.emit(event.target);\r\n  }\r\n\r\n  get paddingInt(): string {\r\n    return this.isNullableParam ? \"0 0 0 22px\" : this.padding;\r\n  }\r\n\r\n  focus() {\r\n    this.oldValue = this.element.nativeElement.value;\r\n  }\r\n\r\n  get isNullableParam(): boolean {\r\n    return this.variable?.basicType == 'NullableValue' || this.variable?.allowNullableString;\r\n  }\r\n\r\n  nullableAction(checked: boolean) {\r\n    this.variable.isNull = !this.variable.isNull;\r\n  }\r\n\r\n  get height(): string {\r\n    return this.model.options.isTouchDevice ? '26px' : '21px';\r\n  }\r\n\r\n  get className(): string {\r\n    if (this._readOnly) {\r\n      return this.styleName + ' ' + this.styleName + 'Default';\r\n    }\r\n    return this.styleName + ' ' + this.styleName + (this.selected ? 'Over' : (this.enabled ? (this.over ? 'Over' : 'Default') : 'Disabled'));\r\n  }\r\n\r\n  @Input()\r\n  set readOnly(value: boolean) {\r\n    this._readOnly = value;\r\n    setTimeout(() => {\r\n      try {\r\n        this.element.nativeElement.setAttribute('unselectable', value ? 'on' : 'off');\r\n        this.element.nativeElement.setAttribute('onselectstart', value ? 'return false' : '');\r\n        this.element.nativeElement.readOnly = value;\r\n      } catch (e) { }\r\n    });\r\n  }\r\n\r\n  get readOnly(): boolean {\r\n    return this._readOnly;\r\n  }\r\n\r\n  ngOnInit() { }\r\n}\r\n"]}