Skip to content

Commit

Permalink
Merge pull request #22 from NeoAren/cleanup
Browse files Browse the repository at this point in the history
Small cleanup (mostly indentation) + update README
  • Loading branch information
tamaskr authored Oct 15, 2022
2 parents 53b5c11 + 0890805 commit 67c7b8d
Show file tree
Hide file tree
Showing 14 changed files with 243 additions and 155 deletions.
10 changes: 8 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,15 @@ VirtualTag is a native Android application, which lets you scan NFC tags using t

## Installation

1. Install and configure [Android Studio](https://developer.android.com/studio/install)
1. Install [Android Studio](https://developer.android.com/studio/install)

2. Open Android Studio and install the application on an [emulator](https://developer.android.com/studio/run/emulator) on an [Android device](https://developer.android.com/studio/run/device) (note - emulators do not have support for NFC)
2. Open Android Studio and install the application on an [emulator](https://developer.android.com/studio/run/emulator) on an [Android device](https://developer.android.com/studio/run/device) *(note - emulators do not have support for NFC)*

## Screenshots

![XRecorder_15102022_130804](https://user-images.githubusercontent.com/91802386/195981888-0016187d-210a-4917-ba07-5dd213150e1c.jpg)
![XRecorder_15102022_130816](https://user-images.githubusercontent.com/91802386/195981890-d573fc3d-e09b-4842-95d6-9277331b15b1.jpg)
![XRecorder_15102022_131423](https://user-images.githubusercontent.com/91802386/195981891-30d148d6-cd42-415e-addd-131e0e6ed1cb.png)

## Used libraries

Expand Down
3 changes: 2 additions & 1 deletion app/src/main/java/com/virtualtag/app/MainActivity.kt
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,8 @@ class MainActivity : ComponentActivity() {
goHome = goHome
)
}
composable("edit/{id}",
composable(
"edit/{id}",
arguments = listOf(navArgument("id") {
type = NavType.StringType
})
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,7 @@ fun CardContainer(
elevation = 2.dp,
modifier = Modifier
.fillMaxWidth()
.padding(top = 8.dp, bottom = 8.dp)
.padding(horizontal = 12.dp),
.padding(vertical = 8.dp),
onClick = onClick,
backgroundColor = color,
enabled = enabled
Expand Down
53 changes: 35 additions & 18 deletions app/src/main/java/com/virtualtag/app/ui/components/DataRow.kt
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import androidx.compose.material.Divider
import androidx.compose.material.Icon
import androidx.compose.material.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.graphics.vector.ImageVector
Expand All @@ -24,26 +25,42 @@ import com.virtualtag.app.R
fun DataRow(title: String, content: String, icon: ImageVector) {
val context = LocalContext.current
val clipboardManager: ClipboardManager = LocalClipboardManager.current
Column(modifier = Modifier
.fillMaxWidth()
.combinedClickable(
onLongClick = {
clipboardManager.setText(AnnotatedString(content))
Toast
.makeText(context, context.getString(R.string.clipboard), Toast.LENGTH_SHORT)
.show()
},
onClick = { /* do nothing */ })) {
Row(modifier = Modifier
Column(
modifier = Modifier
.fillMaxWidth()
.padding(top = 8.dp)) {
Icon(icon, contentDescription = null, modifier = Modifier
.size(48.dp)
.padding(horizontal = 4.dp))
Column(modifier = Modifier
.combinedClickable(
onLongClick = {
clipboardManager.setText(AnnotatedString(content))
Toast
.makeText(
context,
context.getString(R.string.clipboard),
Toast.LENGTH_SHORT
)
.show()
},
onClick = { /* do nothing */ })
) {
Row(
modifier = Modifier
.fillMaxWidth()
.padding(top = 2.dp, end = 16.dp)) {
Text(title, fontWeight = FontWeight.Bold, modifier = Modifier.padding(bottom = 4.dp))
.padding(top = 8.dp), verticalAlignment = Alignment.CenterVertically
) {
Icon(
icon, contentDescription = null, modifier = Modifier
.size(48.dp)
.padding(vertical = 4.dp)
)
Column(
modifier = Modifier
.fillMaxWidth()
.padding(top = 2.dp, end = 16.dp)
) {
Text(
title,
fontWeight = FontWeight.Bold,
modifier = Modifier.padding(bottom = 4.dp)
)
Text(content, modifier = Modifier.padding(bottom = 8.dp))
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,68 +38,79 @@ fun MifareClassicView(card: Card) {
DataRow(
title = stringResource(R.string.serial_number),
content = serialNumber,
icon = Icons.Filled.Key)
icon = Icons.Filled.Key
)
}
item {
DataRow(
title = stringResource(R.string.technologies),
content = techList,
icon = Icons.Filled.Style)
icon = Icons.Filled.Style
)
}
item {
DataRow(
title = stringResource(R.string.type),
content = type,
icon = Icons.Filled.Category)
icon = Icons.Filled.Category
)
}
item {
DataRow(
title = stringResource(R.string.mem_size),
content = "$size bytes",
icon = Icons.Filled.Save)
icon = Icons.Filled.Save
)
}
item {
DataRow(
title = stringResource(R.string.mem_sector_count),
content = "$sectorCount",
icon = Icons.Filled.Save)
icon = Icons.Filled.Save
)
}
item {
DataRow(
title = stringResource(R.string.mem_block_count),
content = "$blockCount",
icon = Icons.Filled.Save)
icon = Icons.Filled.Save
)
}
item {
DataRow(
title = stringResource(R.string.transcieve_timeout),
content = "$timeout ${stringResource(R.string.ms)}",
icon = Icons.Filled.Sensors)
icon = Icons.Filled.Sensors
)
}
item {
DataRow(
title = stringResource(R.string.transcieve_max_length),
content = "$maxTranscieveLength ${stringResource(R.string.bytes)}",
icon = Icons.Filled.Sensors)
icon = Icons.Filled.Sensors
)
}
item {
DataRow(
title = stringResource(R.string.atqa),
content = atqa,
icon = Icons.Filled.Code)
icon = Icons.Filled.Code
)
}
item {
DataRow(
title = stringResource(R.string.sak),
content = "$sak",
icon = Icons.Filled.Code)
icon = Icons.Filled.Code
)
}
if (data.isNotEmpty()) {
items(blockCount) { index ->
DataRow(
title = "${stringResource(R.string.mem_block)} ${index + 1}",
content = formatHex(data.substring(index * 32, index * 32 + 32)),
icon = Icons.Filled.Memory)
icon = Icons.Filled.Memory
)
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,56 +40,65 @@ fun MifareUltralightView(card: Card) {
DataRow(
title = stringResource(R.string.serial_number),
content = serialNumber,
icon = Icons.Filled.Key)
icon = Icons.Filled.Key
)
}
item {
DataRow(
title = stringResource(R.string.technologies),
content = techList,
icon = Icons.Filled.Style)
icon = Icons.Filled.Style
)
}
item {
DataRow(
title = stringResource(R.string.type),
content = type,
icon = Icons.Filled.Category)
icon = Icons.Filled.Category
)
}
item {
DataRow(
title = stringResource(R.string.mem_size),
content = "$size bytes",
icon = Icons.Filled.Save)
icon = Icons.Filled.Save
)
}
item {
DataRow(
title = stringResource(R.string.transcieve_timeout),
content = "$timeout ${stringResource(R.string.ms)}",
icon = Icons.Filled.Sensors)
icon = Icons.Filled.Sensors
)
}
item {
DataRow(
title = stringResource(R.string.transcieve_max_length),
content = "$maxTranscieveLength ${stringResource(R.string.bytes)}",
icon = Icons.Filled.Sensors)
icon = Icons.Filled.Sensors
)
}
item {
DataRow(
title = stringResource(R.string.atqa),
content = atqa,
icon = Icons.Filled.Code)
icon = Icons.Filled.Code
)
}
item {
DataRow(
title = stringResource(R.string.sak),
content = "$sak",
icon = Icons.Filled.Code)
icon = Icons.Filled.Code
)
}
if (data.isNotEmpty()) {
items(dataPageCount) { index ->
DataRow(
title = "${stringResource(R.string.mem_page)} ${index + 1}",
content = formatHex(data.substring(index * 8, index * 8 + 8)),
icon = Icons.Filled.Memory)
icon = Icons.Filled.Memory
)
}
}
}
Expand Down
66 changes: 37 additions & 29 deletions app/src/main/java/com/virtualtag/app/ui/screens/AddScreen.kt
Original file line number Diff line number Diff line change
Expand Up @@ -43,35 +43,42 @@ fun AddScreen(

fun addCardToDb() {
if (name.text == "") {
Toast.makeText(context, context.getString(R.string.empty_name_error), Toast.LENGTH_SHORT).show()
Toast.makeText(
context,
context.getString(R.string.empty_name_error),
Toast.LENGTH_SHORT
).show()
return
}
model.addCard(Card(
id = 0,
name = name.text,
color = color,
// Tag properties
serialNumber = scannedTag.value?.id?.toHex() ?: "0",
techList = scannedTag.value?.techList?.joinToString(",") ?: "",
// MifareClassic properties
mifareClassicAtqa = mifareClassicInfo.value?.atqa,
mifareClassicSak = mifareClassicInfo.value?.sak,
mifareClassicTimeout = mifareClassicInfo.value?.timeout,
mifareClassicMaxTransceiveLength = mifareClassicInfo.value?.maxTransceiveLength,
mifareClassicSize = mifareClassicInfo.value?.size,
mifareClassicType = mifareClassicInfo.value?.type,
mifareClassicSectorCount = mifareClassicInfo.value?.sectorCount,
mifareClassicBlockCount = mifareClassicInfo.value?.blockCount,
mifareClassicData = mifareClassicInfo.value?.data,
// MifareUltralight properties
mifareUltralightType = mifareUltralightInfo.value?.type,
mifareUltralightTimeout = mifareUltralightInfo.value?.timeout,
mifareUltralightMaxTransceiveLength = mifareUltralightInfo.value?.maxTransceiveLength,
mifareUltralightAtqa = mifareUltralightInfo.value?.atqa,
mifareUltralightSak = mifareUltralightInfo.value?.sak,
mifareUltralightData = mifareUltralightInfo.value?.data,
))
Toast.makeText(context, context.getString(R.string.card_added_success), Toast.LENGTH_SHORT).show()
model.addCard(
Card(
id = 0,
name = name.text,
color = color,
// Tag properties
serialNumber = scannedTag.value?.id?.toHex() ?: "0",
techList = scannedTag.value?.techList?.joinToString(",") ?: "",
// MifareClassic properties
mifareClassicAtqa = mifareClassicInfo.value?.atqa,
mifareClassicSak = mifareClassicInfo.value?.sak,
mifareClassicTimeout = mifareClassicInfo.value?.timeout,
mifareClassicMaxTransceiveLength = mifareClassicInfo.value?.maxTransceiveLength,
mifareClassicSize = mifareClassicInfo.value?.size,
mifareClassicType = mifareClassicInfo.value?.type,
mifareClassicSectorCount = mifareClassicInfo.value?.sectorCount,
mifareClassicBlockCount = mifareClassicInfo.value?.blockCount,
mifareClassicData = mifareClassicInfo.value?.data,
// MifareUltralight properties
mifareUltralightType = mifareUltralightInfo.value?.type,
mifareUltralightTimeout = mifareUltralightInfo.value?.timeout,
mifareUltralightMaxTransceiveLength = mifareUltralightInfo.value?.maxTransceiveLength,
mifareUltralightAtqa = mifareUltralightInfo.value?.atqa,
mifareUltralightSak = mifareUltralightInfo.value?.sak,
mifareUltralightData = mifareUltralightInfo.value?.data,
)
)
Toast.makeText(context, context.getString(R.string.card_added_success), Toast.LENGTH_SHORT)
.show()
goHome()
}

Expand Down Expand Up @@ -155,7 +162,7 @@ fun AddScreen(
SecondaryButton(
text = stringResource(R.string.cancel),
onClick = goHome,
modifier = Modifier.padding(top = 8.dp, bottom = 8.dp)
modifier = Modifier.padding(vertical = 8.dp)
)
}
Column(
Expand All @@ -166,7 +173,8 @@ fun AddScreen(
PrimaryButton(
text = stringResource(R.string.ok),
onClick = { addCardToDb() },
modifier = Modifier.padding(top = 8.dp, bottom = 8.dp))
modifier = Modifier.padding(vertical = 8.dp)
)
}
}
}
Expand Down
Loading

0 comments on commit 67c7b8d

Please sign in to comment.