# 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
24 lines
765 B
TypeScript
24 lines
765 B
TypeScript
import { objectMetadataItemsState } from '@/object-metadata/states/objectMetadataItemsState';
|
|
import { useRecoilValue } from 'recoil';
|
|
import { isDefined } from 'twenty-shared';
|
|
|
|
export const useGetFieldMetadataItemById = () => {
|
|
const objectMetadataItems = useRecoilValue(objectMetadataItemsState);
|
|
|
|
const getFieldMetadataItemById = (fieldMetadataId: string) => {
|
|
const fieldMetadataItem = objectMetadataItems
|
|
.flatMap((objectMetadataItem) => objectMetadataItem.fields)
|
|
.find((field) => field.id === fieldMetadataId);
|
|
|
|
if (!isDefined(fieldMetadataItem)) {
|
|
throw new Error(
|
|
`Field metadata item not found for id ${fieldMetadataId}`,
|
|
);
|
|
}
|
|
|
|
return fieldMetadataItem;
|
|
};
|
|
|
|
return { getFieldMetadataItemById };
|
|
};
|