Move general functions methods to the date util.
This commit is contained in:
parent
a6971d6c84
commit
7704fc1223
1 changed files with 124 additions and 1 deletions
|
@ -64,7 +64,130 @@ window.App.Utils.Date = (function () {
|
||||||
return dateMoment.format(format);
|
return dateMoment.format(format);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the Id of a Weekday using the US week format and day names (Sunday=0) as used in the JS code of the
|
||||||
|
* application, case insensitive, short and long names supported.
|
||||||
|
*
|
||||||
|
* @param {String} weekDayName The weekday name among Sunday, Monday, Tuesday, Wednesday, Thursday, Friday,
|
||||||
|
* Saturday.
|
||||||
|
|
||||||
|
* @return {Number} Returns the ID of the weekday.
|
||||||
|
*/
|
||||||
|
function getWeekDayId(weekDayName) {
|
||||||
|
let result;
|
||||||
|
|
||||||
|
switch (weekDayName.toLowerCase()) {
|
||||||
|
case 'sunday':
|
||||||
|
case 'sun':
|
||||||
|
result = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'monday':
|
||||||
|
case 'mon':
|
||||||
|
result = 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'tuesday':
|
||||||
|
case 'tue':
|
||||||
|
result = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'wednesday':
|
||||||
|
case 'wed':
|
||||||
|
result = 3;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'thursday':
|
||||||
|
case 'thu':
|
||||||
|
result = 4;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'friday':
|
||||||
|
case 'fri':
|
||||||
|
result = 5;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'saturday':
|
||||||
|
case 'sat':
|
||||||
|
result = 6;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new Error(`Invalid weekday name provided: ${weekDayName}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sort a dictionary where keys are weekdays
|
||||||
|
*
|
||||||
|
* @param {Object} weekDictionary A dictionary with weekdays as keys.
|
||||||
|
* @param {Number} startDayId Id of the first day to start sorting (From 0 for sunday to 6 for saturday).
|
||||||
|
|
||||||
|
* @return {Object} Returns a sorted dictionary
|
||||||
|
*/
|
||||||
|
function sortWeekDictionary(weekDictionary, startDayId) {
|
||||||
|
const sortedWeekDictionary = {};
|
||||||
|
|
||||||
|
for (let i = startDayId; i < startDayId + 7; i++) {
|
||||||
|
const weekdayName = getWeekdayName(i % 7);
|
||||||
|
sortedWeekDictionary[weekdayName] = weekDictionary[weekdayName];
|
||||||
|
}
|
||||||
|
|
||||||
|
return sortedWeekDictionary;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name in lowercase of a Weekday using its Id.
|
||||||
|
*
|
||||||
|
* @param {Number} weekDayId The Id (From 0 for sunday to 6 for saturday).
|
||||||
|
|
||||||
|
* @return {String} Returns the name of the weekday.
|
||||||
|
*/
|
||||||
|
function getWeekdayName(weekDayId) {
|
||||||
|
let result;
|
||||||
|
|
||||||
|
switch (weekDayId) {
|
||||||
|
case 0:
|
||||||
|
result = 'sunday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1:
|
||||||
|
result = 'monday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 2:
|
||||||
|
result = 'tuesday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 3:
|
||||||
|
result = 'wednesday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 4:
|
||||||
|
result = 'thursday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 5:
|
||||||
|
result = 'friday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 6:
|
||||||
|
result = 'saturday';
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw new Error(`Invalid weekday Id provided: ${weekDayId}`);
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
format
|
format,
|
||||||
|
getWeekDayId,
|
||||||
|
sortWeekDictionary,
|
||||||
|
getWeekdayName
|
||||||
};
|
};
|
||||||
})();
|
})();
|
||||||
|
|
Loading…
Reference in a new issue