Skip to content

Commit

Permalink
Merge pull request #157 from uvarov-frontend/feature/add_self_to_actions
Browse files Browse the repository at this point in the history
Add self to actions
  • Loading branch information
uvarov-frontend authored Dec 3, 2023
2 parents a73147c + 0a45d17 commit f876318
Show file tree
Hide file tree
Showing 13 changed files with 95 additions and 87 deletions.
26 changes: 10 additions & 16 deletions demo/pages/input/main.ts
Original file line number Diff line number Diff line change
@@ -1,26 +1,20 @@
// import { IOptions } from '@package/types';
// import VanillaCalendar from '@/package/build/vanilla-calendar.min';

// import '@/package/build/vanilla-calendar.min.css';
// import '@/package/build/themes/light.min.css';
// import '@/package/build/themes/dark.min.css';

import { IOptions } from '@package/types';
import VanillaCalendar from '@src/vanilla-calendar';

import '@src/styles/vanilla-calendar.css';
import '@src/styles/themes/light.css';
import '@src/styles/themes/dark.css';

const configInput: IOptions = {
input: true,
actions: {
changeToInput(e, calendar, dates) {
if (!dates) return;
if (dates[0]) {
calendar.HTMLInputElement.value = dates[0];
changeToInput(e, calendar, self) {
if (!self.selectedDates || !self.HTMLInputElement) return;
if (self.selectedDates[0]) {
self.HTMLInputElement.value = self.selectedDates[0];
} else {
calendar.HTMLInputElement.value = '';
self.HTMLInputElement.value = '';
}
calendar.hide();
},
Expand All @@ -30,12 +24,12 @@ const configInput: IOptions = {
const configDiv: IOptions = {
input: true,
actions: {
changeToInput(e, calendar, dates) {
if (!dates) return;
if (dates[0]) {
calendar.HTMLInputElement.innerHTML = dates[0];
changeToInput(e, calendar, self) {
if (!self.selectedDates || !self.HTMLInputElement) return;
if (self.selectedDates[0]) {
self.HTMLInputElement.innerHTML = self.selectedDates[0];
} else {
calendar.HTMLInputElement.innerHTML = '';
self.HTMLInputElement.innerHTML = '';
}
calendar.hide();
},
Expand Down
6 changes: 0 additions & 6 deletions demo/pages/multiple/main.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,10 @@
// import { IOptions } from '@package/types';
// import VanillaCalendar from '@/package/build/vanilla-calendar.min';

// import '@/package/build/vanilla-calendar.min.css';
// import '@/package/build/themes/light.min.css';
// import '@/package/build/themes/dark.min.css';

import { IOptions } from '@package/types';
import VanillaCalendar from '@src/vanilla-calendar';

import '@src/styles/vanilla-calendar.css';
import '@src/styles/themes/light.css';
import '@src/styles/themes/dark.css';

const config: IOptions = {
type: 'multiple',
Expand Down
18 changes: 9 additions & 9 deletions package/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as T from './types';

export type Options = T.IOptions;
export type TypesCalendar = T.TypesCalendar;
export type Date = T.IDate;
export type Dates = T.IDates;
export type Range = T.IRange;
export type Selection = T.ISelection;
export type Selected = T.ISelected;
Expand All @@ -13,14 +13,14 @@ export type Popups = T.IPopups;
export type CSSClasses = T.ICSSClasses;
export type DOMTemplates = T.IDOMTemplates;

export default class VanillaCalendar {
export default class VanillaCalendar implements T.IVanillaCalendar {
constructor(selector: HTMLElement | string, options?: Partial<T.IOptions>);

input: boolean;
type: T.TypesCalendar;
months: number;
jumpMonths: number;
date: T.IDate;
date: T.IDates;
settings: {
lang: string;
iso8601: boolean;
Expand Down Expand Up @@ -50,12 +50,12 @@ export default class VanillaCalendar {
readonly selectedDates: T.FormatDateString[];
readonly selectedHolidays: T.FormatDateString[];
readonly selectedMonth: number;
readonly selectedYea: number;
readonly selectedHours: string;
readonly selectedMinutes: string;
readonly selectedKeeping: string;
readonly selectedTime: string;
readonly userTime: boolean;
readonly selectedYear: number;
readonly selectedHours?: string;
readonly selectedMinutes?: string;
readonly selectedKeeping?: string;
readonly selectedTime?: string;
readonly userTime?: boolean;
readonly currentType: T.TypesCalendar;
readonly correctMonths: number;
readonly viewYear: number;
Expand Down
2 changes: 1 addition & 1 deletion package/src/scripts/default.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ export default class DefaultOptionsCalendar {
type: T.TypesCalendar = 'default';
months = 2;
jumpMonths = 1;
date: T.IDate = {
date: T.IDates = {
min: '1970-01-01',
max: '2470-12-31',
today: new Date(),
Expand Down
2 changes: 1 addition & 1 deletion package/src/scripts/handles/handleClickArrow.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const handleClickArrow = (self: VanillaCalendar, event: MouseEvent) => {
createYears(self, event.target as HTMLElement);
}

if (self.actions.clickArrow) self.actions.clickArrow(event, self.selectedYear as number, self.selectedMonth as number);
if (self.actions.clickArrow) self.actions.clickArrow(event, self);
};

export default handleClickArrow;
8 changes: 2 additions & 6 deletions package/src/scripts/handles/handleClickDay.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,18 +20,14 @@ const handleClickDay = (self: VanillaCalendar, event: MouseEvent) => {
daySelectionActions[self.settings.selection.day]();
self.selectedDates?.sort((a, b) => +new Date(a) - +new Date(b));

if (self.actions.clickDay) self.actions.clickDay(event, self.selectedDates);
if (self.actions.clickDay) self.actions.clickDay(event, self);

const isInitAsInput = self.input && self.HTMLInputElement && self.HTMLElement;
if (isInitAsInput && self.actions.changeToInput) {
self.actions.changeToInput(
event,
actionsInput(self),
self.selectedDates,
self.selectedTime,
self.selectedHours,
self.selectedMinutes,
self.selectedKeeping,
self,
);
}

Expand Down
4 changes: 2 additions & 2 deletions package/src/scripts/handles/handleClickMonthOrYear.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,8 @@ type HandleCSSClasses = {

const handleItemClick = (self: VanillaCalendar, event: MouseEvent, type: HandleType, CSSClasses: HandleCSSClasses, itemEl: HTMLElement) => {
const actionByType = {
year: () => self.actions.clickYear?.(event, self.selectedYear as number, self.selectedMonth as number),
month: () => self.actions.clickMonth?.(event, self.selectedMonth as number, self.selectedYear as number),
year: () => self.actions.clickYear?.(event, self),
month: () => self.actions.clickMonth?.(event, self),
};
const selectByType = {
year: () => {
Expand Down
2 changes: 1 addition & 1 deletion package/src/scripts/handles/handleClickWeekNumber.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ const handleClickWeekNumber = (self: VanillaCalendar, event: MouseEvent) => {
const yearWeek = Number(weekNumberEl.dataset.calendarYearWeek);
const daysOfThisWeek = [...daysToWeeks].filter((day) => Number((day as HTMLElement).dataset.calendarWeekNumber) === weekNumberValue);

self.actions.clickWeekNumber(event, weekNumberValue, daysOfThisWeek, yearWeek);
self.actions.clickWeekNumber(event, weekNumberValue, daysOfThisWeek, yearWeek, self);
};

export default handleClickWeekNumber;
7 changes: 3 additions & 4 deletions package/src/scripts/helpers/actionsInput.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,13 @@ import VanillaCalendar from '@src/vanilla-calendar';
const actionsInput = (self: VanillaCalendar) => ({
hide() {
self.HTMLElement.classList.add(self.CSSClasses.calendarHidden);
if (self.actions.hideCalendar) self.actions.hideCalendar(self.HTMLInputElement as HTMLInputElement, self.HTMLElement);
if (self.actions.hideCalendar) self.actions.hideCalendar(self);
},
show() {
self.HTMLElement.classList.remove(self.CSSClasses.calendarHidden);
if (self.actions.showCalendar) self.actions.showCalendar(self.HTMLInputElement as HTMLInputElement, self.HTMLElement);
if (self.actions.showCalendar) self.actions.showCalendar(self);
},
HTMLInputElement: self.HTMLInputElement as HTMLInputElement,
HTMLElement: self.HTMLElement,
self,
});

export default actionsInput;
24 changes: 3 additions & 21 deletions package/src/scripts/methods/changeTime.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,27 +25,9 @@ const setTime = (self: VanillaCalendar, e: Event, value: string, type: TypeTime)

self.selectedTime = `${self.selectedHours}:${self.selectedMinutes}${self.selectedKeeping ? ` ${self.selectedKeeping}` : ''}`;

if (self.actions.changeTime) {
self.actions.changeTime(
e,
self.selectedTime,
self.selectedHours,
self.selectedMinutes,
self.selectedKeeping,
);
}

if (self.input && self.HTMLInputElement && self.actions.changeToInput) {
self.actions.changeToInput(
e,
actionsInput(self),
self.selectedDates,
self.selectedTime,
self.selectedHours,
self.selectedMinutes,
self.selectedKeeping,
);
}
if (self.actions.changeTime) self.actions.changeTime(e, self);

if (self.input && self.HTMLInputElement && self.actions.changeToInput) self.actions.changeToInput(e, actionsInput(self), self);
};

const changeRange = (self: VanillaCalendar, range: HTMLInputElement, input: HTMLInputElement, btnKeepingTime: HTMLButtonElement | null, type: TypeTime, max: number) => {
Expand Down
2 changes: 1 addition & 1 deletion package/src/scripts/methods/createDays.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ const createDay = (
setDayModifier(self, year, dayEl, dayBtnEl, dayWeekID, date, otherMonth);

daysEl.append(dayEl);
if (self.actions.getDays) self.actions.getDays(day, date, dayEl, dayBtnEl);
if (self.actions.getDays) self.actions.getDays(day, date, dayEl, dayBtnEl, self);
};

const prevMonth = (self: VanillaCalendar, daysEl: HTMLElement, selectedYear: number, selectedMonth: number, firstDayWeek: number) => {
Expand Down
2 changes: 1 addition & 1 deletion package/src/vanilla-calendar.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import init from '@scripts/init';
import destroy from '@scripts/destroy';
import messages from '@scripts/helpers/getMessages';

export default class VanillaCalendar extends DefaultOptionsCalendar {
export default class VanillaCalendar extends DefaultOptionsCalendar implements T.IVanillaCalendar {
constructor(selector: HTMLElement | string, options?: Partial<T.IOptions>) {
super();

Expand Down
79 changes: 61 additions & 18 deletions package/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ export type FormatDateString = `${number}-${MM}-${DD}`;

export type TypesCalendar = 'default' | 'multiple' | 'month' | 'year';

export interface IDate {
export interface IDates {
min: FormatDateString;
max: FormatDateString;
today: Date;
Expand Down Expand Up @@ -67,29 +67,23 @@ export interface ILocale {
}

export interface IActions {
clickDay: ((e: MouseEvent, dates: FormatDateString[] | undefined) => void) | null;
clickWeekNumber: ((e: MouseEvent, number: number, days: HTMLElement[], year: number) => void) | null;
clickMonth: ((e: MouseEvent, month: number, year: number) => void) | null;
clickYear: ((e: MouseEvent, year: number, month: number) => void) | null;
clickArrow: ((e: MouseEvent, year: number, month: number) => void) | null;
changeTime: ((e: Event, time: string, hours: string, minutes: string, keeping: string) => void) | null;
clickDay: ((e: MouseEvent, self: IVanillaCalendar) => void) | null;
clickWeekNumber: ((e: MouseEvent, number: number, days: HTMLElement[], year: number, self: IVanillaCalendar) => void) | null;
clickMonth: ((e: MouseEvent, self: IVanillaCalendar) => void) | null;
clickYear: ((e: MouseEvent, self: IVanillaCalendar) => void) | null;
clickArrow: ((e: MouseEvent, self: IVanillaCalendar) => void) | null;
changeTime: ((e: Event, self: IVanillaCalendar) => void) | null;
changeToInput: ((
e: Event,
calendar: {
hide(): void;
show(): void;
HTMLInputElement: HTMLInputElement;
HTMLElement: HTMLElement;
},
dates?: FormatDateString[],
time?: string,
hours?: string,
minutes?: string,
keeping?: string
self: IVanillaCalendar,
) => void) | null;
getDays: ((day: number, date: FormatDateString, HTMLElement: HTMLElement, HTMLButtonElement: HTMLButtonElement) => void) | null;
hideCalendar: ((HTMLInputElement: HTMLInputElement, HTMLElement: HTMLElement) => void) | null;
showCalendar: ((HTMLInputElement: HTMLInputElement, HTMLElement: HTMLElement) => void) | null;
getDays: ((day: number, date: FormatDateString, HTMLElement: HTMLElement, HTMLButtonElement: HTMLButtonElement, self: IVanillaCalendar) => void) | null;
hideCalendar: ((self: IVanillaCalendar) => void) | null;
showCalendar: ((self: IVanillaCalendar) => void) | null;
}

export type IPopup = {
Expand Down Expand Up @@ -185,7 +179,7 @@ export interface IOptions {
type?: TypesCalendar;
months?: number;
jumpMonths?: number;
date?: Partial<IDate>;
date?: Partial<IDates>;
settings?: Partial<{
lang: string;
iso8601: boolean;
Expand All @@ -200,3 +194,52 @@ export interface IOptions {
CSSClasses?: Partial<ICSSClasses>;
DOMTemplates?: Partial<IDOMTemplates>;
}

export interface IVanillaCalendar {
input: boolean;
type: TypesCalendar;
months: number;
jumpMonths: number;
date: IDates;
settings: {
lang: string;
iso8601: boolean;
range: IRange;
selection: ISelection;
selected: ISelected;
visibility: IVisibility;
};
locale: ILocale;
actions: IActions;
popups: IPopups;
CSSClasses: ICSSClasses;
DOMTemplates: IDOMTemplates;

reset: () => void;
update: () => void;
init: () => void;
destroy: () => void;

readonly HTMLElement: HTMLElement;
readonly HTMLOriginalElement: HTMLElement;
readonly HTMLInputElement?: HTMLInputElement;
readonly rangeMin: FormatDateString;
readonly rangeMax: FormatDateString;
readonly rangeDisabled: FormatDateString[];
readonly rangeEnabled: FormatDateString[];
readonly selectedDates: FormatDateString[];
readonly selectedHolidays: FormatDateString[];
readonly selectedMonth: number;
readonly selectedYear: number;
readonly selectedHours?: string;
readonly selectedMinutes?: string;
readonly selectedKeeping?: string;
readonly selectedTime?: string;
readonly userTime?: boolean;
readonly currentType: TypesCalendar;
readonly correctMonths: number;
readonly viewYear: number;
readonly dateMin: Date;
readonly dateMax: Date;
readonly isInit: boolean;
}

0 comments on commit f876318

Please sign in to comment.