Skip to content

Commit

Permalink
feat: stylinh options
Browse files Browse the repository at this point in the history
  • Loading branch information
NickIliev committed Mar 23, 2020
1 parent c018d38 commit 34d8cca
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 18 deletions.
10 changes: 9 additions & 1 deletion app/ns-ui-widgets-category/tabs/styling/article.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,15 @@
> **Note:** - The integration with `nativescript-theme` and the support for custom CSS is currently under development and is on its way.
The main styling options are introduced with three specific properties that should be set on the `TabStrip` component.

- `selectedItemnColor`: Sets the text color of the selected tab strip item. Also sets the color of the tab strip icon when the icon is an icon font (`font://`).
- `unSelectedItemColor`: Sets the text color of the unselected tab strip items. Also sets the color of the tab strip icon when the icon is an icon font (`font://`).
- `highlightColor`: Sets the color of the underline for the selected tab strip item.

Those properties can be set dynamically, inline and via CSS.

<snippet id='tabs-theming-css'/>

> **Note:** Currently, we can set only the `backgroundColor`, `color`, `fontFamily`, `fontSize`, `fontStyle`, `fontWeight` and `textTransform` styling properties to the `Label` and `Image` components inside the TabStripItem. More about the usage of those properties can be found in the [Styling]({%slug styling%}#supported-css-properties) article.
> **Note:** Currently, we can set only the `backgroundColor`, `color`, `fontFamily`, `fontSize`, `fontStyle`, `fontWeight` and `textTransform` styling properties to the `Label` and `Image` components inside the TabStripItem. More about the usage of those properties can be found in the [Styling]({%slug styling%}#supported-css-properties) article. Those properties can be set inline or via CSS.
> **Note:** On iOS, the TabStripItems can not be stylied individually.
20 changes: 4 additions & 16 deletions app/ns-ui-widgets-category/tabs/styling/styling-page.css
Original file line number Diff line number Diff line change
@@ -1,19 +1,10 @@
/* >> tabs-theming-css */

Tabs.bottom-nav {
background-color: orangered;
color: gold;
font-size: 18;
}

TabStripItem.tabstripitem-active {
background-color: teal;
TabStrip {
selected-item-color: blueviolet;
un-selected-item-color: brown;
highlight-color: gold;
}

TabStripItem.tabstripitem-active:active {
background-color: yellowgreen;
}

TabContentItem.first-tabcontent {
background-color: seashell;
color: olive;
Expand All @@ -26,7 +17,4 @@ TabContentItem.third-tabcontent {
background-color: blueviolet;
color: antiquewhite;
}
Tabs TabStrip{
highlight-color: red;
}
/* << tabs-theming-css */
34 changes: 33 additions & 1 deletion app/ns-ui-widgets-category/tabs/usage/article.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,4 +4,36 @@ The `Tabs` component contains two sub-components:

<snippet id='tabs-usage-xml'/>

> **Note:** The number of `TabStripItem` components must be equal to the number of `tabContentItem` components.
> **Note:** The number of `TabStripItem` components must be equal to the number of `tabContentItem` components.on
### Dynamic Creation

To create a `Tabs` component programatically, we need to use special properties for creating each `TabStripItem`. Those properties are `title`, `iconSource` and `iconClass` (that are used to create the coresponding `Label` and `Image`).

```JavaScript
let tabs = new Tabs();
let tabStrip = new TabStrip();

let tabStripItem1 = new TabStripItem();
tabStripItem1.title = "Tab 1";
tabStripItem1.iconSource = "font://" + String.fromCharCode(charCode1);
tabStripItem1.iconClass = "far"; // e.g., FontAвесоме

let tabStripItem2 = new TabStripItem();
tabStripItem2.title = "Tab 2";
tabStripItem2.iconSource = "font://" + String.fromCharCode(charCode2);
tabStripItem2.iconClass = "far"; // e.g., FontAвесоме

let tabStripItems = [tabStripItem1, tabStripItem2];
tabStrip.items = tabStripItems;

let contentItems = [conterntItem1, contentItem2]; // where contentItem1 and 2 are the layouts/frames that holds the actual content

tabs.tabStrip = tabStrip;
tabs.items = contentItems;

let stack = new StackLayout(); // the ""simple rule
stack.addChild(tabs)
somePage.content = stack; // base example for adding the newly created Tabs to the current page
```

0 comments on commit 34d8cca

Please sign in to comment.