stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
361 lines (333 loc) • 45.5 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../../services/model.service";
import * as i2 from "../../services/helper.service";
import * as i3 from "../../menu/menu.service";
import * as i4 from "../../services/interactions.service";
import * as i5 from "@angular/common";
import * as i6 from "./parameter-text-box.component";
import * as i7 from "./parameter-checkbox.component";
import * as i8 from "./parameter-button.component";
export class ParameterComponent {
constructor(model, helper, menuService, intearctionService) {
this.model = model;
this.helper = helper;
this.menuService = menuService;
this.intearctionService = intearctionService;
}
ngOnInit() { }
get params() {
return this._params;
}
set params(params) {
this._params = params;
if (params.basicType === 'Range') {
if (params.type === 'DateTime' && params.keyTo && params.keyTo.isNull) {
params.keyTo = this.helper.getDateTimeObject(new Date());
}
}
}
get showParameterInTwoRows() {
return this.params.basicType === 'Range' && this.model.options.appearance.currentParametersPanelPosition === 'Left';
}
getReadOnlyCheckbox() {
return this.params.basicType === 'List' || !this.params.allowUserValues;
}
getFirstTextBoxValue() {
let value = '';
if (this.params.basicType === 'Value' || this.params.basicType === 'NullableValue') {
if (this.params.type === 'DateTime' && this.params.value === null) {
this.params.value = new Date();
this.params.key = this.helper.getDateTimeObject(this.params.value);
}
value = (this.params.type === 'DateTime') ? this.helper.getStringKey(this.params.key, this.params) : (this.params.allowUserValues ? this.params.key :
(this.params.value != "" || !this.params.isChanged ? this.params.value : this.params.key));
}
// Range
if (this.params.basicType === 'Range') {
if (this.params.type === 'DateTime' && this.params.key && this.params.key.isNull) {
this.params.key = this.helper.getDateTimeObject(new Date());
}
value = this.helper.getStringKey(this.params.key, this.params);
}
// List
if (this.params.basicType === 'List' && this.params.items) {
this.params.items.forEach((item) => {
if (item.isChecked) {
if (value !== '') {
value += (this.model.options.listSeparator ? this.model.options.listSeparator + " " : "; ");
}
if (this.params.allowUserValues) {
value += this.helper.getStringKey(item.key, this.params);
}
else {
value += item.value !== '' ? item.value : this.helper.getStringKey(item.key, this.params);
}
}
});
}
return value != null ? value.toString() : value;
}
firstGuidAction() {
if (this.params.basicType === 'Range') {
this.params.key = this.helper.newGuid();
}
else {
this.params.key = this.params.value = this.helper.newGuid();
}
}
doubleDateTimeAction(event) {
this.menuService.addMenu({
type: 'doubleDatePickerMenu', name: 'doubleDatePickerMenu', items: [], parent: this.rangeFrom,
params: this.params,
state: ''
});
setTimeout(() => {
this.menuService.showMenu('doubleDatePickerMenu');
});
}
firstDateTimeAction(event) {
this.menuService.addMenu({
type: 'datePickerMenu', name: 'datePickerMenu', items: [], parent: this.firstDateTimeButton,
params: this.params,
state: ''
});
setTimeout(() => {
this.menuService.showMenu('datePickerMenu');
});
}
dropDownButtonAction(event) {
let menuType = 'parameterMenuForValue';
switch (this.params.basicType) {
case 'Range':
menuType = 'parameterMenuForRange';
break;
case 'List':
menuType = this.params.allowUserValues ? 'parameterMenuForEditList' : 'parameterMenuForNotEditList';
break;
}
if (this.params.items) {
this.params.items.forEach(i => i.visible = true);
}
let this_ = this;
this.menuService.addMenu({
type: menuType, name: 'parameterMenu', items: [], parent: this.element,
params: this.params,
state: '',
onCloseEvent: () => {
this_.onCloseMenuEvent();
}
});
setTimeout(() => {
this.menuService.showMenu('parameterMenu');
});
}
onCloseMenuEvent() {
if (this.params.binding) {
if (!this.model.options.paramsVariablesStartValues) {
this.model.options.paramsVariablesStartValues = this.helper.copyObject(this.model.options.paramsVariables);
}
this.intearctionService.postInteraction({ action: 'InitVars', variables: this.intearctionService.getParametersValues(), isBindingVariable: true });
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParameterComponent, deps: [{ token: i1.ModelService }, { token: i2.HelperService }, { token: i3.MenuService }, { token: i4.InteractionsService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ParameterComponent, selector: "sti-parameter", inputs: { params: "params" }, viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }, { propertyName: "firstDateTimeButton", first: true, predicate: ["firstDateTimeButton"], descendants: true }, { propertyName: "doubleDateTimeButton", first: true, predicate: ["doubleDateTimeButton"], descendants: true }, { propertyName: "rangeFrom", first: true, predicate: ["rangeFrom"], descendants: true }], ngImport: i0, template: `
<table #element class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" #rangeFrom>
<tbody>
<tr class="stiJsViewerClearAllStyles" >
<td *ngIf="params.type == 'Bool' && (params.basicType == 'Value' || params.basicType == 'NullableValue')"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-checkbox [params]="params" [isEnabled]="params.allowUserValues" (action)="params.value = $event" [nullable]="params.basicType == 'NullableValue'">
</sti-parameter-checkbox>
</td>
<td *ngIf="params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeFrom')}}
</td>
<td *ngIf="params.type != 'Bool' || params.basicType == 'List'"
[style.position]="(params.basicType == 'NullableValue' || params.allowNullableString) && params.allowUserValues ? 'relative' : ''"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="getReadOnlyCheckbox()"
[value]="getFirstTextBoxValue()">
</sti-parameter-text-box>
</td>
<td *ngIf="params.type == 'DateTime' && params.allowUserValues && params.basicType != 'List' && params.basicType != 'Range'"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight" #firstDateTimeButton>
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="firstDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="params.type == 'Guid' && params.allowUserValues && params.basicType != 'List'"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="firstGuidAction()">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeTo')}}
</td>
<!-- second -->
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="!params.allowUserValues"
[value]="helper.getStringKey(params.keyTo, params)"
[secondTextBox]="true">
</sti-parameter-text-box>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues" #doubleDateTimeButton
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="doubleDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="params.keyTo=helper.newGuid()">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.items != null || (params.basicType == 'List' && params.allowUserValues)"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DropDownButton'" [params]="params" (action)="dropDownButtonAction($event)">
</sti-parameter-button>
</td>
</tr>
<!-- NEW LINE -->
<tr *ngIf="showParameterInTwoRows">
<td *ngIf="params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeTo')}}
</td>
<!-- second -->
<td *ngIf="params.basicType == 'Range'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="!params.allowUserValues"
[value]="helper.getStringKey(params.keyTo, params)"
[secondTextBox]="true">
</sti-parameter-text-box>
</td>
<td *ngIf="params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues" #doubleDateTimeButton
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="doubleDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="params.keyTo=helper.newGuid()">
</sti-parameter-button>
</td>
<td *ngIf="params.items != null || (params.basicType == 'List' && params.allowUserValues)"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DropDownButton'" [params]="params" (action)="dropDownButtonAction($event)">
</sti-parameter-button>
</td>
</tr>
</tbody>
</table>
`, isInline: true, dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.ParameterTextBoxComponent, selector: "sti-parameter-text-box", inputs: ["item", "variable", "readOnly", "focusOnCreate", "isMenu", "value", "secondTextBox"] }, { kind: "component", type: i7.ParameterCheckboxComponent, selector: "sti-parameter-checkbox", inputs: ["params", "captionText", "margin", "width", "imageBlockParentWidth", "isEnabled", "isMenuParameter", "paramNull", "nullable"], outputs: ["action"] }, { kind: "component", type: i8.ParameterButtonComponent, selector: "sti-parameter-button", inputs: ["params", "buttonType"], outputs: ["action"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParameterComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-parameter',
template: `
<table #element class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" #rangeFrom>
<tbody>
<tr class="stiJsViewerClearAllStyles" >
<td *ngIf="params.type == 'Bool' && (params.basicType == 'Value' || params.basicType == 'NullableValue')"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-checkbox [params]="params" [isEnabled]="params.allowUserValues" (action)="params.value = $event" [nullable]="params.basicType == 'NullableValue'">
</sti-parameter-checkbox>
</td>
<td *ngIf="params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeFrom')}}
</td>
<td *ngIf="params.type != 'Bool' || params.basicType == 'List'"
[style.position]="(params.basicType == 'NullableValue' || params.allowNullableString) && params.allowUserValues ? 'relative' : ''"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="getReadOnlyCheckbox()"
[value]="getFirstTextBoxValue()">
</sti-parameter-text-box>
</td>
<td *ngIf="params.type == 'DateTime' && params.allowUserValues && params.basicType != 'List' && params.basicType != 'Range'"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight" #firstDateTimeButton>
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="firstDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="params.type == 'Guid' && params.allowUserValues && params.basicType != 'List'"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="firstGuidAction()">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeTo')}}
</td>
<!-- second -->
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="!params.allowUserValues"
[value]="helper.getStringKey(params.keyTo, params)"
[secondTextBox]="true">
</sti-parameter-text-box>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues" #doubleDateTimeButton
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="doubleDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="params.keyTo=helper.newGuid()">
</sti-parameter-button>
</td>
<td *ngIf="!showParameterInTwoRows && params.items != null || (params.basicType == 'List' && params.allowUserValues)"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DropDownButton'" [params]="params" (action)="dropDownButtonAction($event)">
</sti-parameter-button>
</td>
</tr>
<!-- NEW LINE -->
<tr *ngIf="showParameterInTwoRows">
<td *ngIf="params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
{{model.loc('RangeTo')}}
</td>
<!-- second -->
<td *ngIf="params.basicType == 'Range'" [style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-text-box [variable]="params"
[readOnly]="!params.allowUserValues"
[value]="helper.getStringKey(params.keyTo, params)"
[secondTextBox]="true">
</sti-parameter-text-box>
</td>
<td *ngIf="params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues" #doubleDateTimeButton
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DateTimeButton'" [params]="params" (action)="doubleDateTimeAction($event)">
</sti-parameter-button>
</td>
<td *ngIf="params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'GuidButton'" [params]="params" (action)="params.keyTo=helper.newGuid()">
</sti-parameter-button>
</td>
<td *ngIf="params.items != null || (params.basicType == 'List' && params.allowUserValues)"
[style.padding]="'0 2px 0 2px'" [style.height.px]="model.options.parameterRowHeight">
<sti-parameter-button [buttonType]="'DropDownButton'" [params]="params" (action)="dropDownButtonAction($event)">
</sti-parameter-button>
</td>
</tr>
</tbody>
</table>
`
}]
}], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.HelperService }, { type: i3.MenuService }, { type: i4.InteractionsService }], propDecorators: { element: [{
type: ViewChild,
args: ['element']
}], firstDateTimeButton: [{
type: ViewChild,
args: ['firstDateTimeButton']
}], doubleDateTimeButton: [{
type: ViewChild,
args: ['doubleDateTimeButton']
}], rangeFrom: [{
type: ViewChild,
args: ['rangeFrom']
}], params: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parameter.component.js","sourceRoot":"","sources":["../../../../../../projects/stimulsoft-viewer-angular/src/lib/controls/parameters/parameter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ElementRef, ViewChild } from '@angular/core';\r\nimport { ModelService } from '../../services/model.service';\r\nimport { Variable } from '../../services/objects';\r\nimport { HelperService } from '../../services/helper.service';\r\nimport { MenuService } from '../../menu/menu.service';\r\nimport { InteractionsService } from '../../services/interactions.service';\r\n\r\n@Component({\r\n  selector: 'sti-parameter',\r\n  template: `\r\n    <table #element class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\" #rangeFrom>\r\n       <tbody>\r\n          <tr class=\"stiJsViewerClearAllStyles\" >\r\n            <td *ngIf=\"params.type == 'Bool' && (params.basicType == 'Value' || params.basicType == 'NullableValue')\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n                <sti-parameter-checkbox [params]=\"params\" [isEnabled]=\"params.allowUserValues\" (action)=\"params.value = $event\" [nullable]=\"params.basicType == 'NullableValue'\">\r\n                </sti-parameter-checkbox>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'\"  [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n                {{model.loc('RangeFrom')}}\r\n            </td>\r\n\r\n            <td *ngIf=\"params.type != 'Bool' || params.basicType == 'List'\"\r\n                [style.position]=\"(params.basicType == 'NullableValue' || params.allowNullableString) && params.allowUserValues ? 'relative' : ''\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n                <sti-parameter-text-box [variable]=\"params\"\r\n                    [readOnly]=\"getReadOnlyCheckbox()\"\r\n                    [value]=\"getFirstTextBoxValue()\">\r\n                </sti-parameter-text-box>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.type == 'DateTime' && params.allowUserValues && params.basicType != 'List' && params.basicType != 'Range'\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\" #firstDateTimeButton>\r\n                <sti-parameter-button [buttonType]=\"'DateTimeButton'\" [params]=\"params\"  (action)=\"firstDateTimeAction($event)\">\r\n                </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.type == 'Guid' && params.allowUserValues && params.basicType != 'List'\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n                <sti-parameter-button  [buttonType]=\"'GuidButton'\" [params]=\"params\" (action)=\"firstGuidAction()\">\r\n                </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"!showParameterInTwoRows && params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'\" [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              {{model.loc('RangeTo')}}\r\n            </td>\r\n\r\n            <!-- second -->\r\n            <td *ngIf=\"!showParameterInTwoRows && params.basicType == 'Range'\" [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-text-box [variable]=\"params\"\r\n                    [readOnly]=\"!params.allowUserValues\"\r\n                    [value]=\"helper.getStringKey(params.keyTo, params)\"\r\n                    [secondTextBox]=\"true\">\r\n              </sti-parameter-text-box>\r\n            </td>\r\n\r\n            <td *ngIf=\"!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues\" #doubleDateTimeButton\r\n              [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button  [buttonType]=\"'DateTimeButton'\" [params]=\"params\" (action)=\"doubleDateTimeAction($event)\">\r\n              </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"!showParameterInTwoRows && params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues\"\r\n              [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button  [buttonType]=\"'GuidButton'\" [params]=\"params\" (action)=\"params.keyTo=helper.newGuid()\">\r\n              </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"!showParameterInTwoRows && params.items != null || (params.basicType == 'List' && params.allowUserValues)\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button [buttonType]=\"'DropDownButton'\" [params]=\"params\" (action)=\"dropDownButtonAction($event)\">\r\n              </sti-parameter-button>\r\n            </td>\r\n          </tr>\r\n\r\n          <!-- NEW LINE -->\r\n          <tr *ngIf=\"showParameterInTwoRows\">\r\n            <td *ngIf=\"params.basicType == 'Range' && model.options.appearance.currentParametersPanelPosition === 'Top'\" [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              {{model.loc('RangeTo')}}\r\n            </td>\r\n\r\n            <!-- second -->\r\n            <td *ngIf=\"params.basicType == 'Range'\" [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-text-box [variable]=\"params\"\r\n                    [readOnly]=\"!params.allowUserValues\"\r\n                    [value]=\"helper.getStringKey(params.keyTo, params)\"\r\n                    [secondTextBox]=\"true\">\r\n              </sti-parameter-text-box>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.basicType == 'Range' && params.type == 'DateTime' && params.allowUserValues\" #doubleDateTimeButton\r\n              [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button  [buttonType]=\"'DateTimeButton'\" [params]=\"params\" (action)=\"doubleDateTimeAction($event)\">\r\n              </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.basicType == 'Range' && params.type == 'Guid' && params.allowUserValues\"\r\n              [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button  [buttonType]=\"'GuidButton'\" [params]=\"params\" (action)=\"params.keyTo=helper.newGuid()\">\r\n              </sti-parameter-button>\r\n            </td>\r\n\r\n            <td *ngIf=\"params.items != null || (params.basicType == 'List' && params.allowUserValues)\"\r\n                [style.padding]=\"'0 2px 0 2px'\" [style.height.px]=\"model.options.parameterRowHeight\">\r\n              <sti-parameter-button [buttonType]=\"'DropDownButton'\" [params]=\"params\" (action)=\"dropDownButtonAction($event)\">\r\n              </sti-parameter-button>\r\n            </td>\r\n          </tr>\r\n       </tbody>\r\n    </table>\r\n  `\r\n})\r\n\r\nexport class ParameterComponent implements OnInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n  @ViewChild('firstDateTimeButton') firstDateTimeButton: ElementRef;\r\n  @ViewChild('doubleDateTimeButton') doubleDateTimeButton: ElementRef;\r\n  @ViewChild('rangeFrom') rangeFrom: ElementRef;\r\n\r\n  private _params: Variable;\r\n\r\n  constructor(public model: ModelService, public helper: HelperService, public menuService: MenuService, public intearctionService: InteractionsService) { }\r\n\r\n  ngOnInit() { }\r\n\r\n  @Input() get params(): Variable {\r\n    return this._params;\r\n  }\r\n\r\n  set params(params: Variable) {\r\n    this._params = params;\r\n\r\n    if (params.basicType === 'Range') {\r\n      if (params.type === 'DateTime' && params.keyTo && params.keyTo.isNull) {\r\n        params.keyTo = this.helper.getDateTimeObject(new Date());\r\n      }\r\n    }\r\n  }\r\n\r\n  get showParameterInTwoRows(): boolean {\r\n    return this.params.basicType === 'Range' && this.model.options.appearance.currentParametersPanelPosition === 'Left';\r\n  }\r\n\r\n  getReadOnlyCheckbox(): boolean {\r\n    return this.params.basicType === 'List' || !this.params.allowUserValues;\r\n  }\r\n\r\n  getFirstTextBoxValue(): string {\r\n    let value = '';\r\n    if (this.params.basicType === 'Value' || this.params.basicType === 'NullableValue') {\r\n      if (this.params.type === 'DateTime' && this.params.value === null) {\r\n        this.params.value = new Date();\r\n        this.params.key = this.helper.getDateTimeObject(this.params.value);\r\n      }\r\n\r\n      value = (this.params.type === 'DateTime') ? this.helper.getStringKey(this.params.key, this.params) : (this.params.allowUserValues ? this.params.key :\r\n        (this.params.value != \"\" || !this.params.isChanged ? this.params.value : this.params.key));\r\n    }\r\n\r\n    // Range\r\n    if (this.params.basicType === 'Range') {\r\n      if (this.params.type === 'DateTime' && this.params.key && this.params.key.isNull) {\r\n        this.params.key = this.helper.getDateTimeObject(new Date());\r\n      }\r\n      value = this.helper.getStringKey(this.params.key, this.params);\r\n    }\r\n\r\n    // List\r\n    if (this.params.basicType === 'List' && this.params.items) {\r\n      this.params.items.forEach((item) => {\r\n        if (item.isChecked) {\r\n          if (value !== '') {\r\n            value += (this.model.options.listSeparator ? this.model.options.listSeparator + \" \" : \"; \");\r\n          }\r\n\r\n          if (this.params.allowUserValues) {\r\n            value += this.helper.getStringKey(item.key, this.params);\r\n          } else {\r\n            value += item.value !== '' ? item.value : this.helper.getStringKey(item.key, this.params);\r\n          }\r\n        }\r\n      });\r\n    }\r\n\r\n    return value != null ? value.toString() : value;\r\n  }\r\n\r\n  firstGuidAction() {\r\n    if (this.params.basicType === 'Range') {\r\n      this.params.key = this.helper.newGuid();\r\n    } else {\r\n      this.params.key = this.params.value = this.helper.newGuid();\r\n    }\r\n  }\r\n\r\n  doubleDateTimeAction(event: any) {\r\n    this.menuService.addMenu({\r\n      type: 'doubleDatePickerMenu', name: 'doubleDatePickerMenu', items: [], parent: this.rangeFrom,\r\n      params: this.params,\r\n      state: ''\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.menuService.showMenu('doubleDatePickerMenu');\r\n    });\r\n  }\r\n\r\n  firstDateTimeAction(event: any) {\r\n    this.menuService.addMenu({\r\n      type: 'datePickerMenu', name: 'datePickerMenu', items: [], parent: this.firstDateTimeButton,\r\n      params: this.params,\r\n      state: ''\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.menuService.showMenu('datePickerMenu');\r\n    });\r\n  }\r\n\r\n  dropDownButtonAction(event: any) {\r\n    let menuType = 'parameterMenuForValue';\r\n    switch (this.params.basicType) {\r\n      case 'Range':\r\n        menuType = 'parameterMenuForRange';\r\n        break;\r\n      case 'List':\r\n        menuType = this.params.allowUserValues ? 'parameterMenuForEditList' : 'parameterMenuForNotEditList';\r\n        break;\r\n    }\r\n\r\n    if (this.params.items) {\r\n      this.params.items.forEach(i => i.visible = true);\r\n    }\r\n\r\n    let this_ = this;\r\n\r\n    this.menuService.addMenu({\r\n      type: menuType, name: 'parameterMenu', items: [], parent: this.element,\r\n      params: this.params,\r\n      state: '',\r\n      onCloseEvent: () => {\r\n        this_.onCloseMenuEvent();\r\n      }\r\n    });\r\n\r\n    setTimeout(() => {\r\n      this.menuService.showMenu('parameterMenu');\r\n    });\r\n  }\r\n\r\n  onCloseMenuEvent() {\r\n    if (this.params.binding) {\r\n      if (!this.model.options.paramsVariablesStartValues) {\r\n        this.model.options.paramsVariablesStartValues = this.helper.copyObject(this.model.options.paramsVariables);\r\n      }\r\n      this.intearctionService.postInteraction({ action: 'InitVars', variables: this.intearctionService.getParametersValues(), isBindingVariable: true });\r\n    }\r\n  }\r\n}\r\n"]}