Stage 05.1 - order draft flow

This commit is contained in:
2026-04-16 21:23:35 +03:00
parent 76fc122955
commit f662ff1901
9 changed files with 185 additions and 2 deletions

View File

@@ -0,0 +1 @@
"""Package marker."""

View File

@@ -0,0 +1,18 @@
from __future__ import annotations
from aiogram import F, Router
from aiogram.types import Message
router = Router(name="trade_main")
@router.message(F.text == "⚡ Торговля")
async def open_trade(message: Message) -> None:
text = (
"<b>⚡ Торговля</b>\n\n"
"Доступные действия:\n"
"• /new_order — создать черновик ордера\n"
"• /drafts — показать последние черновики\n\n"
"На этом этапе реальные ордера ещё не отправляются."
)
await message.answer(text)

View File

@@ -0,0 +1,53 @@
from __future__ import annotations
from aiogram import Router
from aiogram.filters import Command
from aiogram.types import Message
from src.trading.orders.service import OrderDraftsService
router = Router(name="trade_new_order")
@router.message(Command("new_order"))
async def create_new_order_draft(message: Message) -> None:
service = OrderDraftsService()
draft = service.create_default_draft()
text = (
"<b>📝 Черновик ордера создан</b>\n\n"
f"• инструмент: {draft.symbol}\n"
f"• сторона: {draft.side}\n"
f"• тип: {draft.order_type}\n"
f"• количество: {draft.quantity}\n"
f"• статус: {draft.status}\n\n"
"Это тестовый draft flow. Реальный ордер не отправлялся."
)
await message.answer(text)
@router.message(Command("drafts"))
async def show_recent_drafts(message: Message) -> None:
service = OrderDraftsService()
drafts = service.list_recent_drafts(limit=5)
if not drafts:
await message.answer(
"<b>📝 Черновики ордеров</b>\n\n"
"Черновиков пока нет."
)
return
lines = ["<b>📝 Черновики ордеров</b>", "", "<b>Последние записи</b>", ""]
for item in drafts:
lines.extend(
[
f"{item['symbol']} | {item['side']} | {item['order_type']}",
f" qty: {item['quantity']} | status: {item['status']}",
f" time: {item['created_at']}",
"",
]
)
await message.answer("\n".join(lines).rstrip())

View File

@@ -7,7 +7,8 @@ from src.telegram.handlers.market import router as market_router
from src.telegram.handlers.portfolio import router as portfolio_router
from src.telegram.handlers.start import router as start_router
from src.telegram.handlers.system import router as system_router
from src.telegram.handlers.trade import router as trade_router
from src.telegram.handlers.trade.main import router as trade_main_router
from src.telegram.handlers.trade.new_order import router as trade_new_order_router
def setup_routers(dispatcher: Dispatcher) -> None:
@@ -15,7 +16,8 @@ def setup_routers(dispatcher: Dispatcher) -> None:
dispatcher.include_router(home_router)
dispatcher.include_router(market_router)
dispatcher.include_router(portfolio_router)
dispatcher.include_router(trade_router)
dispatcher.include_router(trade_main_router)
dispatcher.include_router(trade_new_order_router)
dispatcher.include_router(auto_router)
dispatcher.include_router(journal_router)
dispatcher.include_router(system_router)