@qeydar/datepicker
Version:
A comprehensive Date and Time Picker for Angular with Jalali calendar support
238 lines • 25.9 kB
JavaScript
import { Injectable } from '@angular/core';
import * as i0 from "@angular/core";
export class CalendarUtilsService {
/**
* Generate days grid for calendar view
*/
generateDaysGrid(currentDate, dateAdapter) {
const firstDayOfMonth = dateAdapter.startOfMonth(currentDate);
const startDate = dateAdapter.startOfWeek(firstDayOfMonth);
return Array.from({ length: 42 }, (_, i) => dateAdapter.addDays(startDate, i));
}
/**
* Generate month list (1-12)
*/
generateMonthList() {
return Array.from({ length: 12 }, (_, i) => i + 1);
}
/**
* Generate year list around a specific year
*/
generateYearList(centerYear, length = 15) {
const start = centerYear - Math.floor(length / 2);
return Array.from({ length }, (_, i) => start + i);
}
/**
* Generate year ranges for year selector
*/
generateYearRanges(length = 15, dateAdapter) {
const yearCount = 15;
const currentYear = dateAdapter.getYear(new Date);
const startYear = currentYear - Math.floor(yearCount / 2) - (yearCount * Math.floor(length / 2));
const yearRanges = [];
for (let i = 0; i < length; i++) {
const start = startYear + i * yearCount;
yearRanges.push({ start, end: start + 14 });
}
return yearRanges;
}
/**
* Get week day names
*/
getWeekDays(dateAdapter) {
return dateAdapter.getDayOfWeekNames('short');
}
/**
* Get month names
*/
getMonthNames(dateAdapter, format = 'long') {
return dateAdapter.getMonthNames(format);
}
/**
* Get month name by number
*/
getMonthName(month, dateAdapter) {
return dateAdapter.getMonthNames('long')[month - 1];
}
/**
* Get current month name
*/
getCurrentMonthName(currentDate, dateAdapter) {
return dateAdapter.getMonthNames('long')[dateAdapter.getMonth(currentDate)];
}
/**
* Get current year
*/
getCurrentYear(currentDate, dateAdapter) {
return dateAdapter.getYear(currentDate);
}
/**
* Navigate to previous month
*/
navigateToPrevMonth(currentDate, dateAdapter) {
return dateAdapter.addMonths(currentDate, -1);
}
/**
* Navigate to next month
*/
navigateToNextMonth(currentDate, dateAdapter) {
return dateAdapter.addMonths(currentDate, 1);
}
/**
* Navigate to previous year
*/
navigateToPrevYear(currentDate, dateAdapter) {
return dateAdapter.addYears(currentDate, -1);
}
/**
* Navigate to next year
*/
navigateToNextYear(currentDate, dateAdapter) {
return dateAdapter.addYears(currentDate, 1);
}
/**
* Navigate to previous year range
*/
navigateToPrevYearRange(yearList) {
const yearStart = yearList[0] - 15;
return Array.from({ length: 15 }, (_, i) => yearStart + i);
}
/**
* Navigate to next year range
*/
navigateToNextYearRange(yearList) {
const yearStart = yearList[14] + 1;
return Array.from({ length: 15 }, (_, i) => yearStart + i);
}
/**
* Create date for month selection
*/
createDateForMonth(year, month, dateAdapter) {
return dateAdapter.createDate(year, month - 1, 1);
}
/**
* Create date for year selection
*/
createDateForYear(year, currentDate, dateAdapter) {
return dateAdapter.createDate(year, dateAdapter.getMonth(currentDate), 1);
}
/**
* Set year for existing date
*/
setYearForDate(date, year, dateAdapter) {
return dateAdapter.setYear(date, year);
}
/**
* Determine view mode based on datepicker mode
*/
determineViewMode(mode) {
switch (mode) {
case 'day':
return 'days';
case 'month':
return 'months';
case 'year':
return 'years';
default:
return 'days';
}
}
/**
* Generate default periods for range picker
*/
generateDefaultPeriods(today, lang) {
return [
{
label: lang.lastDay,
value: [this.addDays(today, -1), today]
},
{
label: lang.lastWeek,
value: [this.addDays(today, -7), today],
arrow: true
},
{
label: lang.lastMonth,
value: [this.addMonths(today, -1), today]
},
{
label: lang.custom,
value: 'custom'
}
];
}
/**
* Helper method to add days (used in generateDefaultPeriods)
*/
addDays(date, days) {
const result = new Date(date);
result.setDate(result.getDate() + days);
return result;
}
/**
* Helper method to add months (used in generateDefaultPeriods)
*/
addMonths(date, months) {
const result = new Date(date);
result.setMonth(result.getMonth() + months);
return result;
}
/**
* Check if two dates are in the same month
*/
isSameMonth(date1, date2, dateAdapter) {
return dateAdapter.isSameMonth(date1, date2);
}
/**
* Check if date is today
*/
isToday(date, dateAdapter) {
return dateAdapter.isSameDay(date, dateAdapter.today());
}
/**
* Check if month is active
*/
isActiveMonth(month, currentDate, dateAdapter) {
return dateAdapter.getMonth(currentDate) === month - 1;
}
/**
* Check if year is active
*/
isActiveYear(year, currentDate, dateAdapter) {
return year === dateAdapter.getYear(currentDate);
}
/**
* Check if year range is active
*/
isActiveYearRange(startYear, yearList) {
return yearList?.includes(startYear);
}
/**
* Get scroll item ID for different view modes
*/
getScrollItemId(viewMode, date, dateAdapter, yearRanges) {
if (!date)
return null;
switch (viewMode) {
case 'days':
return dateAdapter.getMonth(date) + 1;
case 'months':
return dateAdapter.getYear(date);
case 'years':
const currentYear = dateAdapter.getYear(date);
const currentRange = yearRanges?.find(range => range.start <= currentYear && range.end >= currentYear);
return currentRange?.start || null;
default:
return null;
}
}
}
CalendarUtilsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CalendarUtilsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
CalendarUtilsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CalendarUtilsService, providedIn: 'root' });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CalendarUtilsService, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-utils.service.js","sourceRoot":"","sources":["../../../../../projects/qeydar-datepicker/src/date-picker-popup/services/calendar-utils.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { DateAdapter } from '../../date-adapter';\r\nimport { CustomLabels, YearRange } from '../../utils/models';\r\nimport { DatepickerMode } from '../../utils/types';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class CalendarUtilsService {\r\n\r\n  /**\r\n   * Generate days grid for calendar view\r\n   */\r\n  generateDaysGrid(currentDate: Date, dateAdapter: DateAdapter<Date>): Date[] {\r\n    const firstDayOfMonth = dateAdapter.startOfMonth(currentDate);\r\n    const startDate = dateAdapter.startOfWeek(firstDayOfMonth);\r\n    return Array.from({ length: 42 }, (_, i) => dateAdapter.addDays(startDate, i));\r\n  }\r\n\r\n  /**\r\n   * Generate month list (1-12)\r\n   */\r\n  generateMonthList(): number[] {\r\n    return Array.from({ length: 12 }, (_, i) => i + 1);\r\n  }\r\n\r\n  /**\r\n   * Generate year list around a specific year\r\n   */\r\n  generateYearList(centerYear: number, length: number = 15): number[] {\r\n    const start = centerYear - Math.floor(length / 2);\r\n    return Array.from({ length }, (_, i) => start + i);\r\n  }\r\n\r\n  /**\r\n   * Generate year ranges for year selector\r\n   */\r\n  generateYearRanges(length: number = 15,dateAdapter: DateAdapter<Date>): YearRange[] {\r\n    const yearCount = 15;\r\n    const currentYear = dateAdapter.getYear(new Date);\r\n    const startYear = currentYear - Math.floor(yearCount/2) - (yearCount * Math.floor(length/2));\r\n    const yearRanges: YearRange[] = [];\r\n    \r\n    for (let i = 0; i < length; i++) {\r\n      const start = startYear + i * yearCount;\r\n      yearRanges.push({ start, end: start + 14 });\r\n    }\r\n    \r\n    return yearRanges;\r\n  }\r\n\r\n  /**\r\n   * Get week day names\r\n   */\r\n  getWeekDays(dateAdapter: DateAdapter<Date>): string[] {\r\n    return dateAdapter.getDayOfWeekNames('short');\r\n  }\r\n\r\n  /**\r\n   * Get month names\r\n   */\r\n  getMonthNames(dateAdapter: DateAdapter<Date>, format: 'long' | 'short' = 'long'): string[] {\r\n    return dateAdapter.getMonthNames(format);\r\n  }\r\n\r\n  /**\r\n   * Get month name by number\r\n   */\r\n  getMonthName(month: number, dateAdapter: DateAdapter<Date>): string {\r\n    return dateAdapter.getMonthNames('long')[month - 1];\r\n  }\r\n\r\n  /**\r\n   * Get current month name\r\n   */\r\n  getCurrentMonthName(currentDate: Date, dateAdapter: DateAdapter<Date>): string {\r\n    return dateAdapter.getMonthNames('long')[dateAdapter.getMonth(currentDate)];\r\n  }\r\n\r\n  /**\r\n   * Get current year\r\n   */\r\n  getCurrentYear(currentDate: Date, dateAdapter: DateAdapter<Date>): number {\r\n    return dateAdapter.getYear(currentDate);\r\n  }\r\n\r\n  /**\r\n   * Navigate to previous month\r\n   */\r\n  navigateToPrevMonth(currentDate: Date, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.addMonths(currentDate, -1);\r\n  }\r\n\r\n  /**\r\n   * Navigate to next month\r\n   */\r\n  navigateToNextMonth(currentDate: Date, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.addMonths(currentDate, 1);\r\n  }\r\n\r\n  /**\r\n   * Navigate to previous year\r\n   */\r\n  navigateToPrevYear(currentDate: Date, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.addYears(currentDate, -1);\r\n  }\r\n\r\n  /**\r\n   * Navigate to next year\r\n   */\r\n  navigateToNextYear(currentDate: Date, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.addYears(currentDate, 1);\r\n  }\r\n\r\n  /**\r\n   * Navigate to previous year range\r\n   */\r\n  navigateToPrevYearRange(yearList: number[]): number[] {\r\n    const yearStart = yearList[0] - 15;\r\n    return Array.from({ length: 15 }, (_, i) => yearStart + i);\r\n  }\r\n\r\n  /**\r\n   * Navigate to next year range\r\n   */\r\n  navigateToNextYearRange(yearList: number[]): number[] {\r\n    const yearStart = yearList[14] + 1;\r\n    return Array.from({ length: 15 }, (_, i) => yearStart + i);\r\n  }\r\n\r\n  /**\r\n   * Create date for month selection\r\n   */\r\n  createDateForMonth(year: number, month: number, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.createDate(year, month - 1, 1);\r\n  }\r\n\r\n  /**\r\n   * Create date for year selection\r\n   */\r\n  createDateForYear(year: number, currentDate: Date, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.createDate(\r\n      year, \r\n      dateAdapter.getMonth(currentDate), \r\n      1\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Set year for existing date\r\n   */\r\n  setYearForDate(date: Date, year: number, dateAdapter: DateAdapter<Date>): Date {\r\n    return dateAdapter.setYear(date, year);\r\n  }\r\n\r\n  /**\r\n   * Determine view mode based on datepicker mode\r\n   */\r\n  determineViewMode(mode: DatepickerMode): 'days' | 'months' | 'years' {\r\n    switch (mode) {\r\n      case 'day':\r\n        return 'days';\r\n      case 'month':\r\n        return 'months';\r\n      case 'year':\r\n        return 'years';\r\n      default:\r\n        return 'days';\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Generate default periods for range picker\r\n   */\r\n  generateDefaultPeriods(today: Date, lang: any): CustomLabels[] {\r\n    return [\r\n      { \r\n        label: lang.lastDay, \r\n        value: [this.addDays(today, -1), today] \r\n      },\r\n      { \r\n        label: lang.lastWeek, \r\n        value: [this.addDays(today, -7), today], \r\n        arrow: true \r\n      },\r\n      { \r\n        label: lang.lastMonth, \r\n        value: [this.addMonths(today, -1), today] \r\n      },\r\n      { \r\n        label: lang.custom, \r\n        value: 'custom' \r\n      }\r\n    ];\r\n  }\r\n\r\n  /**\r\n   * Helper method to add days (used in generateDefaultPeriods)\r\n   */\r\n  private addDays(date: Date, days: number): Date {\r\n    const result = new Date(date);\r\n    result.setDate(result.getDate() + days);\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Helper method to add months (used in generateDefaultPeriods)\r\n   */\r\n  private addMonths(date: Date, months: number): Date {\r\n    const result = new Date(date);\r\n    result.setMonth(result.getMonth() + months);\r\n    return result;\r\n  }\r\n\r\n  /**\r\n   * Check if two dates are in the same month\r\n   */\r\n  isSameMonth(date1: Date, date2: Date, dateAdapter: DateAdapter<Date>): boolean {\r\n    return dateAdapter.isSameMonth(date1, date2);\r\n  }\r\n\r\n  /**\r\n   * Check if date is today\r\n   */\r\n  isToday(date: Date, dateAdapter: DateAdapter<Date>): boolean {\r\n    return dateAdapter.isSameDay(date, dateAdapter.today());\r\n  }\r\n\r\n  /**\r\n   * Check if month is active\r\n   */\r\n  isActiveMonth(month: number, currentDate: Date, dateAdapter: DateAdapter<Date>): boolean {\r\n    return dateAdapter.getMonth(currentDate) === month - 1;\r\n  }\r\n\r\n  /**\r\n   * Check if year is active\r\n   */\r\n  isActiveYear(year: number, currentDate: Date, dateAdapter: DateAdapter<Date>): boolean {\r\n    return year === dateAdapter.getYear(currentDate);\r\n  }\r\n\r\n  /**\r\n   * Check if year range is active\r\n   */\r\n  isActiveYearRange(startYear: number, yearList: number[]): boolean {\r\n    return yearList?.includes(startYear);\r\n  }\r\n\r\n  /**\r\n   * Get scroll item ID for different view modes\r\n   */\r\n  getScrollItemId(viewMode: 'days' | 'months' | 'years', date: Date, dateAdapter: DateAdapter<Date>, yearRanges?: YearRange[]): number | null {\r\n    if (!date) return null;\r\n\r\n    switch (viewMode) {\r\n      case 'days':\r\n        return dateAdapter.getMonth(date) + 1;\r\n      case 'months':\r\n        return dateAdapter.getYear(date);\r\n      case 'years':\r\n        const currentYear = dateAdapter.getYear(date);\r\n        const currentRange = yearRanges?.find(range => \r\n          range.start <= currentYear && range.end >= currentYear\r\n        );\r\n        return currentRange?.start || null;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n}\r\n"]}