Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ollm/cordova-plugin-dynamic-color
Get the colors of the Dynamic Color theme in Android 12+
https://github.com/ollm/cordova-plugin-dynamic-color
android-dark-theme cordova cordova-android cordova-plugin dynamic-color dynamic-colors material-3 material-design material-you
Last synced: 2 months ago
JSON representation
Get the colors of the Dynamic Color theme in Android 12+
- Host: GitHub
- URL: https://github.com/ollm/cordova-plugin-dynamic-color
- Owner: ollm
- License: mit
- Created: 2023-03-12T16:09:41.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-06-21T10:32:41.000Z (over 1 year ago)
- Last Synced: 2024-11-16T16:05:51.121Z (2 months ago)
- Topics: android-dark-theme, cordova, cordova-android, cordova-plugin, dynamic-color, dynamic-colors, material-3, material-design, material-you
- Language: Java
- Homepage:
- Size: 24.4 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# cordova-plugin-dynamic-color
![cordova-dynamic-color](https://user-images.githubusercontent.com/18549191/224811654-e745d7a6-fe2d-4ef4-88d3-8883cd8ab537.jpg)
> The `DynamicColor` object provides some functions to obtain current [dynamic color](https://m3.material.io/styles/color/dynamic-color/overview) palette/colors in Android 12+ and dark theme status in Android 9+.
**Table of Contents**
- [Installation](#installation)
- [Methods](#methods)
- [Simple example of plugin usage](#simple-example-of-plugin-usage)
- [DynamicColor.isDynamicColorAvailable](#dynamiccolorisdynamiccoloravailable)
- [DynamicColor.dayNight](#dynamiccolordaynight)
- [DynamicColor.colors](#dynamiccolorcolors)
- [DynamicColor.palette](#dynamiccolorpalette)
- [DynamicColor.tintColors](#dynamiccolortintcolors)
- [DynamicColor.tintSurfaceColors](#dynamiccolortintsurfacecolors)
- [DynamicColor.mixColor](#dynamiccolormixcolor)
- [DynamicColor.mixColorElevation](#dynamiccolormixcolorelevation)
- [DynamicColor.colorsToCssVars](#dynamiccolorcolorstocssvars)
- [DynamicColor.paletteToCssVars](#dynamiccolorpalettetocssvars)
- [DynamicColor.colorsToDom](#dynamiccolorcolorstodom)
- [DynamicColor.paletteToDom](#dynamiccolorpalettetodom)
- [Events](#events)
- [dynamicColorChange](#dynamiccolorchange)## Installation
`cordova plugin add cordova-plugin-dynamic-color`
## Methods
This plugin defines global `DynamicColor` object.
Although in the global scope, it is not available until after the `deviceready` event.
```js
document.addEventListener("deviceready", onDeviceReady, false);function onDeviceReady()
{
console.log(DynamicColor);
}
```### Simple example of plugin usage
```js
document.addEventListener("deviceready", onDeviceReady, false);function onDeviceReady()
{
DynamicColor.isDynamicColorAvailable(function(available) {if(available) {
getDynamicColor();
document.addEventListener('dynamicColorChange', getDynamicColor);
}});
}
function getDynamicColor() {
DynamicColor.colors(function(colors) {
DynamicColor.colorsToDom(DynamicColor.tintSurfaceColors(colors.dayNight));
});
// Optional palette colors
DynamicColor.palette(function(colors) {DynamicColor.paletteToDom(colors.palette);
});
}
``````css
.myAppStyle
{
color: var(--md-sys-color-primary);
background: var(--md-ref-palette-neutral-variant95);
}
```### DynamicColor.isDynamicColorAvailable
Check if the DynamicColor its available in current Android device.
```js
DynamicColor.isDynamicColorAvailable(function(available) {if(available) {
}
});
```### DynamicColor.dayNight
Check current DayNight theme (check if dark theme is on or off).
```js
DynamicColor.dayNight(function(theme) {if(theme == 'light') {
} else { // theme == 'dark'
}
});
```### DynamicColor.colors
Return the DynamicColor colors
```js
DynamicColor.colors(function(colors) {colors = {
theme: 'light', // 'light' or 'dark'
light: {
primary: '#8D4E2A',
onPrimary: '#FFFFFF',
primaryContainer: '#331100',
onPrimaryContainer: '#000000',
secondary: '#765848',
onSecondary: '#FFFFFF',
secondaryContainer: '#FFDBCA',
onSecondaryContainer: '#2B160A',
tertiary: '#646032',
onTertiary: '#FFFFFF',
tertiaryContainer: '#1E1C00',
onTertiaryContainer: '#000000',
error: '#B3261E',
onError: '#FFFFFF',
errorContainer: '#F9DEDC',
onErrorContainer: '#410E0B',
outline: '#84736A',
background: '#FFFBFF',
onBackground: '#201A17',
surface: '#FFFBFF',
onSurface: '#201A17',
surfaceVariant: '#F4DED4',
onSurfaceVariant: '#52443D',
inverseSurface: '#362F2C',
inverseOnSurface: '#FBEEE9',
inversePrimary: '#FFB68F',
shadow: '#000000',
surfaceTint: '#000000',
outlineVariant: '#D7C2B9',
scrim: '#000000',
},
dark: {
...
}
dayNight: {
...
}
}});
```### DynamicColor.palette
Return the DynamicColor palette
```js
DynamicColor.palette(function(colors) {colors = {
theme: 'light', // 'light' or 'dark'
palette: {
error0: '#000000',
error10: '#410E0B',
error20: '#601410',
error30: '#8C1D18',
error40: '#B3261E',
error50: '#DC362E',
error60: '#E46962',
error70: '#EC928E',
error80: '#F2B8B5',
error90: '#F9DEDC',
error95: '#FCEEEE',
error99: '#FFFBF9',
error100: '#FFFFFF',
neutral0: '#000000',
neutral10: '#201A17',
neutral20: '#362F2C',
neutral30: '#4D4542',
neutral40: '#655D59',
neutral50: '#7D7470',
neutral60: '#998F8A',
neutral70: '#B4A9A4',
neutral80: '#D0C4BF',
neutral90: '#ECE0DB',
neutral95: '#FBEEE9',
neutral99: '#FFFBFF',
neutral100: '#FFFFFF',
neutralVariant0: '#000000',
neutralVariant10: '#241913',
neutralVariant20: '#3B2E27',
neutralVariant30: '#52443D',
neutralVariant40: '#6B5B53',
neutralVariant50: '#84736A',
neutralVariant60: '#9F8D84',
neutralVariant70: '#BBA79E',
neutralVariant80: '#D7C2B9',
neutralVariant90: '#F4DED4',
neutralVariant95: '#FFEDE6',
neutralVariant99: '#FFFBFF',
neutralVariant100: '#FFFFFF',
primary0: '#000000',
primary10: '#331100',
primary20: '#532201',
primary30: '#703715',
primary40: '#8D4E2A',
primary50: '#A9653F',
primary60: '#C87F56',
primary70: '#E7996E',
primary80: '#FFB68F',
primary90: '#FFDBCA',
primary95: '#FFEDE6',
primary99: '#FFFBFF',
primary100: '#FFFFFF',
secondary0: '#000000',
secondary10: '#2B160A',
secondary20: '#432B1D',
secondary30: '#5C4132',
secondary40: '#765848',
secondary50: '#906F5E',
secondary60: '#AC8978',
secondary70: '#C9A391',
secondary80: '#E6BEAB',
secondary90: '#FFDBCA',
secondary95: '#FFEDE6',
secondary99: '#FFFBFF',
secondary100: '#FFFFFF',
tertiary0: '#000000',
tertiary10: '#1E1C00',
tertiary20: '#343108',
tertiary30: '#4B481D',
tertiary40: '#646032',
tertiary50: '#7C7847',
tertiary60: '#97925F',
tertiary70: '#B2AD78',
tertiary80: '#CEC891',
tertiary90: '#EBE4AA',
tertiary95: '#F9F3B8',
tertiary99: '#FFFBFF',
tertiary100: '#FFFFFF'
}
}});
```### DynamicColor.tintColors
Apply the tint according to [Material Design Guidelines](https://m3.material.io/styles/color/the-color-system/color-roles#c0cdc1ba-7e67-4d6a-b294-218f659ff648), you can also use css [`color-mix`](https://developer.chrome.com/blog/css-color-mix/) to mix the surface with tint (`color-mix(in srgb, var(--md-sys-color-on-surface), var(--md-sys-color-on-surface-tint) 5%)`), but currently it's not [supported](https://caniuse.com/?search=color-mix) for many browsers.
```js
var colors = DynamicColor.tintColors(colors.light, Array onlyKeys = false);colors = {
surface: '#FFFBFF',
surface1: '#f9f2f4',
surface2: '#f6edee',
surface3: '#f2e8e8',
surface4: '#f1e6e5',
surface5: '#efe3e1',
...
}/*
--md-sys-color-surface: #FFFBFF;
--md-sys-color-surface1: #f9f2f4;
--md-sys-color-surface2: #f6edee;
--md-sys-color-surface3: #f2e8e8;
--md-sys-color-surface4: #f1e6e5;
--md-sys-color-surface5: #efe3e1;
...
*/```
- __onlyKeys__ Keys to generate tint versions, by default all keys.
### DynamicColor.tintSurfaceColors
Same as above code, but only applies to surfaces (Including background).
```js
var colors = DynamicColor.tintSurfaceColors(colors.light);colors = {
surface: '#FFFBFF',
surface1: '#f9f2f4',
surface2: '#f6edee',
surface3: '#f2e8e8',
surface4: '#f1e6e5',
surface5: '#efe3e1',
...
}/*
--md-sys-color-surface: #FFFBFF;
--md-sys-color-surface1: #f9f2f4;
--md-sys-color-surface2: #f6edee;
--md-sys-color-surface3: #f2e8e8;
--md-sys-color-surface4: #f1e6e5;
--md-sys-color-surface5: #efe3e1;
...
*/
```### DynamicColor.mixColor
Mix two colors to one acording a amount.
```js
DynamicColor.mixColor(String color1, String color2, Float amount);
```- __amount__ Amount, from 0.0 to 1.0
### DynamicColor.mixColorElevation
Mix two colors to one acording a [Material Design Guidelines Elevation](https://m3.material.io/styles/color/the-color-system/color-roles#de5b0f5e-c4a5-48ef-8670-369682e9c7b7).
```js
DynamicColor.mixColorElevation(String color1, String color2, Int elevation);
```- __elevation__ Elevation, from 1 to 5.
### DynamicColor.colorsToCssVars
Convert the colors object to css vars.
```js
DynamicColor.colors(function(colors) {var cssVars = DynamicColor.colorsToCssVars(colors.light, String prefix = '--md-sys-color');
/*
--md-sys-color-primary: #8D4E2A;
--md-sys-color-on-primary: #FFFFFF;
...
*/}
```### DynamicColor.paletteToCssVars
Convert the palette object to css vars.
```js
DynamicColor.palette(function(colors) {var cssVars = DynamicColor.paletteToCssVars(colors.palette, String prefix = '--md-ref-palette');
/*
--md-ref-palette-error0: #000000;
--md-ref-palette-error10: #410E0B;
...
*/}
```### DynamicColor.colorsToDom
Convert the colors object to css vars and insert/update it in the dom.
```js
DynamicColor.colors(function(colors) {DynamicColor.colorsToDom(colors.dark, String prefix = '--md-sys-color');
}
```### DynamicColor.paletteToDom
Convert the palette object to css vars and insert/update it in the dom.
```js
DynamicColor.palette(function(colors) {DynamicColor.paletteToDom(colors.palette, String prefix = '--md-ref-palette');
}
```## Events
### dynamicColorChange
This event is fired when any change in DayNight or DynamiColor (or both at the same time) is detected.
```js
document.addEventListener('dynamicColorChange', function(event) {event.changed = {
dayNight: true, // true if the DayNight theme have changed (dark theme turned on or off)
dynamicColor: true, // true if the DynamiColor colors/palette have changed
}if(event.changed.dayNight) {
DynamicColor.dayNight(function(theme) {
if(theme == 'light') {
} else { // theme == 'dark'
}
});
}
if(event.changed.dynamicColor) {
getDynamicColor();
}});
```