Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fennifith/attribouter
A lightweight "about screen" library to allow quick but customizable attribution in Android apps.
https://github.com/fennifith/attribouter
about android-library android-ui gitea github gitlab material-design
Last synced: about 2 months ago
JSON representation
A lightweight "about screen" library to allow quick but customizable attribution in Android apps.
- Host: GitHub
- URL: https://github.com/fennifith/attribouter
- Owner: fennifith
- License: apache-2.0
- Created: 2018-03-07T14:17:33.000Z (almost 7 years ago)
- Default Branch: main
- Last Pushed: 2021-03-17T19:32:32.000Z (almost 4 years ago)
- Last Synced: 2024-11-13T15:05:58.353Z (2 months ago)
- Topics: about, android-library, android-ui, gitea, github, gitlab, material-design
- Language: Kotlin
- Homepage: https://jitpack.io/#me.jfenn/Attribouter
- Size: 2.6 MB
- Stars: 115
- Watchers: 9
- Forks: 12
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
Attribouter
Attribouter is a lightweight "about screen" for Android apps, built for developers to easily credit a project's contributors & dependencies while matching the style of their app. It ships with the ability to fetch metadata directly from GitHub, GitLab, or Gitea (see: git-rest-wrapper), allowing contributors and licenses to be updated or modified without explicit configuration.
### Screenshots
| Contributors | Contributor | Licenses | License | Night Theme |
|--------------|-------------|----------|---------|-------------|
| ![img](./.github/images/attribouter-contributors.png?raw=true) | ![img](./.github/images/attribouter-contributor.png?raw=true) | ![img](./.github/images/attribouter-licenses.png?raw=true) | ![img](./.github/images/attribouter-license.png?raw=true) | ![img](./.github/images/attribouter-night.png?raw=true) |### APK
A demo apk of the sample project can be downloaded [here](../../releases/).
## Usage
This library is published on [JitPack](https://jitpack.io), which you can add to your project by copying the following to your root build.gradle at the end of "repositories".
```gradle
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
```To add the dependency, copy this line into your app module's build.gradle file.
```gradle
implementation 'me.jfenn:Attribouter:0.1.8'
```### Starting an Activity
This is pretty simple.``` kotlin
attribouterActivity {
withFile(R.xml.attribouter)
withTheme(R.style.AttribouterTheme_DayNight)
withGitHubToken("abc123")
}
```Java
Attribouter.from(context)
.withFile(R.xml.attribouter)
.withTheme(R.style.AttribouterTheme_DayNight)
.withGitHubToken("abc123")
.show();### Creating a Fragment
This is also pretty simple.``` kotlin
val fragment = attribouterFragment {
withFile(R.xml.attribouter)
withTheme(R.style.AttribouterTheme_DayNight)
withGitHubToken("abc123")
}
```Java
Attribouter.from(context)
.withFile(R.xml.attribouter)
.withTheme(R.style.AttribouterTheme_DayNight)
.withGitHubToken("abc123")
.show();---
**When using the fragment** with `R.style.AttribouterTheme_DayNight` (the default theme value), be sure that your activity also [uses a dark theme](https://developer.android.com/guide/topics/ui/look-and-feel/darktheme) in the `-night` configuration, or you will have problems with text contrast (the fragment does not have a background, so the parent activity's window background will be drawn behind it). You can also call `withTheme(R.style.AttribouterTheme)` (light) or `withTheme(R.style.AttribouterTheme_Dark)` to change this behavior.
## Things to Note
### Request Limits
This library does not use an auth key for any REST APIs by default. It does cache data to avoid crossing GitHub's [rate limits](https://developer.github.com/v3/rate_limit/), but if your project has more than a few contributors and libraries *or* you want it to have access to a private repository, you will need to provide an auth token by calling `withGitHubToken(token)` on your instance of `Attribouter`. For GitLab/Gitea instances, tokens can be provided per-hostname - for example, `withToken("code.horrific.dev", token)`.
_Be careful not to include these token with your source code._ There are other methods of providing your token at build-time, such as using a [BuildConfig field](https://developer.android.com/studio/build/gradle-tips#share-custom-fields-and-resource-values-with-your-app-code) with an environment variable, that can prevent this from being an issue. These tokens aren't especially dangerous without any scopes/permissions, but GitHub will automatically deactivate them if they show up in any commits/files on their services, which could cause problems for Attribouter.
### Configuration
By default, Attribouter will use the configuration file at [res/xml/attribouter.xml](./attribouter/src/main/res/xml/attribouter.xml). You can either name your configuration file "attribouter.xml" to override the resource, or name it differently and call `withFile(R.xml.[name])` on your instance of `Attribouter` instead.
The configuration file consists of a single root element, ``, with many child elements that can be placed any amount of times in any order, the same as views in a layout file. These elements, called "wedges" in this library for no apparent reason, are created by Attribouter and added to the page in the order and hierarchy that they are defined in. To create your configuration file, you can either use the [file from the sample project](./app/src/main/res/xml/about.xml) as a template or use [the documentation](https://jfenn.me/projects/attribouter/wiki) to write your own.
### Proguard / Minification
For those using the R8 compiler, Attribouter's [proguard rules](./attribouter/consumer-rules.pro) should be conveniently bundled with the library already - otherwise, you will need to add them to your app's `proguard-rules.pro` file yourself to prevent running into any issues with `minifyEnabled` and the like.
Unfortunately, Attribouter still doesn't behave well with `shrinkResources`, as the compiler cannot detect references from Attribouter's config file and will exclude them from compilation. There is a [workaround](https://developer.android.com/studio/build/shrink-code#shrink-resources) to this, however - create a `` tag somewhere in your project, and specify `tools:keep="@{resource}"` for all of the strings and drawables referenced by your config file. For all of Attribouter's own resources, this has already been done - and if you are not referencing any other resources in your configuration, then there shouldn't be an issue.
## Used in
- [Lawnchair Launcher](https://github.com/LawnchairLauncher/Lawnchair)
- [EtchDroid](https://github.com/EtchDroid/EtchDroid)
- [Status](https://github.com/fennifith/Status)
- [Alarmio](https://github.com/fennifith/Alarmio)If you're using Attribouter in your project, feel free to reach out / make a PR to add it to this list!
## How to Contribute
I try to maintain my libraries to meet the needs of all their users - so, to that extent, most contributions will be accepted so long as they represent some kind of functional improvement. I'd much prefer to work together and resolve an issue than turn any genuine effort away. To that end, **if you need help with this process, have any questions or confusion, or want to get feedback before a contribution, please don't hesitate to get in touch.** (either [discord](https://discord.jfenn.me) or [email](mailto:[email protected]) work fine)
This repository has two persistent branches: `main` and `develop` - of the two, most pull requests should be made to the latter. `main` will always contain the source code of the current stable release, so any new changes should be merged into `develop` first. The exception to this is any changes to metadata: the README, documentation, code of conduct, etc. - since these don't affect the compiled program, it makes sense to merge these into `main` immediately, unless they are tied to a change in functionality (changes in a new version of the library, for example).
### Example contributions
- **Development:** Developers can help Alarmio by fixing bugs, implementing features, or helping to debug & research new issues. I'm hoping to write a complete guide to this process in the future - for now, please refer to [CONTRIBUTING.md](./.github/CONTRIBUTING.md).
- **Design:** Attribouter should be intuitive and accessible to a wide variety of users - suggestions to improve certain interfaces are always welcome. This includes compatibility with screen readers, problems with contrast / color blindness, and the sizing/positioning of touch targets in the UI - many of which are shamefully untested in its present state.
- **Localization:** If Attribouter doesn't have support for your fluent language(s), please consider translating it! Most in-app text is stored in [strings.xml](./attribouter/src/main/res/values/strings.xml) - this file should be copied to ../values-{lang}/strings.xml when translated. (this is an absurdly concise explanation - if this isn't clear, simply sending us translations in a new issue or email is perfectly fine!)
- **Documentation:** Writing guides and explanations of how Attribouter works, how to use it, and how to contribute to it can go a long way to ensuring its usefulness and stability in the future. Whether this involves an update to the README, a tutorial for users and contributors, or adding Javadocs & comments to undocumented parts of the codebase - anything is valid!## Acknowledgements
Huge thanks to [everyone that's helped with this library](https://github.com/fennifith/Attribouter/graphs/contributors), directly or otherwise!
Also, mega props to [Kevin Aguilar](https://twitter.com/kevttob) and [221 Pixels](https://221pxls.com/) for helping improve the library's design & interface.
### Development
- [@fennifith](https://github.com/fennifith) (me)
- [@rroyGit](https://github.com/rroyGit)
- [@gcantoni](https://github.com/gcantoni)
- [@divadsn](https://github.com/divadsn)
- [@jahirfiquitiva](https://github.com/jahirfiquitiva)### Design
- [@221pxls](https://twitter.com/221pxls)