Supernova is a design system platform that manages your assets, tokens, components and allows you to write spectacular documentations for your entire teams. And because you found your way here, you are probably interested in its most advanced functionality - automatic hand-off of design and development assets, tokens and data in general. To learn everything Supernova, please check out our developer documentation
The Android exporter allows you to produce production-ready code for all product styles (such as colors) defined inside your design system in such a way that you can immediately use them to style your application elements. Specifically, this exporter automates the coding of:
- Color definitions
- Text Styles
- Fonts
- Radii
- Measures
The exporter will generate a file per style type. Here's an example of the exporter ouput for a single 11 Regular Italic
text style:
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="_11RegularItalic">
<item name="android:textSize">11sp</item>
<item name="android:letterSpacing">0.3</item>
<item name="android:fontFamily">@font/roboto_regular</item>
<item name="android:textStyle">normal</item>
</style>
</resources>
A corresponding font/roboto.xml file will be created:
<?xml version="1.0" encoding="utf-8"?>
<font-family xmlns:app="http://schemas.android.com/apk/res-auto">
<font
app:fontStyle="normal"
app:fontWeight="400"
app:font="@font/roboto_regular" />
</font-family>
Note: exporter doesn't provide required font files (.ttf, .otf). Please, download all necessary font files from your Design System Management system or Google Fonts service. After that, name them accordingly and put next to the corresponding font XML files.
For example above, a Roboto Regular font needs to be downloaded from https://fonts.google.com/, named as roboto_regular.ttf and placed next to font/roboto.xml file.
You can generate all production ready-code either manually using Supernova's VS Code extension, or automate your code delivery pipeline using Supernova Design Continuous Delivery.
Once you have run the exporter against your design system, you can start using the code in your codebase right away. Here are a few examples of how you can use the output of the Android exporter:
<TextView
style="@style/_11RegularItalic"
android:id="@+id/text_home"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginStart="8dp"
android:layout_marginTop="8dp"
android:layout_marginEnd="8dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
In order to make the Supernova Android exporter available for your organization so you can start generating code from your design system, please follow the installation guide in our developer documentation.
To build and contribute, there are a few steps to get started:
- Clone the repository
cd ~/Developer/ git clone https://github.com/Acornsgrow/exporter-android.git
- Set up the
upstream
remote just in case you need to update the forkgit remote add upstream https://github.com/Supernova-Studio/exporter-android.git
- Verify the upstream repository is correct. The command and example output is below:
Output
git remote -v
origin git@github.com:Acornsgrow/exporter-android.git (fetch) origin git@github.com:Acornsgrow/exporter-android.git (push) upstream https://github.com/Supernova-Studio/exporter-android.git (fetch) upstream https://github.com/Supernova-Studio/exporter-android.git (push)
- Checkout to
main
and make sure it's up-to-dategit checkout main && git pull
- Install all
npm
packages and build the JSnpm install && npm run build
- Open VS Code and install the Supernova extension
- Supernova Documentation → Building Exporters 101 → Overview
- Install VS Code Supernova Extension — VS Extension Store URL | Install
- Configure the extension
- In a web browser, login to Supernova
- Generate an API token
- Go to Profile Settings in the top profile menu
- Go to the Authentication tab
- Click on "Generate Token"
- Give the token a recognizable name (e.g.
Development Token
) - Click "Confirm"
- Copy the generated Token value and store it in a secure place, such as a 1Password vault
- Once it is copied and stored securely, you can safely close the dialog
- Return to VS Code and open the Command Palette
- Run the following command and paste the API token you generated in the previous step and press
Enter
⏎> Supernova: Supernova Log In
- Open the Supernova Extension panel by clicking its icon in the leftside rail bar
- Click "Select design system"
- Follow the prompts and select the correct design system and brand.
- Run the exporter by running the following command in the Command Palette, or by clicking the "▷" in the Supernova Extension panel
> Supernova: Run Exporter
- Verify the exporter ran properly by checking the "Output" panel, and by inspecting the
.build
folder
In order to faciliate easy communication and speed up delivery of fixes and features for this exporter, we require everyone to log all issues and feature requests through the issue tracking of this repository.
Please read through the existing issues before you open a new issue! It might be that we have already discussed it before. If you are sure your request wasn't mentioned just yet, proceed to open a new issue and fill in the required information. Thank you!
If you have an idea for improving this exporter package or want a specific issue fixed quickly, we would love to see you contribute to its development!
There are multiple ways you can contribute, so we have written a contribution guide that will walk your through the process. Any pull requests to this repository are very welcome.
Would love to help us build more but maybe need a little bit of support? Join our community and drop us a message, we will support any of your wild ideas!
This exporter is distributed under the MIT license. We absolutely encourage you to clone it and modify it for your purposes, so it fits the requirements of your stack. If you see that you have created something amazing in the process that others would benefit from, we strongly recommend you consider publishing it back to the community as well.
- To learn more about Supernova, go visit our website
- To join our community of fellow developers where we try to push what is possible with design systems and code automation, join our community discord
- To understand everything you can do with Supernova and how much time and resources it can save you, go read our product documentation
- Finally, to learn everything about what exporters are and how you can integrate with your codebase, go read our developer documentation
We are developing and maintaining exporters for many major technologies. Here are all the official exporters maintained by Supernova:
- iOS Token & Style Exporter
- iOS Localization Exporter
- Android Token & Style Exporter
- React Token & Style Exporter
- Flutter Token & Style Exporter
- Angular Token & Style Exporter
- Typescript Token & Style Exporter
- CSS Token & Style Exporter
- LESS Token & Style Exporter
- SCSS Token & Style Exporter
- Style Dictionary Exporter
Additionally, you can also use asset exporters for all major targets, enjoy!:
- SVG Asset Exporter
- PDF Asset Exporter
- PNG Asset Exporter
- iOS Asset Catalogue Exporter
- React Native Asset Exporter
- Android Asset Exporter
- Flutter PNG Asset Exporter
- Flutter SVG Asset Exporter
To browse all exporters created by our amazing community, please visit the Supernova Exporter Store.