diff options
author | Torsten Grote <t@grobox.de> | 2023-04-13 11:31:44 -0300 |
---|---|---|
committer | Torsten Grote <t@grobox.de> | 2023-04-13 11:31:44 -0300 |
commit | 656ab6bb848920986734681a4d6bd69d7fbf5b14 (patch) | |
tree | ca495f9cd45b635dc5fa21e76cc00c4bcb3b2eab /wallet/src/main/java/net/taler/wallet/transactions | |
parent | 1c6fda4c3bfd7599f530b313e6533aa1a5c7c7e8 (diff) | |
download | taler-android-656ab6bb848920986734681a4d6bd69d7fbf5b14.tar.gz taler-android-656ab6bb848920986734681a4d6bd69d7fbf5b14.tar.bz2 taler-android-656ab6bb848920986734681a4d6bd69d7fbf5b14.zip |
[wallet] Clean up compose migration of payment and refund transactions
Diffstat (limited to 'wallet/src/main/java/net/taler/wallet/transactions')
5 files changed, 91 insertions, 104 deletions
diff --git a/wallet/src/main/java/net/taler/wallet/transactions/TransactionDetailFragment.kt b/wallet/src/main/java/net/taler/wallet/transactions/TransactionDetailFragment.kt index d37728f..678bed2 100644 --- a/wallet/src/main/java/net/taler/wallet/transactions/TransactionDetailFragment.kt +++ b/wallet/src/main/java/net/taler/wallet/transactions/TransactionDetailFragment.kt @@ -17,25 +17,16 @@ package net.taler.wallet.transactions import android.os.Bundle -import android.text.SpannableString -import android.text.style.UnderlineSpan import android.view.Menu import android.view.MenuInflater import android.view.MenuItem -import android.widget.TextView import androidx.annotation.StringRes import androidx.fragment.app.Fragment import androidx.fragment.app.activityViewModels import androidx.navigation.fragment.findNavController import com.google.android.material.dialog.MaterialAlertDialogBuilder -import kotlinx.serialization.encodeToString -import kotlinx.serialization.json.Json -import net.taler.common.Amount import net.taler.wallet.MainViewModel import net.taler.wallet.R -import net.taler.wallet.compose.copyToClipBoard -import net.taler.wallet.getAttrColor -import net.taler.wallet.launchInAppBrowser abstract class TransactionDetailFragment : Fragment() { @@ -72,34 +63,6 @@ abstract class TransactionDetailFragment : Fragment() { } } - protected fun bindOrderAndFee( - orderSummaryView: TextView, - orderAmountView: TextView, - orderIdView: TextView, - feeView: TextView, - info: TransactionInfo, - raw: Amount, - fee: Amount, - ) { - orderAmountView.text = raw.toString() - feeView.text = getString(R.string.amount_negative, fee.toString()) - orderSummaryView.text = if (info.fulfillmentMessage == null) { - info.summary - } else { - "${info.summary}\n\n${info.fulfillmentMessage}" - } - if (info.fulfillmentUrl?.startsWith("http", ignoreCase = true) == true) { - val content = SpannableString(info.summary) - content.setSpan(UnderlineSpan(), 0, info.summary.length, 0) - orderSummaryView.text = content - orderSummaryView.setTextColor(requireContext().getAttrColor(android.R.attr.textColorLink)) - orderSummaryView.setOnClickListener { - launchInAppBrowser(requireContext(), info.fulfillmentUrl) - } - } - orderIdView.text = getString(R.string.transaction_order_id, info.orderId) - } - @StringRes protected open val deleteDialogTitle = R.string.transactions_delete @@ -128,30 +91,4 @@ abstract class TransactionDetailFragment : Fragment() { findNavController().popBackStack() } - protected fun onShowErrorButtonClicked(t: Transaction) { - val err = t.error - require(err != null) { "Transaction had no error." } - - @Suppress("OPT_IN_USAGE") - val json = Json { - prettyPrint = true - prettyPrintIndent = " " - } - val message = json.encodeToString(err) - MaterialAlertDialogBuilder(requireContext(), R.style.MaterialAlertDialog_Material3) - .setTitle(getString(R.string.nav_error)) - .setMessage(message) - .setNeutralButton(R.string.close) { dialog, _ -> - dialog.cancel() - } - .setPositiveButton(R.string.copy) { _, _ -> - copyToClipBoard( - requireContext(), - getString(R.string.nav_error), - message, - ) - } - .show() - } - } diff --git a/wallet/src/main/java/net/taler/wallet/transactions/TransactionLinkComposable.kt b/wallet/src/main/java/net/taler/wallet/transactions/TransactionLinkComposable.kt new file mode 100644 index 0000000..e8fca0f --- /dev/null +++ b/wallet/src/main/java/net/taler/wallet/transactions/TransactionLinkComposable.kt @@ -0,0 +1,86 @@ +/* + * This file is part of GNU Taler + * (C) 2023 Taler Systems S.A. + * + * GNU Taler is free software; you can redistribute it and/or modify it under the + * terms of the GNU General Public License as published by the Free Software + * Foundation; either version 3, or (at your option) any later version. + * + * GNU Taler is distributed in the hope that it will be useful, but WITHOUT ANY + * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR + * A PARTICULAR PURPOSE. See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License along with + * GNU Taler; see the file COPYING. If not, see <http://www.gnu.org/licenses/> + */ + +package net.taler.wallet.transactions + +import android.R +import androidx.compose.foundation.layout.Column +import androidx.compose.foundation.layout.padding +import androidx.compose.foundation.text.ClickableText +import androidx.compose.material3.MaterialTheme +import androidx.compose.material3.Text +import androidx.compose.runtime.Composable +import androidx.compose.ui.Alignment.Companion.CenterHorizontally +import androidx.compose.ui.Modifier +import androidx.compose.ui.graphics.Color +import androidx.compose.ui.platform.LocalContext +import androidx.compose.ui.text.SpanStyle +import androidx.compose.ui.text.TextStyle +import androidx.compose.ui.text.buildAnnotatedString +import androidx.compose.ui.text.style.TextAlign +import androidx.compose.ui.text.withStyle +import androidx.compose.ui.tooling.preview.Preview +import androidx.compose.ui.unit.dp +import androidx.compose.ui.unit.sp +import net.taler.wallet.compose.TalerSurface +import net.taler.wallet.getAttrColor + +@Composable +// FIXME this assumes that it is used in a column and applies its own padding, not really re-usable +fun TransactionLinkComposable(label: String, info: String, onClick: () -> Unit) { + Text( + modifier = Modifier.padding(top = 16.dp, start = 16.dp, end = 16.dp), + text = label, + style = MaterialTheme.typography.bodyMedium, + ) + val context = LocalContext.current + val linkColor = Color(context.getAttrColor(R.attr.textColorLink)) + val annotatedString = buildAnnotatedString { + pushStringAnnotation(tag = "url", annotation = info) + withStyle(style = SpanStyle(color = linkColor)) { + append(info) + } + pop() + } + ClickableText( + modifier = Modifier.padding(top = 8.dp, start = 16.dp, end = 16.dp, bottom = 16.dp), + text = annotatedString, + style = TextStyle(fontSize = 24.sp, textAlign = TextAlign.Center), + ) { offset -> + annotatedString.getStringAnnotations( + tag = "url", + start = offset, + end = offset, + ).firstOrNull()?.let { + onClick() + } + } +} + +@Preview +@Composable +fun TransactionLinkComposablePreview() { + TalerSurface { + Column( + horizontalAlignment = CenterHorizontally, + ) { + TransactionLinkComposable( + label = "This is a label", + info = "This is some fulfillment message" + ) {} + } + } +} diff --git a/wallet/src/main/java/net/taler/wallet/transactions/TransactionPaymentFragment.kt b/wallet/src/main/java/net/taler/wallet/transactions/TransactionPaymentFragment.kt index ac35fe0..e9eb5b8 100644 --- a/wallet/src/main/java/net/taler/wallet/transactions/TransactionPaymentFragment.kt +++ b/wallet/src/main/java/net/taler/wallet/transactions/TransactionPaymentFragment.kt @@ -36,7 +36,8 @@ class TransactionPaymentFragment : TransactionDetailFragment() { setContent { TalerSurface { val t = transactionManager.selectedTransaction.observeAsState().value - if (t is TransactionPayment) TransactionPaymentComposable(t, devMode.value, + val devMode = devMode.observeAsState().value ?: false + if (t is TransactionPayment) TransactionPaymentComposable(t, devMode, onFulfill = { url -> launchInAppBrowser(requireContext(), url) }, diff --git a/wallet/src/main/java/net/taler/wallet/transactions/TransactionPeerFragment.kt b/wallet/src/main/java/net/taler/wallet/transactions/TransactionPeerFragment.kt index 170c719..297c937 100644 --- a/wallet/src/main/java/net/taler/wallet/transactions/TransactionPeerFragment.kt +++ b/wallet/src/main/java/net/taler/wallet/transactions/TransactionPeerFragment.kt @@ -24,7 +24,6 @@ import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.padding import androidx.compose.foundation.rememberScrollState -import androidx.compose.foundation.text.ClickableText import androidx.compose.foundation.verticalScroll import androidx.compose.material3.MaterialTheme import androidx.compose.material3.Text @@ -36,18 +35,12 @@ import androidx.compose.ui.graphics.Color import androidx.compose.ui.platform.ComposeView import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.res.colorResource -import androidx.compose.ui.text.SpanStyle -import androidx.compose.ui.text.TextStyle -import androidx.compose.ui.text.buildAnnotatedString -import androidx.compose.ui.text.style.TextAlign -import androidx.compose.ui.text.withStyle import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import net.taler.common.Amount import net.taler.common.toAbsoluteTime import net.taler.wallet.R import net.taler.wallet.compose.TalerSurface -import net.taler.wallet.getAttrColor import net.taler.wallet.peer.TransactionPeerPullCreditComposable import net.taler.wallet.peer.TransactionPeerPullDebitComposable import net.taler.wallet.peer.TransactionPeerPushCreditComposable @@ -132,34 +125,3 @@ fun TransactionInfoComposable(label: String, info: String) { fontSize = 24.sp, ) } - -@Composable -fun TransactionLinkComposable(label: String, info: String, onClick: () -> Unit) { - Text( - modifier = Modifier.padding(top = 16.dp, start = 16.dp, end = 16.dp), - text = label, - style = MaterialTheme.typography.bodyMedium, - ) - val context = LocalContext.current - val linkColor = Color(context.getAttrColor(android.R.attr.textColorLink)) - val annotatedString = buildAnnotatedString { - pushStringAnnotation(tag = "url", annotation = info) - withStyle(style = SpanStyle(color = linkColor)) { - append(info) - } - pop() - } - ClickableText( - modifier = Modifier.padding(top = 8.dp, start = 16.dp, end = 16.dp, bottom = 16.dp), - text = annotatedString, - style = TextStyle(fontSize = 24.sp, textAlign = TextAlign.Center), - ) { offset -> - annotatedString.getStringAnnotations( - tag = "url", - start = offset, - end = offset, - ).firstOrNull()?.let { - onClick() - } - } -}
\ No newline at end of file diff --git a/wallet/src/main/java/net/taler/wallet/transactions/TransactionRefundFragment.kt b/wallet/src/main/java/net/taler/wallet/transactions/TransactionRefundFragment.kt index b4a3be8..61c0364 100644 --- a/wallet/src/main/java/net/taler/wallet/transactions/TransactionRefundFragment.kt +++ b/wallet/src/main/java/net/taler/wallet/transactions/TransactionRefundFragment.kt @@ -24,7 +24,7 @@ import androidx.compose.runtime.livedata.observeAsState import androidx.compose.ui.platform.ComposeView import net.taler.wallet.compose.TalerSurface import net.taler.wallet.launchInAppBrowser -import net.taler.wallet.payment.TransactionPaymentComposable +import net.taler.wallet.refund.TransactionRefundComposable class TransactionRefundFragment : TransactionDetailFragment() { @@ -36,7 +36,8 @@ class TransactionRefundFragment : TransactionDetailFragment() { setContent { TalerSurface { val t = transactionManager.selectedTransaction.observeAsState().value - if (t is TransactionRefund) TransactionPaymentComposable(t, devMode.value, + val devMode = devMode.observeAsState().value ?: false + if (t is TransactionRefund) TransactionRefundComposable(t, devMode, onFulfill = { url -> launchInAppBrowser(requireContext(), url) }, |