igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
153 lines • 16.1 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.
*
*/
var TimeDisplayFormatPipe = /** @class */ (function () {
function TimeDisplayFormatPipe(timePicker) {
this.timePicker = timePicker;
}
/**
* @param {?} value
* @return {?}
*/
TimeDisplayFormatPipe.prototype.transform = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var maskAmPM = this.timePicker.parseMask();
/** @type {?} */
var mask = this.timePicker.parseMask(false);
if (!value || value === mask || value === maskAmPM) {
return '';
}
/** @type {?} */
var sections = value.split(/[\s:]+/);
/** @type {?} */
var hour = sections[0];
/** @type {?} */
var minutes = sections[1];
/** @type {?} */
var amPM = sections[2];
/** @type {?} */
var format = this.timePicker.format;
/** @type {?} */
var prompt = this.timePicker.promptChar;
/** @type {?} */
var 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 {?} */
var 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 {?} */
var 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 = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }
]; };
return TimeDisplayFormatPipe;
}());
export { TimeDisplayFormatPipe };
if (false) {
/**
* @type {?}
* @private
*/
TimeDisplayFormatPipe.prototype.timePicker;
}
/**
* Formats `IgxTimePickerComponent` display value according to the `format` property,
* when the input element gets focus.
*
*/
var TimeInputFormatPipe = /** @class */ (function () {
function TimeInputFormatPipe(timePicker) {
this.timePicker = timePicker;
}
/**
* @param {?} value
* @return {?}
*/
TimeInputFormatPipe.prototype.transform = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var prompt = this.timePicker.promptChar;
/** @type {?} */
var regExp = new RegExp(prompt, 'g');
/** @type {?} */
var 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 {?} */
var sections = value.split(/[\s:]+/);
/** @type {?} */
var hour = sections[0].replace(regExp, '');
/** @type {?} */
var minutes = sections[1].replace(regExp, '');
/** @type {?} */
var amPM = sections[2];
/** @type {?} */
var leadZeroHour = (parseInt(hour, 10) < 10 && !hour.startsWith('0')) || hour === '0';
/** @type {?} */
var 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 = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }
]; };
return TimeInputFormatPipe;
}());
export { TimeInputFormatPipe };
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"]}