Skip to content

feat(KMP-6): move home tab icons and strings into shared resources#176

Open
js-jasinski wants to merge 6 commits into
matejdro:mainfrom
js-jasinski:feat/KMP-6-shared-resources
Open

feat(KMP-6): move home tab icons and strings into shared resources#176
js-jasinski wants to merge 6 commits into
matejdro:mainfrom
js-jasinski:feat/KMP-6-shared-resources

Conversation

@js-jasinski

Copy link
Copy Markdown

The Problem

The home screen's tab icons and labels lived in the Android source set, so the shared home screen couldn't show its tabs on iOS.

Solution

  • move the 4 tab icons and 4 tab strings into the module's shared Compose resources
  • build the tab list in shared code from those resources (Res.drawable.* / Res.string.*)
  • drop the temporary tabs parameter added in KMP-5

Developer Notes

  • Android looks and works the same; only where the icons/strings are loaded from changed.
  • The shared tab list is wrapped in remember, so it isn't rebuilt on every redraw.
  • watches.xml is kept in the Android source set as well, because the Tools screen's button needs it as a drawable resource id

…ugin

Introduces a `library-kmp-module` convention plugin in buildSrc so modules can
target Android and iOS with Compose Multiplatform. Uses the AGP
`com.android.kotlin.multiplatform.library` plugin (avoids the
kotlin.android <-> kotlin.multiplatform conflict) and gates iOS targets to macOS.
Converts common-navigation to a Kotlin Multiplatform module via the
library-kmp-module convention.
Converts home/ui to a Kotlin Multiplatform module. All existing code moves to the
Android source set unchanged, and the shared source set is left empty, so iOS
compiles with nothing in it yet.

- switch home/ui to the multiplatform module convention
- move all sources and resources into androidMain, with no code changes
- apply the Metro, KSP and serialization plugins directly
- run showkase and the navigation compiler through kspAndroid
- keep the Accompanist permissions opt-in on the Android source set only
- drop the unused parcelize plugin
Moves the home screen's content and its navigation bar/rail into the shared source
set so the home screen's visuals run on both Android and iOS.

- move HomeScreenContent and the nav bar/rail into commonMain
- make it data-driven over a list of tabs (tab + icon + label) so it no longer
  depends on Android resources
- build that tab list from Android resources in the Android HomeScreen wrapper
- keep the kotlinova screen wrapper, window-size check and previews on Android
- add Compose Multiplatform material3 and foundation to commonMain
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant