mirror of
https://github.com/gosticks/plane.git
synced 2025-10-16 12:45:33 +00:00
* fix: adding language support package * fix: language support implementation using mobx * fix: adding more languages for support * fix: profile settings translations * feat: added language support for sidebar and user settings * feat: added language support for deactivation modal * fix: added project sync after transfer issues (#6200) * code refactor and improvement (#6203) * chore: package code refactoring * chore: component restructuring and refactor * chore: comment create improvement * refactor: enhance workspace and project wrapper modularity (#6207) * [WEB-2678]feat: added functionality to add labels directly from dropdown (#6211) * enhancement:added functionality to add features directly from dropdown * fix: fixed import order * fix: fixed lint errors * chore: added common component for project activity (#6212) * chore: added common component for project activity * fix: added enum * fix: added enum for initiatives * - Do not clear temp files that are locked. (#6214) - Handle edge cases in sync workspace * fix: labels empty state for drop down (#6216) * refactor: remove cn helper function from the editor package (#6217) * * feat: added language support to issue create modal in sidebar * fix: project activity type * * fix: added missing translations * fix: modified translation for plurals * fix: fixed spanish translation * dev: language type error in space user profile types * fix: type fixes * chore: added alpha tag --------- Co-authored-by: sriram veeraghanta <veeraghanta.sriram@gmail.com> Co-authored-by: Anmol Singh Bhatia <121005188+anmolsinghbhatia@users.noreply.github.com> Co-authored-by: Prateek Shourya <prateekshourya29@gmail.com> Co-authored-by: Akshita Goyal <36129505+gakshita@users.noreply.github.com> Co-authored-by: Satish Gandham <satish.iitg@gmail.com> Co-authored-by: Aaryan Khandelwal <65252264+aaryan610@users.noreply.github.com> Co-authored-by: gurusinath <gurusainath007@gmail.com>
106 lines
3.6 KiB
TypeScript
106 lines
3.6 KiB
TypeScript
import { useState } from "react";
|
|
import { Controller, useFormContext } from "react-hook-form";
|
|
import { X } from "lucide-react";
|
|
import { useTranslation } from "@plane/i18n";
|
|
// plane types
|
|
import { IProject } from "@plane/types";
|
|
// plane ui
|
|
import { CustomEmojiIconPicker, EmojiIconPickerTypes, Logo } from "@plane/ui";
|
|
// components
|
|
import { ImagePickerPopover } from "@/components/core";
|
|
// constants
|
|
import { ETabIndices } from "@/constants/tab-indices";
|
|
// helpers
|
|
import { convertHexEmojiToDecimal } from "@/helpers/emoji.helper";
|
|
import { getFileURL } from "@/helpers/file.helper";
|
|
import { getTabIndex } from "@/helpers/tab-indices.helper";
|
|
|
|
type Props = {
|
|
handleClose: () => void;
|
|
isMobile?: boolean;
|
|
};
|
|
const ProjectCreateHeader: React.FC<Props> = (props) => {
|
|
const { handleClose, isMobile = false } = props;
|
|
const { watch, control } = useFormContext<IProject>();
|
|
const { t } = useTranslation();
|
|
// derived values
|
|
const coverImage = watch("cover_image_url");
|
|
|
|
const [isOpen, setIsOpen] = useState(false);
|
|
const { getIndex } = getTabIndex(ETabIndices.PROJECT_CREATE, isMobile);
|
|
|
|
return (
|
|
<div className="group relative h-44 w-full rounded-lg bg-custom-background-80">
|
|
{coverImage && (
|
|
<img
|
|
src={getFileURL(coverImage)}
|
|
className="absolute left-0 top-0 h-full w-full rounded-lg object-cover"
|
|
alt={t("project_cover_image_alt")}
|
|
/>
|
|
)}
|
|
|
|
<div className="absolute right-2 top-2 p-2">
|
|
<button data-posthog="PROJECT_MODAL_CLOSE" type="button" onClick={handleClose} tabIndex={getIndex("close")}>
|
|
<X className="h-5 w-5 text-white" />
|
|
</button>
|
|
</div>
|
|
<div className="absolute bottom-2 right-2">
|
|
<Controller
|
|
name="cover_image_url"
|
|
control={control}
|
|
render={({ field: { value, onChange } }) => (
|
|
<ImagePickerPopover
|
|
label={t("change_cover")}
|
|
onChange={onChange}
|
|
control={control}
|
|
value={value}
|
|
tabIndex={getIndex("cover_image")}
|
|
/>
|
|
)}
|
|
/>
|
|
</div>
|
|
<div className="absolute -bottom-[22px] left-3">
|
|
<Controller
|
|
name="logo_props"
|
|
control={control}
|
|
render={({ field: { value, onChange } }) => (
|
|
<CustomEmojiIconPicker
|
|
isOpen={isOpen}
|
|
handleToggle={(val: boolean) => setIsOpen(val)}
|
|
className="flex items-center justify-center"
|
|
buttonClassName="flex items-center justify-center"
|
|
label={
|
|
<span className="grid h-11 w-11 place-items-center rounded-md bg-custom-background-80">
|
|
<Logo logo={value} size={20} />
|
|
</span>
|
|
}
|
|
onChange={(val: any) => {
|
|
let logoValue = {};
|
|
|
|
if (val?.type === "emoji")
|
|
logoValue = {
|
|
value: convertHexEmojiToDecimal(val.value.unified),
|
|
url: val.value.imageUrl,
|
|
};
|
|
else if (val?.type === "icon") logoValue = val.value;
|
|
|
|
onChange({
|
|
in_use: val?.type,
|
|
[val?.type]: logoValue,
|
|
});
|
|
setIsOpen(false);
|
|
}}
|
|
defaultIconColor={value.in_use && value.in_use === "icon" ? value.icon?.color : undefined}
|
|
defaultOpen={
|
|
value.in_use && value.in_use === "emoji" ? EmojiIconPickerTypes.EMOJI : EmojiIconPickerTypes.ICON
|
|
}
|
|
/>
|
|
)}
|
|
/>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ProjectCreateHeader;
|