UNPKG

fundamental-ngx

Version:

SAP Fundamentals, implemented in Angular

469 lines 29.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { ChangeDetectorRef, Component, forwardRef, HostBinding, Input, ViewChild, ViewEncapsulation } from '@angular/core'; import { TimeObject } from '../time/time-object'; import { TimeComponent } from '../time/time.component'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { TimeFormatParser } from './format/time-parser'; var TimePickerComponent = /** @class */ (function () { /** @hidden */ function TimePickerComponent(cd, timeAdapter) { this.cd = cd; this.timeAdapter = timeAdapter; /** * @hidden */ this.timepickerclass = true; /** * \@Input An object that contains three integer properties: 'hour' (ranging from 0 to 23), * 'minute' (ranging from 0 to 59), and 'second' (ranging from 0 to 59). This is the model the component consumes. Example: * * ```json * { hour: 12, minute: 0, second: 0 } * ``` */ this.time = { hour: 0, minute: 0, second: 0 }; /** * \@Input Uses compact time picker. */ this.compact = false; /** * \@Input When set to true, uses the 24 hour clock (hours ranging from 0 to 23) * and does not display a period control. */ this.meridian = false; /** * \@Input When set to false, hides the buttons that increment and decrement the corresponding input. */ this.spinners = true; /** * \@Input When set to false, hides the input for seconds. */ this.displaySeconds = true; /** * \@Input When set to false, hides the input for minutes. */ this.displayMinutes = true; /** * \@Input When set to false, hides the input for hours. */ this.displayHours = true; /** * Whether to perform visual validation on the picker input. */ this.validate = true; /** * Aria label for the time picker input. */ this.timePickerInputLabel = 'Time picker input'; /** * Whether a null input is considered valid. */ this.allowNull = true; /** * @hidden Whether the input time is valid. Internal use. */ this.isInvalidTimeInput = false; /** * @hidden */ this.onChange = (/** * @return {?} */ function () { }); /** * @hidden */ this.onTouched = (/** * @return {?} */ function () { }); } /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.ngOnInit = /** * @hidden * @return {?} */ function () { this.placeholder = this.getPlaceholder(); }; /** * Returns the current value of the time input. */ /** * Returns the current value of the time input. * @return {?} */ TimePickerComponent.prototype.getTime = /** * Returns the current value of the time input. * @return {?} */ function () { return this.time; }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.getFormattedTime = /** * @hidden * @return {?} */ function () { /** @type {?} */ var formattedTime = this.timeAdapter.format(this.time, this.meridian); return formattedTime !== undefined ? formattedTime : ''; }; /** @hidden */ /** * @hidden * @param {?} timeFromInput * @return {?} */ TimePickerComponent.prototype.timeInputChanged = /** * @hidden * @param {?} timeFromInput * @return {?} */ function (timeFromInput) { /** @type {?} */ var time = this.timeAdapter.parse(timeFromInput, this.displaySeconds, this.meridian); if (time) { this.isInvalidTimeInput = false; this.child.setDisplayedHour(); this.time = Object.assign(this.time, time); this.onChange(time); } else { if (this.allowNull && timeFromInput === '') { this.isInvalidTimeInput = false; this.child.setDisplayedHour(); this.onChange({ hour: null, minutes: null, seconds: null }); } else { this.isInvalidTimeInput = true; } } }; /** @hidden */ /** * @hidden * @param {?} $event * @return {?} */ TimePickerComponent.prototype.inputGroupClicked = /** * @hidden * @param {?} $event * @return {?} */ function ($event) { if (!this.isOpen && !this.disabled) { $event.stopPropagation(); this.isOpen = true; } }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.onFocusHandler = /** * @hidden * @return {?} */ function () { if (!this.isOpen) { this.isOpen = true; } }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.addOnButtonClicked = /** * @hidden * @return {?} */ function () { if (!this.disabled) { this.isOpen = !this.isOpen; } }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.popoverClosed = /** * @hidden * @return {?} */ function () { this.isOpen = false; }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.getPlaceholder = /** * @hidden * @return {?} */ function () { /** @type {?} */ var retVal; if (this.displaySeconds) { if (this.meridian) { retVal = 'hh' + ':' + 'mm' + ':' + 'ss am/pm'; } else { retVal = 'hh' + ':' + 'mm' + ':' + 'ss'; } } else { if (this.meridian) { retVal = 'hh' + ':' + 'mm' + ' am/pm'; } else { retVal = 'hh' + ':' + 'mm'; } } return retVal; }; /** @hidden */ /** * @hidden * @return {?} */ TimePickerComponent.prototype.timeFromTimeComponentChanged = /** * @hidden * @return {?} */ function () { this.cd.detectChanges(); this.onChange(this.time); }; /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ TimePickerComponent.prototype.registerOnChange = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** @hidden */ /** * @hidden * @param {?} fn * @return {?} */ TimePickerComponent.prototype.registerOnTouched = /** * @hidden * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** @hidden */ /** * @hidden * @param {?} isDisabled * @return {?} */ TimePickerComponent.prototype.setDisabledState = /** * @hidden * @param {?} isDisabled * @return {?} */ function (isDisabled) { this.disabled = isDisabled; }; /** @hidden */ /** * @hidden * @param {?} time * @return {?} */ TimePickerComponent.prototype.writeValue = /** * @hidden * @param {?} time * @return {?} */ function (time) { if (!time) { return; } this.time = time; }; TimePickerComponent.decorators = [ { type: Component, args: [{ selector: 'fd-time-picker', template: "<fd-popover [(isOpen)]=\"isOpen\"\n [triggers]=\"[]\">\n <fd-popover-control>\n <!--fd-input-group *ngIf=\"!meridian\" (timeInputChanged)=\"timeInputChanged($event)\" [type]=\"'time'\"\n [placement]=\"'after'\" [button]=\"true\" (click)=\"inputGroupClicked($event)\" [glyph]=\"'fob-watch'\"\n [placeholder]=\"getPlaceholder()\" [inputText]=\"getFormattedTime()\" [disabled]=\"disabled\"\n (addOnButtonClicked)=\"addOnButtonClicked($event)\"></fd-input-group>\n <fd-input-group *ngIf=\"meridian\" (timeInputChanged)=\"timeInputChanged($event)\" [type]=\"'time'\"\n [placement]=\"'after'\" [button]=\"true\" (click)=\"inputGroupClicked($event)\" [glyph]=\"'fob-watch'\"\n [placeholder]=\"getPlaceholder()\" [inputText]=\"getFormattedTime()\" [disabled]=\"disabled\"\n (addOnButtonClicked)=\"addOnButtonClicked($event)\"></fd-input-group-->\n <div class=\"fd-input-group fd-input-group--after\"\n [ngClass]=\"{'fd-input-group--compact' : compact}\">\n <input [value]=\"getFormattedTime()\"\n (keyup)=\"timeInputChanged($event.currentTarget.value)\"\n (focus)=\"onFocusHandler()\"\n (click)=\"inputGroupClicked($event)\"\n [disabled]=\"disabled\"\n type=\"text\"\n [ngClass]=\"{ 'fd-input--compact': compact, 'is-invalid': isInvalidTimeInput && validate }\"\n [placeholder]=\"placeholder\"\n [attr.aria-label]=\"timePickerInputLabel\">\n <span class=\"fd-input-group__addon fd-input-group__addon--button fd-input-group__addon--after\">\n <button [disabled]=\"disabled\" type=\"button\"\n [ngClass]=\"{ 'fd-button--compact' : compact }\" (click)=\"addOnButtonClicked()\"\n class=\"fd-button--icon fd-button--light sap-icon--fob-watch\"></button>\n </span>\n </div>\n </fd-popover-control>\n <fd-popover-body *ngIf=\"displaySeconds || displayMinutes || displayHours\">\n <fd-time [disabled]=\"disabled\"\n [meridian]=\"meridian\"\n [(ngModel)]=\"time\"\n (ngModelChange)=\"timeFromTimeComponentChanged()\"\n [spinners]=\"spinners\"\n [displayMinutes]=\"displayMinutes\"\n [displaySeconds]=\"displaySeconds\"\n [displayHours]=\"displayHours\"></fd-time>\n </fd-popover-body>\n</fd-popover>\n", host: { '(blur)': 'onTouched()', class: 'fd-timepicker-custom' }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return TimePickerComponent; })), multi: true } ], encapsulation: ViewEncapsulation.None, styles: [".fd-timepicker-custom{display:inline-block}.fd-timepicker-custom fd-popover{display:block}.fd-timepicker-custom fd-time{width:auto}"] }] } ]; /** @nocollapse */ TimePickerComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: TimeFormatParser } ]; }; TimePickerComponent.propDecorators = { timepickerclass: [{ type: HostBinding, args: ['class.fd-time-picker',] }], time: [{ type: Input }], compact: [{ type: Input }], meridian: [{ type: Input }], disabled: [{ type: Input }], spinners: [{ type: Input }], displaySeconds: [{ type: Input }], displayMinutes: [{ type: Input }], displayHours: [{ type: Input }], validate: [{ type: Input }], timePickerInputLabel: [{ type: Input }], allowNull: [{ type: Input }], child: [{ type: ViewChild, args: [TimeComponent,] }] }; return TimePickerComponent; }()); export { TimePickerComponent }; if (false) { /** * @hidden * @type {?} */ TimePickerComponent.prototype.timepickerclass; /** * \@Input An object that contains three integer properties: 'hour' (ranging from 0 to 23), * 'minute' (ranging from 0 to 59), and 'second' (ranging from 0 to 59). This is the model the component consumes. Example: * * ```json * { hour: 12, minute: 0, second: 0 } * ``` * @type {?} */ TimePickerComponent.prototype.time; /** * \@Input Uses compact time picker. * @type {?} */ TimePickerComponent.prototype.compact; /** * \@Input When set to true, uses the 24 hour clock (hours ranging from 0 to 23) * and does not display a period control. * @type {?} */ TimePickerComponent.prototype.meridian; /** * \@Input Disables the component. * @type {?} */ TimePickerComponent.prototype.disabled; /** * \@Input When set to false, hides the buttons that increment and decrement the corresponding input. * @type {?} */ TimePickerComponent.prototype.spinners; /** * \@Input When set to false, hides the input for seconds. * @type {?} */ TimePickerComponent.prototype.displaySeconds; /** * \@Input When set to false, hides the input for minutes. * @type {?} */ TimePickerComponent.prototype.displayMinutes; /** * \@Input When set to false, hides the input for hours. * @type {?} */ TimePickerComponent.prototype.displayHours; /** * Whether to perform visual validation on the picker input. * @type {?} */ TimePickerComponent.prototype.validate; /** * Aria label for the time picker input. * @type {?} */ TimePickerComponent.prototype.timePickerInputLabel; /** * Whether a null input is considered valid. * @type {?} */ TimePickerComponent.prototype.allowNull; /** * @hidden Whether the input time is valid. Internal use. * @type {?} */ TimePickerComponent.prototype.isInvalidTimeInput; /** * @hidden * @type {?} */ TimePickerComponent.prototype.child; /** * @hidden * @type {?} */ TimePickerComponent.prototype.period; /** * @hidden * @type {?} */ TimePickerComponent.prototype.isOpen; /** * @hidden * @type {?} */ TimePickerComponent.prototype.placeholder; /** * @hidden * @type {?} */ TimePickerComponent.prototype.onChange; /** * @hidden * @type {?} */ TimePickerComponent.prototype.onTouched; /** * @type {?} * @private */ TimePickerComponent.prototype.cd; /** @type {?} */ TimePickerComponent.prototype.timeAdapter; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/time-picker/time-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, forwardRef, HostBinding, Input, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { TimeObject } from '../time/time-object';\nimport { TimeComponent } from '../time/time.component';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { TimeFormatParser } from './format/time-parser';\n\n@Component({\n    selector: 'fd-time-picker',\n    templateUrl: './time-picker.component.html',\n    host: {\n        '(blur)': 'onTouched()',\n        class: 'fd-timepicker-custom'\n    },\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => TimePickerComponent),\n            multi: true\n        }\n    ],\n    styleUrls: ['./time-picker.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class TimePickerComponent implements ControlValueAccessor, OnInit {\n\n    /** @hidden */\n    @HostBinding('class.fd-time-picker')\n    timepickerclass = true;\n\n    /**\n     * @Input An object that contains three integer properties: 'hour' (ranging from 0 to 23),\n     * 'minute' (ranging from 0 to 59), and 'second' (ranging from 0 to 59). This is the model the component consumes. Example:\n     *\n     * ```json\n     * { hour: 12, minute: 0, second: 0 }\n     * ```\n     */\n    @Input()\n    time: TimeObject = { hour: 0, minute: 0, second: 0 };\n\n    /** @Input Uses compact time picker. */\n    @Input()\n    compact: boolean = false;\n\n    /** @Input When set to true, uses the 24 hour clock (hours ranging from 0 to 23)\n     * and does not display a period control. */\n    @Input()\n    meridian: boolean = false;\n\n    /** @Input Disables the component. */\n    @Input()\n    disabled: boolean;\n\n    /** @Input When set to false, hides the buttons that increment and decrement the corresponding input. */\n    @Input()\n    spinners: boolean = true;\n\n    /** @Input When set to false, hides the input for seconds. */\n    @Input()\n    displaySeconds: boolean = true;\n\n    /** @Input When set to false, hides the input for minutes. */\n    @Input()\n    displayMinutes: boolean = true;\n\n    /** @Input When set to false, hides the input for hours. */\n    @Input()\n    displayHours: boolean = true;\n\n    /** Whether to perform visual validation on the picker input. */\n    @Input()\n    validate: boolean = true;\n\n    /** Aria label for the time picker input. */\n    @Input()\n    timePickerInputLabel: string = 'Time picker input';\n\n    /** Whether a null input is considered valid. */\n    @Input()\n    allowNull: boolean = true;\n\n    /** @hidden Whether the input time is valid. Internal use. */\n    isInvalidTimeInput: boolean = false;\n\n    /** @hidden */\n    @ViewChild(TimeComponent)\n    child: TimeComponent;\n\n    /** @hidden */\n    period: string;\n\n    /** @hidden */\n    isOpen: boolean;\n\n    /** @hidden */\n    placeholder: string;\n\n    /** @hidden */\n    onChange: Function = () => {};\n    /** @hidden */\n    onTouched: Function = () => {};\n\n    /** @hidden */\n    ngOnInit(): void {\n        this.placeholder = this.getPlaceholder();\n    }\n\n    /**\n     * Returns the current value of the time input.\n     */\n    getTime(): TimeObject {\n        return this.time;\n    }\n\n    /** @hidden */\n    getFormattedTime(): string {\n        const formattedTime = this.timeAdapter.format(this.time, this.meridian);\n        return formattedTime !== undefined ? formattedTime : '';\n    }\n\n    /** @hidden */\n    timeInputChanged(timeFromInput) {\n        const time = this.timeAdapter.parse(timeFromInput, this.displaySeconds, this.meridian);\n        if (time) {\n            this.isInvalidTimeInput = false;\n            this.child.setDisplayedHour();\n            this.time = Object.assign(this.time, time);\n            this.onChange(time);\n        } else {\n            if (this.allowNull && timeFromInput === '') {\n                this.isInvalidTimeInput = false;\n                this.child.setDisplayedHour();\n                this.onChange({hour: null, minutes: null, seconds: null});\n            } else {\n                this.isInvalidTimeInput = true;\n            }\n        }\n    }\n\n    /** @hidden */\n    inputGroupClicked($event) {\n        if (!this.isOpen && !this.disabled) {\n            $event.stopPropagation();\n            this.isOpen = true;\n        }\n    }\n\n    /** @hidden */\n    onFocusHandler() {\n        if (!this.isOpen) {\n            this.isOpen = true;\n        }\n    }\n\n    /** @hidden */\n    addOnButtonClicked() {\n        if (!this.disabled) {\n            this.isOpen = !this.isOpen;\n        }\n    }\n\n    /** @hidden */\n    popoverClosed() {\n        this.isOpen = false;\n    }\n\n    /** @hidden */\n    getPlaceholder(): string {\n        let retVal;\n        if (this.displaySeconds) {\n            if (this.meridian) {\n                retVal = 'hh' + ':' + 'mm' + ':' + 'ss am/pm';\n            } else {\n                retVal = 'hh' + ':' + 'mm' + ':' + 'ss';\n            }\n        } else {\n            if (this.meridian) {\n                retVal = 'hh' + ':' + 'mm' + ' am/pm';\n            } else {\n                retVal = 'hh' + ':' + 'mm';\n            }\n        }\n\n        return retVal;\n    }\n\n    /** @hidden */\n    timeFromTimeComponentChanged() {\n        this.cd.detectChanges();\n        this.onChange(this.time);\n    }\n\n    /** @hidden */\n    registerOnChange(fn: (time: TimeObject) => void): void {\n        this.onChange = fn;\n    }\n\n    /** @hidden */\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    /** @hidden */\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden */\n    writeValue(time: TimeObject): void {\n        if (!time) {\n            return;\n        }\n        this.time = time;\n    }\n\n    /** @hidden */\n    constructor(private cd: ChangeDetectorRef,\n                public timeAdapter: TimeFormatParser) {}\n}\n"]}