Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Parent-PR-for-updating-targetSdkVersion-to-33-(Android-13) #18172

Merged
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
c7d15bb
Update targetSdkVersion to 33
ravishanker Mar 24, 2023
e511a76
Update About-Automattic Version
ravishanker Mar 24, 2023
26df821
Update Utils version to 3.4.0
ravishanker Mar 27, 2023
8db0d91
Remove WRITE_EXTERNAL_STORAGE from tests
irfano Mar 27, 2023
ea209eb
Use media permissions on media picker
irfano Mar 27, 2023
324c4c0
Use media permissions on media browser
irfano Mar 27, 2023
bb26d70
Update WRITE_EXTERNAL_STORAGE usage for newer APIs on advertiseImageO…
irfano Mar 27, 2023
813a253
Update FluxC version to 2.21.0
ravishanker Mar 28, 2023
e8de8bb
Update Utils library reference
irfano Mar 29, 2023
a261fd3
Update Aztec to 1.6.4
ravishanker Mar 29, 2023
d297d54
Update LoginFlow version to 1.2.0
ravishanker Mar 29, 2023
c4fe552
Update Utils version to 3.5.0
ravishanker Mar 29, 2023
b2b57e1
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
ravishanker Mar 30, 2023
11390e5
Update FluxC version to 2.22.0
ravishanker Mar 30, 2023
ac21e3c
Add all media types support to the media picker
irfano Apr 2, 2023
898b117
Migrate permissions in photo picker to Android 13
irfano Apr 3, 2023
ca3e0b5
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
irfano Apr 3, 2023
65737b2
Merge branch 'Parent-PR-for-updating-targetSdkVersion-to-33-(Android-…
irfano Apr 3, 2023
1e4f397
Add POST_NOTIFICATIONS to AndroidManifest
irfano Apr 6, 2023
3ecad02
Add NotificationsPermissionBottomSheetFragment
irfano Apr 6, 2023
c5cba1c
Update the version of WordPress-Utils library
irfano Apr 6, 2023
65b62a3
Add a function for showing notification settings of device
irfano Apr 6, 2023
4c21506
Add permission warning message to the notifications screen
irfano Apr 6, 2023
ddbac77
Add notifications permission step to blogging reminders flow
irfano Apr 6, 2023
63431aa
Make the whole notifications permission banner clickable
irfano Apr 6, 2023
fb0ece3
Prevent updating reminders in no permission case
irfano Apr 6, 2023
21f9975
Update permission_video string resource
irfano Apr 6, 2023
d14b738
Update RELEASE-NOTES
irfano Apr 6, 2023
8b50e67
Resolve "translatable="false" warning on a string
irfano Apr 6, 2023
a76ef47
Merge pull request #18183 from wordpress-mobile/android-13-media-perm…
irfano Apr 6, 2023
af470ad
Improve notifications permission flow on blogging reminders
irfano Apr 6, 2023
6ee77da
Use standard ' for blogging reminders strings
irfano Apr 6, 2023
2c83434
Update RELEASE-NOTES
irfano Apr 6, 2023
9f870dd
Update WordPress-Utils version to trunk
irfano Apr 6, 2023
3545e9c
Resolve "translatable="false" warnings on strings
irfano Apr 6, 2023
6cf91df
Merge branch 'Parent-PR-for-updating-targetSdkVersion-to-33-(Android-…
irfano Apr 6, 2023
b81f101
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
irfano Apr 6, 2023
cdfdd0b
Revert the Aztec library version to 1.6.3
irfano Apr 7, 2023
32e2a4e
Merge branch 'Parent-PR-for-updating-targetSdkVersion-to-33-(Android-…
irfano Apr 7, 2023
d26cfbb
Remove duplicated item in RELEASE-NOTES
irfano Apr 7, 2023
e1ff390
Merge pull request #18239 from wordpress-mobile/issue/17714-notificat…
irfano Apr 8, 2023
a303369
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
irfano Apr 11, 2023
b14689a
Move media permissions from debug to main AndroidManifest
irfano Apr 11, 2023
82a5d1d
Update stories version to the latest trunk
irfano Apr 11, 2023
1e15f0d
Merge pull request #18259 from wordpress-mobile/move-permissions-to-m…
ravishanker Apr 12, 2023
0d2d362
Update Utils lib version to 3.6.0
irfano Apr 12, 2023
49a798a
Update stories lib version to 2.1.0
irfano Apr 12, 2023
1ae6e66
Fix the wrong format of RELEASE-NOTES
irfano Apr 13, 2023
5debc13
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
irfano Apr 13, 2023
419e615
Update FluxC version to the latest trunk
irfano Apr 14, 2023
80be4a9
Merge branch 'trunk' into Parent-PR-for-updating-targetSdkVersion-to-…
irfano Apr 14, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Improve notifications permission flow on blogging reminders
  • Loading branch information
