Files
twenty_crm/packages/twenty-front/src/utils/image/getImageAbsoluteURI.ts
2024-11-27 19:26:45 +01:00

27 lines
714 B
TypeScript

import { REACT_APP_SERVER_BASE_URL } from '~/config';
type ImageAbsoluteURI<T extends string | null | undefined> = T extends string
? string
: null;
export const getImageAbsoluteURI = <T extends string | null | undefined>(
imageUrl: T,
): ImageAbsoluteURI<T> => {
if (!imageUrl) {
return null as ImageAbsoluteURI<T>;
}
if (imageUrl.startsWith('https:') || imageUrl.startsWith('http:')) {
return imageUrl as ImageAbsoluteURI<T>;
}
const serverFilesUrl = new URL(REACT_APP_SERVER_BASE_URL);
serverFilesUrl.pathname = `/files/`;
serverFilesUrl.pathname += imageUrl.startsWith('/')
? imageUrl.slice(1)
: imageUrl;
return serverFilesUrl.toString() as ImageAbsoluteURI<T>;
};