Theme - AppDaddy-Software-Solutions-Inc/framework-markup-language GitHub Wiki
The THEME
involves three methods to give customization and control of the application theme. A configuration setting, an event to change theme and a widget to specify a scope to selectively theme child widgets.
- Usage
- Default Scheme (light/blue)
- Theme Event
- Inline Theming
- Theme Attributes:
- Theme Playground Template
- Documentation you may find useful
- To set the application's default theme colorscheme open config.xml located the root directory set the
<BRIGHTNESS>
tolight
/dark
and<COLOR_SCHEME>
to a color then the entire theme generate a colorscheme (default is light/blue). - To change the theme you can call the event
theme
- To apply a specific color to a theme attribute for a subset of widgets within a template you can use inline themeing
Example usages:
theme('dark', 'deeppurple')
or
<VAR id='brightness' value="light" />
<BUTTON onclick="theme({brightness})', '#000FFF')" />
This applies the scoped theme on a widget and its children for overriding system theming. To utilize it wrap a THEME
widget around anything within a regular template.
Its important to note if wrapping multiple children to include a layout widget such as
<BOX>
Example:
<THEME primary="#2D476F" onprimary="#FFC800" inverseprimary="#FFC800">
<BOX>
<SWITCH value="true" />
<BUTTON type="elevated" label="Click Me" onclick="" />
</BOX>
</THEME>
<ELEMENT /> |
value= |
---|---|
brightness | "light" / "dark" |
primaryColor | Color |
primaryColorLight | Color |
primaryColorDark | Color |
accentColor | Color |
canvasColor | Color |
scaffoldBackgroundColor | Color |
bottomAppBarColor | Color |
cardColor | Color |
dividerColor | Color |
highlightColor | Color |
splashColor | Color |
selectedRowColor | Color |
unselectedWidgetColor | Color |
disabledColor | Color |
buttonColor | Color |
toggleableActiveColor | Color |
secondaryHeaderColor | Color |
cursorColor | Color |
textSelectionColor | Color |
textSelectionHandleColor | Color |
backgroundColor | Color |
dialogBackgroundColor | Color |
indicatorColor | Color |
hintColor | Color |
errorColor | Color |
Click to expand
<FML>
<VAR id="brightness" value="{THEME.brightness}" onchange="theme({brightness}, {selectedcolor})"/>
<VAR id="selectedcolor" value="{THEME.colorscheme}" onchange="theme({brightness}, {selectedcolor})" />
<BOX height="100%" width="100%">
<PADDING top="10" />
<BOX color="{THEME.background}" border="all" borderwidth="4" layout="row" halign="around" valign="center" expand="false" width="100%">
<ROW valign="center" width="200" halign="around">
<TEXT value="Brightness ({brightness})" />
<PADDING all="4">
<ICON id="brightness-icon" icon="brightness_6" size="28" color="={brightness} == 'light' ? 'amber' : 'bluegrey'"/>
</PADDING>
<LINK onclick="{brightness} == 'light' ? brightness.set('dark');animate('switch'); : brightness.set('light');animate('switch');">
<BOX width="50" height="24" layout="stack" center="true">
<POSITIONED left="0">
<BOX width="50" height="20" radius="99" color="={brightness} == 'light' ? 'yellow' : '{THEME.surfacevariant}'"/>
</POSITIONED>
<POSITIONED id="pos" left="={brightness} == 'light' ? 26 : 0" right="={brightness} == 'light' ? 0 : 26">
<BOX width="24" height="24" radius="99" color="={brightness} == 'light' ? 'amber' : 'bluegrey'" />
</POSITIONED>
</BOX>
</LINK>
</ROW>
<TEXT value="Theme Changer" style="h6"/>
<BOX expand="false" width="200">
<!-- <SWITCH color="green"/> -->
</BOX>
</BOX>
<BOX height="10">
</BOX>
<BOX height="={SYSTEM.screenheight} - 160" width="100%" layout="row" halign="around" padding="8,0,0,0">
<BOX width="25%">
<LIST data="COLORS">
<ITEM>
<PADDING all="1">
<BUTTON type="={selectedcolor} == {data.color} ? 'elevated' : 'outlined'" onclick="selectedcolor.set({data.color})" height="26">
<BOX width="110" height="26" layout="row" valign="center" halign="between">
<BOX color="{data.color}" height="20" width="32" radius="24" />
<TEXT value="{data.color}" color="={selectedcolor} == {data.color} ? {brightness} == 'light' ? 'white' : 'black' : ''" />
</BOX>
</BUTTON>
</PADDING>
</ITEM>
</LIST>
</BOX>
<BOX width="25%">
<PADDING top="20" bottom="10" left="0">
<TEXT>
Test Custom Theme Colors:
</TEXT>
</PADDING>
<SELECT id="ibrightness" value="light">
<OPTION label="light" value="light" />
<OPTION label="dark" value="dark" />
</SELECT>
<INPUT id="icolor" hint="color" value="#000FFF" />
<THEME primary="{icolor}">
<BUTTON type="elevated" onclick="{ibrightness} == 'light' || {ibrightness} == 'dark' ? selectedcolor.set({icolor});brightness.set({ibrightness}); : toast('brightness must be light or dark');" label="call theme('{ibrightness}','{icolor}')"/>
</THEME>
</BOX>
<BOX width="50%" height="100%">
<PADDING all="20">
<TEXT>
Theme Color Scheme Bindables:
</TEXT>
<PADDING top="10" />
<ROW wrap="true">
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.background}" radius="10" center="true">
<TEXT color="grey" value="background" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onbackground}" radius="10" center="true">
<TEXT color="grey" value="onbackground" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.shadow}" radius="10" center="true">
<TEXT color="grey" value="shadow" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.outline}" radius="10" center="true">
<TEXT color="grey" value="outline" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.surface}" radius="10" center="true">
<TEXT color="grey" value="surface" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onsurface}" radius="10" center="true">
<TEXT color="grey" value="onsurface" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.surfacevariant}" radius="10" center="true">
<TEXT color="grey" value="surfacevariant" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onsurfacevariant}" radius="10" center="true">
<TEXT color="grey" value="onsurfacevariant" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.inversesurface}" radius="10" center="true">
<TEXT color="grey" value="inversesurface" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.oninversesurface}" radius="10" center="true">
<TEXT color="grey" value="oninversesurface" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.primary}" radius="10" center="true">
<TEXT color="grey" value="primary" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onprimary}" radius="10" center="true">
<TEXT color="grey" value="onprimary" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.primarycontainer}" radius="10" center="true">
<TEXT color="grey" value="primarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onprimarycontainer}" radius="10" center="true">
<TEXT color="grey" value="onprimarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.inverseprimary}" radius="10" center="true">
<TEXT color="grey" value="inverseprimary" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.secondary}" radius="10" center="true">
<TEXT color="grey" value="secondary" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onsecondary}" radius="10" center="true">
<TEXT color="grey" value="onsecondary" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.secondarycontainer}" radius="10" center="true">
<TEXT color="grey" value="secondarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onsecondarycontainer}" radius="10" center="true">
<TEXT color="grey" value="onsecondarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.tertiarycontainer}" radius="10" center="true">
<TEXT color="grey" value="tertiarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.ontertiarycontainer}" radius="10" center="true">
<TEXT color="grey" value="ontertiarycontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.error}" radius="10" center="true">
<TEXT color="grey" value="error" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onerror}" radius="10" center="true">
<TEXT color="grey" value="onerror" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.errorcontainer}" radius="10" center="true">
<TEXT color="grey" value="errorcontainer" />
</BOX>
</PADDING>
<PADDING all="2">
<BOX width="140" height="40" color="{THEME.onerrorcontainer}" radius="10" center="true">
<TEXT color="grey" value="onerrorcontainer" />
</BOX>
</PADDING>
</ROW>
</PADDING>
</BOX>
</BOX>
</BOX>
<DATA id="COLORS" autoexecute="true">
<VALUE>
<![CDATA[<ROWS>
<ROW>
<color>red</color>
</ROW>
<ROW>
<color>pink</color>
</ROW>
<ROW>
<color>purple</color>
</ROW>
<ROW>
<color>deeppurple</color>
</ROW>
<ROW>
<color>indigo</color>
</ROW>
<ROW>
<color>blue</color>
</ROW>
<ROW>
<color>lightblue</color>
</ROW>
<ROW>
<color>cyan</color>
</ROW>
<ROW>
<color>teal</color>
</ROW>
<ROW>
<color>green</color>
</ROW>
<ROW>
<color>lightgreen</color>
</ROW>
<ROW>
<color>lime</color>
</ROW>
<ROW>
<color>yellow</color>
</ROW>
<ROW>
<color>amber</color>
</ROW>
<ROW>
<color>orange</color>
</ROW>
<ROW>
<color>deeporange</color>
</ROW>
<ROW>
<color>brown</color>
</ROW>
<ROW>
<color>bluegrey</color>
</ROW>
</ROWS>]]>
</VALUE>
</DATA>
<DATA id="THEMESCHEME" root="ROW" autoexecute="true">
<VALUE>
<![CDATA[<ROWS>
<ROW>
<themecolor>background</themecolor>
</ROW>
<ROW>
<themecolor>onbackground</themecolor>
</ROW>
<ROW>
<themecolor>shadow</themecolor>
</ROW>
<ROW>
<themecolor>outline</themecolor>
</ROW>
<ROW>
<themecolor>surface</themecolor>
</ROW>
<ROW>
<themecolor>onsurface</themecolor>
</ROW>
<ROW>
<themecolor>surfacevariant</themecolor>
</ROW>
<ROW>
<themecolor>onsurfacevariant</themecolor>
</ROW>
<ROW>
<themecolor>inversesurface</themecolor>
</ROW>
<ROW>
<themecolor>oninversesurface</themecolor>
</ROW>
<ROW>
<themecolor>primary</themecolor>
</ROW>
<ROW>
<themecolor>onprimary</themecolor>
</ROW>
<ROW>
<themecolor>primarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>onprimarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>inverseprimary</themecolor>
</ROW>
<ROW>
<themecolor>secondary</themecolor>
</ROW>
<ROW>
<themecolor>onsecondary</themecolor>
</ROW>
<ROW>
<themecolor>secondarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>onsecondarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>tertiarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>ontertiarycontainer</themecolor>
</ROW>
<ROW>
<themecolor>error</themecolor>
</ROW>
<ROW>
<themecolor>onerror</themecolor>
</ROW>
<ROW>
<themecolor>errorcontainer</themecolor>
</ROW>
<ROW>
<themecolor>onerrorcontainer</themecolor>
</ROW>
</ROWS>]]>
</VALUE>
</DATA>
</FML>