feat: init
This commit is contained in:
1
apps/web/core/components/user/index.ts
Normal file
1
apps/web/core/components/user/index.ts
Normal file
@@ -0,0 +1 @@
|
||||
export * from "./user-greetings";
|
||||
56
apps/web/core/components/user/user-greetings.tsx
Normal file
56
apps/web/core/components/user/user-greetings.tsx
Normal file
@@ -0,0 +1,56 @@
|
||||
import type { FC } from "react";
|
||||
// plane types
|
||||
import { useTranslation } from "@plane/i18n";
|
||||
// hooks
|
||||
import type { IUser } from "@plane/types";
|
||||
import { useCurrentTime } from "@/hooks/use-current-time";
|
||||
// types
|
||||
|
||||
export interface IUserGreetingsView {
|
||||
user: IUser;
|
||||
}
|
||||
|
||||
export const UserGreetingsView: FC<IUserGreetingsView> = (props) => {
|
||||
const { user } = props;
|
||||
// current time hook
|
||||
const { currentTime } = useCurrentTime();
|
||||
// store hooks
|
||||
const { t } = useTranslation();
|
||||
|
||||
const hour = new Intl.DateTimeFormat("en-US", {
|
||||
hour12: false,
|
||||
hour: "numeric",
|
||||
}).format(currentTime);
|
||||
|
||||
const date = new Intl.DateTimeFormat("en-US", {
|
||||
month: "short",
|
||||
day: "numeric",
|
||||
}).format(currentTime);
|
||||
|
||||
const weekDay = new Intl.DateTimeFormat("en-US", {
|
||||
weekday: "long",
|
||||
}).format(currentTime);
|
||||
|
||||
const timeString = new Intl.DateTimeFormat("en-US", {
|
||||
timeZone: user?.user_timezone,
|
||||
hour12: false, // Use 24-hour format
|
||||
hour: "2-digit",
|
||||
minute: "2-digit",
|
||||
}).format(currentTime);
|
||||
|
||||
const greeting = parseInt(hour, 10) < 12 ? "morning" : parseInt(hour, 10) < 18 ? "afternoon" : "evening";
|
||||
|
||||
return (
|
||||
<div className="flex flex-col items-center my-6">
|
||||
<h2 className="text-2xl font-semibold text-center">
|
||||
{t("good")} {t(greeting)}, {user?.first_name} {user?.last_name}
|
||||
</h2>
|
||||
<h5 className="flex items-center gap-2 font-medium text-custom-text-400">
|
||||
<div>{greeting === "morning" ? "🌤️" : greeting === "afternoon" ? "🌥️" : "🌙️"}</div>
|
||||
<div>
|
||||
{weekDay}, {date} {timeString}
|
||||
</div>
|
||||
</h5>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
Reference in New Issue
Block a user