2024-05-27 18:55:43 +02:00
|
|
|
import QtQuick 2.15
|
|
|
|
import QtQuick.Controls 2.15
|
2024-08-06 18:04:22 +02:00
|
|
|
import QtQuick.Layouts 1.15
|
2024-05-27 18:55:43 +02:00
|
|
|
|
|
|
|
import Storybook 1.0
|
|
|
|
import Models 1.0
|
|
|
|
|
2024-08-13 14:03:35 +02:00
|
|
|
import StatusQ 0.1
|
2024-08-06 18:04:22 +02:00
|
|
|
import StatusQ.Core.Backpressure 0.1
|
|
|
|
|
|
|
|
import AppLayouts.Wallet.popups.buy 1.0
|
|
|
|
import AppLayouts.Wallet.stores 1.0
|
2024-08-13 14:03:35 +02:00
|
|
|
import AppLayouts.Wallet.adaptors 1.0
|
2024-08-06 18:04:22 +02:00
|
|
|
|
|
|
|
import shared.stores 1.0
|
2024-05-27 18:55:43 +02:00
|
|
|
|
|
|
|
SplitView {
|
|
|
|
id: root
|
|
|
|
|
|
|
|
orientation: Qt.Horizontal
|
|
|
|
|
2024-08-06 18:04:22 +02:00
|
|
|
QtObject {
|
|
|
|
id: d
|
|
|
|
property string uuid
|
|
|
|
property var debounceFetchProviderUrl: Backpressure.debounce(root, 500, function() {
|
|
|
|
d.buyCryptoStore.providerUrlReady(d.uuid, "xxxx")
|
|
|
|
})
|
|
|
|
property var debounceFetchProvidersList: Backpressure.debounce(root, 500, function() {
|
|
|
|
d.buyCryptoStore.areProvidersLoading = false
|
|
|
|
})
|
|
|
|
readonly property var buyCryptoStore: BuyCryptoStore {
|
|
|
|
readonly property var providersModel: OnRampProvidersModel{}
|
|
|
|
property bool areProvidersLoading
|
|
|
|
signal providerUrlReady(string uuid , string url)
|
|
|
|
|
|
|
|
function fetchProviders() {
|
|
|
|
console.warn("fetchProviders called >>")
|
|
|
|
areProvidersLoading = true
|
|
|
|
d.debounceFetchProvidersList()
|
|
|
|
}
|
|
|
|
|
|
|
|
function fetchProviderUrl(uuid, providerID,
|
|
|
|
isRecurrent, accountAddress = "",
|
|
|
|
chainID = 0, symbol = "") {
|
|
|
|
console.warn("fetchProviderUrl called >> uuid: ", uuid, "providerID: ",providerID
|
|
|
|
, "isRecurrent: ", isRecurrent, "accountAddress: ", accountAddress,
|
|
|
|
"chainID: ", chainID, "symbol: ", symbol)
|
|
|
|
d.uuid = uuid
|
|
|
|
d.debounceFetchProviderUrl()
|
|
|
|
}
|
|
|
|
}
|
2024-08-13 14:03:35 +02:00
|
|
|
|
|
|
|
readonly property var currencyStore: CurrenciesStore {}
|
|
|
|
readonly property var assetsStore: WalletAssetsStore {
|
|
|
|
id: thisWalletAssetStore
|
|
|
|
walletTokensStore: TokensStore {
|
|
|
|
plainTokensBySymbolModel: TokensBySymbolModel {}
|
|
|
|
}
|
|
|
|
readonly property var baseGroupedAccountAssetModel: GroupedAccountsAssetsModel {}
|
|
|
|
assetsWithFilteredBalances: thisWalletAssetStore.groupedAccountsAssetsModel
|
|
|
|
}
|
|
|
|
readonly property BuyCryptoParamsForm buyCryptoInputParamsForm: BuyCryptoParamsForm{
|
|
|
|
selectedWalletAddress: "0x7F47C2e18a4BBf5487E6fb082eC2D9Ab0E6d7240"
|
|
|
|
selectedNetworkChainId: 11155111
|
|
|
|
selectedTokenKey: "ETH"
|
|
|
|
}
|
|
|
|
|
2024-08-06 18:04:22 +02:00
|
|
|
}
|
|
|
|
|
2024-05-27 18:55:43 +02:00
|
|
|
PopupBackground {
|
|
|
|
id: popupBg
|
|
|
|
|
|
|
|
SplitView.fillWidth: true
|
|
|
|
SplitView.fillHeight: true
|
|
|
|
|
|
|
|
Button {
|
|
|
|
id: reopenButton
|
|
|
|
anchors.centerIn: parent
|
|
|
|
text: "Reopen"
|
|
|
|
enabled: !buySellModal.visible
|
|
|
|
|
2024-08-13 14:03:35 +02:00
|
|
|
onClicked: {
|
|
|
|
buySellModal.buyCryptoInputParamsForm.selectedWalletAddress = "0x7F47C2e18a4BBf5487E6fb082eC2D9Ab0E6d7240"
|
|
|
|
buySellModal.buyCryptoInputParamsForm.selectedNetworkChainId = 11155111
|
|
|
|
buySellModal.buyCryptoInputParamsForm.selectedTokenKey = "ETH"
|
|
|
|
buySellModal.open()
|
|
|
|
}
|
2024-05-27 18:55:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
BuyCryptoModal {
|
|
|
|
id: buySellModal
|
2024-08-06 18:04:22 +02:00
|
|
|
anchors.centerIn: parent
|
2024-05-27 18:55:43 +02:00
|
|
|
visible: true
|
2024-08-06 18:04:22 +02:00
|
|
|
modal: false
|
|
|
|
closePolicy: Popup.CloseOnEscape
|
2024-08-13 14:03:35 +02:00
|
|
|
buyProvidersModel: d.buyCryptoStore.providersModel
|
|
|
|
isBuyProvidersModelLoading: d.buyCryptoStore.areProvidersLoading
|
|
|
|
walletAccountsModel: WalletAccountsModel{}
|
|
|
|
networksModel: NetworksModel.flatNetworks
|
|
|
|
areTestNetworksEnabled: true
|
|
|
|
currentCurrency: d.currencyStore.currentCurrency
|
|
|
|
plainTokensBySymbolModel: d.assetsStore.walletTokensStore.plainTokensBySymbolModel
|
|
|
|
groupedAccountAssetsModel: d.assetsStore.groupedAccountAssetsModel
|
|
|
|
buyCryptoInputParamsForm: d.buyCryptoInputParamsForm
|
|
|
|
Component.onCompleted: {
|
|
|
|
fetchProviders.connect(d.buyCryptoStore.fetchProviders)
|
|
|
|
fetchProviderUrl.connect(d.buyCryptoStore.fetchProviderUrl)
|
|
|
|
d.buyCryptoStore.providerUrlReady.connect(providerUrlReady)
|
2024-08-06 18:04:22 +02:00
|
|
|
}
|
2024-05-27 18:55:43 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// category: Popups
|