com.phloxui
Version:
PhloxUI Ng2+ Framework
741 lines (740 loc) • 54.7 kB
JavaScript
/**
* @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';
var /** @type {?} */ TYPE_NAME = "material-switch";
var MaterialToggleSwitch = /** @class */ (function (_super) {
tslib_1.__extends(MaterialToggleSwitch, _super);
function MaterialToggleSwitch(elementRef, needFocusService) {
var _this = _super.call(this, elementRef, needFocusService) || this;
_this.beforeDragChangeEvent = new EventEmitter();
_this.dragChangeEvent = new EventEmitter();
_this.beforeToggleChangeEvent = new EventEmitter();
_this.toggleChangeEvent = new EventEmitter();
return _this;
}
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
_super.prototype.ngOnInit.call(this);
$(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').focus(function ($event) {
_this.onFocusing($event);
});
$(this.elementRef.nativeElement).find('input.mat-slide-toggle-input').blur(function ($event) {
_this.onLostFocusing($event);
});
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype._displayHelp = /**
* @return {?}
*/
function () {
var /** @type {?} */ hasHelp = this.hasHelp();
return hasHelp && this.isShowHelp();
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getLabel = /**
* @return {?}
*/
function () {
return this.label;
};
/**
* @param {?} label
* @return {?}
*/
MaterialToggleSwitch.prototype.setLabel = /**
* @param {?} label
* @return {?}
*/
function (label) {
this.label = label;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getDescription = /**
* @return {?}
*/
function () {
return this.description;
};
/**
* @param {?} description
* @return {?}
*/
MaterialToggleSwitch.prototype.setDescription = /**
* @param {?} description
* @return {?}
*/
function (description) {
this.description = description;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getLabelPosition = /**
* @return {?}
*/
function () {
return this.labelPosition;
};
/**
* @param {?} labelPosition
* @return {?}
*/
MaterialToggleSwitch.prototype.setLabelPosition = /**
* @param {?} labelPosition
* @return {?}
*/
function (labelPosition) {
this.labelPosition = labelPosition;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.isDisableRipple = /**
* @return {?}
*/
function () {
return this.disableRipple;
};
/**
* @param {?} disableRipple
* @return {?}
*/
MaterialToggleSwitch.prototype.setDisableRipple = /**
* @param {?} disableRipple
* @return {?}
*/
function (disableRipple) {
this.disableRipple = disableRipple;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.isDisabled = /**
* @return {?}
*/
function () {
return this.disabled;
};
/**
* @param {?} disabled
* @return {?}
*/
MaterialToggleSwitch.prototype.setDisabled = /**
* @param {?} disabled
* @return {?}
*/
function (disabled) {
this.disabled = disabled;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getDragChangeEvent = /**
* @return {?}
*/
function () {
return this.dragChangeEvent;
};
/**
* @param {?} event
* @return {?}
*/
MaterialToggleSwitch.prototype.setDragChangeEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.dragChangeEvent = event;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getBeforeDragChangeEvent = /**
* @return {?}
*/
function () {
return this.beforeDragChangeEvent;
};
/**
* @param {?} event
* @return {?}
*/
MaterialToggleSwitch.prototype.setBeforeDragChangeEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.beforeDragChangeEvent = event;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getToggleChangeEvent = /**
* @return {?}
*/
function () {
return this.toggleChangeEvent;
};
/**
* @param {?} event
* @return {?}
*/
MaterialToggleSwitch.prototype.setToggleChangeEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.toggleChangeEvent = event;
};
/**
* @return {?}
*/
MaterialToggleSwitch.prototype.getBeforeToggleChangeEvent = /**
* @return {?}
*/
function () {
return this.beforeToggleChangeEvent;
};
/**
* @param {?} event
* @return {?}
*/
MaterialToggleSwitch.prototype.setBeforeToggleChangeEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.beforeToggleChangeEvent = event;
};
/**
* @param {?} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.onClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.isReadOnly()) {
$event.preventDefault();
return;
}
if (this.isDisabled()) {
$event.preventDefault();
return;
}
};
/**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
MaterialToggleSwitch.prototype.onChange = /**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
function ($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 {?}
*/
MaterialToggleSwitch.prototype.onDragChange = /**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
function ($event, fireEvent) {
var _this = this;
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
EventUtils.handleBrowserEvent(this, 'beforeDragChangeEvent', $event, fireEvent, function ($event) {
// doEvent
}, function ($event) {
// emitBeforeEvent
// emitBeforeEvent
_this.emitBeforeDragChangeEvent($event);
}, function ($event, result) {
// emitAfterEvent
// emitAfterEvent
_this.emitDragChangeEvent($event);
}, function ($event) {
// doPrevented
});
};
/**
* @param {?=} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.emitBeforeDragChangeEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @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 {?}
*/
MaterialToggleSwitch.prototype.emitDragChangeEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @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 {?}
*/
MaterialToggleSwitch.prototype.onToggleChange = /**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
function ($event, fireEvent) {
var _this = this;
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
EventUtils.handleBrowserEvent(this, 'beforeToggleChangeEvent', $event, fireEvent, function ($event) {
// doEvent
}, function ($event) {
// emitBeforeEvent
// emitBeforeEvent
_this.emitBeforeToggleChangeEvent($event);
}, function ($event, result) {
// emitAfterEvent
// emitAfterEvent
_this.emitToggleChangeEvent($event);
}, function ($event) {
// doPrevented
});
};
/**
* @param {?=} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.emitBeforeToggleChangeEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @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 {?}
*/
MaterialToggleSwitch.prototype.emitToggleChangeEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(TOGGLE_CHANGE_EVENT, this, data, $event);
if (this.toggleChangeEvent !== null && this.toggleChangeEvent !== undefined) {
this.toggleChangeEvent.emit(ev);
}
};
/**
* @param {?} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.onFocusing = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.needFocusService.setFocusingComponent(this, $event);
};
/**
* @param {?} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.onLostFocusing = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.needFocusService.resetFocusingComponent($event);
};
/**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
MaterialToggleSwitch.prototype.onValidationEnd = /**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
function (inputValue, results) {
};
/**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
MaterialToggleSwitch.prototype.onDataChange = /**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
function (data, inputVal) {
};
/**
* @param {?} $event
* @return {?}
*/
MaterialToggleSwitch.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($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 {?}
*/
MaterialToggleSwitch.prototype.doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($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()\">\n <mat-slide-toggle #mcomp [checked]=\"isToggle()\" [disableRipple]=\"isDisableRipple()\" [disabled]=\"isDisabled()\" [labelPosition]=\"getLabelPosition()\" (change)=\"onChange($event)\" (dragChange)=\"onDragChange($event)\" (toggleChange)=\"onToggleChange($event)\">\n {{getLabel() | phx_text}}\n </mat-slide-toggle>\n <div *ngIf=\"isReadOnly()\" class=\"readonly-panel\" (click)=\"onClick($event)\"></div>\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()\">\n <ng-template [ngIf]=\"getValidationResultMessage()\" [ngIfElse]=\"validation_else\">\n {{getValidationResultMessage() | phx_text}}\n </ng-template>\n <ng-template #validation_else>\n <!-- We've to put whitespace if there is no validation msg to prevent empty dom -->\n <!-- since if validate msg's <div> dom is empty, the component positioning -->\n <!-- will be misplaced. -->\n {{ ' ' }}\n </ng-template>\n </div>\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()\">\n <ng-template [ngIf]=\"getDescription()\" [ngIfElse]=\"description_else\">\n {{ getDescription() | phx_text }}\n </ng-template>\n <ng-template #description_else>\n <!-- We've to put whitespace if there is no description to prevent empty dom -->\n <!-- since if description's <div> dom is empty, the component positioning -->\n <!-- will be misplaced. -->\n {{ ' ' }}\n </ng-template>\n </div>\n <div class=\"help\">\n {{getHelp() | phx_text}}\n </div>\n</div>\n"
},] },
];
/** @nocollapse */
MaterialToggleSwitch.ctorParameters = function () { return [
{ 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);
return MaterialToggleSwitch;
}(ToggleSwitch));
export { MaterialToggleSwitch };
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, 'beforeDragChangeE