Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
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
1 change: 1 addition & 0 deletions changelog.d/5397.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Fix widget permission and get wiget result
Original file line number Diff line number Diff line change
Expand Up @@ -869,11 +869,11 @@ class TimelineFragment @Inject constructor(
}

private fun joinJitsiRoom(jitsiWidget: Widget, enableVideo: Boolean) {
navigator.openRoomWidget(requireContext(), timelineArgs.roomId, jitsiWidget, mapOf(JitsiCallViewModel.ENABLE_VIDEO_OPTION to enableVideo))
navigator.openRoomWidget(requireContext(), null, timelineArgs.roomId, jitsiWidget, mapOf(JitsiCallViewModel.ENABLE_VIDEO_OPTION to enableVideo))
}

private fun openStickerPicker(event: RoomDetailViewEvents.OpenStickerPicker) {
navigator.openStickerPicker(requireContext(), stickerActivityResultLauncher, timelineArgs.roomId, event.widget)
navigator.openStickerPicker(requireContext(), widgetActivityResultLauncher, timelineArgs.roomId, event.widget)
}

private fun startOpenFileIntent(action: RoomDetailViewEvents.OpenFile) {
Expand Down Expand Up @@ -1395,9 +1395,10 @@ class TimelineFragment @Inject constructor(
}
}

