Skip to content
team-nimblehq edited this page Jul 4, 2022 · 6 revisions

Welcome to the android-templates wiki!

This repository generates a new project based on our preferences, by running a simple script.

Example: kscript new_project.kts package-name=co.myproject.example app-name="My Project"

This script must include all essentials by default, while optional features can be appended with flags. To prevent this repository from becoming a dumping playground, features can be rejected too.

Planning to contribute? Let's have a look at the criteria:

How do we decide if a feature is essential? πŸ‘

  • It is always implemented in the projects we've worked on.
  • It allows developers to avoid boilerplate setup, maintain the code quality and have good experience for themselves.
  • It is a Google recommended component.

How do we decide if a feature is optional? 🚩

  • It is regularly implemented in the project's we've worked on.
  • It is an alternative to a newer dominant option.

How do we decide if a feature is rejected? πŸ‘Ž

  • It is barely implemented in the project's we've worked on due to being a specific project requirement.
  • It has been replaced completely by a newer dominant option.

Let's have a look at some examples πŸ”Ž

Essential:

  • Timber: A logging library which is always used in all the projects we've worked on.
  • Firebase App Distribution: Continuous delivery always requires a boilerplate setup.
  • Detekt: Code smell analysis is important to maintain code quality.
  • Hilt: Dependency injection provides a good developer experience.
  • Navigation Component: A suite of libraries for in-app navigation which is recommended by Google.

Optional:

  • RxPermissions: Permissions powered by RxJava are regularly used, but not every project needs it.
  • Bitrise: A CI/CD provider which is regularly used, but GitHub Actions is our default choice.

Rejected:

  • Skeleton Layout: A progress indicator with visual feedback, it has a specific use case that is barely used.
  • Mockito: A mocking framework which is barely used, because Mockk is our default choice.

Keep in mind, the features are based on our team's requirements. In case the client has different requirements or requests, we can consider adding them as optional features if they occur regularly.

Please note that the above examples are not definitive as new and existing libraries keep on emerging and evolving.

Before an issue can be worked on, it must go through our voting process.

How do we vote on an issue? πŸ—³

  • It is the responsibility of the RFC creator to label their proposed change as essential or optional.
  • If we agree with the RFC, we must react with πŸ‘.
    • If there are 3 x πŸ‘, then the issue is approved.
  • If we disagree with the RFC, we must react with πŸ‘Ž and leave a comment explaining why.
    • If there are 3 x πŸ‘Ž, then the issue is rejected.
  • If there are differing opinions, then the repository maintainer must resolve it.

Still unsure where your future contribution belongs? Let's discuss! πŸš€

Clone this wiki locally