'use client' import React, { useState, useEffect } from 'react' export default function AutomationPage() { // Available timeframes for automation const timeframes = [ { label: '5m', value: '5' }, { label: '15m', value: '15' }, { label: '30m', value: '30' }, { label: '1h', value: '60' }, { label: '2h', value: '120' }, { label: '4h', value: '240' }, { label: '1d', value: 'D' }, ] const [config, setConfig] = useState({ mode: 'SIMULATION', dexProvider: 'DRIFT', symbol: 'SOLUSD', timeframe: '1h', selectedTimeframes: ['60'], // Multi-timeframe support tradingAmount: 100, maxLeverage: 5, stopLossPercent: 2, takeProfitPercent: 6, riskPercentage: 2 }) const [status, setStatus] = useState(null) const [balance, setBalance] = useState(null) const [positions, setPositions] = useState([]) const [isLoading, setIsLoading] = useState(false) const [balanceLoading, setBalanceLoading] = useState(false) useEffect(() => { fetchStatus() fetchBalance() fetchPositions() const interval = setInterval(() => { fetchStatus() fetchBalance() fetchPositions() }, 30000) return () => clearInterval(interval) }, []) const toggleTimeframe = (timeframe) => { setConfig(prev => ({ ...prev, selectedTimeframes: prev.selectedTimeframes.includes(timeframe) ? prev.selectedTimeframes.filter(tf => tf !== timeframe) : [...prev.selectedTimeframes, timeframe] })) } const fetchStatus = async () => { try { const response = await fetch('/api/automation/status') const data = await response.json() if (data.success) { setStatus(data.status) } } catch (error) { console.error('Failed to fetch status:', error) } } const fetchBalance = async () => { if (config.dexProvider !== 'DRIFT') return setBalanceLoading(true) try { const response = await fetch('/api/drift/balance') const data = await response.json() if (data.success) { setBalance(data) // Auto-calculate position size based on available balance and leverage const maxPositionSize = (data.availableBalance * config.maxLeverage) * 0.9 // Use 90% of max const suggestedSize = Math.max(10, Math.min(maxPositionSize, config.tradingAmount)) setConfig(prev => ({ ...prev, tradingAmount: Math.round(suggestedSize) })) } } catch (error) { console.error('Failed to fetch balance:', error) } finally { setBalanceLoading(false) } } const fetchPositions = async () => { if (config.dexProvider !== 'DRIFT') return try { const response = await fetch('/api/drift/positions') const data = await response.json() if (data.success) { setPositions(data.positions || []) } } catch (error) { console.error('Failed to fetch positions:', error) } } const handleLeverageChange = (newLeverage) => { const leverage = parseFloat(newLeverage) // Auto-calculate position size when leverage changes if (balance?.availableBalance) { const maxPositionSize = (balance.availableBalance * leverage) * 0.9 // Use 90% of max const suggestedSize = Math.max(10, maxPositionSize) setConfig(prev => ({ ...prev, maxLeverage: leverage, tradingAmount: Math.round(suggestedSize) })) } else { setConfig(prev => ({ ...prev, maxLeverage: leverage })) } } const hasOpenPosition = positions.some(pos => pos.symbol.includes(config.symbol.replace('USD', '')) && pos.size > 0.001 ) const handleStart = async () => { setIsLoading(true) try { const response = await fetch('/api/automation/start', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify(config) }) const data = await response.json() if (data.success) { fetchStatus() } else { alert('Failed to start automation: ' + data.error) } } catch (error) { console.error('Failed to start automation:', error) alert('Failed to start automation') } finally { setIsLoading(false) } } const handleStop = async () => { setIsLoading(true) try { const response = await fetch('/api/automation/stop', { method: 'POST' }) const data = await response.json() if (data.success) { fetchStatus() } else { alert('Failed to stop automation: ' + data.error) } } catch (error) { console.error('Failed to stop automation:', error) alert('Failed to stop automation') } finally { setIsLoading(false) } } return (
Drift Protocol
Loading...
)}