2026-06-30 11:59:27 -03:00

124 lines
4.6 KiB
QML

import QtQuick 2.15
import QtQuick.Controls 2.15
import QtQuick.Layouts 1.15
import Logos.Theme
import "pages"
Item {
id: root
// Backend replica + account model, bridged from the C++ backend.
readonly property var backend: logos.module("amm_ui")
readonly property var accountModel: logos.model("amm_ui", "accountModel")
property bool ready: false
readonly property bool deploymentNetworkMatched: !root.ready || !root.backend || root.backend.deploymentNetworkMatched
readonly property bool deploymentIdentityPending: root.ready
&& root.backend
&& root.backend.isWalletOpen
&& root.backend.deploymentIdentityPending
readonly property bool unsupportedChain: root.ready
&& root.backend
&& root.backend.isWalletOpen
&& !root.backend.deploymentIdentityPending
&& !root.backend.deploymentNetworkMatched
readonly property var deploymentTokens: root.deploymentNetworkMatched && root.backend ? root.backend.deploymentTokens : []
readonly property var deploymentPoolConfig: root.deploymentNetworkMatched && root.backend ? root.backend.deploymentPool : ({})
Connections {
target: logos
function onViewModuleReadyChanged(moduleName, isReady) {
if (moduleName === "amm_ui")
root.ready = isReady && root.backend !== null
}
}
Component.onCompleted: {
root.ready = root.backend !== null && logos.isViewModuleReady("amm_ui")
}
// Connectivity banner: shown when a wallet is open but its configured
// sequencer doesn't answer reachability probes (so transactions will fail).
Rectangle {
id: connectionBanner
anchors.top: parent.top
anchors.left: parent.left
anchors.right: parent.right
z: 101
readonly property bool show: root.deploymentIdentityPending
|| root.unsupportedChain
|| (root.ready
&& root.backend
&& root.backend.isWalletOpen
&& root.backend.sequencerAddr.length > 0
&& !root.backend.sequencerReachable)
height: show ? 32 : 0
visible: height > 0
clip: true
color: Theme.palette.warning
Accessible.role: Accessible.AlertMessage
Accessible.name: bannerText.text
Behavior on height { NumberAnimation { duration: 150; easing.type: Easing.OutCubic } }
Text {
id: bannerText
anchors.centerIn: parent
width: parent.width - 40
horizontalAlignment: Text.AlignHCenter
elide: Text.ElideMiddle
font.pixelSize: 12
font.weight: Font.Medium
color: Theme.palette.background
text: root.deploymentIdentityPending
? qsTr("Checking chain")
: root.unsupportedChain
? qsTr("Unsupported chain")
: qsTr("Unable to connect to network")
}
}
// The app is always usable; the wallet is opt-in via the navbar "Connect"
// control. Trade/Liquidity render immediately on launch.
NavBar {
id: navbar
anchors.top: connectionBanner.bottom
anchors.left: parent.left
anchors.right: parent.right
z: 100
backend: root.ready ? root.backend : null
accountModel: root.accountModel
}
Item {
anchors.top: navbar.bottom
anchors.left: parent.left
anchors.right: parent.right
anchors.bottom: parent.bottom
SwapPage {
anchors.fill: parent
backend: root.ready ? root.backend : null
tokens: root.deploymentTokens
poolConfig: root.deploymentPoolConfig
unsupportedChain: root.unsupportedChain
selectedWalletAccount: navbar.selectedAddress
visible: navbar.currentIndex === 0
}
LiquidityPage {
anchors.fill: parent
backend: root.ready ? root.backend : null
poolConfig: root.deploymentPoolConfig
unsupportedChain: root.unsupportedChain
selectedWalletAccount: navbar.selectedAddress
visible: navbar.currentIndex === 1
}
}
}