Skip to content

Commit

Permalink
Migrate docs from the UI section
Browse files Browse the repository at this point in the history
Signed-off-by: Florian Hotze <[email protected]>
  • Loading branch information
florian-h05 committed Jan 26, 2024
1 parent f97fd9a commit 569c886
Show file tree
Hide file tree
Showing 18 changed files with 283 additions and 252 deletions.
181 changes: 181 additions & 0 deletions mainui/about.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
---
layout: documentation
title: Help & About Page
---

# Help & About Page

<!-- START MAINUI SIDEBAR DOC - DO NOT REMOVE -->
This page shows general information of your openHAB configuration and allows to configure some client related configuration, including:

- UI appearance (theming, color scheme etc.)
- **Web Audio Sink** support
- Setting up the **UI Command Item**

<!-- END MAINUI SIDEBAR DOC - DO NOT REMOVE -->

[[toc]]

## Top Section

![img.png](../images/about/about-top-section.png)

- Version: shows the currently installed version of openHAB
- Links to the official openHAB Website, the openHAB Documentation and the Community Forum

## Technical Information

This section is collapsed by default and can be opened by clicking on it which then reveals the

- Configuration folder on the server
- User data folder on the server
- Logs folder on the server
- Operating System openHAB is running on
- Java Runtime openHAB is running on
- number of processors and memory

Clicking on View Details opens up a popup window that contains very detailed information like

- Runtime information
- Locale (language)
- System information including memory information
- A list of all installed bindings
- Client information including device information, client settings (see also the below section), screen information, theme, user agent information.

The content can be easily copied with the copy button on the top to provide it as additional information when asking questions in the community.

## Appearance (for this device only)

This section allows to have different appearance settings _per_ device.

- **Theme**: Selects the theme for that device
- Auto: tries to detect the client type
- Android
- iOS
- Desktop

![theme-selection.png](../images/about/theme-selection.png)

- **Dark mode** setting
- Auto: uses the default mode
- Light-Mode
- Dark-Mode

![dark-mode.png](../images/about/dark-mode.png)

- **Navigation bars style**: inverts the colors in the navigation bar

![navbar-style.png](../images/about/navbar-style.png)

## Miscellaneous settings

- **Simple navigation bar on home page**: When switching it on, it means the navigation bar will look the same even whether you're at the top of the page or not - you won't have the alternate look with the date.
The first image depicts the normal setting (off), the second image shows it switched off

![simple-nav-off.png](../images/about/simple-nav-off.png) ![simple-nav-on.png](images/simple-nav-on.png)

- **Standard home page background color**: This only relates to the light color scheme.
The background color will be the same as the regular pages you can show from e.g. the sidebar, which is a kind of gray instead of white.
The first image depicts the normal white setting (off), the second image shows it switched off with the gray setting.

![bg-white-setting.png](../images/about/bg-white-setting.png) ![bg-gray-setting.png](images/bg-gray-setting.png)

- **Disable card expansion animations**: Disables the animations when expanding a widget card.
- **Disable page transition animations**: Disables the transitions when switching from one page to the other.

## Web Audio Sink

Main UI implements a web audio sink which allows the openHAB server to play audio through the web browser.

To enable web audio sink support for a client, turn on the **Enable Web Audio sink support** option on the **Help & About** page.
As it is setting specific to your browser environment, web audio support has to be enabled for every client where it should be used.

Please note that due to limitations in Safari (and possibly Chrome as well), a user interaction is required after the first audio stream has been sent to actually play it.
This means, that after opening Main UI, the first audio that should be played on the web audio sink is only player after the user interacts with Main UI in any way (i.e. touching the screen is enough).
For subsequent audio playback, that is not required anymore and the audio is played immediately.

Please also note that you cannot address a particular web audio-enabled device.
When you play a sound on web audio, it will be played on all devices where web audio is enabled.

