mirror of
https://github.com/oxen-io/session-android.git
synced 2024-11-27 12:05:22 +00:00
Fix button styles
This commit is contained in:
parent
4e4ffc02ec
commit
962d4e9a28
@ -7,7 +7,6 @@ import androidx.compose.foundation.layout.fillMaxWidth
|
|||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.rememberScrollState
|
import androidx.compose.foundation.rememberScrollState
|
||||||
import androidx.compose.foundation.verticalScroll
|
import androidx.compose.foundation.verticalScroll
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
@ -23,7 +22,7 @@ import org.thoughtcrime.securesms.ui.LocalPalette
|
|||||||
import org.thoughtcrime.securesms.ui.NoOpCallbacks
|
import org.thoughtcrime.securesms.ui.NoOpCallbacks
|
||||||
import org.thoughtcrime.securesms.ui.OptionsCard
|
import org.thoughtcrime.securesms.ui.OptionsCard
|
||||||
import org.thoughtcrime.securesms.ui.RadioOption
|
import org.thoughtcrime.securesms.ui.RadioOption
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.extraSmall
|
import org.thoughtcrime.securesms.ui.extraSmall
|
||||||
import org.thoughtcrime.securesms.ui.fadingEdges
|
import org.thoughtcrime.securesms.ui.fadingEdges
|
||||||
@ -62,7 +61,7 @@ fun DisappearingMessages(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (state.showSetButton) SessionOutlinedButton(
|
if (state.showSetButton) SlimOutlineButton(
|
||||||
stringResource(R.string.disappearing_messages_set_button_title),
|
stringResource(R.string.disappearing_messages_set_button_title),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.contentDescription(R.string.AccessibilityId_set_button)
|
.contentDescription(R.string.AccessibilityId_set_button)
|
||||||
|
@ -14,6 +14,7 @@ import androidx.compose.foundation.layout.fillMaxWidth
|
|||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.pager.HorizontalPager
|
import androidx.compose.foundation.pager.HorizontalPager
|
||||||
import androidx.compose.foundation.pager.rememberPagerState
|
import androidx.compose.foundation.pager.rememberPagerState
|
||||||
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.collectAsState
|
import androidx.compose.runtime.collectAsState
|
||||||
import androidx.compose.runtime.getValue
|
import androidx.compose.runtime.getValue
|
||||||
@ -42,19 +43,17 @@ import org.thoughtcrime.securesms.conversation.v2.ConversationActivityV2
|
|||||||
import org.thoughtcrime.securesms.dependencies.DatabaseComponent
|
import org.thoughtcrime.securesms.dependencies.DatabaseComponent
|
||||||
import org.thoughtcrime.securesms.showOpenUrlDialog
|
import org.thoughtcrime.securesms.showOpenUrlDialog
|
||||||
import org.thoughtcrime.securesms.ui.LoadingArcOr
|
import org.thoughtcrime.securesms.ui.LoadingArcOr
|
||||||
import org.thoughtcrime.securesms.ui.LocalPalette
|
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.LocalPalette
|
||||||
import org.thoughtcrime.securesms.ui.Palette
|
import org.thoughtcrime.securesms.ui.Palette
|
||||||
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
||||||
import org.thoughtcrime.securesms.ui.components.AppBar
|
import org.thoughtcrime.securesms.ui.components.AppBar
|
||||||
import org.thoughtcrime.securesms.ui.components.BorderlessButtonWithIcon
|
import org.thoughtcrime.securesms.ui.components.BorderlessButtonWithIcon
|
||||||
import org.thoughtcrime.securesms.ui.components.MaybeScanQrCode
|
import org.thoughtcrime.securesms.ui.components.MaybeScanQrCode
|
||||||
import org.thoughtcrime.securesms.ui.components.MediumButtonSize
|
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionButtonText
|
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionTabRow
|
import org.thoughtcrime.securesms.ui.components.SessionTabRow
|
||||||
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.onCreateView
|
import org.thoughtcrime.securesms.ui.onCreateView
|
||||||
|
|
||||||
@ -171,18 +170,17 @@ fun EnterAccountId(
|
|||||||
) { onHelp() }
|
) { onHelp() }
|
||||||
}
|
}
|
||||||
|
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.align(Alignment.CenterHorizontally)
|
.align(Alignment.CenterHorizontally)
|
||||||
.padding(horizontal = LocalDimensions.current.marginLarge)
|
.padding(horizontal = LocalDimensions.current.marginLarge)
|
||||||
.fillMaxWidth()
|
.fillMaxWidth()
|
||||||
.contentDescription(R.string.next),
|
.contentDescription(R.string.next),
|
||||||
size = MediumButtonSize,
|
|
||||||
enabled = state.isNextButtonEnabled,
|
enabled = state.isNextButtonEnabled,
|
||||||
onClick = { callbacks.onContinue() }
|
onClick = { callbacks.onContinue() }
|
||||||
) {
|
) {
|
||||||
LoadingArcOr(state.loading) {
|
LoadingArcOr(state.loading) {
|
||||||
SessionButtonText(stringResource(R.string.next), enabled = state.isNextButtonEnabled)
|
Text(stringResource(R.string.next))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -33,10 +33,8 @@ import org.thoughtcrime.securesms.ui.LocalPalette
|
|||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.components.AppBar
|
import org.thoughtcrime.securesms.ui.components.AppBar
|
||||||
import org.thoughtcrime.securesms.ui.components.MediumButtonSize
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedCopyButton
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineCopyButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
|
||||||
import org.thoughtcrime.securesms.ui.components.SmallButtonSize
|
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.onCreateView
|
import org.thoughtcrime.securesms.ui.onCreateView
|
||||||
import org.thoughtcrime.securesms.ui.small
|
import org.thoughtcrime.securesms.ui.small
|
||||||
@ -110,19 +108,16 @@ private fun InviteFriend(
|
|||||||
modifier = Modifier.padding(horizontal = 8.dp)
|
modifier = Modifier.padding(horizontal = 8.dp)
|
||||||
)
|
)
|
||||||
Row(horizontalArrangement = spacedBy(20.dp)) {
|
Row(horizontalArrangement = spacedBy(20.dp)) {
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
stringResource(R.string.share),
|
stringResource(R.string.share),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.weight(1f)
|
.weight(1f)
|
||||||
.contentDescription("Share button"),
|
.contentDescription("Share button"),
|
||||||
size = MediumButtonSize,
|
|
||||||
color = LocalPalette.current.text,
|
|
||||||
onClick = sendInvitation
|
onClick = sendInvitation
|
||||||
)
|
)
|
||||||
|
|
||||||
SessionOutlinedCopyButton(
|
SlimOutlineCopyButton(
|
||||||
modifier = Modifier.weight(1f),
|
modifier = Modifier.weight(1f),
|
||||||
size = MediumButtonSize,
|
|
||||||
color = LocalPalette.current.text,
|
color = LocalPalette.current.text,
|
||||||
onClick = copyPublicKey
|
onClick = copyPublicKey
|
||||||
)
|
)
|
||||||
|
@ -73,7 +73,6 @@ import org.thoughtcrime.securesms.ui.TitledText
|
|||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.baseMonospace
|
import org.thoughtcrime.securesms.ui.baseMonospace
|
||||||
import org.thoughtcrime.securesms.ui.blackAlpha40
|
import org.thoughtcrime.securesms.ui.blackAlpha40
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionButtonText
|
|
||||||
import org.thoughtcrime.securesms.ui.destructiveButtonColors
|
import org.thoughtcrime.securesms.ui.destructiveButtonColors
|
||||||
import org.thoughtcrime.securesms.ui.setComposeContent
|
import org.thoughtcrime.securesms.ui.setComposeContent
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
@ -393,7 +392,7 @@ fun TitledText(
|
|||||||
@Composable
|
@Composable
|
||||||
fun TitledView(title: GetString, modifier: Modifier = Modifier, content: @Composable () -> Unit) {
|
fun TitledView(title: GetString, modifier: Modifier = Modifier, content: @Composable () -> Unit) {
|
||||||
Column(modifier = modifier, verticalArrangement = Arrangement.spacedBy(4.dp)) {
|
Column(modifier = modifier, verticalArrangement = Arrangement.spacedBy(4.dp)) {
|
||||||
SessionButtonText(text = title.string())
|
Text(title.string())
|
||||||
content()
|
content()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,13 +16,10 @@ import androidx.compose.foundation.layout.Row
|
|||||||
import androidx.compose.foundation.layout.Spacer
|
import androidx.compose.foundation.layout.Spacer
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.fillMaxWidth
|
||||||
import androidx.compose.foundation.layout.height
|
import androidx.compose.foundation.layout.height
|
||||||
import androidx.compose.foundation.layout.heightIn
|
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.requiredWidth
|
import androidx.compose.foundation.layout.requiredWidth
|
||||||
import androidx.compose.foundation.layout.width
|
import androidx.compose.foundation.layout.width
|
||||||
import androidx.compose.foundation.layout.wrapContentHeight
|
|
||||||
import androidx.compose.material.Icon
|
import androidx.compose.material.Icon
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
@ -96,14 +93,14 @@ import org.thoughtcrime.securesms.preferences.SettingsActivity
|
|||||||
import org.thoughtcrime.securesms.showMuteDialog
|
import org.thoughtcrime.securesms.showMuteDialog
|
||||||
import org.thoughtcrime.securesms.showSessionDialog
|
import org.thoughtcrime.securesms.showSessionDialog
|
||||||
import org.thoughtcrime.securesms.ui.Divider
|
import org.thoughtcrime.securesms.ui.Divider
|
||||||
import org.thoughtcrime.securesms.ui.LocalPalette
|
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.LocalPalette
|
||||||
import org.thoughtcrime.securesms.ui.Palette
|
import org.thoughtcrime.securesms.ui.Palette
|
||||||
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
||||||
import org.thoughtcrime.securesms.ui.SessionShieldIcon
|
import org.thoughtcrime.securesms.ui.SessionShieldIcon
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.h4
|
import org.thoughtcrime.securesms.ui.h4
|
||||||
import org.thoughtcrime.securesms.ui.h8
|
import org.thoughtcrime.securesms.ui.h8
|
||||||
@ -407,7 +404,7 @@ class HomeActivity : PassphraseRequiredActionBarActivity(),
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
Spacer(Modifier.width(LocalDimensions.current.marginExtraExtraSmall))
|
Spacer(Modifier.width(LocalDimensions.current.marginExtraExtraSmall))
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
text = stringResource(R.string.continue_2),
|
text = stringResource(R.string.continue_2),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.align(Alignment.CenterVertically)
|
.align(Alignment.CenterVertically)
|
||||||
|
@ -21,7 +21,6 @@ import androidx.compose.foundation.lazy.items
|
|||||||
import androidx.compose.foundation.lazy.rememberLazyListState
|
import androidx.compose.foundation.lazy.rememberLazyListState
|
||||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||||
import androidx.compose.material.Card
|
import androidx.compose.material.Card
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.LaunchedEffect
|
import androidx.compose.runtime.LaunchedEffect
|
||||||
@ -46,14 +45,14 @@ import org.thoughtcrime.securesms.crypto.IdentityKeyUtil
|
|||||||
import org.thoughtcrime.securesms.onboarding.pickname.startPickDisplayNameActivity
|
import org.thoughtcrime.securesms.onboarding.pickname.startPickDisplayNameActivity
|
||||||
import org.thoughtcrime.securesms.service.KeyCachingService
|
import org.thoughtcrime.securesms.service.KeyCachingService
|
||||||
import org.thoughtcrime.securesms.showOpenUrlDialog
|
import org.thoughtcrime.securesms.showOpenUrlDialog
|
||||||
import org.thoughtcrime.securesms.ui.LocalPalette
|
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.LocalPalette
|
||||||
import org.thoughtcrime.securesms.ui.Palette
|
import org.thoughtcrime.securesms.ui.Palette
|
||||||
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
||||||
import org.thoughtcrime.securesms.ui.components.BorderlessHtmlButton
|
import org.thoughtcrime.securesms.ui.components.BorderlessHtmlButton
|
||||||
import org.thoughtcrime.securesms.ui.components.FilledButton
|
import org.thoughtcrime.securesms.ui.components.PrimaryFillButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.PrimaryOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.h4
|
import org.thoughtcrime.securesms.ui.h4
|
||||||
import org.thoughtcrime.securesms.ui.large
|
import org.thoughtcrime.securesms.ui.large
|
||||||
@ -153,7 +152,7 @@ class LandingActivity : BaseActionBarActivity() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Column(modifier = Modifier.padding(horizontal = LocalDimensions.current.marginLarge)) {
|
Column(modifier = Modifier.padding(horizontal = LocalDimensions.current.marginLarge)) {
|
||||||
FilledButton(
|
PrimaryFillButton(
|
||||||
text = stringResource(R.string.onboardingAccountCreate),
|
text = stringResource(R.string.onboardingAccountCreate),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.fillMaxWidth()
|
.fillMaxWidth()
|
||||||
@ -161,13 +160,13 @@ class LandingActivity : BaseActionBarActivity() {
|
|||||||
.contentDescription(R.string.AccessibilityId_create_account_button),
|
.contentDescription(R.string.AccessibilityId_create_account_button),
|
||||||
onClick = ::startPickDisplayNameActivity
|
onClick = ::startPickDisplayNameActivity
|
||||||
)
|
)
|
||||||
Spacer(modifier = Modifier.height(LocalDimensions.current.itemSpacingSmall))
|
Spacer(modifier = Modifier.height(LocalDimensions.current.itemSpacingExtraSmall))
|
||||||
SessionOutlinedButton(
|
PrimaryOutlineButton(
|
||||||
text = stringResource(R.string.onboardingAccountExists),
|
stringResource(R.string.onboardingAccountExists),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.fillMaxWidth()
|
.fillMaxWidth()
|
||||||
.align(Alignment.CenterHorizontally)
|
.align(Alignment.CenterHorizontally)
|
||||||
.contentDescription(R.string.AccessibilityId_restore_account_button)
|
.contentDescription(R.string.AccessibilityId_restore_account_button),
|
||||||
) { start<LinkDeviceActivity>() }
|
) { start<LinkDeviceActivity>() }
|
||||||
BorderlessHtmlButton(
|
BorderlessHtmlButton(
|
||||||
textId = R.string.onboardingTosPrivacy,
|
textId = R.string.onboardingTosPrivacy,
|
||||||
|
@ -14,14 +14,12 @@ import androidx.compose.foundation.layout.width
|
|||||||
import androidx.compose.foundation.pager.HorizontalPager
|
import androidx.compose.foundation.pager.HorizontalPager
|
||||||
import androidx.compose.foundation.pager.rememberPagerState
|
import androidx.compose.foundation.pager.rememberPagerState
|
||||||
import androidx.compose.material.Icon
|
import androidx.compose.material.Icon
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.collectAsState
|
import androidx.compose.runtime.collectAsState
|
||||||
import androidx.compose.runtime.getValue
|
import androidx.compose.runtime.getValue
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.platform.ComposeView
|
|
||||||
import androidx.compose.ui.res.painterResource
|
import androidx.compose.ui.res.painterResource
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.tooling.preview.Preview
|
import androidx.compose.ui.tooling.preview.Preview
|
||||||
@ -35,17 +33,14 @@ import org.thoughtcrime.securesms.BaseActionBarActivity
|
|||||||
import org.thoughtcrime.securesms.onboarding.messagenotifications.startMessageNotificationsActivity
|
import org.thoughtcrime.securesms.onboarding.messagenotifications.startMessageNotificationsActivity
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.SessionMaterialTheme
|
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.baseBold
|
|
||||||
import org.thoughtcrime.securesms.ui.components.MaybeScanQrCode
|
import org.thoughtcrime.securesms.ui.components.MaybeScanQrCode
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.OutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionTabRow
|
import org.thoughtcrime.securesms.ui.components.SessionTabRow
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.h4
|
import org.thoughtcrime.securesms.ui.h4
|
||||||
import org.thoughtcrime.securesms.ui.setComposeContent
|
import org.thoughtcrime.securesms.ui.setComposeContent
|
||||||
import org.thoughtcrime.securesms.util.start
|
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
|
|
||||||
private const val TAG = "LinkDeviceActivity"
|
private const val TAG = "LinkDeviceActivity"
|
||||||
@ -152,7 +147,7 @@ fun RecoveryPassword(state: LinkDeviceState, onChange: (String) -> Unit = {}, on
|
|||||||
error = state.error
|
error = state.error
|
||||||
)
|
)
|
||||||
Spacer(Modifier.weight(2f))
|
Spacer(Modifier.weight(2f))
|
||||||
SessionOutlinedButton(
|
OutlineButton(
|
||||||
stringResource(R.string.continue_2),
|
stringResource(R.string.continue_2),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.align(Alignment.CenterHorizontally)
|
.align(Alignment.CenterHorizontally)
|
||||||
|
@ -32,7 +32,7 @@ import org.thoughtcrime.securesms.ui.PreviewTheme
|
|||||||
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.components.NotificationRadioButton
|
import org.thoughtcrime.securesms.ui.components.NotificationRadioButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.OutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.h4
|
import org.thoughtcrime.securesms.ui.h4
|
||||||
import org.thoughtcrime.securesms.ui.setComposeContent
|
import org.thoughtcrime.securesms.ui.setComposeContent
|
||||||
@ -112,7 +112,7 @@ fun MessageNotificationsScreen(
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
Spacer(Modifier.weight(1f))
|
Spacer(Modifier.weight(1f))
|
||||||
SessionOutlinedButton(
|
OutlineButton(
|
||||||
stringResource(R.string.continue_2),
|
stringResource(R.string.continue_2),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.padding(horizontal = LocalDimensions.current.marginLarge)
|
.padding(horizontal = LocalDimensions.current.marginLarge)
|
||||||
|
@ -10,13 +10,11 @@ import androidx.compose.foundation.layout.Spacer
|
|||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.fillMaxWidth
|
||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.width
|
import androidx.compose.foundation.layout.width
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.collectAsState
|
import androidx.compose.runtime.collectAsState
|
||||||
import androidx.compose.ui.Alignment
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
import androidx.compose.ui.platform.ComposeView
|
|
||||||
import androidx.compose.ui.res.stringResource
|
import androidx.compose.ui.res.stringResource
|
||||||
import androidx.compose.ui.tooling.preview.Preview
|
import androidx.compose.ui.tooling.preview.Preview
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
@ -28,9 +26,8 @@ import org.thoughtcrime.securesms.ApplicationContext
|
|||||||
import org.thoughtcrime.securesms.BaseActionBarActivity
|
import org.thoughtcrime.securesms.BaseActionBarActivity
|
||||||
import org.thoughtcrime.securesms.onboarding.messagenotifications.startMessageNotificationsActivity
|
import org.thoughtcrime.securesms.onboarding.messagenotifications.startMessageNotificationsActivity
|
||||||
import org.thoughtcrime.securesms.ui.PreviewTheme
|
import org.thoughtcrime.securesms.ui.PreviewTheme
|
||||||
import org.thoughtcrime.securesms.ui.SessionMaterialTheme
|
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.OutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
import org.thoughtcrime.securesms.ui.components.SessionOutlinedTextField
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.h4
|
import org.thoughtcrime.securesms.ui.h4
|
||||||
@ -106,7 +103,7 @@ class PickDisplayNameActivity : BaseActionBarActivity() {
|
|||||||
|
|
||||||
Spacer(modifier = Modifier.weight(2f))
|
Spacer(modifier = Modifier.weight(2f))
|
||||||
|
|
||||||
SessionOutlinedButton(
|
OutlineButton(
|
||||||
stringResource(R.string.continue_2),
|
stringResource(R.string.continue_2),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.contentDescription(R.string.AccessibilityId_continue)
|
.contentDescription(R.string.AccessibilityId_continue)
|
||||||
|
@ -31,6 +31,7 @@ import androidx.compose.ui.unit.dp
|
|||||||
import network.loki.messenger.R
|
import network.loki.messenger.R
|
||||||
import org.thoughtcrime.securesms.BaseActionBarActivity
|
import org.thoughtcrime.securesms.BaseActionBarActivity
|
||||||
import org.thoughtcrime.securesms.showSessionDialog
|
import org.thoughtcrime.securesms.showSessionDialog
|
||||||
|
import org.thoughtcrime.securesms.ui.Cell
|
||||||
import org.thoughtcrime.securesms.ui.CellWithPaddingAndMargin
|
import org.thoughtcrime.securesms.ui.CellWithPaddingAndMargin
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.LocalPalette
|
import org.thoughtcrime.securesms.ui.LocalPalette
|
||||||
@ -39,10 +40,9 @@ import org.thoughtcrime.securesms.ui.PreviewTheme
|
|||||||
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
import org.thoughtcrime.securesms.ui.SessionColorsParameterProvider
|
||||||
import org.thoughtcrime.securesms.ui.SessionShieldIcon
|
import org.thoughtcrime.securesms.ui.SessionShieldIcon
|
||||||
import org.thoughtcrime.securesms.ui.base
|
import org.thoughtcrime.securesms.ui.base
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedCopyButton
|
|
||||||
import org.thoughtcrime.securesms.ui.components.QrImage
|
import org.thoughtcrime.securesms.ui.components.QrImage
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SmallButtonSize
|
import org.thoughtcrime.securesms.ui.components.SlimOutlineCopyButton
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.extraSmallMonospace
|
import org.thoughtcrime.securesms.ui.extraSmallMonospace
|
||||||
import org.thoughtcrime.securesms.ui.h8
|
import org.thoughtcrime.securesms.ui.h8
|
||||||
@ -160,26 +160,21 @@ fun RecoveryPasswordCell(seed: String, copySeed:() -> Unit = {}) {
|
|||||||
|
|
||||||
AnimatedVisibility(!showQr) {
|
AnimatedVisibility(!showQr) {
|
||||||
Row(horizontalArrangement = Arrangement.spacedBy(LocalDimensions.current.marginMedium)) {
|
Row(horizontalArrangement = Arrangement.spacedBy(LocalDimensions.current.marginMedium)) {
|
||||||
SessionOutlinedCopyButton(
|
SlimOutlineCopyButton(
|
||||||
Modifier.weight(1f),
|
Modifier.weight(1f),
|
||||||
color = LocalPalette.current.text,
|
|
||||||
size = SmallButtonSize,
|
|
||||||
onClick = copySeed
|
onClick = copySeed
|
||||||
)
|
)
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
text = stringResource(R.string.qrView),
|
stringResource(R.string.qrView),
|
||||||
modifier = Modifier.weight(1f),
|
modifier = Modifier.weight(1f),
|
||||||
color = LocalPalette.current.text,
|
|
||||||
size = SmallButtonSize,
|
|
||||||
onClick = { showQr = !showQr }
|
onClick = { showQr = !showQr }
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
AnimatedVisibility(showQr, modifier = Modifier.align(Alignment.CenterHorizontally)) {
|
AnimatedVisibility(showQr, modifier = Modifier.align(Alignment.CenterHorizontally)) {
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
text = stringResource(R.string.recoveryPasswordView),
|
stringResource(R.string.recoveryPasswordView),
|
||||||
color = LocalPalette.current.text,
|
|
||||||
onClick = { showQr = !showQr }
|
onClick = { showQr = !showQr }
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@ -223,7 +218,7 @@ private fun HideRecoveryPasswordCell(onHide: () -> Unit = {}) {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
Spacer(modifier = Modifier.width(LocalDimensions.current.marginExtraExtraSmall))
|
Spacer(modifier = Modifier.width(LocalDimensions.current.marginExtraExtraSmall))
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
text = stringResource(R.string.hide),
|
text = stringResource(R.string.hide),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.wrapContentWidth()
|
.wrapContentWidth()
|
||||||
|
@ -78,8 +78,8 @@ import org.thoughtcrime.securesms.ui.Divider
|
|||||||
import org.thoughtcrime.securesms.ui.ItemButton
|
import org.thoughtcrime.securesms.ui.ItemButton
|
||||||
import org.thoughtcrime.securesms.ui.ItemButtonWithDrawable
|
import org.thoughtcrime.securesms.ui.ItemButtonWithDrawable
|
||||||
import org.thoughtcrime.securesms.ui.LocalDimensions
|
import org.thoughtcrime.securesms.ui.LocalDimensions
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedCopyButton
|
import org.thoughtcrime.securesms.ui.components.OutlineButton
|
||||||
import org.thoughtcrime.securesms.ui.components.SessionOutlinedButton
|
import org.thoughtcrime.securesms.ui.components.OutlineCopyButton
|
||||||
import org.thoughtcrime.securesms.ui.destructiveButtonColors
|
import org.thoughtcrime.securesms.ui.destructiveButtonColors
|
||||||
import org.thoughtcrime.securesms.ui.setContentWithTheme
|
import org.thoughtcrime.securesms.ui.setContentWithTheme
|
||||||
import org.thoughtcrime.securesms.util.BitmapDecodingException
|
import org.thoughtcrime.securesms.util.BitmapDecodingException
|
||||||
@ -390,13 +390,13 @@ class SettingsActivity : PassphraseRequiredActionBarActivity() {
|
|||||||
.padding(top = LocalDimensions.current.marginTiny),
|
.padding(top = LocalDimensions.current.marginTiny),
|
||||||
horizontalArrangement = Arrangement.spacedBy(LocalDimensions.current.itemSpacingSmall),
|
horizontalArrangement = Arrangement.spacedBy(LocalDimensions.current.itemSpacingSmall),
|
||||||
) {
|
) {
|
||||||
SessionOutlinedButton(
|
OutlineButton(
|
||||||
stringResource(R.string.share),
|
stringResource(R.string.share),
|
||||||
modifier = Modifier.weight(1f),
|
modifier = Modifier.weight(1f),
|
||||||
onClick = { sendInvitationToUseSession() }
|
onClick = { sendInvitationToUseSession() }
|
||||||
)
|
)
|
||||||
|
|
||||||
SessionOutlinedCopyButton(
|
OutlineCopyButton(
|
||||||
modifier = Modifier.weight(1f),
|
modifier = Modifier.weight(1f),
|
||||||
onClick = ::copyPublicKey,
|
onClick = ::copyPublicKey,
|
||||||
)
|
)
|
||||||
|
@ -193,8 +193,12 @@ fun ItemButton(
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun Cell(content: @Composable () -> Unit) {
|
fun Cell(
|
||||||
CellWithPaddingAndMargin(padding = 0.dp) { content() }
|
padding: Dp = 0.dp,
|
||||||
|
margin: Dp = 32.dp,
|
||||||
|
content: @Composable () -> Unit
|
||||||
|
) {
|
||||||
|
CellWithPaddingAndMargin(padding, margin) { content() }
|
||||||
}
|
}
|
||||||
@Composable
|
@Composable
|
||||||
fun CellNoMargin(content: @Composable () -> Unit) {
|
fun CellNoMargin(content: @Composable () -> Unit) {
|
||||||
|
@ -71,20 +71,6 @@ val blackAlpha40 = Color.Black.copy(alpha = 0.4f)
|
|||||||
val LocalPalette = staticCompositionLocalOf<Palette> { ClassicDark() }
|
val LocalPalette = staticCompositionLocalOf<Palette> { ClassicDark() }
|
||||||
|
|
||||||
interface Palette {
|
interface Palette {
|
||||||
@Composable
|
|
||||||
fun outlinedButtonColors(color: Color) = ButtonDefaults.outlinedButtonColors(
|
|
||||||
contentColor = color,
|
|
||||||
backgroundColor = Color.Unspecified,
|
|
||||||
disabledContentColor = disabled
|
|
||||||
)
|
|
||||||
|
|
||||||
@Composable
|
|
||||||
fun filledButtonColors() = ButtonDefaults.outlinedButtonColors(
|
|
||||||
contentColor = background,
|
|
||||||
backgroundColor = primary,
|
|
||||||
disabledContentColor = disabled
|
|
||||||
)
|
|
||||||
|
|
||||||
val isLight: Boolean
|
val isLight: Boolean
|
||||||
val primary: Color
|
val primary: Color
|
||||||
val danger: Color
|
val danger: Color
|
||||||
|
@ -8,7 +8,10 @@ import androidx.compose.foundation.shape.RoundedCornerShape
|
|||||||
import androidx.compose.foundation.text.selection.LocalTextSelectionColors
|
import androidx.compose.foundation.text.selection.LocalTextSelectionColors
|
||||||
import androidx.compose.foundation.text.selection.TextSelectionColors
|
import androidx.compose.foundation.text.selection.TextSelectionColors
|
||||||
import androidx.compose.material.Colors
|
import androidx.compose.material.Colors
|
||||||
|
import androidx.compose.material.ExperimentalMaterialApi
|
||||||
import androidx.compose.material.LocalContentColor
|
import androidx.compose.material.LocalContentColor
|
||||||
|
import androidx.compose.material.LocalMinimumInteractiveComponentEnforcement
|
||||||
|
import androidx.compose.material.LocalTextStyle
|
||||||
import androidx.compose.material.MaterialTheme
|
import androidx.compose.material.MaterialTheme
|
||||||
import androidx.compose.material.Shapes
|
import androidx.compose.material.Shapes
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
@ -33,6 +36,7 @@ fun SessionMaterialTheme(
|
|||||||
/**
|
/**
|
||||||
* Apply a given [Palette], and our typography and shapes as a Material 2 Compose Theme.
|
* Apply a given [Palette], and our typography and shapes as a Material 2 Compose Theme.
|
||||||
**/
|
**/
|
||||||
|
@OptIn(ExperimentalMaterialApi::class)
|
||||||
@Composable
|
@Composable
|
||||||
fun SessionMaterialTheme(
|
fun SessionMaterialTheme(
|
||||||
palette: Palette,
|
palette: Palette,
|
||||||
@ -51,7 +55,7 @@ fun SessionMaterialTheme(
|
|||||||
CompositionLocalProvider(
|
CompositionLocalProvider(
|
||||||
LocalPalette provides palette,
|
LocalPalette provides palette,
|
||||||
LocalContentColor provides palette.text,
|
LocalContentColor provides palette.text,
|
||||||
LocalTextSelectionColors provides textSelectionColors
|
LocalTextSelectionColors provides textSelectionColors,
|
||||||
) {
|
) {
|
||||||
content()
|
content()
|
||||||
}
|
}
|
||||||
@ -92,6 +96,7 @@ fun PreviewTheme(
|
|||||||
SessionMaterialTheme(palette) {
|
SessionMaterialTheme(palette) {
|
||||||
Box(modifier = Modifier.background(color = LocalPalette.current.background)) {
|
Box(modifier = Modifier.background(color = LocalPalette.current.background)) {
|
||||||
content()
|
content()
|
||||||
|
LocalTextStyle
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -11,8 +11,7 @@ import androidx.compose.foundation.layout.Row
|
|||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||||
import androidx.compose.material.ButtonDefaults
|
import androidx.compose.material.ButtonDefaults
|
||||||
import androidx.compose.material.MaterialTheme
|
import androidx.compose.material.LocalTextStyle
|
||||||
import androidx.compose.material.OutlinedButton
|
|
||||||
import androidx.compose.material.RadioButton
|
import androidx.compose.material.RadioButton
|
||||||
import androidx.compose.material.Text
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.material.TextButton
|
import androidx.compose.material.TextButton
|
||||||
@ -28,7 +27,6 @@ import androidx.compose.ui.unit.dp
|
|||||||
import kotlinx.coroutines.flow.filter
|
import kotlinx.coroutines.flow.filter
|
||||||
import org.thoughtcrime.securesms.ui.GetString
|
import org.thoughtcrime.securesms.ui.GetString
|
||||||
import org.thoughtcrime.securesms.ui.LocalPalette
|
import org.thoughtcrime.securesms.ui.LocalPalette
|
||||||
import org.thoughtcrime.securesms.ui.base
|
|
||||||
import org.thoughtcrime.securesms.ui.baseBold
|
import org.thoughtcrime.securesms.ui.baseBold
|
||||||
import org.thoughtcrime.securesms.ui.contentDescription
|
import org.thoughtcrime.securesms.ui.contentDescription
|
||||||
import org.thoughtcrime.securesms.ui.extraSmall
|
import org.thoughtcrime.securesms.ui.extraSmall
|
||||||
@ -37,45 +35,6 @@ import org.thoughtcrime.securesms.ui.h9
|
|||||||
import org.thoughtcrime.securesms.ui.radioButtonColors
|
import org.thoughtcrime.securesms.ui.radioButtonColors
|
||||||
import org.thoughtcrime.securesms.ui.small
|
import org.thoughtcrime.securesms.ui.small
|
||||||
|
|
||||||
val LocalButtonTextStyle = staticCompositionLocalOf { baseBold }
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Text to be used in buttons.
|
|
||||||
*
|
|
||||||
* This text gets its style from [LocalButtonTextStyle] which may vary if button size is changed
|
|
||||||
* by passing in a [ButtonSize] to some Session Button.
|
|
||||||
*/
|
|
||||||
@Composable
|
|
||||||
fun SessionButtonText(
|
|
||||||
text: String,
|
|
||||||
modifier: Modifier = Modifier,
|
|
||||||
style: TextStyle = LocalButtonTextStyle.current,
|
|
||||||
color: Color = LocalPalette.current.buttonOutline,
|
|
||||||
enabled: Boolean = true
|
|
||||||
) {
|
|
||||||
Text(
|
|
||||||
modifier = modifier,
|
|
||||||
text = text,
|
|
||||||
style = style,
|
|
||||||
color = if (enabled) color else LocalPalette.current.disabled
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
@Composable
|
|
||||||
fun FilledButton(
|
|
||||||
text: String,
|
|
||||||
modifier: Modifier = Modifier,
|
|
||||||
onClick: () -> Unit
|
|
||||||
) {
|
|
||||||
OutlinedButton(
|
|
||||||
modifier = modifier,
|
|
||||||
onClick = onClick,
|
|
||||||
colors = LocalPalette.current.filledButtonColors()
|
|
||||||
) {
|
|
||||||
SessionButtonText(text, color = LocalPalette.current.background)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun BorderlessButton(
|
fun BorderlessButton(
|
||||||
modifier: Modifier = Modifier,
|
modifier: Modifier = Modifier,
|
||||||
@ -171,11 +130,12 @@ fun NotificationRadioButton(
|
|||||||
onClick: () -> Unit = {}
|
onClick: () -> Unit = {}
|
||||||
) {
|
) {
|
||||||
Row {
|
Row {
|
||||||
SessionOutlinedButton(
|
Button(
|
||||||
onClick = onClick,
|
onClick = onClick,
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.weight(1f)
|
.weight(1f)
|
||||||
.contentDescription(contentDescription),
|
.contentDescription(contentDescription),
|
||||||
|
type = ButtonType.Outline,
|
||||||
color = LocalPalette.current.text,
|
color = LocalPalette.current.text,
|
||||||
border = BorderStroke(
|
border = BorderStroke(
|
||||||
width = ButtonDefaults.OutlinedBorderSize,
|
width = ButtonDefaults.OutlinedBorderSize,
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
package org.thoughtcrime.securesms.ui.components
|
package org.thoughtcrime.securesms.ui.components
|
||||||
|
|
||||||
import android.annotation.SuppressLint
|
import android.annotation.SuppressLint
|
||||||
|
import androidx.compose.material.ExperimentalMaterialApi
|
||||||
|
import androidx.compose.material.LocalMinimumInteractiveComponentEnforcement
|
||||||
|
import androidx.compose.material.LocalTextStyle
|
||||||
import androidx.compose.material.MaterialTheme
|
import androidx.compose.material.MaterialTheme
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.CompositionLocalProvider
|
import androidx.compose.runtime.CompositionLocalProvider
|
||||||
@ -13,9 +16,13 @@ import org.thoughtcrime.securesms.ui.extraSmallBold
|
|||||||
import org.thoughtcrime.securesms.ui.smallBold
|
import org.thoughtcrime.securesms.ui.smallBold
|
||||||
|
|
||||||
interface ButtonSize {
|
interface ButtonSize {
|
||||||
|
@OptIn(ExperimentalMaterialApi::class)
|
||||||
@SuppressLint("ComposableNaming")
|
@SuppressLint("ComposableNaming")
|
||||||
@Composable fun applyTextStyle(content: @Composable () -> Unit) {
|
@Composable fun applyConstraints(content: @Composable () -> Unit) {
|
||||||
CompositionLocalProvider(LocalButtonTextStyle provides textStyle) {
|
CompositionLocalProvider(
|
||||||
|
LocalMinimumInteractiveComponentEnforcement provides false,
|
||||||
|
LocalTextStyle provides textStyle,
|
||||||
|
) {
|
||||||
content()
|
content()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -34,7 +41,7 @@ object MediumButtonSize: ButtonSize {
|
|||||||
override val minHeight = 34.dp
|
override val minHeight = 34.dp
|
||||||
}
|
}
|
||||||
|
|
||||||
object SmallButtonSize: ButtonSize {
|
object SlimButtonSize: ButtonSize {
|
||||||
override val textStyle @Composable get() = extraSmallBold
|
override val textStyle @Composable get() = extraSmallBold
|
||||||
override val minHeight = 29.dp
|
override val minHeight = 29.dp
|
||||||
}
|
}
|
||||||
|
@ -21,7 +21,6 @@ import androidx.compose.foundation.layout.fillMaxWidth
|
|||||||
import androidx.compose.foundation.layout.padding
|
import androidx.compose.foundation.layout.padding
|
||||||
import androidx.compose.foundation.layout.size
|
import androidx.compose.foundation.layout.size
|
||||||
import androidx.compose.foundation.shape.RoundedCornerShape
|
import androidx.compose.foundation.shape.RoundedCornerShape
|
||||||
import androidx.compose.material.MaterialTheme
|
|
||||||
import androidx.compose.material.Scaffold
|
import androidx.compose.material.Scaffold
|
||||||
import androidx.compose.material.Snackbar
|
import androidx.compose.material.Snackbar
|
||||||
import androidx.compose.material.SnackbarHost
|
import androidx.compose.material.SnackbarHost
|
||||||
@ -97,7 +96,7 @@ fun MaybeScanQrCode(
|
|||||||
textAlign = TextAlign.Center
|
textAlign = TextAlign.Center
|
||||||
)
|
)
|
||||||
Spacer(modifier = Modifier.size(20.dp))
|
Spacer(modifier = Modifier.size(20.dp))
|
||||||
SessionOutlinedButton(
|
OutlineButton(
|
||||||
stringResource(R.string.sessionSettings),
|
stringResource(R.string.sessionSettings),
|
||||||
modifier = Modifier.align(Alignment.CenterHorizontally),
|
modifier = Modifier.align(Alignment.CenterHorizontally),
|
||||||
onClick = onClickSettings
|
onClick = onClickSettings
|
||||||
@ -105,7 +104,7 @@ fun MaybeScanQrCode(
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Box(modifier = Modifier.fillMaxSize().padding(LocalDimensions.current.marginLarge)) {
|
Box(modifier = Modifier.fillMaxSize().padding(LocalDimensions.current.marginLarge)) {
|
||||||
SessionOutlinedButton(
|
SlimOutlineButton(
|
||||||
stringResource(R.string.cameraGrantAccess),
|
stringResource(R.string.cameraGrantAccess),
|
||||||
modifier = Modifier
|
modifier = Modifier
|
||||||
.align(Alignment.Center)
|
.align(Alignment.Center)
|
||||||
|
@ -1,17 +1,18 @@
|
|||||||
package org.thoughtcrime.securesms.ui.components
|
package org.thoughtcrime.securesms.ui.components
|
||||||
|
|
||||||
import androidx.compose.animation.AnimatedVisibility
|
import androidx.compose.animation.AnimatedVisibility
|
||||||
import androidx.compose.animation.Crossfade
|
|
||||||
import androidx.compose.animation.fadeIn
|
import androidx.compose.animation.fadeIn
|
||||||
import androidx.compose.animation.fadeOut
|
import androidx.compose.animation.fadeOut
|
||||||
import androidx.compose.foundation.BorderStroke
|
import androidx.compose.foundation.BorderStroke
|
||||||
import androidx.compose.foundation.interaction.MutableInteractionSource
|
import androidx.compose.foundation.interaction.MutableInteractionSource
|
||||||
import androidx.compose.foundation.layout.Box
|
import androidx.compose.foundation.layout.Box
|
||||||
import androidx.compose.foundation.layout.fillMaxWidth
|
import androidx.compose.foundation.layout.RowScope
|
||||||
import androidx.compose.foundation.layout.heightIn
|
import androidx.compose.foundation.layout.heightIn
|
||||||
import androidx.compose.foundation.layout.wrapContentWidth
|
import androidx.compose.material.ButtonColors
|
||||||
|
import androidx.compose.material.ButtonDefaults
|
||||||
|
import androidx.compose.material.ButtonElevation
|
||||||
import androidx.compose.material.MaterialTheme
|
import androidx.compose.material.MaterialTheme
|
||||||
import androidx.compose.material.OutlinedButton
|
import androidx.compose.material.Text
|
||||||
import androidx.compose.runtime.Composable
|
import androidx.compose.runtime.Composable
|
||||||
import androidx.compose.runtime.getValue
|
import androidx.compose.runtime.getValue
|
||||||
import androidx.compose.runtime.mutableStateOf
|
import androidx.compose.runtime.mutableStateOf
|
||||||
@ -32,56 +33,66 @@ import org.thoughtcrime.securesms.ui.contentDescription
|
|||||||
import kotlin.time.Duration
|
import kotlin.time.Duration
|
||||||
import kotlin.time.Duration.Companion.seconds
|
import kotlin.time.Duration.Companion.seconds
|
||||||
|
|
||||||
|
//@Composable
|
||||||
|
//fun OutlineButton(
|
||||||
|
// text: String,
|
||||||
|
// modifier: Modifier = Modifier,
|
||||||
|
// size: ButtonSize = LargeButtonSize,
|
||||||
|
// color: Color = LocalPalette.current.buttonOutline,
|
||||||
|
// onClick: () -> Unit
|
||||||
|
//) {
|
||||||
|
// OutlineButton(
|
||||||
|
// modifier = modifier,
|
||||||
|
// size = size,
|
||||||
|
// color = color,
|
||||||
|
// onClick = onClick
|
||||||
|
// ) {
|
||||||
|
// SessionButtonText(text = text, style = size.textStyle, color = color)
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
//
|
||||||
|
///**
|
||||||
|
// * Base implementation of [SessionOutlinedButton]
|
||||||
|
// */
|
||||||
|
//@Composable
|
||||||
|
//fun OutlineButton(
|
||||||
|
// modifier: Modifier = Modifier,
|
||||||
|
// size: ButtonSize = LargeButtonSize,
|
||||||
|
// enabled: Boolean = true,
|
||||||
|
// interactionSource: MutableInteractionSource = remember { MutableInteractionSource() },
|
||||||
|
// color: Color = LocalPalette.current.buttonOutline,
|
||||||
|
// border: BorderStroke = BorderStroke(1.dp, if (enabled) color else LocalPalette.current.disabled),
|
||||||
|
// shape: Shape = MaterialTheme.shapes.small,
|
||||||
|
// onClick: () -> Unit,
|
||||||
|
// content: @Composable () -> Unit = {}
|
||||||
|
//) {
|
||||||
|
// Button(
|
||||||
|
// modifier = modifier.heightIn(min = size.minHeight),
|
||||||
|
// enabled = enabled,
|
||||||
|
// interactionSource = interactionSource,
|
||||||
|
// onClick = onClick,
|
||||||
|
// border = border,
|
||||||
|
// shape = shape,
|
||||||
|
// type = ButtonType.Outline,
|
||||||
|
// color = color
|
||||||
|
// ) {
|
||||||
|
// size.applyTextStyle {
|
||||||
|
// content()
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun SessionOutlinedButton(
|
fun SlimOutlineCopyButton(
|
||||||
text: String,
|
|
||||||
modifier: Modifier = Modifier,
|
modifier: Modifier = Modifier,
|
||||||
size: ButtonSize = LargeButtonSize,
|
|
||||||
color: Color = LocalPalette.current.buttonOutline,
|
color: Color = LocalPalette.current.buttonOutline,
|
||||||
onClick: () -> Unit
|
onClick: () -> Unit
|
||||||
) {
|
) {
|
||||||
SessionOutlinedButton(
|
OutlineCopyButton(modifier, SlimButtonSize, color, onClick)
|
||||||
modifier = modifier,
|
|
||||||
size = size,
|
|
||||||
color = color,
|
|
||||||
onClick = onClick
|
|
||||||
) {
|
|
||||||
SessionButtonText(text = text, style = size.textStyle, color = color)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Base implementation of [SessionOutlinedButton]
|
|
||||||
*/
|
|
||||||
@Composable
|
|
||||||
fun SessionOutlinedButton(
|
|
||||||
modifier: Modifier = Modifier,
|
|
||||||
size: ButtonSize = LargeButtonSize,
|
|
||||||
enabled: Boolean = true,
|
|
||||||
interactionSource: MutableInteractionSource = remember { MutableInteractionSource() },
|
|
||||||
color: Color = LocalPalette.current.buttonOutline,
|
|
||||||
border: BorderStroke = BorderStroke(1.dp, if (enabled) color else LocalPalette.current.disabled),
|
|
||||||
shape: Shape = MaterialTheme.shapes.small,
|
|
||||||
onClick: () -> Unit,
|
|
||||||
content: @Composable () -> Unit = {}
|
|
||||||
) {
|
|
||||||
OutlinedButton(
|
|
||||||
modifier = modifier.heightIn(min = size.minHeight),
|
|
||||||
enabled = enabled,
|
|
||||||
interactionSource = interactionSource,
|
|
||||||
onClick = onClick,
|
|
||||||
border = border,
|
|
||||||
shape = shape,
|
|
||||||
colors = LocalPalette.current.outlinedButtonColors(color)
|
|
||||||
) {
|
|
||||||
size.applyTextStyle {
|
|
||||||
content()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun SessionOutlinedCopyButton(
|
fun OutlineCopyButton(
|
||||||
modifier: Modifier = Modifier,
|
modifier: Modifier = Modifier,
|
||||||
size: ButtonSize = LargeButtonSize,
|
size: ButtonSize = LargeButtonSize,
|
||||||
color: Color = LocalPalette.current.buttonOutline,
|
color: Color = LocalPalette.current.buttonOutline,
|
||||||
@ -89,27 +100,18 @@ fun SessionOutlinedCopyButton(
|
|||||||
) {
|
) {
|
||||||
val interactionSource = remember { MutableInteractionSource() }
|
val interactionSource = remember { MutableInteractionSource() }
|
||||||
|
|
||||||
SessionOutlinedButton(
|
Button(
|
||||||
modifier = modifier.contentDescription(R.string.AccessibilityId_copy_button),
|
modifier = modifier.contentDescription(R.string.AccessibilityId_copy_button),
|
||||||
size = size,
|
|
||||||
interactionSource = interactionSource,
|
interactionSource = interactionSource,
|
||||||
|
size = size,
|
||||||
|
type = ButtonType.Outline,
|
||||||
color = color,
|
color = color,
|
||||||
onClick = onClick
|
onClick = onClick
|
||||||
) {
|
) {
|
||||||
TemporaryClickedContent(
|
TemporaryClickedContent(
|
||||||
interactionSource = interactionSource,
|
interactionSource = interactionSource,
|
||||||
content = {
|
content = { Text(stringResource(R.string.copy)) },
|
||||||
SessionButtonText(
|
temporaryContent = { Text(stringResource(R.string.copied)) }
|
||||||
text = stringResource(R.string.copy),
|
|
||||||
color = color
|
|
||||||
)
|
|
||||||
},
|
|
||||||
temporaryContent = {
|
|
||||||
SessionButtonText(
|
|
||||||
text = stringResource(R.string.copied),
|
|
||||||
color = color
|
|
||||||
)
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -143,3 +145,110 @@ fun TemporaryClickedContent(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface ButtonType {
|
||||||
|
@Composable fun border(color: Color, enabled: Boolean): BorderStroke?
|
||||||
|
@Composable fun buttonColors(color: Color): ButtonColors
|
||||||
|
val elevation: ButtonElevation? @Composable get
|
||||||
|
|
||||||
|
object Outline: ButtonType {
|
||||||
|
@Composable override fun border(color: Color, enabled: Boolean) = BorderStroke(1.dp, if (enabled) color else LocalPalette.current.disabled)
|
||||||
|
@Composable override fun buttonColors(color: Color) = ButtonDefaults.buttonColors(
|
||||||
|
contentColor = color,
|
||||||
|
backgroundColor = Color.Unspecified,
|
||||||
|
disabledContentColor = LocalPalette.current.disabled,
|
||||||
|
disabledBackgroundColor = Color.Unspecified
|
||||||
|
)
|
||||||
|
override val elevation: ButtonElevation? @Composable get() = null
|
||||||
|
}
|
||||||
|
object Fill: ButtonType {
|
||||||
|
@Composable override fun border(color: Color, enabled: Boolean) = null
|
||||||
|
@Composable override fun buttonColors(color: Color) = ButtonDefaults.buttonColors(
|
||||||
|
contentColor = LocalPalette.current.background,
|
||||||
|
backgroundColor = color,
|
||||||
|
disabledContentColor = LocalPalette.current.disabled,
|
||||||
|
disabledBackgroundColor = Color.Unspecified
|
||||||
|
)
|
||||||
|
override val elevation: ButtonElevation? @Composable get() = ButtonDefaults.elevation()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base [Button] implementation
|
||||||
|
*/
|
||||||
|
@Composable
|
||||||
|
fun Button(
|
||||||
|
onClick: () -> Unit,
|
||||||
|
color: Color,
|
||||||
|
type: ButtonType,
|
||||||
|
modifier: Modifier = Modifier,
|
||||||
|
enabled: Boolean = true,
|
||||||
|
size: ButtonSize = LargeButtonSize,
|
||||||
|
elevation: ButtonElevation? = type.elevation,
|
||||||
|
shape: Shape = MaterialTheme.shapes.small,
|
||||||
|
border: BorderStroke? = type.border(color, enabled),
|
||||||
|
colors: ButtonColors = type.buttonColors(color),
|
||||||
|
interactionSource: MutableInteractionSource = remember { MutableInteractionSource() },
|
||||||
|
content: @Composable RowScope.() -> Unit
|
||||||
|
) {
|
||||||
|
size.applyConstraints {
|
||||||
|
androidx.compose.material.Button(
|
||||||
|
onClick,
|
||||||
|
modifier.heightIn(min = size.minHeight),
|
||||||
|
enabled,
|
||||||
|
interactionSource,
|
||||||
|
elevation,
|
||||||
|
shape,
|
||||||
|
border,
|
||||||
|
colors,
|
||||||
|
content = content
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Courtesy [Button] implementation
|
||||||
|
*/
|
||||||
|
@Composable
|
||||||
|
fun Button(
|
||||||
|
text: String,
|
||||||
|
onClick: () -> Unit,
|
||||||
|
color: Color,
|
||||||
|
type: ButtonType,
|
||||||
|
modifier: Modifier = Modifier,
|
||||||
|
enabled: Boolean = true,
|
||||||
|
size: ButtonSize = LargeButtonSize,
|
||||||
|
elevation: ButtonElevation? = type.elevation,
|
||||||
|
shape: Shape = MaterialTheme.shapes.small,
|
||||||
|
border: BorderStroke? = type.border(color, enabled),
|
||||||
|
colors: ButtonColors = type.buttonColors(color),
|
||||||
|
interactionSource: MutableInteractionSource = remember { MutableInteractionSource() },
|
||||||
|
) {
|
||||||
|
Button(onClick, color, type, modifier, enabled, size, elevation, shape, border, colors, interactionSource) {
|
||||||
|
Text(text)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun FillButton(text: String, modifier: Modifier = Modifier, enabled: Boolean = true, onClick: () -> Unit) {
|
||||||
|
Button(text, onClick, LocalPalette.current.buttonOutline, ButtonType.Fill, modifier, enabled)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun PrimaryFillButton(text: String, modifier: Modifier = Modifier, enabled: Boolean = true, onClick: () -> Unit) {
|
||||||
|
Button(text, onClick, LocalPalette.current.primary, ButtonType.Fill, modifier, enabled)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun OutlineButton(text: String, modifier: Modifier = Modifier, color: Color = LocalPalette.current.buttonOutline, enabled: Boolean = true, onClick: () -> Unit) {
|
||||||
|
Button(text, onClick, color, ButtonType.Outline, modifier, enabled)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun PrimaryOutlineButton(text: String, modifier: Modifier = Modifier, enabled: Boolean = true, onClick: () -> Unit) {
|
||||||
|
Button(text, onClick, LocalPalette.current.primary, ButtonType.Outline, modifier, enabled)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun SlimOutlineButton(text: String, modifier: Modifier = Modifier, color: Color = LocalPalette.current.buttonOutline, enabled: Boolean = true, onClick: () -> Unit) {
|
||||||
|
Button(text, onClick, color, ButtonType.Outline, modifier, enabled, SlimButtonSize)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable fun SlimOutlineButton(onClick: () -> Unit, modifier: Modifier = Modifier, color: Color = LocalPalette.current.buttonOutline, enabled: Boolean = true, content: @Composable () -> Unit) {
|
||||||
|
Button(onClick, color, ButtonType.Outline, modifier, enabled, SlimButtonSize) { content() }
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user