Move composables to separate file

pull/1400/head
Alex Baker 5 years ago
parent e259762ab6
commit 84ff3a542c

@ -2,32 +2,13 @@ package org.tasks.caldav
import android.os.Bundle import android.os.Bundle
import androidx.activity.viewModels import androidx.activity.viewModels
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
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.Icon
import androidx.compose.material.IconButton
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.platform.ComposeView import androidx.compose.ui.platform.ComposeView
import androidx.compose.ui.res.colorResource
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.core.view.isVisible import androidx.core.view.isVisible
import androidx.lifecycle.lifecycleScope import androidx.lifecycle.lifecycleScope
import dagger.hilt.android.AndroidEntryPoint import dagger.hilt.android.AndroidEntryPoint
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
import org.tasks.R import org.tasks.R
import org.tasks.compose.ListSettingsComposables.PrincipalList
import org.tasks.data.CaldavAccount import org.tasks.data.CaldavAccount
import org.tasks.data.CaldavAccount.Companion.SERVER_OWNCLOUD import org.tasks.data.CaldavAccount.Companion.SERVER_OWNCLOUD
import org.tasks.data.CaldavAccount.Companion.SERVER_SABREDAV import org.tasks.data.CaldavAccount.Companion.SERVER_SABREDAV
@ -74,7 +55,11 @@ class CaldavCalendarSettingsActivity : BaseCaldavCalendarSettingsActivity() {
principalDao.getPrincipals(it.id).observe(this) { principalDao.getPrincipals(it.id).observe(this) {
findViewById<ComposeView>(R.id.people) findViewById<ComposeView>(R.id.people)
.apply { isVisible = it.isNotEmpty() } .apply { isVisible = it.isNotEmpty() }
.setContent { PrincipalList(it) } .setContent {
tasksTheme.TasksTheme {
PrincipalList(it, if (canRemovePrincipals) this::onRemove else null)
}
}
} }
} }
} }
@ -102,59 +87,6 @@ class CaldavCalendarSettingsActivity : BaseCaldavCalendarSettingsActivity() {
} }
} }
@Composable
private fun PrincipalList(principals: List<Principal>) {
tasksTheme.TasksTheme {
Column(
modifier = Modifier
.padding(16.dp)
.fillMaxWidth()
) {
Text(
stringResource(R.string.list_members),
style = MaterialTheme.typography.h6,
color = MaterialTheme.colors.onBackground
)
Spacer(Modifier.height(8.dp))
principals.forEach {
PrincipalRow(it)
}
}
}
}
@Composable
fun PrincipalRow(principal: Principal) {
Row(modifier = Modifier
.padding(PaddingValues(0.dp, 16.dp))
.fillMaxWidth()) {
Icon(
painter = painterResource(R.drawable.ic_outline_perm_identity_24px),
contentDescription = null,
modifier = Modifier.padding(end = 16.dp),
tint = colorResource(R.color.icon_tint_with_alpha)
)
Text(
principal.name!!,
style = MaterialTheme.typography.body1,
color = MaterialTheme.colors.onBackground,
)
if (canRemovePrincipals) {
Row(horizontalArrangement = Arrangement.End, modifier = Modifier.fillMaxWidth()) {
IconButton(
modifier = Modifier.then(Modifier.size(24.dp)),
onClick = { onRemove(principal) }) {
Icon(
painter = painterResource(R.drawable.ic_outline_clear_24px),
contentDescription = null,
tint = colorResource(R.color.icon_tint_with_alpha),
)
}
}
}
}
}
override suspend fun createCalendar(caldavAccount: CaldavAccount, name: String, color: Int) = override suspend fun createCalendar(caldavAccount: CaldavAccount, name: String, color: Int) =
createCalendarViewModel.createCalendar(caldavAccount, name, color) createCalendarViewModel.createCalendar(caldavAccount, name, color)
@ -165,15 +97,6 @@ class CaldavCalendarSettingsActivity : BaseCaldavCalendarSettingsActivity() {
override suspend fun deleteCalendar(caldavAccount: CaldavAccount, caldavCalendar: CaldavCalendar) = override suspend fun deleteCalendar(caldavAccount: CaldavAccount, caldavCalendar: CaldavCalendar) =
deleteCalendarViewModel.deleteCalendar(caldavAccount, caldavCalendar) deleteCalendarViewModel.deleteCalendar(caldavAccount, caldavCalendar)
@Preview
@Composable
private fun PreviewList() {
PrincipalList(listOf(
Principal().apply { displayName = "user1" },
Principal().apply { displayName = "user2" },
))
}
companion object { companion object {
val CaldavAccount.canRemovePrincipal: Boolean val CaldavAccount.canRemovePrincipal: Boolean
get() = when (serverType) { get() = when (serverType) {

@ -0,0 +1,9 @@
package org.tasks.compose
import androidx.compose.ui.unit.dp
object Constants {
const val ICON_ALPHA = 0.54f
val KEYLINE_FIRST = 16.dp
val HALF_KEYLINE = 8.dp
}

@ -0,0 +1,115 @@
package org.tasks.compose
import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
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.Icon
import androidx.compose.material.IconButton
import androidx.compose.material.MaterialTheme
import androidx.compose.material.MaterialTheme.colors
import androidx.compose.material.Text
import androidx.compose.material.darkColors
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import org.tasks.R
import org.tasks.compose.Constants.HALF_KEYLINE
import org.tasks.compose.Constants.ICON_ALPHA
import org.tasks.compose.Constants.KEYLINE_FIRST
import org.tasks.data.Principal
import org.tasks.data.Principal.Companion.name
private val principals = listOf(
Principal().apply { displayName = "user1" },
Principal().apply { displayName = "user2" },
)
@Preview(showBackground = true, backgroundColor = 0xFFFFFF)
@Composable
private fun Owner() = MaterialTheme {
ListSettingsComposables.PrincipalList(principals) {}
}
@Preview(showBackground = true, backgroundColor = 0x202124)
@Composable
private fun OwnerDark() = MaterialTheme(darkColors()) {
ListSettingsComposables.PrincipalList(principals) {}
}
@Preview(showBackground = true, backgroundColor = 0xFFFFFF)
@Composable
private fun NotOwner() = MaterialTheme {
ListSettingsComposables.PrincipalList(principals, null)
}
object ListSettingsComposables {
@Composable
fun PrincipalList(
principals: List<Principal>,
onRemove: ((Principal) -> Unit)?,
) {
Column(
modifier = Modifier
.padding(16.dp)
.fillMaxWidth()
) {
Text(
stringResource(R.string.list_members),
style = MaterialTheme.typography.h6,
color = colors.onBackground
)
Spacer(Modifier.height(HALF_KEYLINE))
principals.forEach {
PrincipalRow(it, onRemove)
}
}
}
@Composable
fun PrincipalRow(
principal: Principal,
onRemove: ((Principal) -> Unit)?,
) {
Row(modifier = Modifier
.padding(PaddingValues(0.dp, KEYLINE_FIRST))
.fillMaxWidth()) {
Icon(
painter = painterResource(R.drawable.ic_outline_perm_identity_24px),
contentDescription = null,
tint = colors.onBackground,
modifier = Modifier
.padding(end = KEYLINE_FIRST)
.alpha(ICON_ALPHA),
)
Text(
principal.name!!,
style = MaterialTheme.typography.body1,
color = colors.onBackground,
)
onRemove?.let {
Row(horizontalArrangement = Arrangement.End, modifier = Modifier.fillMaxWidth()) {
IconButton(
modifier = Modifier.then(Modifier.size(24.dp)),
onClick = { it(principal) }) {
Icon(
painter = painterResource(R.drawable.ic_outline_clear_24px),
contentDescription = null,
tint = colors.onBackground,
modifier = Modifier.alpha(ICON_ALPHA)
)
}
}
}
}
}
}

@ -9,6 +9,7 @@ import androidx.compose.material.darkColors
import androidx.compose.material.lightColors import androidx.compose.material.lightColors
import androidx.compose.runtime.Composable import androidx.compose.runtime.Composable
import androidx.compose.ui.graphics.Color import androidx.compose.ui.graphics.Color
import androidx.core.content.ContextCompat
import dagger.hilt.android.qualifiers.ActivityContext import dagger.hilt.android.qualifiers.ActivityContext
import org.tasks.R import org.tasks.R
import javax.inject.Inject import javax.inject.Inject
@ -34,6 +35,8 @@ class Theme @Inject constructor(
primary = primary, primary = primary,
onPrimary = onPrimary, onPrimary = onPrimary,
secondary = secondary, secondary = secondary,
background = Color(ContextCompat.getColor(context, R.color.window_background)),
surface = Color(ContextCompat.getColor(context, R.color.content_background)),
) )
} else { } else {
lightColors( lightColors(

Loading…
Cancel
Save