irfano committed Apr 6, 2023
commit af470adfb3c0c77d65a714f06784f89ace026822
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,12 @@ class BloggingReminderBottomSheetFragment : BottomSheetDialogFragment() {
if (granted) {
viewModel.onPermissionGranted()
} else {
viewModel.onPermissionDenied()
val isAlwaysDenied = Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU &&
WPPermissionUtils.isPermissionAlwaysDenied(
requireActivity(),
Manifest.permission.POST_NOTIFICATIONS
)
viewModel.onPermissionDenied(isAlwaysDenied)
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,8 @@ class BloggingRemindersViewModel @Inject constructor(

private val _bloggingRemindersModel = MutableLiveData<BloggingRemindersUiModel>()
private val _isFirstTimeFlow = MutableLiveData<Boolean>()
private val _hasNotificationsPermission = MutableLiveData<Boolean>()
private val _notificationsPermissionAlwaysDenied = MutableLiveData<Boolean>()
private var hasNotificationsPermissionState = false
private var notificationsPermissionAlwaysDeniedState = false

val uiState: LiveData<UiState> = merge(
selectedScreen,
Expand All @@ -85,7 +85,10 @@ class BloggingRemindersViewModel @Inject constructor(
this::showBloggingPromptDialog
)
Screen.NOTIFICATIONS_PERMISSION -> {
notificationsPermissionBuilder.buildUiItems(resourceProvider.getString(R.string.app_name))
notificationsPermissionBuilder.buildUiItems(
appName = resourceProvider.getString(R.string.app_name),
showAppSettingsGuide = notificationsPermissionAlwaysDeniedState
)
}
Screen.EPILOGUE -> epilogueBuilder.buildUiItems(bloggingRemindersModel)
}
Expand All @@ -99,7 +102,9 @@ class BloggingRemindersViewModel @Inject constructor(
isFirstTimeFlow == true,
this::onSelectionButtonClick
)
Screen.NOTIFICATIONS_PERMISSION -> notificationsPermissionBuilder.buildPrimaryButton(showAppSettings)
Screen.NOTIFICATIONS_PERMISSION -> {
notificationsPermissionBuilder.buildPrimaryButton(onPermissionButtonTapped)
}
Screen.EPILOGUE -> epilogueBuilder.buildPrimaryButton(finish)
}
UiState(uiItems, primaryButton)
Expand All @@ -119,8 +124,12 @@ class BloggingRemindersViewModel @Inject constructor(
_isBottomSheetShowing.value = Event(false)
}

private val showAppSettings: () -> Unit = {
_showDevicePermissionSettings.value = Event(true)
private val onPermissionButtonTapped: () -> Unit = {
if (notificationsPermissionAlwaysDeniedState) {
_showDevicePermissionSettings.value = Event(true)
} else {
_requestPermission.value = Event(true)
}
}

private fun onScreenChanged(screen: Screen) {
Expand Down Expand Up @@ -155,7 +164,7 @@ class BloggingRemindersViewModel @Inject constructor(
}
}

fun selectDay(day: DayOfWeek) {
private fun selectDay(day: DayOfWeek) {
val currentState = _bloggingRemindersModel.value!!
val enabledDays = currentState.enabledDays.toMutableSet()
if (enabledDays.contains(day)) {
Expand All @@ -167,11 +176,11 @@ class BloggingRemindersViewModel @Inject constructor(
}

fun setPermissionState(hasNotificationsPermission: Boolean, notificationsPermissionAlwaysDenied: Boolean) {
_hasNotificationsPermission.value = hasNotificationsPermission
_notificationsPermissionAlwaysDenied.value = notificationsPermissionAlwaysDenied
hasNotificationsPermissionState = hasNotificationsPermission
notificationsPermissionAlwaysDeniedState = notificationsPermissionAlwaysDenied
}

fun selectTime() {
private fun selectTime() {
_isTimePickerShowing.value = Event(true)
}

Expand Down Expand Up @@ -233,14 +242,12 @@ class BloggingRemindersViewModel @Inject constructor(
}

private fun checkPermission(): Boolean {
val hasPermission = _hasNotificationsPermission.value == true
val alwaysDenied = _notificationsPermissionAlwaysDenied.value == true
return when {
!hasPermission && alwaysDenied -> {
!hasNotificationsPermissionState && notificationsPermissionAlwaysDeniedState -> {
_selectedScreen.value = Screen.NOTIFICATIONS_PERMISSION
false
}
!hasPermission -> {
!hasNotificationsPermissionState -> {
_requestPermission.value = Event(true)
false
}
Expand Down Expand Up @@ -327,18 +334,21 @@ class BloggingRemindersViewModel @Inject constructor(
}

fun onPermissionGranted() {
if (_hasNotificationsPermission.value == false) {
if (!hasNotificationsPermissionState) {
// Permission state is changed.
_hasNotificationsPermission.value = true
_notificationsPermissionAlwaysDenied.value = false
hasNotificationsPermissionState = true
notificationsPermissionAlwaysDeniedState = false

if (_selectedScreen.value == Screen.NOTIFICATIONS_PERMISSION) {
onSelectionButtonClick(_bloggingRemindersModel.value)
}
}
}

fun onPermissionDenied() {
_hasNotificationsPermission.value = false
fun onPermissionDenied(isAlwaysDenied: Boolean) {
hasNotificationsPermissionState = false
notificationsPermissionAlwaysDeniedState = isAlwaysDenied

_selectedScreen.value = Screen.NOTIFICATIONS_PERMISSION
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,20 +14,23 @@ import org.wordpress.android.ui.utils.UiString.UiStringRes
import javax.inject.Inject

class NotificationsPermissionBuilder @Inject constructor() {
fun buildUiItems(appName: String): List<BloggingRemindersItem> {
fun buildUiItems(appName: String, showAppSettingsGuide: Boolean): List<BloggingRemindersItem> {
val title = UiStringRes(string.blogging_reminders_notifications_permission_title)

val body = UiString.UiStringResWithParams(
string.blogging_reminders_notifications_permission_description,
UiString.UiStringText(appName)
)

return listOf(
val uiItems = mutableListOf(
Illustration(drawable.img_illustration_bell_yellow_96dp),
Title(title),
Caption(UiStringRes(string.blogging_reminders_notifications_permission_caption)),
HighEmphasisText(EmphasizedText(body, false))
Caption(UiStringRes(string.blogging_reminders_notifications_permission_caption))
)
if (showAppSettingsGuide) {
uiItems.add(HighEmphasisText(EmphasizedText(body, false)))
}
return uiItems
}

fun buildPrimaryButton(onDone: () -> Unit): PrimaryButton {
Expand Down