## Query depth deprecation I'm deprecating depth parameter in our graphql query / cache tooling. They were obsolete since we introduce the possibility to provide RecordGqlFields ## Refactor combinedFindManyRecordHook The hook can now take an array of operationSignatures ## Fix tasks issues Fix optimistic rendering issue. Note that we still haven't handle optimisticEffect on creation properly
129 lines
2.9 KiB
TypeScript
129 lines
2.9 KiB
TypeScript
import { isUndefined } from '@sniptt/guards';
|
|
|
|
import { ObjectMetadataItem } from '@/object-metadata/types/ObjectMetadataItem';
|
|
import { mapObjectMetadataToGraphQLQuery } from '@/object-metadata/utils/mapObjectMetadataToGraphQLQuery';
|
|
import { FieldMetadataType } from '~/generated-metadata/graphql';
|
|
|
|
import { FieldMetadataItem } from '../types/FieldMetadataItem';
|
|
|
|
// TODO: change ObjectMetadataItems mock before refactoring with relationDefinition computed field
|
|
export const mapFieldMetadataToGraphQLQuery = ({
|
|
objectMetadataItems,
|
|
field,
|
|
relationrecordFields,
|
|
computeReferences = false,
|
|
}: {
|
|
objectMetadataItems: ObjectMetadataItem[];
|
|
field: Pick<
|
|
FieldMetadataItem,
|
|
'name' | 'type' | 'toRelationMetadata' | 'fromRelationMetadata'
|
|
>;
|
|
relationrecordFields?: Record<string, any>;
|
|
computeReferences?: boolean;
|
|
}): any => {
|
|
const fieldType = field.type;
|
|
|
|
const fieldIsSimpleValue = (
|
|
[
|
|
'UUID',
|
|
'TEXT',
|
|
'PHONE',
|
|
'DATE_TIME',
|
|
'DATE',
|
|
'EMAIL',
|
|
'NUMBER',
|
|
'BOOLEAN',
|
|
'RATING',
|
|
'SELECT',
|
|
'MULTI_SELECT',
|
|
'POSITION',
|
|
'RAW_JSON',
|
|
] as FieldMetadataType[]
|
|
).includes(fieldType);
|
|
|
|
if (fieldIsSimpleValue) {
|
|
return field.name;
|
|
} else if (
|
|
fieldType === 'RELATION' &&
|
|
field.toRelationMetadata?.relationType === 'ONE_TO_MANY'
|
|
) {
|
|
const relationMetadataItem = objectMetadataItems.find(
|
|
(objectMetadataItem) =>
|
|
objectMetadataItem.id ===
|
|
(field.toRelationMetadata as any)?.fromObjectMetadata?.id,
|
|
);
|
|
|
|
if (isUndefined(relationMetadataItem)) {
|
|
return '';
|
|
}
|
|
|
|
return `${field.name}
|
|
${mapObjectMetadataToGraphQLQuery({
|
|
objectMetadataItems,
|
|
objectMetadataItem: relationMetadataItem,
|
|
recordGqlFields: relationrecordFields,
|
|
computeReferences: computeReferences,
|
|
isRootLevel: false,
|
|
})}`;
|
|
} else if (
|
|
fieldType === 'RELATION' &&
|
|
field.fromRelationMetadata?.relationType === 'ONE_TO_MANY'
|
|
) {
|
|
const relationMetadataItem = objectMetadataItems.find(
|
|
(objectMetadataItem) =>
|
|
objectMetadataItem.id ===
|
|
(field.fromRelationMetadata as any)?.toObjectMetadata?.id,
|
|
);
|
|
|
|
if (isUndefined(relationMetadataItem)) {
|
|
return '';
|
|
}
|
|
|
|
return `${field.name}
|
|
{
|
|
edges {
|
|
node ${mapObjectMetadataToGraphQLQuery({
|
|
objectMetadataItems,
|
|
objectMetadataItem: relationMetadataItem,
|
|
recordGqlFields: relationrecordFields,
|
|
computeReferences,
|
|
isRootLevel: false,
|
|
})}
|
|
}
|
|
}`;
|
|
} else if (fieldType === 'LINK') {
|
|
return `${field.name}
|
|
{
|
|
label
|
|
url
|
|
}`;
|
|
} else if (fieldType === 'CURRENCY') {
|
|
return `${field.name}
|
|
{
|
|
amountMicros
|
|
currencyCode
|
|
}
|
|
`;
|
|
} else if (fieldType === 'FULL_NAME') {
|
|
return `${field.name}
|
|
{
|
|
firstName
|
|
lastName
|
|
}`;
|
|
} else if (fieldType === 'ADDRESS') {
|
|
return `${field.name}
|
|
{
|
|
addressStreet1
|
|
addressStreet2
|
|
addressCity
|
|
addressState
|
|
addressCountry
|
|
addressPostcode
|
|
addressLat
|
|
addressLng
|
|
}`;
|
|
}
|
|
|
|
return '';
|
|
};
|