UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

675 lines (674 loc) 49.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, Output, ViewChild, EventEmitter } from '@angular/core'; import { I18N } from '../../../../../decorator/I18N.decorator'; import { Option } from '../../../../../decorator/Option.decorator'; import { EventUtils } from '../../../../../share/utils/EventUtils'; import { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../../../../../share/CustomEventType'; import { NeedFocusService } from '../../../../../service/NeedFocusService.service'; import { AbstractInputDataView } from '../../../../../component/dataview/input/AbstractInputDataView'; import { MatSlider } from '@angular/material'; const /** @type {?} */ TYPE_NAME = "material-slider"; export class MaterialSlider extends AbstractInputDataView { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(elementRef, needFocusService); this.beforeClickEvent = new EventEmitter(); this.clickEvent = new EventEmitter(); this.beforeFocusEvent = new EventEmitter(); this.focusEvent = new EventEmitter(); this.beforeLostFocusEvent = new EventEmitter(); this.lostFocusEvent = new EventEmitter(); this.beforeChangeEvent = new EventEmitter(); this.changeEvent = new EventEmitter(); this.disabled = false; } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { setTimeout(() => { this.initEventHandlers(); this._oldValue = this.slider.value; }, 20); } /** * @return {?} */ initEventHandlers() { $(this.elementRef.nativeElement).find('mat-slider.mat-slider').focus(($event) => { this.onFocusing($event); }); $(this.elementRef.nativeElement).find('mat-slider.mat-slider').blur(($event) => { this.onLostFocusing($event); }); } /** * @return {?} */ isInvert() { return this.invert; } /** * @param {?} invert * @return {?} */ setInvert(invert) { this.invert = invert; } /** * @return {?} */ getMaximum() { return this.max; } /** * @param {?} max * @return {?} */ setMaximum(max) { this.max = max; } /** * @return {?} */ getMinimum() { return this.min; } /** * @param {?} min * @return {?} */ setMinimum(min) { this.min = min; } /** * @return {?} */ getStep() { return this.step; } /** * @param {?} step * @return {?} */ setStep(step) { this.step = step; } /** * @return {?} */ isVertical() { return this.vertical; } /** * @param {?} vertical * @return {?} */ setVertical(vertical) { this.vertical = vertical; } /** * @return {?} */ isThumbLabel() { return this.thumbLabel; } /** * @param {?} thumbLabel * @return {?} */ setThumbLabel(thumbLabel) { this.thumbLabel = thumbLabel; } /** * @return {?} */ getTickInterval() { return this.tickInterval; } /** * @param {?} tickInterval * @return {?} */ setTickInterval(tickInterval) { if (typeof tickInterval === "number") { this.tickInterval = tickInterval; } else { this.tickInterval = 'auto'; } } /** * @return {?} */ getDescription() { return this.description; } /** * @param {?} description * @return {?} */ setDescription(description) { this.description = description; } /** * @return {?} */ hasDescription() { if (this.description !== null && typeof this.description === 'string' && this.description !== '') { return true; } return false; } /** * @param {?} $event * @return {?} */ onChanged($event) { this.slider.value = this._oldValue; this.setInputValue($event.value); } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onClicked($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } if (this.isReadOnly()) { $event.preventDefault(); return; } if (this.isDisabled()) { $event.preventDefault(); return; } EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event) => { // doEvent }, ($event) => { // emitBeforeEvent this.emitBeforeClickEvent($event); }, ($event, result) => { // emitAfterEvent this.emitClickEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?} oldValue * @param {?} newValue * @param {?} valueChange * @param {?=} $event * @return {?} */ emitChangeEvent(oldValue, newValue, valueChange, $event) { super.emitChangeEvent(oldValue, newValue, valueChange, $event); this._oldValue = newValue; } /** * @param {?=} $event * @return {?} */ emitBeforeClickEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event); if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) { this.beforeClickEvent.emit(ev); } } /** * @param {?=} $event * @return {?} */ emitClickEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event); if (this.clickEvent !== null && this.clickEvent !== undefined) { this.clickEvent.emit(ev); } } /** * @param {?} $event * @return {?} */ onFocusing($event) { this.needFocusService.setFocusingComponent(this, $event); } /** * @param {?} $event * @return {?} */ onLostFocusing($event) { this.needFocusService.resetFocusingComponent($event); } /** * @param {?} $event * @return {?} */ doFocus($event) { if ($(this.elementRef.nativeElement).find('mat-slider.mat-slider:focus').length <= 0) { $(this.elementRef.nativeElement).find('mat-slider.mat-slider').focus(); } } /** * @param {?} $event * @return {?} */ doLostFocus($event) { if ($(this.elementRef.nativeElement).find('mat-slider.mat-slider:focus').length > 0) { $(this.elementRef.nativeElement).find('mat-slider.mat-slider').blur(); } } /** * @param {?} $event * @return {?} */ onReadonlyClick($event) { if (this.isReadOnly()) { this.onFocusing($event); $event.preventDefault(); return; } } /** * @return {?} */ getWidth() { return this.width; } /** * @param {?} width * @return {?} */ setWidth(width) { this.width = width; } /** * @return {?} */ getHeight() { return this.height; } /** * @param {?} height * @return {?} */ setHeight(height) { this.height = height; } /** * @param {?} inputValue * @param {?} results * @return {?} */ onValidationEnd(inputValue, results) { } /** * @param {?} data * @param {?} inputVal * @return {?} */ onDataChange(data, inputVal) { } /** * @return {?} */ isSelfDataDirty() { return; } /** * @param {?} data * @return {?} */ selfSaveData(data) { } /** * @return {?} */ selfResetData() { } } MaterialSlider.TYPE_NAME = TYPE_NAME; MaterialSlider.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="material-input material-slider"> <div id="material-slider-readonly" *ngIf="isReadOnly()" style="width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 50;" (click)="onReadonlyClick($event)"></div> <mat-slider #mcomp [disabled]="isDisabled()" *ngIf="!isVertical()" [style.width]="getWidth()" [value]="getInputValue()" [vertical]="isVertical()" [tickInterval]="getTickInterval()" [thumbLabel]="isThumbLabel()" [invert]="isInvert()" [max]="getMaximum()" [min]="getMinimum()" [step]="getStep()" (click)="onClicked($event)" (change)="onChanged($event)"> </mat-slider> <mat-slider #mcomp [disabled]="isDisabled()" *ngIf="isVertical()" [style.height]="getHeight()" [value]="getInputValue()" [vertical]="isVertical()" [tickInterval]="getTickInterval()" [thumbLabel]="isThumbLabel()" [invert]="isInvert()" [max]="getMaximum()" [min]="getMinimum()" [step]="getStep()" (click)="onClicked($event)" (change)="onChanged($event)"> </mat-slider> <div class="validation" [style.display]="getValidationResultMessage() ? undefined : 'none'" [class.normal]="isNormal() && !isDisabled()" [class.success]="isSuccess() && !isDisabled()" [class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()"> <ng-template [ngIf]="getValidationResultMessage()" [ngIfElse]="validation_else"> {{getValidationResultMessage() | phx_text}} </ng-template> <ng-template #validation_else> <!-- We've to put whitespace if there is no validation msg to prevent empty dom --> <!-- since if validate msg's <div> dom is empty, the component positioning --> <!-- will be misplaced. --> {{ '&nbsp;' }} </ng-template> </div> <div class="description" [style.display]="getValidationResultMessage() ? 'none' : undefined" [class.normal]="isNormal() && !isDisabled()" [class.success]="isSuccess() && !isDisabled()" [class.warning]="isWarning() && !isDisabled()" [class.error]="isError() && !isDisabled()"> <ng-template [ngIf]="getDescription()" [ngIfElse]="description_else"> {{ getDescription() | phx_text }} </ng-template> <ng-template #description_else> <!-- We've to put whitespace if there is no description to prevent empty dom --> <!-- since if description's <div> dom is empty, the component positioning --> <!-- will be misplaced. --> {{ '&nbsp;' }} </ng-template> </div> <div class="help"> {{getHelp() | phx_text}} </div> </div>`, },] }, ]; /** @nocollapse */ MaterialSlider.ctorParameters = () => [ { type: ElementRef, }, { type: NeedFocusService, }, ]; MaterialSlider.propDecorators = { "dataParent": [{ type: Input },], "ignoreParentData": [{ type: Input },], "data": [{ type: Input },], "ignoreParentDisabled": [{ type: Input },], "delegateHistory": [{ type: Input },], "onDisabled": [{ type: Input },], "onEnabled": [{ type: Input },], "loadingEnabled": [{ type: Input },], "i18nKey": [{ type: Input },], "bypass": [{ type: Input, args: ['i18nBypass',] },], "options": [{ type: Input },], "disabled": [{ type: Input },], "field": [{ type: Input },], "name": [{ type: Input },], "typeOfData": [{ type: Input },], "readOnly": [{ type: Input },], "help": [{ type: Input },], "description": [{ type: Input },], "width": [{ type: Input },], "height": [{ type: Input },], "invert": [{ type: Input },], "max": [{ type: Input },], "min": [{ type: Input },], "step": [{ type: Input },], "thumbLabel": [{ type: Input },], "vertical": [{ type: Input },], "tickInterval": [{ type: Input },], "loadEvent": [{ type: Output, args: ['phxLoad',] },], "startValidateEvent": [{ type: Output, args: ['phxStartValidate',] },], "endValidateEvent": [{ type: Output, args: ['phxEndValidate',] },], "beforeFocusEvent": [{ type: Output, args: ['phxBeforeFocus',] },], "focusEvent": [{ type: Output, args: ['phxFocus',] },], "beforeLostFocusEvent": [{ type: Output, args: ['phxBeforeLostFocus',] },], "lostFocusEvent": [{ type: Output, args: ['phxLostFocus',] },], "beforeChangeEvent": [{ type: Output, args: ['phxBeforeChange',] },], "changeEvent": [{ type: Output, args: ['phxChange',] },], "beforeClickEvent": [{ type: Output, args: ['phxBeforeClick',] },], "clickEvent": [{ type: Output, args: ['phxClick',] },], "slider": [{ type: ViewChild, args: ['mcomp',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialSlider.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialSlider.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialSlider.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialSlider.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "i18nKey", void 0); tslib_1.__decorate([ Option('i18nBypass'), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "bypass", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "disabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "field", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "name", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "typeOfData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "readOnly", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", Object) ], MaterialSlider.prototype, "help", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "description", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "width", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialSlider.prototype, "height", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "invert", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Number) ], MaterialSlider.prototype, "max", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Number) ], MaterialSlider.prototype, "min", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Number) ], MaterialSlider.prototype, "step", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "thumbLabel", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialSlider.prototype, "vertical", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialSlider.prototype, "tickInterval", void 0); tslib_1.__decorate([ Option('load'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "loadEvent", void 0); tslib_1.__decorate([ Option('startValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "startValidateEvent", void 0); tslib_1.__decorate([ Option('endValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "endValidateEvent", void 0); tslib_1.__decorate([ Option('beforeFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "beforeFocusEvent", void 0); tslib_1.__decorate([ Option('focus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "focusEvent", void 0); tslib_1.__decorate([ Option('beforeLostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "beforeLostFocusEvent", void 0); tslib_1.__decorate([ Option('lostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "lostFocusEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "beforeChangeEvent", void 0); tslib_1.__decorate([ Option('change'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "changeEvent", void 0); tslib_1.__decorate([ Option('beforeClick'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "beforeClickEvent", void 0); tslib_1.__decorate([ Option('click'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialSlider.prototype, "clickEvent", void 0); function MaterialSlider_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialSlider.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialSlider.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialSlider.propDecorators; /** @type {?} */ MaterialSlider.TYPE_NAME; /** @type {?} */ MaterialSlider.prototype.dataParent; /** @type {?} */ MaterialSlider.prototype.ignoreParentData; /** @type {?} */ MaterialSlider.prototype.data; /** @type {?} */ MaterialSlider.prototype.ignoreParentDisabled; /** @type {?} */ MaterialSlider.prototype.delegateHistory; /** @type {?} */ MaterialSlider.prototype.onDisabled; /** @type {?} */ MaterialSlider.prototype.onEnabled; /** @type {?} */ MaterialSlider.prototype.loadingEnabled; /** @type {?} */ MaterialSlider.prototype.i18nKey; /** @type {?} */ MaterialSlider.prototype.bypass; /** @type {?} */ MaterialSlider.prototype.options; /** @type {?} */ MaterialSlider.prototype.disabled; /** @type {?} */ MaterialSlider.prototype.field; /** @type {?} */ MaterialSlider.prototype.name; /** @type {?} */ MaterialSlider.prototype.typeOfData; /** @type {?} */ MaterialSlider.prototype.readOnly; /** @type {?} */ MaterialSlider.prototype.help; /** @type {?} */ MaterialSlider.prototype.description; /** @type {?} */ MaterialSlider.prototype.width; /** @type {?} */ MaterialSlider.prototype.height; /** @type {?} */ MaterialSlider.prototype.invert; /** @type {?} */ MaterialSlider.prototype.max; /** @type {?} */ MaterialSlider.prototype.min; /** @type {?} */ MaterialSlider.prototype.step; /** @type {?} */ MaterialSlider.prototype.thumbLabel; /** @type {?} */ MaterialSlider.prototype.vertical; /** @type {?} */ MaterialSlider.prototype.tickInterval; /** @type {?} */ MaterialSlider.prototype.loadEvent; /** @type {?} */ MaterialSlider.prototype.startValidateEvent; /** @type {?} */ MaterialSlider.prototype.endValidateEvent; /** @type {?} */ MaterialSlider.prototype.beforeFocusEvent; /** @type {?} */ MaterialSlider.prototype.focusEvent; /** @type {?} */ MaterialSlider.prototype.beforeLostFocusEvent; /** @type {?} */ MaterialSlider.prototype.lostFocusEvent; /** @type {?} */ MaterialSlider.prototype.beforeChangeEvent; /** @type {?} */ MaterialSlider.prototype.changeEvent; /** @type {?} */ MaterialSlider.prototype.beforeClickEvent; /** @type {?} */ MaterialSlider.prototype.clickEvent; /** @type {?} */ MaterialSlider.prototype.slider; /** @type {?} */ MaterialSlider.prototype._oldValue; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialSlider.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialSlider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, ViewChild, SimpleChanges, EventEmitter } from '@angular/core';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { EventUtils } from '../../../../../share/utils/EventUtils';\r\nimport { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../../../../../share/CustomEventType';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { AbstractInputDataView } from '../../../../../component/dataview/input/AbstractInputDataView';\r\nimport { ValidationResult } from '../../../../../component/model/ValidationResult';\r\nimport { MatSlider } from '@angular/material';\r\n\r\nconst TYPE_NAME: string = \"material-slider\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-input material-slider\">\r\n    <div id=\"material-slider-readonly\" *ngIf=\"isReadOnly()\" style=\"width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 50;\" (click)=\"onReadonlyClick($event)\"></div>\r\n    <mat-slider #mcomp [disabled]=\"isDisabled()\" *ngIf=\"!isVertical()\" [style.width]=\"getWidth()\" [value]=\"getInputValue()\" [vertical]=\"isVertical()\" [tickInterval]=\"getTickInterval()\" [thumbLabel]=\"isThumbLabel()\" [invert]=\"isInvert()\" [max]=\"getMaximum()\" [min]=\"getMinimum()\" [step]=\"getStep()\" (click)=\"onClicked($event)\" (change)=\"onChanged($event)\">\r\n    </mat-slider>\r\n    <mat-slider #mcomp [disabled]=\"isDisabled()\" *ngIf=\"isVertical()\"  [style.height]=\"getHeight()\" [value]=\"getInputValue()\" [vertical]=\"isVertical()\" [tickInterval]=\"getTickInterval()\" [thumbLabel]=\"isThumbLabel()\" [invert]=\"isInvert()\" [max]=\"getMaximum()\" [min]=\"getMinimum()\" [step]=\"getStep()\" (click)=\"onClicked($event)\" (change)=\"onChanged($event)\">\r\n    </mat-slider>\r\n    <div class=\"validation\" [style.display]=\"getValidationResultMessage() ? undefined : 'none'\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\r\n        <ng-template [ngIf]=\"getValidationResultMessage()\" [ngIfElse]=\"validation_else\">\r\n            {{getValidationResultMessage() | phx_text}}\r\n        </ng-template>\r\n        <ng-template #validation_else>\r\n            <!-- We've to put whitespace if there is no validation msg to prevent empty dom -->\r\n            <!-- since if validate msg's <div> dom is empty, the component positioning -->\r\n            <!-- will be misplaced. -->\r\n            {{ '&nbsp;' }}\r\n        </ng-template>\r\n    </div>\r\n    <div class=\"description\" [style.display]=\"getValidationResultMessage() ? 'none' : undefined\" [class.normal]=\"isNormal() && !isDisabled()\" [class.success]=\"isSuccess() && !isDisabled()\" [class.warning]=\"isWarning() && !isDisabled()\" [class.error]=\"isError() && !isDisabled()\">\r\n        <ng-template [ngIf]=\"getDescription()\" [ngIfElse]=\"description_else\">\r\n            {{ getDescription() | phx_text }}\r\n        </ng-template>\r\n        <ng-template #description_else>\r\n            <!-- We've to put whitespace if there is no description to prevent empty dom -->\r\n            <!-- since if description's <div> dom is empty, the component positioning -->\r\n            <!-- will be misplaced. -->\r\n            {{ '&nbsp;' }}\r\n        </ng-template>\r\n    </div>\r\n    <div class=\"help\">\r\n        {{getHelp() | phx_text}}\r\n    </div>\r\n</div>`,\r\n})\r\nexport class MaterialSlider extends AbstractInputDataView implements OnInit {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // Re-declare field to declare ng @Input.\r\n  // --- from AbstractHasData\r\n  @Input()\r\n  @Option()\r\n  protected dataParent: IHasData;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected data: any;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected i18nKey: string;\r\n  @Input('i18nBypass')\r\n  @Option('i18nBypass')\r\n  protected bypass: boolean; \r\n  @Input()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected disabled: boolean;\r\n  // --- from AbstractDataView\r\n  @Input()\r\n  @Option()\r\n  protected field: string;\r\n  // --- from AbstractInputDataView\r\n  @Input()\r\n  @Option()\r\n  protected name: string;\r\n  @Input()\r\n  @Option()\r\n  protected typeOfData: string;\r\n  @Input()\r\n  @Option()\r\n  protected readOnly: boolean;\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected help: any;\r\n\r\n  // --- self\r\n  @I18N()\r\n  @Option()\r\n  @Input()\r\n  private description: string;\r\n  @Input()\r\n  @Option()\r\n  protected width: string;\r\n  @Input()\r\n  @Option()\r\n  protected height: string;\r\n  @Input()\r\n  @Option()\r\n  protected invert: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected max: number;\r\n  @Input()\r\n  @Option()\r\n  protected min: number;\r\n  @Input()\r\n  @Option()\r\n  protected step: number;\r\n  @Input()\r\n  @Option()\r\n  protected thumbLabel: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected vertical: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected tickInterval: 'auto' | number;\r\n\r\n  // Re-declare field to declare ng @Output.\r\n  // --- from AbstractHasData\r\n  @Output('phxLoad')\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n  // --- from AbstractDataView\r\n  // --- from AbstractInputDataView\r\n  @Output('phxStartValidate')\r\n  @Option('startValidate')\r\n  protected startValidateEvent: EventEmitter<any>;\r\n  @Output('phxEndValidate')\r\n  @Option('endValidate')\r\n  protected endValidateEvent: EventEmitter<any>;\r\n  @Output('phxBeforeFocus')\r\n  @Option('beforeFocus')\r\n  protected beforeFocusEvent: EventEmitter<any>;\r\n  @Output('phxFocus')\r\n  @Option('focus')\r\n  protected focusEvent: EventEmitter<any>;\r\n  @Output('phxBeforeLostFocus')\r\n  @Option('beforeLostFocus')\r\n  protected beforeLostFocusEvent: EventEmitter<any>;\r\n  @Output('phxLostFocus')\r\n  @Option('lostFocus')\r\n  protected lostFocusEvent: EventEmitter<any>;\r\n  @Output('phxBeforeChange')\r\n  @Option('beforeChange')\r\n  protected beforeChangeEvent: EventEmitter<any>;\r\n  @Output('phxChange')\r\n  @Option('change')\r\n  protected changeEvent: EventEmitter<any>;\r\n\r\n  // --- Self\r\n\r\n  @Output('phxBeforeClick')\r\n  @Option('beforeClick')\r\n  protected beforeClickEvent: EventEmitter<any>;\r\n  @Output('phxClick')\r\n  @Option('click')\r\n  protected clickEvent: EventEmitter<any>;\r\n\r\n  @ViewChild('mcomp')\r\n  private slider: MatSlider;\r\n  private _oldValue: any;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\r\n    super(elementRef, needFocusService)\r\n\r\n    this.beforeClickEvent = new EventEmitter();\r\n    this.clickEvent = new EventEmitter();\r\n    this.beforeFocusEvent = new EventEmitter();\r\n    this.focusEvent = new EventEmitter();\r\n    this.beforeLostFocusEvent = new EventEmitter();\r\n    this.lostFocusEvent = new EventEmitter();\r\n    this.beforeChangeEvent = new EventEmitter();\r\n    this.changeEvent = new EventEmitter();\r\n\r\n    this.disabled = false;\r\n  }\r\n\r\n  public ngOnChanges(changes: SimpleChanges): void {\r\n    setTimeout(() => {\r\n      this.initEventHandlers();\r\n\r\n      this._oldValue = this.slider.value;\r\n    }, 20)\r\n  }\r\n\r\n  private initEventHandlers(): void {\r\n    $(this.elementRef.nativeElement).find('mat-slider.mat-slider').focus(($event) => {\r\n      this.onFocusing($event);\r\n    });\r\n\r\n    $(this.elementRef.nativeElement).find('mat-slider.mat-slider').blur(($event) => {\r\n      this.onLostFocusing($event);\r\n    });\r\n  }\r\n\r\n  public isInvert(): boolean {\r\n    return this.invert;\r\n  }\r\n\r\n  public setInvert(invert: boolean): void {\r\n    this.invert = invert;\r\n  }\r\n\r\n  public getMaximum(): number {\r\n    return this.max;\r\n  }\r\n\r\n  public setMaximum(max: number): void {\r\n    this.max = max;\r\n  }\r\n\r\n  public getMinimum(): number {\r\n    return this.min;\r\n  }\r\n\r\n  public setMinimum(min: number): void {\r\n    this.min = min;\r\n  }\r\n\r\n  public getStep(): number {\r\n    return this.step;\r\n  }\r\n\r\n  public setStep(step: number): void {\r\n    this.step = step;\r\n  }\r\n\r\n  public isVertical(): boolean {\r\n    return this.vertical;\r\n  }\r\n\r\n  public setVertical(vertical: boolean): void {\r\n    this.vertical = vertical;\r\n  }\r\n\r\n  public isThumbLabel(): boolean {\r\n    return this.thumbLabel;\r\n  }\r\n\r\n  public setThumbLabel(thumbLabel: boolean): void {\r\n    this.thumbLabel = thumbLabel;\r\n  }\r\n\r\n  public getTickInterval(): any {\r\n    return this.tickInterval;\r\n  }\r\n\r\n  public setTickInterval(tickInterval: 'auto' | number): void {\r\n    if (typeof tickInterval === \"number\") {\r\n      this.tickInterval = tickInterval;\r\n    } else {\r\n      this.tickInterval = 'auto';\r\n    }\r\n  }\r\n\r\n  public getDescription(): string {\r\n    return this.description;\r\n  }\r\n\r\n  public setDescription(description: string): void {\r\n    this.description = description;\r\n  }\r\n\r\n  public hasDescription(): boolean {\r\n    if (this.description !== null && typeof this.description === 'string' && this.description !== '') {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public onChanged($event: any): void {\r\n    this.slider.value = this._oldValue;\r\n\r\n    this.setInputValue($event.value);\r\n  }\r\n\r\n  public onClicked($event: Event, fireEvent?: boolean): void {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    if (this.isReadOnly()) {\r\n      $event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    if (this.isDisabled()) {\r\n      $event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeClickEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitClickEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  // Override: to save this._oldValue\r\n  protected emitChangeEvent(oldValue: any, newValue: any, valueChange: boolean, $event?: any): void {\r\n    super.emitChangeEvent(oldValue, newValue, valueChange, $event);\r\n\r\n    this._oldValue = newValue;\r\n  }\r\n\r\n  protected emitBeforeClickEvent($event?: any): void {\r\n    let eventData: any = null;\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);\r\n\r\n    if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) {\r\n      this.beforeClickEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitClickEvent($event?: any): void {\r\n    let eventData: any = null;\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);\r\n\r\n    if (this.clickEvent !== null && this.clickEvent !== undefined) {\r\n      this.clickEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  public onFocusing($event: Event): void {\r\n    this.needFocusService.setFocusingComponent(this, $event);\r\n  }\r\n\r\n  public onLostFocusing($event: Event): void {\r\n    this.needFocusService.resetFocusingComponent($event);\r\n  }\r\n\r\n  protected doFocus($event: Event): void {\r\n    if ($(this.elementRef.nativeElement).find('mat-slider.mat-slider:focus').length <= 0) {\r\n      $(this.elementRef.nativeElement).find('mat-slider.mat-slider').focus();\r\n    }\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    if ($(this.elementRef.nativeElement).find('mat-slider.mat-slider:focus').length > 0) {\r\n      $(this.elementRef.nativeElement).find('mat-slider.mat-slider').blur();\r\n    }\r\n  }\r\n\r\n  public onReadonlyClick($event: Event): void {\r\n    if (this.isReadOnly()) {\r\n      this.onFocusing($event);\r\n      $event.preventDefault();\r\n      return;\r\n    }\r\n  }\r\n\r\n  public getWidth(): string {\r\n    return this.width;\r\n  }\r\n\r\n  public setWidth(width: string): void {\r\n    this.width = width;\r\n  }\r\n\r\n  public getHeight(): string {\r\n    return this.height;\r\n  }\r\n\r\n  public setHeight(height: string): void {\r\n    this.height = height;\r\n  }\r\n\r\n  protected onValidationEnd(inputValue: any, results: ValidationResult[]): void {\r\n\r\n  }\r\n\r\n  protected onDataChange(data: any, inputVal: any): void {\r\n\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return\r\n  }\r\n\r\n  public selfSaveData(data: any): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n}\r\n"]}