Web audio sinks can be used for example on wall-mounted tablets to make announcements using a [text-to-speech (TTS) engine]({{base}}/configuration/multimedia.html#text-to-speech) and play notification or alarm sounds.

For more information about audio sinks as well as audio and voice actions, please refer to the [multimedia configuration docs]({{base}}/configuration/multimedia.html), where you will also find examples including UI-based rules and Blockly.

### Testing Web Audio

To test if it works play some static content that comes with openHAB in the /sounds dir using an openHAB console command.
Use [openHABs console]({{base}}/administration/console.html#using-the-console) or just run the following from the Linux shell:

> openhab-cli console
and then enter the following command:

```text
openhab> audio play webaudio barking.mp3
```

If you have a dog that gets triggered by barking you may opt for playing `doorbell.mp3` instead.
If you play `doorbell.mp3` your dog will then probably play its own barking audio sound. 😉

Here are some useful actions available to rules in which you can specify webaudio as sink, see:

- [playSound]({{base}}/configuration/multimedia.html#actions-2)

```text
playSound("webaudio", "barking.mp3")
```

- [say]({{base}}/configuration/multimedia.html#actions-3)

```text
say("Hello world!", "voicerss:enUS", "webaudio")
```

You can also configure webaudio as sink when creating rules in the UI:

![play-rule.png](../images/about/play-rule.png)

or using it in a blockly rule:

![webaudio-blockly.png](../images/about/webaudio-blockly.png)

## UI Command Item

Main UI can be controlled from the openHAB server by setting up a so-called UI command Item.

Similarly to web audio support, this is a setting specific to your local browser environment, so you have to define the UI command Item for each client, which also allows you to different UI command Items for different clients.
To set up an Item as the UI command Item on your device, first create a particular Item of type `String`, then open the **Help & About** page from the menu and select an Item for the **Listen for UI command to** option.

The command Item has to be a `String` Item.
The UI is listening for commands to that Item, and if an Item command is a valid command string, the UI executes the given command.

Currently, the supported commands are:

- `navigate:$path`:
Navigate to a given `$path`, e.g. `navigate:/locations` to navigate to the **Locations** tab of the home page or `navigate:/page/my_custom_page` to navigate to a page with the ID `my_custom_page`.
For example, you can use this to open a video camera page of the door automatically when the doorbell is rung.
- `popup:$target`, `popover:$target` and `sheet:$target`:
Open a `$target`, which can be a page (`$target` is `page:` + a page ID), a custom widget (`$target` is `widget:` + widget ID) or any [`oh-` component]({{base}}/ui/components/) (`$target` is the component name), in a popup, popover or sheet.

For example, to open `oh-clock-card` inside a popup, send `popup:oh-clock-card` to the UI command Item.
- `notification:$text:$title:$subtitle:$titleRight:$closeTimeout`:
Display a notification inside the UI:
The `$text` parameter is mandatory, all other parameters are optional.
`$closeTimeout` is in milliseconds and defaults 5000, which means by default a notification will be closed after 5 seconds.
To leave out a parameter, leave a colon space empty, e.g. `notification:$text:$title:::$closeTimeout`.

For example, send `notification:This is the text.:This is the title.:This is the subtitle.:This is the right title.` to the UI command Item to display the following notification:
<p align="center"><img style="max-width: 40%;" src="../images/about/notification.png"/></p>
- `close`:
Close all popups, popovers and sheets.
- `back`:
Navigate back.
- `reload`:
Reload the current page.

## Reload

Main UI is using caching and service workers to locally store ressources to reduce loading times.
A consequence of this is, that updates might not always be properly recognized.

The reload buttons make Main UI to properly reload.
33 changes: 33 additions & 0 deletions mainui/developer/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
---
layout: documentation
title: Developer Tools - Overview
---

# Developer Tools - Overview

<!-- START MAINUI SIDEBAR DOC - DO NOT REMOVE -->
The developer tools page is split into two tabs:

- Expert Features
- Debugging Features: Test the SSE connection and test different implementations of an icon for different states.

The expert features include:

## Advanced Object Managment

- [**Widgets**](widgets)<br>
Develop custom widgets, that can be then used on your pages. Community made widgets can be installed from the **UI** tab of the add-on store.
- **Block Libraries**<br>
Even though Blockly comes with a large [library of blocks]({{base}}/configuration/blockly/) out of the box, you can still extend it by developing your own Block libraries.
- **Add Items from textual definition**<br>
Create or update Items and links in bulk by using the [`.items`-file syntax]({{base}}/configuration/items).

## Maintenance Tools

- **Developer Sidebar**
The [developer sidebar]({{base}}/mainui/developer/sidebar) is accessible from anywhere in the UI and provides both an integrated help and developer tools, like the universal search or the widget expression tester.
In fact does the integrated help render selected parts of the [Main UI documentation]({{base}}/mainui).
So if you read this from the website: You can also read this from inside the UI.
- **API Explorer**
Interactively discover and access the [REST API]({{base}}/configuration/restdocs), which is also used by Main UI to interact with the openHAB server.
<!-- END MAINUI SIDEBAR DOC - DO NOT REMOVE -->
55 changes: 55 additions & 0 deletions mainui/developer/sidebar.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
---
layout: documentation
title: Developer Tools - Developer Sidebar
---

# Developer Tools - Developer Sidebar

<!-- START MAINUI SIDEBAR DOC - DO NOT REMOVE -->
Main UI provides a developer sidebar for administrator user(s), that is accessible from anywhere in the UI.
The developer sidebar is split into a "tools" section with several useful tools including a [universal search]({{base}}/mainui/developer/sidebar#developer-sidebar-search) across nearly all UI-configurable entities and a widget expression tester,
and a "help" section aiming at providing help and useful information regarding configuration and setup.

<!-- END MAINUI SIDEBAR DOC - DO NOT REMOVE -->

If your device's screen is wide enough (it has to be at least 1280 pixels wide), you can open the developer side-panel by:

- Opening the **Developer Tools** page from the menu and enabling the developer sidebar.
- Clicking on the help icon displayed in the upper right corner of most pages.
- Pressing the key combination <kbd>Alt</kbd><kbd>Shift</kbd><kbd>D</kbd> on your keyboard.

## Developer Sidebar Search

As already mentioned, the developer sidebar provides a universal search across nearly all UI-configurable entities.
This means, you can search through most configuration available in Main UI, including Things, Items, pages.

Imagine you need to find all usages of an Item.
You could start to open all rules, scenes and scripts, check persistence configuration and have a look at pages and sitemaps to find usages of that Item - Or you use the developer sidebar search.

The developer sidebar search ignores case (so it doesn't matter whether you search `LivingRoom_Light` or `livingroom_light`) and searches inside the following entities:

- Things
- UID
- label
- Items
- name
- label
- tags (requires exact match, i.e. if the Item has a tag `Lightbulb`, only the search query `Lightbulb` (case doesn't matter) will match)
- metadata
- Pages (including Sitemaps)
- uid
- label
- content (widgets, tabs, charts, etc. with their configuration)/slots
- Transformations
- uid
- label
- type
- Rules, Scenes & Scripts
- Item name & Thing UID of triggers, actions & conditions
- script code (e.g. Rules DSL, JavaScript, and even Blockly)
- script MIME types (requires exact match)
- Blockly scripts (using `block`, `blockly` or `blocksource` as search string, where case is ignored)
- tags (requires exact match)
- Persistence Configurations:
- label & service id of persistence service
- Items persisted by persistence service
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
File renamed without changes
16 changes: 13 additions & 3 deletions mainui/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,10 @@ title: Main UI
# Main UI - Overview

<!-- START MAINUI SIDEBAR DOC - DO NOT REMOVE -->
Welcome to help for openHAB's MainUI.
This user interface is the primary system for management of your openHAB system as well as one of the available standard UIs.
Since openHAB 3.0, the so-called "Main UI" is the primary web user interface of openHAB.
It allows you to configure openHAB system, and provides a user interface for monitoring and control of your smart home.

If you are new to openHAB, please refer to the [Getting Started guide]({{base}}/tutorial/), which is introducing you to Main UI by using it to set up openHAB.

Users with the administrator role can use the left panel menu to access:

Expand All @@ -16,7 +18,15 @@ Users with the administrator role can use the left panel menu to access:
- [**Add-on Store**](addons)<br>
openHAB can and has to be extended via add-ons. Add-ons include bindings, automation, persistence and much more. Visit the store to discover all available add-ons.
- [**Developer Tools**](developer)<br>
Special functions including creation of custom widgets and block libraries.
Special functions including creation of custom widgets and block libraries as well as the developer sidebar.
- [**Help & About**](about)<br>
The about page shows general information of your openHAB configuration and allows to configure some client related configuration.
<!-- END MAINUI SIDEBAR DOC - DO NOT REMOVE -->

## Special Features

This section attempts to highlight some of Main UI's "special" features by linking to their respective documentation:

- [Developer Sidebar Search]({{base}}/mainui/developer/sidebar#developer-sidebar-search), which is able to search across nearly all UI-configurable entities.
- [Web Audio Sink]({{base}}/mainui/about#web-audio-sink) support, which allows the openHAB server to play audio on Main UI clients.
- [UI Command Item]({{base}}/mainui/about#)
2 changes: 1 addition & 1 deletion mainui/settings/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,7 @@ See [What's the Difference Between a Rule, Script, and Schedule?]({{base}}/tutor

## System Settings

This section lists openHAB's system settings, which e.g. included location or time zone setup.
This section lists openHAB's system settings, which e.g. includes regional, language, unit system and network settings.

## Add-on Settings

Expand Down
Loading

0 comments on commit 569c886

Please sign in to comment.