2023-05-20 12:00:15 +00:00
|
|
|
import { FC } from "react";
|
2023-08-11 10:29:13 +00:00
|
|
|
|
|
|
|
// hooks
|
2023-05-20 12:00:15 +00:00
|
|
|
import { useChart } from "../hooks";
|
2023-08-11 10:29:13 +00:00
|
|
|
// types
|
|
|
|
import { IMonthBlock } from "../views";
|
2023-05-20 12:00:15 +00:00
|
|
|
|
|
|
|
export const MonthChartView: FC<any> = () => {
|
2023-08-11 10:29:13 +00:00
|
|
|
const { currentViewData, renderView } = useChart();
|
|
|
|
|
|
|
|
const monthBlocks: IMonthBlock[] = renderView;
|
2023-05-20 12:00:15 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
2024-01-29 08:17:56 +00:00
|
|
|
<div className="absolute flex h-full flex-grow divide-x divide-neutral-border-subtle">
|
2023-08-11 10:29:13 +00:00
|
|
|
{monthBlocks &&
|
|
|
|
monthBlocks.length > 0 &&
|
|
|
|
monthBlocks.map((block, _idxRoot) => (
|
|
|
|
<div key={`month-${block?.month}-${block?.year}`} className="relative flex flex-col">
|
2023-08-28 07:55:47 +00:00
|
|
|
<div className="h-[60px] w-full">
|
|
|
|
<div className="relative h-[30px]">
|
|
|
|
<div className="sticky left-0 inline-flex whitespace-nowrap px-3 py-2 text-xs font-medium capitalize">
|
|
|
|
{block?.title}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2023-12-10 10:18:10 +00:00
|
|
|
<div className="flex h-[30px] w-full">
|
2023-08-28 07:55:47 +00:00
|
|
|
{block?.children &&
|
|
|
|
block?.children.length > 0 &&
|
|
|
|
block?.children.map((monthDay, _idx) => (
|
|
|
|
<div
|
|
|
|
key={`sub-title-${_idxRoot}-${_idx}`}
|
2024-01-29 08:17:56 +00:00
|
|
|
className="flex-shrink-0 border-b border-neutral-border-medium py-1 text-center capitalize"
|
2023-08-28 07:55:47 +00:00
|
|
|
style={{ width: `${currentViewData?.data.width}px` }}
|
|
|
|
>
|
2023-12-10 10:18:10 +00:00
|
|
|
<div className="space-x-1 text-xs">
|
2023-11-08 15:01:46 +00:00
|
|
|
<span className="text-custom-text-200">{monthDay.dayData.shortTitle[0]}</span>{" "}
|
2023-12-10 10:18:10 +00:00
|
|
|
<span className={monthDay.today ? "rounded-full bg-custom-primary-100 px-1 text-white" : ""}>
|
2023-08-28 07:55:47 +00:00
|
|
|
{monthDay.day}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
))}
|
2023-05-20 12:00:15 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2024-01-29 08:17:56 +00:00
|
|
|
<div className="flex h-full w-full divide-x divide-neutral-border-subtle">
|
2023-08-11 10:29:13 +00:00
|
|
|
{block?.children &&
|
|
|
|
block?.children.length > 0 &&
|
|
|
|
block?.children.map((monthDay, _idx) => (
|
2023-05-20 12:00:15 +00:00
|
|
|
<div
|
2023-08-28 07:55:47 +00:00
|
|
|
key={`column-${_idxRoot}-${_idx}`}
|
2023-05-20 12:00:15 +00:00
|
|
|
className="relative flex h-full flex-col overflow-hidden whitespace-nowrap"
|
2023-08-11 10:29:13 +00:00
|
|
|
style={{ width: `${currentViewData?.data.width}px` }}
|
2023-05-20 12:00:15 +00:00
|
|
|
>
|
|
|
|
<div
|
2023-12-10 10:18:10 +00:00
|
|
|
className={`relative flex h-full w-full flex-1 justify-center ${
|
2024-01-30 06:46:21 +00:00
|
|
|
["sat", "sun"].includes(monthDay?.dayData?.shortTitle || "")
|
|
|
|
? `bg-neutral-component-surface-medium`
|
|
|
|
: ``
|
2023-05-20 12:00:15 +00:00
|
|
|
}`}
|
|
|
|
>
|
2023-08-28 07:55:47 +00:00
|
|
|
{/* {monthDay?.today && (
|
2023-08-11 10:29:13 +00:00
|
|
|
<div className="absolute top-0 bottom-0 w-[1px] bg-red-500" />
|
2023-08-28 07:55:47 +00:00
|
|
|
)} */}
|
2023-05-20 12:00:15 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|