mirror of
https://github.com/logos-blockchain/lez-programs.git
synced 2026-07-03 05:29:50 +00:00
106 lines
3.1 KiB
QML
106 lines
3.1 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import Logos.Theme
|
|
|
|
import "components/wallet"
|
|
|
|
// Self-contained navigation bar — styling is independent of any view's theme.
|
|
// Use currentIndex to read the active tab; tabChanged(index) fires on selection.
|
|
Item {
|
|
id: root
|
|
|
|
property int currentIndex: 0
|
|
readonly property var tabs: ["Trade", "Liquidity", "Create Pool"]
|
|
|
|
// Wallet wiring, passed down from Main.qml.
|
|
property var backend: null
|
|
property var accountModel: null
|
|
|
|
// Address of the account currently selected in the header control.
|
|
readonly property string selectedAddress: accountControl.selectedAddress
|
|
|
|
signal tabChanged(int index)
|
|
|
|
implicitHeight: 56
|
|
|
|
Rectangle {
|
|
anchors.fill: parent
|
|
color: Theme.palette.background
|
|
|
|
// Bottom separator
|
|
Rectangle {
|
|
anchors.left: parent.left
|
|
anchors.right: parent.right
|
|
anchors.bottom: parent.bottom
|
|
height: 1
|
|
color: Theme.palette.borderSecondary
|
|
}
|
|
|
|
RowLayout {
|
|
anchors.fill: parent
|
|
anchors.leftMargin: 20
|
|
anchors.rightMargin: 20
|
|
spacing: 4
|
|
|
|
// App identity
|
|
Text {
|
|
text: "Logos AMM"
|
|
color: Theme.palette.text
|
|
font.pixelSize: 17
|
|
font.weight: Font.Bold
|
|
}
|
|
|
|
Item { Layout.fillWidth: true }
|
|
|
|
// Tab pills
|
|
Row {
|
|
spacing: 4
|
|
|
|
Repeater {
|
|
model: root.tabs
|
|
|
|
delegate: Rectangle {
|
|
readonly property bool active: root.currentIndex === index
|
|
|
|
height: 36
|
|
width: tabLabel.implicitWidth + 28
|
|
radius: 18
|
|
color: active ? Theme.palette.backgroundSecondary : "transparent"
|
|
|
|
Behavior on color { ColorAnimation { duration: 150 } }
|
|
|
|
Text {
|
|
id: tabLabel
|
|
anchors.centerIn: parent
|
|
text: modelData
|
|
color: active ? Theme.palette.text : Theme.palette.textSecondary
|
|
font.pixelSize: 14
|
|
font.weight: active ? Font.Medium : Font.Normal
|
|
|
|
Behavior on color { ColorAnimation { duration: 150 } }
|
|
}
|
|
|
|
MouseArea {
|
|
anchors.fill: parent
|
|
cursorShape: Qt.PointingHandCursor
|
|
onClicked: {
|
|
root.currentIndex = index
|
|
root.tabChanged(index)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Wallet / account control on the far right.
|
|
AccountControl {
|
|
id: accountControl
|
|
Layout.leftMargin: 12
|
|
backend: root.backend
|
|
accountModel: root.accountModel
|
|
}
|
|
}
|
|
}
|
|
}
|