Add functionality for new account

This commit is contained in:
Rene Vergara 2024-06-24 10:34:46 -05:00
parent bf663843b3
commit b9ab1623b3
No known key found for this signature in database
GPG key ID: 65122AD495A7F5B2
2 changed files with 52 additions and 22 deletions

View file

@ -15,7 +15,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
- Balance display - Balance display
- Account selector - Account selector
- Menu for new addresses, accounts, wallets - Menu for new addresses, accounts, wallets
- Dialog to display and copy seed phrase
- Dialog to add new address - Dialog to add new address
- Dialog to add new account
## [0.5.3.0-beta] ## [0.5.3.0-beta]

View file

@ -49,8 +49,8 @@ data AppEvent
| AccountClicked | AccountClicked
| MenuClicked | MenuClicked
| NewClicked | NewClicked
| NewAddress | NewAddress !(Maybe (Entity ZcashAccount))
| NewAccount | NewAccount !(Maybe (Entity ZcashWallet))
| NewWallet | NewWallet
| SetPool !ZcashPool | SetPool !ZcashPool
| SwitchQr !(Maybe QrCode) | SwitchQr !(Maybe QrCode)
@ -62,8 +62,8 @@ data AppEvent
| LoadAddrs ![Entity WalletAddress] | LoadAddrs ![Entity WalletAddress]
| LoadAccs ![Entity ZcashAccount] | LoadAccs ![Entity ZcashAccount]
| ConfirmCancel | ConfirmCancel
| SaveAddress | SaveAddress !(Maybe (Entity ZcashAccount))
| SaveAccount | SaveAccount !(Maybe (Entity ZcashWallet))
| SaveWallet | SaveWallet
| CloseSeed | CloseSeed
| ShowSeed | ShowSeed
@ -204,11 +204,11 @@ buildUI wenv model = widgetTree
[alignMiddle] [alignMiddle]
(vstack (vstack
[ box_ [ box_
[alignLeft, onClick NewAddress] [alignLeft, onClick $ NewAddress currentAccount]
(hstack [label "Address", filler]) `styleBasic` (hstack [label "Address", filler]) `styleBasic`
[bgColor white, borderB 1 gray, padding 3] [bgColor white, borderB 1 gray, padding 3]
, box_ , box_
[alignLeft, onClick NewAccount] [alignLeft, onClick $ NewAccount currentWallet]
(hstack [label "Account", filler]) `styleBasic` (hstack [label "Account", filler]) `styleBasic`
[bgColor white, borderB 1 gray, padding 3] [bgColor white, borderB 1 gray, padding 3]
, box_ , box_
@ -600,23 +600,23 @@ handleEvent wenv node model evt =
AccountClicked -> [Model $ model & accPopup .~ True] AccountClicked -> [Model $ model & accPopup .~ True]
MenuClicked -> [Model $ model & menuPopup .~ True] MenuClicked -> [Model $ model & menuPopup .~ True]
NewClicked -> [Model $ model & newPopup .~ not (model ^. newPopup)] NewClicked -> [Model $ model & newPopup .~ not (model ^. newPopup)]
NewAddress -> NewAddress acc ->
[ Model $ [ Model $
model & confirmTitle ?~ "New Address" & confirmAccept .~ "Create" & model & confirmTitle ?~ "New Address" & confirmAccept .~ "Create" &
confirmCancel .~ confirmCancel .~
"Cancel" & "Cancel" &
confirmEvent .~ confirmEvent .~
SaveAddress & SaveAddress acc &
menuPopup .~ menuPopup .~
False False
] ]
NewAccount -> NewAccount wal ->
[ Model $ [ Model $
model & confirmTitle ?~ "New Account" & confirmAccept .~ "Create" & model & confirmTitle ?~ "New Account" & confirmAccept .~ "Create" &
confirmCancel .~ confirmCancel .~
"Cancel" & "Cancel" &
confirmEvent .~ confirmEvent .~
SaveAccount & SaveAccount wal &
menuPopup .~ menuPopup .~
False False
] ]
@ -632,18 +632,18 @@ handleEvent wenv node model evt =
] ]
ConfirmCancel -> [Model $ model & confirmTitle .~ Nothing & mainInput .~ ""] ConfirmCancel -> [Model $ model & confirmTitle .~ Nothing & mainInput .~ ""]
ShowSeed -> [Model $ model & showSeed .~ True & menuPopup .~ False] ShowSeed -> [Model $ model & showSeed .~ True & menuPopup .~ False]
SaveAddress -> SaveAddress acc ->
if T.length (model ^. mainInput) > 1 if T.length (model ^. mainInput) > 1
then [ Task $ addNewAddress (model ^. mainInput) External currentAccount then [ Task $ addNewAddress (model ^. mainInput) External acc
, Event ConfirmCancel
]
else [Event $ ShowError "Invalid input", Event ConfirmCancel]
SaveAccount wal ->
if T.length (model ^. mainInput) > 1
then [ Task $ addNewAccount (model ^. mainInput) wal
, Event ConfirmCancel , Event ConfirmCancel
] ]
else [Event $ ShowError "Invalid input", Event ConfirmCancel] else [Event $ ShowError "Invalid input", Event ConfirmCancel]
SaveAccount ->
[ if T.length (model ^. mainInput) > 1
then Event $ ShowMsg $ "You saved account: " <> model ^. mainInput
else Event $ ShowError "Invalid input"
, Event ConfirmCancel
]
SaveWallet -> SaveWallet ->
[ if T.length (model ^. mainInput) > 1 [ if T.length (model ^. mainInput) > 1
then Event $ ShowMsg $ "You saved wallet: " <> model ^. mainInput then Event $ ShowMsg $ "You saved wallet: " <> model ^. mainInput
@ -710,8 +710,14 @@ handleEvent wenv node model evt =
, Event $ ShowMsg "Copied seed phrase!" , Event $ ShowMsg "Copied seed phrase!"
] ]
LoadTxs t -> [Model $ model & transactions .~ t] LoadTxs t -> [Model $ model & transactions .~ t]
LoadAddrs a -> [Model $ model & addresses .~ a, Event $ SetPool Orchard] LoadAddrs a ->
LoadAccs a -> [Model $ model & accounts .~ a, Event $ SwitchAcc 0] if not (null a)
then [Model $ model & addresses .~ a, Event $ SetPool Orchard]
else [Event $ NewAddress currentAccount]
LoadAccs a ->
if not (null a)
then [Model $ model & accounts .~ a, Event $ SwitchAcc 0]
else [Event $ NewAccount currentWallet]
CloseMsg -> [Model $ model & msg .~ Nothing & inError .~ False] CloseMsg -> [Model $ model & msg .~ Nothing & inError .~ False]
CloseSeed -> [Model $ model & showSeed .~ False] CloseSeed -> [Model $ model & showSeed .~ False]
where where
@ -756,6 +762,25 @@ handleEvent wenv node model evt =
generateQRCodes $ model ^. configuration generateQRCodes $ model ^. configuration
addrL <- runNoLoggingT $ getAddresses pool $ entityKey a addrL <- runNoLoggingT $ getAddresses pool $ entityKey a
return $ LoadAddrs addrL return $ LoadAddrs addrL
addNewAccount :: T.Text -> Maybe (Entity ZcashWallet) -> IO AppEvent
addNewAccount n w = do
case w of
Nothing -> return $ ShowError "No wallet available"
Just w' -> do
pool <- runNoLoggingT $ initPool $ c_dbPath $ model ^. configuration
accIx <- getMaxAccount pool $ entityKey w'
newAcc <-
try $ createZcashAccount n (accIx + 1) w' :: IO
(Either IOError ZcashAccount)
case newAcc of
Left e -> return $ ShowError "Failed to create account"
Right newAcc' -> do
r <- saveAccount pool newAcc'
case r of
Nothing -> return $ ShowError "Account already exists"
Just _x -> do
aList <- runNoLoggingT $ getAccounts pool (entityKey w')
return $ LoadAccs aList
runZenithGUI :: Config -> IO () runZenithGUI :: Config -> IO ()
runZenithGUI config = do runZenithGUI config = do
@ -817,7 +842,10 @@ runZenithGUI config = do
Nothing Nothing
"" ""
"" ""
SaveAddress (SaveAddress $
if not (null accList)
then Just (head accList)
else Nothing)
False False
False False
startApp model handleEvent buildUI params startApp model handleEvent buildUI params
@ -851,7 +879,7 @@ runZenithGUI config = do
Nothing Nothing
"" ""
"" ""
SaveAddress (SaveAddress Nothing)
False False
False False
startApp model handleEvent buildUI params startApp model handleEvent buildUI params