From 248dc5097acee965b9fa62aec5d69d300fb2da51 Mon Sep 17 00:00:00 2001 From: sajal Date: Tue, 10 Dec 2024 14:02:18 +0530 Subject: [PATCH 1/6] copy address and back button fixes --- wallet_app/app/build.gradle.kts | 2 + .../com/example/walletapp/db/TokenDatabase.kt | 23 ++++++++- .../com/example/walletapp/ui/WalletApp.kt | 4 +- .../walletapp/ui/account/AddTokenScreen.kt | 10 +--- .../walletapp/ui/account/WalletScreen.kt | 40 +++++++++++----- .../ui/onboarding/CreateAccountScreen.kt | 22 +-------- .../FinalizeAccountCreationScreen.kt | 20 -------- .../ui/onboarding/ImportAccountScreen.kt | 21 --------- .../walletapp/ui/transfer/ReceiveScreen.kt | 10 +++- .../walletapp/ui/transfer/SendScreen.kt | 44 ++++++++++-------- wallet_app/app/src/main/res/drawable/copy.png | Bin 218 -> 8103 bytes wallet_app/local.properties | 6 +-- 12 files changed, 94 insertions(+), 108 deletions(-) diff --git a/wallet_app/app/build.gradle.kts b/wallet_app/app/build.gradle.kts index 76dd788d..28eef37c 100644 --- a/wallet_app/app/build.gradle.kts +++ b/wallet_app/app/build.gradle.kts @@ -104,6 +104,8 @@ dependencies { // Material Design 3 implementation(libs.androidx.material3) + implementation("com.google.android.material:material:1.11.0") + // Retrofit for network requests implementation(libs.retrofit) implementation(libs.converter.gson) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/db/TokenDatabase.kt b/wallet_app/app/src/main/java/com/example/walletapp/db/TokenDatabase.kt index ec84a265..790abd03 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/db/TokenDatabase.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/db/TokenDatabase.kt @@ -5,6 +5,7 @@ import androidx.room.Database import androidx.room.Room import androidx.room.RoomDatabase import androidx.room.TypeConverters +import androidx.room.migration.Migration import androidx.sqlite.db.SupportSQLiteDatabase import com.example.walletapp.model.Token import com.example.walletapp.utils.Converters @@ -19,10 +20,28 @@ abstract class TokenDatabase : RoomDatabase() { abstract fun tokenDao(): TokenDao + + companion object { @Volatile private var INSTANCE: TokenDatabase? = null + val MIGRATION_1_2 = object : Migration(1, 2) { + override fun migrate(database: SupportSQLiteDatabase) { + // Create the Token table if it is new + database.execSQL( + """ + CREATE TABLE IF NOT EXISTS Token ( + contactAddress TEXT NOT NULL PRIMARY KEY, + name TEXT NOT NULL, + symbol TEXT NOT NULL, + decimals INTEGER NOT NULL, + tokenId TEXT NOT NULL + ) + """.trimIndent() + ) + } + } fun getDatabase(context: Context): TokenDatabase { return INSTANCE ?: synchronized(this) { val instance = Room.databaseBuilder( @@ -30,7 +49,8 @@ abstract class TokenDatabase : RoomDatabase() { TokenDatabase::class.java, "token_database" ) - .addCallback(DatabaseCallback()) // Add callback here + .addCallback(DatabaseCallback()) + .addMigrations(MIGRATION_1_2) .build() INSTANCE = instance instance @@ -38,6 +58,7 @@ abstract class TokenDatabase : RoomDatabase() { } } + private class DatabaseCallback : RoomDatabase.Callback() { override fun onCreate(db: SupportSQLiteDatabase) { super.onCreate(db) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt index 1cb97596..8a26af1b 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt @@ -106,8 +106,8 @@ fun WalletApp(tokenViewModel: TokenViewModel) { composable { AddTokenScreen( tokenViewModel=tokenViewModel, - navController: navController, - onConfirm = { navController.navigateUp() } + onConfirm = { navController.navigateUp() }, + navController ) } diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/AddTokenScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/AddTokenScreen.kt index be817f5e..e3de6001 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/AddTokenScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/AddTokenScreen.kt @@ -10,18 +10,12 @@ import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.foundation.shape.RoundedCornerShape -import androidx.compose.material.Button -import androidx.compose.material.ButtonDefaults -import androidx.compose.material.Icon -import androidx.compose.material.IconButton -import androidx.compose.material.Surface -import androidx.compose.material.Text -import androidx.compose.material.TextField -import androidx.compose.material.TextFieldDefaults import androidx.compose.material.icons.Icons import androidx.compose.material.icons.filled.ArrowBack import androidx.compose.material3.Button import androidx.compose.material3.ButtonDefaults +import androidx.compose.material3.Icon +import androidx.compose.material3.IconButton import androidx.compose.material3.OutlinedTextFieldDefaults import androidx.compose.material3.Surface import androidx.compose.material3.Text diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt index 6f63522e..0de63670 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt @@ -2,7 +2,7 @@ package com.example.walletapp.ui.account import android.annotation.SuppressLint import android.app.Activity -import android.util.Log +import androidx.compose.ui.platform.ClipboardManager import android.widget.Toast import androidx.compose.foundation.Image import androidx.compose.foundation.background @@ -45,12 +45,13 @@ import androidx.compose.runtime.* import androidx.compose.runtime.livedata.observeAsState import androidx.compose.runtime.saveable.rememberSaveable import androidx.compose.ui.draw.clip -import androidx.compose.ui.graphics.painter.Painter +import androidx.compose.ui.platform.ClipEntry import androidx.compose.ui.layout.ContentScale +import androidx.compose.ui.platform.LocalClipboardManager import androidx.compose.ui.platform.LocalConfiguration import androidx.compose.ui.text.font.FontWeight import androidx.compose.ui.text.style.TextAlign -import androidx.compose.ui.text.toLowerCase +import android.content.ClipData import androidx.compose.ui.text.toUpperCase import androidx.compose.ui.window.Popup import androidx.compose.ui.window.PopupProperties @@ -108,6 +109,8 @@ fun Wallet(modifier: Modifier, onNewTokenPress: () -> Unit, onReceivePress: () - val address= BuildConfig.ACCOUNT_ADDRESS val accountAddress = Felt.fromHex(address) + + val clipboard: ClipboardManager = LocalClipboardManager.current var tokenImages by rememberSaveable { mutableStateOf>(hashMapOf()) } val balances by walletViewModel.balances.collectAsState() val coinsPrices by rememberSaveable { mutableStateOf>(hashMapOf()) } @@ -175,18 +178,33 @@ fun Wallet(modifier: Modifier, onNewTokenPress: () -> Unit, onReceivePress: () - text = formatter.format(totalBalance), fontFamily = FontFamily(Font(R.font.publicsans_bold)), color = Color.White, - fontSize = 24.sp, + fontSize = 26.sp, modifier = Modifier .align(Alignment.CenterHorizontally) .padding(top = 70.dp) ) - Text( - text = address.take(10) + ".....", - fontFamily = FontFamily(Font(R.font.inter_regular)), - color = Color.White, - fontSize = 14.sp, - modifier = Modifier.align(Alignment.CenterHorizontally) - ) + Row( + modifier = Modifier.align(Alignment.CenterHorizontally)) { + Text( + text = address.take(8) + "....", + fontFamily = FontFamily(Font(R.font.inter_regular)), + color = Color.White, + fontSize = 12.sp, + ) + Icon( + painter = painterResource(R.drawable.copy),// replace with your Ethereum icon + contentDescription = null, + tint=Color.White, + modifier = Modifier.padding(start=5.dp) + .size(15.dp).clickable { + val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) + clipboard.setClip(clip) + Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() + } + ) + + } + Spacer(modifier = Modifier.height(32.dp)) val configuration = LocalConfiguration.current val screenHeight = configuration.screenHeightDp.dp/2 diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/CreateAccountScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/CreateAccountScreen.kt index 8f39553f..3656c184 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/CreateAccountScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/CreateAccountScreen.kt @@ -64,11 +64,6 @@ fun CreateAccountScreen( var progress by remember { mutableStateOf(0.5f) } Scaffold( topBar = { - TopAppBar( - backgroundColor = Color("#0C0C4F".toColorInt()), - contentColor = Color.White, - elevation = 4.dp - ) { Row( modifier = Modifier .fillMaxWidth() @@ -97,22 +92,8 @@ fun CreateAccountScreen( } - } + } - title = { Text("Create Account", color = Color.White, fontSize = 20.sp) }, - navigationIcon = { - Icon( - imageVector = Icons.Filled.ArrowBack, - contentDescription = "Backward Arrow", - modifier = Modifier.padding(start = 8.dp), - tint = Color.White - ) - }, - colors = TopAppBarDefaults.topAppBarColors( - containerColor = Color("#0C0C4F".toColorInt()), - titleContentColor = Color.White - ) - ) } ) { paddingValues -> Column( @@ -386,4 +367,3 @@ fun GeneratekeySheet( } - diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt index a0dedd29..91d43ba9 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt @@ -41,11 +41,6 @@ fun FinalizeAccountCreationScreen( ) { Scaffold( topBar = { - TopAppBar( - backgroundColor = Color("#0C0C4F".toColorInt()), - contentColor = Color.White, - elevation = 4.dp - ) { Row( modifier = Modifier .fillMaxWidth() @@ -76,21 +71,6 @@ fun FinalizeAccountCreationScreen( } } - title = { Text("Create Account", color = Color.White, fontSize = 20.sp) }, - navigationIcon = { - Icon( - imageVector = Icons.Filled.ArrowBack, - contentDescription = "Backward Arrow", - modifier = Modifier.padding(start = 8.dp), - tint = Color.White - ) - }, - colors = TopAppBarDefaults.topAppBarColors( - containerColor = Color("#0C0C4F".toColorInt()), - titleContentColor = Color.White - ) - ) - } ) { paddingValues -> Column( modifier = Modifier diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt index 634b8c72..a996ad7f 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt @@ -60,15 +60,9 @@ fun ImportAccountScreen( onFinishAccountImport: () -> Unit, onBackButtonPressed: () -> Unit ) { -fun ImportAccountScreen(onFinishAccountImport: () -> Unit) { var progress by remember { mutableStateOf(0.5f) } Scaffold( topBar = { - TopAppBar( - backgroundColor = Color("#0C0C4F".toColorInt()), - contentColor = Color.White, - elevation = 4.dp - ) { Row( modifier = Modifier .fillMaxWidth() @@ -99,21 +93,6 @@ fun ImportAccountScreen(onFinishAccountImport: () -> Unit) { } } - title = { Text("Import existing wallet", color = Color.White, fontSize = 20.sp) }, - navigationIcon = { - Icon( - imageVector = Icons.Filled.ArrowBack, - contentDescription = "Backward Arrow", - modifier = Modifier.padding(start = 8.dp), - tint = Color.White - ) - }, - colors = TopAppBarDefaults.topAppBarColors( - containerColor = Color("#0C0C4F".toColorInt()), - titleContentColor = Color.White - ) - ) - } ) { paddingValues -> Column( modifier = Modifier diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt index 13ce2665..f579d653 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt @@ -1,6 +1,7 @@ package com.example.walletapp.ui.transfer import android.content.ClipData +import android.widget.Toast import androidx.compose.foundation.Image import androidx.compose.foundation.background import androidx.compose.foundation.clickable @@ -21,17 +22,21 @@ import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.ClipEntry import androidx.compose.ui.platform.ClipboardManager import androidx.compose.ui.platform.LocalClipboardManager +import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.painterResource import androidx.compose.ui.text.font.Font import androidx.compose.ui.text.font.FontFamily import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import androidx.core.graphics.toColorInt +import com.example.walletapp.BuildConfig import com.example.walletapp.R @Composable fun ReceiveScreen(modifier: Modifier) { val clipboard: ClipboardManager = LocalClipboardManager.current + val context= LocalContext.current + val address= BuildConfig.ACCOUNT_ADDRESS Surface(modifier = Modifier.fillMaxSize()) { Column( @@ -59,7 +64,7 @@ fun ReceiveScreen(modifier: Modifier) { // Wallet Address Text( - text = "0xfoo...123", // Replace with actual wallet address + text = address.take(8) + "....", fontFamily = FontFamily(Font(R.font.publicsans_bold)), color = Color.White, fontSize = 40.sp @@ -74,8 +79,9 @@ fun ReceiveScreen(modifier: Modifier) { color = Color.White, fontSize = 15.sp, modifier = Modifier.clickable { - val clip = ClipEntry(ClipData.newPlainText("Wallet Address", "0xfoo...123")) // TODO: Replace with actual wallet address + val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) clipboard.setClip(clip) + Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() } ) } diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt index c2b95ec4..31625579 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt @@ -44,8 +44,8 @@ import com.example.walletapp.R import com.example.walletapp.ui.account.WalletViewModel import android.widget.Toast import androidx.compose.foundation.layout.Box -import androidx.compose.material.DropdownMenuItem import androidx.compose.material3.DropdownMenu +import androidx.compose.material3.DropdownMenuItem import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.collectAsState import androidx.compose.runtime.remember @@ -306,27 +306,33 @@ fun TokenDropdown( DropdownMenuItem(onClick = { onTokenSelected("ethereum") expanded = false - }) { - Image( - painter = painterResource(id = R.drawable.ic_ethereum), - contentDescription = null, - modifier = Modifier.size(24.dp) - ) - Spacer(modifier = Modifier.width(8.dp)) - Text("ETH", color = Color.White) - } + }, + leadingIcon = { + Image( + painter = painterResource(id = R.drawable.ic_ethereum), + contentDescription = null, + modifier = Modifier.size(24.dp) + ) + + }, + text={ + Text("ETH", color = Color.White) + }) DropdownMenuItem(onClick = { onTokenSelected("starknet") expanded = false - }) { - Image( - painter = painterResource(id = R.drawable.starknet_icon), - contentDescription = null, - modifier = Modifier.size(24.dp) - ) - Spacer(modifier = Modifier.width(8.dp)) - Text("STRK", color = Color.White) - } + }, + leadingIcon = { + Image( + painter = painterResource(id = R.drawable.starknet_icon), + contentDescription = null, + modifier = Modifier.size(24.dp) + ) + + }, + text={ + Text("STRK", color = Color.White) + }) } } } diff --git a/wallet_app/app/src/main/res/drawable/copy.png b/wallet_app/app/src/main/res/drawable/copy.png index c2198fe63e9b69cb11e2c6d68d2d2d6550b77cd9..562a13c3962477943145aab535f6bf1f43eebbca 100644 GIT binary patch literal 8103 zcmeHsc|4Te`~Q8-&1~n)^Q2IoEZrbD!(Huj_p-?BDBz zmr#;`AP7&T*wY{g1s+k5xET1EkL_6mKWi8iuSf_YJQn@Ko#D5Sf<{HAgD2B9{5Uh_ zP{c7PCML!(_+)70kwc7QhT#!`g)^2)5Ts^IwYPPPEt(!YJ+F2!VRde72m6ogbJt|v z*QR><>OPh0K8wNpiK&&j?JifP>yWr;S6Ow*J#=boh&lEfsVtRJ8MawgSNB-HI>`b4 zNOFPNOEDDadGX4rw(kA8f-7AyU%wYy{QJ{vOw~-qY%I#~%9Rg+U*8b3wWyr`vA+i| z_cNgi2W_|zE<~+QS^XGG-|b1NNGMiZnc77k(m&$mNm_V{D&fh`aXT3X6rG}qm`$A(|*7o5GWUf;5yJ-AG{u#u8f1Dm2 zM1tj@sFy)Jhr}d0Ss+Gt3nEb~zen=L_z`?-cHoiWyyvLWfs3SHf0e*0Yr@tlJJB3o zvZh$!&}B&S@NnK^RH^T@c#FK5T*0~`2bz@}#~JbB(rQVjdmFr;Fz6B@TL@(qUaQcsFOmrikIi~8g5(6lta0hzTChpok&ifHB zy7okTotc@-CD5L(#|@0%UY1OG@uC%3gIw&kjTqL}OEbl&pa;&$CsBJ_B^p)DjHr1OI^c5L{=jngJTbgL;5qI@y)FHQ_CKQTFrwNc-N;0+U*XBGYUZa;nxvB$TyL_WqI5a5zZI6i&41KjgxRXizEGyLjN;X*p;i)ObSOTpjf69arQp z$O<;tmVCSuP|}g!#+~^n-k6P&!#0W8{EA&K*kF*&X$qE@SlZ~}gbU_mL2kWb2oZ_y zw$-YzeM$W+C7c~s-!ms)bcambvchQ!mlc@MY0T`KLUEgeyEPO3?y_*=I2*0$lW8Q8 zDeEnBDm|vqF|Y+#YA)+bc3zNCAbC=zU4z#=inpMI!C-u&`2NuEaxFp^p7Ru}mPI%qKMMt&I1Zn25OwpC`i8NTBOc}Y z_EwpEO#jDllK)I-tl4 z){T=Y(z%AqoWtKRzSQN1r89G1mBuI%F_<~rLBAt<0x#ZQ8>w@ITRzrCD-VVyat`}B zF54dLj9q6|`t@OsaYSKm^t<$(PCZ-wpFCwvrs5|$?lpNKBUi^9X$g+G^$J-#J$kkd zd3_(CXbkOHZa3zgGBLV7b0McERT_GkY8{?&)Yp6IPYP_PvqD#T-pHD-BT#>uU2Sne zcF_+{-y`AQ#&P{-%cO56cA6l4{eccV^&-l$`BAOMT{kv`;?^d~ELfcE{Io)wiSS=9 zxFPn{PO0GC1?$vB#V$^?VP0NCH}c>~iR+?b|V~5 zpzIRs4M=e}yeQD)RqdhmxB1pAEC^ZrlMm%+xBD(kmc9XWRf$+y7Fmv_C>3mCo$l7qF8~b^lB}DKxZCud z!CgtzW1hS9;fH-Y$u=A0pgk7}``hu{n)6is&IjG_|LI+y3Yw$3VJ*DxUMxM5w*!Bd z4!_j~9U4u@EH3*@M!e}SC2W`ivCKmbIsr_aT>>^Gwpx&Fupf(DH$(lpWSgvFQcW+y znT!lzvLsA132!$^vfif?-j;Wkfxfx#=1N|g_o7O}epDwK0t)BwS=*8nb7TUi=o-C_km-&vh(^T)#) ze3(9gtaoM`K-1gS#6A|p5(VD$Gu!%oyhC!L*cZ>QCTh|@Jy>o|XEn1e*q_*iY>Qgi z+m8*Px(;{=!olxYesgshvWE<6mjq@fg(X(f@oJ4qjcIP;+&8t5)X;h45VDq=zS7ud z#(7Ui)qWNfP~*ZF<_wsDt~D^cY8)ZQYF9w3pj6N*Hj585^tSlGvudi5>~z*WwwmL4 z&f@6w*W=UT@q}2}Mwx<4`J@WTdT1}HN?r&HcGBa6NEIYWo9&4>GxD1|~?qA^l3jmNq3&YJSB_dCa>^4!ZFwlP{w`J#hqpb}&r52<m=pj+aqi)+CKmTvMr>n+%O@Lg%8`e`LbEGd4%1-LHLK&zx+6nD0oc`km3^@1% z$E}hhiO2}{A*b5SwSrG{Kx4VlGI=4c5wK8&v5P5AoosJH&NXV=nCL%%ics+)G&*QR zXq4^SOipdO{shI46-r3{~m+2h?XoZMzbiCV|9pt?GBA6G&7ObBr*3T;_#`9+oe~Ul64L$CJ`a*14BB z>q6nU%q)Ti6|aCV!tKr^lr1w`p)hRG2I4M`lCh%McJd$pycx%3+SEF?W zLqM0yWl5xje{U;w)GVL*!F7`AA&JN#V*ojM&>qwyS>mpr;~}sax=$DQgzsw?j@m5T zPRG&%=#Ic|i3t7R+4aFyP418*9FPj^v+HqtGYQv!OnJkx(gF)GN4-8BO6Ya2$s`R{ zkX()eqe9qgkj`?u+k;JR(9pg`ewNnr$TELN4++F9teJEFP8|~9n6m$j=pfPVJTUXU z`WDNHJ;sthpTeEj7sS#@wd;>nXIK-2vPL^h&-dS!#L{I2tL1i5&*J%xd~d!xKauVq zMADNkXHBy_;I@5nezDTLPG(b>0b?D*nJH7TCI#L^w)9s|n4Yp}O1jGt3)bXC{^RvT zZER2GX|9Ead7Xx@JsA&?lHB@#^LqaLjCzB;B$M=Q$JU5dttPBZ z+aV{q`P}N`DU~jc>70VcuqAc!^$(#Eo2-#NBqx5;rvVmE;RwJR0D7-wb zZW6bT2|aLmgQbVlotddh1AF@)3CqUSIsS(=7$mU8;u)97uheHFAB9}{u6Eu!jj%s? zic+I#r9iajDf!uu_a>K>1Ssg65d#sx|OR)A~%tf-5QIvQn9#4 zUv;9|&mot~?B*v}<4{Nnkou22{MjW>sa)9@_4qlGAnK`;=wUzN1q~?>OQo|=N%F*9 zv?@82PIi6L>*rd0lWq;!EuE-Z4<>78k^SPG67I=|u+W{Ex^qNm=WOz_3d$h0jjc97 zmqA|FQ{c+F0r0lpip=^l>JCL?wCz)FkG}&TYBH(8OKFMtr+*wuyX*tUMlo4wGf;IJ zL8Ic-_UECSk?Ka7+E_W(@oRhhb+FW54^!qFx5y7uV%!ea4oDyb0K1+NMQX%dJfuh- z!25JLTG#y~mL39NwOV`D>hZ>dkvoGQ*Z6uu5 z0G<4g;}GYsk%;B23xrZn^9`(`mD-(ZL>pScSQ&a=_m@c-E+Snyi=JEx`6 zK3&WLdG?oas8!@b|H;E3pba37R$zUpbzF-Y@|PDf+^sQ57u7jCB-vNM^WopmtM*QbzmmZR z=lWaXwm6braw{`oL-9@`C|EoVefFIaxOA<|C<4-kuI3EyS z-M@$V;&-Eq(+E5<(I#2*NUY`JF8SrEOi>IRd&$Z|&%&25fx-DvpzP%IWS>UV(4R8_ zQzz;zKPdJJ`idC~+N=gsI88^f3^9RYi?9Zeep*z&IR%Ca;{+qqK=g_8nl~Vq*&f4B z+X9Ecj7Gm1@-h6c*TCoI=*>@mBHW z?E*#q6~2MjOMs#CRbSTtm_By}gh06*dJIZJTdq~Up$wopT@>S6MK!VN>cZ81-uxJH zB67)pv*xkb6Tu_FIYEBtHrHqPU- zO$P^+K{|9q#CD|O*>+`iZrPt6y5XNyK?90FFd_8Lb~`H#4Fdrk-XGn;anE!7yt8uK zqyA^RDIw`|NY@4H4{nM{ec%=*FTYNquR_Gmh$Y!BpT0TSC!%VUqUC_7cW&D8 z_%7Q0D)v~ab*G!6b@);3ylVsRA)9^*X$KBUaZ1T{Ykv1^thX&c!ZO9##@kJPuyjdr zAIitnNR4w?g}QwDM#bCZ{}QLNx$E@iF4HmZcGz?@1S%@ zB2Suh9Mc%ab2vBR5p6@My#6p3{?e0@O^)O@m1hofb=R{4)+O!l-CEu0fw^INRctv! z7->&DvI>|yiG@91r0+C!`0`WZZaL9Pw4tPZac=SnCvP9IOsib&-TE%ox^`04<4XgY zOG(K!Ea)CPOYZ#KOSYp)O2PL;B%^9NJCf};S*TClawLf__a$ppyJJ&mkxqrlN`^4G zvZ79^5ff`M;rfg-`2ZUnklCDSJyfW)uMqeRR0o^53)Ql$6YP@g`iVTPjY$|$`aRu~j}Q8a_Q^dtP37=y`S!~T zH74V{GuKPR{4+qAx_M5Kx9f25gQf@^#M>@-&9VX|3avJUB}$=_Z?`tx6{Fv{NKOA@ z3Q8L)n}9aFNVpz7#UnzLEJzL&4mb^}?IU#2I$-L<0}Cko(Z>Xw;0`FpjOppD57|R$ zocDKJ(jgCTR1s@az{dPBw-#ZgliwLkEl(4Xjo-YVW}Yaa;;^_DR9=QVQJ%qQ{z-Zz z7~fNy@3XSv!IT*-PtStfuS&Nl2PEh8Bn0xG25g90Sc^DI=geSQGyqj^GIEkvwR)r5 zHt({bHBezNq5QcS+;DKOwo<&OnEQZ^TQ7kQZ%oUzd2>JNBu9GqX+VPhbqIO|XSOdu zoTgzE-=$k4uco>N_Uzq9!P32dvkyL$7}JEAnn(F=5cEiL_fydIp9Ld<9H5Wo>2UJDvo>D4l@=3kiCn#`vrj}Y6xN-E5 z9>bVn$CQb3x&Y?&VB-X7a2~f4@8v#E46KgetP&T7~LXGvn3$v_jbme|S zy_SPePvA~>2Sy9A{2Q0h9@%n(EsF9~XQe-tDQEI5Wq_hF?8(HH8h#=`s9_-nnhrqvD_ewD3_vh!ObHcY~X}x*6O`+Pu3*lbapt$aM>Erh6}GyZ(B5Y zKIqO||6hvo;I?tk@!Wbz>-2fAQ+k^Kzj;-BH!c%Jz;twUKW5Zt6#E=G{hL}t4-hb63wOUKQLKkcQdU5%G?BZB-XB~27728lmZuz@UFbFQ$ OA*#b(`|4fvv;PIu#F1eD literal 218 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VXMsm#F#`j)FbFd;%$g$s6l5$8 za(7}_cTVOdki(Mh=7A=>TW>jgt>IfAr0oTA@;N zM&O^Lh2`&?Gf(q$S8Z4yF3{k7X#0g=j{nXUT%9*gXYO3KAll4x*0#L;d)sCLt!D6a L^>bP0l+XkK56(>a diff --git a/wallet_app/local.properties b/wallet_app/local.properties index 9e09d72f..29ab9f8a 100644 --- a/wallet_app/local.properties +++ b/wallet_app/local.properties @@ -4,8 +4,8 @@ # Location of the SDK. This is only used by Gradle. # For customization when using a Version Control System, please read the # header note. -#Sun Oct 06 17:45:21 CDT 2024 +#Tue Dec 10 11:04:46 IST 2024 ACCOUNT_ADDRESS=0x06b06423feba3e1a345095699c59430e936c5413699ff9ef8ec8a6dbefdab1f1 KEY_NAME= -RPC_URL=https://starknet-mainnet.g.alchemy.com/starknet/version/rpc/v0_7/Fl4zNtN2hak5hrWq92a8pnB-ZospWX9a -sdk.dir=/home/thomas/Android/Sdk +RPC_URL=https://starknet-sepolia.g.alchemy.com/starknet/version/rpc/v0_7/yPM6Zsiftub_GVxfcKGpDzoS1J89DrnZ +sdk.dir=C\:\\Users\\user\\AppData\\Local\\Android\\Sdk From 66a0fcfd37ef827a42bc4eb46db448f719ff1e45 Mon Sep 17 00:00:00 2001 From: sajal Date: Thu, 12 Dec 2024 15:09:08 +0530 Subject: [PATCH 2/6] Some minor changes --- wallet_app/app/.gitignore | 3 +- .../com/example/walletapp/ui/WalletApp.kt | 4 +- .../walletapp/ui/account/WalletScreen.kt | 57 +++++++++-------- .../walletapp/ui/transfer/ReceiveScreen.kt | 61 ++++++++++++------- .../walletapp/ui/transfer/SendScreen.kt | 16 ++++- 5 files changed, 88 insertions(+), 53 deletions(-) diff --git a/wallet_app/app/.gitignore b/wallet_app/app/.gitignore index 591843f0..3449035b 100644 --- a/wallet_app/app/.gitignore +++ b/wallet_app/app/.gitignore @@ -1,2 +1,3 @@ android/app/build -build \ No newline at end of file +build +local.properties \ No newline at end of file diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt index 8a26af1b..51b4ed26 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt @@ -112,10 +112,10 @@ fun WalletApp(tokenViewModel: TokenViewModel) { } composable { - SendScreen(walletViewModel) + SendScreen(walletViewModel,navController) } composable { - ReceiveScreen(modifier = Modifier) + ReceiveScreen(modifier = Modifier,navController) } } } diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt index 0de63670..b8d77a66 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/account/WalletScreen.kt @@ -8,7 +8,6 @@ import androidx.compose.foundation.Image import androidx.compose.foundation.background import androidx.compose.foundation.border import androidx.compose.foundation.clickable -import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row @@ -27,7 +26,6 @@ import androidx.compose.material3.Card import androidx.compose.material3.Surface import androidx.compose.material3.Text import androidx.compose.runtime.Composable -import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.LocalContext @@ -52,6 +50,8 @@ import androidx.compose.ui.platform.LocalConfiguration import androidx.compose.ui.text.font.FontWeight import androidx.compose.ui.text.style.TextAlign import android.content.ClipData +import androidx.compose.foundation.layout.Arrangement +import androidx.compose.ui.Alignment import androidx.compose.ui.text.toUpperCase import androidx.compose.ui.window.Popup import androidx.compose.ui.window.PopupProperties @@ -174,35 +174,38 @@ fun Wallet(modifier: Modifier, onNewTokenPress: () -> Unit, onReceivePress: () - }.sum() val formatter = NumberFormat.getCurrencyInstance(Locale.US) - Text( - text = formatter.format(totalBalance), - fontFamily = FontFamily(Font(R.font.publicsans_bold)), - color = Color.White, - fontSize = 26.sp, - modifier = Modifier - .align(Alignment.CenterHorizontally) - .padding(top = 70.dp) - ) - Row( - modifier = Modifier.align(Alignment.CenterHorizontally)) { + Column(verticalArrangement = Arrangement.Center, horizontalAlignment = Alignment.CenterHorizontally, modifier = Modifier.fillMaxWidth()) { Text( - text = address.take(8) + "....", - fontFamily = FontFamily(Font(R.font.inter_regular)), + text = formatter.format(totalBalance), + fontFamily = FontFamily(Font(R.font.publicsans_bold)), color = Color.White, - fontSize = 12.sp, - ) - Icon( - painter = painterResource(R.drawable.copy),// replace with your Ethereum icon - contentDescription = null, - tint=Color.White, - modifier = Modifier.padding(start=5.dp) - .size(15.dp).clickable { - val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) - clipboard.setClip(clip) - Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() - } + fontSize = 26.sp, + modifier = Modifier + .align(Alignment.CenterHorizontally) + .padding(top = 70.dp) ) + Row( + modifier = Modifier.fillMaxWidth(), verticalAlignment = Alignment.CenterVertically, horizontalArrangement = Arrangement.Center + ) { + Text( + text = address.take(8) + "...", + fontFamily = FontFamily(Font(R.font.inter_regular)), + color = Color.White, + fontSize = 12.sp, + ) + Icon( + painter = painterResource(R.drawable.copy),// replace with your Ethereum icon + contentDescription = null, + tint = Color.White, + modifier = Modifier.padding(start = 5.dp) + .size(15.dp).clickable { + val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) + clipboard.setClip(clip) + Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() + } + ) + } } Spacer(modifier = Modifier.height(32.dp)) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt index f579d653..63f7615a 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/ReceiveScreen.kt @@ -8,11 +8,17 @@ import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column +import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer import androidx.compose.foundation.layout.fillMaxSize +import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.size +import androidx.compose.material.icons.Icons +import androidx.compose.material.icons.filled.ArrowBack +import androidx.compose.material3.Icon +import androidx.compose.material3.IconButton import androidx.compose.material3.Surface import androidx.compose.material3.Text import androidx.compose.runtime.Composable @@ -29,11 +35,12 @@ import androidx.compose.ui.text.font.FontFamily import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import androidx.core.graphics.toColorInt +import androidx.navigation.NavController import com.example.walletapp.BuildConfig import com.example.walletapp.R @Composable -fun ReceiveScreen(modifier: Modifier) { +fun ReceiveScreen(modifier: Modifier,navController: NavController) { val clipboard: ClipboardManager = LocalClipboardManager.current val context= LocalContext.current val address= BuildConfig.ACCOUNT_ADDRESS @@ -45,8 +52,19 @@ fun ReceiveScreen(modifier: Modifier) { .background(Color("#0C0C4F".toColorInt())) // Your dark blue background color .padding(16.dp), horizontalAlignment = Alignment.CenterHorizontally, - verticalArrangement = Arrangement.Center ) { + // Back Button + IconButton( + onClick = { navController.navigateUp() }, + modifier = Modifier.align(Alignment.Start) + ) { + Icon( + imageVector = Icons.Default.ArrowBack, + contentDescription = "Back", + tint = Color.White + ) + } + Spacer(modifier = Modifier.height(40.dp)) // QR Code Image Box( modifier = Modifier @@ -62,28 +80,27 @@ fun ReceiveScreen(modifier: Modifier) { Spacer(modifier = Modifier.height(24.dp)) - // Wallet Address - Text( - text = address.take(8) + "....", - fontFamily = FontFamily(Font(R.font.publicsans_bold)), - color = Color.White, - fontSize = 40.sp - ) - Spacer(modifier = Modifier.height(8.dp)) + Row(modifier = Modifier.fillMaxWidth(), verticalAlignment = Alignment.CenterVertically, horizontalArrangement = Arrangement.Center) { + Text( + text = address.take(8) + "...", + fontFamily = FontFamily(Font(R.font.publicsans_bold)), + color = Color.White, + fontSize = 30.sp + ) + Icon( + painter = painterResource(R.drawable.copy),// replace with your Ethereum icon + contentDescription = null, + tint=Color.White, + modifier = Modifier.padding(start=5.dp) + .size(25.dp).clickable { + val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) + clipboard.setClip(clip) + Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() + } + ) - // Clickable Text for Copy - Text( - text = "Click to copy address", - fontFamily = FontFamily(Font(R.font.publicsans_regular)), - color = Color.White, - fontSize = 15.sp, - modifier = Modifier.clickable { - val clip = ClipEntry(ClipData.newPlainText("Wallet Address", address)) - clipboard.setClip(clip) - Toast.makeText(context, "Address Copied", Toast.LENGTH_LONG).show() - } - ) + } } } diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt index 31625579..e8d6a2c8 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/transfer/SendScreen.kt @@ -44,12 +44,15 @@ import com.example.walletapp.R import com.example.walletapp.ui.account.WalletViewModel import android.widget.Toast import androidx.compose.foundation.layout.Box +import androidx.compose.material.icons.filled.ArrowBack import androidx.compose.material3.DropdownMenu import androidx.compose.material3.DropdownMenuItem +import androidx.compose.material3.IconButton import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.collectAsState import androidx.compose.runtime.remember import androidx.compose.ui.platform.LocalContext +import androidx.navigation.NavController import com.example.walletapp.utils.etherToWei import com.example.walletapp.utils.isValidEthereumAddress import com.swmansion.starknet.account.StandardAccount @@ -63,7 +66,7 @@ import java.math.BigDecimal @Composable -fun SendScreen(walletViewModel: WalletViewModel) { +fun SendScreen(walletViewModel: WalletViewModel,navController: NavController) { val balances by walletViewModel.balances.collectAsState() val address= BuildConfig.ACCOUNT_ADDRESS @@ -143,6 +146,17 @@ fun SendScreen(walletViewModel: WalletViewModel) { horizontalAlignment = Alignment.CenterHorizontally, verticalArrangement = Arrangement.Center ) { + // Back Button + IconButton( + onClick = { navController.navigateUp() }, + modifier = Modifier.align(Alignment.Start) + ) { + Icon( + imageVector = Icons.Default.ArrowBack, + contentDescription = "Back", + tint = Color.White + ) + } Spacer(modifier = Modifier.height(40.dp)) // "From" label above the wallet address field (readonly) From f3a714941ac6329d51e5be071ec08fd47b2aa44f Mon Sep 17 00:00:00 2001 From: sajal Date: Thu, 12 Dec 2024 15:18:07 +0530 Subject: [PATCH 3/6] Remove local.properties from repository --- wallet_app/local.properties | 11 ----------- 1 file changed, 11 deletions(-) delete mode 100644 wallet_app/local.properties diff --git a/wallet_app/local.properties b/wallet_app/local.properties deleted file mode 100644 index 29ab9f8a..00000000 --- a/wallet_app/local.properties +++ /dev/null @@ -1,11 +0,0 @@ -## This file must *NOT* be checked into Version Control Systems, -# as it contains information specific to your local configuration. -# -# Location of the SDK. This is only used by Gradle. -# For customization when using a Version Control System, please read the -# header note. -#Tue Dec 10 11:04:46 IST 2024 -ACCOUNT_ADDRESS=0x06b06423feba3e1a345095699c59430e936c5413699ff9ef8ec8a6dbefdab1f1 -KEY_NAME= -RPC_URL=https://starknet-sepolia.g.alchemy.com/starknet/version/rpc/v0_7/yPM6Zsiftub_GVxfcKGpDzoS1J89DrnZ -sdk.dir=C\:\\Users\\user\\AppData\\Local\\Android\\Sdk From 4f9369237795ca303e216910cd8c072466c680c6 Mon Sep 17 00:00:00 2001 From: sajal Date: Sun, 22 Dec 2024 00:16:47 +0530 Subject: [PATCH 4/6] Save Account Info --- wallet_app/app/build.gradle.kts | 4 ++ .../walletapp/datastore/DataStoreModule.kt | 48 +++++++++++++++++++ .../com/example/walletapp/ui/WalletApp.kt | 31 +++++++----- .../FinalizeAccountCreationScreen.kt | 12 ++++- .../ui/onboarding/ImportAccountScreen.kt | 16 ++++++- 5 files changed, 95 insertions(+), 16 deletions(-) create mode 100644 wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt diff --git a/wallet_app/app/build.gradle.kts b/wallet_app/app/build.gradle.kts index 28eef37c..b1c09b6e 100644 --- a/wallet_app/app/build.gradle.kts +++ b/wallet_app/app/build.gradle.kts @@ -74,6 +74,10 @@ dependencies { implementation("com.swmansion.starknet:starknet:0.13.0@aar"){ isTransitive = true } + + // DataStore + implementation("androidx.datastore:datastore-preferences:1.1.1") + // Navigation stuff implementation(libs.androidx.navigation.compose.v283) implementation(libs.androidx.navigation.compose.v283) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt b/wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt new file mode 100644 index 00000000..8bc3b34a --- /dev/null +++ b/wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt @@ -0,0 +1,48 @@ +package com.example.walletapp.datastore + +import android.content.Context +import androidx.datastore.core.DataStore +import androidx.datastore.preferences.core.Preferences +import androidx.datastore.preferences.core.booleanPreferencesKey +import androidx.datastore.preferences.core.edit +import androidx.datastore.preferences.core.stringPreferencesKey +import androidx.datastore.preferences.preferencesDataStore +import kotlinx.coroutines.flow.Flow +import kotlinx.coroutines.flow.map + +class DataStoreModule(private val context: Context) { + companion object { + private val Context.dataStore: DataStore by preferencesDataStore("wallet_prefs") + private val HAS_ACCOUNT = booleanPreferencesKey("has_account") + private val ACCOUNT_NAME = stringPreferencesKey("acc_name") + private val PRIVATE_KEY = stringPreferencesKey("private_key") + } + + val hasAccount: Flow = context.dataStore.data.map { preferences -> + preferences[HAS_ACCOUNT] ?: false + } + + suspend fun setHasAccount(hasAccount: Boolean) { + context.dataStore.edit { preferences -> + preferences[HAS_ACCOUNT] = hasAccount + } + } + val accName: Flow = context.dataStore.data.map { preferences -> + preferences[ACCOUNT_NAME] ?: "" + } + + suspend fun setAccountName(accName: String) { + context.dataStore.edit { preferences -> + preferences[ACCOUNT_NAME] = accName + } + } + val privateKey: Flow = context.dataStore.data.map { preferences -> + preferences[PRIVATE_KEY] ?: "" + } + + suspend fun setPrivateKey(privateKey: String) { + context.dataStore.edit { preferences -> + preferences[PRIVATE_KEY] = privateKey + } + } +} \ No newline at end of file diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt index 51b4ed26..3350ed2f 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt @@ -1,12 +1,15 @@ package com.example.walletapp.ui import androidx.compose.runtime.Composable +import androidx.compose.runtime.collectAsState import androidx.compose.ui.Modifier +import androidx.compose.ui.platform.LocalContext import androidx.lifecycle.viewmodel.compose.viewModel import androidx.navigation.compose.NavHost import androidx.navigation.compose.composable import androidx.navigation.compose.rememberNavController import com.example.walletapp.BuildConfig +import com.example.walletapp.datastore.DataStoreModule import com.example.walletapp.ui.account.AddTokenScreen import com.example.walletapp.ui.account.TokenViewModel import com.example.walletapp.ui.account.WalletScreen @@ -19,6 +22,9 @@ import com.example.walletapp.ui.onboarding.OnboardingScreen import com.example.walletapp.ui.theme.WalletappTheme import com.example.walletapp.ui.transfer.ReceiveScreen import com.example.walletapp.ui.transfer.SendScreen +import kotlinx.coroutines.CoroutineScope +import kotlinx.coroutines.Dispatchers +import kotlinx.coroutines.launch import kotlinx.serialization.Serializable // main user account view @@ -48,21 +54,17 @@ object Receive @Composable fun WalletApp(tokenViewModel: TokenViewModel) { val walletViewModel: WalletViewModel = viewModel() + val context = LocalContext.current + val dataStore = DataStoreModule(context) + val hasAccountState = dataStore.hasAccount.collectAsState(initial = null) + hasAccountState.value?.let { hasAccount -> WalletappTheme { - // TODO(#109): get this information from a data store - val hasAccount = false - fun getStart(): Any { - return if (hasAccount) { - Wallet - } else { - Onboarding - } - } + val startDestination = if (hasAccount) Wallet else Onboarding val navController = rememberNavController() - NavHost(navController, startDestination = getStart()) { + NavHost(navController, startDestination = startDestination) { composable { OnboardingScreen( @@ -78,7 +80,7 @@ fun WalletApp(tokenViewModel: TokenViewModel) { } composable { FinalizeAccountCreationScreen( - onContinue = { navController.navigate( route = CreatePin )}, + onContinue = { navController.navigate( route = CreatePin ) }, onBackButtonPressed = { navController.navigateUp() } ) } @@ -90,7 +92,11 @@ fun WalletApp(tokenViewModel: TokenViewModel) { } composable { CreatePinScreen( - onContinue = { navController.navigate( route = Wallet )} + onContinue = { navController.navigate( route = Wallet ) + CoroutineScope(Dispatchers.IO).launch { + dataStore.setHasAccount(true) + } + } ) } @@ -119,4 +125,5 @@ fun WalletApp(tokenViewModel: TokenViewModel) { } } } + } } \ No newline at end of file diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt index 91d43ba9..f2caf3f6 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt @@ -32,6 +32,10 @@ import android.widget.Toast import androidx.compose.ui.graphics.painter.Painter import androidx.core.graphics.toColorInt import com.example.walletapp.R +import com.example.walletapp.datastore.DataStoreModule +import kotlinx.coroutines.CoroutineScope +import kotlinx.coroutines.Dispatchers +import kotlinx.coroutines.launch @OptIn(ExperimentalMaterial3Api::class) @Composable @@ -90,7 +94,7 @@ fun FinalizeAccountCreationScreen( fun AccountInfoView(onContinue: () -> Unit) { val context = LocalContext.current as Activity val clipboardManager = LocalContext.current.getSystemService(ClipboardManager::class.java) - + val dataStore = DataStoreModule(context) var checked by remember { mutableStateOf(true) } val accountName = "Starknet" val privateKey = "q78ggh277ibckewjtnM" @@ -276,7 +280,11 @@ fun AccountInfoView(onContinue: () -> Unit) { Spacer(modifier = Modifier.weight(1f)) Button( - onClick = onContinue, + onClick = {onContinue() + CoroutineScope(Dispatchers.IO).launch { + dataStore.setAccountName(accountName) + dataStore.setPrivateKey(privateKey) + }}, contentPadding = ButtonDefaults.ContentPadding, shape = RoundedCornerShape(8.dp), colors = ButtonDefaults.buttonColors( diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt index a996ad7f..ea9b69e3 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt @@ -52,7 +52,10 @@ import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import androidx.core.graphics.toColorInt import com.example.walletapp.R +import com.example.walletapp.datastore.DataStoreModule import kotlinx.coroutines.CoroutineScope +import kotlinx.coroutines.Dispatchers +import kotlinx.coroutines.launch @OptIn(ExperimentalMaterial3Api::class) @Composable @@ -145,6 +148,8 @@ fun PrivateKeyView(modifier: Modifier = Modifier, onNext: () -> Unit) { val scope = rememberCoroutineScope() var openBottomSheet by remember { mutableStateOf(false) } val sheetState = rememberModalBottomSheetState() + val context = (LocalContext.current as Activity) + val dataStore = DataStoreModule(context) Column( modifier = modifier @@ -197,7 +202,10 @@ fun PrivateKeyView(modifier: Modifier = Modifier, onNext: () -> Unit) { Spacer(modifier = Modifier.weight(1f)) Button( - onClick = onNext, + onClick = {onNext() + CoroutineScope(Dispatchers.IO).launch { + dataStore.setPrivateKey(accountName) + }}, contentPadding = ButtonDefaults.ContentPadding, shape = RoundedCornerShape(8.dp), colors = ButtonDefaults.buttonColors( @@ -231,6 +239,7 @@ fun CreateNameView(modifier: Modifier = Modifier, onFinishAccountImport: () -> U val borderColor = Color("#1B1B76".toColorInt()) var accountName by remember { mutableStateOf("") } val context = (LocalContext.current as Activity) + val dataStore = DataStoreModule(context) Column( modifier = modifier @@ -283,7 +292,10 @@ fun CreateNameView(modifier: Modifier = Modifier, onFinishAccountImport: () -> U Spacer(modifier = Modifier.weight(1f)) Button( - onClick = onFinishAccountImport, + onClick = {onFinishAccountImport() + CoroutineScope(Dispatchers.IO).launch { + dataStore.setAccountName(accountName) + }}, contentPadding = ButtonDefaults.ContentPadding, shape = RoundedCornerShape(8.dp), colors = ButtonDefaults.buttonColors( From 63c41e553b1ad20f3cb53bef3e6d539d89ee4aeb Mon Sep 17 00:00:00 2001 From: Thomas Date: Sun, 22 Dec 2024 22:09:43 -0600 Subject: [PATCH 5/6] rename datastore --- .../{DataStoreModule.kt => WalletStoreModule.kt} | 2 +- .../java/com/example/walletapp/ui/WalletApp.kt | 5 ++--- .../onboarding/FinalizeAccountCreationScreen.kt | 5 ++--- .../ui/onboarding/ImportAccountScreen.kt | 16 +++------------- 4 files changed, 8 insertions(+), 20 deletions(-) rename wallet_app/app/src/main/java/com/example/walletapp/datastore/{DataStoreModule.kt => WalletStoreModule.kt} (96%) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt b/wallet_app/app/src/main/java/com/example/walletapp/datastore/WalletStoreModule.kt similarity index 96% rename from wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt rename to wallet_app/app/src/main/java/com/example/walletapp/datastore/WalletStoreModule.kt index 8bc3b34a..5f4ae6ad 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/datastore/DataStoreModule.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/datastore/WalletStoreModule.kt @@ -10,7 +10,7 @@ import androidx.datastore.preferences.preferencesDataStore import kotlinx.coroutines.flow.Flow import kotlinx.coroutines.flow.map -class DataStoreModule(private val context: Context) { +class WalletStoreModule(private val context: Context) { companion object { private val Context.dataStore: DataStore by preferencesDataStore("wallet_prefs") private val HAS_ACCOUNT = booleanPreferencesKey("has_account") diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt index 3350ed2f..3326f7bf 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/WalletApp.kt @@ -8,8 +8,7 @@ import androidx.lifecycle.viewmodel.compose.viewModel import androidx.navigation.compose.NavHost import androidx.navigation.compose.composable import androidx.navigation.compose.rememberNavController -import com.example.walletapp.BuildConfig -import com.example.walletapp.datastore.DataStoreModule +import com.example.walletapp.datastore.WalletStoreModule import com.example.walletapp.ui.account.AddTokenScreen import com.example.walletapp.ui.account.TokenViewModel import com.example.walletapp.ui.account.WalletScreen @@ -55,7 +54,7 @@ object Receive fun WalletApp(tokenViewModel: TokenViewModel) { val walletViewModel: WalletViewModel = viewModel() val context = LocalContext.current - val dataStore = DataStoreModule(context) + val dataStore = WalletStoreModule(context) val hasAccountState = dataStore.hasAccount.collectAsState(initial = null) hasAccountState.value?.let { hasAccount -> WalletappTheme { diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt index f2caf3f6..cfb86b68 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/FinalizeAccountCreationScreen.kt @@ -29,10 +29,9 @@ import androidx.compose.ui.unit.sp import android.content.ClipboardManager import android.content.ClipData import android.widget.Toast -import androidx.compose.ui.graphics.painter.Painter import androidx.core.graphics.toColorInt import com.example.walletapp.R -import com.example.walletapp.datastore.DataStoreModule +import com.example.walletapp.datastore.WalletStoreModule import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch @@ -94,7 +93,7 @@ fun FinalizeAccountCreationScreen( fun AccountInfoView(onContinue: () -> Unit) { val context = LocalContext.current as Activity val clipboardManager = LocalContext.current.getSystemService(ClipboardManager::class.java) - val dataStore = DataStoreModule(context) + val dataStore = WalletStoreModule(context) var checked by remember { mutableStateOf(true) } val accountName = "Starknet" val privateKey = "q78ggh277ibckewjtnM" diff --git a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt index ea9b69e3..175f437b 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/ui/onboarding/ImportAccountScreen.kt @@ -1,10 +1,7 @@ package com.example.walletapp.ui.onboarding import android.app.Activity -import android.content.Intent -import androidx.compose.foundation.Image import androidx.compose.foundation.background -import androidx.compose.foundation.layout.Arrangement import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row @@ -13,7 +10,6 @@ import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding -import androidx.compose.foundation.layout.size import androidx.compose.foundation.layout.width import androidx.compose.foundation.shape.RoundedCornerShape import androidx.compose.material3.Button @@ -24,16 +20,12 @@ import androidx.compose.material3.OutlinedTextField import androidx.compose.material3.Scaffold import androidx.compose.material3.Text import androidx.compose.material3.TextFieldDefaults -import androidx.compose.material3.TopAppBar import androidx.compose.material3.ExperimentalMaterial3Api import androidx.compose.material3.IconButton -import androidx.compose.material3.ModalBottomSheet -import androidx.compose.material3.SheetState import androidx.compose.material3.rememberModalBottomSheetState import androidx.compose.material.icons.Icons import androidx.compose.material.icons.filled.ArrowBack import androidx.compose.material.icons.filled.ArrowForward -import androidx.compose.material3.TopAppBarDefaults import androidx.compose.runtime.Composable import androidx.compose.runtime.getValue import androidx.compose.runtime.mutableStateOf @@ -44,15 +36,13 @@ import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.LocalContext -import androidx.compose.ui.res.painterResource import androidx.compose.ui.text.TextStyle import androidx.compose.ui.text.font.FontWeight import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import androidx.core.graphics.toColorInt -import com.example.walletapp.R -import com.example.walletapp.datastore.DataStoreModule +import com.example.walletapp.datastore.WalletStoreModule import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch @@ -149,7 +139,7 @@ fun PrivateKeyView(modifier: Modifier = Modifier, onNext: () -> Unit) { var openBottomSheet by remember { mutableStateOf(false) } val sheetState = rememberModalBottomSheetState() val context = (LocalContext.current as Activity) - val dataStore = DataStoreModule(context) + val dataStore = WalletStoreModule(context) Column( modifier = modifier @@ -239,7 +229,7 @@ fun CreateNameView(modifier: Modifier = Modifier, onFinishAccountImport: () -> U val borderColor = Color("#1B1B76".toColorInt()) var accountName by remember { mutableStateOf("") } val context = (LocalContext.current as Activity) - val dataStore = DataStoreModule(context) + val dataStore = WalletStoreModule(context) Column( modifier = modifier From eceab4cc99dae62b0bc57eac8918800dd99f67d8 Mon Sep 17 00:00:00 2001 From: Thomas Date: Sun, 22 Dec 2024 22:39:28 -0600 Subject: [PATCH 6/6] remove unused vars --- .../main/java/com/example/walletapp/utils/StarknetClient.kt | 3 --- 1 file changed, 3 deletions(-) diff --git a/wallet_app/app/src/main/java/com/example/walletapp/utils/StarknetClient.kt b/wallet_app/app/src/main/java/com/example/walletapp/utils/StarknetClient.kt index 342fabf0..aaf45c55 100644 --- a/wallet_app/app/src/main/java/com/example/walletapp/utils/StarknetClient.kt +++ b/wallet_app/app/src/main/java/com/example/walletapp/utils/StarknetClient.kt @@ -32,9 +32,6 @@ const val ACCOUNT_CLASS_HASH = "0x04c6d6cf894f8bc96bb9c525e6853e5483177841f7388f class StarknetClient(private val rpcUrl: String) { private val provider = JsonRpcProvider(rpcUrl) - private val privateKey = BuildConfig.PRIVATE_KEY - private val accountAddress = BuildConfig.ACCOUNT_ADDRESS - private val tag = "StarknetClient" private val keystore = Keystore() suspend fun deployAccount() {