From cbabbf5c1ec7db89a2b1ab9ffbbc460236ebc744 Mon Sep 17 00:00:00 2001 From: Benoit Marty Date: Thu, 11 Feb 2021 12:56:29 +0100 Subject: [PATCH] Create a factory for JitsiWidgetProperties --- .../call/conference/JitsiCallViewModel.kt | 5 +- .../call/conference/JitsiWidgetProperties.kt | 28 +---------- .../JitsiWidgetPropertiesFactory.kt | 46 +++++++++++++++++++ 3 files changed, 49 insertions(+), 30 deletions(-) create mode 100644 vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetPropertiesFactory.kt diff --git a/vector/src/main/java/im/vector/app/features/call/conference/JitsiCallViewModel.kt b/vector/src/main/java/im/vector/app/features/call/conference/JitsiCallViewModel.kt index b3c29752d8..1525ca6dfe 100644 --- a/vector/src/main/java/im/vector/app/features/call/conference/JitsiCallViewModel.kt +++ b/vector/src/main/java/im/vector/app/features/call/conference/JitsiCallViewModel.kt @@ -24,7 +24,6 @@ import dagger.assisted.Assisted import dagger.assisted.AssistedInject import dagger.assisted.AssistedFactory import im.vector.app.core.platform.VectorViewModel -import im.vector.app.core.resources.StringProvider import im.vector.app.features.themes.ThemeProvider import org.jitsi.meet.sdk.JitsiMeetUserInfo import org.matrix.android.sdk.api.query.QueryStringValue @@ -38,7 +37,7 @@ class JitsiCallViewModel @AssistedInject constructor( @Assisted initialState: JitsiCallViewState, @Assisted val args: VectorJitsiActivity.Args, private val session: Session, - private val stringProvider: StringProvider, + private val jitsiMeetPropertiesFactory: JitsiWidgetPropertiesFactory, private val themeProvider: ThemeProvider ) : VectorViewModel(initialState) { @@ -68,7 +67,7 @@ class JitsiCallViewModel @AssistedInject constructor( val jitsiWidget = it.firstOrNull() if (jitsiWidget != null) { val ppt = widgetService.getWidgetComputedUrl(jitsiWidget, themeProvider.isLightTheme()) - ?.let { url -> JitsiWidgetProperties.fromUrl(url, stringProvider) } + ?.let { url -> jitsiMeetPropertiesFactory.create(url) } setState { copy( widget = Success(jitsiWidget), diff --git a/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetProperties.kt b/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetProperties.kt index f1af3ae052..ed63f723c8 100644 --- a/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetProperties.kt +++ b/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetProperties.kt @@ -16,35 +16,9 @@ package im.vector.app.features.call.conference -import android.net.Uri -import im.vector.app.R -import im.vector.app.core.resources.StringProvider -import org.matrix.android.sdk.api.extensions.tryOrNull -import java.net.URLDecoder - data class JitsiWidgetProperties( val domain: String, val confId: String?, val displayName: String?, val avatarUrl: String? -) { - companion object { - fun fromUrl(url: String, stringProvider: StringProvider): JitsiWidgetProperties { - val configString: String? = tryOrNull { Uri.parse(url) }?.fragment - - val configs: Map = configString?.split("&") - ?.map { it.split("=") } - ?.filter { it.size == 2 } - ?.map { (key, value) -> key to URLDecoder.decode(value, "UTF-8") } - ?.toMap() - .orEmpty() - - return JitsiWidgetProperties( - domain = configs["conferenceDomain"] ?: stringProvider.getString(R.string.preferred_jitsi_domain), - confId = configs["conferenceId"], - displayName = configs["displayName"], - avatarUrl = configs["avatarUrl"] - ) - } - } -} +) diff --git a/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetPropertiesFactory.kt b/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetPropertiesFactory.kt new file mode 100644 index 0000000000..8014e01fb2 --- /dev/null +++ b/vector/src/main/java/im/vector/app/features/call/conference/JitsiWidgetPropertiesFactory.kt @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2021 New Vector Ltd + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package im.vector.app.features.call.conference + +import android.net.Uri +import im.vector.app.R +import im.vector.app.core.resources.StringProvider +import org.matrix.android.sdk.api.extensions.tryOrNull +import java.net.URLDecoder +import javax.inject.Inject + +class JitsiWidgetPropertiesFactory @Inject constructor( + private val stringProvider: StringProvider +) { + fun create(url: String): JitsiWidgetProperties { + val configString = tryOrNull { Uri.parse(url) }?.fragment + + val configs = configString?.split("&") + ?.map { it.split("=") } + ?.filter { it.size == 2 } + ?.map { (key, value) -> key to URLDecoder.decode(value, "UTF-8") } + ?.toMap() + .orEmpty() + + return JitsiWidgetProperties( + domain = configs["conferenceDomain"] ?: stringProvider.getString(R.string.preferred_jitsi_domain), + confId = configs["conferenceId"], + displayName = configs["displayName"], + avatarUrl = configs["avatarUrl"] + ) + } +}