mirror of
https://github.com/makeplane/plane.git
synced 2025-12-25 16:19:43 +01:00
* chore: migrations and backmigration to move attachments to file asset * chore: move attachments to file assets * chore: update migration file to include created by and updated by and size * chore: remove uninmport errors * chore: make size as float field * fix: file asset uploads * chore: asset uploads migration changes * chore: v2 assets endpoint * chore: remove unused imports * chore: issue attachments * chore: issue attachments * chore: workspace logo endpoints * chore: private bucket changes * chore: user asset endpoint * chore: add logo_url validation * chore: cover image urlk * chore: change asset max length * chore: pages endpoint * chore: store the storage_metadata only when none * chore: attachment asset apis * chore: update create private bucket * chore: make bucket private * chore: fix response of user uploads * fix: response of user uploads * fix: job to fix file asset uploads * fix: user asset endpoints * chore: avatar for user profile * chore: external apis user url endpoint * chore: upload workspace and user asset actions updated * chore: analytics endpoint * fix: analytics export * chore: avatar urls * chore: update user avatar instances * chore: avatar urls for assignees and creators * chore: bucket permission script * fix: all user avatr instances in the web app * chore: update project cover image logic * fix: issue attachment endpoint * chore: patch endpoint for issue attachment * chore: attachments * chore: change attachment storage class * chore: update issue attachment endpoints * fix: issue attachment * chore: update issue attachment implementation * chore: page asset endpoints * fix: web build errors * chore: attachments * chore: page asset urls * chore: comment and issue asset endpoints * chore: asset endpoints * chore: attachment endpoints * chore: bulk asset endpoint * chore: restore endpoint * chore: project assets endpoints * chore: asset url * chore: add delete asset endpoints * chore: fix asset upload endpoint * chore: update patch endpoints * chore: update patch endpoint * chore: update editor image handling * chore: asset restore endpoints * chore: avatar url for space assets * chore: space app assets migration * fix: space app urls * chore: space endpoints * fix: old editor images rendering logic * fix: issue archive and attachment activity * chore: asset deletes * chore: attachment delete * fix: issue attachment * fix: issue attachment get * chore: cover image url for projects * chore: remove duplicate py file * fix: url check function * chore: chore project cover asset delete * fix: migrations * chore: delete migration files * chore: update bucket * fix: build errors * chore: add asset url in intake attachment * chore: project cover fix * chore: update next.config * chore: delete old workspace logos * chore: workspace assets * chore: asset get for space * chore: update project modal * chore: remove unused imports * fix: space app editor helper * chore: update rich-text read-only editor * chore: create multiple column for entity identifiers * chore: update migrations * chore: remove entity identifier * fix: issue assets * chore: update maximum file size logic * chore: update editor max file size logic * fix: close modal after removing workspace logo * chore: update uploaded asstes' status post issue creation * chore: added file size limit to the space app * dev: add file size limit restriction on all endpoints * fix: remove old workspace logo and user avatar --------- Co-authored-by: pablohashescobar <nikhilschacko@gmail.com>
81 lines
2.8 KiB
TypeScript
81 lines
2.8 KiB
TypeScript
"use client";
|
|
|
|
import { FC, useState } from "react";
|
|
import { observer } from "mobx-react";
|
|
import { ChevronDown } from "lucide-react";
|
|
import { Menu, Transition } from "@headlessui/react";
|
|
// ui
|
|
import { Avatar } from "@plane/ui";
|
|
// helpers
|
|
import { cn } from "@/helpers/common.helper";
|
|
import { getFileURL } from "@/helpers/file.helper";
|
|
// hooks
|
|
import { useUser } from "@/hooks/store";
|
|
// components
|
|
import { SwitchAccountModal } from "./switch-account-modal";
|
|
|
|
type TSwitchAccountDropdownProps = {
|
|
fullName?: string;
|
|
};
|
|
|
|
export const SwitchAccountDropdown: FC<TSwitchAccountDropdownProps> = observer((props) => {
|
|
const { fullName } = props;
|
|
// states
|
|
const [showSwitchAccountModal, setShowSwitchAccountModal] = useState(false);
|
|
// store hooks
|
|
const { data: user } = useUser();
|
|
|
|
const displayName = user?.first_name
|
|
? `${user?.first_name} ${user?.last_name ?? ""}`
|
|
: fullName && fullName.trim().length > 0
|
|
? fullName
|
|
: user?.email;
|
|
|
|
return (
|
|
<div className="flex w-full shrink-0 justify-end">
|
|
<SwitchAccountModal isOpen={showSwitchAccountModal} onClose={() => setShowSwitchAccountModal(false)} />
|
|
<div className="flex items-center gap-x-2 pr-4 z-10">
|
|
{user?.avatar_url && (
|
|
<Avatar
|
|
name={displayName}
|
|
src={getFileURL(user?.avatar_url)}
|
|
size={24}
|
|
shape="square"
|
|
fallbackBackgroundColor="#FCBE1D"
|
|
className="!text-base capitalize"
|
|
/>
|
|
)}
|
|
<Menu as="div" className="relative">
|
|
<Menu.Button className="flex items-center gap-x-1 z-10">
|
|
<span className="text-sm font-medium text-custom-text-200">{displayName}</span>
|
|
<ChevronDown className="h-4 w-4 text-custom-text-300" />
|
|
</Menu.Button>
|
|
<Transition
|
|
enter="transition duration-100 ease-out"
|
|
enterFrom="transform scale-95 opacity-0"
|
|
enterTo="transform scale-100 opacity-100"
|
|
leave="transition duration-75 ease-out"
|
|
leaveFrom="transform scale-100 opacity-100"
|
|
leaveTo="transform scale-95 opacity-0"
|
|
>
|
|
<Menu.Items className="absolute z-10 right-0 rounded-md border-[0.5px] border-custom-border-300 mt-2 bg-custom-background-100 px-2 py-2.5 text-sm min-w-[12rem] shadow-custom-shadow-rg">
|
|
<Menu.Item
|
|
as="button"
|
|
type="button"
|
|
className={({ active }) =>
|
|
cn("text-red-500 px-1 py-1.5 whitespace-nowrap text-left rounded w-full", {
|
|
"bg-custom-background-80": active,
|
|
})
|
|
}
|
|
onClick={() => setShowSwitchAccountModal(true)}
|
|
>
|
|
Wrong e-mail address?
|
|
</Menu.Item>
|
|
</Menu.Items>
|
|
</Transition>
|
|
</Menu>
|
|
</div>
|
|
</div>
|
|
);
|
|
});
|