2021-09-14 12:24:47 +00:00
|
|
|
import QtQuick 2.13
|
2021-09-14 16:23:02 +00:00
|
|
|
import "../../../../shared"
|
2021-10-14 12:14:11 +00:00
|
|
|
import "../../../../shared/panels"
|
2021-09-28 15:04:06 +00:00
|
|
|
|
|
|
|
import utils 1.0
|
2021-09-14 16:23:02 +00:00
|
|
|
import "../popups"
|
2021-09-14 12:24:47 +00:00
|
|
|
|
|
|
|
Item {
|
|
|
|
id: root
|
2021-09-08 15:41:38 +00:00
|
|
|
width: selectRectangle.width
|
|
|
|
height: childrenRect.height
|
2021-09-14 16:23:02 +00:00
|
|
|
property var allNetworks
|
|
|
|
property var enabledNetworks
|
2021-09-23 14:40:05 +00:00
|
|
|
signal toggleNetwork(int chainId)
|
2021-09-14 12:24:47 +00:00
|
|
|
|
|
|
|
Rectangle {
|
|
|
|
id: selectRectangle
|
|
|
|
border.width: 1
|
|
|
|
border.color: Style.current.border
|
|
|
|
radius: Style.current.radius
|
|
|
|
width: text.width + Style.current.padding * 4
|
|
|
|
height: text.height + Style.current.padding
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: text
|
|
|
|
text: qsTr("All networks")
|
|
|
|
anchors.left: parent.left
|
|
|
|
anchors.leftMargin: Style.current.padding
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
font.pixelSize: Style.current.primaryTextFontSize
|
|
|
|
}
|
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
id: caretImg
|
|
|
|
width: 10
|
|
|
|
height: 6
|
2021-09-28 15:04:06 +00:00
|
|
|
source: Style.svg("caret")
|
2021-09-14 12:24:47 +00:00
|
|
|
anchors.right: parent.right
|
|
|
|
anchors.rightMargin: Style.current.padding
|
|
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
|
|
fillMode: Image.PreserveAspectFit
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: selectRectangle
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
|
|
|
onClicked: {
|
|
|
|
if (selectPopup.opened) {
|
2021-09-14 16:23:02 +00:00
|
|
|
selectPopup.close();
|
|
|
|
return;
|
2021-09-14 12:24:47 +00:00
|
|
|
}
|
2021-09-14 16:23:02 +00:00
|
|
|
selectPopup.open();
|
2021-09-14 12:24:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-14 16:23:02 +00:00
|
|
|
|
|
|
|
NetworkFilterPanel {
|
|
|
|
id: networkFilterPanel
|
|
|
|
width: root.width
|
2021-09-14 12:24:47 +00:00
|
|
|
anchors.topMargin: Style.current.halfPadding
|
|
|
|
anchors.top: selectRectangle.bottom
|
2021-09-14 16:23:02 +00:00
|
|
|
model: root.enabledNetworks
|
2021-09-14 12:24:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
NetworkSelectPopup {
|
|
|
|
id: selectPopup
|
2021-09-08 15:41:38 +00:00
|
|
|
x: (parent.width - width)
|
2021-09-14 16:23:02 +00:00
|
|
|
y: (root.height - networkFilterPanel.height)
|
|
|
|
model: root.allNetworks
|
2021-09-23 14:40:05 +00:00
|
|
|
onToggleNetwork: {
|
|
|
|
root.toggleNetwork(chainId)
|
|
|
|
}
|
2021-09-14 12:24:47 +00:00
|
|
|
}
|
2021-09-08 15:41:38 +00:00
|
|
|
}
|