From 6d118db648045a84892415594e89f31453d43a0b Mon Sep 17 00:00:00 2001 From: Jerome Luckenbach Date: Wed, 27 Jan 2021 22:32:11 +0100 Subject: [PATCH] Delete habpanel.md (#1471) * Delete habpanel.md This file is gathered from its code repository for a long time already. Signed-off-by: Jerome Luckenbach * Add habpanel placeholder for preview Signed-off-by: Jerome Luckenbach --- .vuepress/add_placeholders.rb | 1 + configuration/habpanel.md | 286 ---------------------------------- 2 files changed, 1 insertion(+), 286 deletions(-) delete mode 100644 configuration/habpanel.md diff --git a/.vuepress/add_placeholders.rb b/.vuepress/add_placeholders.rb index 87606c40a..7a2e53b28 100644 --- a/.vuepress/add_placeholders.rb +++ b/.vuepress/add_placeholders.rb @@ -8,6 +8,7 @@ def add_placeholder_pages() "docs/configuration/iconsets/classic", "docs/configuration/ui/habmin", "docs/configuration/ui/habot", + "docs/configuration/ui/habpanel", "docs/configuration/ui/basic", "docs/configuration/ui/classic", "docs/ecosystem/alexa", diff --git a/configuration/habpanel.md b/configuration/habpanel.md deleted file mode 100644 index 2cabbd0fc..000000000 --- a/configuration/habpanel.md +++ /dev/null @@ -1,286 +0,0 @@ ---- -layout: documentation -title: HABPanel -source: https://github.com/openhab/openhab-webui/blob/main/bundles/org.openhab.ui.habpanel/doc/habpanel.md ---- - -{% include base.html %} - - - -# Designing dashboard interfaces with HABPanel - -The HABPanel user interface is installed by default when choosing any initial setup package, and allows the creation of user-friendly dashboards, particularly suited for (e.g. wall-mounted) tablets. These dashboards can be designed interactively in the embedded designer, rather than using configuration files. - -Despite being similar, HABPanel's dashboards and [sitemaps]({{base}}/configuration/sitemaps.html) are separate concepts, and can be designed independently as they aren't related to each other; however, they rely and act on [items]({{base}}/concepts/items.html) which must therefore be [defined]({{base}}/configuration/items.html) first. The [demo setup package]({{base}}/configuration/packages.html#demo-package-sample-setup), available for installation when starting openHAB for the first time, defines a series of sample items and configures HABPanel with a comprehensive set of dashboards to showcase a possible end result. It's the same as the one installed on the [openHAB Demo Server](https://demo.openhab.org/){:target="_blank"}, and it may be modified without risk of breaking anything: it's the best playground to discover HABPanel's features. - -## Concepts - -HABPanel has its own terminology of entities presented below: - -![HABPanel concepts](images/habpanel_concepts.png) - -- The **Panel Registry** is the central storage used by HABPanel on a given openHAB instance, it contains several **Panel Configurations**; -- A **Panel Configuration** is a container holding a **Panel** along with its **Settings** and the definition of **Custom Widgets**. Each device HABPanel runs on (desktop browser, tablet...) has an active panel configuration and displays the panel associated with it; -- A **Panel** is a set of **Dashboards** (or pages) which can be presented to end users, who can also easily switch between them using the menu. -- A **Dashboard** is comprised of discrete **Widgets** positioned on the dashboard's surface at design time. There are several types of built-in *standard widgets*, configured separately, and the administrator can also develop (or import) *custom widgets*. - -## About data persistence - -By default, when running HABPanel on a new browser or device, a tutorial will be displayed allowing the user to start from scratch, or switch to an previously defined panel configuration. **Until a panel configuration is created (or chosen), HABPanel will run in "local storage" mode for this device: the settings will be retained in the browser's local storage only and nothing will be persisted on the server.** By contrast, when an active panel configuration is set, each change performed on the device will update the panel configuration on the server. This allows the sharing of panel configuration among devices, because other browsers and devices using this panel configuration will pick up the changes with a page refresh - this is useful for instance to design a panel comfortably on a computer, then use it on a tablet. - -To switch from the local storage to a server-hosted panel configuration, go to the Settings page from the main menu or the side drawer (see below). A list of panel configurations will be presented in the _Current storage configuration_ section; if only the _"Local storage"_ option is available, click on the **Save the current configuration to a new panel configuration** link, give it a name to identify it (avoid spaces or special characters), and it should be added to the list. The radio button is also automatically checked, meaning it is now the active panel configuration. - -Even when there is an active panel configuration, HABPanel uses the browser's storage to sync a locally-managed copy. With the **Edit the local panel configuration (experts only)** link under the _"Local storage"_ storage configuration option in the settings screen, the raw structure of the panel configuration can be inspected, modified, and exported or imported from/to a .json file. It is also an alternative way to backup, restore and share the configuration. - -HABPanel uses service configuration variables to store its data on the openHAB server. They can be accessed using UI (_Settings > UI > HABPanel > Configure_) or in the openHAB Karaf console: - -```shell -openhab> config:edit org.openhab.habpanel -openhab> config:property-get -``` - -The following properties are defined: - -- `panelsRegistry`: contains the entire registry serialized in JSON, it is maintained by the application and shouldn't be modified directly (editing it by hand, while possible, is strongly discouraged); -- `lockEditing`: when enabled, all HABPanel instances will hide their editing features (a page refresh is necessary). When panels are complete and stable, it is advisable to turn on this setting so they cannot be easily modified by end users; -- `initialPanelConfig`: if this option is unset and no prior local configuration is detected, the tutorial will be displayed until some dashboards are added or a panel configuration is selected. This setting allows to bypass the tutorial and switch directly to the existing panel configuration with the given name. - -## Major interface elements and features - -### The main menu - -The main menu is HABPanel's home page. It contains tiles linking to the panel's dashboards, and an icon to switch between the run mode and the edit mode (if available). - -![Main menu - run mode](images/habpanel_main-menu-run.png) - -Use the gears icon in the top-right corner to switch between the two modes. - -![Main menu - edit mode](images/habpanel_main-menu-edit.png) - -When in edit mode, several features are available: - -- Add a new empty dashboard with the **Add new dashboard** link; -- Go to the settings screen (for instance, to switch from local storage to a server-managed panel configuration) by clicking on the **Advanced settings** link; -- Adjust the number of columns for the grid of main menu tiles with the slider, from 1 (the default) to 6; -- Drag the arrow icons in the top-left corner of each tile to move it; -- Resize tiles with the chevron (triangle) in the bottom-right corner of each tile; -- Configure the tiles and the dashboards themselves with the gears icons in the top-right corner of each tile; -- Enter the dashboard designer by clicking inside a tile. - -The configuration dialog when clicking on a tile's gear icon contains the following settings: - -| Setting | Description | -|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| Name | The name of the dashboard, also displayed on the tile | -| Background URL | The URL of a background image *for the main menu tile* | -| Backdrop Icon | Iconset and icon displayed on the tile as a Backdrop | -| Center backdrop horizontally | When unchecked, the backdrop is aligned to the right of the tile; when checked, it is centered | -| Icon | Icon associated with the dashboard, currently only used in the side drawer | -| Size (icon) | _(currently unused)_ | -| Title Text Color | Color for the name of the dashboard on the tile | -| Advanced tab | Contains settings currently unstable or unsupported, for advanced users only | -| Custom widgets tab | This [experimental feature](https://community.openhab.org/t/new-display-options-incl-experimental-custom-widgets-everywhere/34140/1) allows certain parts of a dashboard to be replaced by a custom widget (see _Custom Widgets_ below): the main menu tile, the drawer menu and the dashboard item - use with caution | - -It also contains a **Delete** button which will delete the entire dashboard and its contents - this happens immediately and cannot be undone! - -### The side drawer - -![Side drawer](images/habpanel_side-drawer.png) - -The side drawer can be accessed from any screen by a swipe or drag to the right (on most elements where there isn't a conflict with this gesture), or with the "hamburger icon" ☰ in the top-left corner. - -It is comprised of three parts: - -1. A **header** - clicking on it returns to the main menu. Note: if defined, the title of the panel is displayed instead of the default "HABPanel" label, it is configured in the settings (see below); -1. A **list of dashboards** for quick switching between dashboards without going back to the main menu - they are presented in the order of the menu (sorted by row, then by column); -1. A **footer** displaying the current date & time and featuring a link to the settings screen (if available). - -### The dashboard designer - -![Dashboard designer](images/habpanel_dashboard-designer.png) - -The dashboard designer is where widgets can be added, positioned, resized and configured. Placeholders are displayed where actual widgets would be on the running dashboard. - -To add a widget, use the **Add widget** button and choose among the list of standard widgets, or eventual custom widgets in the panel configuration. -See below for a description of the standard widgets. - -![Add widget menu](images/habpanel_add-widget.png) - -Use the header of a widget placeholder (with the four-arrow icon and the widget type) to move the widget. Moving a widget over other widgets do not push them away to make room (contrary to the main menu tiles), so ensure there is sufficient room for your widget before moving it. - -![Widget placeholder features](images/habpanel_dashboard-designer-placeholder-menu.png) - -When hovering over a placeholder (or tapping inside it if on a touch interface), a chevron appears in the bottom-right corner allowing to resize it. - -Use the ellipsis icon **⁝** to bring up the widget's contextual menu, offering the following options: - -- **Edit...:** Displays the configuration dialog for the widget. The options available in the dialog depend on the type of the widget and are detailed in the Widgets section; -- **Copy/move to...**: Displays a dialog allowing to clone the widget with its configuration, to the current dashboard or another, or move it to another dashboard (the target widget will retain its size of the source widget but it will be placed where there is available room, use the target dashboard's designer to find it and reposition it); -- **Delete**: Deletes the widget. - -Modifications to the dashboard are not saved automatically, use the **Save** button in the header to commit the changes to the panel configuration (or local storage). The **Run** button also saves, then runs the dashboard. - -### Running dashboards - -![A running dashboard](images/habpanel_running-dashboard.png) - -When a dashboard is running, widgets can be interacted with, and server-sent events are received when items' states are updated, so widgets update automatically in HABPanel. - -The icons in the top-right corner perform the following: - -- the **speech balloon** activates the speech recognition feature and send the results as text to openHAB's default human language interpreter. This implies [some configuration on the server]({{base}}/configuration/multimedia.html#human-language-interpreter), and this icon might not be displayed if the browser doesn't support voice recognition ([mainly only in Chrome and other webkit variants currently](https://caniuse.com/#feat=speech-recognition){:target="_blank"}). It can also be configured in the panel configuration to appear on the bottom of the screen; -- the **refresh** button forces HABPanel to retrieve the current state of all items; -- the **fullscreen** button tells the browser to go fullscreen, if supported. - -Tip: while running a dasboard, append `?kiosk=on` to the URL in the web browser to switch to "kiosk mode"; in this mode, the header, hamburger menu and toolbar will be hidden and the side drawer will be disabled - therefore there will be no easy way for an end user to switch to another screen (except with button widgets configured for that purpose). This mode is useful to display a full-screen, bare-bones UI for a fixed tablet. - -## Additional features and settings - -Apart from the storage configuration discussed above, the settings screen contains several settings kept as part of the panel configuration (meaning they are set separately): - -| Setting | Description | -|------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| -| Panel name | An user-friendly name for the panel. It will be displayed in the header of the side drawer. | -| Theme | HABPanel comes with a number of built-in themes, with this setting a different theme may applied to the panel. Themes are not user-modifiable. | -| Background image | Sets the specified URL as background image for the whole panel. *Tip: the background image works best with the 'translucent' theme!* | -| Additional stylesheet | Reference the relative URL of an additional CSS file which will be included and can be used to override the styles defined by the theme. For additional information on how you can customize HABPanel's styles, go to: [HABPanel Development & Advanced Features: Start Here!](https://community.openhab.org/t/habpanel-development-advanced-features-start-here/30755/1) | -| Drawer heading image | Reference the URL of an image (expected width: 265 pixels) which will replace the header in the side drawer | -| Hide the drawer's footer | Check to remove the bottom black part of the side drawer containing the date & time | -| Hide toolbar buttons (speak/refresh/fullscreen) | Check those boxes to hide the corresponding button in the default dashboard header top-right corner | -| Show a clock in the header | If checked, a clock will be displayed in the main menu and the dashboards | -| Header clock format (shown if "Show a clock in the header" is checked) | Use an [AngularJS' date filter format string](https://docs.angularjs.org/api/ng/filter/date) to customize the clock format in the header. The default is `HH:mm` | -| Prevent scrolling (when not editing) | When enabled, it is impossible to scroll the dashboard on a tablet (and it prevents the "elastic" bouncing effect on iOS/Safari) | -| Manage > (custom widgets) | Goes to the list of custom widget definitions for the active panel configuration | -| Voice | Selects a voice from the detected list for text-to-speech* | -| Speak the new value of the following item when it changes | When the selected String item change to a new text, HABPanel will use the browser's text-to-speech engine and the selected voice to read it aloud* | -| Display a floating speech button at the bottom of the screen | Use an alternative style for the Speak (voice input) button in dashboards | -| When this item changes to a dashboard's name, switch to it | This allows controlling the currently displayed dashboard by an openHAB item (useful with rules and as a side-effect to commands) | - -*Note: the text-to-speech functionality featured in HABPanel is unrelated to the [TTS services]({{base}}/configuration/multimedia.html#text-to-speech) defined on the openHAB server, and they are not compatible (this is why a String item is required and the `say()` function cannot be used). However, HABPanel will play audio streamed through the ['webaudio' sink]({{base}}/configuration/multimedia.html#audio), including spoken text. - -## Widgets - -### Standard widgets - -The following built-in widgets are available: - -#### Dummy (dummy) - -![Dummy widget](images/habpanel_widget-dummy.png) - -The so-called dummy widget (whose name is explained by historical reasons - it evolved from the first developed widget) displays the current state of an item without any interactivity, along with a label and an optional icon. - -#### Switch (switch) - -![Switch widget](images/habpanel_widget-switch.png) - -The switch widget is a simple widget to control a Switch item as defined in openHAB - it reports its state and is able to toggle it between ON and OFF. - -#### Label (label) - -![Label widget](images/habpanel_widget-label.png) - -The label widget is straightforward: it simply displays a fixed text and has a few appeareance options (color, font). It can for example be used as a header for a group of widgets below it. - -#### Button (button) - -![Button widget](images/habpanel_widget-button.png) - -The button widget can be clicked (or tapped) and will perform an action, like sending commands to an item or navigating to another dashboard. It can also adjust its colors depending on the state of the underlying item. - -Multiple buttons are often used together to present different options for an item. - -#### Slider (slider) - -![Slider widget](images/habpanel_widget-slider.png) - -The slider widget can reflect the state of, and update, numerical items within a range of values. Several options are available to alter its appearance and behavior. - -#### Knob (knob) - -![Knob widget](images/habpanel_widget-knob.png) - -The knob widget is similar in essence to the slider, but in a rotary fashion. It also offers extensive configurability over its appearance and behavior. - -#### Selection (selection) - -![Selection widget](images/habpanel_widget-selection.png) - -The selection widget displays the current state of an item, much like a dummy widget, except it opens a menu or a grid of automatically or manually configured choices for sending commands to this item. Various display options are available. - -#### Color picker (colorpicker) - -![Color picker widget](images/habpanel_widget-colorpicker.png) - -The color picker widget offers several ways of displaying and updating the state of an openHAB Color item (or group). - -#### Image (image) - -![Image widget](images/habpanel_widget-image.png) - -The image widget can display an image, directly or via an openHAB String item, and can refresh it at regular intervals. - -#### Frame (frame) - -![Frame widget](images/habpanel_widget-frame.png) - -The frame widget displays an external web page in a HTML `