igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
147 lines • 15.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Pipe, Inject } from '@angular/core';
import { IGX_TIME_PICKER_COMPONENT } from './time-picker.common';
/**
* Formats `IgxTimePickerComponent` display value according to the `format` property,
* when the input element loses focus.
*
*/
export class TimeDisplayFormatPipe {
/**
* @param {?} timePicker
*/
constructor(timePicker) {
this.timePicker = timePicker;
}
/**
* @param {?} value
* @return {?}
*/
transform(value) {
/** @type {?} */
const maskAmPM = this.timePicker.parseMask();
/** @type {?} */
const mask = this.timePicker.parseMask(false);
if (!value || value === mask || value === maskAmPM) {
return '';
}
/** @type {?} */
const sections = value.split(/[\s:]+/);
/** @type {?} */
let hour = sections[0];
/** @type {?} */
let minutes = sections[1];
/** @type {?} */
let amPM = sections[2];
/** @type {?} */
const format = this.timePicker.format;
/** @type {?} */
const prompt = this.timePicker.promptChar;
/** @type {?} */
const regExp = new RegExp(this.timePicker.promptChar, 'g');
if (format.indexOf('hh') !== -1 || format.indexOf('HH') !== -1 && hour.indexOf(prompt) !== -1) {
hour = hour === prompt + prompt ? '00' : hour.replace(regExp, '0');
}
if (format.indexOf('mm') !== -1 && minutes.indexOf(prompt) !== -1) {
minutes = minutes === prompt + prompt ? '00' : minutes.replace(regExp, '0');
}
if (format.indexOf('hh') === -1 && format.indexOf('HH') === -1) {
hour = hour.indexOf(prompt) !== -1 ? hour.replace(regExp, '') : hour;
/** @type {?} */
const hourVal = parseInt(hour, 10);
hour = !hourVal ? '0' : hourVal < 10 && hourVal !== 0 ? hour.replace('0', '') : hour;
}
if (format.indexOf('mm') === -1) {
minutes = minutes.indexOf(prompt) !== -1 ? minutes.replace(regExp, '') : minutes;
/** @type {?} */
const minutesVal = parseInt(minutes, 10);
minutes = !minutesVal ? '0' : minutesVal < 10 && minutesVal !== 0 ? minutes.replace('0', '') : minutes;
}
if (format.indexOf('tt') !== -1 && (amPM !== 'AM' || amPM !== 'PM')) {
amPM = amPM.indexOf('p') !== -1 || amPM.indexOf('P') !== -1 ? 'PM' : 'AM';
}
return amPM ? `${hour}:${minutes} ${amPM}` : `${hour}:${minutes}`;
}
}
TimeDisplayFormatPipe.decorators = [
{ type: Pipe, args: [{ name: 'displayFormat' },] }
];
/** @nocollapse */
TimeDisplayFormatPipe.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }
];
if (false) {
/**
* @type {?}
* @private
*/
TimeDisplayFormatPipe.prototype.timePicker;
}
/**
* Formats `IgxTimePickerComponent` display value according to the `format` property,
* when the input element gets focus.
*
*/
export class TimeInputFormatPipe {
/**
* @param {?} timePicker
*/
constructor(timePicker) {
this.timePicker = timePicker;
}
/**
* @param {?} value
* @return {?}
*/
transform(value) {
/** @type {?} */
const prompt = this.timePicker.promptChar;
/** @type {?} */
const regExp = new RegExp(prompt, 'g');
/** @type {?} */
let mask;
if (this.timePicker.cleared) {
this.timePicker.cleared = false;
mask = this.timePicker.parseMask(false);
}
else {
mask = this.timePicker.parseMask();
}
if (!value || value === mask) {
return mask;
}
/** @type {?} */
const sections = value.split(/[\s:]+/);
/** @type {?} */
let hour = sections[0].replace(regExp, '');
/** @type {?} */
let minutes = sections[1].replace(regExp, '');
/** @type {?} */
const amPM = sections[2];
/** @type {?} */
const leadZeroHour = (parseInt(hour, 10) < 10 && !hour.startsWith('0')) || hour === '0';
/** @type {?} */
const leadZeroMinutes = (parseInt(minutes, 10) < 10 && !minutes.startsWith('0')) || minutes === '0';
hour = leadZeroHour ? '0' + hour : hour;
minutes = leadZeroMinutes ? '0' + minutes : minutes;
return amPM ? `${hour}:${minutes} ${amPM}` : `${hour}:${minutes}`;
}
}
TimeInputFormatPipe.decorators = [
{ type: Pipe, args: [{ name: 'inputFormat' },] }
];
/** @nocollapse */
TimeInputFormatPipe.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }
];
if (false) {
/**
* @type {?}
* @private
*/
TimeInputFormatPipe.prototype.timePicker;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.pipes.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/time-picker/time-picker.pipes.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform, Inject} from '@angular/core';\nimport { IGX_TIME_PICKER_COMPONENT, IgxTimePickerBase } from './time-picker.common';\n\n\n/**\n * Formats `IgxTimePickerComponent` display value according to the `format` property,\n * when the input element loses focus.\n **/\n@Pipe({ name: 'displayFormat'})\nexport class TimeDisplayFormatPipe implements PipeTransform {\n\n     constructor(@Inject(IGX_TIME_PICKER_COMPONENT) private timePicker: IgxTimePickerBase) { }\n\n     transform(value: any): string {\n\n        const maskAmPM = this.timePicker.parseMask();\n        const mask = this.timePicker.parseMask(false);\n        if (!value || value === mask || value === maskAmPM) {\n            return '';\n        }\n\n        const sections = value.split(/[\\s:]+/);\n\n        let hour = sections[0];\n        let minutes = sections[1];\n        let amPM = sections[2];\n\n        const format = this.timePicker.format;\n        const prompt = this.timePicker.promptChar;\n        const regExp = new RegExp(this.timePicker.promptChar, 'g');\n\n        if (format.indexOf('hh') !== -1 || format.indexOf('HH') !== -1 && hour.indexOf(prompt) !== -1) {\n           hour = hour === prompt + prompt ? '00' : hour.replace(regExp, '0');\n        }\n\n        if (format.indexOf('mm') !== -1 && minutes.indexOf(prompt) !== -1) {\n           minutes = minutes === prompt + prompt ? '00' : minutes.replace(regExp, '0');\n        }\n\n        if (format.indexOf('hh') === -1 && format.indexOf('HH') === -1) {\n            hour = hour.indexOf(prompt) !== -1 ? hour.replace(regExp, '') : hour;\n            const hourVal = parseInt(hour, 10);\n            hour = !hourVal ? '0' : hourVal < 10 && hourVal !== 0 ? hour.replace('0', '') : hour;\n        }\n\n        if (format.indexOf('mm') === -1) {\n            minutes = minutes.indexOf(prompt) !== -1 ? minutes.replace(regExp, '') : minutes;\n            const minutesVal = parseInt(minutes, 10);\n            minutes = !minutesVal ? '0' : minutesVal < 10 && minutesVal !== 0 ? minutes.replace('0', '') : minutes;\n        }\n\n        if (format.indexOf('tt') !== -1 && (amPM !== 'AM' || amPM !== 'PM')) {\n           amPM = amPM.indexOf('p') !== -1 || amPM.indexOf('P') !== -1 ? 'PM' : 'AM';\n        }\n\n        return amPM ? `${hour}:${minutes} ${amPM}` : `${hour}:${minutes}`;\n    }\n}\n\n/**\n * Formats `IgxTimePickerComponent` display value according to the `format` property,\n * when the input element gets focus.\n **/\n@Pipe({ name: 'inputFormat' })\nexport class TimeInputFormatPipe implements PipeTransform {\n\n    constructor(@Inject(IGX_TIME_PICKER_COMPONENT) private timePicker: IgxTimePickerBase) { }\n\n    transform(value: any): string {\n        const prompt = this.timePicker.promptChar;\n        const regExp = new RegExp(prompt, 'g');\n\n        let mask: string;\n        if (this.timePicker.cleared) {\n            this.timePicker.cleared = false;\n            mask = this.timePicker.parseMask(false);\n        } else {\n            mask = this.timePicker.parseMask();\n        }\n\n        if (!value || value === mask) {\n            return mask;\n        }\n\n        const sections = value.split(/[\\s:]+/);\n\n        let hour = sections[0].replace(regExp, '');\n        let minutes = sections[1].replace(regExp, '');\n        const amPM = sections[2];\n\n        const leadZeroHour = (parseInt(hour, 10) < 10 && !hour.startsWith('0')) || hour === '0';\n        const leadZeroMinutes = (parseInt(minutes, 10) < 10 && !minutes.startsWith('0')) || minutes === '0';\n\n        hour = leadZeroHour ? '0' + hour : hour;\n        minutes = leadZeroMinutes ? '0' + minutes : minutes;\n\n        return amPM ? `${hour}:${minutes} ${amPM}` : `${hour}:${minutes}`;\n    }\n}\n"]}