2023-06-27 00:10:22 +00:00
|
|
|
import { act, renderHook } from '@testing-library/react';
|
2023-12-28 12:33:18 +00:00
|
|
|
import { STORAGE_KEY, useOrderListGridState } from './orders-container';
|
2023-06-27 00:10:22 +00:00
|
|
|
import { Filter } from '@vegaprotocol/orders';
|
|
|
|
import { OrderType } from '@vegaprotocol/types';
|
|
|
|
|
|
|
|
describe('useOrderListGridState', () => {
|
|
|
|
afterAll(() => {
|
|
|
|
localStorage.clear();
|
|
|
|
});
|
|
|
|
|
|
|
|
const setup = (filter: Filter | undefined) => {
|
|
|
|
return renderHook(() => useOrderListGridState(filter));
|
|
|
|
};
|
|
|
|
|
|
|
|
it.each(Object.values(Filter))(
|
|
|
|
'sets and stores column state and filters for %s',
|
|
|
|
(filter) => {
|
|
|
|
const filterModel = {
|
|
|
|
type: {
|
|
|
|
value: [OrderType.TYPE_LIMIT],
|
|
|
|
},
|
|
|
|
};
|
|
|
|
const { result } = setup(filter);
|
|
|
|
|
|
|
|
act(() => {
|
|
|
|
result.current.updateGridState(filter, {
|
|
|
|
filterModel,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(result.current.gridState).toEqual({
|
|
|
|
columnState: undefined,
|
2023-12-28 12:33:18 +00:00
|
|
|
filterModel,
|
2023-06-27 00:10:22 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
const columnState = [{ colId: 'status', width: 200 }];
|
|
|
|
|
|
|
|
act(() => {
|
|
|
|
result.current.updateGridState(filter, {
|
|
|
|
columnState,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(result.current.gridState).toEqual({
|
|
|
|
columnState,
|
2023-12-28 12:33:18 +00:00
|
|
|
filterModel,
|
2023-06-27 00:10:22 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
const storeKeyMap = {
|
|
|
|
[Filter.Open]: 'open',
|
|
|
|
[Filter.Rejected]: 'rejected',
|
|
|
|
[Filter.Closed]: 'closed',
|
|
|
|
};
|
|
|
|
|
|
|
|
expect(JSON.parse(localStorage.getItem(STORAGE_KEY) || '')).toMatchObject(
|
|
|
|
{
|
|
|
|
state: {
|
|
|
|
[storeKeyMap[filter]]: {
|
|
|
|
columnState,
|
|
|
|
filterModel, // no need to check that status is set, hook will return status
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|