From 7024a8c521b721a39a23dca80b18b83b0c95085a Mon Sep 17 00:00:00 2001 From: fankesyooni Date: Fri, 3 Jun 2022 04:46:23 +0800 Subject: [PATCH] Added muted errors apps management function and fix i18n translation --- README.md | 6 +- app/src/main/AndroidManifest.xml | 5 + .../bean/MutedErrorsAppBean.kt | 37 ++++++ .../hook/entity/FrameworkHooker.kt | 31 ++++- .../apperrorstracking/locale/LocaleString.kt | 22 ++-- .../errors/AppErrorsDisplayActivity.kt | 8 +- .../activity/errors/AppErrorsMutedActivity.kt | 90 ++++++++++++++ .../ui/activity/main/MainActivity.kt | 9 +- .../utils/tool/FrameworkTool.kt | 112 +++++++++++++++--- .../res/layout/activity_app_errors_muted.xml | 85 +++++++++++++ .../res/layout/activity_app_errors_record.xml | 2 +- app/src/main/res/layout/activity_main.xml | 12 +- .../res/layout/adapter_app_errors_muted.xml | 67 +++++++++++ .../res/layout/dia_app_errors_display.xml | 4 +- app/src/main/res/values-ja/strings.xml | 24 ++-- app/src/main/res/values-zh-rCN/strings.xml | 24 ++-- app/src/main/res/values-zh-rHK/strings.xml | 24 ++-- app/src/main/res/values-zh-rMO/strings.xml | 24 ++-- app/src/main/res/values-zh-rTW/strings.xml | 24 ++-- app/src/main/res/values/strings.xml | 32 ++--- 20 files changed, 526 insertions(+), 116 deletions(-) create mode 100644 app/src/main/java/com/fankes/apperrorstracking/bean/MutedErrorsAppBean.kt create mode 100644 app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsMutedActivity.kt create mode 100644 app/src/main/res/layout/activity_app_errors_muted.xml create mode 100644 app/src/main/res/layout/adapter_app_errors_muted.xml diff --git a/README.md b/README.md index 9af4493..7fdf43d 100644 --- a/README.md +++ b/README.md @@ -54,11 +54,9 @@ Added more features to app's crash dialog, fixed custom rom deleted dialog, the 此项目依然在开发中,现在未解决的问题和包含的问题如下 -- 排除列表功能 +- 应用配置模板功能 -- 已忽略异常的 APP 查看功能 - -- 更多功能 +- 更多功能 (计划内) ## License diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index 9a3a705..497395d 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -59,6 +59,11 @@ android:exported="true" android:screenOrientation="behind" /> + + + * + * This file is Created by fankes on 2022/6/3. + */ +package com.fankes.apperrorstracking.bean + +import java.io.Serializable + +/** + * 已忽略异常的应用 bean + * @param type 类型 + * @param packageName 包名 + */ +data class MutedErrorsAppBean(var type: MuteType, var packageName: String) : Serializable { + + /** + * 已忽略的异常类型 + */ + enum class MuteType { UNTIL_UNLOCKS, UNTIL_REBOOTS } +} \ No newline at end of file diff --git a/app/src/main/java/com/fankes/apperrorstracking/hook/entity/FrameworkHooker.kt b/app/src/main/java/com/fankes/apperrorstracking/hook/entity/FrameworkHooker.kt index 2f29378..1f37795 100644 --- a/app/src/main/java/com/fankes/apperrorstracking/hook/entity/FrameworkHooker.kt +++ b/app/src/main/java/com/fankes/apperrorstracking/hook/entity/FrameworkHooker.kt @@ -30,6 +30,7 @@ import android.os.Message import com.fankes.apperrorstracking.BuildConfig import com.fankes.apperrorstracking.bean.AppErrorsDisplayBean import com.fankes.apperrorstracking.bean.AppErrorsInfoBean +import com.fankes.apperrorstracking.bean.MutedErrorsAppBean import com.fankes.apperrorstracking.data.DataConst import com.fankes.apperrorstracking.locale.LocaleString import com.fankes.apperrorstracking.ui.activity.errors.AppErrorsDisplayActivity @@ -65,10 +66,10 @@ object FrameworkHooker : YukiBaseHooker() { ) /** 已忽略错误的 APP 数组 - 直到重新解锁 */ - private var ignoredErrorsIfUnlockApps = HashSet() + private var mutedErrorsIfUnlockApps = HashSet() /** 已忽略错误的 APP 数组 - 直到重新启动 */ - private var ignoredErrorsIfRestartApps = HashSet() + private var mutedErrorsIfRestartApps = HashSet() /** 已记录的 APP 异常信息数组 - 直到重新启动 */ private val appErrorsRecords = ArrayList() @@ -77,7 +78,7 @@ object FrameworkHooker : YukiBaseHooker() { private fun register() { onAppLifecycle { /** 解锁后清空已记录的忽略错误 APP */ - registerReceiver(Intent.ACTION_USER_PRESENT) { _, _ -> ignoredErrorsIfUnlockApps.clear() } + registerReceiver(Intent.ACTION_USER_PRESENT) { _, _ -> mutedErrorsIfUnlockApps.clear() } /** 刷新模块 Resources 缓存 */ registerReceiver(Intent.ACTION_LOCALE_CHANGED) { _, _ -> refreshModuleAppResources() } } @@ -86,8 +87,26 @@ object FrameworkHooker : YukiBaseHooker() { onPushAppErrorsInfoData { appErrorsRecords } onRemoveAppErrorsInfoData { appErrorsRecords.remove(it) } onClearAppErrorsInfoData { appErrorsRecords.clear() } - onIgnoredErrorsIfUnlock { ignoredErrorsIfUnlockApps.add(it) } - onIgnoredErrorsIfRestart { ignoredErrorsIfRestartApps.add(it) } + onMutedErrorsIfUnlock { mutedErrorsIfUnlockApps.add(it) } + onMutedErrorsIfRestart { mutedErrorsIfRestartApps.add(it) } + onPushMutedErrorsAppsData { + arrayListOf().apply { + mutedErrorsIfUnlockApps.takeIf { it.isNotEmpty() } + ?.forEach { add(MutedErrorsAppBean(MutedErrorsAppBean.MuteType.UNTIL_UNLOCKS, it)) } + mutedErrorsIfRestartApps.takeIf { it.isNotEmpty() } + ?.forEach { add(MutedErrorsAppBean(MutedErrorsAppBean.MuteType.UNTIL_REBOOTS, it)) } + } + } + onUnmuteErrorsApp { + when (it.type) { + MutedErrorsAppBean.MuteType.UNTIL_UNLOCKS -> mutedErrorsIfUnlockApps.remove(it.packageName) + MutedErrorsAppBean.MuteType.UNTIL_REBOOTS -> mutedErrorsIfRestartApps.remove(it.packageName) + } + } + onUnmuteAllErrorsApps { + mutedErrorsIfUnlockApps.clear() + mutedErrorsIfRestartApps.clear() + } } } @@ -179,7 +198,7 @@ object FrameworkHooker : YukiBaseHooker() { return@afterHook } /** 判断是否为已忽略的 APP */ - if (ignoredErrorsIfUnlockApps.contains(packageName) || ignoredErrorsIfRestartApps.contains(packageName)) return@afterHook + if (mutedErrorsIfUnlockApps.contains(packageName) || mutedErrorsIfRestartApps.contains(packageName)) return@afterHook /** 判断是否为后台进程 */ if ((isBackgroundProcess || context.isAppCanOpened(packageName).not()) && prefs.get(DataConst.ENABLE_ONLY_SHOW_ERRORS_IN_FRONT) diff --git a/app/src/main/java/com/fankes/apperrorstracking/locale/LocaleString.kt b/app/src/main/java/com/fankes/apperrorstracking/locale/LocaleString.kt index 832cc3f..feab41a 100644 --- a/app/src/main/java/com/fankes/apperrorstracking/locale/LocaleString.kt +++ b/app/src/main/java/com/fankes/apperrorstracking/locale/LocaleString.kt @@ -144,28 +144,28 @@ object LocaleString { fun errorDetail(vararg objArrs: Any) = R.string.error_detail.bind(*objArrs) /** @string Automatic generated */ - val ignoreIfUnlock get() = ignoreIfUnlock() + val muteIfUnlock get() = muteIfUnlock() /** @string Automatic generated */ - fun ignoreIfUnlock(vararg objArrs: Any) = R.string.ignore_if_unlock.bind(*objArrs) + fun muteIfUnlock(vararg objArrs: Any) = R.string.mute_if_unlock.bind(*objArrs) /** @string Automatic generated */ - val ignoreIfRestart get() = ignoreIfRestart() + val muteIfRestart get() = muteIfRestart() /** @string Automatic generated */ - fun ignoreIfRestart(vararg objArrs: Any) = R.string.ignore_if_restart.bind(*objArrs) + fun muteIfRestart(vararg objArrs: Any) = R.string.mute_if_restart.bind(*objArrs) /** @string Automatic generated */ - val ignoreIfUnlockTip get() = ignoreIfUnlockTip() + val muteIfUnlockTip get() = muteIfUnlockTip() /** @string Automatic generated */ - fun ignoreIfUnlockTip(vararg objArrs: Any) = R.string.ignore_if_unlock_tip.bind(*objArrs) + fun muteIfUnlockTip(vararg objArrs: Any) = R.string.mute_if_unlock_tip.bind(*objArrs) /** @string Automatic generated */ - val ignoreIfRestartTip get() = ignoreIfRestartTip() + val muteIfRestartTip get() = muteIfRestartTip() /** @string Automatic generated */ - fun ignoreIfRestartTip(vararg objArrs: Any) = R.string.ignore_if_restart_tip.bind(*objArrs) + fun muteIfRestartTip(vararg objArrs: Any) = R.string.mute_if_restart_tip.bind(*objArrs) /** @string Automatic generated */ val confirm get() = confirm() @@ -340,4 +340,10 @@ object LocaleString { /** @string Automatic generated */ fun shareErrorStack(vararg objArrs: Any) = R.string.share_error_stack.bind(*objArrs) + + /** @string Automatic generated */ + val areYouSureUnmuteAll get() = areYouSureUnmuteAll() + + /** @string Automatic generated */ + fun areYouSureUnmuteAll(vararg objArrs: Any) = R.string.are_you_sure_unmute_all.bind(*objArrs) } \ No newline at end of file diff --git a/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsDisplayActivity.kt b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsDisplayActivity.kt index 4fd50bb..e787474 100644 --- a/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsDisplayActivity.kt +++ b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsDisplayActivity.kt @@ -87,14 +87,14 @@ class AppErrorsDisplayActivity : BaseActivity() } } ignoreIfUnlockItem.setOnClickListener { - FrameworkTool.ignoredErrorsIfUnlock(context, appErrorsDisplay.packageName) { - toast(LocaleString.ignoreIfUnlockTip(appErrorsDisplay.appName)) + FrameworkTool.mutedErrorsIfUnlock(context, appErrorsDisplay.packageName) { + toast(LocaleString.muteIfUnlockTip(appErrorsDisplay.appName)) cancel() } } ignoreIfRestartItem.setOnClickListener { - FrameworkTool.ignoredErrorsIfRestart(context, appErrorsDisplay.packageName) { - toast(LocaleString.ignoreIfRestartTip(appErrorsDisplay.appName)) + FrameworkTool.mutedErrorsIfRestart(context, appErrorsDisplay.packageName) { + toast(LocaleString.muteIfRestartTip(appErrorsDisplay.appName)) cancel() } } diff --git a/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsMutedActivity.kt b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsMutedActivity.kt new file mode 100644 index 0000000..e437f3d --- /dev/null +++ b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/errors/AppErrorsMutedActivity.kt @@ -0,0 +1,90 @@ +/* + * AppErrorsTracking - Added more features to app's crash dialog, fixed custom rom deleted dialog, the best experience to Android developer. + * Copyright (C) 2019-2022 Fankes Studio(qzmmcn@163.com) + * https://github.com/KitsunePie/AppErrorsTracking + * + * This software is non-free but opensource software: you can redistribute it + * and/or modify it under the terms of the GNU Affero General Public License + * as published by the Free Software Foundation; either + * version 3 of the License, or any later version. + * + * This software 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 + * Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * and eula along with this software. If not, see + * + * + * This file is Created by fankes on 2022/6/3. + */ +@file:Suppress("DEPRECATION", "OVERRIDE_DEPRECATION") + +package com.fankes.apperrorstracking.ui.activity.errors + +import androidx.core.view.isVisible +import com.fankes.apperrorstracking.bean.MutedErrorsAppBean +import com.fankes.apperrorstracking.databinding.ActivityAppErrorsMutedBinding +import com.fankes.apperrorstracking.databinding.AdapterAppErrorsMutedBinding +import com.fankes.apperrorstracking.locale.LocaleString +import com.fankes.apperrorstracking.ui.activity.base.BaseActivity +import com.fankes.apperrorstracking.utils.factory.appIcon +import com.fankes.apperrorstracking.utils.factory.appName +import com.fankes.apperrorstracking.utils.factory.bindAdapter +import com.fankes.apperrorstracking.utils.factory.showDialog +import com.fankes.apperrorstracking.utils.tool.FrameworkTool + +class AppErrorsMutedActivity : BaseActivity() { + + /** 回调适配器改变 */ + private var onChanged: (() -> Unit)? = null + + /** 全部的已忽略异常的 APP 信息 */ + private val listData = ArrayList() + + override fun onCreate() { + binding.titleBackIcon.setOnClickListener { onBackPressed() } + binding.unmuteAllIcon.setOnClickListener { + showDialog { + title = LocaleString.notice + msg = LocaleString.areYouSureUnmuteAll + confirmButton { FrameworkTool.unmuteAllErrorsApps(context) { refreshData() } } + cancelButton() + } + } + /** 设置列表元素和 Adapter */ + binding.listView.bindAdapter { + onBindDatas { listData } + onBindViews { binding, position -> + listData[position].also { bean -> + binding.appIcon.setImageDrawable(appIcon(bean.packageName)) + binding.appNameText.text = appName(bean.packageName) + binding.muteTypeText.text = when (bean.type) { + MutedErrorsAppBean.MuteType.UNTIL_UNLOCKS -> LocaleString.muteIfUnlock + MutedErrorsAppBean.MuteType.UNTIL_REBOOTS -> LocaleString.muteIfRestart + } + binding.unmuteButton.setOnClickListener { FrameworkTool.unmuteErrorsApp(context, bean) { refreshData() } } + } + } + }.apply { onChanged = { notifyDataSetChanged() } } + } + + /** 更新列表数据 */ + private fun refreshData() { + FrameworkTool.fetchMutedErrorsAppsData(context = this) { + listData.clear() + it.takeIf { e -> e.isNotEmpty() }?.forEach { e -> listData.add(e) } + onChanged?.invoke() + binding.unmuteAllIcon.isVisible = listData.isNotEmpty() + binding.listView.isVisible = listData.isNotEmpty() + binding.listNoDataView.isVisible = listData.isEmpty() + } + } + + override fun onResume() { + super.onResume() + /** 执行更新 */ + refreshData() + } +} \ No newline at end of file diff --git a/app/src/main/java/com/fankes/apperrorstracking/ui/activity/main/MainActivity.kt b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/main/MainActivity.kt index 1158721..8cb5c93 100644 --- a/app/src/main/java/com/fankes/apperrorstracking/ui/activity/main/MainActivity.kt +++ b/app/src/main/java/com/fankes/apperrorstracking/ui/activity/main/MainActivity.kt @@ -33,6 +33,7 @@ import com.fankes.apperrorstracking.data.DataConst import com.fankes.apperrorstracking.databinding.ActivityMainBinding import com.fankes.apperrorstracking.locale.LocaleString import com.fankes.apperrorstracking.ui.activity.base.BaseActivity +import com.fankes.apperrorstracking.ui.activity.errors.AppErrorsMutedActivity import com.fankes.apperrorstracking.ui.activity.errors.AppErrorsRecordActivity import com.fankes.apperrorstracking.utils.factory.navigate import com.fankes.apperrorstracking.utils.factory.openBrowser @@ -72,13 +73,13 @@ class MainActivity : BaseActivity() { } binding.enableAppsConfigsTemplateSwitch.setOnCheckedChangeListener { btn, b -> if (b) btn.isChecked = false - toastComingSooon() + toastComingSoon() } /** 管理应用配置模板按钮点击事件 */ - binding.mgrAppsConfigsTemplateButton.setOnClickListener { toastComingSooon() } + binding.mgrAppsConfigsTemplateButton.setOnClickListener { toastComingSoon() } /** 功能管理按钮点击事件 */ binding.viewErrorsRecordButton.setOnClickListener { navigate() } - binding.viewIgnoredErrorsAppsButton.setOnClickListener { toastComingSooon() } + binding.viewMutedErrorsAppsButton.setOnClickListener { navigate() } /** 重启按钮点击事件 */ binding.titleRestartIcon.setOnClickListener { FrameworkTool.restartSystem(context = this) } /** 项目地址按钮点击事件 */ @@ -111,7 +112,7 @@ class MainActivity : BaseActivity() { } /** 敬请期待 */ - private fun toastComingSooon() = toast(msg = "Coming soon") + private fun toastComingSoon() = toast(msg = "Coming soon") override fun onResume() { super.onResume() diff --git a/app/src/main/java/com/fankes/apperrorstracking/utils/tool/FrameworkTool.kt b/app/src/main/java/com/fankes/apperrorstracking/utils/tool/FrameworkTool.kt index 1034f27..b917f29 100644 --- a/app/src/main/java/com/fankes/apperrorstracking/utils/tool/FrameworkTool.kt +++ b/app/src/main/java/com/fankes/apperrorstracking/utils/tool/FrameworkTool.kt @@ -25,6 +25,7 @@ package com.fankes.apperrorstracking.utils.tool import android.content.Context import com.fankes.apperrorstracking.bean.AppErrorsInfoBean +import com.fankes.apperrorstracking.bean.MutedErrorsAppBean import com.fankes.apperrorstracking.locale.LocaleString import com.fankes.apperrorstracking.utils.factory.execShell import com.fankes.apperrorstracking.utils.factory.isRootAccess @@ -43,17 +44,23 @@ object FrameworkTool { private const val SYSTEM_FRAMEWORK_NAME = "android" private const val CALL_APP_ERRORS_DATA_GET = "call_app_errors_data_get" - private const val CALL_APP_ERRORS_DATA_REMOVE_RESULT = "call_app_errors_data_remove_result" + private const val CALL_MUTED_ERRORS_APP_DATA_GET = "call_muted_app_errors_data_get" private const val CALL_APP_ERRORS_DATA_CLEAR = "call_app_errors_data_clear" + private const val CALL_UNMUTE_ALL_ERRORS_APPS_DATA = "call_unmute_all_errors_apps_data" + private const val CALL_APP_ERRORS_DATA_REMOVE_RESULT = "call_app_errors_data_remove_result" private const val CALL_APP_ERRORS_DATA_CLEAR_RESULT = "call_app_errors_data_clear_result" - private const val CALL_IGNORED_ERRORS_IF_UNLOCK_RESULT = "call_ignored_errors_if_unlock_result" - private const val CALL_IGNORED_ERRORS_IF_RESTART_RESULT = "call_ignored_errors_if_restart_result" + private const val CALL_MUTED_ERRORS_IF_UNLOCK_RESULT = "call_muted_errors_if_unlock_result" + private const val CALL_MUTED_ERRORS_IF_RESTART_RESULT = "call_muted_errors_if_restart_result" + private const val CALL_UNMUTE_ERRORS_APP_DATA_RESULT = "call_unmute_errors_app_data_result" + private const val CALL_UNMUTE_ALL_ERRORS_APPS_DATA_RESULT = "call_unmute_all_errors_apps_data_result" private val CALL_OPEN_SPECIFY_APP = ChannelData("call_open_specify_app") private val CALL_APP_ERRORS_DATA_REMOVE = ChannelData("call_app_errors_data_remove") private val CALL_APP_ERRORS_DATA_GET_RESULT = ChannelData>("call_app_errors_data_get_result") - private val CALL_IGNORED_ERRORS_IF_UNLOCK = ChannelData("call_ignored_errors_if_unlock") - private val CALL_IGNORED_ERRORS_IF_RESTART = ChannelData("call_ignored_errors_if_restart") + private val CALL_MUTED_ERRORS_APP_DATA_GET_RESULT = ChannelData>("call_muted_app_errors_data_get_result") + private val CALL_UNMUTE_ERRORS_APP_DATA = ChannelData("call_unmute_errors_app_data") + private val CALL_MUTED_ERRORS_IF_UNLOCK = ChannelData("call_muted_errors_if_unlock") + private val CALL_MUTED_ERRORS_IF_RESTART = ChannelData("call_muted_errors_if_restart") /** * 宿主注册监听 @@ -115,11 +122,11 @@ object FrameworkTool { * 监听忽略 APP 的错误直到设备重新解锁 * @param result 回调包名 */ - fun onIgnoredErrorsIfUnlock(result: (String) -> Unit) { + fun onMutedErrorsIfUnlock(result: (String) -> Unit) { instance?.dataChannel?.with { - wait(CALL_IGNORED_ERRORS_IF_UNLOCK) { + wait(CALL_MUTED_ERRORS_IF_UNLOCK) { result(it) - put(CALL_IGNORED_ERRORS_IF_UNLOCK_RESULT) + put(CALL_MUTED_ERRORS_IF_UNLOCK_RESULT) } } } @@ -128,11 +135,45 @@ object FrameworkTool { * 监听忽略 APP 的错误直到设备重新启动 * @param result 回调包名 */ - fun onIgnoredErrorsIfRestart(result: (String) -> Unit) { + fun onMutedErrorsIfRestart(result: (String) -> Unit) { instance?.dataChannel?.with { - wait(CALL_IGNORED_ERRORS_IF_RESTART) { + wait(CALL_MUTED_ERRORS_IF_RESTART) { result(it) - put(CALL_IGNORED_ERRORS_IF_RESTART_RESULT) + put(CALL_MUTED_ERRORS_IF_RESTART_RESULT) + } + } + } + + /** + * 监听发送已忽略异常的 APP 信息数组 + * @param result 回调数据 + */ + fun onPushMutedErrorsAppsData(result: () -> ArrayList) { + instance?.dataChannel?.with { wait(CALL_MUTED_ERRORS_APP_DATA_GET) { put(CALL_MUTED_ERRORS_APP_DATA_GET_RESULT, result()) } } + } + + /** + * 监听取消指定已忽略异常的 APP + * @param result 回调数据 + */ + fun onUnmuteErrorsApp(result: (MutedErrorsAppBean) -> Unit) { + instance?.dataChannel?.with { + wait(CALL_UNMUTE_ERRORS_APP_DATA) { + result(it) + put(CALL_UNMUTE_ERRORS_APP_DATA_RESULT) + } + } + } + + /** + * 监听取消全部已忽略异常的 APP + * @param callback 回调 + */ + fun onUnmuteAllErrorsApps(callback: () -> Unit) { + instance?.dataChannel?.with { + wait(CALL_UNMUTE_ALL_ERRORS_APPS_DATA) { + callback() + put(CALL_UNMUTE_ALL_ERRORS_APPS_DATA_RESULT) } } } @@ -217,10 +258,10 @@ object FrameworkTool { * @param packageName APP 包名 * @param callback 成功后回调 */ - fun ignoredErrorsIfUnlock(context: Context, packageName: String, callback: () -> Unit) { + fun mutedErrorsIfUnlock(context: Context, packageName: String, callback: () -> Unit) { context.dataChannel(SYSTEM_FRAMEWORK_NAME).with { - wait(CALL_IGNORED_ERRORS_IF_UNLOCK_RESULT) { callback() } - put(CALL_IGNORED_ERRORS_IF_UNLOCK, packageName) + wait(CALL_MUTED_ERRORS_IF_UNLOCK_RESULT) { callback() } + put(CALL_MUTED_ERRORS_IF_UNLOCK, packageName) } } @@ -230,10 +271,47 @@ object FrameworkTool { * @param packageName APP 包名 * @param callback 成功后回调 */ - fun ignoredErrorsIfRestart(context: Context, packageName: String, callback: () -> Unit) { + fun mutedErrorsIfRestart(context: Context, packageName: String, callback: () -> Unit) { context.dataChannel(SYSTEM_FRAMEWORK_NAME).with { - wait(CALL_IGNORED_ERRORS_IF_RESTART_RESULT) { callback() } - put(CALL_IGNORED_ERRORS_IF_RESTART, packageName) + wait(CALL_MUTED_ERRORS_IF_RESTART_RESULT) { callback() } + put(CALL_MUTED_ERRORS_IF_RESTART, packageName) + } + } + + /** + * 获取已忽略异常的 APP 信息数组 + * @param context 实例 + * @param result 回调数据 + */ + fun fetchMutedErrorsAppsData(context: Context, result: (ArrayList) -> Unit) { + context.dataChannel(SYSTEM_FRAMEWORK_NAME).with { + wait(CALL_MUTED_ERRORS_APP_DATA_GET_RESULT) { result(it) } + put(CALL_MUTED_ERRORS_APP_DATA_GET) + } + } + + /** + * 取消指定已忽略异常的 APP + * @param context 实例 + * @param mutedErrorsApp 指定已忽略异常的 APP 信息 + * @param callback 成功后回调 + */ + fun unmuteErrorsApp(context: Context, mutedErrorsApp: MutedErrorsAppBean, callback: () -> Unit) { + context.dataChannel(SYSTEM_FRAMEWORK_NAME).with { + wait(CALL_UNMUTE_ERRORS_APP_DATA_RESULT) { callback() } + put(CALL_UNMUTE_ERRORS_APP_DATA, mutedErrorsApp) + } + } + + /** + * 取消全部已忽略异常的 APP + * @param context 实例 + * @param callback 成功后回调 + */ + fun unmuteAllErrorsApps(context: Context, callback: () -> Unit) { + context.dataChannel(SYSTEM_FRAMEWORK_NAME).with { + wait(CALL_UNMUTE_ALL_ERRORS_APPS_DATA_RESULT) { callback() } + put(CALL_UNMUTE_ALL_ERRORS_APPS_DATA) } } } \ No newline at end of file diff --git a/app/src/main/res/layout/activity_app_errors_muted.xml b/app/src/main/res/layout/activity_app_errors_muted.xml new file mode 100644 index 0000000..7491a74 --- /dev/null +++ b/app/src/main/res/layout/activity_app_errors_muted.xml @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/activity_app_errors_record.xml b/app/src/main/res/layout/activity_app_errors_record.xml index b4768bc..727bcd4 100644 --- a/app/src/main/res/layout/activity_app_errors_record.xml +++ b/app/src/main/res/layout/activity_app_errors_record.xml @@ -73,7 +73,7 @@ android:layout_gravity="center" android:gravity="center" android:lineSpacingExtra="6dp" - android:text="@string/no_errors_data" + android:text="@string/no_list_data" android:textColor="@color/colorTextDark" android:textSize="17sp" /> diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml index 23bffd7..2d788c6 100644 --- a/app/src/main/res/layout/activity_main.xml +++ b/app/src/main/res/layout/activity_main.xml @@ -387,7 +387,7 @@ android:textSize="12sp" /> @@ -409,7 +409,7 @@ android:layout_marginBottom="10dp" android:alpha="0.6" android:lineSpacingExtra="6dp" - android:text="@string/view_ignored_errors_apps_tip" + android:text="@string/view_muted_errors_apps_tip" android:textColor="@color/colorTextDark" android:textSize="12sp" /> @@ -453,7 +453,7 @@ android:id="@+id/hide_icon_in_launcher_switch" android:layout_width="match_parent" android:layout_height="wrap_content" - android:text="@string/hide_app_icon_on_desktop" + android:text="@string/hide_app_icon_on_launcher" android:textAllCaps="false" android:textColor="@color/colorTextGray" android:textSize="15sp" /> @@ -464,7 +464,7 @@ android:layout_marginBottom="10dp" android:alpha="0.6" android:lineSpacingExtra="6dp" - android:text="@string/hide_app_icon_on_desktop_tip" + android:text="@string/hide_app_icon_on_launcher_tip" android:textColor="@color/colorTextDark" android:textSize="12sp" /> @@ -474,7 +474,7 @@ android:layout_marginBottom="10dp" android:alpha="0.6" android:lineSpacingExtra="6dp" - android:text="@string/hide_app_icon_on_desktop_notice" + android:text="@string/hide_app_icon_on_launcher_notice" android:textColor="#FF5722" android:textSize="12sp" /> diff --git a/app/src/main/res/layout/adapter_app_errors_muted.xml b/app/src/main/res/layout/adapter_app_errors_muted.xml new file mode 100644 index 0000000..d3db770 --- /dev/null +++ b/app/src/main/res/layout/adapter_app_errors_muted.xml @@ -0,0 +1,67 @@ + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/dia_app_errors_display.xml b/app/src/main/res/layout/dia_app_errors_display.xml index 796644e..605b1ea 100644 --- a/app/src/main/res/layout/dia_app_errors_display.xml +++ b/app/src/main/res/layout/dia_app_errors_display.xml @@ -125,7 +125,7 @@ @@ -147,7 +147,7 @@ diff --git a/app/src/main/res/values-ja/strings.xml b/app/src/main/res/values-ja/strings.xml index 1a62648..c895700 100644 --- a/app/src/main/res/values-ja/strings.xml +++ b/app/src/main/res/values-ja/strings.xml @@ -5,13 +5,13 @@ アプリ情報 アプリをリスタート エラーの詳細 - 無視(ロックが解除されるまで) - 無視(システイムが再起動するまで) + 無視(ロックが解除されるまで) + 無視(システイムがリスタートまで) アプリを閉じる %1$s がエラー %1$s が再びエラー - システイムが再起動するまで、「%1$s」のエラーを無視します - ロックが解除されるまで、「%1$s」のエラーを無視します + システイムがリスタートするまで、「%1$s」のエラーを無視します + ロックが解除されるまで、「%1$s」のエラーを無視します 戻る エラースタックをコピーする ファイルにエクスポート @@ -31,7 +31,7 @@ すべてエクスポート すべてクリア エラー履歴記錄 - 一時的にエラーなデータレコードはありません + 一時的にデータレコードはありません 確認 キャンセル モア @@ -54,9 +54,9 @@ モジュールが有効化でした 一部の設定を変更した後、リスタートシステムして有効にするには、右上隅をクリックする必要がある場合があります。 表示設定 - デスクトップ上のアプリアイコンを非表示 - モジュールアイコンを非表示にすると、インターフェイスが閉じてデスクトップに表示されなくなります。モジュール設定は、EdXposedまたはLSPosedで検索して開くことができます。 - 注:LSPosedの「Force apps to show launcher icons」機能を必ずオフにしてください + デスクトップ上のアプリアイコンを非表示 + モジュールアイコンを非表示にすると、インターフェイスが閉じてデスクトップに表示されなくなります。モジュール設定は、EdXposedまたはLSPosedで検索して開くことができます。 + 注:LSPosedの「Force apps to show launcher icons」機能を必ずオフにしてください このモジュールは、YukiHookAPIを使用して構築できます。 \n詳細 https://github.com/fankes/YukiHookAPI モジュールが不完全に有効化でした リスタートシステムしてもよろしいですか @@ -78,10 +78,14 @@ アプリ設定テンプレートを有効にする アプリ設定テンプレートを管理する エラー履歴を表示する - エラーを無視したアプリを表示する + エラーを無視したアプリを表示する 有効にすると、エラーが発生したアプリがフォアグラウンド(使用中)の場合にのみエラーダイアログが表示されます。エラーが発生したバックグラウンドアプリではエラーダイアログは表示されませんが、すべてがに記録されます。エラー履歴。 有効にすると、エラーダイアログは、アプリで発生したエラーがメインプロセス(最初のアプリケーションインスタンスオブジェクト)にある場合にのみ表示されます。 ここでは、アプリごとに個別にエラーが発生したときにエラーダイアログを表示するかどうかを設定できます。 ここでは、システムの電源を入れてから現在までのすべてのアプリエラーレコードを確認できます。エラー履歴はリスタート後に自動的にクリアされます。レコードの表示、エクスポート、共有、およびクリアが可能です。 - ここでは、さまざまな形式のエラーを手動で無視したアプリを見つけることができます。このリストは、リスタート後に自動的にクリアされます。これらの無視されたアプリを管理し、無視リストから削除できます。 + ここでは、さまざまな形式のエラーを手動で無視したアプリを見つけることができます。このリストは、リスタート後に自動的にクリアされます。これらの無視されたアプリを管理し、無視リストから削除できます。 + エラーを無視したアプリ + 無視を解除 + 無視を全部解除 + エラーを無視したすべてのアプリを解除してもよろしいですか \ No newline at end of file diff --git a/app/src/main/res/values-zh-rCN/strings.xml b/app/src/main/res/values-zh-rCN/strings.xml index a044326..c5198c3 100644 --- a/app/src/main/res/values-zh-rCN/strings.xml +++ b/app/src/main/res/values-zh-rCN/strings.xml @@ -5,13 +5,13 @@ 应用信息 重新打开 错误详情 - 忽略(直到设备重新解锁) - 忽略(直到设备重新启动) + 忽略(直到设备重新解锁) + 忽略(直到设备重新启动) 关闭应用 %1$s 已停止运行 %1$s 屡次停止运行 - 忽略“%1$s”的错误直到设备重新解锁 - 忽略“%1$s”的错误直到设备重新启动 + 忽略“%1$s”的错误直到设备重新解锁 + 忽略“%1$s”的错误直到设备重新启动 返回 复制异常堆栈 导出到文件 @@ -31,7 +31,7 @@ 导出全部 清空全部 异常历史记录 - 暂时没有异常数据记录 + 暂时没有记录 确定 取消 更多 @@ -54,9 +54,9 @@ 模块已激活 部分设置修改后可能需要点击右上角重启系统才能生效。 显示设置 - 在桌面隐藏模块图标 - 隐藏模块图标后界面可能会被关闭,将不会再在桌面显示,你可以在 EdXposed、LSPosed 中找到模块设置并打开。 - 注意:请务必在 LSPosed 中关闭“强制显示桌面图标”功能 + 在桌面隐藏模块图标 + 隐藏模块图标后界面可能会被关闭,将不会再在桌面显示,你可以在 EdXposed、LSPosed 中找到模块设置并打开。 + 注意:请务必在 LSPosed 中关闭“强制显示桌面图标”功能 此模块使用 YukiHookAPI 构建。\n了解更多 https://github.com/fankes/YukiHookAPI 模块未完全激活,请重启系统 你确定要重启系统吗? @@ -78,10 +78,14 @@ 启用应用配置模板 管理应用配置模板 查看异常历史记录 - 查看已忽略异常的应用 + 查看已忽略异常的应用 启用后,只有发生异常的应用处于前台(正在使用中)时才会展示错误对话框,发生异常的后台应用虽然不会展示错误对话框,但是它们都会被记录到异常历史记录中。 启用后,只有应用发生的异常位于主进程(第一个 Application 实例对象)时才会展示错误对话框。 你可以在这里对每个应用发生异常时,单独配置其在发生异常时是否展示错误对话框。 在这里,你可以找到从系统开机以来到现在为止的全部应用异常记录,异常历史记录在重新启动后会自动清空,你可以对记录进行查看、导出和分享以及清空。 - 在这里,你可以找到已被你以不同形式手动忽略异常的应用,这个列表将会在重新启动后自动清空,你可以对这些已忽略的应用进行管理以及从忽略列表中移除它们。 + 在这里,你可以找到已被你以不同形式手动忽略异常的应用,这个列表将会在重新启动后自动清空,你可以对这些已忽略的应用进行管理以及从忽略列表中移除它们。 + 已忽略异常的应用 + 取消忽略 + 取消全部忽略 + 你确定要取消全部已忽略异常的应用吗? \ No newline at end of file diff --git a/app/src/main/res/values-zh-rHK/strings.xml b/app/src/main/res/values-zh-rHK/strings.xml index 5391323..28264b1 100644 --- a/app/src/main/res/values-zh-rHK/strings.xml +++ b/app/src/main/res/values-zh-rHK/strings.xml @@ -5,13 +5,13 @@ 程式情報 重新開啟 異常詳解 - 忽略(直到設備重新開屏) - 忽略(直到設備重新開機) + 忽略(直到設備重新開屏) + 忽略(直到設備重新開機) 結束程式 %1$s 已停止運作 %1$s 屢次停止運作 - 忽略“%1$s”的錯誤直到設備重新開屏 - 忽略“%1$s”的錯誤直到設備重新開機 + 忽略“%1$s”的錯誤直到設備重新開屏 + 忽略“%1$s”的錯誤直到設備重新開機 回退 複製異常堆棧 導出到副案 @@ -31,7 +31,7 @@ 導出全部 清空全部 異常歷史記錄 - 暫時沒有異常數據紀錄 + 暫時沒有紀錄 確認 取消 更多 @@ -54,9 +54,9 @@ 模組已激活 部分設置修改後可能需要點擊右上角重啟系統才能生效。 顯示設置 - 在桌面隱藏模組圖標 - 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 - 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 + 在桌面隱藏模組圖標 + 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 + 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 此模組使用 YukiHookAPI 構建。 \n了解更多 https://github.com/fankes/YukiHookAPI 模組未完全激活,請重新開機 你確定要重新開機嗎? @@ -78,10 +78,14 @@ 啟用程式配置模板 管理程式配置模板 查看異常歷史記錄 - 查看已忽略異常的程式 + 查看已忽略異常的程式 啟用後,只有發生異常的程式處於前台(正在使用中)時才會展示錯誤對話框,發生異常的後台程式雖然不會展示錯誤對話框,但是它們都會被記錄到異常歷史記錄中。 啟用後,只有程式發生的異常位於主進程(第一個 Application 實例對象)時才會展示錯誤對話框。 你可以在這裡對每個程式發生異常時,單獨配置其在發生異常時是否展示錯誤對話框。 在這裡,你可以找到從系統開機以來到現在為止的全部程式異常記錄,異常歷史記錄在重新啟動後會自動清空,你可以對記錄進行查看、導出和分享以及清空。 - 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 已忽略異常的程式 + 取消忽略 + 取消全部忽略 + 你確認要取消全部已忽略異常的程式嗎? \ No newline at end of file diff --git a/app/src/main/res/values-zh-rMO/strings.xml b/app/src/main/res/values-zh-rMO/strings.xml index 2276b14..f063cb9 100644 --- a/app/src/main/res/values-zh-rMO/strings.xml +++ b/app/src/main/res/values-zh-rMO/strings.xml @@ -5,13 +5,13 @@ 程式詳情 重新開啟 異常詳解 - 忽略(直到設備重新開屏) - 忽略(直到設備重新開機) + 忽略(直到設備重新開屏) + 忽略(直到設備重新開機) 結束程式 %1$s 已停止運作 %1$s 屢次停止運作 - 忽略“%1$s”的錯誤直到設備重新開屏 - 忽略“%1$s”的錯誤直到設備重新開機 + 忽略“%1$s”的錯誤直到設備重新開屏 + 忽略“%1$s”的錯誤直到設備重新開機 回退 複製異常堆棧 導出到副案 @@ -31,7 +31,7 @@ 導出全部 清空全部 異常歷史記錄 - 暫時沒有異常數據紀錄 + 暫時沒有紀錄 確認 取消 更多 @@ -54,9 +54,9 @@ 模組已激活 部分設置修改後可能需要點擊右上角重啟系統才能生效。 顯示設置 - 在桌面隱藏模組圖標 - 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 - 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 + 在桌面隱藏模組圖標 + 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 + 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 此模組使用 YukiHookAPI 構建。 \n了解更多 https://github.com/fankes/YukiHookAPI 模組未完全激活,請重新開機 你確定要重新開機嗎? @@ -78,10 +78,14 @@ 啟用程式配置模板 管理程式配置模板 查看異常歷史記錄 - 查看已忽略異常的程式 + 查看已忽略異常的程式 啟用後,只有發生異常的程式處於前台(正在使用中)時才會展示錯誤對話框,發生異常的後台程式雖然不會展示錯誤對話框,但是它們都會被記錄到異常歷史記錄中。 啟用後,只有程式發生的異常位於主進程(第一個 Application 實例對象)時才會展示錯誤對話框。 你可以在這裡對每個程式發生異常時,單獨配置其在發生異常時是否展示錯誤對話框。 在這裡,你可以找到從系統開機以來到現在為止的全部程式異常記錄,異常歷史記錄在重新啟動後會自動清空,你可以對記錄進行查看、導出和分享以及清空。 - 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 已忽略異常的程式 + 取消忽略 + 取消全部忽略 + 你確認要取消全部已忽略異常的程式嗎? \ No newline at end of file diff --git a/app/src/main/res/values-zh-rTW/strings.xml b/app/src/main/res/values-zh-rTW/strings.xml index 72297a4..ce5960e 100644 --- a/app/src/main/res/values-zh-rTW/strings.xml +++ b/app/src/main/res/values-zh-rTW/strings.xml @@ -5,13 +5,13 @@ 程式情報 重新開啟 異常詳解 - 忽略(直到設備重新開屏) - 忽略(直到設備重新開機) + 忽略(直到設備重新開屏) + 忽略(直到設備重新開機) 結束程式 %1$s 已停止運作 %1$s 屢次停止運作 - 忽略“%1$s”的錯誤直到設備重新開屏 - 忽略“%1$s”的錯誤直到設備重新開機 + 忽略“%1$s”的錯誤直到設備重新開屏 + 忽略“%1$s”的錯誤直到設備重新開機 回退 複製異常堆棧 導出到副案 @@ -31,7 +31,7 @@ 導出全部 清空全部 異常歷史記錄 - 暫時沒有異常數據紀錄 + 暫時沒有紀錄 確認 取消 更多 @@ -54,9 +54,9 @@ 模組已激活 部分設置修改後可能需要點擊右上角重啟系統才能生效。 顯示設置 - 在桌面隱藏模組圖標 - 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 - 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 + 在桌面隱藏模組圖標 + 隱藏模組圖標後界面可能會被關閉,將不會再在桌面顯示,你可以在 EdXposed、LSPosed 中找到模組設置並打開。 + 注意:請務必在 LSPosed 中關閉“強制顯示桌面圖標”功能 此模組使用 YukiHookAPI 構建。 \n了解更多 https://github.com/fankes/YukiHookAPI 模組未完全激活,請重新開機 你確定要重新開機嗎? @@ -78,10 +78,14 @@ 啟用程式配置模板 管理程式配置模板 查看異常歷史記錄 - 查看已忽略異常的程式 + 查看已忽略異常的程式 啟用後,只有發生異常的程式處於前台(正在使用中)時才會展示錯誤對話框,發生異常的後台程式雖然不會展示錯誤對話框,但是它們都會被記錄到異常歷史記錄中。 啟用後,只有程式發生的異常位於主進程(第一個 Application 實例對象)時才會展示錯誤對話框。 你可以在這裡對每個程式發生異常時,單獨配置其在發生異常時是否展示錯誤對話框。 在這裡,你可以找到從系統開機以來到現在為止的全部程式異常記錄,異常歷史記錄在重新啟動後會自動清空,你可以對記錄進行查看、導出和分享以及清空。 - 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 在這裡,你可以找到已被你以不同形式手動忽略異常的程式,這個列表將會在重新啟動後自動清空,你可以對這些已忽略的程式進行管理以及從忽略列表中移除它們。 + 已忽略異常的程式 + 取消忽略 + 取消全部忽略 + 你確認要取消全部已忽略異常的程式嗎? \ No newline at end of file diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 1fce34c..60d578b 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -2,16 +2,16 @@ AppErrorsTracking Added more features to app\'s crash dialog, fixed custom rom deleted dialog, the best experience to Android developer. - App\'s Info + App Info Reopen App Error Detail - Mute until device unlocks - Mute until device restarts + Mute until device unlocks + Mute until device restarts Close App %1$s has stopped %1$s keeps stopping - Ignore errors for \'%1$s\' until device is re-unlocked - Ignore errors for \'%1$s\' until device reboots + Muted errors for \'%1$s\' until device is re-unlocked + Muted errors for \'%1$s\' until device reboots Back Copy error stack Export to file @@ -30,8 +30,8 @@ Failed to export exception stack Export all Clear all - AppErrorsRecord - No errors data for now + App Errors Record + No data for now Confirm Cancel More @@ -54,9 +54,9 @@ Module is activated After some settings are modified, you may need to click the upper right corner to restart the system to take effect. Display settings - Hide app icons on desktop - After hiding the app icon, the interface may be closed and will no longer be displayed on the desktop. You can find and open the module settings in EdXposed or LSPosed. - Note: Be sure to turn off the \"Force apps to show launcher icons\" feature in LSPosed + Hide app icons on launcher + After hiding the app icon, the interface may be closed and will no longer be displayed on the launcher. You can find and open the module settings in EdXposed or LSPosed. + Note: Be sure to turn off the \"Force apps to show launcher icons\" feature in LSPosed This module is made by YukiHookAPI. \nLearn more https://github.com/fankes/YukiHookAPI Module not fully activated Are you sure you want to restart system? @@ -77,11 +77,15 @@ Show error dialogs only for main process apps Enable apps config template Management apps config template - View apps errors record - View ignored errors apps + View app errors record + View muted errors apps After enabling, the error dialog will only be displayed when the abnormal apps is in the foreground (in use). Although the abnormal background application will not display the error dialog, they will be recorded in the errors history. After enabling, the error dialog will only be displayed if the exception occurred in the application is in the main process (the first Application instance object). Here you can individually configure whether to display an error dialog when an exception occurs for each apps. - Here you can find all apps exception records since the system was turned on until now. The exception history will be automatically cleared after restarting. You can view, export, share and clear the records. - Here you can find apps that you have manually ignored exceptions in different forms. This list will be automatically cleared after restarting. You can manage these ignored applications and remove them from the ignore list. + Here you can find all apps errors records since the system was turned on until now. The exception history will be automatically cleared after restarting. You can view, export, share and clear the records. + Here you can find apps that you have manually muted errors in different forms. This list will be automatically cleared after restarting. You can manage these ignored applications and remove them from the mute list. + Muted Errors Apps + Unmute + Unmute all + Are you sure you want to unmute all apps? \ No newline at end of file