# Introduction Avoid having multiple `isDefined` definition across our pacakges Also avoid importing `isDefined` from `twenty-ui` which exposes a huge barrel for a such little util function ## In a nutshell Removed own `isDefined.ts` definition from `twenty-ui` `twenty-front` and `twenty-server` to move it to `twenty-shared`. Updated imports for each packages, and added explicit dependencies to `twenty-shared` if not already in place Related PR https://github.com/twentyhq/twenty/pull/9941
46 lines
1.5 KiB
TypeScript
46 lines
1.5 KiB
TypeScript
import { Company } from '@/companies/types/Company';
|
|
import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular';
|
|
import { FieldMetadataItem } from '@/object-metadata/types/FieldMetadataItem';
|
|
import { getCompanyDomainName } from '@/object-metadata/utils/getCompanyDomainName';
|
|
import { ObjectRecord } from '@/object-record/types/ObjectRecord';
|
|
import { getImageAbsoluteURI, isDefined } from 'twenty-shared';
|
|
import { REACT_APP_SERVER_BASE_URL } from '~/config';
|
|
import { getLogoUrlFromDomainName } from '~/utils';
|
|
import { getImageIdentifierFieldValue } from './getImageIdentifierFieldValue';
|
|
|
|
export const getAvatarUrl = (
|
|
objectNameSingular: string,
|
|
record: ObjectRecord,
|
|
imageIdentifierFieldMetadataItem: FieldMetadataItem | undefined,
|
|
) => {
|
|
if (objectNameSingular === CoreObjectNameSingular.WorkspaceMember) {
|
|
return record.avatarUrl ?? undefined;
|
|
}
|
|
|
|
if (objectNameSingular === CoreObjectNameSingular.Company) {
|
|
return getLogoUrlFromDomainName(
|
|
getCompanyDomainName(record as Company) ?? '',
|
|
);
|
|
}
|
|
|
|
if (objectNameSingular === CoreObjectNameSingular.Person) {
|
|
return isDefined(record.avatarUrl)
|
|
? getImageAbsoluteURI({
|
|
imageUrl: record.avatarUrl,
|
|
baseUrl: REACT_APP_SERVER_BASE_URL,
|
|
})
|
|
: '';
|
|
}
|
|
|
|
const imageIdentifierFieldValue = getImageIdentifierFieldValue(
|
|
record,
|
|
imageIdentifierFieldMetadataItem,
|
|
);
|
|
|
|
if (isDefined(imageIdentifierFieldValue)) {
|
|
return imageIdentifierFieldValue;
|
|
}
|
|
|
|
return '';
|
|
};
|