UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

576 lines (575 loc) 40.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core'; import { CheckBox } from '../../../../../component/dataview/input/CheckBox.component'; import { I18N } from '../../../../../decorator/I18N.decorator'; import { Option } from '../../../../../decorator/Option.decorator'; import { NeedFocusService } from '../../../../../service/NeedFocusService.service'; import { EventUtils } from '../../../../../share/utils/EventUtils'; import { INDETERMINATE_CHANGE_EVENT, BEFORE_INDETERMINATE_CHANGE_EVENT } from '../../../../../share/CustomEventType'; import { MatCheckbox } from '@angular/material'; var /** @type {?} */ TYPE_NAME = "material-checkbox"; var /** @type {?} */ DEFAULT_FIELD = "label"; var MaterialCheckBox = /** @class */ (function (_super) { tslib_1.__extends(MaterialCheckBox, _super); function MaterialCheckBox(elementRef, needFocusService) { var _this = _super.call(this, elementRef, needFocusService) || this; _this.beforeIndeterminateChangeEvent = new EventEmitter(); _this.indeterminateChangeEvent = new EventEmitter(); return _this; } /** * @return {?} */ MaterialCheckBox.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; _super.prototype.ngOnInit.call(this); $(this.elementRef.nativeElement).find('input.mat-checkbox-input').focus(function ($event) { _this.onFocusing($event); }); $(this.elementRef.nativeElement).find('input.mat-checkbox-input').blur(function ($event) { _this.onLostFocusing($event); }); }; /** * @return {?} */ MaterialCheckBox.prototype._displayHelp = /** * @return {?} */ function () { var /** @type {?} */ hasHelp = this.hasHelp(); return hasHelp && this.isShowHelp(); }; /** * @return {?} */ MaterialCheckBox.prototype.getLastPosition = /** * @return {?} */ function () { return this.labelPosition; }; /** * @param {?} labelPosition * @return {?} */ MaterialCheckBox.prototype.setLastPosition = /** * @param {?} labelPosition * @return {?} */ function (labelPosition) { this.labelPosition = labelPosition; }; /** * @return {?} */ MaterialCheckBox.prototype.isDisableRipple = /** * @return {?} */ function () { return this.disableRipple; }; /** * @param {?} disableRipple * @return {?} */ MaterialCheckBox.prototype.setDisableRipple = /** * @param {?} disableRipple * @return {?} */ function (disableRipple) { this.disableRipple = disableRipple; }; /** * @return {?} */ MaterialCheckBox.prototype.getLabel = /** * @return {?} */ function () { return this.label; }; /** * @param {?} label * @return {?} */ MaterialCheckBox.prototype.setLabel = /** * @param {?} label * @return {?} */ function (label) { this.label = label; }; /** * @return {?} */ MaterialCheckBox.prototype.isIndeterminate = /** * @return {?} */ function () { return this.indeterminate; }; /** * @param {?} indeterminate * @return {?} */ MaterialCheckBox.prototype.setIndeterminate = /** * @param {?} indeterminate * @return {?} */ function (indeterminate) { this.indeterminate = indeterminate; }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.onClick = /** * @param {?} $event * @return {?} */ function ($event) { if (this.isReadOnly() || (this.isDisabled())) { $event.preventDefault(); } }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.onChange = /** * @param {?} $event * @return {?} */ function ($event) { this.mcomp.toggle(); // $event is MatCheckboxChange {source: MatCheckbox, checked: boolean} if ($event.checked !== null && $event.checked !== undefined) { this.setInputValue($event.checked); } }; /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ MaterialCheckBox.prototype.onIndeterminateChange = /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ function ($event, fireEvent) { var _this = this; // $event is boolean if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } if (fireEvent) { this.emitBeforeIndeterminateChangeEvent(!$event, $event); } EventUtils.handleBrowserEvent(this, 'beforeIndeterminateChangeEvent', $event, fireEvent, function ($event) { // doEvent }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeIndeterminateChangeEvent(!$event, $event); }, function ($event, result) { // emitAfterEvent // emitAfterEvent _this.emitIndeterminateChangeEvent(!$event, $event); }, function ($event) { // doPrevented }); }; /** * @param {?} oldValue * @param {?} newValue * @param {?=} $event * @return {?} */ MaterialCheckBox.prototype.emitBeforeIndeterminateChangeEvent = /** * @param {?} oldValue * @param {?} newValue * @param {?=} $event * @return {?} */ function (oldValue, newValue, $event) { var /** @type {?} */ eventData = { data: this.data, oldValue: oldValue, newValue: newValue }; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_INDETERMINATE_CHANGE_EVENT, this, data, $event); if (this.beforeIndeterminateChangeEvent !== null && this.beforeIndeterminateChangeEvent !== undefined) { this.beforeIndeterminateChangeEvent.emit(ev); } }; /** * @param {?} oldValue * @param {?} newValue * @param {?=} $event * @return {?} */ MaterialCheckBox.prototype.emitIndeterminateChangeEvent = /** * @param {?} oldValue * @param {?} newValue * @param {?=} $event * @return {?} */ function (oldValue, newValue, $event) { var /** @type {?} */ eventData = { data: this.data, oldValue: oldValue, newValue: newValue }; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(INDETERMINATE_CHANGE_EVENT, this, data, $event); if (this.indeterminateChangeEvent !== null && this.indeterminateChangeEvent !== undefined) { this.indeterminateChangeEvent.emit(ev); } }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.onFocusing = /** * @param {?} $event * @return {?} */ function ($event) { this.needFocusService.setFocusingComponent(this, $event); }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.onLostFocusing = /** * @param {?} $event * @return {?} */ function ($event) { this.needFocusService.resetFocusingComponent($event); }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.doFocus = /** * @param {?} $event * @return {?} */ function ($event) { if ($(this.elementRef.nativeElement).find('input.mat-checkbox-input:focus').length <= 0) { $(this.elementRef.nativeElement).find('input.mat-checkbox-input').focus(); } }; /** * @param {?} $event * @return {?} */ MaterialCheckBox.prototype.doLostFocus = /** * @param {?} $event * @return {?} */ function ($event) { if ($(this.elementRef.nativeElement).find('input.mat-checkbox-input:focus').length > 0) { $(this.elementRef.nativeElement).find('input.mat-checkbox-input').blur(); } }; /** * @return {?} */ MaterialCheckBox.prototype.getBeforeIndeterminateChangeEvent = /** * @return {?} */ function () { return this.beforeIndeterminateChangeEvent; }; /** * @param {?} event * @return {?} */ MaterialCheckBox.prototype.setBeforeIndeterminateChangeEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeIndeterminateChangeEvent = event; }; /** * @return {?} */ MaterialCheckBox.prototype.getIndeterminateChangeEvent = /** * @return {?} */ function () { return this.indeterminateChangeEvent; }; /** * @param {?} event * @return {?} */ MaterialCheckBox.prototype.setIndeterminateChangeEvent = /** * @param {?} event * @return {?} */ function (event) { this.indeterminateChangeEvent = event; }; MaterialCheckBox.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"material-input material-checkbox\">\n <mat-checkbox #mcomp [disabled]=\"isDisabled()\" [checked]=\"isToggle()\" [indeterminate]=\"isIndeterminate()\" [disableRipple]=\"isDisableRipple()\" [labelPosition]=\"getLastPosition()\" (click)=\"onClick($event)\" (change)=\"onChange($event)\" (indeterminateChange)=\"onIndeterminateChange($event)\">{{getLabel()}}</mat-checkbox>\n\t<div class=\"help\">\n\t\t{{getHelp() | phx_text}}\n\t</div>\n</div>\n" },] }, ]; /** @nocollapse */ MaterialCheckBox.ctorParameters = function () { return [ { type: ElementRef, }, { type: NeedFocusService, }, ]; }; MaterialCheckBox.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 },], "labelPosition": [{ type: Input },], "label": [{ type: Input },], "disableRipple": [{ type: Input },], "indeterminate": [{ type: Input },], "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',] },], "beforeIndeterminateChangeEvent": [{ type: Output, args: ['phxBeforeIndeterminateChange',] },], "indeterminateChangeEvent": [{ type: Output, args: ['phxIndeterminateChange',] },], "mcomp": [{ type: ViewChild, args: ['mcomp',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialCheckBox.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialCheckBox.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialCheckBox.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialCheckBox.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "i18nKey", void 0); tslib_1.__decorate([ Option('i18nBypass'), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "bypass", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "disabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "field", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "name", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "typeOfData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "readOnly", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", Object) ], MaterialCheckBox.prototype, "help", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "labelPosition", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialCheckBox.prototype, "label", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "disableRipple", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialCheckBox.prototype, "indeterminate", void 0); tslib_1.__decorate([ Option('startValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "startValidateEvent", void 0); tslib_1.__decorate([ Option('endValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "endValidateEvent", void 0); tslib_1.__decorate([ Option('beforeFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "beforeFocusEvent", void 0); tslib_1.__decorate([ Option('focus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "focusEvent", void 0); tslib_1.__decorate([ Option('beforeLostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "beforeLostFocusEvent", void 0); tslib_1.__decorate([ Option('lostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "lostFocusEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "beforeChangeEvent", void 0); tslib_1.__decorate([ Option('change'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "changeEvent", void 0); tslib_1.__decorate([ Option('beforeIndeterminateChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "beforeIndeterminateChangeEvent", void 0); tslib_1.__decorate([ Option('indeterminateChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialCheckBox.prototype, "indeterminateChangeEvent", void 0); return MaterialCheckBox; }(CheckBox)); export { MaterialCheckBox }; function MaterialCheckBox_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialCheckBox.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialCheckBox.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialCheckBox.propDecorators; /** @type {?} */ MaterialCheckBox.prototype.dataParent; /** @type {?} */ MaterialCheckBox.prototype.ignoreParentData; /** @type {?} */ MaterialCheckBox.prototype.data; /** @type {?} */ MaterialCheckBox.prototype.ignoreParentDisabled; /** @type {?} */ MaterialCheckBox.prototype.delegateHistory; /** @type {?} */ MaterialCheckBox.prototype.onDisabled; /** @type {?} */ MaterialCheckBox.prototype.onEnabled; /** @type {?} */ MaterialCheckBox.prototype.loadingEnabled; /** @type {?} */ MaterialCheckBox.prototype.i18nKey; /** @type {?} */ MaterialCheckBox.prototype.bypass; /** @type {?} */ MaterialCheckBox.prototype.options; /** @type {?} */ MaterialCheckBox.prototype.disabled; /** @type {?} */ MaterialCheckBox.prototype.field; /** @type {?} */ MaterialCheckBox.prototype.name; /** @type {?} */ MaterialCheckBox.prototype.typeOfData; /** @type {?} */ MaterialCheckBox.prototype.readOnly; /** @type {?} */ MaterialCheckBox.prototype.help; /** @type {?} */ MaterialCheckBox.prototype.labelPosition; /** @type {?} */ MaterialCheckBox.prototype.label; /** @type {?} */ MaterialCheckBox.prototype.disableRipple; /** @type {?} */ MaterialCheckBox.prototype.indeterminate; /** @type {?} */ MaterialCheckBox.prototype.startValidateEvent; /** @type {?} */ MaterialCheckBox.prototype.endValidateEvent; /** @type {?} */ MaterialCheckBox.prototype.beforeFocusEvent; /** @type {?} */ MaterialCheckBox.prototype.focusEvent; /** @type {?} */ MaterialCheckBox.prototype.beforeLostFocusEvent; /** @type {?} */ MaterialCheckBox.prototype.lostFocusEvent; /** @type {?} */ MaterialCheckBox.prototype.beforeChangeEvent; /** @type {?} */ MaterialCheckBox.prototype.changeEvent; /** @type {?} */ MaterialCheckBox.prototype.beforeIndeterminateChangeEvent; /** @type {?} */ MaterialCheckBox.prototype.indeterminateChangeEvent; /** @type {?} */ MaterialCheckBox.prototype.mcomp; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialCheckBox.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialCheckBox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, ElementRef, EventEmitter, ViewChild } from '@angular/core';\r\nimport { CheckBox } from '../../../../../component/dataview/input/CheckBox.component';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { EventUtils } from '../../../../../share/utils/EventUtils';\r\nimport { INDETERMINATE_CHANGE_EVENT, BEFORE_INDETERMINATE_CHANGE_EVENT } from '../../../../../share/CustomEventType';\r\nimport { MatCheckbox } from '@angular/material';\r\n\r\n\r\nconst TYPE_NAME: string = \"material-checkbox\";\r\n\r\nconst DEFAULT_FIELD: string = \"label\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-input material-checkbox\">\r\n  <mat-checkbox #mcomp [disabled]=\"isDisabled()\" [checked]=\"isToggle()\" [indeterminate]=\"isIndeterminate()\" [disableRipple]=\"isDisableRipple()\" [labelPosition]=\"getLastPosition()\" (click)=\"onClick($event)\" (change)=\"onChange($event)\" (indeterminateChange)=\"onIndeterminateChange($event)\">{{getLabel()}}</mat-checkbox>\r\n\t<div class=\"help\">\r\n\t\t{{getHelp() | phx_text}}\r\n\t</div>\r\n</div>\r\n`\r\n})\r\nexport class MaterialCheckBox extends CheckBox implements OnInit {\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  @Option()\r\n  protected labelPosition: string;\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected label: string;\r\n  @Input()\r\n  @Option()\r\n  protected disableRipple: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected indeterminate: boolean;\r\n\r\n  // Re-declare field to declare ng @Output.\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  @Output('phxBeforeIndeterminateChange')\r\n  @Option('beforeIndeterminateChange')\r\n  protected beforeIndeterminateChangeEvent: EventEmitter<any>;\r\n  @Output('phxIndeterminateChange')\r\n  @Option('indeterminateChange')\r\n  protected indeterminateChangeEvent: EventEmitter<any>;\r\n\r\n  @ViewChild('mcomp')\r\n  private mcomp: MatCheckbox;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\r\n    super(elementRef, needFocusService);\r\n\r\n    this.beforeIndeterminateChangeEvent = new EventEmitter<any>();\r\n    this.indeterminateChangeEvent = 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-checkbox-input').focus(($event) => {\r\n      this.onFocusing($event);\r\n    });\r\n\r\n    $(this.elementRef.nativeElement).find('input.mat-checkbox-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 getLastPosition(): string {\r\n    return this.labelPosition;\r\n  }\r\n\r\n  public setLastPosition(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 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 isIndeterminate(): boolean {\r\n    return this.indeterminate;\r\n  }\r\n\r\n  public setIndeterminate(indeterminate: boolean): void {\r\n    this.indeterminate = indeterminate;\r\n  }\r\n\r\n  public onClick($event: Event) {\r\n    if (this.isReadOnly() || (this.isDisabled())) {\r\n      $event.preventDefault();\r\n    }\r\n  }\r\n\r\n  public onChange($event) {\r\n    this.mcomp.toggle();\r\n\r\n    // $event is MatCheckboxChange {source: MatCheckbox, checked: boolean}\r\n    if ($event.checked !== null && $event.checked !== undefined) {\r\n      this.setInputValue($event.checked);\r\n    }\r\n  }\r\n\r\n  public onIndeterminateChange($event: any, fireEvent?: boolean) {\r\n    // $event is boolean\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    if (fireEvent) {\r\n      this.emitBeforeIndeterminateChangeEvent(!$event, $event);\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeIndeterminateChangeEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeIndeterminateChangeEvent(!$event, $event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitIndeterminateChangeEvent(!$event, $event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected emitBeforeIndeterminateChangeEvent(oldValue: any, newValue: any, $event?: any): void {\r\n    let eventData: any = {\r\n      data: this.data,\r\n      oldValue: oldValue,\r\n      newValue: newValue\r\n    };\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(BEFORE_INDETERMINATE_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.beforeIndeterminateChangeEvent !== null && this.beforeIndeterminateChangeEvent !== undefined) {\r\n      this.beforeIndeterminateChangeEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitIndeterminateChangeEvent(oldValue: any, newValue: any, $event?: any): void {\r\n    let eventData: any = {\r\n      data: this.data,\r\n      oldValue: oldValue,\r\n      newValue: newValue\r\n    };\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(INDETERMINATE_CHANGE_EVENT, this, data, $event);\r\n\r\n    if (this.indeterminateChangeEvent !== null && this.indeterminateChangeEvent !== undefined) {\r\n      this.indeterminateChangeEvent.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('input.mat-checkbox-input:focus').length <= 0) {\r\n      $(this.elementRef.nativeElement).find('input.mat-checkbox-input').focus();\r\n    }\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    if ($(this.elementRef.nativeElement).find('input.mat-checkbox-input:focus').length > 0) {\r\n      $(this.elementRef.nativeElement).find('input.mat-checkbox-input').blur();\r\n    }\r\n  }\r\n\r\n  public getBeforeIndeterminateChangeEvent(): EventEmitter<any> {\r\n    return this.beforeIndeterminateChangeEvent;\r\n  }\r\n\r\n  public setBeforeIndeterminateChangeEvent(event: EventEmitter<any>): void {\r\n    this.beforeIndeterminateChangeEvent = event;\r\n  }\r\n\r\n  public getIndeterminateChangeEvent(): EventEmitter<any> {\r\n    return this.indeterminateChangeEvent;\r\n  }\r\n\r\n  public setIndeterminateChangeEvent(event: EventEmitter<any>): void {\r\n    this.indeterminateChangeEvent = event;\r\n  }\r\n}\r\n"]}