Files
mocoapp-browser-extension/src/js/components/Calendar/Day.js
2019-06-26 09:27:31 +02:00

37 lines
1.1 KiB
JavaScript

import React, { useCallback } from "react"
import PropTypes from "prop-types"
import Hours from "./Hours"
import { format, getDay } from "date-fns"
import deLocale from "date-fns/locale/de"
import cn from "classnames"
const Day = ({ date, hours, absence, active, onClick }) => {
const handleClick = useCallback(() => onClick(date), [date])
return (
<div
className={cn("moco-bx-calendar__day", `moco-bx-calendar__day--week-day-${getDay(date)}`, {
"moco-bx-calendar__day--active": active,
"moco-bx-calendar__day--filled": hours > 0,
"moco-bx-calendar__day--absence": absence,
})}
onClick={handleClick}
>
<span className="moco-bx-calendar__day-of-week">
{format(date, "dd", { locale: deLocale })}
</span>
<Hours hours={hours} absence={absence} active={active} />
</div>
)
}
Day.propTypes = {
date: PropTypes.instanceOf(Date).isRequired,
hours: PropTypes.number.isRequired,
absence: PropTypes.object,
active: PropTypes.bool.isRequired,
onClick: PropTypes.func.isRequired,
}
export default Day