UNPKG

stimulsoft-viewer-angular

Version:
361 lines (333 loc) 45.5 kB
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"]}