fundamental-ngx
Version:
SAP Fundamentals, implemented in Angular
469 lines • 29.4 kB
JavaScript
/**
* @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"]}