mirror of
https://github.com/nacabaro/vbhelper.git
synced 2026-01-27 16:05:32 +00:00
Merge pull request #47 from nacabaro/specialMissions/fix
Fix Special Missions a bit more
This commit is contained in:
commit
8c99046edb
@ -152,7 +152,8 @@ fun ItemDisplay(
|
|||||||
fun SpecialMissionsEntry(
|
fun SpecialMissionsEntry(
|
||||||
specialMission: SpecialMissions,
|
specialMission: SpecialMissions,
|
||||||
modifier: Modifier = Modifier,
|
modifier: Modifier = Modifier,
|
||||||
onClickCard: () -> Unit = { },
|
onClickMission: (Long) -> Unit = { },
|
||||||
|
onClickCollect: (Long) -> Unit = { }
|
||||||
) {
|
) {
|
||||||
val textValue = when (specialMission.missionType) {
|
val textValue = when (specialMission.missionType) {
|
||||||
SpecialMission.Type.NONE -> stringResource(R.string.special_mission_none)
|
SpecialMission.Type.NONE -> stringResource(R.string.special_mission_none)
|
||||||
@ -219,10 +220,12 @@ fun SpecialMissionsEntry(
|
|||||||
Card(
|
Card(
|
||||||
modifier = modifier,
|
modifier = modifier,
|
||||||
shape = androidx.compose.material.MaterialTheme.shapes.small,
|
shape = androidx.compose.material.MaterialTheme.shapes.small,
|
||||||
onClick = if (specialMission.status == SpecialMission.Status.COMPLETED || specialMission.status == SpecialMission.Status.FAILED) {
|
onClick = if (specialMission.status == SpecialMission.Status.COMPLETED) {
|
||||||
onClickCard
|
{ onClickCollect(specialMission.id) }
|
||||||
|
} else if (specialMission.status == SpecialMission.Status.UNAVAILABLE) {
|
||||||
|
{ }
|
||||||
} else {
|
} else {
|
||||||
{ }
|
{ onClickMission(specialMission.id) }
|
||||||
},
|
},
|
||||||
colors = CardDefaults.cardColors(
|
colors = CardDefaults.cardColors(
|
||||||
containerColor = color
|
containerColor = color
|
||||||
|
|||||||
@ -2,6 +2,8 @@ package com.github.nacabaro.vbhelper.daos
|
|||||||
|
|
||||||
import androidx.room.Dao
|
import androidx.room.Dao
|
||||||
import androidx.room.Query
|
import androidx.room.Query
|
||||||
|
import com.github.nacabaro.vbhelper.domain.device_data.SpecialMissions
|
||||||
|
import kotlinx.coroutines.flow.Flow
|
||||||
|
|
||||||
@Dao
|
@Dao
|
||||||
interface SpecialMissionDao {
|
interface SpecialMissionDao {
|
||||||
@ -12,4 +14,11 @@ interface SpecialMissionDao {
|
|||||||
WHERE id = :id
|
WHERE id = :id
|
||||||
""")
|
""")
|
||||||
suspend fun clearSpecialMission(id: Long)
|
suspend fun clearSpecialMission(id: Long)
|
||||||
|
|
||||||
|
@Query("""
|
||||||
|
SELECT *
|
||||||
|
FROM SpecialMissions
|
||||||
|
WHERE id = :id
|
||||||
|
""")
|
||||||
|
fun getSpecialMission(id: Long): Flow<SpecialMissions>
|
||||||
}
|
}
|
||||||
@ -1,9 +1,8 @@
|
|||||||
package com.github.nacabaro.vbhelper.screens.homeScreens
|
package com.github.nacabaro.vbhelper.screens.homeScreens
|
||||||
|
|
||||||
import com.github.cfogrady.vbnfc.vb.SpecialMission
|
|
||||||
import com.github.nacabaro.vbhelper.dtos.ItemDtos
|
import com.github.nacabaro.vbhelper.dtos.ItemDtos
|
||||||
|
|
||||||
interface HomeScreenController {
|
interface HomeScreenController {
|
||||||
fun didAdventureMissionsFinish(onCompletion: (Boolean) -> Unit)
|
fun didAdventureMissionsFinish(onCompletion: (Boolean) -> Unit)
|
||||||
fun clearSpecialMission(missionId: Long, missionCompletion: SpecialMission.Status, onCleared: (ItemDtos.PurchasedItem?, Int?) -> Unit)
|
fun clearSpecialMission(missionId: Long, onCleared: (ItemDtos.PurchasedItem?, Int?) -> Unit)
|
||||||
}
|
}
|
||||||
@ -33,13 +33,18 @@ class HomeScreenControllerImpl(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun clearSpecialMission(missionId: Long, missionCompletion: SpecialMission.Status, onCleared: (ItemDtos.PurchasedItem?, Int?) -> Unit) {
|
override fun clearSpecialMission(missionId: Long, onCleared: (ItemDtos.PurchasedItem?, Int?) -> Unit) {
|
||||||
componentActivity.lifecycleScope.launch {
|
componentActivity.lifecycleScope.launch {
|
||||||
|
val missionStatus = database
|
||||||
|
.specialMissionDao()
|
||||||
|
.getSpecialMission(missionId)
|
||||||
|
.first()
|
||||||
|
|
||||||
database
|
database
|
||||||
.specialMissionDao()
|
.specialMissionDao()
|
||||||
.clearSpecialMission(missionId)
|
.clearSpecialMission(missionId)
|
||||||
|
|
||||||
if (missionCompletion == SpecialMission.Status.COMPLETED) {
|
if (missionStatus.status == SpecialMission.Status.COMPLETED) {
|
||||||
val randomItem = database
|
val randomItem = database
|
||||||
.itemDao()
|
.itemDao()
|
||||||
.getAllItems()
|
.getAllItems()
|
||||||
@ -73,7 +78,6 @@ class HomeScreenControllerImpl(
|
|||||||
} else {
|
} else {
|
||||||
onCleared(null, null)
|
onCleared(null, null)
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -0,0 +1,56 @@
|
|||||||
|
package com.github.nacabaro.vbhelper.screens.homeScreens.dialogs
|
||||||
|
|
||||||
|
import androidx.compose.foundation.layout.Column
|
||||||
|
import androidx.compose.foundation.layout.Row
|
||||||
|
import androidx.compose.foundation.layout.Spacer
|
||||||
|
import androidx.compose.foundation.layout.padding
|
||||||
|
import androidx.compose.material3.Button
|
||||||
|
import androidx.compose.material3.Card
|
||||||
|
import androidx.compose.material3.Text
|
||||||
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.ui.Modifier
|
||||||
|
import androidx.compose.ui.res.stringResource
|
||||||
|
import androidx.compose.ui.text.style.TextAlign
|
||||||
|
import androidx.compose.ui.unit.dp
|
||||||
|
import androidx.compose.ui.window.Dialog
|
||||||
|
import com.github.nacabaro.vbhelper.R
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
fun DeleteSpecialMissionDialog(
|
||||||
|
onClickDismiss: () -> Unit,
|
||||||
|
onClickDelete: () -> Unit
|
||||||
|
) {
|
||||||
|
Dialog(
|
||||||
|
onDismissRequest = onClickDismiss
|
||||||
|
) {
|
||||||
|
Card {
|
||||||
|
Column(
|
||||||
|
modifier = Modifier
|
||||||
|
.padding(16.dp)
|
||||||
|
) {
|
||||||
|
Text(
|
||||||
|
text = stringResource(R.string.home_special_mission_delete_main),
|
||||||
|
textAlign = TextAlign.Center
|
||||||
|
)
|
||||||
|
Spacer(modifier = Modifier.padding(8.dp))
|
||||||
|
Row {
|
||||||
|
Button(
|
||||||
|
onClick = onClickDismiss,
|
||||||
|
modifier = Modifier
|
||||||
|
.padding(8.dp)
|
||||||
|
) {
|
||||||
|
Text(text = stringResource(R.string.home_special_mission_delete_dismiss))
|
||||||
|
}
|
||||||
|
|
||||||
|
Button(
|
||||||
|
onClick = onClickDelete,
|
||||||
|
modifier = Modifier
|
||||||
|
.padding(8.dp)
|
||||||
|
) {
|
||||||
|
Text(text = stringResource(R.string.home_special_mission_delete_remove))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -10,6 +10,10 @@ import androidx.compose.foundation.rememberScrollState
|
|||||||
import androidx.compose.foundation.verticalScroll
|
import androidx.compose.foundation.verticalScroll
|
||||||
import androidx.compose.material3.Text
|
import androidx.compose.material3.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.getValue
|
||||||
|
import androidx.compose.runtime.mutableStateOf
|
||||||
|
import androidx.compose.runtime.remember
|
||||||
|
import androidx.compose.runtime.setValue
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
import androidx.compose.ui.unit.sp
|
import androidx.compose.ui.unit.sp
|
||||||
@ -26,6 +30,7 @@ import com.github.nacabaro.vbhelper.screens.homeScreens.HomeScreenControllerImpl
|
|||||||
import com.github.nacabaro.vbhelper.utils.BitmapData
|
import com.github.nacabaro.vbhelper.utils.BitmapData
|
||||||
import java.util.Locale
|
import java.util.Locale
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
|
import com.github.nacabaro.vbhelper.screens.homeScreens.dialogs.DeleteSpecialMissionDialog
|
||||||
|
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
@ -39,6 +44,8 @@ fun VBDiMHomeScreen(
|
|||||||
contentPadding: PaddingValues,
|
contentPadding: PaddingValues,
|
||||||
onClickCollect: (ItemDtos.PurchasedItem?, Int?) -> Unit
|
onClickCollect: (ItemDtos.PurchasedItem?, Int?) -> Unit
|
||||||
) {
|
) {
|
||||||
|
var selectedSpecialMissionId by remember { mutableStateOf<Long>(-1) }
|
||||||
|
|
||||||
Column(
|
Column(
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.padding(top = contentPadding.calculateTopPadding())
|
.padding(top = contentPadding.calculateTopPadding())
|
||||||
@ -183,11 +190,28 @@ fun VBDiMHomeScreen(
|
|||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.weight(1f)
|
.weight(1f)
|
||||||
.padding(8.dp),
|
.padding(8.dp),
|
||||||
) {
|
onClickMission = { missionId ->
|
||||||
homeScreenController
|
selectedSpecialMissionId = missionId
|
||||||
.clearSpecialMission(mission.id, mission.status, onClickCollect)
|
},
|
||||||
}
|
onClickCollect = {
|
||||||
|
homeScreenController
|
||||||
|
.clearSpecialMission(selectedSpecialMissionId, onClickCollect)
|
||||||
|
}
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (selectedSpecialMissionId.toInt() != -1) {
|
||||||
|
DeleteSpecialMissionDialog(
|
||||||
|
onClickDismiss = {
|
||||||
|
selectedSpecialMissionId = -1
|
||||||
|
},
|
||||||
|
onClickDelete = {
|
||||||
|
homeScreenController
|
||||||
|
.clearSpecialMission(selectedSpecialMissionId, onClickCollect)
|
||||||
|
selectedSpecialMissionId = -1
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@ -162,33 +162,35 @@ class ItemsScreenControllerImpl (
|
|||||||
ItemTypes.Win4.id -> 4
|
ItemTypes.Win4.id -> 4
|
||||||
else -> 0
|
else -> 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val specialMissionSlot = when (itemIcon) {
|
||||||
|
ItemTypes.Step8k.id -> 0
|
||||||
|
ItemTypes.Step4k.id -> 0
|
||||||
|
ItemTypes.Vitals1000.id -> 1
|
||||||
|
ItemTypes.Vitals250.id -> 1
|
||||||
|
ItemTypes.Battle20.id -> 2
|
||||||
|
ItemTypes.Battle5.id -> 2
|
||||||
|
ItemTypes.Win10.id -> 3
|
||||||
|
ItemTypes.Win4.id -> 3
|
||||||
|
else -> 0
|
||||||
|
}
|
||||||
|
|
||||||
val availableSpecialMissions = database
|
val availableSpecialMissions = database
|
||||||
.userCharacterDao()
|
.userCharacterDao()
|
||||||
.getSpecialMissions(characterId)
|
.getSpecialMissions(characterId)
|
||||||
|
.first()
|
||||||
|
|
||||||
var firstUnavailableMissionSlot: Long = 0
|
var newSpecialMission = availableSpecialMissions[specialMissionSlot]
|
||||||
var watchId = 0
|
newSpecialMission = SpecialMissions(
|
||||||
|
id = newSpecialMission.id,
|
||||||
for ((index, mission) in availableSpecialMissions.first().withIndex()) {
|
characterId = newSpecialMission.characterId,
|
||||||
if (
|
|
||||||
mission.status == SpecialMission.Status.UNAVAILABLE
|
|
||||||
) {
|
|
||||||
firstUnavailableMissionSlot = mission.id
|
|
||||||
watchId = index + 1
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
val newSpecialMission = SpecialMissions(
|
|
||||||
id = firstUnavailableMissionSlot,
|
|
||||||
characterId = characterId,
|
|
||||||
missionType = specialMissionType,
|
|
||||||
goal = specialMissionGoal,
|
goal = specialMissionGoal,
|
||||||
timeLimitInMinutes = itemLength,
|
watchId = newSpecialMission.watchId,
|
||||||
watchId = watchId,
|
|
||||||
status = SpecialMission.Status.AVAILABLE,
|
|
||||||
progress = 0,
|
progress = 0,
|
||||||
timeElapsedInMinutes = 0
|
status = SpecialMission.Status.AVAILABLE,
|
||||||
|
timeElapsedInMinutes = 0,
|
||||||
|
timeLimitInMinutes = itemLength,
|
||||||
|
missionType = specialMissionType
|
||||||
)
|
)
|
||||||
|
|
||||||
database
|
database
|
||||||
|
|||||||
@ -222,5 +222,8 @@
|
|||||||
<string name="special_mission_wins_progress">Won %1$d battles</string>
|
<string name="special_mission_wins_progress">Won %1$d battles</string>
|
||||||
<string name="special_mission_vitals_progress">Earned %1$d vitals</string>
|
<string name="special_mission_vitals_progress">Earned %1$d vitals</string>
|
||||||
<string name="special_mission_icon_content_description">Special mission icon</string>
|
<string name="special_mission_icon_content_description">Special mission icon</string>
|
||||||
|
<string name="home_special_mission_delete_main">Are you sure you want to delete this special mission with this progress?</string>
|
||||||
|
<string name="home_special_mission_delete_dismiss">Dismiss</string>
|
||||||
|
<string name="home_special_mission_delete_remove">Remove</string>
|
||||||
|
|
||||||
</resources>
|
</resources>
|
||||||
Loading…
x
Reference in New Issue
Block a user