-
Notifications
You must be signed in to change notification settings - Fork 521
Dark Mode
Author credit: Thanks to @ayush0402 for writing up the initial version of this guide.
This guide explains the newly adopted convention for using colors in oppia-android and adding support for dark mode to any particular layout while keeping the code organised and strictly following the decided convention.
The approach is to split color declarations in 4 different files instead of keeping the colors at one place, promoting separation of concerns and hence improving code maintainability and understandability.
The following files have been added for maintaining the colors :
-
color_defs.xml
This file should strictly contain actual color names (irrespective of their intended use) with their hex color code declaration.
example:Don't
<color name="color_def_background_green">#90EE90</color> <color name="color_def_secondary_green">#90EE90</color> <color name="color_def_text_view_error_red">#FF0000</color>
Do
<color name="color_def_lime_green">#90EE90</color> <color name="color_def_blue">#0000FF</color>
Declarations from this file should be only used in
color_palette.xml
. -
color_palette.xml
There are two versions for this file (day/night variations). The purpose of this file is to split the colors for them to be later referenced bycomponent_colors.xml
. The color declarations in this should have a generic name and should not contain any name tied to the intended component like toolbar, edittext, textview, etec. to be used on. Also, colors should not contain "feature" based name (like add_profile_background_color). The declarations in this file should only referencecolor_defs.xml
.Don't:
<color name="color_palette_add_profile_background_color">@color/light_black</color> <color name="color_palette_text_input_layout_error_color">@color/oppia_pink</color>
Do:
<color name="color_palette_background_color">@color/light_black</color> <color name="color_palette_error_color">@color/oppia_pink</color>
You can refer to both variations of these files to see how it separates the colors.
-
component_colors.xml
This file contains the highest level of color declarations. The declarations in this file should only referencecolor_palette.xml
. It uses UI component specific names. Component colors should be shared very little outside of their respective views/fragments/activities. All the layouts/views should only reference this file for colors.
examples:<color name="component_color_shared_text_input_edit_text_cursor_color">@color/primary_text_color</color> <color name="component_color_shared_activity_toolbar_color">@color/toolbar_color</color> <!-- styles.xml --> <color name="component_color_shared_text_input_layout_text_color">@color/primary_text_color</color> <color name="component_color_shared_input_interaction_edit_text_text_color">@color/primary_text_color</color> <color name="component_color_shared_text_input_layout_background_color">@color/text_input_background_color</color> <!-- Admin Auth Activity --> <color name="component_color_admin_auth_secondary_text_color">@color/description_text_color</color> <color name="component_color_admin_auth_layout_background_color">@color/background_color</color> <!-- Add Profile Activity --> <color name="component_color_add_profile_activity_label_text_color">@color/primary_text_color</color> <color name="component_color_add_profile_activity_switch_text_color">@color/dark_text_color</color>
Note:
-
All color names should strictly follow
snake_case
naming convention.
-
All colors in
component_colors.xml
andcolor_palette.xml
should have_color
as suffix and just the opposite forcolor_defs.xml
- All color declaration must have their parent file name as prefix of their name, i.e. "
<file_name>_<color_name>
" (Look at the color name examples for better understanding.)
- Naming these colors can be bit tricky so it is suggested to take help from already exisitng colors in these files.
- The general idea is to make sure layouts reference colors only from
component_colors.xml
, which is then referencing a version ofcolor_palette.xml
based on the active theme, making sure all the color declarations are as per the conventions decided for them.
Tip: Use layout Inspector to know more about targeted views.
We suggest running the app on an API 30 Google Pixel emulator using the system-wide dark mode option from settings.
Some other skins of android might force their own version of dark mode to screens not having dark mode support yet.
Disclaimer: The current designs in the android code do not match the mocks fully because the mocks were inconsistent across various screens and also there were some UI parts where we don’t have dark-mode mocks entirely.
These rules were followed while implementing dark-mode designs in android app:
- Avoid introducing new colors in the codebase as much as possible. For example, if there are two colors
#727272
and another#737373
both of which have slight differences only, then use only one color, whichever is getting used more in general on similar screens. - Keep the UI for similar screens consistent. For example: the colors of all screens where a pin is entered for authentication like
Add Profile
,Pin Verification
,Admin Auth
, etc should have similar colors in both dark mode and light mode. - Similar views should be consistent. Best example for this is Toolbar/ActionBar. In current dark-mode designs the toolbar color is very inconsistent, so to remove any confusion we have kept the background color of all toolbars the same for dark mode (with some minor exceptions). Similarly, the divider color in
Help
screen and inOptions
screen should have similar color too. Same consistency rule applies for buttons and many other views too. - New color rule: As mentioned earlier, we tried introducing new colors as much as possible and also used consistent colors across various screens but if we had to introduce a new color on our own we did this by using light mode designs as guidelines along with keeping the contrast ratio the same. For example: for this App Version blue background color we did not have dark-mode mocks and this color is not even getting used anywhere in the app. So for this we introduced a new dark mode color by following these steps:
-
- The background color code is :
#A5D3EC
which is blue, so for dark mode we introduced#1B5879
which is similar to blue but also makes sure that the color contrast is more than required so that it passes WCAG guidelines.
- The background color code is :
- Have a look at color_def, color_palette light & dark and component_colors files.
- If you need to introduce any new color, check if you can find some similar color in the color_def file and possibly use that.
- Try to introduce similar colors for the same UI. For example: if you are using
Topic Name
somewhere then if possible try to use similar colors which have already been used for topic names in the android app. - If you are looking for an already existing view and trying to find its light/dark color code, you will need to navigate to component_colors first and find the name for the view in component_colors.xml file. For example you can look at:
- @color/color_palette_info_icon_color
- In this, we now we can find the related color_palette name, i.e., color_palette_info_icon_color. Now we can visit the color_palette file for light and dark mode, i.e.,for light mode @color/color_def_chooser_grey and for dark-mode @color/color_def_oppia_silver
- In the end, we can see that the light color is color_def_chooser_grey and dark color is color_def_oppia_silver and we can find the exact color code for both in the color_def file.
- Ensure that the naming of new colors across all files should follow the rules mentioned above.
- If any new color is getting introduced in the
color_defs.xml
file, then treat it as a red flag and keep a close eye on why it is getting introduced? Why can't any of the existing colors be used? Has this been approved by the design team? - If any new color palette is getting introduced in
color_palette.xml
keep a close eye on that to make sure that there is no similar color palette already defined incolor_palette.xml
light/dark files. If there is a similar color palette, can you rename the existing color_palette such that it can be used on existing places as well as new places? - Hardcoded-colors should only be mentioned in icons/thumbnails of
mipmap
anddrawable
folder and in thecolor_defs.xml
file.
Have an idea for how to improve the wiki? Please help make our documentation better by following our instructions for contributing to the wiki.
Core documentation
Developing Oppia
- Contributing to Oppia Android
- Bazel
- Key Workflows
- Testing
- Developing Skills
- Frequent Errors and Solutions
- RTL Guidelines
- Working on UI
- Writing Design Docs
Developer Reference
- Code style
- Background Processing
- Dark mode
- Buf Guide
- Firebase Console Guide
- Platform Parameters & Feature Flags
- Work Manager
- Dependency Injection with Dagger
- Revert & regression policy
- Upgrading target SDK version
- Spotlight Guide
- Triaging Process
- Bazel
- Internationalization
- Terminology in Oppia
- Past Events