Added info popup to explain what 'Fetch all transactions' means (TODO: displays only data of first account for which not all transactions have been fetched, display all)
This commit is contained in:
parent
3c5f63dcd2
commit
7f14215907
|
@ -5,7 +5,6 @@ import android.graphics.drawable.ColorDrawable
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.text.TextWatcher
|
import android.text.TextWatcher
|
||||||
import android.text.method.DigitsKeyListener
|
import android.text.method.DigitsKeyListener
|
||||||
import android.view.Gravity
|
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
@ -33,8 +32,8 @@ import net.dankito.banking.ui.model.responses.BankingClientResponse
|
||||||
import net.dankito.banking.ui.presenter.BankingPresenter
|
import net.dankito.banking.ui.presenter.BankingPresenter
|
||||||
import net.dankito.banking.util.InputValidator
|
import net.dankito.banking.util.InputValidator
|
||||||
import net.dankito.banking.bankfinder.BankInfo
|
import net.dankito.banking.bankfinder.BankInfo
|
||||||
import net.dankito.banking.ui.android.extensions.hideKeyboard
|
|
||||||
import net.dankito.banking.ui.android.extensions.isEllipsized
|
import net.dankito.banking.ui.android.extensions.isEllipsized
|
||||||
|
import net.dankito.banking.ui.android.views.InfoPopupWindow
|
||||||
import net.dankito.banking.util.ValidationResult
|
import net.dankito.banking.util.ValidationResult
|
||||||
import net.dankito.utils.multiplatform.toBigDecimal
|
import net.dankito.utils.multiplatform.toBigDecimal
|
||||||
import net.dankito.utils.android.extensions.asActivity
|
import net.dankito.utils.android.extensions.asActivity
|
||||||
|
@ -155,7 +154,7 @@ open class TransferMoneyDialog : DialogFragment() {
|
||||||
val decimalSeparator = DecimalFormatSymbols.getInstance().getDecimalSeparator()
|
val decimalSeparator = DecimalFormatSymbols.getInstance().getDecimalSeparator()
|
||||||
rootView.edtxtAmount.keyListener = DigitsKeyListener.getInstance("0123456789$decimalSeparator")
|
rootView.edtxtAmount.keyListener = DigitsKeyListener.getInstance("0123456789$decimalSeparator")
|
||||||
|
|
||||||
rootView.btnShowRealTimeTransferInfo.setOnClickListener { showRealTimeTransferInfo(rootView.btnShowRealTimeTransferInfo, rootView) }
|
rootView.btnShowRealTimeTransferInfo.setOnClickListener { showRealTimeTransferInfo(rootView.btnShowRealTimeTransferInfo) }
|
||||||
|
|
||||||
setRealTimeTransferControlsVisibility(rootView)
|
setRealTimeTransferControlsVisibility(rootView)
|
||||||
|
|
||||||
|
@ -192,21 +191,8 @@ open class TransferMoneyDialog : DialogFragment() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun showRealTimeTransferInfo(btnShowRealTimeTransferInfo: ImageButton, rootView: View) {
|
protected open fun showRealTimeTransferInfo(btnShowRealTimeTransferInfo: ImageButton) {
|
||||||
requireActivity().layoutInflater.inflate(R.layout.view_real_time_transfer_info, null)?.let { contentView ->
|
InfoPopupWindow(requireActivity(), R.string.dialog_transfer_money_real_time_transfer_info).show(btnShowRealTimeTransferInfo)
|
||||||
requireContext().hideKeyboard(lytRealTimeTransfer)
|
|
||||||
|
|
||||||
val popupWindow = PopupWindow(contentView, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT)
|
|
||||||
|
|
||||||
popupWindow.isFocusable = true
|
|
||||||
popupWindow.isOutsideTouchable = true
|
|
||||||
|
|
||||||
contentView.findViewById<Button>(R.id.btnDismissPopup)?.setOnClickListener { popupWindow.dismiss() }
|
|
||||||
|
|
||||||
popupWindow.showAtLocation(btnShowRealTimeTransferInfo, Gravity.TOP, 0, 0)
|
|
||||||
|
|
||||||
popupWindow.showAsDropDown(btnShowRealTimeTransferInfo)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun transferMoneyIfEnterPressed(editText: EditText) {
|
private fun transferMoneyIfEnterPressed(editText: EditText) {
|
||||||
|
|
|
@ -6,6 +6,7 @@ import android.os.Bundle
|
||||||
import android.view.*
|
import android.view.*
|
||||||
import android.view.inputmethod.EditorInfo
|
import android.view.inputmethod.EditorInfo
|
||||||
import android.widget.EditText
|
import android.widget.EditText
|
||||||
|
import android.widget.ImageButton
|
||||||
import androidx.appcompat.app.AlertDialog
|
import androidx.appcompat.app.AlertDialog
|
||||||
import androidx.appcompat.widget.SearchView
|
import androidx.appcompat.widget.SearchView
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
|
@ -19,6 +20,7 @@ import net.dankito.banking.ui.android.adapter.AccountTransactionAdapter
|
||||||
import net.dankito.banking.ui.android.di.BankingComponent
|
import net.dankito.banking.ui.android.di.BankingComponent
|
||||||
import net.dankito.banking.ui.android.extensions.addHorizontalItemDivider
|
import net.dankito.banking.ui.android.extensions.addHorizontalItemDivider
|
||||||
import net.dankito.banking.ui.android.extensions.showAmount
|
import net.dankito.banking.ui.android.extensions.showAmount
|
||||||
|
import net.dankito.banking.ui.android.views.InfoPopupWindow
|
||||||
import net.dankito.banking.ui.model.TransactionsRetrievalState
|
import net.dankito.banking.ui.model.TransactionsRetrievalState
|
||||||
import net.dankito.banking.ui.model.TypedBankAccount
|
import net.dankito.banking.ui.model.TypedBankAccount
|
||||||
import net.dankito.banking.ui.model.parameters.TransferMoneyData
|
import net.dankito.banking.ui.model.parameters.TransferMoneyData
|
||||||
|
@ -99,6 +101,8 @@ class HomeFragment : Fragment() {
|
||||||
fetchAllTransactions()
|
fetchAllTransactions()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rootView.btnShowFetchAllTransactionsInfo.setOnClickListener { showFetchAllTransactionsInfo(rootView.btnShowFetchAllTransactionsInfo) }
|
||||||
|
|
||||||
rootView.btnHideTopFetchAllTransactionsView.setOnClickListener {
|
rootView.btnHideTopFetchAllTransactionsView.setOnClickListener {
|
||||||
hideTopFetchAllTransactionsView()
|
hideTopFetchAllTransactionsView()
|
||||||
}
|
}
|
||||||
|
@ -318,6 +322,15 @@ class HomeFragment : Fragment() {
|
||||||
setFetchAllTransactionsView()
|
setFetchAllTransactionsView()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun showFetchAllTransactionsInfo(btnShowFetchAllTransactionsInfo: ImageButton) {
|
||||||
|
val account = presenter.selectedAccountsForWhichNotAllTransactionsHaveBeenFetched.first()
|
||||||
|
|
||||||
|
val dateOfFirstRetrievedTransaction = account.retrievedTransactionsFromOn?.let { presenter.formatToMediumDate(it) } ?: ""
|
||||||
|
val info = requireContext().getString(R.string.popup_fetch_all_transactions_info, dateOfFirstRetrievedTransaction,
|
||||||
|
account.countDaysForWhichTransactionsAreKept, presenter.formatToMediumDate(presenter.getDayOfFirstTransactionStoredOnBankServer(account)))
|
||||||
|
InfoPopupWindow(requireActivity(), info).show(btnShowFetchAllTransactionsInfo, Gravity.BOTTOM)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private fun fetchTransactions() {
|
private fun fetchTransactions() {
|
||||||
presenter.fetchTransactionsOfSelectedAccounts()
|
presenter.fetchTransactionsOfSelectedAccounts()
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
package net.dankito.banking.ui.android.views
|
||||||
|
|
||||||
|
import android.app.Activity
|
||||||
|
import android.view.Gravity
|
||||||
|
import android.view.View
|
||||||
|
import android.view.ViewGroup
|
||||||
|
import android.widget.Button
|
||||||
|
import android.widget.PopupWindow
|
||||||
|
import androidx.annotation.StringRes
|
||||||
|
import kotlinx.android.synthetic.main.view_info_popup.view.*
|
||||||
|
import net.dankito.banking.ui.android.R
|
||||||
|
import net.dankito.banking.ui.android.extensions.hideKeyboard
|
||||||
|
|
||||||
|
|
||||||
|
open class InfoPopupWindow(open val activity: Activity, open val info: String) {
|
||||||
|
|
||||||
|
constructor(activity: Activity, @StringRes infoStringResId: Int) : this(activity, activity.getString(infoStringResId))
|
||||||
|
|
||||||
|
|
||||||
|
open fun show(atLocationOf: View, gravity: Int = Gravity.TOP) {
|
||||||
|
activity.layoutInflater.inflate(R.layout.view_info_popup, null)?.let { contentView ->
|
||||||
|
activity.hideKeyboard(atLocationOf)
|
||||||
|
|
||||||
|
contentView.txtInfo.text = info
|
||||||
|
|
||||||
|
val popupWindow = PopupWindow(contentView, ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT)
|
||||||
|
|
||||||
|
popupWindow.isFocusable = true
|
||||||
|
popupWindow.isOutsideTouchable = true
|
||||||
|
|
||||||
|
contentView.findViewById<Button>(R.id.btnDismissPopup)?.setOnClickListener { popupWindow.dismiss() }
|
||||||
|
|
||||||
|
popupWindow.showAtLocation(atLocationOf, gravity, 0, 0)
|
||||||
|
|
||||||
|
popupWindow.showAsDropDown(atLocationOf)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -154,8 +154,8 @@
|
||||||
|
|
||||||
<ImageButton
|
<ImageButton
|
||||||
android:id="@+id/btnShowRealTimeTransferInfo"
|
android:id="@+id/btnShowRealTimeTransferInfo"
|
||||||
android:layout_width="@dimen/dialog_transfer_money_real_time_transfer_show_info_button_size"
|
android:layout_width="@dimen/info_button_size"
|
||||||
android:layout_height="@dimen/dialog_transfer_money_real_time_transfer_show_info_button_size"
|
android:layout_height="@dimen/info_button_size"
|
||||||
android:layout_weight="0"
|
android:layout_weight="0"
|
||||||
android:layout_gravity="start|center_vertical"
|
android:layout_gravity="start|center_vertical"
|
||||||
android:layout_marginLeft="@dimen/dialog_transfer_money_real_time_transfer_show_info_button_margin_start"
|
android:layout_marginLeft="@dimen/dialog_transfer_money_real_time_transfer_show_info_button_margin_start"
|
||||||
|
|
|
@ -65,10 +65,10 @@
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
>
|
>
|
||||||
|
|
||||||
<Button
|
<LinearLayout
|
||||||
android:id="@+id/btnTopFetchAllTransactions"
|
android:orientation="horizontal"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="@dimen/fragment_account_transaction_fetch_all_transactions_button_height"
|
android:layout_height="match_parent"
|
||||||
android:layout_alignParentTop="true"
|
android:layout_alignParentTop="true"
|
||||||
android:layout_alignParentLeft="true"
|
android:layout_alignParentLeft="true"
|
||||||
android:layout_alignParentStart="true"
|
android:layout_alignParentStart="true"
|
||||||
|
@ -76,13 +76,37 @@
|
||||||
android:layout_toLeftOf="@+id/btnHideTopFetchAllTransactionsView"
|
android:layout_toLeftOf="@+id/btnHideTopFetchAllTransactionsView"
|
||||||
android:layout_toStartOf="@+id/btnHideTopFetchAllTransactionsView"
|
android:layout_toStartOf="@+id/btnHideTopFetchAllTransactionsView"
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
|
>
|
||||||
|
|
||||||
|
<Button
|
||||||
|
android:id="@+id/btnTopFetchAllTransactions"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="@dimen/fragment_account_transaction_fetch_all_transactions_button_height"
|
||||||
|
android:paddingRight="@dimen/fragment_account_transaction_fetch_transactions_button_end"
|
||||||
|
android:paddingEnd="@dimen/fragment_account_transaction_fetch_transactions_button_end"
|
||||||
|
android:gravity="center"
|
||||||
android:textAlignment="gravity"
|
android:textAlignment="gravity"
|
||||||
style="?android:attr/buttonBarButtonStyle"
|
style="?android:attr/buttonBarButtonStyle"
|
||||||
|
android:textSize="@dimen/fragment_account_transaction_fetch_all_transactions_button_text_size"
|
||||||
android:textAllCaps="false"
|
android:textAllCaps="false"
|
||||||
android:textColor="@color/linkColor"
|
android:textColor="@color/linkColor"
|
||||||
android:text="@string/fragment_home_fetch_all_account_transactions"
|
android:text="@string/fragment_home_fetch_all_account_transactions"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
<ImageButton
|
||||||
|
android:id="@+id/btnShowFetchAllTransactionsInfo"
|
||||||
|
android:layout_width="@dimen/info_button_size"
|
||||||
|
android:layout_height="@dimen/info_button_size"
|
||||||
|
android:layout_gravity="start|center_vertical"
|
||||||
|
android:layout_marginRight="@dimen/fragment_account_transaction_show_fetch_all_transactions_info_button_margin_end"
|
||||||
|
android:layout_marginEnd="@dimen/fragment_account_transaction_show_fetch_all_transactions_info_button_margin_end"
|
||||||
|
android:background="@null"
|
||||||
|
app:srcCompat="@drawable/ic_baseline_info_24"
|
||||||
|
android:tint="@color/infoIconColor"
|
||||||
|
/>
|
||||||
|
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<ImageButton
|
<ImageButton
|
||||||
android:id="@+id/btnHideTopFetchAllTransactionsView"
|
android:id="@+id/btnHideTopFetchAllTransactionsView"
|
||||||
android:layout_width="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_height_and_width"
|
android:layout_width="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_height_and_width"
|
||||||
|
@ -96,7 +120,7 @@
|
||||||
android:layout_marginRight="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end"
|
android:layout_marginRight="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end"
|
||||||
android:layout_marginEnd="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end"
|
android:layout_marginEnd="@dimen/fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end"
|
||||||
android:background="@null"
|
android:background="@null"
|
||||||
android:tint="#000000"
|
android:tint="@color/textColorSecondary"
|
||||||
app:srcCompat="@drawable/ic_baseline_close_24"
|
app:srcCompat="@drawable/ic_baseline_close_24"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
|
|
@ -15,11 +15,11 @@
|
||||||
>
|
>
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:id="@+id/txtInfo"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
style="@style/TextAppearance.AppCompat.Medium"
|
style="@style/TextAppearance.AppCompat.Medium"
|
||||||
android:textSize="@dimen/view_real_time_transfer_info_text_size"
|
android:textSize="@dimen/view_info_popup_text_size"
|
||||||
android:text="@string/dialog_transfer_money_real_time_transfer_info"
|
|
||||||
/>
|
/>
|
||||||
|
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
|
@ -27,14 +27,14 @@
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:id="@+id/lytButtonBar"
|
android:id="@+id/lytButtonBar"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="@dimen/view_real_time_info_dismiss_button_height"
|
android:layout_height="@dimen/view_info_popup_dismiss_button_height"
|
||||||
android:layout_alignParentBottom="true"
|
android:layout_alignParentBottom="true"
|
||||||
android:gravity="center"
|
android:gravity="center"
|
||||||
>
|
>
|
||||||
|
|
||||||
<Button
|
<Button
|
||||||
android:id="@+id/btnDismissPopup"
|
android:id="@+id/btnDismissPopup"
|
||||||
android:layout_width="@dimen/view_real_time_transfer_info_dismiss_button_width"
|
android:layout_width="@dimen/view_info_popup_dismiss_button_width"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
style="?android:attr/buttonBarButtonStyle"
|
style="?android:attr/buttonBarButtonStyle"
|
||||||
android:text="@android:string/ok"
|
android:text="@android:string/ok"
|
|
@ -60,7 +60,13 @@
|
||||||
<string name="fragment_home_transactions_retrieval_state_no_transactions_in_retrieved_period">Empfangener Zeitraum vom %1$s - %2$s enthält keine Umsätze</string>
|
<string name="fragment_home_transactions_retrieval_state_no_transactions_in_retrieved_period">Empfangener Zeitraum vom %1$s - %2$s enthält keine Umsätze</string>
|
||||||
<string name="fragment_home_transfer_money_to">Neue Überweisung an %s</string>
|
<string name="fragment_home_transfer_money_to">Neue Überweisung an %s</string>
|
||||||
<string name="fragment_home_transfer_money_with_same_data">Neue Überweisung mit gleichen Daten</string>
|
<string name="fragment_home_transfer_money_with_same_data">Neue Überweisung mit gleichen Daten</string>
|
||||||
<string name="fragment_home_fetch_all_account_transactions">Ältere Umsätze abrufen (erfordert TAN)</string>
|
<string name="fragment_home_fetch_all_account_transactions">Alle Umsätze abrufen (erfordert TAN)</string>
|
||||||
|
|
||||||
|
<string name="popup_fetch_all_transactions_info">Bisher wurden nur die Umsätze seit dem %1$s abgerufen.
|
||||||
|
\n\nFür dieses Konto können die Umsätze der letzten %2$d Tage, also bis zum %3$s, abgerufen werden.
|
||||||
|
\n\nWenn Sie dies tun möchten, klicken Sie einfach auf den links stehenden Button.
|
||||||
|
\n\nMöchten Sie hingegen den Button für dieses Konto nicht mehr angezeigt bekommen, klicken Sie auf das \'x\' rechts. Der Button wird dann immer noch am Ende der Umsatzlist angezeigt, falls Sie die älteren Umsätze später doch noch abrufen möchten.
|
||||||
|
</string>
|
||||||
|
|
||||||
<string name="dialog_add_account_enter_bank">Bank (Suche auch mittels Bankleitzahl oder Ort):</string>
|
<string name="dialog_add_account_enter_bank">Bank (Suche auch mittels Bankleitzahl oder Ort):</string>
|
||||||
<string name="dialog_add_account_add">Hinzufügen</string>
|
<string name="dialog_add_account_add">Hinzufügen</string>
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
<dimen name="form_on_off_value_height">30dp</dimen>
|
<dimen name="form_on_off_value_height">30dp</dimen>
|
||||||
<dimen name="form_on_off_value_label_text_size">15sp</dimen>
|
<dimen name="form_on_off_value_label_text_size">15sp</dimen>
|
||||||
|
|
||||||
|
<dimen name="info_button_size">20dp</dimen>
|
||||||
|
|
||||||
<dimen name="activity_login_app_logo_size">70dp</dimen>
|
<dimen name="activity_login_app_logo_size">70dp</dimen>
|
||||||
<dimen name="activity_login_app_logo_margin_bottom">40dp</dimen>
|
<dimen name="activity_login_app_logo_margin_bottom">40dp</dimen>
|
||||||
<dimen name="activity_login_enter_password_margin_top">30dp</dimen>
|
<dimen name="activity_login_enter_password_margin_top">30dp</dimen>
|
||||||
|
@ -52,10 +54,13 @@
|
||||||
<dimen name="fragment_account_transaction_transactions_summary_margin_bottom">6dp</dimen>
|
<dimen name="fragment_account_transaction_transactions_summary_margin_bottom">6dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_fetch_transactions_button_height">40dp</dimen>
|
<dimen name="fragment_account_transaction_fetch_transactions_button_height">40dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_fetch_transactions_button_margin_top">18dp</dimen>
|
<dimen name="fragment_account_transaction_fetch_transactions_button_margin_top">18dp</dimen>
|
||||||
|
<dimen name="fragment_account_transaction_fetch_transactions_button_end">12dp</dimen>
|
||||||
|
<dimen name="fragment_account_transaction_show_fetch_all_transactions_info_button_margin_end">12dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_add_account_button_height">40dp</dimen>
|
<dimen name="fragment_account_transaction_add_account_button_height">40dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_fetch_all_transactions_layout_height">48dp</dimen>
|
<dimen name="fragment_account_transaction_fetch_all_transactions_layout_height">48dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_fetch_all_transactions_button_height">40dp</dimen>
|
<dimen name="fragment_account_transaction_fetch_all_transactions_button_height">40dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_hide_fetch_all_transactions_button_height_and_width">30dp</dimen>
|
<dimen name="fragment_account_transaction_fetch_all_transactions_button_text_size">15sp</dimen>
|
||||||
|
<dimen name="fragment_account_transaction_hide_fetch_all_transactions_button_height_and_width">40dp</dimen>
|
||||||
<dimen name="fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end">2dp</dimen>
|
<dimen name="fragment_account_transaction_hide_fetch_all_transactions_button_margin_start_and_end">2dp</dimen>
|
||||||
|
|
||||||
<dimen name="list_item_account_transaction_height">74dp</dimen>
|
<dimen name="list_item_account_transaction_height">74dp</dimen>
|
||||||
|
@ -104,7 +109,6 @@
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_text_size">14sp</dimen>
|
<dimen name="dialog_transfer_money_real_time_transfer_text_size">14sp</dimen>
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_margin_top">6dp</dimen>
|
<dimen name="dialog_transfer_money_real_time_transfer_margin_top">6dp</dimen>
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_margin_bottom">6dp</dimen>
|
<dimen name="dialog_transfer_money_real_time_transfer_margin_bottom">6dp</dimen>
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_show_info_button_size">20dp</dimen>
|
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_show_info_button_margin_start">6dp</dimen>
|
<dimen name="dialog_transfer_money_real_time_transfer_show_info_button_margin_start">6dp</dimen>
|
||||||
<dimen name="dialog_transfer_money_real_time_transfer_show_info_button_margin_end">12dp</dimen>
|
<dimen name="dialog_transfer_money_real_time_transfer_show_info_button_margin_end">12dp</dimen>
|
||||||
<dimen name="dialog_transfer_money_buttons_width">120dp</dimen>
|
<dimen name="dialog_transfer_money_buttons_width">120dp</dimen>
|
||||||
|
@ -117,10 +121,9 @@
|
||||||
<dimen name="list_item_recipient_padding">4dp</dimen>
|
<dimen name="list_item_recipient_padding">4dp</dimen>
|
||||||
<dimen name="list_item_recipient_space_between_fields">4dp</dimen>
|
<dimen name="list_item_recipient_space_between_fields">4dp</dimen>
|
||||||
|
|
||||||
<dimen name="view_real_time_transfer_info_padding">8dp</dimen>
|
<dimen name="view_info_popup_text_size">15sp</dimen>
|
||||||
<dimen name="view_real_time_transfer_info_text_size">15sp</dimen>
|
<dimen name="view_info_popup_dismiss_button_width">150dp</dimen>
|
||||||
<dimen name="view_real_time_transfer_info_dismiss_button_width">150dp</dimen>
|
<dimen name="view_info_popup_dismiss_button_height">40dp</dimen>
|
||||||
<dimen name="view_real_time_info_dismiss_button_height">40dp</dimen>
|
|
||||||
|
|
||||||
<dimen name="view_tan_image_controls_buttons_height">40dp</dimen>
|
<dimen name="view_tan_image_controls_buttons_height">40dp</dimen>
|
||||||
<dimen name="view_tan_image_controls_buttons_width">40dp</dimen>
|
<dimen name="view_tan_image_controls_buttons_width">40dp</dimen>
|
||||||
|
|
|
@ -60,7 +60,13 @@
|
||||||
<string name="fragment_home_transactions_retrieval_state_no_transactions_in_retrieved_period">There haven\'t been any transactions in retrieved period from %1$s - %2$s</string>
|
<string name="fragment_home_transactions_retrieval_state_no_transactions_in_retrieved_period">There haven\'t been any transactions in retrieved period from %1$s - %2$s</string>
|
||||||
<string name="fragment_home_transfer_money_to">Transfer money to %s</string>
|
<string name="fragment_home_transfer_money_to">Transfer money to %s</string>
|
||||||
<string name="fragment_home_transfer_money_with_same_data">New transfer with same data</string>
|
<string name="fragment_home_transfer_money_with_same_data">New transfer with same data</string>
|
||||||
<string name="fragment_home_fetch_all_account_transactions">Fetch earlier transactions (requires TAN)</string>
|
<string name="fragment_home_fetch_all_account_transactions">Fetch all transactions (requires TAN)</string>
|
||||||
|
|
||||||
|
<string name="popup_fetch_all_transactions_info">Until now only the transactions since the %1$s were retrieved.
|
||||||
|
\n\nFor this account the transactions of the last %2$d days, i.e. up to %3$s, can be retrieved.
|
||||||
|
\n\nIf you want to do this, simply click on the button to the left.
|
||||||
|
\n\nIf you no longer wish to see this button for this account, click on the \'x\' on the right. The button will still be displayed at the end of the list of transactions, in case you want to retrieve the earlier transactions later.
|
||||||
|
</string>
|
||||||
|
|
||||||
<string name="dialog_add_account_enter_bank">Bank (find also by bank code or city):</string>
|
<string name="dialog_add_account_enter_bank">Bank (find also by bank code or city):</string>
|
||||||
<string name="dialog_add_account_add">Add</string>
|
<string name="dialog_add_account_add">Add</string>
|
||||||
|
|
|
@ -427,15 +427,17 @@ open class BankingPresenter(
|
||||||
protected open fun didFetchAllTransactionsStoredOnBankServer(account: IBankAccount<IAccountTransaction>, fetchedTransactions: Collection<IAccountTransaction>): Boolean {
|
protected open fun didFetchAllTransactionsStoredOnBankServer(account: IBankAccount<IAccountTransaction>, fetchedTransactions: Collection<IAccountTransaction>): Boolean {
|
||||||
account.countDaysForWhichTransactionsAreKept?.let { countDaysForWhichTransactionsAreKept ->
|
account.countDaysForWhichTransactionsAreKept?.let { countDaysForWhichTransactionsAreKept ->
|
||||||
(account.retrievedTransactionsFromOn ?: getDateOfFirstRetrievedTransaction(account.bookedTransactions) ?: getDateOfFirstRetrievedTransaction(fetchedTransactions))?.let { retrievedTransactionsFromOn ->
|
(account.retrievedTransactionsFromOn ?: getDateOfFirstRetrievedTransaction(account.bookedTransactions) ?: getDateOfFirstRetrievedTransaction(fetchedTransactions))?.let { retrievedTransactionsFromOn ->
|
||||||
val dayOfFirstTransactionStoredOnBankServer = Date(Date.today.millisSinceEpoch - countDaysForWhichTransactionsAreKept * OneDayMillis)
|
return retrievedTransactionsFromOn.isBeforeOrEquals(getDayOfFirstTransactionStoredOnBankServer(account))
|
||||||
|
|
||||||
return retrievedTransactionsFromOn.isBeforeOrEquals(dayOfFirstTransactionStoredOnBankServer)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
open fun getDayOfFirstTransactionStoredOnBankServer(account: IBankAccount<IAccountTransaction>): Date {
|
||||||
|
return Date(Date.today.millisSinceEpoch - (account.countDaysForWhichTransactionsAreKept ?: 0) * OneDayMillis)
|
||||||
|
}
|
||||||
|
|
||||||
protected open fun getDateOfFirstRetrievedTransaction(transactions: Collection<IAccountTransaction>): Date? {
|
protected open fun getDateOfFirstRetrievedTransaction(transactions: Collection<IAccountTransaction>): Date? {
|
||||||
return transactions.map { it.valueDate }.minBy { it.millisSinceEpoch }
|
return transactions.map { it.valueDate }.minBy { it.millisSinceEpoch }
|
||||||
}
|
}
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
3642F0182502723A005186FE /* UIKitButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0172502723A005186FE /* UIKitButton.swift */; };
|
3642F0182502723A005186FE /* UIKitButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0172502723A005186FE /* UIKitButton.swift */; };
|
||||||
3642F01A2502931F005186FE /* RealTimeTransferInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */; };
|
3642F01A2502931F005186FE /* RealTimeTransferInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */; };
|
||||||
3642F04B25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */; };
|
3642F04B25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */; };
|
||||||
|
36693A4E25280BCB00BB7AE5 /* InfoButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 36693A4D25280BCB00BB7AE5 /* InfoButton.swift */; };
|
||||||
366FA4DA24C472A90094F009 /* Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4D924C472A90094F009 /* Extensions.swift */; };
|
366FA4DA24C472A90094F009 /* Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4D924C472A90094F009 /* Extensions.swift */; };
|
||||||
366FA4DC24C479120094F009 /* BankInfoListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DB24C479120094F009 /* BankInfoListItem.swift */; };
|
366FA4DC24C479120094F009 /* BankInfoListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DB24C479120094F009 /* BankInfoListItem.swift */; };
|
||||||
366FA4E024C4924A0094F009 /* RecipientListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DF24C4924A0094F009 /* RecipientListItem.swift */; };
|
366FA4E024C4924A0094F009 /* RecipientListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DF24C4924A0094F009 /* RecipientListItem.swift */; };
|
||||||
|
@ -186,6 +187,7 @@
|
||||||
3642F0172502723A005186FE /* UIKitButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIKitButton.swift; sourceTree = "<group>"; };
|
3642F0172502723A005186FE /* UIKitButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIKitButton.swift; sourceTree = "<group>"; };
|
||||||
3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RealTimeTransferInfoView.swift; sourceTree = "<group>"; };
|
3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RealTimeTransferInfoView.swift; sourceTree = "<group>"; };
|
||||||
3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionHeaderWithRightAlignedEditButton.swift; sourceTree = "<group>"; };
|
3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionHeaderWithRightAlignedEditButton.swift; sourceTree = "<group>"; };
|
||||||
|
36693A4D25280BCB00BB7AE5 /* InfoButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InfoButton.swift; sourceTree = "<group>"; };
|
||||||
366FA4D924C472A90094F009 /* Extensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Extensions.swift; sourceTree = "<group>"; };
|
366FA4D924C472A90094F009 /* Extensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Extensions.swift; sourceTree = "<group>"; };
|
||||||
366FA4DB24C479120094F009 /* BankInfoListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BankInfoListItem.swift; sourceTree = "<group>"; };
|
366FA4DB24C479120094F009 /* BankInfoListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BankInfoListItem.swift; sourceTree = "<group>"; };
|
||||||
366FA4DF24C4924A0094F009 /* RecipientListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RecipientListItem.swift; sourceTree = "<group>"; };
|
366FA4DF24C4924A0094F009 /* RecipientListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RecipientListItem.swift; sourceTree = "<group>"; };
|
||||||
|
@ -568,6 +570,7 @@
|
||||||
36BE06B424CF85A300CBBB68 /* AmountLabel.swift */,
|
36BE06B424CF85A300CBBB68 /* AmountLabel.swift */,
|
||||||
360782CE24F3D6610098FEFE /* InfoLabel.swift */,
|
360782CE24F3D6610098FEFE /* InfoLabel.swift */,
|
||||||
360782C224E49FF70098FEFE /* ValidationLabel.swift */,
|
360782C224E49FF70098FEFE /* ValidationLabel.swift */,
|
||||||
|
36693A4D25280BCB00BB7AE5 /* InfoButton.swift */,
|
||||||
3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */,
|
3642F0192502931F005186FE /* RealTimeTransferInfoView.swift */,
|
||||||
36BE065C24CB08FB00CBBB68 /* LazyView.swift */,
|
36BE065C24CB08FB00CBBB68 /* LazyView.swift */,
|
||||||
36C4009A24D2F9E4005227AD /* IconedTitleView.swift */,
|
36C4009A24D2F9E4005227AD /* IconedTitleView.swift */,
|
||||||
|
@ -832,6 +835,7 @@
|
||||||
3675052C251FFE98006B13A0 /* AccountTransactionDetailsDialog.swift in Sources */,
|
3675052C251FFE98006B13A0 /* AccountTransactionDetailsDialog.swift in Sources */,
|
||||||
36B8A44B2503D1E800C15359 /* BiometricAuthenticationService.swift in Sources */,
|
36B8A44B2503D1E800C15359 /* BiometricAuthenticationService.swift in Sources */,
|
||||||
36FC929E24B39A05002B12E9 /* SceneDelegate.swift in Sources */,
|
36FC929E24B39A05002B12E9 /* SceneDelegate.swift in Sources */,
|
||||||
|
36693A4E25280BCB00BB7AE5 /* InfoButton.swift in Sources */,
|
||||||
3607829924E148D40098FEFE /* AdaptsToKeyboard.swift in Sources */,
|
3607829924E148D40098FEFE /* AdaptsToKeyboard.swift in Sources */,
|
||||||
36750532252006C9006B13A0 /* TextWithScrollView.swift in Sources */,
|
36750532252006C9006B13A0 /* TextWithScrollView.swift in Sources */,
|
||||||
36E21ECF24DA0EEE00649DC8 /* IconView.swift in Sources */,
|
36E21ECF24DA0EEE00649DC8 /* IconView.swift in Sources */,
|
||||||
|
|
|
@ -78,7 +78,11 @@
|
||||||
|
|
||||||
"%@ transactions" = "%@ transactions";
|
"%@ transactions" = "%@ transactions";
|
||||||
|
|
||||||
"Fetch all account transactions" = "Fetch earlier transactions (requires TAN)";
|
"Fetch all account transactions" = "Fetch all transactions (requires TAN)";
|
||||||
|
"Fetch all transactions info %@ %@ %@" = "Until now only the transactions since the %@ were retrieved.
|
||||||
|
\n\nFor this account the transactions of the last %@ days, i.e. up to %@, can be retrieved.
|
||||||
|
\n\nIf you want to do this, simply click on the button to the left.
|
||||||
|
\n\nIf you no longer wish to see this button for this account, click on the \'x\' on the right. The button will still be displayed at the end of the list of transactions, in case you want to retrieve the earlier transactions later.";
|
||||||
|
|
||||||
"Fetch transactions" = "Fetch transactions";
|
"Fetch transactions" = "Fetch transactions";
|
||||||
"Account type not supported by app" = "Account type not supported by app";
|
"Account type not supported by app" = "Account type not supported by app";
|
||||||
|
|
|
@ -78,7 +78,11 @@
|
||||||
|
|
||||||
"%@ transactions" = "%@ Umsätze";
|
"%@ transactions" = "%@ Umsätze";
|
||||||
|
|
||||||
"Fetch all account transactions" = "Ältere Umsätze laden (erfordert TAN)";
|
"Fetch all account transactions" = "Alle Umsätze abrufen (erfordert TAN)";
|
||||||
|
"Fetch all transactions info %@ %@ %@" = "Bisher wurden nur die Umsätze seit dem %@ abgerufen.
|
||||||
|
\n\nFür dieses Konto können die Umsätze der letzten %@ Tage, also bis zum %@, abgerufen werden.
|
||||||
|
\n\nWenn Sie dies tun möchten, klicken Sie einfach auf den links stehenden Button.
|
||||||
|
\n\nMöchten Sie hingegen den Button für dieses Konto nicht mehr angezeigt bekommen, klicken Sie auf das \'x\' rechts. Der Button wird dann immer noch am Ende der Umsatzlist angezeigt, falls Sie die älteren Umsätze später doch noch abrufen möchten.";
|
||||||
|
|
||||||
"Fetch transactions" = "Umsätze abrufen";
|
"Fetch transactions" = "Umsätze abrufen";
|
||||||
"Account type not supported by app" = "Kontotyp wird von App nicht unterstützt";
|
"Account type not supported by app" = "Kontotyp wird von App nicht unterstützt";
|
||||||
|
|
|
@ -98,6 +98,9 @@ struct AccountTransactionsDialog: View {
|
||||||
fetchAllTransactionsButton
|
fetchAllTransactionsButton
|
||||||
.padding(.horizontal, 0)
|
.padding(.horizontal, 0)
|
||||||
|
|
||||||
|
InfoButton(getFetchAllTransactionsInfoText(), .bottom)
|
||||||
|
.padding(.horizontal, 8)
|
||||||
|
|
||||||
}
|
}
|
||||||
.padding(.horizontal, 0)
|
.padding(.horizontal, 0)
|
||||||
.padding(.trailing, Self.HideTopFetchAllTransactionsViewButtonWidth)
|
.padding(.trailing, Self.HideTopFetchAllTransactionsViewButtonWidth)
|
||||||
|
@ -185,11 +188,20 @@ struct AccountTransactionsDialog: View {
|
||||||
private var fetchAllTransactionsButton: some View {
|
private var fetchAllTransactionsButton: some View {
|
||||||
Button(action: { self.fetchAllTransactions() } ) {
|
Button(action: { self.fetchAllTransactions() } ) {
|
||||||
Text("Fetch all account transactions")
|
Text("Fetch all account transactions")
|
||||||
|
.font(.callout)
|
||||||
.multilineTextAlignment(.center)
|
.multilineTextAlignment(.center)
|
||||||
}
|
}
|
||||||
.foregroundColor(Color.blue)
|
.foregroundColor(Color.blue)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private func getFetchAllTransactionsInfoText() -> LocalizedStringKey {
|
||||||
|
let account = presenter.selectedAccountsForWhichNotAllTransactionsHaveBeenFetched.first!
|
||||||
|
|
||||||
|
let dateOfFirstRetrievedTransaction = account.retrievedTransactionsFromOn != nil ? presenter.formatToMediumDate(date: account.retrievedTransactionsFromOn!) : ""
|
||||||
|
|
||||||
|
return LocalizedStringKey("Fetch all transactions info \(dateOfFirstRetrievedTransaction) \(account.countDaysForWhichTransactionsAreKept ?? 0) \(presenter.formatToMediumDate(date: presenter.getDayOfFirstTransactionStoredOnBankServer(account: account)))")
|
||||||
|
}
|
||||||
|
|
||||||
private var hideTopFetchAllTransactionsViewButton: some View {
|
private var hideTopFetchAllTransactionsViewButton: some View {
|
||||||
// do not set Button's action as then if any of the two buttons get pressed, both actions get executed (bug in iOS). Use .onTapGesture() instead
|
// do not set Button's action as then if any of the two buttons get pressed, both actions get executed (bug in iOS). Use .onTapGesture() instead
|
||||||
Button("X") { }
|
Button("X") { }
|
||||||
|
|
|
@ -0,0 +1,57 @@
|
||||||
|
import SwiftUI
|
||||||
|
|
||||||
|
|
||||||
|
struct InfoButton: View {
|
||||||
|
|
||||||
|
@State private var showInfoPopover = false
|
||||||
|
|
||||||
|
private let infoText: LocalizedStringKey
|
||||||
|
|
||||||
|
private let arrowEdge: Edge
|
||||||
|
|
||||||
|
|
||||||
|
init(_ infoText: LocalizedStringKey, _ arrowEdge: Edge = .leading) {
|
||||||
|
self.infoText = infoText
|
||||||
|
self.arrowEdge = arrowEdge
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
var body: some View {
|
||||||
|
UIKitButton(.infoLight) { self.showInfoPopover = true }
|
||||||
|
.frame(width: 15, height: 15)
|
||||||
|
.popover(isPresented: $showInfoPopover, arrowEdge: arrowEdge ) {
|
||||||
|
if UIDevice.isRunningOniPad {
|
||||||
|
ScrollView {
|
||||||
|
Text(infoText)
|
||||||
|
.padding()
|
||||||
|
.detailForegroundColor()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
VStack {
|
||||||
|
Text(infoText)
|
||||||
|
.padding()
|
||||||
|
.detailForegroundColor()
|
||||||
|
|
||||||
|
HStack {
|
||||||
|
Spacer()
|
||||||
|
|
||||||
|
Button("OK") { self.showInfoPopover = false }
|
||||||
|
|
||||||
|
Spacer()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
struct InfoButton_Previews: PreviewProvider {
|
||||||
|
|
||||||
|
static var previews: some View {
|
||||||
|
InfoButton("Info")
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -3,8 +3,6 @@ import SwiftUI
|
||||||
|
|
||||||
struct RealTimeTransferInfoView: View {
|
struct RealTimeTransferInfoView: View {
|
||||||
|
|
||||||
@State private var showRealTimeTransferInfoPopover = false
|
|
||||||
|
|
||||||
|
|
||||||
var body: some View {
|
var body: some View {
|
||||||
HStack {
|
HStack {
|
||||||
|
@ -15,32 +13,7 @@ struct RealTimeTransferInfoView: View {
|
||||||
.minimumScaleFactor(0.5)
|
.minimumScaleFactor(0.5)
|
||||||
.padding(.horizontal, 0)
|
.padding(.horizontal, 0)
|
||||||
|
|
||||||
UIKitButton(.infoLight) { self.showRealTimeTransferInfoPopover = true }
|
InfoButton("Real-time transfer information")
|
||||||
.frame(width: 15, height: 15)
|
|
||||||
.popover(isPresented: $showRealTimeTransferInfoPopover, arrowEdge: .leading ) {
|
|
||||||
if UIDevice.isRunningOniPad {
|
|
||||||
ScrollView {
|
|
||||||
Text("Real-time transfer information")
|
|
||||||
.padding()
|
|
||||||
.detailForegroundColor()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
VStack {
|
|
||||||
Text("Real-time transfer information")
|
|
||||||
.padding()
|
|
||||||
.detailForegroundColor()
|
|
||||||
|
|
||||||
HStack {
|
|
||||||
Spacer()
|
|
||||||
|
|
||||||
Button("OK") { self.showRealTimeTransferInfoPopover = false }
|
|
||||||
|
|
||||||
Spacer()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue