From c51c3a3250821dee002ddc251c795189a93e338b Mon Sep 17 00:00:00 2001 From: gitstart-twenty Date: Wed, 17 Jul 2024 16:22:33 +0000 Subject: [PATCH] Improve performance of demo workspace - Rename `getImageAbsoluteURIOrBase64` function --- .../src/emails/send-invite-link.email.tsx | 4 +-- ...eURIOrBase64.ts => getImageAbsoluteURI.ts} | 4 +-- .../calendar/components/CalendarEventRow.tsx | 4 +-- .../activities/comment/CommentHeader.tsx | 4 +-- .../activities/components/ParticipantChip.tsx | 4 +-- .../emails/components/EmailThreadPreview.tsx | 10 +++---- .../timeline/components/TimelineActivity.tsx | 4 +-- .../src/modules/auth/components/Logo.tsx | 4 +-- .../favorites/components/Favorites.tsx | 4 +-- .../components/AppNavigationDrawer.tsx | 4 +-- .../object-metadata/utils/getAvatarUrl.ts | 4 +-- .../components/GenericEntityFilterChip.tsx | 4 +-- .../MultipleObjectRecordSelectItem.tsx | 4 +-- .../components/SelectableMenuItemSelect.tsx | 4 +-- .../MultipleRecordSelectDropdown.tsx | 4 +-- .../components/ProfilePictureUploader.tsx | 4 +-- .../components/WorkspaceLogoUploader.tsx | 4 +-- .../MultiWorkspaceDropdownButton.tsx | 6 ++--- .../constants/DefaultWorkspaceLogo.ts | 2 +- .../src/modules/users/components/UserChip.tsx | 4 +-- .../components/WorkspaceMemberCard.tsx | 4 +-- .../__tests__/getImageAbsoluteURI.test.ts | 21 +++++++++++++++ .../getImageAbsoluteURIOrBase64.test.ts | 27 ------------------- ...eURIOrBase64.ts => getImageAbsoluteURI.ts} | 4 +-- .../typeorm-seeds/core/demo/workspaces.ts | 2 +- .../database/typeorm-seeds/core/workspaces.ts | 4 +-- 26 files changed, 70 insertions(+), 78 deletions(-) rename packages/twenty-emails/src/utils/{getImageAbsoluteURIOrBase64.ts => getImageAbsoluteURI.ts} (70%) create mode 100644 packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts delete mode 100644 packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURIOrBase64.test.ts rename packages/twenty-front/src/utils/image/{getImageAbsoluteURIOrBase64.ts => getImageAbsoluteURI.ts} (60%) diff --git a/packages/twenty-emails/src/emails/send-invite-link.email.tsx b/packages/twenty-emails/src/emails/send-invite-link.email.tsx index 36e712acf936..e1c3e70ca3af 100644 --- a/packages/twenty-emails/src/emails/send-invite-link.email.tsx +++ b/packages/twenty-emails/src/emails/send-invite-link.email.tsx @@ -9,7 +9,7 @@ import { MainText } from 'src/components/MainText'; import { Title } from 'src/components/Title'; import { WhatIsTwenty } from 'src/components/WhatIsTwenty'; import { capitalize } from 'src/utils/capitalize'; -import { getImageAbsoluteURIOrBase64 } from 'src/utils/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from 'src/utils/getImageAbsoluteURI'; type SendInviteLinkEmailProps = { link: string; @@ -27,7 +27,7 @@ export const SendInviteLinkEmail = ({ sender, serverUrl, }: SendInviteLinkEmailProps) => { - const workspaceLogo = getImageAbsoluteURIOrBase64(workspace.logo, serverUrl); + const workspaceLogo = getImageAbsoluteURI(workspace.logo, serverUrl); return ( diff --git a/packages/twenty-emails/src/utils/getImageAbsoluteURIOrBase64.ts b/packages/twenty-emails/src/utils/getImageAbsoluteURI.ts similarity index 70% rename from packages/twenty-emails/src/utils/getImageAbsoluteURIOrBase64.ts rename to packages/twenty-emails/src/utils/getImageAbsoluteURI.ts index cab930f76518..28a6e637a303 100644 --- a/packages/twenty-emails/src/utils/getImageAbsoluteURIOrBase64.ts +++ b/packages/twenty-emails/src/utils/getImageAbsoluteURI.ts @@ -1,4 +1,4 @@ -export const getImageAbsoluteURIOrBase64 = ( +export const getImageAbsoluteURI = ( imageUrl?: string | null, serverUrl?: string, ) => { @@ -6,7 +6,7 @@ export const getImageAbsoluteURIOrBase64 = ( return null; } - if (imageUrl?.startsWith('data:') || imageUrl?.startsWith('https:')) { + if (imageUrl?.startsWith('https:')) { return imageUrl; } diff --git a/packages/twenty-front/src/modules/activities/calendar/components/CalendarEventRow.tsx b/packages/twenty-front/src/modules/activities/calendar/components/CalendarEventRow.tsx index e5ad988d3153..3185c3c71b50 100644 --- a/packages/twenty-front/src/modules/activities/calendar/components/CalendarEventRow.tsx +++ b/packages/twenty-front/src/modules/activities/calendar/components/CalendarEventRow.tsx @@ -16,7 +16,7 @@ import { Card } from '@/ui/layout/card/components/Card'; import { CardContent } from '@/ui/layout/card/components/CardContent'; import { TimelineCalendarEvent } from '~/generated-metadata/graphql'; import { CalendarChannelVisibility } from '~/generated/graphql'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { isDefined } from '~/utils/isDefined'; type CalendarEventRowProps = { @@ -163,7 +163,7 @@ export const CalendarEventRow = ({ key={[participant.workspaceMemberId, participant.displayName] .filter(isDefined) .join('-')} - avatarUrl={getImageAbsoluteURIOrBase64(participant.avatarUrl)} + avatarUrl={getImageAbsoluteURI(participant.avatarUrl)} placeholder={ participant.firstName && participant.lastName ? `${participant.firstName} ${participant.lastName}` diff --git a/packages/twenty-front/src/modules/activities/comment/CommentHeader.tsx b/packages/twenty-front/src/modules/activities/comment/CommentHeader.tsx index d48f114e9d7f..86a02f2b1e7a 100644 --- a/packages/twenty-front/src/modules/activities/comment/CommentHeader.tsx +++ b/packages/twenty-front/src/modules/activities/comment/CommentHeader.tsx @@ -6,7 +6,7 @@ import { beautifyExactDateTime, beautifyPastDateRelativeToNow, } from '~/utils/date-utils'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledContainer = styled.div` align-items: center; @@ -60,7 +60,7 @@ export const CommentHeader = ({ comment, actionBar }: CommentHeaderProps) => { <StyledContainer> <StyledLeftContainer> <Avatar - avatarUrl={getImageAbsoluteURIOrBase64(avatarUrl)} + avatarUrl={getImageAbsoluteURI(avatarUrl)} size="md" placeholderColorSeed={author?.id} placeholder={authorName} diff --git a/packages/twenty-front/src/modules/activities/components/ParticipantChip.tsx b/packages/twenty-front/src/modules/activities/components/ParticipantChip.tsx index f0242f67ea69..db805d178b43 100644 --- a/packages/twenty-front/src/modules/activities/components/ParticipantChip.tsx +++ b/packages/twenty-front/src/modules/activities/components/ParticipantChip.tsx @@ -4,7 +4,7 @@ import { Avatar } from 'twenty-ui'; import { getDisplayNameFromParticipant } from '@/activities/emails/utils/getDisplayNameFromParticipant'; import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular'; import { RecordChip } from '@/object-record/components/RecordChip'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledAvatar = styled(Avatar)` margin-right: ${({ theme }) => theme.spacing(1)}; @@ -73,7 +73,7 @@ export const ParticipantChip = ({ ) : ( <StyledChip> <StyledAvatar - avatarUrl={getImageAbsoluteURIOrBase64(avatarUrl)} + avatarUrl={getImageAbsoluteURI(avatarUrl)} type="rounded" placeholder={displayName} size="sm" diff --git a/packages/twenty-front/src/modules/activities/emails/components/EmailThreadPreview.tsx b/packages/twenty-front/src/modules/activities/emails/components/EmailThreadPreview.tsx index b9daf483a2a4..e6b27eb8b466 100644 --- a/packages/twenty-front/src/modules/activities/emails/components/EmailThreadPreview.tsx +++ b/packages/twenty-front/src/modules/activities/emails/components/EmailThreadPreview.tsx @@ -10,7 +10,7 @@ import { CardContent } from '@/ui/layout/card/components/CardContent'; import { useRightDrawer } from '@/ui/layout/right-drawer/hooks/useRightDrawer'; import { MessageChannelVisibility, TimelineThread } from '~/generated/graphql'; import { formatToHumanReadableDate } from '~/utils/date-utils'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledCardContent = styled(CardContent)<{ visibility: MessageChannelVisibility; @@ -154,15 +154,13 @@ export const EmailThreadPreview = ({ <StyledHeading unread={!thread.read}> <StyledParticipantsContainer> <Avatar - avatarUrl={getImageAbsoluteURIOrBase64( - thread?.firstParticipant?.avatarUrl, - )} + avatarUrl={getImageAbsoluteURI(thread?.firstParticipant?.avatarUrl)} placeholder={thread.firstParticipant.displayName} type="rounded" /> {thread?.lastTwoParticipants?.[0] && ( <StyledAvatar - avatarUrl={getImageAbsoluteURIOrBase64( + avatarUrl={getImageAbsoluteURI( thread.lastTwoParticipants[0].avatarUrl, )} placeholder={thread.lastTwoParticipants[0].displayName} @@ -171,7 +169,7 @@ export const EmailThreadPreview = ({ )} {finalDisplayedName && ( <StyledAvatar - avatarUrl={getImageAbsoluteURIOrBase64(finalAvatarUrl)} + avatarUrl={getImageAbsoluteURI(finalAvatarUrl)} placeholder={finalDisplayedName} type="rounded" color={isCountIcon ? GRAY_SCALE.gray50 : undefined} diff --git a/packages/twenty-front/src/modules/activities/timeline/components/TimelineActivity.tsx b/packages/twenty-front/src/modules/activities/timeline/components/TimelineActivity.tsx index fc915a1ce1bc..a80c3ff774b5 100644 --- a/packages/twenty-front/src/modules/activities/timeline/components/TimelineActivity.tsx +++ b/packages/twenty-front/src/modules/activities/timeline/components/TimelineActivity.tsx @@ -11,7 +11,7 @@ import { beautifyExactDateTime, beautifyPastDateRelativeToNow, } from '~/utils/date-utils'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledAvatarContainer = styled.div` align-items: center; @@ -154,7 +154,7 @@ export const TimelineActivity = ({ <StyledTimelineItemContainer> <StyledAvatarContainer> <Avatar - avatarUrl={getImageAbsoluteURIOrBase64( + avatarUrl={getImageAbsoluteURI( activityForTimeline.author?.avatarUrl, )} placeholder={activityForTimeline.author?.name.firstName ?? ''} diff --git a/packages/twenty-front/src/modules/auth/components/Logo.tsx b/packages/twenty-front/src/modules/auth/components/Logo.tsx index a1bbc54bebfa..34ddf069cd91 100644 --- a/packages/twenty-front/src/modules/auth/components/Logo.tsx +++ b/packages/twenty-front/src/modules/auth/components/Logo.tsx @@ -1,6 +1,6 @@ import styled from '@emotion/styled'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; type LogoProps = { workspaceLogo?: string | null; @@ -58,7 +58,7 @@ export const Logo = ({ workspaceLogo }: LogoProps) => { return ( <StyledContainer> - <StyledMainLogo logo={getImageAbsoluteURIOrBase64(workspaceLogo)} /> + <StyledMainLogo logo={getImageAbsoluteURI(workspaceLogo)} /> <StyledTwentyLogoContainer> <StyledTwentyLogo src="/icons/android/android-launchericon-192-192.png" /> </StyledTwentyLogoContainer> diff --git a/packages/twenty-front/src/modules/favorites/components/Favorites.tsx b/packages/twenty-front/src/modules/favorites/components/Favorites.tsx index 9835a860b41f..5366ece6e6b0 100644 --- a/packages/twenty-front/src/modules/favorites/components/Favorites.tsx +++ b/packages/twenty-front/src/modules/favorites/components/Favorites.tsx @@ -10,7 +10,7 @@ import { NavigationDrawerItem } from '@/ui/navigation/navigation-drawer/componen import { NavigationDrawerSection } from '@/ui/navigation/navigation-drawer/components/NavigationDrawerSection'; import { NavigationDrawerSectionTitle } from '@/ui/navigation/navigation-drawer/components/NavigationDrawerSectionTitle'; import { useNavigationSection } from '@/ui/navigation/navigation-drawer/hooks/useNavigationSection'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { useFavorites } from '../hooks/useFavorites'; @@ -81,7 +81,7 @@ export const Favorites = () => { Icon={() => ( <StyledAvatar placeholderColorSeed={recordId} - avatarUrl={getImageAbsoluteURIOrBase64(avatarUrl)} + avatarUrl={getImageAbsoluteURI(avatarUrl)} type={avatarType} placeholder={labelIdentifier} className="fav-avatar" diff --git a/packages/twenty-front/src/modules/navigation/components/AppNavigationDrawer.tsx b/packages/twenty-front/src/modules/navigation/components/AppNavigationDrawer.tsx index 310aadc735ef..52814e91837f 100644 --- a/packages/twenty-front/src/modules/navigation/components/AppNavigationDrawer.tsx +++ b/packages/twenty-front/src/modules/navigation/components/AppNavigationDrawer.tsx @@ -11,7 +11,7 @@ import { } from '@/ui/navigation/navigation-drawer/components/NavigationDrawer'; import { isNavigationDrawerOpenState } from '@/ui/navigation/states/isNavigationDrawerOpenState'; import { useIsMobile } from '@/ui/utilities/responsive/hooks/useIsMobile'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { useIsSettingsPage } from '../hooks/useIsSettingsPage'; import { currentMobileNavigationDrawerState } from '../states/currentMobileNavigationDrawerState'; @@ -49,7 +49,7 @@ export const AppNavigationDrawer = ({ : { logo: (currentWorkspace?.logo && - getImageAbsoluteURIOrBase64(currentWorkspace.logo)) ?? + getImageAbsoluteURI(currentWorkspace.logo)) ?? undefined, title: currentWorkspace?.displayName ?? undefined, children: <MainNavigationDrawerItems />, diff --git a/packages/twenty-front/src/modules/object-metadata/utils/getAvatarUrl.ts b/packages/twenty-front/src/modules/object-metadata/utils/getAvatarUrl.ts index 7965b905b443..97ffc4e384fb 100644 --- a/packages/twenty-front/src/modules/object-metadata/utils/getAvatarUrl.ts +++ b/packages/twenty-front/src/modules/object-metadata/utils/getAvatarUrl.ts @@ -2,7 +2,7 @@ import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSi import { FieldMetadataItem } from '@/object-metadata/types/FieldMetadataItem'; import { ObjectRecord } from '@/object-record/types/ObjectRecord'; import { getLogoUrlFromDomainName } from '~/utils'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { isDefined } from '~/utils/isDefined'; import { getImageIdentifierFieldValue } from './getImageIdentifierFieldValue'; @@ -21,7 +21,7 @@ export const getAvatarUrl = ( } if (objectNameSingular === CoreObjectNameSingular.Person) { - return getImageAbsoluteURIOrBase64(record.avatarUrl) ?? ''; + return getImageAbsoluteURI(record.avatarUrl) ?? ''; } const imageIdentifierFieldValue = getImageIdentifierFieldValue( diff --git a/packages/twenty-front/src/modules/object-record/object-filter-dropdown/components/GenericEntityFilterChip.tsx b/packages/twenty-front/src/modules/object-record/object-filter-dropdown/components/GenericEntityFilterChip.tsx index fae9454c187a..3903304d0674 100644 --- a/packages/twenty-front/src/modules/object-record/object-filter-dropdown/components/GenericEntityFilterChip.tsx +++ b/packages/twenty-front/src/modules/object-record/object-filter-dropdown/components/GenericEntityFilterChip.tsx @@ -1,6 +1,6 @@ import { AvatarChip, IconComponent } from 'twenty-ui'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { Filter } from '../types/Filter'; @@ -17,7 +17,7 @@ export const GenericEntityFilterChip = ({ placeholderColorSeed={filter.value} name={filter.displayValue} avatarType="rounded" - avatarUrl={getImageAbsoluteURIOrBase64(filter.displayAvatarUrl) || ''} + avatarUrl={getImageAbsoluteURI(filter.displayAvatarUrl) || ''} LeftIcon={Icon} /> ); diff --git a/packages/twenty-front/src/modules/object-record/relation-picker/components/MultipleObjectRecordSelectItem.tsx b/packages/twenty-front/src/modules/object-record/relation-picker/components/MultipleObjectRecordSelectItem.tsx index af92fedd19f0..7d73fb6ab06f 100644 --- a/packages/twenty-front/src/modules/object-record/relation-picker/components/MultipleObjectRecordSelectItem.tsx +++ b/packages/twenty-front/src/modules/object-record/relation-picker/components/MultipleObjectRecordSelectItem.tsx @@ -10,7 +10,7 @@ import { SelectableItem } from '@/ui/layout/selectable-list/components/Selectabl import { useSelectableList } from '@/ui/layout/selectable-list/hooks/useSelectableList'; import { MenuItemMultiSelectAvatar } from '@/ui/navigation/menu-item/components/MenuItemMultiSelectAvatar'; import { useAvailableScopeIdOrThrow } from '@/ui/utilities/recoil-scope/scopes-internal/hooks/useAvailableScopeId'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { isDefined } from '~/utils/isDefined'; export const StyledSelectableItem = styled(SelectableItem)` @@ -65,7 +65,7 @@ export const MultipleObjectRecordSelectItem = ({ selected={selected} avatar={ <Avatar - avatarUrl={getImageAbsoluteURIOrBase64(recordIdentifier.avatarUrl)} + avatarUrl={getImageAbsoluteURI(recordIdentifier.avatarUrl)} placeholderColorSeed={objectRecordId} placeholder={recordIdentifier.name} size="md" diff --git a/packages/twenty-front/src/modules/object-record/relation-picker/components/SelectableMenuItemSelect.tsx b/packages/twenty-front/src/modules/object-record/relation-picker/components/SelectableMenuItemSelect.tsx index 16eb58fad271..c1eddec0c5ac 100644 --- a/packages/twenty-front/src/modules/object-record/relation-picker/components/SelectableMenuItemSelect.tsx +++ b/packages/twenty-front/src/modules/object-record/relation-picker/components/SelectableMenuItemSelect.tsx @@ -6,7 +6,7 @@ import { EntityForSelect } from '@/object-record/relation-picker/types/EntityFor import { SelectableItem } from '@/ui/layout/selectable-list/components/SelectableItem'; import { useSelectableList } from '@/ui/layout/selectable-list/hooks/useSelectableList'; import { MenuItemSelectAvatar } from '@/ui/navigation/menu-item/components/MenuItemSelectAvatar'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; type SelectableMenuItemSelectProps = { entity: EntityForSelect; @@ -40,7 +40,7 @@ export const SelectableMenuItemSelect = ({ hovered={isSelectedItemId} avatar={ <Avatar - avatarUrl={getImageAbsoluteURIOrBase64(entity.avatarUrl)} + avatarUrl={getImageAbsoluteURI(entity.avatarUrl)} placeholderColorSeed={entity.id} placeholder={entity.name} size="md" diff --git a/packages/twenty-front/src/modules/object-record/select/components/MultipleRecordSelectDropdown.tsx b/packages/twenty-front/src/modules/object-record/select/components/MultipleRecordSelectDropdown.tsx index af608e0077d5..a1440c2108f7 100644 --- a/packages/twenty-front/src/modules/object-record/select/components/MultipleRecordSelectDropdown.tsx +++ b/packages/twenty-front/src/modules/object-record/select/components/MultipleRecordSelectDropdown.tsx @@ -6,7 +6,7 @@ import { DropdownMenuSkeletonItem } from '@/ui/input/relation-picker/components/ import { DropdownMenuItemsContainer } from '@/ui/layout/dropdown/components/DropdownMenuItemsContainer'; import { MenuItem } from '@/ui/navigation/menu-item/components/MenuItem'; import { MenuItemMultiSelectAvatar } from '@/ui/navigation/menu-item/components/MenuItemMultiSelectAvatar'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; export const MultipleRecordSelectDropdown = ({ recordsToSelect, @@ -69,7 +69,7 @@ export const MultipleRecordSelectDropdown = ({ } avatar={ <Avatar - avatarUrl={getImageAbsoluteURIOrBase64(record.avatarUrl)} + avatarUrl={getImageAbsoluteURI(record.avatarUrl)} placeholderColorSeed={record.id} placeholder={record.name} size="md" diff --git a/packages/twenty-front/src/modules/settings/profile/components/ProfilePictureUploader.tsx b/packages/twenty-front/src/modules/settings/profile/components/ProfilePictureUploader.tsx index 6bc475de5a0a..8cb3c910d0a6 100644 --- a/packages/twenty-front/src/modules/settings/profile/components/ProfilePictureUploader.tsx +++ b/packages/twenty-front/src/modules/settings/profile/components/ProfilePictureUploader.tsx @@ -6,7 +6,7 @@ import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSi import { useUpdateOneRecord } from '@/object-record/hooks/useUpdateOneRecord'; import { ImageInput } from '@/ui/input/components/ImageInput'; import { useUploadProfilePictureMutation } from '~/generated/graphql'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { isDefined } from '~/utils/isDefined'; import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull'; @@ -101,7 +101,7 @@ export const ProfilePictureUploader = () => { return ( <ImageInput - picture={getImageAbsoluteURIOrBase64(currentWorkspaceMember?.avatarUrl)} + picture={getImageAbsoluteURI(currentWorkspaceMember?.avatarUrl)} onUpload={handleUpload} onRemove={handleRemove} onAbort={handleAbort} diff --git a/packages/twenty-front/src/modules/settings/workspace/components/WorkspaceLogoUploader.tsx b/packages/twenty-front/src/modules/settings/workspace/components/WorkspaceLogoUploader.tsx index 3a3699c9b02c..ace4e9d2357c 100644 --- a/packages/twenty-front/src/modules/settings/workspace/components/WorkspaceLogoUploader.tsx +++ b/packages/twenty-front/src/modules/settings/workspace/components/WorkspaceLogoUploader.tsx @@ -6,7 +6,7 @@ import { useUpdateWorkspaceMutation, useUploadWorkspaceLogoMutation, } from '~/generated/graphql'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull'; export const WorkspaceLogoUploader = () => { @@ -57,7 +57,7 @@ export const WorkspaceLogoUploader = () => { return ( <ImageInput - picture={getImageAbsoluteURIOrBase64(currentWorkspace?.logo)} + picture={getImageAbsoluteURI(currentWorkspace?.logo)} onUpload={onUpload} onRemove={onRemove} /> diff --git a/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/components/MultiWorkspaceDropdownButton.tsx b/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/components/MultiWorkspaceDropdownButton.tsx index 23d356aa4fea..07be1ee8bf14 100644 --- a/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/components/MultiWorkspaceDropdownButton.tsx +++ b/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/components/MultiWorkspaceDropdownButton.tsx @@ -14,7 +14,7 @@ import { DEFAULT_WORKSPACE_LOGO } from '@/ui/navigation/navigation-drawer/consta import { MULTI_WORKSPACE_DROPDOWN_ID } from '@/ui/navigation/navigation-drawer/constants/MulitWorkspaceDropdownId'; import { useWorkspaceSwitching } from '@/ui/navigation/navigation-drawer/hooks/useWorkspaceSwitching'; import { NavigationDrawerHotKeyScope } from '@/ui/navigation/navigation-drawer/types/NavigationDrawerHotKeyScope'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledLogo = styled.div<{ logo: string }>` background: url(${({ logo }) => logo}); @@ -88,7 +88,7 @@ export const MultiWorkspaceDropdownButton = ({ <StyledContainer> <StyledLogo logo={ - getImageAbsoluteURIOrBase64( + getImageAbsoluteURI( currentWorkspace?.logo === null ? DEFAULT_WORKSPACE_LOGO : currentWorkspace?.logo, @@ -111,7 +111,7 @@ export const MultiWorkspaceDropdownButton = ({ avatar={ <StyledLogo logo={ - getImageAbsoluteURIOrBase64( + getImageAbsoluteURI( workspace.logo === null ? DEFAULT_WORKSPACE_LOGO : workspace.logo, diff --git a/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/constants/DefaultWorkspaceLogo.ts b/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/constants/DefaultWorkspaceLogo.ts index 7f58ca06ba31..7428bf82b1ec 100644 --- a/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/constants/DefaultWorkspaceLogo.ts +++ b/packages/twenty-front/src/modules/ui/navigation/navigation-drawer/constants/DefaultWorkspaceLogo.ts @@ -1,2 +1,2 @@ export const DEFAULT_WORKSPACE_LOGO = - ''; + 'https://twentyhq.github.io/placeholder-images/workspaces/twenty-logo.png'; diff --git a/packages/twenty-front/src/modules/users/components/UserChip.tsx b/packages/twenty-front/src/modules/users/components/UserChip.tsx index 5f4fbc94ebf3..a14f0ae4eb5a 100644 --- a/packages/twenty-front/src/modules/users/components/UserChip.tsx +++ b/packages/twenty-front/src/modules/users/components/UserChip.tsx @@ -1,6 +1,6 @@ import { AvatarChip } from 'twenty-ui'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; export type UserChipProps = { id: string; @@ -13,6 +13,6 @@ export const UserChip = ({ id, name, avatarUrl }: UserChipProps) => ( placeholderColorSeed={id} name={name} avatarType="rounded" - avatarUrl={getImageAbsoluteURIOrBase64(avatarUrl) || ''} + avatarUrl={getImageAbsoluteURI(avatarUrl) || ''} /> ); diff --git a/packages/twenty-front/src/modules/workspace/components/WorkspaceMemberCard.tsx b/packages/twenty-front/src/modules/workspace/components/WorkspaceMemberCard.tsx index 2fc774905ae0..94c9dcee1ac3 100644 --- a/packages/twenty-front/src/modules/workspace/components/WorkspaceMemberCard.tsx +++ b/packages/twenty-front/src/modules/workspace/components/WorkspaceMemberCard.tsx @@ -2,7 +2,7 @@ import styled from '@emotion/styled'; import { Avatar, OverflowingTextWithTooltip } from 'twenty-ui'; import { WorkspaceMember } from '@/workspace-member/types/WorkspaceMember'; -import { getImageAbsoluteURIOrBase64 } from '~/utils/image/getImageAbsoluteURIOrBase64'; +import { getImageAbsoluteURI } from '~/utils/image/getImageAbsoluteURI'; const StyledContainer = styled.div` background: ${({ theme }) => theme.background.secondary}; @@ -39,7 +39,7 @@ export const WorkspaceMemberCard = ({ }: WorkspaceMemberCardProps) => ( <StyledContainer> <Avatar - avatarUrl={getImageAbsoluteURIOrBase64(workspaceMember.avatarUrl)} + avatarUrl={getImageAbsoluteURI(workspaceMember.avatarUrl)} placeholderColorSeed={workspaceMember.id} placeholder={workspaceMember.name.firstName || ''} type="squared" diff --git a/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts b/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts new file mode 100644 index 000000000000..aea54c164869 --- /dev/null +++ b/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURI.test.ts @@ -0,0 +1,21 @@ +import { getImageAbsoluteURI } from '../getImageAbsoluteURI'; + +describe('getImageAbsoluteURI', () => { + it('should return null if imageUrl is null', () => { + const imageUrl = null; + const result = getImageAbsoluteURI(imageUrl); + expect(result).toBeNull(); + }); + + it('should return absolute url if the imageUrl is an absolute url', () => { + const imageUrl = 'https://XXX'; + const result = getImageAbsoluteURI(imageUrl); + expect(result).toBe(imageUrl); + }); + + it('should return fully formed url if imageUrl is a relative url', () => { + const imageUrl = 'XXX'; + const result = getImageAbsoluteURI(imageUrl); + expect(result).toBe('http://localhost:3000/files/XXX'); + }); +}); diff --git a/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURIOrBase64.test.ts b/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURIOrBase64.test.ts deleted file mode 100644 index 226aa6a0e598..000000000000 --- a/packages/twenty-front/src/utils/image/__tests__/getImageAbsoluteURIOrBase64.test.ts +++ /dev/null @@ -1,27 +0,0 @@ -import { getImageAbsoluteURIOrBase64 } from '../getImageAbsoluteURIOrBase64'; - -describe('getImageAbsoluteURIOrBase64', () => { - it('should return null if imageUrl is null', () => { - const imageUrl = null; - const result = getImageAbsoluteURIOrBase64(imageUrl); - expect(result).toBeNull(); - }); - - it('should return base64 encoded string if prefixed with data', () => { - const imageUrl = 'data:XXX'; - const result = getImageAbsoluteURIOrBase64(imageUrl); - expect(result).toBe(imageUrl); - }); - - it('should return absolute url if the imageUrl is an absolute url', () => { - const imageUrl = 'https://XXX'; - const result = getImageAbsoluteURIOrBase64(imageUrl); - expect(result).toBe(imageUrl); - }); - - it('should return fully formed url if imageUrl is a relative url', () => { - const imageUrl = 'XXX'; - const result = getImageAbsoluteURIOrBase64(imageUrl); - expect(result).toBe('http://localhost:3000/files/XXX'); - }); -}); diff --git a/packages/twenty-front/src/utils/image/getImageAbsoluteURIOrBase64.ts b/packages/twenty-front/src/utils/image/getImageAbsoluteURI.ts similarity index 60% rename from packages/twenty-front/src/utils/image/getImageAbsoluteURIOrBase64.ts rename to packages/twenty-front/src/utils/image/getImageAbsoluteURI.ts index 7f4ad3b3529d..6237813b78c7 100644 --- a/packages/twenty-front/src/utils/image/getImageAbsoluteURIOrBase64.ts +++ b/packages/twenty-front/src/utils/image/getImageAbsoluteURI.ts @@ -1,11 +1,11 @@ import { REACT_APP_SERVER_BASE_URL } from '~/config'; -export const getImageAbsoluteURIOrBase64 = (imageUrl?: string | null) => { +export const getImageAbsoluteURI = (imageUrl?: string | null) => { if (!imageUrl) { return null; } - if (imageUrl?.startsWith('data:') || imageUrl?.startsWith('https:')) { + if (imageUrl?.startsWith('https:')) { return imageUrl; } diff --git a/packages/twenty-server/src/database/typeorm-seeds/core/demo/workspaces.ts b/packages/twenty-server/src/database/typeorm-seeds/core/demo/workspaces.ts index 8778e721a39d..bc0b3c93b155 100644 --- a/packages/twenty-server/src/database/typeorm-seeds/core/demo/workspaces.ts +++ b/packages/twenty-server/src/database/typeorm-seeds/core/demo/workspaces.ts @@ -24,7 +24,7 @@ export const seedWorkspaces = async ( displayName: 'Demo', domainName: 'demo.dev', inviteHash: 'demo.dev-invite-hash', - logo: '', + logo: 'https://twentyhq.github.io/placeholder-images/workspaces/apple-logo.png', }, ]) .execute(); diff --git a/packages/twenty-server/src/database/typeorm-seeds/core/workspaces.ts b/packages/twenty-server/src/database/typeorm-seeds/core/workspaces.ts index 71fcea2d4bb6..54b2f4a85fd5 100644 --- a/packages/twenty-server/src/database/typeorm-seeds/core/workspaces.ts +++ b/packages/twenty-server/src/database/typeorm-seeds/core/workspaces.ts @@ -23,14 +23,14 @@ export const seedWorkspaces = async ( displayName: 'Apple', domainName: 'apple.dev', inviteHash: 'apple.dev-invite-hash', - logo: '', + logo: 'https://twentyhq.github.io/placeholder-images/workspaces/apple-logo.png', }, [SEED_TWENTY_WORKSPACE_ID]: { id: workspaceId, displayName: 'Twenty', domainName: 'twenty.dev', inviteHash: 'twenty.dev-invite-hash', - logo: '', + logo: 'https://twentyhq.github.io/placeholder-images/workspaces/twenty-logo.png', }, };