UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

533 lines (532 loc) 48.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, Output, EventEmitter } from '@angular/core'; import { TimePicker } from '../../../../../component/dataview/input/TimePicker.component'; import { NeedFocusService } from '../../../../../service/NeedFocusService.service'; import { I18N } from '../../../../../decorator/I18N.decorator'; import { Option } from '../../../../../decorator/Option.decorator'; import { FormatterFactory } from '../../../../../service/FormatterFactory.service'; import { PhloxAppInfoService } from '../../../../../service/PhloxAppInfoService.service'; var /** @type {?} */ TYPE_NAME = "material-time-picker"; var /** @type {?} */ DEFAULT_BUTTON_ICON = 'access_time'; var /** @type {?} */ DEFAULT_BUTTON_POSITION = 'suffix'; var MaterialTimePicker = /** @class */ (function (_super) { tslib_1.__extends(MaterialTimePicker, _super); function MaterialTimePicker(elementRef, needFocusService, formatterFactory, phloxAppInfoService) { var _this = _super.call(this, elementRef, needFocusService, formatterFactory, phloxAppInfoService) || this; _this.buttonIcon = DEFAULT_BUTTON_ICON; _this.buttonPosition = DEFAULT_BUTTON_POSITION; return _this; } /** * @return {?} */ MaterialTimePicker.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); }; /** * @return {?} */ MaterialTimePicker.prototype.getClassMatFocused = /** * @return {?} */ function () { return this.isReadOnly() ? { 'mat-focused': this.isClassFocused() } : {}; }; /** * @param {?} $event * @return {?} */ MaterialTimePicker.prototype.doLostFocus = /** * @param {?} $event * @return {?} */ function ($event) { // Super will always hide popup in doLostFocus(). _super.prototype.doLostFocus.call(this, $event); this._classFocused = false; }; /** * @param {?} $event * @return {?} */ MaterialTimePicker.prototype.onClick = /** * @param {?} $event * @return {?} */ function ($event) { this._btnIconClick = true; }; /** * @param {?} event * @return {?} */ MaterialTimePicker.prototype.onFocus = /** * @param {?} event * @return {?} */ function (event) { _super.prototype.onFocus.call(this, event); this._classFocused = true; }; /** * @param {?} $event * @return {?} */ MaterialTimePicker.prototype.onFocusing = /** * @param {?} $event * @return {?} */ function ($event) { if (this._btnIconClick) { _super.prototype.onFocusing.call(this, $event); } }; /** * @param {?} $event * @return {?} */ MaterialTimePicker.prototype.onLostFocusing = /** * @param {?} $event * @return {?} */ function ($event) { if (this._btnIconClick || this.isActive()) { this._btnIconClick = false; _super.prototype.onLostFocusing.call(this, $event); } }; /** * @return {?} */ MaterialTimePicker.prototype.isClassFocused = /** * @return {?} */ function () { return this._classFocused; }; /** * @return {?} */ MaterialTimePicker.prototype.getButtonIcon = /** * @return {?} */ function () { return (!this.buttonIcon ? DEFAULT_BUTTON_ICON : this.buttonIcon); ; }; /** * @param {?} buttonIcon * @return {?} */ MaterialTimePicker.prototype.setButtonIcon = /** * @param {?} buttonIcon * @return {?} */ function (buttonIcon) { this.buttonIcon = buttonIcon; }; /** * @return {?} */ MaterialTimePicker.prototype.getButtonPosition = /** * @return {?} */ function () { return (!this.buttonPosition ? DEFAULT_BUTTON_POSITION : this.buttonPosition); }; /** * @param {?} buttonPosition * @return {?} */ MaterialTimePicker.prototype.setButtonPosition = /** * @param {?} buttonPosition * @return {?} */ function (buttonPosition) { this.buttonPosition = buttonPosition; }; /** * @return {?} */ MaterialTimePicker.prototype.getLabel = /** * @return {?} */ function () { return this.label; }; /** * @param {?} label * @return {?} */ MaterialTimePicker.prototype.setLabel = /** * @param {?} label * @return {?} */ function (label) { this.label = label; }; /** * @return {?} */ MaterialTimePicker.prototype.getDescription = /** * @return {?} */ function () { return this.description; }; /** * @param {?} description * @return {?} */ MaterialTimePicker.prototype.setDescription = /** * @param {?} description * @return {?} */ function (description) { this.description = description; }; MaterialTimePicker.TYPE_NAME = TYPE_NAME; MaterialTimePicker.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"material-input material-time-picker\" [style.width]=\"getWidth()\" [style.height]=\"getHeight()\">\n <div class=\"time-picker-wrapper\" [class.active]=\"isActive()\">\n <div class=\"time-picker-table\">\n <div>\n <div class=\"table-wrapper\">\n <mat-form-field [ngClass]=\"getClassMatFocused()\">\n <input matInput type=\"text\" placeholder=\"{{getLabel() | phx_text}}\" class=\"form-control\" [class.focus]=\"isActive()\" [disabled]=\"isDisabled()\"\n [class.dirty]=\"isDataDirty()\" [readonly]=\"isReadOnly()\" [value]=\"formattedData | phx_text\" (focus)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\"\n (change)=\"onValueChanged($event)\" [class.normal]=\"isNormal()\" [class.success]=\"isSuccess()\" [class.warning]=\"isWarning()\" [class.error]=\"isError()\">\n <button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'suffix' && !(isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" matSuffix mat-icon-button>\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n \t\t\t\t</button>\n \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'prefix' && !(isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" matPrefix mat-icon-button>\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n \t\t\t\t</button>\n \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'suffix' && (isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" disabled matSuffix mat-icon-button>\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n \t\t\t\t</button>\n \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'prefix' && (isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" disabled matPrefix mat-icon-button>\n \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\n \t\t\t\t</button>\n </mat-form-field>\n <div class=\"time-picker-view\" [class.show]=\"isActive()\" [style.top]=\"getPopupPositionTop() ? getPopupPositionTop() + 'px' : undefined\" [style.left]=\"getPopupPositionLeft() ? getPopupPositionLeft() + 'px' : undefined\">\n <div class=\"time-view-wrapper\">\n <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\n <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, HOUR)\"></div>\n <div *ngFor=\"let hour of getRangeHour(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentHourTime(hour)\" (mousedown)=\"onTimeClicked($event, hour, HOUR)\">\n {{hour | number:'2.0-0'}}\n </div>\n <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, HOUR)\"></div>\n </div>\n <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\n <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, MIN)\"></div>\n <div *ngFor=\"let min of getRangeMin(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentMinTime(min)\" (mousedown)=\"onTimeClicked($event, min, MIN)\">\n {{min | number:'2.0-0'}}\n </div>\n <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, MIN)\"></div>\n </div>\n <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\n <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, SEC)\"></div>\n <div *ngFor=\"let sec of getRangeSec(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentSecTime(sec)\" (mousedown)=\"onTimeClicked($event, sec, SEC)\">\n {{sec | number:'2.0-0'}}\n </div>\n <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, SEC)\"></div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div>\n <div class=\"table-wrapper description-wrapper\">\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 {{ '&nbsp;' }}\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 {{ '&nbsp;' }}\n </ng-template>\n </div>\n </div>\n </div>\n <div>\n <div class=\"table-wrapper help-wrapper\">\n <div class=\"help\">{{getHelp() | phx_text}}</div>\n </div>\n </div>\n </div>\n </div>\n</div>\n" },] }, ]; /** @nocollapse */ MaterialTimePicker.ctorParameters = function () { return [ { type: ElementRef, }, { type: NeedFocusService, }, { type: FormatterFactory, }, { type: PhloxAppInfoService, }, ]; }; MaterialTimePicker.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 },], "formatter": [{ type: Input, args: ['formatter',] },], "formatterName": [{ type: Input, args: ['formatterName',] },], "formatterOptions": [{ type: Input, args: ['formatterOptions',] },], "formatterUsePropertyValue": [{ type: Input, args: ['formatterUsePropertyValue',] },], "dataPattern": [{ type: Input },], "range": [{ type: Input },], "hideSecond": [{ type: Input },], "width": [{ type: Input },], "height": [{ type: Input },], "label": [{ type: Input },], "description": [{ type: Input },], "buttonIcon": [{ type: Input },], "buttonPosition": [{ 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',] },], "beforeViewShowEvent": [{ type: Output, args: ['phxBeforeViewShow',] },], "viewShowEvent": [{ type: Output, args: ['phxViewShow',] },], "beforeViewHideEvent": [{ type: Output, args: ['phxBeforeViewHide',] },], "viewHideEvent": [{ type: Output, args: ['phxViewHide',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialTimePicker.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialTimePicker.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialTimePicker.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialTimePicker.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "i18nKey", void 0); tslib_1.__decorate([ Option('i18nBypass'), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "bypass", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "disabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "field", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "name", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "typeOfData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "readOnly", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", Object) ], MaterialTimePicker.prototype, "help", void 0); tslib_1.__decorate([ Option('formatter.instance'), tslib_1.__metadata("design:type", Object) ], MaterialTimePicker.prototype, "formatter", void 0); tslib_1.__decorate([ Option('formatter.name'), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "formatterName", void 0); tslib_1.__decorate([ Option('formatter.options'), tslib_1.__metadata("design:type", Object) ], MaterialTimePicker.prototype, "formatterOptions", void 0); tslib_1.__decorate([ Option('formatter.usePropertyValue'), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "formatterUsePropertyValue", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "dataPattern", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Number) ], MaterialTimePicker.prototype, "range", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialTimePicker.prototype, "hideSecond", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "width", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "height", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "label", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "description", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "buttonIcon", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialTimePicker.prototype, "buttonPosition", void 0); tslib_1.__decorate([ Option('load'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "loadEvent", void 0); tslib_1.__decorate([ Option('startValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "startValidateEvent", void 0); tslib_1.__decorate([ Option('endValidate'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "endValidateEvent", void 0); tslib_1.__decorate([ Option('beforeFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "beforeFocusEvent", void 0); tslib_1.__decorate([ Option('focus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "focusEvent", void 0); tslib_1.__decorate([ Option('beforeLostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "beforeLostFocusEvent", void 0); tslib_1.__decorate([ Option('lostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "lostFocusEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "beforeChangeEvent", void 0); tslib_1.__decorate([ Option('change'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "changeEvent", void 0); tslib_1.__decorate([ Option('beforeViewShow'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "beforeViewShowEvent", void 0); tslib_1.__decorate([ Option('viewShow'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "viewShowEvent", void 0); tslib_1.__decorate([ Option('beforeViewHide'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "beforeViewHideEvent", void 0); tslib_1.__decorate([ Option('viewHide'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialTimePicker.prototype, "viewHideEvent", void 0); return MaterialTimePicker; }(TimePicker)); export { MaterialTimePicker }; function MaterialTimePicker_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialTimePicker.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialTimePicker.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialTimePicker.propDecorators; /** @type {?} */ MaterialTimePicker.TYPE_NAME; /** @type {?} */ MaterialTimePicker.prototype.dataParent; /** @type {?} */ MaterialTimePicker.prototype.ignoreParentData; /** @type {?} */ MaterialTimePicker.prototype.data; /** @type {?} */ MaterialTimePicker.prototype.ignoreParentDisabled; /** @type {?} */ MaterialTimePicker.prototype.delegateHistory; /** @type {?} */ MaterialTimePicker.prototype.onDisabled; /** @type {?} */ MaterialTimePicker.prototype.onEnabled; /** @type {?} */ MaterialTimePicker.prototype.loadingEnabled; /** @type {?} */ MaterialTimePicker.prototype.i18nKey; /** @type {?} */ MaterialTimePicker.prototype.bypass; /** @type {?} */ MaterialTimePicker.prototype.options; /** @type {?} */ MaterialTimePicker.prototype.disabled; /** @type {?} */ MaterialTimePicker.prototype.field; /** @type {?} */ MaterialTimePicker.prototype.name; /** @type {?} */ MaterialTimePicker.prototype.typeOfData; /** @type {?} */ MaterialTimePicker.prototype.readOnly; /** @type {?} */ MaterialTimePicker.prototype.help; /** @type {?} */ MaterialTimePicker.prototype.formatter; /** @type {?} */ MaterialTimePicker.prototype.formatterName; /** @type {?} */ MaterialTimePicker.prototype.formatterOptions; /** @type {?} */ MaterialTimePicker.prototype.formatterUsePropertyValue; /** @type {?} */ MaterialTimePicker.prototype.dataPattern; /** @type {?} */ MaterialTimePicker.prototype.range; /** @type {?} */ MaterialTimePicker.prototype.hideSecond; /** @type {?} */ MaterialTimePicker.prototype.width; /** @type {?} */ MaterialTimePicker.prototype.height; /** @type {?} */ MaterialTimePicker.prototype.label; /** @type {?} */ MaterialTimePicker.prototype.description; /** @type {?} */ MaterialTimePicker.prototype.buttonIcon; /** @type {?} */ MaterialTimePicker.prototype.buttonPosition; /** @type {?} */ MaterialTimePicker.prototype.loadEvent; /** @type {?} */ MaterialTimePicker.prototype.startValidateEvent; /** @type {?} */ MaterialTimePicker.prototype.endValidateEvent; /** @type {?} */ MaterialTimePicker.prototype.beforeFocusEvent; /** @type {?} */ MaterialTimePicker.prototype.focusEvent; /** @type {?} */ MaterialTimePicker.prototype.beforeLostFocusEvent; /** @type {?} */ MaterialTimePicker.prototype.lostFocusEvent; /** @type {?} */ MaterialTimePicker.prototype.beforeChangeEvent; /** @type {?} */ MaterialTimePicker.prototype.changeEvent; /** @type {?} */ MaterialTimePicker.prototype.beforeViewShowEvent; /** @type {?} */ MaterialTimePicker.prototype.viewShowEvent; /** @type {?} */ MaterialTimePicker.prototype.beforeViewHideEvent; /** @type {?} */ MaterialTimePicker.prototype.viewHideEvent; /** @type {?} */ MaterialTimePicker.prototype._classFocused; /** @type {?} */ MaterialTimePicker.prototype._btnIconClick; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialTimePicker.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/dataview/input/MaterialTimePicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, EventEmitter } from '@angular/core';\r\nimport { TimePicker } from '../../../../../component/dataview/input/TimePicker.component';\r\nimport { INeedFocus } from '../../../../../component/INeedFocus';\r\nimport { NeedFocusService } from '../../../../../service/NeedFocusService.service';\r\nimport { IFormatter } from '../../../../../share/formatter/IFormatter';\r\nimport { I18N } from '../../../../../decorator/I18N.decorator';\r\nimport { Option } from '../../../../../decorator/Option.decorator';\r\nimport { IHasData } from '../../../../../component/IHasData';\r\nimport { FormatterFactory } from '../../../../../service/FormatterFactory.service';\r\nimport { PhloxAppInfoService } from '../../../../../service/PhloxAppInfoService.service';\r\n\r\nconst TYPE_NAME: string = \"material-time-picker\";\r\n\r\nconst DEFAULT_BUTTON_ICON = 'access_time';\r\nconst DEFAULT_BUTTON_POSITION = 'suffix';\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"material-input material-time-picker\" [style.width]=\"getWidth()\" [style.height]=\"getHeight()\">\r\n  <div class=\"time-picker-wrapper\" [class.active]=\"isActive()\">\r\n    <div class=\"time-picker-table\">\r\n      <div>\r\n        <div class=\"table-wrapper\">\r\n          <mat-form-field [ngClass]=\"getClassMatFocused()\">\r\n            <input matInput type=\"text\" placeholder=\"{{getLabel() | phx_text}}\" class=\"form-control\" [class.focus]=\"isActive()\" [disabled]=\"isDisabled()\"\r\n            [class.dirty]=\"isDataDirty()\" [readonly]=\"isReadOnly()\" [value]=\"formattedData | phx_text\" (focus)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\"\r\n              (change)=\"onValueChanged($event)\" [class.normal]=\"isNormal()\" [class.success]=\"isSuccess()\" [class.warning]=\"isWarning()\" [class.error]=\"isError()\">\r\n              <button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'suffix' && !(isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" matSuffix mat-icon-button>\r\n          \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\r\n      \t\t\t\t</button>\r\n      \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'prefix' && !(isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" matPrefix mat-icon-button>\r\n          \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\r\n      \t\t\t\t</button>\r\n      \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'suffix' && (isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" disabled matSuffix mat-icon-button>\r\n          \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\r\n      \t\t\t\t</button>\r\n      \t\t\t\t<button mat-button *ngIf=\"getButtonIcon() && (formattedData && getButtonPosition() === 'prefix' && (isDisabled() || isReadOnly()))\" (click)=\"onClick($event)\" disabled matPrefix mat-icon-button>\r\n          \t\t\t<mat-icon>{{getButtonIcon()}}</mat-icon>\r\n      \t\t\t\t</button>\r\n          </mat-form-field>\r\n          <div class=\"time-picker-view\" [class.show]=\"isActive()\" [style.top]=\"getPopupPositionTop() ? getPopupPositionTop() + 'px' : undefined\" [style.left]=\"getPopupPositionLeft() ? getPopupPositionLeft() + 'px' : undefined\">\r\n            <div class=\"time-view-wrapper\">\r\n              <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\r\n                <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, HOUR)\"></div>\r\n                <div *ngFor=\"let hour of getRangeHour(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentHourTime(hour)\" (mousedown)=\"onTimeClicked($event, hour, HOUR)\">\r\n                  {{hour | number:'2.0-0'}}\r\n                </div>\r\n                <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, HOUR)\"></div>\r\n              </div>\r\n              <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\r\n                <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, MIN)\"></div>\r\n                <div *ngFor=\"let min of getRangeMin(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentMinTime(min)\" (mousedown)=\"onTimeClicked($event, min, MIN)\">\r\n                  {{min | number:'2.0-0'}}\r\n                </div>\r\n                <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, MIN)\"></div>\r\n              </div>\r\n              <div class=\"time-view\" [class.not-open-sec]=\"_isNotOpenSecShow()\">\r\n                <div class=\"icon-arrow-up\" (mousedown)=\"onUpArrow($event, SEC)\"></div>\r\n                <div *ngFor=\"let sec of getRangeSec(); let i = index;\" class=\"time-number\" [class.selected]=\"_isCurrentSecTime(sec)\" (mousedown)=\"onTimeClicked($event, sec, SEC)\">\r\n                  {{sec | number:'2.0-0'}}\r\n                </div>\r\n                <div class=\"icon-arrow-down\" (mousedown)=\"onDownArrow($event, SEC)\"></div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n      <div>\r\n        <div class=\"table-wrapper description-wrapper\">\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>\r\n      </div>\r\n      <div>\r\n        <div class=\"table-wrapper help-wrapper\">\r\n          <div class=\"help\">{{getHelp() | phx_text}}</div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n`\r\n})\r\n\r\nexport class MaterialTimePicker extends TimePicker implements OnInit, INeedFocus {\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 AbstractHasFormatterInputDataView\r\n  @Input('formatter')\r\n  @Option('formatter.instance')\r\n  protected formatter: IFormatter;\r\n  @Input('formatterName')\r\n  @Option('formatter.name')\r\n  protected formatterName: string;\r\n  @Input('formatterOptions')\r\n  @Option('formatter.options')\r\n  protected formatterOptions: any;\r\n  @Input('formatterUsePropertyValue')\r\n  @Option('formatter.usePropertyValue')\r\n  protected formatterUsePropertyValue: boolean;\r\n  // --- from AbstractDateTimePicker \r\n  @Input()\r\n  @Option()\r\n  protected dataPattern: string;\r\n  // --- from TimePicker\r\n  @Input()\r\n  @Option()\r\n  protected range: number;\r\n  @Input()\r\n  @Option()\r\n  protected hideSecond: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected width: string;\r\n  @Input()\r\n  @Option()\r\n  protected height: string;\r\n\r\n  // --- self\r\n  @I18N()\r\n  @Option()\r\n  @Input()\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 buttonIcon: string;\r\n  @Input()\r\n  @Option()\r\n  protected buttonPosition: string;\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 AbstractHasFormatterInputDataView\r\n  // --- from AbstractDateTimePicker\r\n  @Output('phxBeforeViewShow')\r\n  @Option('beforeViewShow')\r\n  protected beforeViewShowEvent: EventEmitter<any>;\r\n  @Output('phxViewShow')\r\n  @Option('viewShow')\r\n  protected viewShowEvent: EventEmitter<any>;\r\n  @Output('phxBeforeViewHide')\r\n  @Option('beforeViewHide')\r\n  protected beforeViewHideEvent: EventEmitter<any>;\r\n  @Output('phxViewHide')\r\n  @Option('viewHide')\r\n  protected viewHideEvent: EventEmitter<any>;\r\n\r\n  private _classFocused: boolean;\r\n  private _btnIconClick: boolean;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService, formatterFactory: FormatterFactory, phloxAppInfoService: PhloxAppInfoService) {\r\n    super(elementRef, needFocusService, formatterFactory, phloxAppInfoService);\r\n\r\n    this.buttonIcon = DEFAULT_BUTTON_ICON;\r\n    this.buttonPosition = DEFAULT_BUTTON_POSITION;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n  } \r\n\r\n  public getClassMatFocused(): any {\r\n    return this.isReadOnly() ? { 'mat-focused': this.isClassFocused() } : {};\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    // Super will always hide popup in doLostFocus().\r\n    super.doLostFocus($event);\r\n    this._classFocused = false;\r\n  }\r\n\r\n  public onClick($event: Event): void {\r\n    this._btnIconClick = true;\r\n  }\r\n\r\n  public onFocus(event: any): void {\r\n    super.onFocus(event);\r\n    this._classFocused = true;\r\n  }\r\n\r\n  public onFocusing($event: any): void {\r\n    if (this._btnIconClick) {\r\n      super.onFocusing($event);\r\n    }\r\n  }\r\n\r\n  public onLostFocusing($event: any): void {\r\n    if (this._btnIconClick || this.isActive()) {\r\n      this._btnIconClick = false;\r\n\r\n      super.onLostFocusing($event);\r\n    }\r\n  }\r\n\r\n  public isClassFocused(): boolean {\r\n    return this._classFocused;\r\n  }\r\n\r\n  public getButtonIcon(): string {\r\n    return (!this.buttonIcon ? DEFAULT_BUTTON_ICON : this.buttonIcon);;\r\n  }\r\n\r\n  public setButtonIcon(buttonIcon: string): void {\r\n    this.buttonIcon = buttonIcon;\r\n  }\r\n\r\n  public getButtonPosition(): string {\r\n    return (!this.buttonPosition ? DEFAULT_BUTTON_POSITION : this.buttonPosition);\r\n  }\r\n\r\n  public setButtonPosition(buttonPosition: string): void {\r\n    this.buttonPosition = buttonPosition;\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"]}