com.phloxui
Version:
PhloxUI Ng2+ Framework
670 lines (669 loc) • 48.6 kB
JavaScript
/**
* @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 { AbstractSelectItems } from '../../../../../component/dataview/input/AbstractSelectItems';
import { NeedFocusService } from '../../../../../service/NeedFocusService.service';
import { EventUtils } from '../../../../../share/utils/EventUtils';
import { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../../../../../share/CustomEventType';
import { MatButtonToggleGroup } from '@angular/material';
var /** @type {?} */ TYPE_NAME = "material-button-toggle";
var MaterialButtonToggle = /** @class */ (function (_super) {
tslib_1.__extends(MaterialButtonToggle, _super);
function MaterialButtonToggle(elementRef, needFocusService) {
var _this = _super.call(this, elementRef, needFocusService) || this;
_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.selectEvent = new EventEmitter();
_this.beforeSelectEvent = new EventEmitter();
_this.multiple = false;
return _this;
}
/**
* @return {?}
*/
MaterialButtonToggle.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
setTimeout(function () {
_this.initEventHandlers();
}, 20);
};
/**
* @param {?} $event
* @param {?} index
* @return {?}
*/
MaterialButtonToggle.prototype.setSelectedItem = /**
* @param {?} $event
* @param {?} index
* @return {?}
*/
function ($event, index) {
var /** @type {?} */ oldIndexes = this.getSelectedIndexes();
var /** @type {?} */ item = this.getItemAtIndex(index);
var /** @type {?} */ oldDatas = [];
var /** @type {?} */ newDatas = [];
if (oldIndexes !== null && oldIndexes !== undefined) {
try {
for (var oldIndexes_1 = tslib_1.__values(oldIndexes), oldIndexes_1_1 = oldIndexes_1.next(); !oldIndexes_1_1.done; oldIndexes_1_1 = oldIndexes_1.next()) {
var oldIndex = oldIndexes_1_1.value;
oldDatas.push(this.getItemAtIndex(oldIndex));
newDatas.push(this.getItemAtIndex(oldIndex));
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (oldIndexes_1_1 && !oldIndexes_1_1.done && (_a = oldIndexes_1.return)) _a.call(oldIndexes_1);
}
finally { if (e_1) throw e_1.error; }
}
}
if (oldDatas.indexOf(item) === -1) {
newDatas.push(item);
}
else {
newDatas.splice(oldDatas.indexOf(item), 1);
}
this.setSelectedItems(newDatas);
var e_1, _a;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.getItems = /**
* @return {?}
*/
function () {
return this.items;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.isDisableRipple = /**
* @return {?}
*/
function () {
return this.disableRipple;
};
/**
* @param {?} disableRipple
* @return {?}
*/
MaterialButtonToggle.prototype.setDisableRipple = /**
* @param {?} disableRipple
* @return {?}
*/
function (disableRipple) {
this.disableRipple = disableRipple;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.isMultiple = /**
* @return {?}
*/
function () {
return this.multiple;
};
/**
* @param {?} multiple
* @return {?}
*/
MaterialButtonToggle.prototype.setMultiple = /**
* @param {?} multiple
* @return {?}
*/
function (multiple) {
this.multiple = multiple;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.toggle = /**
* @return {?}
*/
function () {
this.multiple = !this.multiple;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.isDisabledRipple = /**
* @return {?}
*/
function () {
return this.disableRipple;
};
/**
* @param {?} disableRipple
* @return {?}
*/
MaterialButtonToggle.prototype.setDisabledRipple = /**
* @param {?} disableRipple
* @return {?}
*/
function (disableRipple) {
this.disableRipple = disableRipple;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.isVertical = /**
* @return {?}
*/
function () {
return this.vertical;
};
/**
* @param {?} vertical
* @return {?}
*/
MaterialButtonToggle.prototype.setVertical = /**
* @param {?} vertical
* @return {?}
*/
function (vertical) {
this.vertical = vertical;
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.isChecked = /**
* @return {?}
*/
function () {
return this.checked;
};
/**
* @param {?} checked
* @return {?}
*/
MaterialButtonToggle.prototype.setChecked = /**
* @param {?} checked
* @return {?}
*/
function (checked) {
this.checked = checked;
};
/**
* @param {?} $event
* @param {?} i
* @return {?}
*/
MaterialButtonToggle.prototype.onChange = /**
* @param {?} $event
* @param {?} i
* @return {?}
*/
function ($event, i) {
if ($event.value !== null && $event.value !== undefined) {
}
};
/**
* @param {?} $event
* @return {?}
*/
MaterialButtonToggle.prototype.onFocusing = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.needFocusService.setFocusingComponent(this, $event);
};
/**
* @param {?} $event
* @return {?}
*/
MaterialButtonToggle.prototype.onLostFocusing = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.needFocusService.resetFocusingComponent($event);
};
/**
* @return {?}
*/
MaterialButtonToggle.prototype.initEventHandlers = /**
* @return {?}
*/
function () {
var _this = this;
$(this.elementRef.nativeElement).find('button.mat-button-toggle-button').focus(function ($event) {
_this.onFocusing($event);
});
$(this.elementRef.nativeElement).find('button.mat-button-toggle-button').blur(function ($event) {
_this.onLostFocusing($event);
});
};
/**
* @param {?} $event
* @param {?} index
* @param {?=} fireEvent
* @return {?}
*/
MaterialButtonToggle.prototype.onClick = /**
* @param {?} $event
* @param {?} index
* @param {?=} fireEvent
* @return {?}
*/
function ($event, index, fireEvent) {
var _this = this;
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
if (this.beforeClickEvent.observers.length > 0 && fireEvent) {
if (!this._beforeClickInited) {
this.beforeClickEvent.subscribe(function ($event) {
if (!$event.defaultPrevented) {
_this.setSelectedItem($event, index);
_this.emitClickEvent($event);
}
});
this._beforeClickInited = true;
}
this.emitBeforeClickEvent($event);
}
else {
if (fireEvent) {
this.setSelectedItem($event, index);
this.emitClickEvent($event);
}
}
};
/**
* @param {?=} $event
* @return {?}
*/
MaterialButtonToggle.prototype.emitBeforeClickEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);
if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) {
this.beforeClickEvent.emit(ev);
}
};
/**
* @param {?=} $event
* @return {?}
*/
MaterialButtonToggle.prototype.emitClickEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);
if (this.clickEvent !== null && this.clickEvent !== undefined) {
this.clickEvent.emit(ev);
}
};
/**
* @param {?} $event
* @return {?}
*/
MaterialButtonToggle.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if ($(this.elementRef.nativeElement).find('button.mat-button-toggle-button:focus').length <= 0) {
$(this.elementRef.nativeElement).find('button.mat-button-toggle-button').focus();
}
};
/**
* @param {?} $event
* @return {?}
*/
MaterialButtonToggle.prototype.doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if ($(this.elementRef.nativeElement).find('button.mat-button-toggle-button:focus').length > 0) {
$(this.elementRef.nativeElement).find('button.mat-button-toggle-button').blur();
}
};
/**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
MaterialButtonToggle.prototype.onValidationEnd = /**
* @param {?} inputValue
* @param {?} results
* @return {?}
*/
function (inputValue, results) {
};
/**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
MaterialButtonToggle.prototype.onDataChange = /**
* @param {?} data
* @param {?} inputVal
* @return {?}
*/
function (data, inputVal) {
};
MaterialButtonToggle.TYPE_NAME = TYPE_NAME;
MaterialButtonToggle.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"material-input\">\n <mat-button-toggle-group #group=\"matButtonToggleGroup\" multiple *ngIf=\"isMultiple() === true\" [vertical]=\"isVertical()\">\n <mat-button-toggle [value]=\"item.value\" *ngFor=\"let item of getItems(); let i = index\" [disabled]=\"isDisabled()\" [disableRipple]=\"isDisabledRipple()\" [checked]=\"isChecked()\" (change)=\"onChange($event, i)\" (click)=\"onClick($event, i)\">\n <mat-icon>{{ item.label }}</mat-icon>\n </mat-button-toggle>\n </mat-button-toggle-group>\n <mat-button-toggle-group #group=\"matButtonToggleGroup\" *ngIf=\"isMultiple() === false\" [vertical]=\"isVertical()\">\n <mat-button-toggle [value]=\"item.value\" *ngFor=\"let item of getItems(); let i = index\" [disabled]=\"isDisabled()\" [disableRipple]=\"isDisabledRipple()\" [checked]=\"isChecked()\" (change)=\"onChange($event, i)\" (click)=\"onClick($event, i)\">\n <mat-icon>{{ item.label }}</mat-icon>\n </mat-button-toggle>\n </mat-button-toggle-group>\n</div>",
},] },
];
/** @nocollapse */
MaterialButtonToggle.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: NeedFocusService, },
]; };
MaterialButtonToggle.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 },],
"dataComparator": [{ type: Input, args: ['comparator',] },],
"items": [{ 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',] },],
"beforeSelectEvent": [{ type: Output, args: ['phxBeforeSelect',] },],
"selectEvent": [{ type: Output, args: ['phxSelect',] },],
"value": [{ type: Input },],
"multiple": [{ type: Input },],
"vertical": [{ type: Input },],
"disableRipple": [{ type: Input },],
"checked": [{ type: Input },],
"beforeClickEvent": [{ type: Output, args: ['phxBeforeClick',] },],
"clickEvent": [{ type: Output, args: ['phxClick',] },],
"group": [{ type: ViewChild, args: ['group',] },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialButtonToggle.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialButtonToggle.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialButtonToggle.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], MaterialButtonToggle.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialButtonToggle.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "disabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialButtonToggle.prototype, "field", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialButtonToggle.prototype, "name", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MaterialButtonToggle.prototype, "typeOfData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "readOnly", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialButtonToggle.prototype, "help", void 0);
tslib_1.__decorate([
Option('comparator'),
tslib_1.__metadata("design:type", Object)
], MaterialButtonToggle.prototype, "dataComparator", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Array)
], MaterialButtonToggle.prototype, "items", void 0);
tslib_1.__decorate([
Option('load'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "loadEvent", void 0);
tslib_1.__decorate([
Option('startValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "startValidateEvent", void 0);
tslib_1.__decorate([
Option('endValidate'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "endValidateEvent", void 0);
tslib_1.__decorate([
Option('beforeFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "beforeFocusEvent", void 0);
tslib_1.__decorate([
Option('focus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "focusEvent", void 0);
tslib_1.__decorate([
Option('beforeLostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "beforeLostFocusEvent", void 0);
tslib_1.__decorate([
Option('lostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "lostFocusEvent", void 0);
tslib_1.__decorate([
Option('beforeChange'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "beforeChangeEvent", void 0);
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "changeEvent", void 0);
tslib_1.__decorate([
Option('beforeSelect'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "beforeSelectEvent", void 0);
tslib_1.__decorate([
Option('select'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "selectEvent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], MaterialButtonToggle.prototype, "value", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "multiple", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "vertical", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "disableRipple", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], MaterialButtonToggle.prototype, "checked", void 0);
tslib_1.__decorate([
Option('beforeClick'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "beforeClickEvent", void 0);
tslib_1.__decorate([
Option('click'),
tslib_1.__metadata("design:type", EventEmitter)
], MaterialButtonToggle.prototype, "clickEvent", void 0);
tslib_1.__decorate([
I18N(),
tslib_1.__metadata("design:type", MatButtonToggleGroup)
], MaterialButtonToggle.prototype, "group", void 0);
return MaterialButtonToggle;
}(AbstractSelectItems));
export { MaterialButtonToggle };
function MaterialButtonToggle_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MaterialButtonToggle.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MaterialButtonToggle.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
MaterialButtonToggle.propDecorators;
/** @type {?} */
MaterialButtonToggle.TYPE_NAME;
/** @type {?} */
MaterialButtonToggle.prototype.dataParent;
/** @type {?} */
MaterialButtonToggle.prototype.ignoreParentData;
/** @type {?} */
MaterialButtonToggle.prototype.data;
/** @type {?} */
MaterialButtonToggle.prototype.ignoreParentDisabled;
/** @type {?} */
MaterialButtonToggle.prototype.delegateHistory;
/** @type {?} */
MaterialButtonToggle.prototype.onDisabled;
/** @type {?} */
MaterialButtonToggle.prototype.onEnabled;
/** @type {?} */
MaterialButtonToggle.prototype.loadingEnabled;
/** @type {?} */
MaterialButtonToggle.prototype.i18nKey;
/** @type {?} */
MaterialButtonToggle.prototype.bypass;
/** @type {?} */
MaterialButtonToggle.prototype.options;
/** @type {?} */
MaterialButtonToggle.prototype.disabled;
/** @type {?} */
MaterialButtonToggle.prototype.field;
/** @type {?} */
MaterialButtonToggle.prototype.name;
/** @type {?} */
MaterialButtonToggle.prototype.typeOfData;
/** @type {?} */
MaterialButtonToggle.prototype.readOnly;
/** @type {?} */
MaterialButtonToggle.prototype.help;
/** @type {?} */
MaterialButtonToggle.prototype.dataComparator;
/** @type {?} */
MaterialButtonToggle.prototype.items;
/** @type {?} */
MaterialButtonToggle.prototype.loadEvent;
/** @type {?} */
MaterialButtonToggle.prototype.startValidateEvent;
/** @type {?} */
MaterialButtonToggle.prototype.endValidateEvent;
/** @type {?} */
MaterialButtonToggle.prototype.beforeFocusEvent;
/** @type {?} */
MaterialButtonToggle.prototype.focusEvent;
/** @type {?} */
MaterialButtonToggle.prototype.beforeLostFocusEvent;
/** @type {?} */
MaterialButtonToggle.prototype.lostFocusEvent;
/** @type {?} */
MaterialButtonToggle.prototype.beforeChangeEvent;
/** @type {?} */
MaterialButtonToggle.prototype.changeEvent;
/** @type {?} */
MaterialButtonToggle.prototype.beforeSelectEvent;
/** @type {?} */
MaterialButtonToggle.prototype.selectEvent;
/** @type {?} */
MaterialButtonToggle.prototype.value;
/** @type {?} */
MaterialButtonToggle.prototype.multiple;
/** @type {?} */
MaterialButtonToggle.prototype.vertical;
/** @type {?} */
MaterialButtonToggle.prototype.disableRipple;
/** @type {?} */
MaterialButtonToggle.prototype.checked;
/** @type {?} */
MaterialButtonToggle.prototype.beforeClickEvent;
/** @type {?} */
MaterialButtonToggle.prototype.clickEvent;
/** @type {?} */
MaterialButtonToggle.prototype.group;
/** @type {?} */
MaterialButtonToggle.prototype._beforeClickInited;
/** @type {?} */
MaterialButtonToggle.prototype.array;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialButtonToggle.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialButtonToggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, HostListener, ViewChild, SimpleChanges, EventEmitter } from '@angular/core';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { AbstractSelectItems } from '../../../../../component/dataview/input/AbstractSelectItems';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { EventUtils } from '../../../../../share/utils/EventUtils';\r\nimport { ValidationResult } from '../../../../../component/model/ValidationResult';\r\nimport { DefaultSelectItemModel } from '../../../../../component/model/DefaultSelectItemModel';\r\nimport { IDataComparator } from '../../../../../component/IDataComparator';\r\nimport { CLICK_EVENT, BEFORE_CLICK_EVENT, FOCUS_EVENT, LOST_FOCUS_EVENT, SELECT_EVENT, BEFORE_SELECT_EVENT } from '../../../../../share/CustomEventType';\r\nimport { MatButtonToggleGroup } from '@angular/material';\r\n\r\n\r\nconst TYPE_NAME: string = \"material-button-toggle\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-input\">\r\n  <mat-button-toggle-group #group=\"matButtonToggleGroup\" multiple *ngIf=\"isMultiple() === true\" [vertical]=\"isVertical()\">\r\n    <mat-button-toggle [value]=\"item.value\" *ngFor=\"let item of getItems(); let i = index\" [disabled]=\"isDisabled()\" [disableRipple]=\"isDisabledRipple()\" [checked]=\"isChecked()\" (change)=\"onChange($event, i)\" (click)=\"onClick($event, i)\">\r\n      <mat-icon>{{ item.label }}</mat-icon>\r\n    </mat-button-toggle>\r\n  </mat-button-toggle-group>\r\n  <mat-button-toggle-group #group=\"matButtonToggleGroup\" *ngIf=\"isMultiple() === false\" [vertical]=\"isVertical()\">\r\n    <mat-button-toggle [value]=\"item.value\" *ngFor=\"let item of getItems(); let i = index\" [disabled]=\"isDisabled()\" [disableRipple]=\"isDisabledRipple()\" [checked]=\"isChecked()\" (change)=\"onChange($event, i)\" (click)=\"onClick($event, i)\">\r\n      <mat-icon>{{ item.label }}</mat-icon>\r\n    </mat-button-toggle>\r\n  </mat-button-toggle-group>\r\n</div>`,\r\n})\r\nexport class MaterialButtonToggle extends AbstractSelectItems implements OnInit, IHasData {\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  // --- from AbstractSelectItems\r\n  @Input('comparator')\r\n  @Option('comparator')\r\n  protected dataComparator: IDataComparator<any>;\r\n  @Input()\r\n  @Option()\r\n  protected items: DefaultSelectItemModel[];\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  // --- from AbstractSelectItems\r\n  // --- from AbstractSelectOneItem\r\n  @Output('phxBeforeSelect')\r\n  @Option('beforeSelect')\r\n  protected beforeSelectEvent: EventEmitter<any>;\r\n  @Output('phxSelect')\r\n  @Option('select')\r\n  protected selectEvent: EventEmitter<any>;\r\n\r\n  // --- from self\r\n  @Input()\r\n  @Option()\r\n  protected value: any;\r\n  @Input()\r\n  @Option()\r\n  protected multiple: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected vertical: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected disableRipple: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected checked: boolean;\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  @I18N()\r\n  @ViewChild('group')\r\n  private group: MatButtonToggleGroup;\r\n\r\n  private _beforeClickInited: boolean;\r\n  private array: 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.selectEvent = new EventEmitter();\r\n    this.beforeSelectEvent = new EventEmitter();\r\n    this.multiple = false;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    setTimeout(()=>{\r\n      this.initEventHandlers();\r\n    },20)\r\n  }\r\n\r\n  private setSelectedItem($event: any, index: number): void {\r\n    let oldIndexes: number[] = this.getSelectedIndexes();\r\n\r\n    let item = this.getItemAtIndex(index);\r\n\r\n    let oldDatas: any = [];\r\n    let newDatas: any = [];\r\n\r\n    if (oldIndexes !== null && oldIndexes !== undefined) {\r\n      for (let oldIndex of oldIndexes) {\r\n        oldDatas.push(this.getItemAtIndex(oldIndex));\r\n        newDatas.push(this.getItemAtIndex(oldIndex));\r\n      }\r\n    }\r\n\r\n    if (oldDatas.indexOf(item) === -1) {\r\n      newDatas.push(item);\r\n    } else {\r\n      newDatas.splice(oldDatas.indexOf(item), 1);\r\n    }\r\n\r\n    this.setSelectedItems(newDatas);\r\n  }\r\n\r\n  public getItems(): any[] {\r\n    return this.items;\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 isMultiple(): boolean {\r\n    return this.multiple;\r\n  }\r\n\r\n  public setMultiple(multiple: boolean): void {\r\n    this.multiple = multiple;\r\n  }\r\n\r\n  public toggle(): void {\r\n    this.multiple = !this.multiple;\r\n  }\r\n\r\n  public isDisabledRipple(): boolean {\r\n    return this.disableRipple;\r\n  }\r\n\r\n  public setDisabledRipple(disableRipple: boolean): void {\r\n    this.disableRipple = disableRipple;\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 isChecked(): boolean {\r\n    return this.checked;\r\n  }\r\n\r\n  public setChecked(checked: boolean): void {\r\n    this.checked = checked;\r\n  }\r\n\r\n  public onChange($event: any, i:number): void {\r\n    if($event.value !== null && $event.value !== undefined) {\r\n\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  public initEventHandlers(): void {\r\n    $(this.elementRef.nativeElement).find('button.mat-button-toggle-button').focus(($event)=>{\r\n      this.onFocusing($event);\r\n    })\r\n\r\n    $(this.elementRef.nativeElement).find('button.mat-button-toggle-button').blur(($event)=>{\r\n      this.onLostFocusing($event);\r\n    });\r\n  }\r\n\r\n  public onClick($event: Event, index: number, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    if (this.beforeClickEvent.observers.length > 0 && fireEvent) {\r\n      if (!this._beforeClickInited) {\r\n        this.beforeClickEvent.subscribe(($event: any) => {\r\n\r\n          if (!$event.defaultPrevented) {\r\n            this.setSelectedItem($event, index);\r\n            this.emitClickEvent($event);\r\n          }\r\n        });\r\n        this._beforeClickInited = true;\r\n      }\r\n\r\n      this.emitBeforeClickEvent($event);\r\n    } else {\r\n      if (fireEvent) {\r\n        this.setSelectedItem($event, index);\r\n        this.emitClickEvent($event);\r\n      }\r\n    }\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  protected doFocus($event: Event): void {\r\n    if($(this.elementRef.nativeElement).find('button.mat-button-toggle-button:focus').length <= 0) {\r\n      $(this.elementRef.nativeElement).find('button.mat-button-toggle-button').focus();\r\n    }\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    if($(this.elementRef.nativeElement).find('button.mat-button-toggle-button:focus').length > 0) {\r\n      $(this.elementRef.nativeElement).find('button.mat-button-toggle-button').blur();\r\n    }\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}\r\n"]}