From 17e8cf8b9a20094ea48fd1a9c87ca623944e2d10 Mon Sep 17 00:00:00 2001 From: Ondrej Ruttkay Date: Fri, 8 Dec 2023 12:42:33 +0100 Subject: [PATCH 1/2] Update the FluxC hash --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 14ac7948498..ec04632da19 100644 --- a/build.gradle +++ b/build.gradle @@ -94,7 +94,7 @@ tasks.register("installGitHooks", Copy) { } ext { - fluxCVersion = 'trunk-2f304118ff4776274b83f6e34c66180cdc16eb40' + fluxCVersion = 'trunk-3f65981193242842166b7428f409fd2d290076ac' glideVersion = '4.13.2' coilVersion = '2.1.0' constraintLayoutVersion = '1.2.0' From e1eca2911a0cb820f0da478716b3d66394936739 Mon Sep 17 00:00:00 2001 From: Ondrej Ruttkay Date: Fri, 8 Dec 2023 12:43:36 +0100 Subject: [PATCH 2/2] Handle the nullable ThemeModel.demoUrl by filtering out themes that don't have a value --- .../com/woocommerce/android/model/Theme.kt | 2 +- .../android/ui/themes/ThemePickerViewModel.kt | 33 ++++++++++--------- .../ui/themes/ThemePreviewViewModel.kt | 2 +- .../android/ui/themes/ThemeRepository.kt | 3 ++ 4 files changed, 23 insertions(+), 17 deletions(-) diff --git a/WooCommerce/src/main/kotlin/com/woocommerce/android/model/Theme.kt b/WooCommerce/src/main/kotlin/com/woocommerce/android/model/Theme.kt index b40a4c59aae..365762d3a2f 100644 --- a/WooCommerce/src/main/kotlin/com/woocommerce/android/model/Theme.kt +++ b/WooCommerce/src/main/kotlin/com/woocommerce/android/model/Theme.kt @@ -5,7 +5,7 @@ import org.wordpress.android.fluxc.model.ThemeModel data class Theme( val id: String, val name: String, - val demoUrl: String + val demoUrl: String? ) fun ThemeModel.toAppModel(): Theme { diff --git a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePickerViewModel.kt b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePickerViewModel.kt index 2cf01ea3bea..7cef12ce0f5 100644 --- a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePickerViewModel.kt +++ b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePickerViewModel.kt @@ -44,23 +44,26 @@ class ThemePickerViewModel @Inject constructor( onSuccess = { result -> _viewState.update { Success( - carouselItems = result.map { theme -> - CarouselItem.Theme( - themeId = theme.id, - name = theme.name, - screenshotUrl = AppUrls.getScreenshotUrl(theme.demoUrl), - demoUri = theme.demoUrl - ) - }.plus( - CarouselItem.Message( - title = resourceProvider.getString( - string.theme_picker_carousel_info_item_title - ), - description = resourceProvider.getString( - string.theme_picker_carousel_info_item_description + carouselItems = result + .filter { theme -> theme.demoUrl != null } + .map { theme -> + CarouselItem.Theme( + themeId = theme.id, + name = theme.name, + screenshotUrl = AppUrls.getScreenshotUrl(theme.demoUrl!!), + demoUri = theme.demoUrl + ) + } + .plus( + CarouselItem.Message( + title = resourceProvider.getString( + string.theme_picker_carousel_info_item_title + ), + description = resourceProvider.getString( + string.theme_picker_carousel_info_item_description + ) ) ) - ) ) } }, diff --git a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePreviewViewModel.kt b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePreviewViewModel.kt index cf4862a731d..df2f4de580e 100644 --- a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePreviewViewModel.kt +++ b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemePreviewViewModel.kt @@ -106,7 +106,7 @@ class ThemePreviewViewModel @Inject constructor( private suspend fun Theme.prepareThemeDemoPages(): Flow> = flow { val homePage = ThemeDemoPage( - uri = demoUrl, + uri = requireNotNull(demoUrl), title = resourceProvider.getString(R.string.theme_preview_bottom_sheet_home_section), isLoaded = true ) diff --git a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemeRepository.kt b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemeRepository.kt index 3da484a3b91..f85ef94fa1f 100644 --- a/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemeRepository.kt +++ b/WooCommerce/src/main/kotlin/com/woocommerce/android/ui/themes/ThemeRepository.kt @@ -21,6 +21,7 @@ import org.wordpress.android.fluxc.store.ThemeStore.SiteThemePayload import org.wordpress.android.fluxc.store.ThemeStore.ThemeErrorType import javax.inject.Inject +@Suppress("DEPRECATION") class ThemeRepository @Inject constructor( private val themeStore: ThemeStore, private val dispatcher: Dispatcher, @@ -108,6 +109,8 @@ class ThemeRepository @Inject constructor( private suspend fun installThemeIfNeeded(themeId: String): Result { val installationResult: OnThemeInstalled = dispatcher.dispatchAndAwait( ThemeActionBuilder.newInstallThemeAction( + // The Default constructor ThemeModel() is deprecated. + // We should add a new method to ThemeStore install a theme by themeId SiteThemePayload(selectedSite.get(), ThemeModel().apply { this.themeId = themeId }) ) )