* Wip * WIP * Removed concole log * Add relations to workspace init (#2511) * Add relations to workspace init * remove logs * update prefill * add missing isSystem * comment relation fields * Migrate v2 core models to graphql schema (#2509) * migrate v2 core models to graphql schema * Migrate to new workspace member schema * Continue work * migrated-main * Finished accountOwner nested field integration on companies * Introduce bug * Fix --------- Co-authored-by: Lucas Bordeau <bordeau.lucas@gmail.com> Co-authored-by: Weiko <corentin@twenty.com>
44 lines
1.2 KiB
TypeScript
44 lines
1.2 KiB
TypeScript
import { getOperationName } from '@apollo/client/utilities';
|
|
import { useRecoilValue } from 'recoil';
|
|
|
|
import { currentWorkspaceState } from '@/auth/states/currentWorkspaceState';
|
|
import { ImageInput } from '@/ui/input/components/ImageInput';
|
|
import { GET_CURRENT_USER } from '@/users/graphql/queries/getCurrentUser';
|
|
import { getImageAbsoluteURIOrBase64 } from '@/users/utils/getProfilePictureAbsoluteURI';
|
|
import {
|
|
useRemoveWorkspaceLogoMutation,
|
|
useUploadWorkspaceLogoMutation,
|
|
} from '~/generated/graphql';
|
|
|
|
export const WorkspaceLogoUploader = () => {
|
|
const [uploadLogo] = useUploadWorkspaceLogoMutation();
|
|
const [removeLogo] = useRemoveWorkspaceLogoMutation();
|
|
const currentWorkspace = useRecoilValue(currentWorkspaceState);
|
|
|
|
const onUpload = async (file: File) => {
|
|
if (!file) {
|
|
return;
|
|
}
|
|
await uploadLogo({
|
|
variables: {
|
|
file,
|
|
},
|
|
refetchQueries: [getOperationName(GET_CURRENT_USER) ?? ''],
|
|
});
|
|
};
|
|
|
|
const onRemove = async () => {
|
|
await removeLogo({
|
|
refetchQueries: [getOperationName(GET_CURRENT_USER) ?? ''],
|
|
});
|
|
};
|
|
|
|
return (
|
|
<ImageInput
|
|
picture={getImageAbsoluteURIOrBase64(currentWorkspace?.logo)}
|
|
onUpload={onUpload}
|
|
onRemove={onRemove}
|
|
/>
|
|
);
|
|
};
|