# 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
28 lines
809 B
TypeScript
28 lines
809 B
TypeScript
import { CoreObjectNameSingular } from '@/object-metadata/types/CoreObjectNameSingular';
|
|
import { useUpdateOneRecord } from '@/object-record/hooks/useUpdateOneRecord';
|
|
import { ViewField } from '@/views/types/ViewField';
|
|
import { useRecoilCallback } from 'recoil';
|
|
import { isDefined } from 'twenty-shared';
|
|
|
|
export const useUpdateViewField = () => {
|
|
const { updateOneRecord } = useUpdateOneRecord({
|
|
objectNameSingular: CoreObjectNameSingular.ViewField,
|
|
});
|
|
|
|
const updateViewField = useRecoilCallback(
|
|
() => async (viewField: Partial<ViewField>) => {
|
|
if (isDefined(viewField.id)) {
|
|
await updateOneRecord({
|
|
idToUpdate: viewField.id,
|
|
updateOneRecordInput: viewField,
|
|
});
|
|
}
|
|
},
|
|
[updateOneRecord],
|
|
);
|
|
|
|
return {
|
|
updateViewField,
|
|
};
|
|
};
|