private val stickerActivityResultLauncher = registerStartForActivityResult { activityResult ->
private val widgetActivityResultLauncher = registerStartForActivityResult { activityResult ->
val data = activityResult.data ?: return@registerStartForActivityResult
if (activityResult.resultCode == Activity.RESULT_OK) {
// The msgType can be check to handle other widget actions
WidgetActivity.getOutput(data).toModel<MessageStickerContent>()
?.let { content ->
timelineViewModel.handle(RoomDetailAction.SendSticker(content))
Expand Down Expand Up @@ -2654,7 +2655,7 @@ class TimelineFragment @Inject constructor(
}

private fun onViewWidgetsClicked() {
RoomWidgetsBottomSheet.newInstance()
RoomWidgetsBottomSheet.newInstance(widgetActivityResultLauncher)
.show(childFragmentManager, "ROOM_WIDGETS_BOTTOM_SHEET")
}

Expand All @@ -2663,7 +2664,7 @@ class TimelineFragment @Inject constructor(
.activeRoomWidgets()
?.find { it.type == WidgetType.ElementCall }
?.also { widget ->
navigator.openRoomWidget(requireContext(), state.roomId, widget)
navigator.openRoomWidget(requireContext(), null, state.roomId, widget)
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@

package im.vector.app.features.home.room.detail.widget

import android.content.Intent
import android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.activity.result.ActivityResultLauncher
import com.airbnb.mvrx.parentFragmentViewModel
import com.airbnb.mvrx.withState
import dagger.hilt.android.AndroidEntryPoint
Expand All @@ -40,7 +42,7 @@ import javax.inject.Inject
* Bottom sheet displaying active widgets in a room.
*/
@AndroidEntryPoint
class RoomWidgetsBottomSheet :
class RoomWidgetsBottomSheet(private val widgetActivityResultLauncher: ActivityResultLauncher<Intent>) :
VectorBaseBottomSheetDialogFragment<BottomSheetGenericListWithTitleBinding>(),
RoomWidgetsController.Listener {

Expand Down Expand Up @@ -73,7 +75,7 @@ class RoomWidgetsBottomSheet :
}

override fun didSelectWidget(widget: Widget) = withState(timelineViewModel) {
navigator.openRoomWidget(requireContext(), it.roomId, widget)
navigator.openRoomWidget(requireContext(), widgetActivityResultLauncher, it.roomId, widget)
dismiss()
}

Expand All @@ -83,8 +85,8 @@ class RoomWidgetsBottomSheet :
}

companion object {
fun newInstance(): RoomWidgetsBottomSheet {
return RoomWidgetsBottomSheet()
fun newInstance(widgetActivityResultLauncher: ActivityResultLauncher<Intent>): RoomWidgetsBottomSheet {
return RoomWidgetsBottomSheet(widgetActivityResultLauncher)
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -452,7 +452,13 @@ class DefaultNavigator @Inject constructor(
activityResultLauncher.launch(intent)
}

override fun openRoomWidget(context: Context, roomId: String, widget: Widget, options: Map<String, Any>?) {
override fun openRoomWidget(
context: Context,
activityResultLauncher: ActivityResultLauncher<Intent>?,
roomId: String,
widget: Widget,
options: Map<String, Any>?
) {
if (widget.type is WidgetType.Jitsi) {
// Jitsi SDK is now for API 23+
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.M) {
Expand All @@ -470,7 +476,12 @@ class DefaultNavigator @Inject constructor(
context.startActivity(WidgetActivity.newIntent(context, widgetArgs))
} else {
val widgetArgs = widgetArgsBuilder.buildRoomWidgetArgs(roomId, widget)
context.startActivity(WidgetActivity.newIntent(context, widgetArgs))
val intent = WidgetActivity.newIntent(context, widgetArgs)
activityResultLauncher?.let {
it.launch(intent)
} ?: run {
context.startActivity(intent)
}
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,13 @@ interface Navigator {
screen: String?
)

fun openRoomWidget(context: Context, roomId: String, widget: Widget, options: Map<String, Any>? = null)
fun openRoomWidget(
context: Context,
activityResultLauncher: ActivityResultLauncher<Intent>?,
roomId: String,
widget: Widget,
options: Map<String, Any>? = null
)

fun openMediaViewer(
activity: Activity,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,8 +86,10 @@ class WidgetFragment @Inject constructor(
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
views.widgetWebView.setupForWidget(requireActivity(), checkWebViewPermissionsUseCase, this)
if (fragmentArgs.kind.isAdmin()) {
viewModel.getPostAPIMediator().setWebView(views.widgetWebView)
withState(viewModel) { state ->
if (state.status == WidgetStatus.WIDGET_ALLOWED) {
viewModel.getPostAPIMediator().setWebView(views.widgetWebView)
}
}
viewModel.observeViewEvents {
Timber.v("Observed view events: $it")
Expand Down Expand Up @@ -118,8 +120,10 @@ class WidgetFragment @Inject constructor(
}

override fun onDestroyView() {
if (fragmentArgs.kind.isAdmin()) {
viewModel.getPostAPIMediator().clearWebView()
withState(viewModel) { state ->
if (state.status == WidgetStatus.WIDGET_ALLOWED) {
viewModel.getPostAPIMediator().clearWebView()
}
}
views.widgetWebView.clearAfterWidget()
super.onDestroyView()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -77,12 +77,12 @@ class WidgetViewModel @AssistedInject constructor(

init {
integrationManagerService.addListener(this)
if (initialState.widgetKind.isAdmin()) {
widgetPostAPIHandler = widgetPostAPIHandlerFactory.create(initialState.roomId).apply {
navigationCallback = this@WidgetViewModel
}
postAPIMediator.setHandler(widgetPostAPIHandler)
// WidgetStatus is still unknown
// Nevertheless, we can create the Handler without using it later
widgetPostAPIHandler = widgetPostAPIHandlerFactory.create(initialState.roomId).apply {
navigationCallback = this@WidgetViewModel
}
postAPIMediator.setHandler(widgetPostAPIHandler)
if (!integrationManagerService.isIntegrationEnabled()) {
_viewEvents.post(WidgetViewEvents.Close(null))
}
Expand Down Expand Up @@ -248,8 +248,10 @@ class WidgetViewModel @AssistedInject constructor(
}

private fun handleWebViewLoadingSuccess(action: WidgetAction.OnWebViewLoadingSuccess) {
if (initialState.widgetKind.isAdmin()) {
postAPIMediator.injectAPI()
withState { state ->
if (state.status == WidgetStatus.WIDGET_ALLOWED) {
postAPIMediator.injectAPI()
}
}
setState { copy(webviewLoadedUrl = Success(action.url)) }
}
Expand Down