mirror of
https://github.com/logos-blockchain/lez-programs.git
synced 2026-07-03 05:29:50 +00:00
99 lines
2.8 KiB
QML
99 lines
2.8 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
|
|
|
|
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.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.error
|
|
|
|
Behavior on height { NumberAnimation { duration: 150; easing.type: Easing.OutCubic } }
|
|
|
|
Text {
|
|
anchors.centerIn: parent
|
|
width: parent.width - 40
|
|
horizontalAlignment: Text.AlignHCenter
|
|
elide: Text.ElideMiddle
|
|
font.pixelSize: 12
|
|
font.weight: Font.Medium
|
|
color: Theme.palette.text
|
|
text: 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
|
|
visible: navbar.currentIndex === 0
|
|
}
|
|
|
|
LiquidityPage {
|
|
anchors.fill: parent
|
|
visible: navbar.currentIndex === 1
|
|
}
|
|
|
|
CreatePoolPage {
|
|
anchors.fill: parent
|
|
visible: navbar.currentIndex === 2
|
|
}
|
|
}
|
|
}
|