stimulsoft-viewer-angular
Version:
The Viewer component is designed to view reports and dashboards in the web browser.
155 lines • 17.1 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../../services/helper.service";
import * as i2 from "../../services/model.service";
import * as i3 from "../text-box.componet";
export class ParameterTextBoxComponent {
constructor(helper, model) {
this.helper = helper;
this.model = model;
this.focusOnCreate = false;
this.isMenu = false;
this.value = '';
this.secondTextBox = false;
}
ngOnInit() { }
onchange(target) {
if (this.element.oldValue === target.value) {
return;
}
const value = this.getValue(target);
if (this.isMenu) {
if (!this.secondTextBox) {
this.item.key = value;
}
else {
this.item.keyTo = value;
}
}
else {
if (!this.secondTextBox) {
if (this.variable.basicType === 'Range' || this.variable.type === 'DateTime') {
this.variable.key = value;
}
else {
this.variable.value = value;
if (this.variable.basicType === 'Value') {
this.variable.key = value;
}
}
}
else {
this.variable.keyTo = value;
}
}
}
getValue(target) {
if (this.variable.type === 'DateTime') {
if (this.element.oldValue === target.value) {
return;
}
try {
const timeString = new Date().toLocaleTimeString();
const isAmericanFormat = timeString.toLowerCase().indexOf('am') >= 0 || timeString.toLowerCase().indexOf('pm') >= 0;
const formatDate = isAmericanFormat ? 'MM/dd/yyyy' : 'dd.MM.yyyy';
let format = formatDate + (isAmericanFormat ? ' h:mm:ss tt' : ' hh:mm:ss');
if (this.variable.dateTimeType === 'Date') {
format = formatDate;
}
if (this.variable.dateTimeType === 'Time') {
format = 'hh:mm:ss';
}
const date = this.helper.getDateTimeFromString(target.value, this.model.options.appearance.parametersPanelDateFormat || format);
return this.helper.getDateTimeObject(date);
}
catch (e) {
alert(e);
}
}
else {
return target.value;
}
}
get width() {
let width = 210;
if (this.variable.basicType === 'Range') {
width = 140;
if (this.variable.type === 'Guid' || this.variable.type === 'String') {
width = 190;
}
if (this.variable.type === 'DateTime') {
width = 235;
}
if (this.variable.type === 'Char') {
width = 60;
}
}
else {
if (this.variable.type === 'Guid') {
width = 265;
}
else {
width = 210;
}
}
return width;
}
get color() {
return !this.variable.isNull
? (this.model.options.toolbar.fontColor && this.model.options.toolbar.fontColor !== 'Empty' ? this.model.options.toolbar.fontColor : '#444444')
: this.variable.type === 'DateTime' ? 'transparent' : '#c6c6c6';
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ParameterTextBoxComponent, deps: [{ token: i1.HelperService }, { token: i2.ModelService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: ParameterTextBoxComponent, selector: "sti-parameter-text-box", inputs: { item: "item", variable: "variable", readOnly: "readOnly", focusOnCreate: "focusOnCreate", isMenu: "isMenu", value: "value", secondTextBox: "secondTextBox" }, viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: `
<sti-text-box #element
[maxLength]="variable.type === 'Char' ? 1 : ''"
[value]="isMenu ? helper.getStringKey(item.key, variable): value"
[width]="width"
[readOnly]="readOnly"
[focusOnCreate]="focusOnCreate"
[enabled]="!variable?.isNull"
[color]="color"
[variable]="variable"
[textAlign]="model.options.currentParameterAlignment?.toLowerCase()"
(onblur)="onchange($event)">
</sti-text-box>
`, isInline: true, dependencies: [{ kind: "component", type: i3.TextBoxComponent, selector: "sti-text-box", inputs: ["width", "actionLostFocus", "tooltip", "enabled", "value", "margin", "focusOnCreate", "maxLength", "color", "type", "padding", "border", "variable", "textAlign", "autocomplete", "readOnly"], outputs: ["action", "onchange", "onblur"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: ParameterTextBoxComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-parameter-text-box',
template: `
<sti-text-box #element
[maxLength]="variable.type === 'Char' ? 1 : ''"
[value]="isMenu ? helper.getStringKey(item.key, variable): value"
[width]="width"
[readOnly]="readOnly"
[focusOnCreate]="focusOnCreate"
[enabled]="!variable?.isNull"
[color]="color"
[variable]="variable"
[textAlign]="model.options.currentParameterAlignment?.toLowerCase()"
(onblur)="onchange($event)">
</sti-text-box>
`
}]
}], ctorParameters: () => [{ type: i1.HelperService }, { type: i2.ModelService }], propDecorators: { element: [{
type: ViewChild,
args: ['element']
}], item: [{
type: Input
}], variable: [{
type: Input
}], readOnly: [{
type: Input
}], focusOnCreate: [{
type: Input
}], isMenu: [{
type: Input
}], value: [{
type: Input
}], secondTextBox: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameter-text-box.component.js","sourceRoot":"","sources":["../../../../../../projects/stimulsoft-viewer-angular/src/lib/controls/parameters/parameter-text-box.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild } from '@angular/core';\r\nimport { Variable } from '../../services/objects';\r\nimport { TextBoxComponent } from '../text-box.componet';\r\nimport { HelperService } from '../../services/helper.service';\r\nimport { ModelService } from '../../services/model.service';\r\n\r\n@Component({\r\n  selector: 'sti-parameter-text-box',\r\n  template: `\r\n    <sti-text-box #element\r\n      [maxLength]=\"variable.type === 'Char' ? 1 : ''\"\r\n      [value]=\"isMenu ? helper.getStringKey(item.key, variable): value\"\r\n      [width]=\"width\"\r\n      [readOnly]=\"readOnly\"\r\n      [focusOnCreate]=\"focusOnCreate\"\r\n      [enabled]=\"!variable?.isNull\"\r\n      [color]=\"color\"\r\n      [variable]=\"variable\"\r\n      [textAlign]=\"model.options.currentParameterAlignment?.toLowerCase()\"\r\n      (onblur)=\"onchange($event)\">\r\n    </sti-text-box>\r\n  `\r\n})\r\n\r\nexport class ParameterTextBoxComponent implements OnInit {\r\n\r\n  @ViewChild('element') element: TextBoxComponent;\r\n\r\n  @Input() item: Variable;\r\n  @Input() variable: Variable;\r\n  @Input() readOnly: boolean;\r\n  @Input() focusOnCreate = false;\r\n  @Input() isMenu = false;\r\n  @Input() value = '';\r\n  @Input() secondTextBox = false;\r\n\r\n  constructor(public helper: HelperService, public model: ModelService) { }\r\n\r\n  ngOnInit() { }\r\n\r\n  onchange(target: any) {\r\n    if (this.element.oldValue === target.value) {\r\n      return;\r\n    }\r\n    const value = this.getValue(target);\r\n    if (this.isMenu) {\r\n      if (!this.secondTextBox) {\r\n        this.item.key = value;\r\n      } else {\r\n        this.item.keyTo = value;\r\n      }\r\n    } else {\r\n      if (!this.secondTextBox) {\r\n        if (this.variable.basicType === 'Range' || this.variable.type === 'DateTime') {\r\n          this.variable.key = value;\r\n        } else {\r\n          this.variable.value = value;\r\n          if (this.variable.basicType === 'Value') {\r\n            this.variable.key = value;\r\n          }\r\n        }\r\n      } else {\r\n        this.variable.keyTo = value;\r\n      }\r\n    }\r\n  }\r\n\r\n  getValue(target: any): any {\r\n    if (this.variable.type === 'DateTime') {\r\n      if (this.element.oldValue === target.value) {\r\n        return;\r\n      }\r\n      try {\r\n        const timeString = new Date().toLocaleTimeString();\r\n        const isAmericanFormat = timeString.toLowerCase().indexOf('am') >= 0 || timeString.toLowerCase().indexOf('pm') >= 0;\r\n        const formatDate = isAmericanFormat ? 'MM/dd/yyyy' : 'dd.MM.yyyy';\r\n        let format = formatDate + (isAmericanFormat ? ' h:mm:ss tt' : ' hh:mm:ss');\r\n        if (this.variable.dateTimeType === 'Date') {\r\n          format = formatDate;\r\n        }\r\n        if (this.variable.dateTimeType === 'Time') {\r\n          format = 'hh:mm:ss';\r\n        }\r\n        const date = this.helper.getDateTimeFromString(target.value, this.model.options.appearance.parametersPanelDateFormat || format);\r\n        return this.helper.getDateTimeObject(date);\r\n      } catch (e) {\r\n        alert(e);\r\n      }\r\n    } else {\r\n      return target.value;\r\n    }\r\n  }\r\n\r\n  get width(): number {\r\n    let width = 210;\r\n    if (this.variable.basicType === 'Range') {\r\n      width = 140;\r\n      if (this.variable.type === 'Guid' || this.variable.type === 'String') {\r\n        width = 190;\r\n      }\r\n      if (this.variable.type === 'DateTime') {\r\n        width = 235;\r\n      }\r\n      if (this.variable.type === 'Char') {\r\n        width = 60;\r\n      }\r\n    } else {\r\n      if (this.variable.type === 'Guid') {\r\n        width = 265;\r\n      } else {\r\n        width = 210;\r\n      }\r\n    }\r\n    return width;\r\n  }\r\n\r\n  get color(): string {\r\n    return !this.variable.isNull\r\n      ? (this.model.options.toolbar.fontColor && this.model.options.toolbar.fontColor !== 'Empty' ? this.model.options.toolbar.fontColor : '#444444')\r\n      : this.variable.type === 'DateTime' ? 'transparent' : '#c6c6c6';\r\n  }\r\n}\r\n"]}