google / accompanist

A collection of extension libraries for Jetpack Compose
https://google.github.io/accompanist
Apache License 2.0
7.46k stars 599 forks source link
android-library jetpack-compose

Accompanist logo

Accompanist is a group of libraries that aim to supplement Jetpack Compose with features that are commonly required by developers but not yet available.

Accompanist is a labs like environment for new Compose APIs. We use it to help fill known gaps in the Compose toolkit, experiment with new APIs and to gather insight into the development experience of developing a Compose library. The goal of these libraries is to upstream them into the official toolkit, at which point they will be deprecated and removed from Accompanist.

For more details like, why does this library exist? Why is it not part of AndroidX? Will you be releasing more libraries? Check out our Accompanist FAQ.

Compose versions

Each release outlines what version of the Compose UI libraries it depends on. We are currently releasing multiple versions of Accompanist for the different versions of Compose:

Compose 1.0 (1.0.x)Maven Central
Compose 1.1 (1.1.x)Maven Central
Compose UI 1.2 (1.2.x)Maven Central
Compose UI 1.3 (1.3.x)Maven Central
Compose UI 1.4 (1.4.x)Maven Central
Compose UI 1.5 (1.5.x)Maven Central
Compose UI 1.6 (1.6.x)Maven Central
Compose UI 1.7 & 1.8 (1.7.x)Maven Central

For stable versions of Compose, we use the latest stable version of the Compose compiler. For non-stable versions (alpha, beta, etc), we use the latest compiler at the time of release.

:warning: Ensure you are using the Accompanist version that matches with your Compose UI version: If you upgrade Accompanist, it will upgrade your Compose libraries version via transitive dependencies.

Libraries

šŸ“« Permissions

A library that provides Android runtime permissions support for Jetpack Compose.

šŸ–Œļø Drawable Painter

A library which provides a way to use Android Drawables as Jetpack Compose Painters.

šŸ“œ Adaptive

A library providing a collection of utilities for adaptive layouts.

ā¬‡ļø Swipe to Refresh (Deprecated)

See our Migration Guide for migrating to PullRefresh in Compose Material.

šŸŽØ AppCompat Theme Adapter (Deprecated)

See our Migration Guide for migrating to the new artifact in Accompanist.

šŸ“– Pager (Deprecated)

See our Migration Guide for migrating to Pager in Compose.

šŸŒŠ Flow Layouts (Deprecated)

See our Migration Guide for migrating to FlowLayout in Compose.

šŸ§­āœØNavigation-Animation (Deprecated)

See our Migration Guide for migrating to using built in support for animations in Jetpack Navigation Compose.

šŸ§­šŸŽØļø Navigation-Material (Deprecated)

See our Migration Guide for migrating to using built in material-navigation support.

ā³ Placeholder (Deprecated)

A library that provides easy-to-use modifiers for displaying a placeholder UI while content is loading.

šŸ« System UI Controller (Deprecated)

We recommend migrating to edge to edge. See our Migration Guide for more details.

šŸŽØ AppCompat Theme Adapter (Deprecated)

A library that enables the reuse of AppCompat XML themes, for theming in Jetpack Compose.

šŸŽØ Material Theme Adapter (Deprecated)

A library that enables the reuse of MDC-Android Material 2 XML themes, for theming in Jetpack Compose.

šŸŽØ Material 3 Theme Adapter (Deprecated)

A library that enables the reuse of MDC-Android Material 3 XML themes, for theming in Jetpack Compose.

šŸŒ Web (Deprecated)

A wrapper around WebView for basic WebView support in Jetpack Compose.

šŸ—œ Test Harness (Deprecated)

Utilities for testing Compose layouts.

šŸ“ Insets (Deprecated & Removed)

See our Migration Guide for migrating to Insets in Compose.


Future?

Any of the features available in this group of libraries may become obsolete in the future, at which point they will (probably) become deprecated.

We will aim to provide a migration path (where possible), to whatever supersedes the functionality.

Snapshots

Snapshots of the current development version of Accompanist are available, which track the latest commit. See here for more information.


Why the name?

The library is all about adding some utilities around Compose. Music composing is done by a composer, and since this library is about supporting composition, the supporting role of an accompanist felt like a good name.

Contributions

Please contribute! We will gladly review any pull requests. Make sure to read the Contributing page first though.

License

Copyright 2020 The Android Open Source Project

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

    https://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.