forked from github/plane
c9337d4a41
* fix: created dashboard, widgets and dashboard widget model * fix: new user home dashboard * chore: recent projects list * chore: recent collaborators * chore: priority order change * chore: payload changes * chore: collaborator's active issue count * chore: all dashboard widgets added with services and typs * chore: centered metric for pie chart * chore: widget filters * chore: created issue filter * fix: created and assigned issues payload change * chore: created issue payload change * fix: date filter change * chore: implement filters * fix: added expansion fields * fix: changed issue structure with relation * chore: new issues response * fix: project member fix * chore: updated issue_relation structure * chore: code cleanup * chore: update issues response and added empty states * fix: button text wrap * chore: update empty state messages * fix: filters * chore: update dark mode empty states * build-error: Type check in the issue relation service * fix: issues redirection * fix: project empty state * chore: project member active check * chore: project member check in state and priority * chore: remove console logs and replace harcoded values with constants * fix: code refactoring * fix: key name changed * refactor: mapping through similar components using an array * fix: build errors --------- Co-authored-by: Aaryan Khandelwal <aaryankhandu123@gmail.com> Co-authored-by: gurusainath <gurusainath007@gmail.com>
50 lines
1.3 KiB
TypeScript
50 lines
1.3 KiB
TypeScript
import { FC } from "react";
|
|
import { IUser } from "@plane/types";
|
|
|
|
export interface IUserGreetingsView {
|
|
user: IUser;
|
|
}
|
|
|
|
export const UserGreetingsView: FC<IUserGreetingsView> = (props) => {
|
|
const { user } = props;
|
|
|
|
const currentTime = new Date();
|
|
|
|
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>
|
|
<h3 className="text-xl font-semibold">
|
|
Good {greeting}, {user?.first_name} {user?.last_name}
|
|
</h3>
|
|
<h6 className="flex items-center gap-2 font-medium text-custom-text-400">
|
|
<div>{greeting === "morning" ? "🌤️" : greeting === "afternoon" ? "🌥️" : "🌙️"}</div>
|
|
<div>
|
|
{weekDay}, {date} {timeString}
|
|
</div>
|
|
</h6>
|
|
</div>
|
|
);
|
|
};
|