status-desktop/storybook/pages/PaymentRequestModalPage.qml
2024-12-04 11:19:27 -05:00

158 lines
4.8 KiB
QML

import QtQuick 2.15
import QtQuick.Controls 2.15
import QtQuick.Layouts 1.15
import SortFilterProxyModel 0.2
import QtTest 1.15
import StatusQ 0.1
import StatusQ.Controls 0.1
import StatusQ.Core 0.1
import StatusQ.Core.Backpressure 0.1
import StatusQ.Core.Utils 0.1
import utils 1.0
import Storybook 1.0
import Models 1.0
import mainui 1.0
import AppLayouts.Wallet.stores 1.0 as WalletStores
import AppLayouts.Wallet.adaptors 1.0
import AppLayouts.Chat.popups 1.0
import AppLayouts.stores 1.0 as AppLayoutStores
import shared.stores 1.0 as SharedStores
SplitView {
id: root
Logs { id: logs }
orientation: Qt.Horizontal
QtObject {
id: d
function launchPopup() {
const modal = paymentRequestModalComponent.createObject(root)
modal.open()
}
readonly property var accounts: WalletAccountsModel {}
readonly property var flatNetworks: NetworksModel.flatNetworks
readonly property string selectedAccountAddress: ctrlAccount.currentValue ?? ""
readonly property int selectedNetworkChainId: ctrlSelectedNetworkChainId.currentValue ?? -1
}
PopupBackground {
id: popupBg
SplitView.fillWidth: true
SplitView.fillHeight: true
Button {
id: reopenButton
anchors.centerIn: parent
text: "Reopen"
enabled: !paymentRequestModalComponent.visible
onClicked: d.launchPopup()
}
Component.onCompleted: Qt.callLater(d.launchPopup)
Component {
id: paymentRequestModalComponent
PaymentRequestModal {
id: paymentRequestModal
modal: false
closePolicy: Popup.CloseOnEscape
destroyOnClose: true
currentCurrency: currenciesStore.currentCurrency
formatCurrencyAmount: currenciesStore.formatCurrencyAmount
flatNetworksModel: d.flatNetworks
accountsModel: d.accounts
assetsModel: tokenAdaptor.outputAssetsModel
readonly property SharedStores.CurrenciesStore currenciesStore: SharedStores.CurrenciesStore {}
readonly property var tokenAdaptor: TokenSelectorViewAdaptor {
assetsModel: null
flatNetworksModel: d.flatNetworks
currentCurrency: paymentRequestModal.currentCurrency
plainTokensBySymbolModel: TokensBySymbolModel {}
showAllTokens: true
}
Connections {
target: d
function onSelectedNetworkChainIdChanged() {
paymentRequestModal.selectedNetworkChainId = d.selectedNetworkChainId
}
function onSelectedAccountAddressChanged() {
paymentRequestModal.selectedAccountAddress = d.selectedAccountAddress
}
}
Component.onCompleted: {
if (d.selectedNetworkChainId > -1)
paymentRequestModal.selectedNetworkChainId = d.selectedNetworkChainId
if (!!d.selectedAccountAddress)
paymentRequestModal.selectedAccountAddress = d.selectedAccountAddress
}
}
}
}
ScrollView {
id: rightPanel
SplitView.minimumWidth: 300
SplitView.preferredWidth: 300
SplitView.minimumHeight: 300
ColumnLayout {
anchors.top: parent.top
anchors.left: parent.left
anchors.margins: 10
spacing: 10
Label {
text: "pre-selection:"
}
RowLayout {
Layout.fillWidth: true
Label {
text: "Chain:"
}
ComboBox {
Layout.fillWidth: true
id: ctrlSelectedNetworkChainId
model: d.flatNetworks
textRole: "chainName"
valueRole: "chainId"
displayText: currentIndex === -1 ? "All chains" : currentText
currentIndex: -1 // all chains
}
}
RowLayout {
Layout.fillWidth: true
Label { text: "Account:" }
ComboBox {
Layout.fillWidth: true
id: ctrlAccount
textRole: "name"
valueRole: "address"
displayText: currentText || "----"
model: SortFilterProxyModel {
sourceModel: d.accounts
sorters: RoleSorter { roleName: "position" }
}
currentIndex: -1
}
}
}
}
}
// category: Popups