- Fix default value sent to backend, using single quotes by default - Use default value in field definition and column definition so that field inputs can access it - Used currency default value in CurrencyFieldInput --------- Co-authored-by: Charles Bochet <charles@twenty.com>
71 lines
2.7 KiB
TypeScript
71 lines
2.7 KiB
TypeScript
import { FieldMetadata } from '@/object-record/record-field/types/FieldMetadata';
|
|
import { ColumnDefinition } from '@/object-record/record-table/types/ColumnDefinition';
|
|
import { mapArrayToObject } from '~/utils/array/mapArrayToObject';
|
|
import { moveArrayItem } from '~/utils/array/moveArrayItem';
|
|
import { isDefined } from '~/utils/isDefined';
|
|
import { isUndefinedOrNull } from '~/utils/isUndefinedOrNull';
|
|
|
|
import { ViewField } from '../types/ViewField';
|
|
|
|
export const mapViewFieldsToColumnDefinitions = ({
|
|
columnDefinitions,
|
|
viewFields,
|
|
}: {
|
|
columnDefinitions: ColumnDefinition<FieldMetadata>[];
|
|
viewFields: ViewField[];
|
|
}): ColumnDefinition<FieldMetadata>[] => {
|
|
let labelIdentifierFieldMetadataId = '';
|
|
|
|
const columnDefinitionsByFieldMetadataId = mapArrayToObject(
|
|
columnDefinitions,
|
|
({ fieldMetadataId }) => fieldMetadataId,
|
|
);
|
|
|
|
const columnDefinitionsFromViewFields = viewFields
|
|
.map((viewField) => {
|
|
const correspondingColumnDefinition =
|
|
columnDefinitionsByFieldMetadataId[viewField.fieldMetadataId];
|
|
|
|
if (isUndefinedOrNull(correspondingColumnDefinition)) return null;
|
|
|
|
const { isLabelIdentifier } = correspondingColumnDefinition;
|
|
|
|
if (isLabelIdentifier === true) {
|
|
labelIdentifierFieldMetadataId =
|
|
correspondingColumnDefinition.fieldMetadataId;
|
|
}
|
|
|
|
return {
|
|
fieldMetadataId: viewField.fieldMetadataId,
|
|
label: correspondingColumnDefinition.label,
|
|
metadata: correspondingColumnDefinition.metadata,
|
|
infoTooltipContent: correspondingColumnDefinition.infoTooltipContent,
|
|
iconName: correspondingColumnDefinition.iconName,
|
|
type: correspondingColumnDefinition.type,
|
|
position: isLabelIdentifier ? 0 : viewField.position,
|
|
size: viewField.size ?? correspondingColumnDefinition.size,
|
|
isLabelIdentifier,
|
|
isVisible: isLabelIdentifier || viewField.isVisible,
|
|
viewFieldId: viewField.id,
|
|
isSortable: correspondingColumnDefinition.isSortable,
|
|
isFilterable: correspondingColumnDefinition.isFilterable,
|
|
defaultValue: correspondingColumnDefinition.defaultValue,
|
|
} as ColumnDefinition<FieldMetadata>;
|
|
})
|
|
.filter(isDefined);
|
|
|
|
// No label identifier set for this object
|
|
if (!labelIdentifierFieldMetadataId) return columnDefinitionsFromViewFields;
|
|
|
|
const labelIdentifierIndex = columnDefinitionsFromViewFields.findIndex(
|
|
({ fieldMetadataId }) => fieldMetadataId === labelIdentifierFieldMetadataId,
|
|
);
|
|
|
|
// Label identifier field found in view fields
|
|
// => move it to the start of the list
|
|
return moveArrayItem(columnDefinitionsFromViewFields, {
|
|
fromIndex: labelIdentifierIndex,
|
|
toIndex: 0,
|
|
});
|
|
};
|