2023-07-24 08:37:18 +00:00
|
|
|
import { OrderbookManager } from '@vegaprotocol/market-depth';
|
|
|
|
import { useCreateOrderStore } from '@vegaprotocol/orders';
|
|
|
|
import { ViewType, useSidebar } from '../sidebar';
|
2023-08-02 10:28:33 +00:00
|
|
|
import { useStopOrderFormValues } from '@vegaprotocol/deal-ticket';
|
2023-07-24 08:37:18 +00:00
|
|
|
|
|
|
|
export const OrderbookContainer = ({ marketId }: { marketId: string }) => {
|
|
|
|
const useOrderStoreRef = useCreateOrderStore();
|
|
|
|
const updateOrder = useOrderStoreRef((store) => store.update);
|
2023-08-02 10:28:33 +00:00
|
|
|
const updateStoredFormValues = useStopOrderFormValues(
|
|
|
|
(state) => state.update
|
|
|
|
);
|
2023-07-24 08:37:18 +00:00
|
|
|
const setView = useSidebar((store) => store.setView);
|
|
|
|
return (
|
|
|
|
<OrderbookManager
|
|
|
|
marketId={marketId}
|
|
|
|
onClick={({ price, size }) => {
|
|
|
|
if (price) {
|
|
|
|
updateOrder(marketId, { price });
|
2023-08-02 10:28:33 +00:00
|
|
|
updateStoredFormValues(marketId, { price });
|
2023-07-24 08:37:18 +00:00
|
|
|
}
|
|
|
|
if (size) {
|
|
|
|
updateOrder(marketId, { size });
|
2023-08-02 10:28:33 +00:00
|
|
|
updateStoredFormValues(marketId, { size });
|
2023-07-24 08:37:18 +00:00
|
|
|
}
|
|
|
|
setView({ type: ViewType.Order });
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|