UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

635 lines (634 loc) 49.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, Output, EventEmitter, ElementRef, ViewChild } from '@angular/core'; import { ToggleSwitch } from '../../../../../component/dataview/input/ToggleSwitch.component'; import { Option } from '../../../../../decorator/Option.decorator'; import { I18N } from '../../../../../decorator/I18N.decorator'; import { NeedFocusService } from '../../../../../service/NeedFocusService.service'; import { EventUtils } from '../../../../../share/utils/EventUtils'; import { DRAG_CHANGE_EVENT, BEFORE_DRAG_CHANGE_EVENT, TOGGLE_CHANGE_EVENT, BEFORE_TOGGLE_CHANGE_EVENT } from '../../../../../share/CustomEventType'; import { MatSlideToggle } from '@angular/material'; const /** @type {?} */ TYPE_NAME = "material-switch"; export class MaterialToggleSwitch extends ToggleSwitch { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(elementRef, needFocusService); this.beforeDragChangeEvent = new EventEmitter(); this.dragChangeEvent = new EventEmitter(); this.beforeToggleChangeEvent = new EventEmitter(); this.toggleChangeEvent = new EventEmitter(); } /** * @return {?} */ ngOnInit() { super.ngOnInit(); $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').focus(($event) => { this.onFocusing($event); }); $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').blur(($event) => { this.onLostFocusing($event); }); } /** * @return {?} */ _displayHelp() { let /** @type {?} */ hasHelp = this.hasHelp(); return hasHelp && this.isShowHelp(); } /** * @return {?} */ getLabel() { return this.label; } /** * @param {?} label * @return {?} */ setLabel(label) { this.label = label; } /** * @return {?} */ getDescription() { return this.description; } /** * @param {?} description * @return {?} */ setDescription(description) { this.description = description; } /** * @return {?} */ getLabelPosition() { return this.labelPosition; } /** * @param {?} labelPosition * @return {?} */ setLabelPosition(labelPosition) { this.labelPosition = labelPosition; } /** * @return {?} */ isDisableRipple() { return this.disableRipple; } /** * @param {?} disableRipple * @return {?} */ setDisableRipple(disableRipple) { this.disableRipple = disableRipple; } /** * @return {?} */ isDisabled() { return this.disabled; } /** * @param {?} disabled * @return {?} */ setDisabled(disabled) { this.disabled = disabled; } /** * @return {?} */ getDragChangeEvent() { return this.dragChangeEvent; } /** * @param {?} event * @return {?} */ setDragChangeEvent(event) { this.dragChangeEvent = event; } /** * @return {?} */ getBeforeDragChangeEvent() { return this.beforeDragChangeEvent; } /** * @param {?} event * @return {?} */ setBeforeDragChangeEvent(event) { this.beforeDragChangeEvent = event; } /** * @return {?} */ getToggleChangeEvent() { return this.toggleChangeEvent; } /** * @param {?} event * @return {?} */ setToggleChangeEvent(event) { this.toggleChangeEvent = event; } /** * @return {?} */ getBeforeToggleChangeEvent() { return this.beforeToggleChangeEvent; } /** * @param {?} event * @return {?} */ setBeforeToggleChangeEvent(event) { this.beforeToggleChangeEvent = event; } /** * @param {?} $event * @return {?} */ onClick($event) { if (this.isReadOnly()) { $event.preventDefault(); return; } if (this.isDisabled()) { $event.preventDefault(); return; } } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onChange($event, fireEvent) { if (this.mcomp.checked != this.getInputValue()) { this.mcomp.toggle(); } if (this.isReadOnly()) { return; } if (this.isDisabled()) { return; } this.setInputValue($event.checked, $event, fireEvent); } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onDragChange($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeDragChangeEvent', $event, fireEvent, ($event) => { // doEvent }, ($event) => { // emitBeforeEvent this.emitBeforeDragChangeEvent($event); }, ($event, result) => { // emitAfterEvent this.emitDragChangeEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?=} $event * @return {?} */ emitBeforeDragChangeEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_DRAG_CHANGE_EVENT, this, data, $event); if (this.beforeDragChangeEvent !== null && this.beforeDragChangeEvent !== undefined) { this.beforeDragChangeEvent.emit(ev); } } /** * @param {?=} $event * @return {?} */ emitDragChangeEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(DRAG_CHANGE_EVENT, this, data, $event); if (this.dragChangeEvent !== null && this.dragChangeEvent !== undefined) { this.dragChangeEvent.emit(ev); } } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onToggleChange($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeToggleChangeEvent', $event, fireEvent, ($event) => { // doEvent }, ($event) => { // emitBeforeEvent this.emitBeforeToggleChangeEvent($event); }, ($event, result) => { // emitAfterEvent this.emitToggleChangeEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?=} $event * @return {?} */ emitBeforeToggleChangeEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_TOGGLE_CHANGE_EVENT, this, data, $event); if (this.beforeToggleChangeEvent !== null && this.beforeToggleChangeEvent !== undefined) { this.beforeToggleChangeEvent.emit(ev); } } /** * @param {?=} $event * @return {?} */ emitToggleChangeEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(TOGGLE_CHANGE_EVENT, this, data, $event); if (this.toggleChangeEvent !== null && this.toggleChangeEvent !== undefined) { this.toggleChangeEvent.emit(ev); } } /** * @param {?} $event * @return {?} */ onFocusing($event) { this.needFocusService.setFocusingComponent(this, $event); } /** * @param {?} $event * @return {?} */ onLostFocusing($event) { this.needFocusService.resetFocusingComponent($event); } /** * @param {?} inputValue * @param {?} results * @return {?} */ onValidationEnd(inputValue, results) { } /** * @param {?} data * @param {?} inputVal * @return {?} */ onDataChange(data, inputVal) { } /** * @param {?} $event * @return {?} */ doFocus($event) { if ($(this.elementRef.nativeElement).find('input.mat-slide-toggle-input:focus').length <= 0) { $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').focus(); } } /** * @param {?} $event * @return {?} */ doLostFocus($event) { if ($(this.elementRef.nativeElement).find('input.mat-slide-toggle-input:focus').length > 0) { $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').blur(); } } } MaterialToggleSwitch.TYPE_NAME = TYPE_NAME; MaterialToggleSwitch.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="material-switch" [class.readonly]="isReadOnly()"> <mat-slide-toggle #mcomp [checked]="isToggle()" [disableRipple]="isDisableRipple()" [disabled]="isDisabled()" [labelPosition]="getLabelPosition()" (change)="onChange($event)" (dragChange)="onDragChange($event)" (toggleChange)="onToggleChange($event)"> {{getLabel() | phx_text}} </mat-slide-toggle> <div *ngIf="isReadOnly()" class="readonly-panel" (click)="onClick($event)"></div> <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 */ MaterialToggleSwitch.ctorParameters = () => [ { type: ElementRef, }, { type: NeedFocusService, }, ]; MaterialToggleSwitch.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 },], "label": [{ type: Input },], "description": [{ type: Input },], "disableRipple": [{ type: Input },], "labelPosition": [{ 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',] },], "beforeDragChangeEvent": [{ type: Output, args: ['phxBeforeDragChange',] },], "dragChangeEvent": [{ type: Output, args: ['phxDragChange',] },], "beforeToggleChangeEvent": [{ type: Output, args: ['phxBeforeToggleChange',] },], "toggleChangeEvent": [{ type: Output, args: ['phxToggleChange',] },], "mcomp": [{ type: ViewChild, args: ['mcomp',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialToggleSwitch.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialToggleSwitch.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialToggleSwitch.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialToggleSwitch.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "i18nKey", void 0); tslib_1.__decorate([ Option('i18nBypass'), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "bypass", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "disabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "field", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "name", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "typeOfData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "readOnly", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", Object) ], MaterialToggleSwitch.prototype, "help", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "label", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "description", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialToggleSwitch.prototype, "disableRipple", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialToggleSwitch.prototype, "labelPosition", void 0); tslib_1.__decorate([ Option('load'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "loadEvent", void 0); tslib_1.__decorate([ Option('startValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "startValidateEvent", void 0); tslib_1.__decorate([ Option('endValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "endValidateEvent", void 0); tslib_1.__decorate([ Option('beforeFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "beforeFocusEvent", void 0); tslib_1.__decorate([ Option('focus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "focusEvent", void 0); tslib_1.__decorate([ Option('beforeLostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "beforeLostFocusEvent", void 0); tslib_1.__decorate([ Option('lostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "lostFocusEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "beforeChangeEvent", void 0); tslib_1.__decorate([ Option('change'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "changeEvent", void 0); tslib_1.__decorate([ Option('beforeDragChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "beforeDragChangeEvent", void 0); tslib_1.__decorate([ Option('dragChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "dragChangeEvent", void 0); tslib_1.__decorate([ Option('beforeToggleChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "beforeToggleChangeEvent", void 0); tslib_1.__decorate([ Option('toggleChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialToggleSwitch.prototype, "toggleChangeEvent", void 0); function MaterialToggleSwitch_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialToggleSwitch.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialToggleSwitch.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialToggleSwitch.propDecorators; /** @type {?} */ MaterialToggleSwitch.TYPE_NAME; /** @type {?} */ MaterialToggleSwitch.prototype.dataParent; /** @type {?} */ MaterialToggleSwitch.prototype.ignoreParentData; /** @type {?} */ MaterialToggleSwitch.prototype.data; /** @type {?} */ MaterialToggleSwitch.prototype.ignoreParentDisabled; /** @type {?} */ MaterialToggleSwitch.prototype.delegateHistory; /** @type {?} */ MaterialToggleSwitch.prototype.onDisabled; /** @type {?} */ MaterialToggleSwitch.prototype.onEnabled; /** @type {?} */ MaterialToggleSwitch.prototype.loadingEnabled; /** @type {?} */ MaterialToggleSwitch.prototype.i18nKey; /** @type {?} */ MaterialToggleSwitch.prototype.bypass; /** @type {?} */ MaterialToggleSwitch.prototype.options; /** @type {?} */ MaterialToggleSwitch.prototype.disabled; /** @type {?} */ MaterialToggleSwitch.prototype.field; /** @type {?} */ MaterialToggleSwitch.prototype.name; /** @type {?} */ MaterialToggleSwitch.prototype.typeOfData; /** @type {?} */ MaterialToggleSwitch.prototype.readOnly; /** @type {?} */ MaterialToggleSwitch.prototype.help; /** @type {?} */ MaterialToggleSwitch.prototype.label; /** @type {?} */ MaterialToggleSwitch.prototype.description; /** @type {?} */ MaterialToggleSwitch.prototype.disableRipple; /** @type {?} */ MaterialToggleSwitch.prototype.labelPosition; /** @type {?} */ MaterialToggleSwitch.prototype.loadEvent; /** @type {?} */ MaterialToggleSwitch.prototype.startValidateEvent; /** @type {?} */ MaterialToggleSwitch.prototype.endValidateEvent; /** @type {?} */ MaterialToggleSwitch.prototype.beforeFocusEvent; /** @type {?} */ MaterialToggleSwitch.prototype.focusEvent; /** @type {?} */ MaterialToggleSwitch.prototype.beforeLostFocusEvent; /** @type {?} */ MaterialToggleSwitch.prototype.lostFocusEvent; /** @type {?} */ MaterialToggleSwitch.prototype.beforeChangeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.changeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.beforeDragChangeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.dragChangeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.beforeToggleChangeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.toggleChangeEvent; /** @type {?} */ MaterialToggleSwitch.prototype.mcomp; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialToggleSwitch.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialToggleSwitch.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, ElementRef, ViewChild } from '@angular/core';\r\nimport { ToggleSwitch } from '../../../../../component/dataview/input/ToggleSwitch.component';\r\nimport { ValidationResult } from '../../../../../component/model/ValidationResult';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { EventUtils } from '../../../../../share/utils/EventUtils';\r\nimport { DRAG_CHANGE_EVENT, BEFORE_DRAG_CHANGE_EVENT, TOGGLE_CHANGE_EVENT, BEFORE_TOGGLE_CHANGE_EVENT } from '../../../../../share/CustomEventType';\r\nimport { MatSlideToggle } from '@angular/material';\r\n\r\nconst TYPE_NAME: string = \"material-switch\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-switch\" [class.readonly]=\"isReadOnly()\">\r\n  <mat-slide-toggle #mcomp [checked]=\"isToggle()\" [disableRipple]=\"isDisableRipple()\" [disabled]=\"isDisabled()\" [labelPosition]=\"getLabelPosition()\" (change)=\"onChange($event)\" (dragChange)=\"onDragChange($event)\" (toggleChange)=\"onToggleChange($event)\">\r\n    {{getLabel() | phx_text}}\r\n  </mat-slide-toggle>\r\n  <div *ngIf=\"isReadOnly()\" class=\"readonly-panel\" (click)=\"onClick($event)\"></div>\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\n})\r\nexport class MaterialToggleSwitch extends ToggleSwitch 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  // --- Self\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected label: string;\r\n  @I18N()\r\n  @Option()\r\n  @Input()\r\n  protected description: string;\r\n  @Input()\r\n  @Option()\r\n  protected disableRipple: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected labelPosition: string; // 'before' | 'after'\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  // --- Self\r\n  @Output('phxBeforeDragChange')\r\n  @Option('beforeDragChange')\r\n  protected beforeDragChangeEvent: EventEmitter<any>;\r\n  @Output('phxDragChange')\r\n  @Option('dragChange')\r\n  protected dragChangeEvent: EventEmitter<any>;\r\n  @Output('phxBeforeToggleChange')\r\n  @Option('beforeToggleChange')\r\n  protected beforeToggleChangeEvent: EventEmitter<any>;\r\n  @Output('phxToggleChange')\r\n  @Option('toggleChange')\r\n  protected toggleChangeEvent: EventEmitter<any>;\r\n\r\n  @ViewChild('mcomp')\r\n  private mcomp: MatSlideToggle;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\r\n    super(elementRef, needFocusService);\r\n\r\n    this.beforeDragChangeEvent = new EventEmitter<any>();\r\n    this.dragChangeEvent = new EventEmitter<any>();\r\n    this.beforeToggleChangeEvent = new EventEmitter<any>();\r\n    this.toggleChangeEvent = new EventEmitter<any>();\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').focus(($event) => {\r\n      this.onFocusing($event);\r\n    });\r\n\r\n    $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').blur(($event) => {\r\n      this.onLostFocusing($event);\r\n    });\r\n  } \r\n\r\n  public _displayHelp(): boolean {\r\n    let hasHelp = this.hasHelp();\r\n\r\n    return hasHelp && this.isShowHelp();\r\n  }\r\n\r\n  public getLabel(): string {\r\n    return this.label;\r\n  }\r\n\r\n  public setLabel(label: string): void {\r\n    this.label = label;\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 getLabelPosition(): string {\r\n    return this.labelPosition;\r\n  }\r\n\r\n  public setLabelPosition(labelPosition: string): void {\r\n    this.labelPosition = labelPosition;\r\n  }\r\n\r\n  public isDisableRipple(): boolean {\r\n    return this.disableRipple;\r\n  }\r\n\r\n  public setDisableRipple(disableRipple: boolean): void {\r\n    this.disableRipple = disableRipple;\r\n  }\r\n\r\n  public isDisabled(): boolean {\r\n    return this.disabled;\r\n  }\r\n\r\n  public setDisabled(disabled: boolean): void {\r\n    this.disabled = disabled;\r\n  }\r\n\r\n  public getDragChangeEvent(): EventEmitter<any> {\r\n    return this.dragChangeEvent;\r\n  }\r\n\r\n  public setDragChangeEvent(event: EventEmitter<any>): void {\r\n    this.dragChangeEvent = event;\r\n  }\r\n\r\n  public getBeforeDragChangeEvent(): EventEmitter<any> {\r\n    return this.beforeDragChangeEvent;\r\n  }\r\n\r\n  public setBeforeDragChangeEvent(event: EventEmitter<any>): void {\r\n    this.beforeDragChangeEvent = event;\r\n  }\r\n\r\n  public getToggleChangeEvent(): EventEmitter<any> {\r\n    return this.toggleChangeEvent;\r\n  }\r\n\r\n  public setToggleChangeEvent(event: EventEmitter<any>): void {\r\n    this.toggleChangeEvent = event;\r\n  }\r\n\r\n  public getBeforeToggleChangeEvent(): EventEmitter<any> {\r\n    return this.beforeToggleChangeEvent;\r\n  }\r\n\r\n  public setBeforeToggleChangeEvent(event: EventEmitter<any>): void {\r\n    this.beforeToggleChangeEvent = event;\r\n  }\r\n\r\n  public onClick($event: Event): void {\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\r\n  public onChange($event: any, fireEvent?: boolean) {\r\n    if(this.mcomp.checked != this.getInputValue()){\r\n      this.mcomp.toggle();\r\n    }\r\n    \r\n    if (this.isReadOnly()) {\r\n      return;\r\n    }\r\n    \r\n    if (this.isDisabled()) {\r\n      return;\r\n    }\r\n    \r\n    this.setInputValue($event.checked, $event, fireEvent);\r\n  }\r\n\r\n  public onDragChange($event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeDragChangeEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeDragChangeEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitDragChangeEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected emitBeforeDragChangeEvent($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_DRAG_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.beforeDragChangeEvent !== null && this.beforeDragChangeEvent !== undefined) {\r\n      this.beforeDragChangeEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitDragChangeEvent($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(DRAG_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.dragChangeEvent !== null && this.dragChangeEvent !== undefined) {\r\n      this.dragChangeEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  public onToggleChange($event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeToggleChangeEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeToggleChangeEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitToggleChangeEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected emitBeforeToggleChangeEvent($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_TOGGLE_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.beforeToggleChangeEvent !== null && this.beforeToggleChangeEvent !== undefined) {\r\n      this.beforeToggleChangeEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitToggleChangeEvent($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(TOGGLE_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.toggleChangeEvent !== null && this.toggleChangeEvent !== undefined) {\r\n      this.toggleChangeEvent.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 onValidationEnd(inputValue: any, results: ValidationResult[]): void {\r\n  }\r\n\r\n  protected onDataChange(data: any, inputVal: any): void {\r\n  }\r\n\r\n  protected doFocus($event: Event): void {\r\n    if ($(this.elementRef.nativeElement).find('input.mat-slide-toggle-input:focus').length <= 0) {\r\n      $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').focus();\r\n    }\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    if ($(this.elementRef.nativeElement).find('input.mat-slide-toggle-input:focus').length > 0) {\r\n      $(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').blur();\r\n    }\r\n  }\r\n\r\n}\r\n"]}