stimulsoft-viewer-angular
Version:
The Viewer component is designed to view reports and dashboards in the web browser.
185 lines • 18.1 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 "@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"]}