2024-05-06 19:55:11 +02:00
import QtQuick 2.15
import QtQuick . Controls 2.15
import QtQuick . Layouts 1.15
import QtQml 2.15
import Qt . labs . settings 1.0
import QtTest 1.15
2024-06-04 23:45:03 +03:00
import QtQml . Models 2.14
2024-05-06 19:55:11 +02:00
import StatusQ . Core 0.1
import StatusQ . Core . Utils 0.1
import StatusQ . Controls 0.1
import StatusQ . Components 0.1
import StatusQ . Core . Theme 0.1
import StatusQ . Popups . Dialog 0.1
2024-05-06 22:22:43 +02:00
import StatusQ . Core . Utils 0.1 as SQUtils
2024-05-06 19:55:11 +02:00
import Models 1.0
import Storybook 1.0
import AppLayouts . Wallet . controls 1.0
import AppLayouts . Wallet . services . dapps 1.0
import SortFilterProxyModel 0.2
import AppLayouts . Wallet . panels 1.0
2024-05-06 22:22:43 +02:00
import AppLayouts . Profile . stores 1.0
2024-05-06 19:55:11 +02:00
import utils 1.0
import shared . stores 1.0
Item {
id: root
SplitView {
anchors.fill: parent
ColumnLayout {
SplitView.fillWidth: true
Rectangle {
Layout.alignment: Qt . AlignCenter
Layout.preferredWidth: dappsWorkflow . implicitHeight + 20
Layout.preferredHeight: dappsWorkflow . implicitHeight + 20
border.color: "blue"
border.width: 1
DAppsWorkflow {
id: dappsWorkflow
anchors.centerIn: parent
spacing: 8
2024-05-06 22:22:43 +02:00
wcService: walletConnectService
2024-05-31 12:34:59 +03:00
onDisplayToastMessage: ( message , isErr ) = > {
if ( isErr ) {
console . log ( ` Storybook . displayToastMessage ( $ { message } , "" , "warning" , false , Constants . ephemeralNotificationType . danger , "" ) ` )
return
}
console . log ( ` Storybook . displayToastMessage ( $ { message } , "" , "checkmark-circle" , false , Constants . ephemeralNotificationType . success , "" ) ` )
}
2024-05-06 19:55:11 +02:00
}
}
ColumnLayout { }
}
ColumnLayout {
id: optionsSpace
RowLayout {
2024-05-31 12:58:47 +03:00
StatusBaseText { text: "projectId" }
StatusBaseText {
2024-05-06 19:55:11 +02:00
id: projectIdText
readonly property string projectId: SystemUtils . getEnvVar ( "WALLET_CONNECT_PROJECT_ID" )
2024-05-06 22:22:43 +02:00
text: SQUtils . Utils . elideText ( projectId , 3 )
2024-05-06 19:55:11 +02:00
font.bold: true
}
}
2024-05-06 22:22:43 +02:00
CheckBox {
text: "Testnet Mode"
checked: settings . testNetworks
onCheckedChanged: {
settings . testNetworks = checked
}
}
2024-05-31 12:58:47 +03:00
StatusTextArea {
text: settings . customAccounts
onTextChanged: {
settings . customAccounts = text
customAccountsModel . clear ( )
let customData = JSON . parse ( text )
customData . forEach ( function ( account ) {
customAccountsModel . append ( account )
} )
}
Layout.fillWidth: true
Layout.preferredHeight: ! ! text ? 400 : undefined
}
Rectangle {
Layout.fillWidth: true
Layout.preferredHeight: 1
color: "grey"
}
ListView {
Layout.fillWidth: true
model: walletConnectService . requestHandler . requestsModel
delegate: RowLayout {
StatusBaseText {
text: SQUtils . Utils . elideAndFormatWalletAddress ( model . topic , 6 , 4 )
Layout.fillWidth: true
}
}
}
2024-05-06 19:55:11 +02:00
// spacer
ColumnLayout { }
2024-05-31 12:34:59 +03:00
CheckBox {
text: "Enable SDK"
checked: settings . enableSDK
onCheckedChanged: {
settings . enableSDK = checked
}
}
2024-05-06 19:55:11 +02:00
RowLayout {
2024-05-31 12:58:47 +03:00
StatusBaseText { text: "URI" }
StatusInput {
2024-05-06 19:55:11 +02:00
id: pairUriInput
2024-05-31 12:58:47 +03:00
//placeholderText: "Enter WC Pair URI"
2024-05-06 19:55:11 +02:00
text: settings . pairUri
onTextChanged: {
settings . pairUri = text
}
Layout.fillWidth: true
}
}
2024-05-21 13:42:50 +03:00
ComboBox {
model: [ { testCase: d . noTestCase , name: "No Test Case" } ,
{ testCase: d . openDappsTestCase , name: "Open dApps" } ,
{ testCase: d . openPairTestCase , name: "Open Pair" }
]
textRole: "name"
valueRole: "testCase"
currentIndex: settings . testCase
onCurrentValueChanged: {
settings . testCase = currentValue
if ( currentValue !== d . noTestCase ) {
d . startTestCase ( )
2024-05-06 19:55:11 +02:00
}
}
2024-05-06 22:22:43 +02:00
2024-05-06 19:55:11 +02:00
Connections {
target: dappsWorkflow
2024-05-06 22:22:43 +02:00
// If Open Pair workflow if selected in the side bar
2024-05-21 13:42:50 +03:00
function onDappsListReady ( ) {
if ( d . activeTestCase < d . openPairTestCase )
2024-05-06 19:55:11 +02:00
return
let items = InspectionUtils . findVisualsByTypeName ( dappsWorkflow , "DAppsListPopup" )
if ( items . length === 1 ) {
let buttons = InspectionUtils . findVisualsByTypeName ( items [ 0 ] , "StatusButton" )
if ( buttons . length === 1 ) {
buttons [ 0 ] . clicked ( )
}
}
}
2024-05-06 22:22:43 +02:00
function onPairWCReady ( ) {
2024-05-21 13:42:50 +03:00
if ( d . activeTestCase < d . openPairTestCase )
2024-05-06 19:55:11 +02:00
return
if ( pairUriInput . text . length > 0 ) {
let items = InspectionUtils . findVisualsByTypeName ( dappsWorkflow , "StatusBaseInput" )
if ( items . length === 1 ) {
items [ 0 ] . text = pairUriInput . text
2024-05-06 22:22:43 +02:00
clickDoneIfSDKReady ( )
2024-05-06 19:55:11 +02:00
}
}
2024-05-06 22:22:43 +02:00
}
function clickDoneIfSDKReady ( ) {
2024-05-21 13:42:50 +03:00
if ( d . activeTestCase < d . openPairTestCase ) {
2024-05-06 22:22:43 +02:00
return
}
let modals = InspectionUtils . findVisualsByTypeName ( dappsWorkflow , "PairWCModal" )
if ( modals . length === 1 ) {
let buttons = InspectionUtils . findVisualsByTypeName ( modals [ 0 ] . footer , "StatusButton" )
if ( buttons . length === 1 && walletConnectService . wcSDK . sdkReady ) {
2024-05-21 13:42:50 +03:00
d . activeTestCase = d . noTestCase
2024-05-06 22:22:43 +02:00
buttons [ 0 ] . clicked ( )
return
}
}
Backpressure . debounce ( dappsWorkflow , 250 , clickDoneIfSDKReady ) ( )
2024-05-06 19:55:11 +02:00
}
}
}
}
}
2024-06-04 23:45:03 +03:00
StatusDialog {
id: authMockDialog
title: "Authenticate user"
visible: false
property string topic: ""
property string id: ""
ColumnLayout {
RowLayout {
StatusBaseText { text: "Topic" }
StatusBaseText { text: authMockDialog . topic }
StatusBaseText { text: "ID" }
StatusBaseText { text: authMockDialog . id }
}
}
footer: StatusDialogFooter {
rightButtons: ObjectModel {
StatusButton {
text: qsTr ( "Reject" )
onClicked: {
walletConnectService . store . userAuthenticationFailed ( authMockDialog . topic , authMockDialog . id )
authMockDialog . close ( )
}
}
StatusButton {
text: qsTr ( "Authenticate" )
onClicked: {
2024-06-07 19:54:19 +03:00
walletConnectService . store . userAuthenticated ( authMockDialog . topic , authMockDialog . id , "0x1234567890" , "123" )
2024-06-04 23:45:03 +03:00
authMockDialog . close ( )
}
}
}
}
}
2024-05-06 22:22:43 +02:00
WalletConnectService {
id: walletConnectService
wcSDK: WalletConnectSDK {
2024-05-31 12:34:59 +03:00
active: settings . enableSDK
2024-05-06 19:55:11 +02:00
projectId: projectIdText . projectId
2024-05-06 22:22:43 +02:00
}
2024-05-20 21:42:31 +03:00
store: DAppsStore {
2024-05-21 13:42:50 +03:00
signal dappsListReceived ( string dappsJson )
2024-06-07 19:54:19 +03:00
signal userAuthenticated ( string topic , string id , string password , string pin )
2024-06-04 23:45:03 +03:00
signal userAuthenticationFailed ( string topic , string id )
2024-05-21 13:42:50 +03:00
2024-05-20 21:42:31 +03:00
function addWalletConnectSession ( sessionJson ) {
console . info ( "Persist Session" , sessionJson )
2024-05-21 13:42:50 +03:00
let session = JSON . parse ( sessionJson )
let firstIconUrl = session . peer . metadata . icons . length > 0 ? session . peer . metadata . icons [ 0 ] : ""
let persistedDapp = {
"name" : session . peer . metadata . name ,
"url" : session . peer . metadata . url ,
"iconUrl" : firstIconUrl
}
d . persistedDapps . push ( persistedDapp )
2024-06-07 19:54:19 +03:00
return true
2024-05-21 13:42:50 +03:00
}
function getDapps ( ) {
this . dappsListReceived ( JSON . stringify ( d . persistedDapps ) )
return true
2024-05-20 21:42:31 +03:00
}
2024-06-04 23:45:03 +03:00
function authenticateUser ( topic , id , address ) {
authMockDialog . topic = topic
authMockDialog . id = id
authMockDialog . open ( )
return true
}
2024-06-07 19:54:19 +03:00
// hardcoded for https://react-app.walletconnect.com/
function signMessage ( topic , id , address , password , message ) {
return "0x0b083acc1b3b612dd38e8e725b28ce9b2dd4936b4cf7922da4e4a3c6f44f7f4f6d3050ccb41455a2b85093f1bfadb10fc6a75d83bb590b2eb70e3447653459701c"
}
// hardcoded for https://react-app.walletconnect.com/
function signTypedDataV4 ( topic , id , address , password , typedDataJson ) {
return "0xf8ceb3468319cc215523b67c24c4504b3addd9bf8de31c278038d7478c9b6de554f7d8a516cd5d6a066b7d48b81f03d9d6bb7d5d754513c08325674ebcc7efbc1b"
}
2024-05-06 22:22:43 +02:00
}
2024-05-06 19:55:11 +02:00
2024-05-06 22:22:43 +02:00
walletStore: WalletStore {
property var flatNetworks: SortFilterProxyModel {
sourceModel: NetworksModel . flatNetworks
filters: ValueFilter { roleName: "isTest" ; value: settings . testNetworks ; }
2024-05-06 19:55:11 +02:00
}
2024-05-31 12:58:47 +03:00
property var accounts: customAccountsModel . count > 0 ? customAccountsModel : defaultAccountsModel
readonly property ListModel ownAccounts: accounts
2024-05-06 19:55:11 +02:00
}
2024-06-04 23:45:03 +03:00
onDisplayToastMessage: ( message , error ) = > console . info ( "Storybook - toast message: " , message , ! ! error ? "; error: " + error: "" )
2024-05-06 19:55:11 +02:00
}
2024-05-31 12:58:47 +03:00
QObject {
2024-05-06 19:55:11 +02:00
id: d
2024-05-21 13:42:50 +03:00
property int activeTestCase: noTestCase
2024-05-06 19:55:11 +02:00
2024-05-21 13:42:50 +03:00
function startTestCase ( ) {
d . activeTestCase = settings . testCase
2024-05-06 19:55:11 +02:00
if ( root . visible ) {
dappsWorkflow . clicked ( )
}
}
2024-05-21 13:42:50 +03:00
readonly property int noTestCase: 0
readonly property int openDappsTestCase: 1
readonly property int openPairTestCase: 2
property var persistedDapps: [
{ "name" : "Test dApp 1" , "url" : "https://dapp.test/1" , "iconUrl" : "https://se-sdk-dapp.vercel.app/assets/eip155:1.png" } ,
{ "name" : "Test dApp 2" , "url" : "https://dapp.test/2" , "iconUrl" : "https://react-app.walletconnect.com/assets/eip155-1.png" } ,
{ "name" : "Test dApp 3" , "url" : "https://dapp.test/3" , "iconUrl" : "https://react-app.walletconnect.com/assets/eip155-1.png" } ,
{ "name" : "Test dApp 4 - very long name !!!!!!!!!!!!!!!!" , "url" : "https://dapp.test/4" , "iconUrl" : "https://react-app.walletconnect.com/assets/eip155-1.png" } ,
{ "name" : "Test dApp 5 - very long url" , "url" : "https://dapp.test/very_long/url/unusual" , "iconUrl" : "https://react-app.walletconnect.com/assets/eip155-1.png" } ,
{ "name" : "Test dApp 6" , "url" : "https://dapp.test/6" , "iconUrl" : "https://react-app.walletconnect.com/assets/eip155-1.png" }
]
2024-05-31 12:58:47 +03:00
ListModel {
id: customAccountsModel
}
WalletAccountsModel {
id: defaultAccountsModel
}
2024-05-06 19:55:11 +02:00
}
onVisibleChanged: {
2024-05-21 13:42:50 +03:00
if ( visible && d . activeTestCase !== d . noTestCase ) {
d . startTestCase ( )
2024-05-06 19:55:11 +02:00
}
}
Settings {
id: settings
2024-05-21 13:42:50 +03:00
property int testCase: d . noTestCase
2024-05-06 19:55:11 +02:00
property string pairUri: ""
2024-05-06 22:22:43 +02:00
property bool testNetworks: false
2024-05-31 12:34:59 +03:00
property bool enableSDK: true
2024-05-31 12:58:47 +03:00
property string customAccounts: ""
2024-05-06 19:55:11 +02:00
}
}
// category: Wallet