From 6b3ea318824a9d342ded381d9ccc38649eacb1c2 Mon Sep 17 00:00:00 2001 From: "Rene V. Vergara" Date: Thu, 2 Jan 2025 13:28:08 -0500 Subject: [PATCH] rvv001 - Issue 085 - [Zenith GUI] Read a payment URI Send TX windows working Closing the URI form is not working --- src/Zenith/GUI.hs | 136 +++++++++++++++++++++++++++++++++++--------- src/Zenith/Types.hs | 2 +- src/Zenith/Utils.hs | 2 +- 3 files changed, 112 insertions(+), 28 deletions(-) diff --git a/src/Zenith/GUI.hs b/src/Zenith/GUI.hs index 0879302..292e9e6 100644 --- a/src/Zenith/GUI.hs +++ b/src/Zenith/GUI.hs @@ -77,10 +77,11 @@ import Zenith.Utils , showAddress , validBarValue , getZcashPrice + , parseZcashPayment ) data VkTypeDef - = VkNone + = VkNone | VkFull | VkIncoming deriving (Eq, Show) @@ -156,14 +157,17 @@ data AppEvent | SendShield | StartSync | TreeSync - | ShowFIATBalance + | ShowFIATBalance | DisplayFIATBalance Double Double | CloseFIATBalance - | ShowViewingKey !VkTypeDef !T.Text + | ShowViewingKey !VkTypeDef !T.Text | CopyViewingKey !T.Text !T.Text | CloseShowVK | DisplayPaymentURI | ClosePaymentURI + | DisplayPayUsingURI + | ClosePayUsingURI + | ProcIfValidURI deriving (Eq, Show) data AppModel = AppModel @@ -223,7 +227,7 @@ data AppModel = AppModel , _tBalanceValid :: !Bool , _sBalance :: !Integer , _sBalanceValid :: !Bool - , _displayFIATBalance :: !Bool + , _displayFIATBalance :: !Bool , _zPrice :: !Double , _aBal :: !Double , _viewingKeyPopup :: !Bool @@ -231,6 +235,8 @@ data AppModel = AppModel , _vkTypeName :: !T.Text , _vkData :: !T.Text , _paymentURIDisplay :: !Bool + , _usepmtURIOverlay :: !Bool + , _uriString :: !T.Text } deriving (Eq, Show) makeLenses ''AppModel @@ -267,6 +273,7 @@ buildUI wenv model = widgetTree [ mainWindow , confirmOverlay `nodeVisible` isJust (model ^. confirmTitle) , seedOverlay `nodeVisible` model ^. showSeed + , paymentURIOverlay `nodeVisible` model ^. paymentURIDisplay , txOverlay `nodeVisible` isJust (model ^. showTx) , sendTxOverlay `nodeVisible` model ^. openSend , txIdOverlay `nodeVisible` isJust (model ^. showId) @@ -282,7 +289,7 @@ buildUI wenv model = widgetTree model ^. updateABAddress , showVKOverlay `nodeVisible` model ^. viewingKeyDisplay - , paymentURIOverlay `nodeVisible` model ^. paymentURIDisplay + , pmtUsingURIOverlay `nodeVisible` model ^. usepmtURIOverlay , shieldOverlay `nodeVisible` model ^. shieldZec , deShieldOverlay `nodeVisible` model ^. deShieldZec , msgAdrBookOverlay `nodeVisible` isJust (model ^. msgAB) @@ -354,7 +361,7 @@ buildUI wenv model = widgetTree [bgColor white, borderB 1 gray, padding 3] , box_ [alignLeft, onClick ShowDeShield] (label "De-Shield ZEC") `styleBasic` [bgColor white, borderB 1 gray, padding 3] - , box_ + , box_ [alignLeft] (vstack [ box_ @@ -374,6 +381,8 @@ buildUI wenv model = widgetTree [bgColor white, borderB 1 gray, padding 3] , box_ [alignLeft, onClick DisplayPaymentURI] (label "Create URI") `styleBasic` [bgColor white, borderB 1 gray, padding 3] + , box_ [alignLeft, onClick DisplayPayUsingURI] (label "Pay using URI") `styleBasic` + [bgColor white, borderB 1 gray, padding 3] ]) `styleBasic` [bgColor btnColor, padding 3] newBox = @@ -1052,9 +1061,9 @@ buildUI wenv model = widgetTree , label_ (txtWrapN (fromMaybe "" (model ^. msgAB)) 64) [multiline] , filler ] - dfBalOverlay = + dfBalOverlay = alert CloseFIATBalance $ - vstack + vstack [ box_ [] (label ("Account Balance in " <> (T.toUpper (c_currencyCode (model ^. configuration))) ) `styleBasic` @@ -1062,10 +1071,10 @@ buildUI wenv model = widgetTree [bgColor btnColor, radius 2, padding 3] , filler , (label ("1 ZEC = " <> ( T.pack (printf "%.2f" ( model ^. zPrice ))) <> " " <> (T.toUpper (c_currencyCode (model ^. configuration))) ) ) `styleBasic` [] - , filler - , (label ( ( T.pack (printf "%.8f" (model ^. aBal) ) <> " ZEC = " <> ( T.pack (printf "%.2f" (( model ^. zPrice )*( model ^. aBal ) ) ) ) <> " " <> (T.toUpper (c_currencyCode (model ^. configuration))) ) ) ) `styleBasic` [] - ] - showVKOverlay = + , filler + , (label ( ( T.pack (printf "%.8f" (model ^. aBal) ) <> " ZEC = " <> ( T.pack (printf "%.2f" (( model ^. zPrice )*( model ^. aBal ) ) ) ) <> " " <> (T.toUpper (c_currencyCode (model ^. configuration))) ) ) ) `styleBasic` [] + ] + showVKOverlay = alert CloseShowVK $ vstack [ box_ @@ -1245,7 +1254,7 @@ buildUI wenv model = widgetTree [ spacer , mainButton "Create URI" NotImplemented `nodeEnabled` True , spacer - , button "Cancel" ClosePaymentURI + , button "Cancel" ClosePaymentURI , spacer ]) ]) `styleBasic` @@ -1255,8 +1264,42 @@ buildUI wenv model = widgetTree , filler ]) `styleBasic` [bgColor (white & L.a .~ 0.5)] - -notImplemented = NotImplemented + pmtUsingURIOverlay = + box + (vstack + [ filler + , hstack + [ filler + , box_ + [] + (vstack + [ box_ + [alignMiddle] + (label "Pay using URI" `styleBasic` + [textColor white, textFont "Bold", textSize 12]) `styleBasic` [bgColor btnColor] + , separatorLine `styleBasic` [fgColor btnColor] + , spacer + , hstack + [ label "URI :" `styleBasic` + [width 30, textFont "Bold"] + , spacer + , textArea uriString `styleBasic` [width 170, height 30] + ] + , spacer + , box_ + [alignMiddle] + (hstack + [ spacer + , button "Cancel" ClosePayUsingURI + , spacer + , mainButton "Process" ProcIfValidURI + , spacer + ]) + ]) `styleBasic` [radius 4, border 2 btnColor, bgColor white, padding 4] + , filler + ] + , filler + ]) `styleBasic` [bgColor (white & L.a .~ 0.5)] generateQRCodes :: Config -> IO () generateQRCodes config = do @@ -1380,8 +1423,8 @@ handleEvent wenv node model evt = ] ConfirmCancel -> [Model $ model & confirmTitle .~ Nothing & mainInput .~ ""] ViewingKeysClicked -> [Model $ model & viewingKeyPopup .~ not (model ^. viewingKeyPopup)] - NewAddress vk -> - [ Model $ + NewAddress vk -> + [ Model $ model & confirmTitle ?~ "New Address" & confirmCancel .~ "Cancel" & menuPopup .~ False ] @@ -1661,7 +1704,7 @@ handleEvent wenv node model evt = ] ShowMessage a -> [Model $ model & msgAB ?~ a & menuPopup .~ False] NotImplemented -> - [ Model $ + [ Model $ model & msgAB ?~ "Function not implemented..." & menuPopup .~ False ] CloseMsgAB -> [Model $ model & msgAB .~ Nothing & inError .~ False] @@ -1672,26 +1715,58 @@ handleEvent wenv node model evt = DisplayFIATBalance zpr abal -> [ Model $ model & zPrice .~ zpr & aBal .~ abal & displayFIATBalance .~ True & menuPopup .~ False ] - ShowFIATBalance -> - if model ^. network == MainNet - then [ Task $ sfBalance (model ^. configuration) + ShowFIATBalance -> + if model ^. network == MainNet + then [ Task $ sfBalance (model ^. configuration) ] - else [ Model $ model & zPrice .~ 0.0 & aBal .~ 0.0 + else [ Model $ model & zPrice .~ 0.0 & aBal .~ 0.0 , Event $ ShowError "Balance conversion not available for TestNet" ] CloseFIATBalance -> [Model $ model & displayFIATBalance .~ False] -- -- Show Viewing Keys -- - ShowViewingKey vkType vkText -> + ShowViewingKey vkType vkText -> case vkType of VkFull -> [ Model $ model & vkTypeName .~ "Full" & vkData .~ vkText & viewingKeyDisplay .~ True & menuPopup .~ False] VkIncoming -> [ Model $ model & vkTypeName .~ "Incoming" & vkData .~ vkText & viewingKeyDisplay .~ True & menuPopup .~ False] - -- + -- -- Display PaymentURI Form -- - DisplayPaymentURI -> [ Model $ model & paymentURIDisplay .~ True & menuPopup .~ False] + DisplayPaymentURI -> [ Model $ model & paymentURIDisplay .~ True & uriString .~ "" & menuPopup .~ False] ClosePaymentURI -> [Model $ model & paymentURIDisplay .~ False] + ProcIfValidURI -> do + [Model $ model & paymentURIDisplay .~ False ] + let zp = parseZcashPayment $ T.unpack (model ^. uriString) + case zp of + Right p -> do + case uriAmount p of + Just a -> + [ Model $ model & paymentURIDisplay .~ False + & openSend .~ True + & privacyChoice .~ Full + & recipientValid .~ False + & sendRecipient .~ T.pack ( uriAddress p ) + & sendAmount .~ realToFrac a + & sendMemo .~ (uriMemo p) + , Event $ ClosePaymentURI + ] + Nothing -> + [ Model $ model & paymentURIDisplay .~ False + & openSend .~ False + & uriString .~ "" + , Event $ ShowError "Invalid URI" + ] + Left e -> [ Model $ model & paymentURIDisplay .~ False + & openSend .~ False + & uriString .~ "" + , Event $ ShowError "Invalid URI" + ] + -- + -- Display Pay using URI Form + -- + DisplayPayUsingURI -> [ Model $ model & usepmtURIOverlay.~ True & menuPopup .~ False] + ClosePayUsingURI -> [Model $ model & usepmtURIOverlay .~ False] -- -- ShowShield -> @@ -1737,6 +1812,7 @@ handleEvent wenv node model evt = (entityKey acc) , Event CloseShield ] + where currentWallet = if null (model ^. wallets) @@ -1860,8 +1936,14 @@ handleEvent wenv node model evt = case zpr of Just zp -> do let zbal = ( dbal (model ^. balance) ) / 100000000 - return $ DisplayFIATBalance zp zbal + return $ DisplayFIATBalance zp zbal Nothing -> return $ ShowMessage ( "Currency not supported [" <> c_currencyCode config <> "]") + -- + procIfValidURI :: T.Text -> IO AppEvent + procIfValidURI ustr = do + return $ ShowSend + + scanZebra :: T.Text @@ -2227,6 +2309,8 @@ runZenithGUI config = do "" "" False + False + "" startApp model handleEvent buildUI (params hD) Left _e -> print "Zebra not available" where diff --git a/src/Zenith/Types.hs b/src/Zenith/Types.hs index b94c78d..042bc74 100644 --- a/src/Zenith/Types.hs +++ b/src/Zenith/Types.hs @@ -513,7 +513,7 @@ encodeHexText' t = data ZcashPaymentURI = ZcashPaymentURI { uriAddress :: String , uriAmount :: Maybe Double - , uriMemo :: C.ByteString + , uriMemo :: T.Text , uriLabel :: Maybe String , uriMessage :: Maybe String } deriving (Show, Eq) diff --git a/src/Zenith/Utils.hs b/src/Zenith/Utils.hs index cfb98e9..8bee6f5 100644 --- a/src/Zenith/Utils.hs +++ b/src/Zenith/Utils.hs @@ -314,7 +314,7 @@ parseZcashPayment input { uriAddress = addrPart , uriAmount = lookup "amount" queryParams >>= readMaybe , uriMemo = case lookup "memo" queryParams of - Just m -> processEither $ B64.decode $ BC.pack m + Just m -> T.pack ( BC.unpack (processEither $ B64.decode $ BC.pack m ) ) _ -> "" , uriLabel = lookup "label" queryParams , uriMessage = lookup "message" queryParams