Rocky_Mountain_Vending/.pnpm-store/v10/files/3d/9fcaf0a499c9c42b06edb9293a0e67f9628a93c517fc886f3fb4130d99034b9abc7376357f710fca4aec5e17b434f4a1683696213e9837532432b0010badcf
DMleadgen 46d973904b
Initial commit: Rocky Mountain Vending website
Next.js website for Rocky Mountain Vending company featuring:
- Product catalog with Stripe integration
- Service areas and parts pages
- Admin dashboard with Clerk authentication
- SEO optimized pages with JSON-LD structured data

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-12 16:22:15 -07:00

38 lines
1.4 KiB
Text

import { DayFlag, SelectionState, UI } from "../UI.js";
import type { ModifiersClassNames, ClassNames } from "../types/index.js";
/**
* Returns the class names for a day based on its modifiers.
*
* This function combines the base class name for the day with any class names
* associated with active modifiers.
*
* @param modifiers The modifiers applied to the day.
* @param classNames The base class names for the calendar elements.
* @param modifiersClassNames The class names associated with specific
* modifiers.
* @returns An array of class names for the day.
*/
export function getClassNamesForModifiers(
modifiers: Record<string, boolean>,
classNames: ClassNames,
modifiersClassNames: ModifiersClassNames = {}
): string[] {
const modifierClassNames = Object.entries(modifiers)
.filter(([, active]) => active === true)
.reduce(
(previousValue, [key]) => {
if (modifiersClassNames[key]) {
previousValue.push(modifiersClassNames[key as string]);
} else if (classNames[DayFlag[key as DayFlag]]) {
previousValue.push(classNames[DayFlag[key as DayFlag]]);
} else if (classNames[SelectionState[key as SelectionState]]) {
previousValue.push(classNames[SelectionState[key as SelectionState]]);
}
return previousValue;
},
[classNames[UI.Day]] as string[]
);
return modifierClassNames;
}