* Added generic relation cell * Deactivated debug * Added default warning * Put back display component * Removed unused types * wip * Renamed to view field * Use new view field structure to have chip working * Finished * Added a temp feature flag * Added double text chip cell * Ok * Finished tables * Fixed icon size * Fixed bug on date field * Use icon index * Fix * Fixed naming * Fix * removed file from merge * Fixed tests * Coverage
66 lines
2.3 KiB
TypeScript
66 lines
2.3 KiB
TypeScript
import { useRecoilCallback } from 'recoil';
|
|
|
|
import { availableFiltersScopedState } from '@/ui/filter-n-sort/states/availableFiltersScopedState';
|
|
import { FilterDefinition } from '@/ui/filter-n-sort/types/FilterDefinition';
|
|
import { useContextScopeId } from '@/ui/recoil-scope/hooks/useContextScopeId';
|
|
import { useResetTableRowSelection } from '@/ui/table/hooks/useResetTableRowSelection';
|
|
import { entityTableDimensionsState } from '@/ui/table/states/entityTableDimensionsState';
|
|
import { isFetchingEntityTableDataState } from '@/ui/table/states/isFetchingEntityTableDataState';
|
|
import { TableContext } from '@/ui/table/states/TableContext';
|
|
import { tableEntitiesFamilyState } from '@/ui/table/states/tableEntitiesFamilyState';
|
|
import { tableRowIdsState } from '@/ui/table/states/tableRowIdsState';
|
|
import { viewFieldsFamilyState } from '@/ui/table/states/viewFieldsState';
|
|
import {
|
|
ViewFieldDefinition,
|
|
ViewFieldMetadata,
|
|
} from '@/ui/table/types/ViewField';
|
|
|
|
export function useSetEntityTableData() {
|
|
const resetTableRowSelection = useResetTableRowSelection();
|
|
|
|
const tableContextScopeId = useContextScopeId(TableContext);
|
|
|
|
return useRecoilCallback(
|
|
({ set, snapshot }) =>
|
|
<T extends { id: string }>(
|
|
newEntityArray: T[],
|
|
viewFields: ViewFieldDefinition<ViewFieldMetadata>[],
|
|
filters: FilterDefinition[],
|
|
) => {
|
|
for (const entity of newEntityArray) {
|
|
const currentEntity = snapshot
|
|
.getLoadable(tableEntitiesFamilyState(entity.id))
|
|
.valueOrThrow();
|
|
|
|
if (JSON.stringify(currentEntity) !== JSON.stringify(entity)) {
|
|
set(tableEntitiesFamilyState(entity.id), entity);
|
|
}
|
|
}
|
|
|
|
const entityIds = newEntityArray.map((entity) => entity.id);
|
|
|
|
set(tableRowIdsState, (currentRowIds) => {
|
|
if (JSON.stringify(currentRowIds) !== JSON.stringify(entityIds)) {
|
|
return entityIds;
|
|
}
|
|
|
|
return currentRowIds;
|
|
});
|
|
|
|
resetTableRowSelection();
|
|
|
|
set(entityTableDimensionsState, {
|
|
numberOfColumns: viewFields.length,
|
|
numberOfRows: entityIds.length,
|
|
});
|
|
|
|
set(availableFiltersScopedState(tableContextScopeId), filters);
|
|
|
|
set(viewFieldsFamilyState, viewFields);
|
|
|
|
set(isFetchingEntityTableDataState, false);
|
|
},
|
|
[],
|
|
);
|
|
}
|