diff --git a/app/src/main/java/com/kunzisoft/keepass/activities/GroupActivity.kt b/app/src/main/java/com/kunzisoft/keepass/activities/GroupActivity.kt index 9de6ad9b4..a5d2ed9c4 100644 --- a/app/src/main/java/com/kunzisoft/keepass/activities/GroupActivity.kt +++ b/app/src/main/java/com/kunzisoft/keepass/activities/GroupActivity.kt @@ -124,6 +124,7 @@ class GroupActivity : DatabaseLockActivity(), private var drawerLayout: DrawerLayout? = null private var databaseNavView: NavigationDatabaseView? = null private var coordinatorLayout: CoordinatorLayout? = null + private var coordinatorError: CoordinatorLayout? = null private var lockView: View? = null private var toolbar: Toolbar? = null private var databaseModifiedView: ImageView? = null @@ -270,6 +271,7 @@ class GroupActivity : DatabaseLockActivity(), drawerLayout = findViewById(R.id.drawer_layout) databaseNavView = findViewById(R.id.database_nav_view) coordinatorLayout = findViewById(R.id.group_coordinator) + coordinatorError = findViewById(R.id.error_coordinator) numberChildrenView = findViewById(R.id.group_numbers) addNodeButtonView = findViewById(R.id.add_node_button) toolbar = findViewById(R.id.toolbar) @@ -690,7 +692,7 @@ class GroupActivity : DatabaseLockActivity(), } } - coordinatorLayout?.showActionErrorIfNeeded(result) + coordinatorError?.showActionErrorIfNeeded(result) // Reload the group loadGroup() diff --git a/app/src/main/java/com/kunzisoft/keepass/database/helper/LocalizedHelper.kt b/app/src/main/java/com/kunzisoft/keepass/database/helper/LocalizedHelper.kt index 9b5c0c00b..7ebe3aa0f 100644 --- a/app/src/main/java/com/kunzisoft/keepass/database/helper/LocalizedHelper.kt +++ b/app/src/main/java/com/kunzisoft/keepass/database/helper/LocalizedHelper.kt @@ -26,7 +26,7 @@ import com.kunzisoft.keepass.database.element.template.TemplateEngine import com.kunzisoft.keepass.database.element.template.TemplateField import com.kunzisoft.keepass.database.exception.* -fun DatabaseException.getLocalizedMessage(resources: Resources): String = parameters?.let { +fun DatabaseException.getLocalizedMessage(resources: Resources): String? = when (this) { is FileNotFoundDatabaseException -> resources.getString(R.string.file_not_found_content) is CorruptedDatabaseException -> resources.getString(R.string.corrupted_file) @@ -39,7 +39,7 @@ fun DatabaseException.getLocalizedMessage(resources: Resources): String = parame is InvalidCredentialsDatabaseException -> resources.getString(R.string.invalid_credentials) is KDFMemoryDatabaseException -> resources.getString(R.string.error_load_database_KDF_memory) is NoMemoryDatabaseException -> resources.getString(R.string.error_out_of_memory) - is DuplicateUuidDatabaseException -> resources.getString(R.string.invalid_db_same_uuid) + is DuplicateUuidDatabaseException -> resources.getString(R.string.invalid_db_same_uuid, parameters[0], parameters[1]) is XMLMalformedDatabaseException -> resources.getString(R.string.error_XML_malformed) is MergeDatabaseKDBException -> resources.getString(R.string.error_unable_merge_database_kdb) is MoveEntryDatabaseException -> resources.getString(R.string.error_move_entry_here) @@ -48,9 +48,8 @@ fun DatabaseException.getLocalizedMessage(resources: Resources): String = parame is CopyGroupDatabaseException -> resources.getString(R.string.error_copy_group_here) is DatabaseInputException -> resources.getString(R.string.error_load_database) is DatabaseOutputException -> resources.getString(R.string.error_save_database) - else -> (mThrowable as? DatabaseException)?.getLocalizedMessage(resources) + else -> localizedMessage } -} ?: resources.getString(R.string.error_load_database) fun CompressionAlgorithm.getLocalizedName(resources: Resources): String { return when (this) { diff --git a/app/src/main/res/layout/activity_group.xml b/app/src/main/res/layout/activity_group.xml index e89bcdf47..6e5515e7c 100644 --- a/app/src/main/res/layout/activity_group.xml +++ b/app/src/main/res/layout/activity_group.xml @@ -157,6 +157,13 @@ android:layout_height="wrap_content" app:layout_constraintBottom_toTopOf="@+id/screenshot_mode_banner" /> + + diff --git a/database/src/main/java/com/kunzisoft/keepass/database/exception/DatabaseException.kt b/database/src/main/java/com/kunzisoft/keepass/database/exception/DatabaseException.kt index e5962fc53..d25359ca1 100644 --- a/database/src/main/java/com/kunzisoft/keepass/database/exception/DatabaseException.kt +++ b/database/src/main/java/com/kunzisoft/keepass/database/exception/DatabaseException.kt @@ -27,7 +27,7 @@ import java.io.PrintWriter abstract class DatabaseException : Exception { var innerMessage: String? = null - var parameters: (Array)? = null + var parameters = mutableListOf() var mThrowable: Throwable? = null constructor() : super() @@ -94,7 +94,10 @@ class NoMemoryDatabaseException(exception: Throwable) : DatabaseInputException(e class DuplicateUuidDatabaseException(type: Type, uuid: NodeId<*>) : DatabaseInputException() { init { - parameters = arrayOf(type.name, uuid.toString()) + parameters.apply { + add(type.name) + add(uuid.toString()) + } } }