Page Not Found | Biotz Academy
-
+
diff --git a/about.html b/about.html
index ca28c7f..4c3fdf1 100644
--- a/about.html
+++ b/about.html
@@ -4,7 +4,7 @@
Markdown page example 1 | Biotz Academy
-
+
diff --git a/assets/images/alarm-triggers-013cc3b4c4ba368837039873dadc32ca.png b/assets/images/alarm-triggers-013cc3b4c4ba368837039873dadc32ca.png
new file mode 100644
index 0000000..dbb8593
Binary files /dev/null and b/assets/images/alarm-triggers-013cc3b4c4ba368837039873dadc32ca.png differ
diff --git a/assets/images/new-alarm-trigger-946e9b5936d374848785ffdf86d3d9de.png b/assets/images/new-alarm-trigger-946e9b5936d374848785ffdf86d3d9de.png
new file mode 100644
index 0000000..1de0648
Binary files /dev/null and b/assets/images/new-alarm-trigger-946e9b5936d374848785ffdf86d3d9de.png differ
diff --git a/assets/images/select-user-18a55047740179573ffdeae6b53c41d2.png b/assets/images/select-user-18a55047740179573ffdeae6b53c41d2.png
new file mode 100644
index 0000000..6448605
Binary files /dev/null and b/assets/images/select-user-18a55047740179573ffdeae6b53c41d2.png differ
diff --git a/assets/images/transformation-bb3024fee6bcec263baabe0e53b8ab6b.png b/assets/images/transformation-bb3024fee6bcec263baabe0e53b8ab6b.png
new file mode 100644
index 0000000..c6e450d
Binary files /dev/null and b/assets/images/transformation-bb3024fee6bcec263baabe0e53b8ab6b.png differ
diff --git a/assets/images/with-variables-92f0f92646733fea74ffb0fff1b9e6d5.png b/assets/images/with-variables-92f0f92646733fea74ffb0fff1b9e6d5.png
new file mode 100644
index 0000000..e9ab440
Binary files /dev/null and b/assets/images/with-variables-92f0f92646733fea74ffb0fff1b9e6d5.png differ
diff --git a/assets/js/498d4d26.029a96c8.js b/assets/js/498d4d26.029a96c8.js
new file mode 100644
index 0000000..b32508b
--- /dev/null
+++ b/assets/js/498d4d26.029a96c8.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[6246],{2165:(e,i,n)=>{n.r(i),n.d(i,{assets:()=>d,contentTitle:()=>a,default:()=>h,frontMatter:()=>s,metadata:()=>o,toc:()=>l});var t=n(4848),r=n(8453);const s={sidebar_position:8,sidebar_label:"How to define alarm triggers"},a="How to define alarm triggers",o={id:"How-to guides/How to define alarm and triggers",title:"How to define alarm triggers",description:"Introduction",source:"@site/docs/How-to guides/How to define alarm and triggers.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to define alarm and triggers",permalink:"/docs/How-to guides/How to define alarm and triggers",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:8,frontMatter:{sidebar_position:8,sidebar_label:"How to define alarm triggers"},sidebar:"tutorialSidebar",previous:{title:"How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables"},next:{title:"How to update device firmware",permalink:"/docs/How-to guides/How to update device firmware"}},d={},l=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Alarm definition",id:"alarm-definition",level:2},{value:"General options",id:"general-options",level:3},{value:"Rule definition",id:"rule-definition",level:3},{value:"Notifications",id:"notifications",level:3}];function c(e){const i={code:"code",h1:"h1",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(i.h1,{id:"how-to-define-alarm-triggers",children:"How to define alarm triggers"}),"\n",(0,t.jsx)(i.h2,{id:"introduction",children:"Introduction"}),"\n",(0,t.jsx)(i.p,{children:"Biotz provides alarm generation and notification capabilities based on the data received in the data ingestion flows. The alarm trigger or rules are evaluated against each received data observation, and when an alarm is triggered the corresponding users are notified."}),"\n",(0,t.jsx)(i.p,{children:"This guide explains how to define the rules that decide when an alarm is triggered and how to specify the list of users that must be notified."}),"\n",(0,t.jsx)(i.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,t.jsx)(i.p,{children:"In order to define the alarm triggers you need to have a device-type with at least one message-type and message type schema."}),"\n",(0,t.jsx)(i.p,{children:"The alarm trigger will apply to all the devices of a certain device type no matter if they were created before or after defining the trigger."}),"\n",(0,t.jsx)(i.h2,{id:"alarm-definition",children:"Alarm definition"}),"\n",(0,t.jsx)(i.p,{children:"The alarm triggers are defined in the \u201cAlarm triggers\u201d subsection under the \u201cSetup\u201d section."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)("div",{class:"tutorial-image-container",children:(0,t.jsx)(i.p,{children:(0,t.jsx)(i.img,{alt:"Creating panels",src:n(5641).A+"",width:"244",height:"248"})})}),"\n",(0,t.jsx)(i.p,{children:"To create the first alarm click on the \u201cNew alarm trigger\u201d button.If you want to create a new one you can also click on the top right hand corner."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)("div",{class:"tutorial-image-container",children:(0,t.jsx)(i.p,{children:(0,t.jsx)(i.img,{alt:"Creating panels",src:n(5417).A+"",width:"1562",height:"323"})})}),"\n",(0,t.jsx)(i.p,{children:"Defining an alarm requires three steps: general options, rule definition and notification settings."}),"\n",(0,t.jsx)(i.h3,{id:"general-options",children:"General options"}),"\n",(0,t.jsx)(i.p,{children:"The following fields have to be completed:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsx)(i.li,{children:"Name: an identifier for the trigger. This name will be displayed in the triggered alarm list and notifications."}),"\n",(0,t.jsx)(i.li,{children:"Level: the criticality or severity of the alarm. The possible values are: alert, critical, emergency, info and warning."}),"\n",(0,t.jsx)(i.li,{children:"Device type: the device type for which the alarm trigger will be evaluated. The trigger will apply to all the devices of a certain type."}),"\n",(0,t.jsx)(i.li,{children:"Message type: the message type that will be used to define the trigger rule. The trigger will only be evaluated when the devices send data for the selected message type."}),"\n"]}),"\n",(0,t.jsx)(i.p,{children:""}),"\n",(0,t.jsx)(i.h3,{id:"rule-definition",children:"Rule definition"}),"\n",(0,t.jsx)(i.p,{children:"Each individual data observation is evaluated against the rule defined in this section. Those rules are composed of condition and group blocks:"}),"\n",(0,t.jsx)(i.p,{children:(0,t.jsx)(i.strong,{children:"Conditions"})}),"\n",(0,t.jsx)(i.p,{children:"For each attribute in the message-type, one or more conditions can be specified. The \u201cattribute \u201c values are compared with the \u201cvalue\u201d using the \u201coperator\u201d."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"The available operators differ depending on the attribute type:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsxs)(i.li,{children:["numeric: ",(0,t.jsx)(i.code,{children:">, >=, <, <=, =, <>"})]}),"\n",(0,t.jsxs)(i.li,{children:["boolean: ",(0,t.jsx)(i.code,{children:"<>, ="})]}),"\n",(0,t.jsxs)(i.li,{children:["text: ",(0,t.jsx)(i.code,{children:"<>, ="})]}),"\n",(0,t.jsxs)(i.li,{children:["others: ",(0,t.jsx)(i.code,{children:"None"})]}),"\n"]}),"\n",(0,t.jsxs)(i.p,{children:["\u200d",(0,t.jsx)(i.strong,{children:"Groups"})]}),"\n",(0,t.jsx)(i.p,{children:"Multiple conditions can be grouped. When doing so, a logical operator has to be chosen to define the relation between the grouped conditions."}),"\n",(0,t.jsx)(i.p,{children:"The following are the available logical operators:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsx)(i.li,{children:"AND: The group is considered truthy if all the individual conditions are met."}),"\n",(0,t.jsx)(i.li,{children:"OR: The group is considered truthy if at least one individual condition is met."}),"\n",(0,t.jsx)(i.li,{children:"NOT AND: The group is considered truthy if none or some, but not all individual conditions are met\n-NOT OR: The group is considered truthy if none of the individual conditions is met."}),"\n"]}),"\n",(0,t.jsx)("div",{class:"tutorial-image-container",children:(0,t.jsx)(i.p,{children:(0,t.jsx)(i.img,{alt:"Groups",src:n(1602).A+"",width:"1600",height:"322"})})}),"\n",(0,t.jsx)(i.p,{children:"Conditions and groups can be nested to build complex rules."}),"\n",(0,t.jsx)(i.h3,{id:"notifications",children:"Notifications"}),"\n",(0,t.jsx)(i.p,{children:"By default no users will be notified when an alarm is triggered. The triggered alarm will be persisted and viewable in the alarms list, but none of the users will get a message. To change that, the \u201cEdit users\u201d button can be used. Pressing the button will open a sidebar where the list of users to be notified can be selected."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"The selected users will get a web notification and an email when an alarm is triggered."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)("div",{class:"tutorial-image-container",children:(0,t.jsx)(i.p,{children:(0,t.jsx)(i.img,{alt:"Groups",src:n(3108).A+"",width:"394",height:"197"})})}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"To avoid overwhelming the user with notifications, a rate limit is applied to the notifications sent to the users. The users will be notified at most once every 15 minutes for each device an alarm trigger definition. Additional notifications will be ignored, but the alarm will be persisted and viewable in the alarms list."})]})}function h(e={}){const{wrapper:i}={...(0,r.R)(),...e.components};return i?(0,t.jsx)(i,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},5641:(e,i,n)=>{n.d(i,{A:()=>t});const t=n.p+"assets/images/alarm-triggers-013cc3b4c4ba368837039873dadc32ca.png"},1602:(e,i,n)=>{n.d(i,{A:()=>t});const t=n.p+"assets/images/groups-9026e0e02903e812c56b2d95612349d9.png"},5417:(e,i,n)=>{n.d(i,{A:()=>t});const t=n.p+"assets/images/new-alarm-trigger-946e9b5936d374848785ffdf86d3d9de.png"},3108:(e,i,n)=>{n.d(i,{A:()=>t});const t=n.p+"assets/images/select-user-18a55047740179573ffdeae6b53c41d2.png"},8453:(e,i,n)=>{n.d(i,{R:()=>a,x:()=>o});var t=n(6540);const r={},s=t.createContext(r);function a(e){const i=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(i):{...i,...e}}),[i,e])}function o(e){let i;return i=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:a(e.components),t.createElement(s.Provider,{value:i},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/498d4d26.6cc742f9.js b/assets/js/498d4d26.6cc742f9.js
deleted file mode 100644
index cf3d148..0000000
--- a/assets/js/498d4d26.6cc742f9.js
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[6246],{2165:(e,i,n)=>{n.r(i),n.d(i,{assets:()=>d,contentTitle:()=>o,default:()=>h,frontMatter:()=>s,metadata:()=>a,toc:()=>l});var t=n(4848),r=n(8453);const s={sidebar_position:8,sidebar_label:"How to define alarm triggers"},o="How to define alarm triggers",a={id:"How-to guides/How to define alarm and triggers",title:"How to define alarm triggers",description:"Introduction",source:"@site/docs/How-to guides/How to define alarm and triggers.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to define alarm and triggers",permalink:"/docs/How-to guides/How to define alarm and triggers",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:8,frontMatter:{sidebar_position:8,sidebar_label:"How to define alarm triggers"},sidebar:"tutorialSidebar",previous:{title:"How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables"},next:{title:"How to update device firmware",permalink:"/docs/How-to guides/How to update device firmware"}},d={},l=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Alarm definition",id:"alarm-definition",level:2},{value:"General options",id:"general-options",level:3},{value:"Rule definition",id:"rule-definition",level:3},{value:"Notifications",id:"notifications",level:3}];function c(e){const i={code:"code",h1:"h1",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,r.R)(),...e.components};return(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)(i.h1,{id:"how-to-define-alarm-triggers",children:"How to define alarm triggers"}),"\n",(0,t.jsx)(i.h2,{id:"introduction",children:"Introduction"}),"\n",(0,t.jsx)(i.p,{children:"Biotz provides alarm generation and notification capabilities based on the data received in the data ingestion flows. The alarm trigger or rules are evaluated against each received data observation, and when an alarm is triggered the corresponding users are notified."}),"\n",(0,t.jsx)(i.p,{children:"This guide explains how to define the rules that decide when an alarm is triggered and how to specify the list of users that must be notified."}),"\n",(0,t.jsx)(i.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,t.jsx)(i.p,{children:"In order to define the alarm triggers you need to have a device-type with at least one message-type and message type schema."}),"\n",(0,t.jsx)(i.p,{children:"The alarm trigger will apply to all the devices of a certain device type no matter if they were created before or after defining the trigger."}),"\n",(0,t.jsx)(i.h2,{id:"alarm-definition",children:"Alarm definition"}),"\n",(0,t.jsx)(i.p,{children:"The alarm triggers are defined in the \u201cAlarm triggers\u201d subsection under the \u201cSetup\u201d section."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:""}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:""}),"\n",(0,t.jsx)(i.p,{children:"Defining an alarm requires three steps: general options, rule definition and notification settings."}),"\n",(0,t.jsx)(i.h3,{id:"general-options",children:"General options"}),"\n",(0,t.jsx)(i.p,{children:"The following fields have to be completed:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsx)(i.li,{children:"Name: an identifier for the trigger. This name will be displayed in the triggered alarm list and notifications."}),"\n",(0,t.jsx)(i.li,{children:"Level: the criticality or severity of the alarm. The possible values are: alert, critical, emergency, info and warning."}),"\n",(0,t.jsx)(i.li,{children:"Device type: the device type for which the alarm trigger will be evaluated. The trigger will apply to all the devices of a certain type."}),"\n",(0,t.jsx)(i.li,{children:"Message type: the message type that will be used to define the trigger rule. The trigger will only be evaluated when the devices send data for the selected message type."}),"\n"]}),"\n",(0,t.jsx)(i.p,{children:""}),"\n",(0,t.jsx)(i.h3,{id:"rule-definition",children:"Rule definition"}),"\n",(0,t.jsx)(i.p,{children:"Each individual data observation is evaluated against the rule defined in this section. Those rules are composed of condition and group blocks:"}),"\n",(0,t.jsx)(i.p,{children:(0,t.jsx)(i.strong,{children:"Conditions"})}),"\n",(0,t.jsx)(i.p,{children:"For each attribute in the message-type, one or more conditions can be specified. The \u201cattribute \u201c values are compared with the \u201cvalue\u201d using the \u201coperator\u201d."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"The available operators differ depending on the attribute type:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsxs)(i.li,{children:["numeric: ",(0,t.jsx)(i.code,{children:">, >=, <, <=, =, <>"})]}),"\n",(0,t.jsxs)(i.li,{children:["boolean: ",(0,t.jsx)(i.code,{children:"<>, ="})]}),"\n",(0,t.jsxs)(i.li,{children:["text: ",(0,t.jsx)(i.code,{children:"<>, ="})]}),"\n",(0,t.jsxs)(i.li,{children:["others: ",(0,t.jsx)(i.code,{children:"None"})]}),"\n"]}),"\n",(0,t.jsxs)(i.p,{children:["\u200d",(0,t.jsx)(i.strong,{children:"Groups"})]}),"\n",(0,t.jsx)(i.p,{children:"Multiple conditions can be grouped. When doing so, a logical operator has to be chosen to define the relation between the grouped conditions."}),"\n",(0,t.jsx)(i.p,{children:"The following are the available logical operators:"}),"\n",(0,t.jsxs)(i.ul,{children:["\n",(0,t.jsx)(i.li,{children:"AND: The group is considered truthy if all the individual conditions are met."}),"\n",(0,t.jsx)(i.li,{children:"OR: The group is considered truthy if at least one individual condition is met."}),"\n",(0,t.jsx)(i.li,{children:"NOT AND: The group is considered truthy if none or some, but not all individual conditions are met\n-NOT OR: The group is considered truthy if none of the individual conditions is met."}),"\n"]}),"\n",(0,t.jsx)("div",{class:"tutorial-image-container",children:(0,t.jsx)(i.p,{children:(0,t.jsx)(i.img,{alt:"Groups",src:n(1602).A+"",width:"1600",height:"322"})})}),"\n",(0,t.jsx)(i.p,{children:"Conditions and groups can be nested to build complex rules."}),"\n",(0,t.jsx)(i.h3,{id:"notifications",children:"Notifications"}),"\n",(0,t.jsx)(i.p,{children:"By default no users will be notified when an alarm is triggered. The triggered alarm will be persisted and viewable in the alarms list, but none of the users will get a message. To change that, the \u201cEdit users\u201d button can be used. Pressing the button will open a sidebar where the list of users to be notified can be selected."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"The selected users will get a web notification and an email when an alarm is triggered."}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:""}),"\n",(0,t.jsx)("br",{}),"\n",(0,t.jsx)(i.p,{children:"To avoid overwhelming the user with notifications, a rate limit is applied to the notifications sent to the users. The users will be notified at most once every 15 minutes for each device an alarm trigger definition. Additional notifications will be ignored, but the alarm will be persisted and viewable in the alarms list."})]})}function h(e={}){const{wrapper:i}={...(0,r.R)(),...e.components};return i?(0,t.jsx)(i,{...e,children:(0,t.jsx)(c,{...e})}):c(e)}},1602:(e,i,n)=>{n.d(i,{A:()=>t});const t=n.p+"assets/images/groups-9026e0e02903e812c56b2d95612349d9.png"},8453:(e,i,n)=>{n.d(i,{R:()=>o,x:()=>a});var t=n(6540);const r={},s=t.createContext(r);function o(e){const i=t.useContext(s);return t.useMemo((function(){return"function"==typeof e?e(i):{...i,...e}}),[i,e])}function a(e){let i;return i=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:o(e.components),t.createElement(s.Provider,{value:i},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/75a8a8f3.587827f2.js b/assets/js/75a8a8f3.587827f2.js
deleted file mode 100644
index 30c73fe..0000000
--- a/assets/js/75a8a8f3.587827f2.js
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[9814],{9015:(e,a,t)=>{t.r(a),t.d(a,{assets:()=>o,contentTitle:()=>h,default:()=>c,frontMatter:()=>s,metadata:()=>n,toc:()=>i});var d=t(4848),r=t(8453);const s={sidebar_position:7,sidebar_label:"How to use dashboard variables"},h="How to use dashboard variables",n={id:"How-to guides/How to use dashboard variables",title:"How to use dashboard variables",description:"Introduction",source:"@site/docs/How-to guides/How to use dashboard variables.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:7,frontMatter:{sidebar_position:7,sidebar_label:"How to use dashboard variables"},sidebar:"tutorialSidebar",previous:{title:"How to create a dashboard",permalink:"/docs/How-to guides/How to create a dashboard"},next:{title:"How to define alarm triggers",permalink:"/docs/How-to guides/How to define alarm and triggers"}},o={},i=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Define dashboard variables",id:"define-dashboard-variables",level:2},{value:"Use dashboard variables",id:"use-dashboard-variables",level:2}];function l(e){const a={h1:"h1",h2:"h2",img:"img",p:"p",...(0,r.R)(),...e.components};return(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(a.h1,{id:"how-to-use-dashboard-variables",children:"How to use dashboard variables"}),"\n",(0,d.jsx)(a.h2,{id:"introduction",children:"Introduction"}),"\n",(0,d.jsx)(a.p,{children:"Dashboard variables allow users to make dashboard panels more dynamic. Instead of hardcoding specific devices in the panels, device selectors can be added to the dashboard. Those selectors are displayed in the main dashboard view, and the selected value can be changed by the final users at any time. Changing the value updates the data for all the panels that are using that variable."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"The dashboard variables are defined at dashboard level. Then they can be used when defining the panel queries."}),"\n",(0,d.jsx)(a.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,d.jsx)(a.p,{children:"The dashboard has to be pre-created, and at least one device is needed."}),"\n",(0,d.jsx)(a.h2,{id:"define-dashboard-variables",children:"Define dashboard variables"}),"\n",(0,d.jsx)(a.p,{children:"The variables are created from the dashboard edition view. For that click on the \u201cpencil\u201d icon in the dashboard toolbar."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Dashboard Toolbars",src:t(6626).A+"",width:"537",height:"135"})})}),"\n",(0,d.jsx)(a.p,{children:"Creating a variable only requires specifying a name and selecting a device-type."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"The dashboard variables are always device-type specific to ensure that all the selectable devices are compatible with the dashboard panel queries in which the variable is used."}),"\n",(0,d.jsx)(a.p,{children:"When entering the device type, the panels that use this variable will use this device by default. But in the dashboard toolbar you can select any other device of the same type, and display the data of that other device instead."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Documentation Dasboard",src:t(8889).A+"",width:"480",height:"270"})})}),"\n",(0,d.jsx)(a.p,{children:"Up to 4 variables can be defined."}),"\n",(0,d.jsx)(a.h2,{id:"use-dashboard-variables",children:"Use dashboard variables"}),"\n",(0,d.jsx)(a.p,{children:"Once a dashboard variable is defined it can be used when defining dashboard panel queries. The same variable can be used in multiple queries and panels."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"For that, click on the \u201cVariable, select a variable defined in the dashboard\u201d in the query builder. Then select a specific variable from the list. Continue with the rest of the form as when selecting a specific device."}),"\n",(0,d.jsx)(a.p,{children:"The dashboard variable is now ready to use. Changing the device in the dashboard view will update the corresponding panels."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Creating panels",src:t(8738).A+"",width:"1148",height:"358"})})}),"\n",(0,d.jsx)(a.p,{children:"\u200d"})]})}function c(e={}){const{wrapper:a}={...(0,r.R)(),...e.components};return a?(0,d.jsx)(a,{...e,children:(0,d.jsx)(l,{...e})}):l(e)}},6626:(e,a,t)=>{t.d(a,{A:()=>d});const d=""},8889:(e,a,t)=>{t.d(a,{A:()=>d});const d=t.p+"assets/images/documentation-dashboard-bd03c54ca3bd1c340036cd2959c69e10.png"},8738:(e,a,t)=>{t.d(a,{A:()=>d});const d=t.p+"assets/images/variable-selector-325584b3bed50c0d21980b618e372947.png"},8453:(e,a,t)=>{t.d(a,{R:()=>h,x:()=>n});var d=t(6540);const r={},s=d.createContext(r);function h(e){const a=d.useContext(s);return d.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function n(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:h(e.components),d.createElement(s.Provider,{value:a},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/75a8a8f3.ccbfd68f.js b/assets/js/75a8a8f3.ccbfd68f.js
new file mode 100644
index 0000000..23f5f51
--- /dev/null
+++ b/assets/js/75a8a8f3.ccbfd68f.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[9814],{9015:(e,a,t)=>{t.r(a),t.d(a,{assets:()=>h,contentTitle:()=>i,default:()=>c,frontMatter:()=>s,metadata:()=>n,toc:()=>o});var d=t(4848),r=t(8453);const s={sidebar_position:7,sidebar_label:"How to use dashboard variables"},i="How to use dashboard variables",n={id:"How-to guides/How to use dashboard variables",title:"How to use dashboard variables",description:"Introduction",source:"@site/docs/How-to guides/How to use dashboard variables.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:7,frontMatter:{sidebar_position:7,sidebar_label:"How to use dashboard variables"},sidebar:"tutorialSidebar",previous:{title:"How to create a dashboard",permalink:"/docs/How-to guides/How to create a dashboard"},next:{title:"How to define alarm triggers",permalink:"/docs/How-to guides/How to define alarm and triggers"}},h={},o=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Define dashboard variables",id:"define-dashboard-variables",level:2},{value:"Use dashboard variables",id:"use-dashboard-variables",level:2}];function l(e){const a={h1:"h1",h2:"h2",img:"img",p:"p",...(0,r.R)(),...e.components};return(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(a.h1,{id:"how-to-use-dashboard-variables",children:"How to use dashboard variables"}),"\n",(0,d.jsx)(a.h2,{id:"introduction",children:"Introduction"}),"\n",(0,d.jsx)(a.p,{children:"Dashboard variables allow users to make dashboard panels more dynamic. Instead of hardcoding specific devices in the panels, device selectors can be added to the dashboard. Those selectors are displayed in the main dashboard view, and the selected value can be changed by the final users at any time. Changing the value updates the data for all the panels that are using that variable."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"The dashboard variables are defined at dashboard level. Then they can be used when defining the panel queries."}),"\n",(0,d.jsx)(a.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,d.jsx)(a.p,{children:"The dashboard has to be pre-created, and at least one device is needed."}),"\n",(0,d.jsx)(a.h2,{id:"define-dashboard-variables",children:"Define dashboard variables"}),"\n",(0,d.jsx)(a.p,{children:"The variables are created from the dashboard edition view. For that click on the \u201cpencil\u201d icon in the dashboard toolbar."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Dashboard Toolbars",src:t(6626).A+"",width:"537",height:"135"})})}),"\n",(0,d.jsx)(a.p,{children:"Creating a variable only requires specifying a name and selecting a device-type."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"The dashboard variables are always device-type specific to ensure that all the selectable devices are compatible with the dashboard panel queries in which the variable is used."}),"\n",(0,d.jsx)(a.p,{children:"When entering the device type, the panels that use this variable will use this device by default. But in the dashboard toolbar you can select any other device of the same type, and display the data of that other device instead."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Documentation Dasboard",src:t(8889).A+"",width:"480",height:"270"})})}),"\n",(0,d.jsx)(a.p,{children:"Up to 4 variables can be defined."}),"\n",(0,d.jsx)(a.h2,{id:"use-dashboard-variables",children:"Use dashboard variables"}),"\n",(0,d.jsx)(a.p,{children:"Once a dashboard variable is defined it can be used when defining dashboard panel queries. The same variable can be used in multiple queries and panels."}),"\n",(0,d.jsx)("br",{}),"\n",(0,d.jsx)(a.p,{children:"For that, click on the \u201cVariable, select a variable defined in the dashboard\u201d in the query builder. Then select a specific variable from the list. Continue with the rest of the form as when selecting a specific device."}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Creating panels",src:t(8738).A+"",width:"1148",height:"358"})})}),"\n",(0,d.jsx)(a.p,{children:"\u200d\nThe dashboard variable is now ready to use. Changing the device in the dashboard view will update the corresponding panels."}),"\n",(0,d.jsx)(a.p,{children:"This is what a new panel would look like using variables:"}),"\n",(0,d.jsx)("div",{class:"tutorial-image-container",children:(0,d.jsx)(a.p,{children:(0,d.jsx)(a.img,{alt:"Creating panels",src:t(6814).A+"",width:"452",height:"313"})})}),"\n",(0,d.jsx)(a.p,{children:"\u200d"})]})}function c(e={}){const{wrapper:a}={...(0,r.R)(),...e.components};return a?(0,d.jsx)(a,{...e,children:(0,d.jsx)(l,{...e})}):l(e)}},6626:(e,a,t)=>{t.d(a,{A:()=>d});const d=""},8889:(e,a,t)=>{t.d(a,{A:()=>d});const d=t.p+"assets/images/documentation-dashboard-bd03c54ca3bd1c340036cd2959c69e10.png"},8738:(e,a,t)=>{t.d(a,{A:()=>d});const d=t.p+"assets/images/variable-selector-325584b3bed50c0d21980b618e372947.png"},6814:(e,a,t)=>{t.d(a,{A:()=>d});const d=t.p+"assets/images/with-variables-92f0f92646733fea74ffb0fff1b9e6d5.png"},8453:(e,a,t)=>{t.d(a,{R:()=>i,x:()=>n});var d=t(6540);const r={},s=d.createContext(r);function i(e){const a=d.useContext(s);return d.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function n(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(r):e.components||r:i(e.components),d.createElement(s.Provider,{value:a},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/842fc954.6284c7eb.js b/assets/js/842fc954.6284c7eb.js
deleted file mode 100644
index 6e3d42d..0000000
--- a/assets/js/842fc954.6284c7eb.js
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[4712],{6155:(e,A,t)=>{t.r(A),t.d(A,{assets:()=>c,contentTitle:()=>s,default:()=>l,frontMatter:()=>i,metadata:()=>r,toc:()=>o});var a=t(4848),n=t(8453);const i={sidebar_position:3,sidebar_label:"How to create a schema - setup apllication to ingest certain data"},s="How to create a schema",r={id:"How-to guides/How to create a schema",title:"How to create a schema",description:"Introduction",source:"@site/docs/How-to guides/How to create a schema.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to create a schema",permalink:"/docs/How-to guides/How to create a schema",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,sidebar_label:"How to create a schema - setup apllication to ingest certain data"},sidebar:"tutorialSidebar",previous:{title:"How to register devices",permalink:"/docs/How-to guides/How to register devices"},next:{title:"How to publish device data using MQTT - setup devices to send data",permalink:"/docs/How-to guides/How to publish device data"}},c={},o=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Creating a schema",id:"creating-a-schema",level:2},{value:"Create a schema using the text editor",id:"create-a-schema-using-the-text-editor",level:2}];function d(e){const A={h1:"h1",h2:"h2",img:"img",li:"li",p:"p",ul:"ul",...(0,n.R)(),...e.components};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(A.h1,{id:"how-to-create-a-schema",children:"How to create a schema"}),"\n",(0,a.jsx)(A.h2,{id:"introduction",children:"Introduction"}),"\n",(0,a.jsx)(A.p,{children:"When data arrives into Biotz's ingestion system, the received package of data is checked against schemas defined in Biotz. These schemas are the definition of the content of the data package and the user must take care of defining them in the system."}),"\n",(0,a.jsx)(A.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,a.jsx)(A.p,{children:"In order to create a schema having a deceive-type with at least one message type is required. A schema is directly related to device-type, there can be zero to many schemas."}),"\n",(0,a.jsx)(A.h2,{id:"creating-a-schema",children:"Creating a schema"}),"\n",(0,a.jsx)(A.p,{children:"Schemas are created from the Setup > Data ingestion flow > Device-type > Message-type \u201cNew schema\u201d"}),"\n",(0,a.jsx)("div",{class:"tutorial-image-container",children:(0,a.jsx)(A.p,{children:(0,a.jsx)(A.img,{alt:"Creating a schema",src:t(3655).A+"",width:"989",height:"461"})})}),"\n",(0,a.jsx)(A.p,{children:"When clicking on \u201cNew schema\u201d an empty schema is created."}),"\n",(0,a.jsx)("div",{class:"tutorial-image-container",children:(0,a.jsx)(A.p,{children:(0,a.jsx)(A.img,{alt:"New schema",src:t(764).A+"",width:"989",height:"418"})})}),"\n",(0,a.jsx)(A.p,{children:"First thing will be giving a name to the schema, the purpose of this is just to identify it, it is not further used in the communication or data sending."}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsx)(A.p,{children:"After naming the schema the proper and important specification happens under the \u2018Schema definition\u2019 section. It is time to let Biotz know how the sending data is structured. Once \u2018Add new item\u2019 is selected, a set of different item types are offered to cover almost all the data sending options:"}),"\n",(0,a.jsx)("div",{class:"tutorial-image-container",children:(0,a.jsx)(A.p,{children:(0,a.jsx)(A.img,{alt:"Item types",src:t(3051).A+"",width:"1206",height:"640"})})}),"\n",(0,a.jsxs)(A.p,{children:["Detailed specification of the item types is shared in ",(0,a.jsx)("a",{href:"/docs/Reference guides/Message-type Schema specification",target:"_self",children:"here"}),".\n\u200d"]}),"\n",(0,a.jsxs)(A.ul,{children:["\n",(0,a.jsx)(A.li,{children:"Collection of identical items: collection of more than one identical item. Being an item anything from an object/map/dictionary to singular element as a text, boolean, integer or decimal."}),"\n",(0,a.jsx)(A.li,{children:"Collection of unrelated items: collection of any kind of item, present just once."}),"\n",(0,a.jsx)(A.li,{children:"Object / Map / Dictionary: They are containers of the final properties, as the collection type items. 1 to n items can be added to this one, they are grouped in two types based on the data needed to define them:"}),"\n",(0,a.jsx)(A.li,{children:"Unix timestamp (integer)"}),"\n",(0,a.jsx)(A.li,{children:"Unix timestamp (text)"}),"\n",(0,a.jsx)(A.li,{children:"Unix timestamp RFC-3339"}),"\n",(0,a.jsx)(A.li,{children:"Text"}),"\n",(0,a.jsx)(A.li,{children:"Boolean"}),"\n",(0,a.jsx)(A.li,{children:"Integer"}),"\n",(0,a.jsx)(A.li,{children:"Integer, as text"}),"\n",(0,a.jsx)(A.li,{children:"Integer, as hexadecimal text"}),"\n",(0,a.jsx)(A.li,{children:"Decimal"}),"\n",(0,a.jsx)(A.li,{children:"Decimal, as text"}),"\n"]}),"\n",(0,a.jsx)(A.p,{children:"These are the descriptions of each of the parameters of an item:"}),"\n",(0,a.jsxs)(A.ul,{children:["\n",(0,a.jsx)(A.li,{children:"Item type: the type of the element in the payload."}),"\n",(0,a.jsx)(A.li,{children:"Key name: key name in the object/dictionary."}),"\n",(0,a.jsx)(A.li,{children:"Item name: the name of the column where this data will be stored."}),"\n",(0,a.jsx)(A.li,{children:"Mandatory?"}),"\n",(0,a.jsx)(A.li,{children:"Can be null?"}),"\n"]}),"\n",(0,a.jsx)("div",{class:"tutorial-image-container",children:(0,a.jsx)(A.p,{children:(0,a.jsx)(A.img,{alt:"parameters",src:t(3418).A+"",width:"979",height:"136"})})}),"\n",(0,a.jsx)(A.p,{children:"Timestamp ones, the same as the rest with an extra one:"}),"\n",(0,a.jsxs)(A.ul,{children:["\n",(0,a.jsx)(A.li,{children:"Payload timestamp?: to be marked if this is the timestamp Biotz should use for the time series date mark."}),"\n"]}),"\n",(0,a.jsx)("div",{class:"tutorial-image-container",children:(0,a.jsx)(A.p,{children:(0,a.jsx)(A.img,{alt:"Payload Timestamp",src:t(6341).A+"",width:"979",height:"136"})})}),"\n",(0,a.jsx)(A.p,{children:"Once the schema is totally represented the \u2018save\u2019 button will register the schema. This will create the necessary machinery for the data validation and ingestion, it will also create the needed database structure for the data to be stored."}),"\n",(0,a.jsx)(A.h2,{id:"create-a-schema-using-the-text-editor",children:"Create a schema using the text editor"}),"\n",(0,a.jsx)(A.p,{children:"Apart from the interactive user interface to register a schema, there is a editor mode to perform the same task."}),"\n",(0,a.jsx)(A.p,{children:"The editor mode provides a more flexible way of registering a schema, but requires advanced knowledge of the structure it must follow."}),"\n",(0,a.jsx)(A.p,{children:"It can also be used to get a plain text description of the schema that can be copied and saved to local files."}),"\n",(0,a.jsx)(A.p,{children:"The scheme must be a valid schema to be able to 'save' it."}),"\n",(0,a.jsx)("br",{}),"\n",(0,a.jsxs)(A.p,{children:["Next step should be setting up the other piece of the communication, the device. This ",(0,a.jsx)("a",{href:"./How to publish device data",target:"_self",children:"other"}),"\nhow-to guide talks about it."]}),"\n",(0,a.jsx)(A.p,{children:"\u200d"})]})}function l(e={}){const{wrapper:A}={...(0,n.R)(),...e.components};return A?(0,a.jsx)(A,{...e,children:(0,a.jsx)(d,{...e})}):d(e)}},3655:(e,A,t)=>{t.d(A,{A:()=>a});const a=t.p+"assets/images/creating-schema-5f711220394c7af9927d860f5f60e65f.png"},3051:(e,A,t)=>{t.d(A,{A:()=>a});const a=t.p+"assets/images/item-types-8cbacb7885eed1e065059a63cb7ac6ea.png"},764:(e,A,t)=>{t.d(A,{A:()=>a});const a=t.p+"assets/images/new-schema-8501d9e7e576be722e3a335942a3a475.png"},3418:(e,A,t)=>{t.d(A,{A:()=>a});const a=""},6341:(e,A,t)=>{t.d(A,{A:()=>a});const a=t.p+"assets/images/payload-timestamp-f3c66893dd165c2646d87dfef87dcd2e.png"},8453:(e,A,t)=>{t.d(A,{R:()=>s,x:()=>r});var a=t(6540);const n={},i=a.createContext(n);function s(e){const A=a.useContext(i);return a.useMemo((function(){return"function"==typeof e?e(A):{...A,...e}}),[A,e])}function r(e){let A;return A=e.disableParentContext?"function"==typeof e.components?e.components(n):e.components||n:s(e.components),a.createElement(i.Provider,{value:A},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/842fc954.6c6b9684.js b/assets/js/842fc954.6c6b9684.js
new file mode 100644
index 0000000..2e86df9
--- /dev/null
+++ b/assets/js/842fc954.6c6b9684.js
@@ -0,0 +1 @@
+"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[4712],{6155:(e,t,A)=>{A.r(t),A.d(t,{assets:()=>d,contentTitle:()=>s,default:()=>l,frontMatter:()=>a,metadata:()=>r,toc:()=>o});var n=A(4848),i=A(8453);const a={sidebar_position:3,sidebar_label:"How to create a schema - setup apllication to ingest certain data"},s="How to create a schema",r={id:"How-to guides/How to create a schema",title:"How to create a schema",description:"Introduction",source:"@site/docs/How-to guides/How to create a schema.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to create a schema",permalink:"/docs/How-to guides/How to create a schema",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:3,frontMatter:{sidebar_position:3,sidebar_label:"How to create a schema - setup apllication to ingest certain data"},sidebar:"tutorialSidebar",previous:{title:"How to register devices",permalink:"/docs/How-to guides/How to register devices"},next:{title:"How to publish device data using MQTT - setup devices to send data",permalink:"/docs/How-to guides/How to publish device data"}},d={},o=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Creating a schema",id:"creating-a-schema",level:2},{value:"Data tranformation",id:"data-tranformation",level:3},{value:"Create a schema using the text editor",id:"create-a-schema-using-the-text-editor",level:2}];function c(e){const t={h1:"h1",h2:"h2",h3:"h3",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,i.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(t.h1,{id:"how-to-create-a-schema",children:"How to create a schema"}),"\n",(0,n.jsx)(t.h2,{id:"introduction",children:"Introduction"}),"\n",(0,n.jsx)(t.p,{children:"When data arrives into Biotz's ingestion system, the received package of data is checked against schemas defined in Biotz. These schemas are the definition of the content of the data package and the user must take care of defining them in the system."}),"\n",(0,n.jsx)(t.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,n.jsx)(t.p,{children:"In order to create a schema having a deceive-type with at least one message type is required. A schema is directly related to device-type, there can be zero to many schemas."}),"\n",(0,n.jsx)(t.h2,{id:"creating-a-schema",children:"Creating a schema"}),"\n",(0,n.jsx)(t.p,{children:"Schemas are created from the Setup > Data ingestion flow > Device-type > Message-type \u201cNew schema\u201d"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"Creating a schema",src:A(3655).A+"",width:"989",height:"461"})})}),"\n",(0,n.jsx)(t.p,{children:"When clicking on \u201cNew schema\u201d an empty schema is created."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"New schema",src:A(764).A+"",width:"989",height:"418"})})}),"\n",(0,n.jsx)(t.p,{children:"First thing will be giving a name to the schema, the purpose of this is just to identify it, it is not further used in the communication or data sending."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(t.p,{children:"After naming the schema the proper and important specification happens under the \u2018Schema definition\u2019 section. It is time to let Biotz know how the sending data is structured. Once \u2018Add new item\u2019 is selected, a set of different item types are offered to cover almost all the data sending options:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"Item types",src:A(3051).A+"",width:"1206",height:"640"})})}),"\n",(0,n.jsxs)(t.p,{children:["Detailed specification of the item types is shared in ",(0,n.jsx)("a",{href:"/docs/Reference guides/Message-type Schema specification",target:"_self",children:"here"}),".\n\u200d"]}),"\n",(0,n.jsxs)(t.ul,{children:["\n",(0,n.jsx)(t.li,{children:"Collection of identical items: collection of more than one identical item. Being an item anything from an object/map/dictionary to singular element as a text, boolean, integer or decimal."}),"\n",(0,n.jsx)(t.li,{children:"Collection of unrelated items: collection of any kind of item, present just once."}),"\n",(0,n.jsx)(t.li,{children:"Object / Map / Dictionary: They are containers of the final properties, as the collection type items. 1 to n items can be added to this one, they are grouped in two types based on the data needed to define them:"}),"\n",(0,n.jsx)(t.li,{children:"Unix timestamp (integer)"}),"\n",(0,n.jsx)(t.li,{children:"Unix timestamp (text)"}),"\n",(0,n.jsx)(t.li,{children:"Unix timestamp RFC-3339"}),"\n",(0,n.jsx)(t.li,{children:"Text"}),"\n",(0,n.jsx)(t.li,{children:"Boolean"}),"\n",(0,n.jsx)(t.li,{children:"Integer"}),"\n",(0,n.jsx)(t.li,{children:"Integer, as text"}),"\n",(0,n.jsx)(t.li,{children:"Integer, as hexadecimal text"}),"\n",(0,n.jsx)(t.li,{children:"Decimal"}),"\n",(0,n.jsx)(t.li,{children:"Decimal, as text"}),"\n"]}),"\n",(0,n.jsx)(t.p,{children:"These are the descriptions of each of the parameters of an item:"}),"\n",(0,n.jsxs)(t.ul,{children:["\n",(0,n.jsx)(t.li,{children:"Item type: the type of the element in the payload."}),"\n",(0,n.jsx)(t.li,{children:"Key name: key name in the object/dictionary."}),"\n",(0,n.jsx)(t.li,{children:"Item name: the name of the column where this data will be stored."}),"\n",(0,n.jsx)(t.li,{children:"Mandatory?"}),"\n",(0,n.jsx)(t.li,{children:"Can be null?"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"parameters",src:A(3418).A+"",width:"979",height:"136"})})}),"\n",(0,n.jsx)(t.p,{children:"Timestamp ones, the same as the rest with an extra one:"}),"\n",(0,n.jsxs)(t.ul,{children:["\n",(0,n.jsx)(t.li,{children:"Payload timestamp?: to be marked if this is the timestamp Biotz should use for the time series date mark."}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"Payload Timestamp",src:A(6341).A+"",width:"979",height:"136"})})}),"\n",(0,n.jsx)(t.h3,{id:"data-tranformation",children:"Data tranformation"}),"\n",(0,n.jsx)(t.p,{children:"This would be a data transformation functionality during ingestion, which now includes advanced options such as the application of scaling and offsetting. This feature allows users to adjust their data more precisely during the ingestion process, this will be applicable to integers and decimals."}),"\n",(0,n.jsx)(t.p,{children:"How to Use the Functionality"}),"\n",(0,n.jsxs)(t.p,{children:[(0,n.jsx)(t.strong,{children:"Step 1: Access the Ingestion Configuration"}),'\nNavigate to the data ingestion module in the Biotz platform.\nSelect the "Data Transformation" option clicking where it says "fx": will only appear on click when having selected, integer, integer as text, integer as hexadecimal text, decimal and decimal as text.']}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"Creating panels",src:A(3986).A+"",width:"528",height:"119"})})}),"\n",(0,n.jsx)(t.p,{children:(0,n.jsx)(t.strong,{children:"Step 2: Define Transformation Rules with Scale and Offset"})}),"\n",(0,n.jsx)(t.p,{children:'Click on "Tranformation type".\nSelect the type of transformation you want to apply, you can only choose scale and offset.\nConfigure the specific parameters of the transformation.'}),"\n",(0,n.jsx)(t.p,{children:"For example:"}),"\n",(0,n.jsx)(t.p,{children:"Scale: 1.5\nOffset: -2\nThis means that each data value will be multiplied by 1.5 and then 2 will be subtracted."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(t.p,{children:(0,n.jsx)(t.img,{alt:"Creating panels",src:A(9569).A+"",width:"692",height:"276"})})}),"\n",(0,n.jsx)(t.p,{children:(0,n.jsx)(t.strong,{children:"Step 3: Apply Transformations"})}),"\n",(0,n.jsx)(t.p,{children:"Associate the defined transformation rules with the data ingestion flow."}),"\n",(0,n.jsx)(t.p,{children:"Once the schema is totally represented the \u2018save\u2019 button will register the schema. This will create the necessary machinery for the data validation and ingestion, it will also create the needed database structure for the data to be stored."}),"\n",(0,n.jsx)(t.h2,{id:"create-a-schema-using-the-text-editor",children:"Create a schema using the text editor"}),"\n",(0,n.jsx)(t.p,{children:"Apart from the interactive user interface to register a schema, there is a editor mode to perform the same task."}),"\n",(0,n.jsx)(t.p,{children:"The editor mode provides a more flexible way of registering a schema, but requires advanced knowledge of the structure it must follow."}),"\n",(0,n.jsx)(t.p,{children:"It can also be used to get a plain text description of the schema that can be copied and saved to local files."}),"\n",(0,n.jsx)(t.p,{children:"The scheme must be a valid schema to be able to 'save' it."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsxs)(t.p,{children:["Next step should be setting up the other piece of the communication, the device. This ",(0,n.jsx)("a",{href:"./How to publish device data",target:"_self",children:"other"}),"\nhow-to guide talks about it."]}),"\n",(0,n.jsx)(t.p,{children:"\u200d"})]})}function l(e={}){const{wrapper:t}={...(0,i.R)(),...e.components};return t?(0,n.jsx)(t,{...e,children:(0,n.jsx)(c,{...e})}):c(e)}},3986:(e,t,A)=>{A.d(t,{A:()=>n});const n=""},3655:(e,t,A)=>{A.d(t,{A:()=>n});const n=A.p+"assets/images/creating-schema-5f711220394c7af9927d860f5f60e65f.png"},3051:(e,t,A)=>{A.d(t,{A:()=>n});const n=A.p+"assets/images/item-types-8cbacb7885eed1e065059a63cb7ac6ea.png"},764:(e,t,A)=>{A.d(t,{A:()=>n});const n=A.p+"assets/images/new-schema-8501d9e7e576be722e3a335942a3a475.png"},3418:(e,t,A)=>{A.d(t,{A:()=>n});const n=""},6341:(e,t,A)=>{A.d(t,{A:()=>n});const n=A.p+"assets/images/payload-timestamp-f3c66893dd165c2646d87dfef87dcd2e.png"},9569:(e,t,A)=>{A.d(t,{A:()=>n});const n=A.p+"assets/images/transformation-bb3024fee6bcec263baabe0e53b8ab6b.png"},8453:(e,t,A)=>{A.d(t,{R:()=>s,x:()=>r});var n=A(6540);const i={},a=n.createContext(i);function s(e){const t=n.useContext(a);return n.useMemo((function(){return"function"==typeof e?e(t):{...t,...e}}),[t,e])}function r(e){let t;return t=e.disableParentContext?"function"==typeof e.components?e.components(i):e.components||i:s(e.components),n.createElement(a.Provider,{value:t},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/f5546e3f.0cc3fb80.js b/assets/js/f5546e3f.00620e30.js
similarity index 60%
rename from assets/js/f5546e3f.0cc3fb80.js
rename to assets/js/f5546e3f.00620e30.js
index 4703622..2a7e4a2 100644
--- a/assets/js/f5546e3f.0cc3fb80.js
+++ b/assets/js/f5546e3f.00620e30.js
@@ -1 +1 @@
-"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[6363],{250:(e,a,i)=>{i.r(a),i.d(a,{assets:()=>d,contentTitle:()=>s,default:()=>o,frontMatter:()=>l,metadata:()=>r,toc:()=>h});var n=i(4848),t=i(8453);const l={sidebar_position:6,sidebar_label:"How to create a dashboard"},s="How to create a dashboard",r={id:"How-to guides/How to create a dashboard",title:"How to create a dashboard",description:"Introduction",source:"@site/docs/How-to guides/How to create a dashboard.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to create a dashboard",permalink:"/docs/How-to guides/How to create a dashboard",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,sidebar_label:"How to create a dashboard"},sidebar:"tutorialSidebar",previous:{title:"How to configure and trigger a remote action in devices",permalink:"/docs/How-to guides/How to configure and trigger a remote action in devices"},next:{title:"How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables"}},d={},h=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Creating a dashboard",id:"creating-a-dashboard",level:2},{value:"Creating panels",id:"creating-panels",level:2},{value:"General information",id:"general-information",level:3},{value:"Configuration",id:"configuration",level:3},{value:"Time series",id:"time-series",level:3},{value:"Query builder",id:"query-builder",level:5},{value:"Appearance",id:"appearance",level:4},{value:"Gauge",id:"gauge",level:3},{value:"Query builder",id:"query-builder-1",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods",level:5},{value:"Appearance",id:"appearance-1",level:4},{value:"Pie chart",id:"pie-chart",level:3},{value:"Query builder",id:"query-builder-2",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods-1",level:4},{value:"Appearance",id:"appearance-2",level:4},{value:"State chart",id:"state-chart",level:3},{value:"Query builder",id:"query-builder-3",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods-2",level:5},{value:"Appearance",id:"appearance-3",level:4},{value:"Device map",id:"device-map",level:3},{value:"Query builder",id:"query-builder-4",level:4},{value:"Query Builder Functionality:",id:"query-builder-functionality",level:5},{value:"Device Type Selection:",id:"device-type-selection",level:5}];function c(e){const a={h1:"h1",h2:"h2",h3:"h3",h4:"h4",h5:"h5",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(a.h1,{id:"how-to-create-a-dashboard",children:"How to create a dashboard"}),"\n",(0,n.jsx)(a.h2,{id:"introduction",children:"Introduction"}),"\n",(0,n.jsx)(a.p,{children:"Biotz provides a dashboarding tool that can be used to visualize the data coming from the devices."}),"\n",(0,n.jsx)(a.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,n.jsx)(a.p,{children:"In order to create a dashboard having a device-type with at least one message type and schema is required. Having a device that has already sent some data is also recommended to visualize the created panels straight away and have a faster feedback loop."}),"\n",(0,n.jsx)(a.h2,{id:"creating-a-dashboard",children:"Creating a dashboard"}),"\n",(0,n.jsx)(a.p,{children:"Dashboards are created from the \u201cDashboards\u201d list. Just a name and an optional description are requested."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Dashboards",src:i(7173).A+"",width:"681",height:"430"})})}),"\n",(0,n.jsx)(a.p,{children:"When clicking on \u201ccreate\u201d an empty dashboard is created."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Empty dashboard",src:i(2968).A+"",width:"1600",height:"460"})})}),"\n",(0,n.jsx)(a.h2,{id:"creating-panels",children:"Creating panels"}),"\n",(0,n.jsx)(a.p,{children:"A dashboard is composed of one or more panels. To create a new one use the \u201cNew panel\u201d button and select the type of panel to create."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"At the moment the available panel types are the following: time-series, pie chart, gauge and device map."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(5395).A+"",width:"1600",height:"698"})})}),"\n",(0,n.jsx)(a.h3,{id:"general-information",children:"General information"}),"\n",(0,n.jsx)(a.p,{children:"Name the panel and optionally set a description."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.h3,{id:"configuration",children:"Configuration"}),"\n",(0,n.jsx)(a.p,{children:"(make this type dependent)"}),"\n",(0,n.jsx)(a.h3,{id:"time-series",children:"Time series"}),"\n",(0,n.jsx)(a.h5,{id:"query-builder",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the panel display. The x-axis will always be the time, and the y axis will contain one or more time-series lines. Each line is defined by an independent query."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"Defining a query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each line in the chart can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each line in the chart can show the data of a single message type attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The method used to aggregate the devices data to adapt the number of displayed points to the user's screen size and zoom level."}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:(0,n.jsx)(a.strong,{children:"Attribute type and Available aggregation methods"})}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, and sum."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count"}),"\n",(0,n.jsx)(a.li,{children:"Text: Count"}),"\n"]}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"The reason for aggregating the data is performance. Lets say a certain device is sending data observations every second, and the user wants to display the data of a whole month. That would result in 2,678,400 data points. Displaying so many data points would be technically impossible for the browser because of the limited amount of pixels that a screen can display. Also, it would be very CPU heavy. To avoid that, the dashboard panel aggregates data to adapt to the screen size and chosen zoom level."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(3618).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.h4,{id:"appearance",children:"Appearance"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7728).A+"",width:"1210",height:"613"})})}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"X axis title"}),"\n",(0,n.jsx)(a.li,{children:"Y axis title"}),"\n",(0,n.jsx)(a.li,{children:"Series appearance (configurable for each of them)"}),"\n",(0,n.jsx)(a.li,{children:"Display name"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n",(0,n.jsx)(a.li,{children:"Dash style"}),"\n",(0,n.jsx)(a.li,{children:"Marker symbol"}),"\n",(0,n.jsx)(a.li,{children:"Enable/disable legend"}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:"This woul be an example of a time series panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7987).A+"",width:"461",height:"335"})})}),"\n",(0,n.jsx)(a.h3,{id:"gauge",children:"Gauge"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-1",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the gauge display. A gauge shows the aggregation of a certain device message-type attribute in the selected time-frame period."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(5736).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each gauge can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each gauge can work with a single attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"attribute-type-and-available-aggregation-methods",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-1",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Min value"}),"\n",(0,n.jsx)(a.li,{children:"Max value"}),"\n",(0,n.jsx)(a.li,{children:"Unit"}),"\n",(0,n.jsx)(a.li,{children:"Thresholds: the gauge can represent multiple threshold values using colors."}),"\n",(0,n.jsx)(a.li,{children:"Percentage"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7710).A+"",width:"1152",height:"299"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an exaple of a gauge panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(2634).A+"",width:"457",height:"317"})})}),"\n",(0,n.jsx)(a.h3,{id:"pie-chart",children:"Pie chart"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-2",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the pie chart display. Each segment of the pie is defined by an independent query that displays the aggregation of a certain device message type attribute."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(4776).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each pie segment can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable\n(see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each pie segment can work with a single attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"attribute-type-and-available-aggregation-methods-1",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-2",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Enable/disable legend"}),"\n",(0,n.jsx)(a.li,{children:"Enable/disable data-labels"}),"\n",(0,n.jsx)(a.li,{children:"Segments appearance"}),"\n",(0,n.jsx)(a.li,{children:"Display name"}),"\n",(0,n.jsx)(a.li,{children:"Color\n\u200d"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(1606).A+"",width:"1152",height:"299"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a pie chart panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(2093).A+"",width:"461",height:"344"})})}),"\n",(0,n.jsx)(a.h3,{id:"state-chart",children:"State chart"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-3",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the state chart display. Each chart can show the data from one variable."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6077).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"attribute-type-and-available-aggregation-methods-2",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-3",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Enable/disable value with unit marker."}),"\n",(0,n.jsx)(a.li,{children:"Conditions for different styles, applies the first that's true"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n",(0,n.jsx)(a.li,{children:"Text to display"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6407).A+"",width:"1164",height:"362"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a state chart panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6331).A+"",width:"462",height:"341"})})}),"\n",(0,n.jsx)(a.h3,{id:"device-map",children:"Device map"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-4",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the device map show."}),"\n",(0,n.jsx)(a.h5,{id:"query-builder-functionality",children:"Query Builder Functionality:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(514).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"In the query builder, you can first choose the type of device or have the option to select all devices. If you choose to select a specific device, you can name the type of device."}),"\n",(0,n.jsx)(a.li,{children:"In the appearance section, you cannot make any changes because The appearance of the panel cannot be configured."}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"device-type-selection",children:"Device Type Selection:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"After choosing the device type you want, you can save the panel, and it should appear on the dashboard with a map and the selected device types."}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a device map panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(7109).A+"",width:"620",height:"451"})})}),"\n",(0,n.jsx)(a.p,{children:"After creating one of these panels, you should select the dashboard for which you have created the panel, and you should see all the panels you have created for that dashboard. The panels vary depending on the type of panel and its configuration."})]})}function o(e={}){const{wrapper:a}={...(0,t.R)(),...e.components};return a?(0,n.jsx)(a,{...e,children:(0,n.jsx)(c,{...e})}):c(e)}},7710:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-gauge-840e14449c4e81361c2e1995628f9b00.png"},1606:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-pie-chart-2de0d52a02b4fefdb8ff5697b1111735.png"},6407:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-state-chart-bb2c541fda01a18ca96f91cfa4c98a74.png"},7728:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-12c7bb21cf25f28de36f919329a9886c.png"},5395:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/creating-panels-d690a4852755653dc95ba94237e71e5f.png"},7173:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/dashboards-fe506ed19f8bd0d7466a73e9365b4df2.png"},7109:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/device-map-c0afd4af6a8f7be21e7e3c0dadafeb59.png"},2968:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/empty-dashboard-8e6228026c297301c9ed2d262d10a1a0.png"},2634:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/gauge-52ae6f7980253334b74409783f763040.png"},2093:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/pie-chart-06c856df0d257654cd544c2195fdfaf4.png"},514:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-device-map-28de35f7a0a6bafea5becce573256993.png"},5736:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-gauge-a8b95a5cb9cf5bca0e31fb40a2bd9d07.png"},4776:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-pie-chart-40b85d3548fd3637e7d2f15e33986bfc.png"},6077:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-state-chart-1bfe6c538aece965dba410358f263839.png"},3618:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-time-series-bddd971e0a35d433ace8721861687447.png"},6331:(e,a,i)=>{i.d(a,{A:()=>n});const n=""},7987:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/time-series-ccd82d7b9d1311e8f87c44192bb9a82d.png"},8453:(e,a,i)=>{i.d(a,{R:()=>s,x:()=>r});var n=i(6540);const t={},l=n.createContext(t);function s(e){const a=n.useContext(l);return n.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function r(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:s(e.components),n.createElement(l.Provider,{value:a},e.children)}}}]);
\ No newline at end of file
+"use strict";(self.webpackChunkacademy=self.webpackChunkacademy||[]).push([[6363],{250:(e,a,i)=>{i.r(a),i.d(a,{assets:()=>d,contentTitle:()=>s,default:()=>o,frontMatter:()=>l,metadata:()=>r,toc:()=>h});var n=i(4848),t=i(8453);const l={sidebar_position:6,sidebar_label:"How to create a dashboard"},s="How to create a dashboard",r={id:"How-to guides/How to create a dashboard",title:"How to create a dashboard",description:"Introduction",source:"@site/docs/How-to guides/How to create a dashboard.md",sourceDirName:"How-to guides",slug:"/How-to guides/How to create a dashboard",permalink:"/docs/How-to guides/How to create a dashboard",draft:!1,unlisted:!1,tags:[],version:"current",sidebarPosition:6,frontMatter:{sidebar_position:6,sidebar_label:"How to create a dashboard"},sidebar:"tutorialSidebar",previous:{title:"How to configure and trigger a remote action in devices",permalink:"/docs/How-to guides/How to configure and trigger a remote action in devices"},next:{title:"How to use dashboard variables",permalink:"/docs/How-to guides/How to use dashboard variables"}},d={},h=[{value:"Introduction",id:"introduction",level:2},{value:"Prerequisites",id:"prerequisites",level:2},{value:"Creating a dashboard",id:"creating-a-dashboard",level:2},{value:"Creating panels",id:"creating-panels",level:2},{value:"General information",id:"general-information",level:3},{value:"Configuration",id:"configuration",level:3},{value:"Time series",id:"time-series",level:3},{value:"Query builder",id:"query-builder",level:5},{value:"Appearance",id:"appearance",level:4},{value:"Gauge",id:"gauge",level:3},{value:"Query builder",id:"query-builder-1",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods",level:5},{value:"Appearance",id:"appearance-1",level:4},{value:"Pie chart",id:"pie-chart",level:3},{value:"Query builder",id:"query-builder-2",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods-1",level:4},{value:"Appearance",id:"appearance-2",level:4},{value:"State chart",id:"state-chart",level:3},{value:"Query builder",id:"query-builder-3",level:4},{value:"Attribute type and Available aggregation methods",id:"attribute-type-and-available-aggregation-methods-2",level:5},{value:"Appearance",id:"appearance-3",level:4},{value:"Device map",id:"device-map",level:3},{value:"Query builder",id:"query-builder-4",level:4},{value:"Query Builder Functionality:",id:"query-builder-functionality",level:5},{value:"Device Type Selection:",id:"device-type-selection",level:5}];function c(e){const a={h1:"h1",h2:"h2",h3:"h3",h4:"h4",h5:"h5",img:"img",li:"li",p:"p",strong:"strong",ul:"ul",...(0,t.R)(),...e.components};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(a.h1,{id:"how-to-create-a-dashboard",children:"How to create a dashboard"}),"\n",(0,n.jsx)(a.h2,{id:"introduction",children:"Introduction"}),"\n",(0,n.jsx)(a.p,{children:"Biotz provides a dashboarding tool that can be used to visualize the data coming from the devices."}),"\n",(0,n.jsx)(a.h2,{id:"prerequisites",children:"Prerequisites"}),"\n",(0,n.jsx)(a.p,{children:"In order to create a dashboard having a device-type with at least one message type and schema is required. Having a device that has already sent some data is also recommended to visualize the created panels straight away and have a faster feedback loop."}),"\n",(0,n.jsx)(a.h2,{id:"creating-a-dashboard",children:"Creating a dashboard"}),"\n",(0,n.jsx)(a.p,{children:"Dashboards are created from the \u201cDashboards\u201d list. Just a name and an optional description are requested."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Dashboards",src:i(7173).A+"",width:"681",height:"430"})})}),"\n",(0,n.jsx)(a.p,{children:"When clicking on \u201ccreate\u201d an empty dashboard is created."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Empty dashboard",src:i(2968).A+"",width:"1600",height:"460"})})}),"\n",(0,n.jsx)(a.h2,{id:"creating-panels",children:"Creating panels"}),"\n",(0,n.jsx)(a.p,{children:"A dashboard is composed of one or more panels. To create a new one use the \u201cNew panel\u201d button and select the type of panel to create."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"At the moment the available panel types are the following: time-series, pie chart, gauge and device map."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(5395).A+"",width:"1600",height:"698"})})}),"\n",(0,n.jsx)(a.h3,{id:"general-information",children:"General information"}),"\n",(0,n.jsx)(a.p,{children:"Name the panel and optionally set a description."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.h3,{id:"configuration",children:"Configuration"}),"\n",(0,n.jsx)(a.p,{children:"(make this type dependent)"}),"\n",(0,n.jsx)(a.h3,{id:"time-series",children:"Time series"}),"\n",(0,n.jsx)(a.h5,{id:"query-builder",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the panel display. The x-axis will always be the time, and the y axis will contain one or more time-series lines. Each line is defined by an independent query."}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"Defining a query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each line in the chart can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each line in the chart can show the data of a single message type attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The method used to aggregate the devices data to adapt the number of displayed points to the user's screen size and zoom level."}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:(0,n.jsx)(a.strong,{children:"Attribute type and Available aggregation methods"})}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, and sum."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count"}),"\n",(0,n.jsx)(a.li,{children:"Text: Count"}),"\n"]}),"\n",(0,n.jsx)("br",{}),"\n",(0,n.jsx)(a.p,{children:"The reason for aggregating the data is performance. Lets say a certain device is sending data observations every second, and the user wants to display the data of a whole month. That would result in 2,678,400 data points. Displaying so many data points would be technically impossible for the browser because of the limited amount of pixels that a screen can display. Also, it would be very CPU heavy. To avoid that, the dashboard panel aggregates data to adapt to the screen size and chosen zoom level."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(3618).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.h4,{id:"appearance",children:"Appearance"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7728).A+"",width:"1210",height:"613"})})}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"X axis title"}),"\n",(0,n.jsx)(a.li,{children:"Y axis title"}),"\n",(0,n.jsx)(a.li,{children:"Series appearance (configurable for each of them)"}),"\n",(0,n.jsx)(a.li,{children:"Display name"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n",(0,n.jsx)(a.li,{children:"Dash style"}),"\n",(0,n.jsx)(a.li,{children:"Marker symbol"}),"\n",(0,n.jsx)(a.li,{children:"Enable/disable legend"}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:"This woul be an example of a time series panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7987).A+"",width:"461",height:"335"})})}),"\n",(0,n.jsx)(a.h3,{id:"gauge",children:"Gauge"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-1",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the gauge display. A gauge shows the aggregation of a certain device message-type attribute in the selected time-frame period."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(5736).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each gauge can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each gauge can work with a single attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"attribute-type-and-available-aggregation-methods",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-1",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Min value"}),"\n",(0,n.jsx)(a.li,{children:"Max value"}),"\n",(0,n.jsx)(a.li,{children:"Unit"}),"\n",(0,n.jsx)(a.li,{children:"Thresholds: the gauge can represent multiple threshold values using colors."}),"\n",(0,n.jsx)(a.li,{children:"Percentage"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(7710).A+"",width:"1152",height:"299"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an exaple of a gauge panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(2634).A+"",width:"457",height:"317"})})}),"\n",(0,n.jsx)(a.h3,{id:"pie-chart",children:"Pie chart"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-2",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the pie chart display. Each segment of the pie is defined by an independent query that displays the aggregation of a certain device message type attribute."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(4776).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. Each pie segment can show the data of a single device. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable\n(see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute. Each pie segment can work with a single attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"attribute-type-and-available-aggregation-methods-1",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-2",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Enable/disable legend"}),"\n",(0,n.jsx)(a.li,{children:"Enable/disable data-labels"}),"\n",(0,n.jsx)(a.li,{children:"Segments appearance"}),"\n",(0,n.jsx)(a.li,{children:"Display name"}),"\n",(0,n.jsx)(a.li,{children:"Color\n\u200d"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(1606).A+"",width:"1152",height:"299"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a pie chart panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(2093).A+"",width:"461",height:"344"})})}),"\n",(0,n.jsx)(a.h3,{id:"state-chart",children:"State chart"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-3",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the state chart display. Each chart can show the data from one variable."}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6077).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsxs)(a.li,{children:["Selecting a device or device variable. The device to be used can be fixed and defined at panel creation time, or determined by a dashboard variable (see ",(0,n.jsx)("a",{href:"./How to use dashboard variables",target:"_self",children:"this"})," for more info)."]}),"\n",(0,n.jsx)(a.li,{children:"Message type and attribute."}),"\n",(0,n.jsx)(a.li,{children:"Aggregation method. The data for the selected device and attribute will be aggregated using this method. Note that the special \u201cfirst\u201d and \u201clast\u201d aggregation methods are also available that show a single data point.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"attribute-type-and-available-aggregation-methods-2",children:"Attribute type and Available aggregation methods"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Numeric: Count, maximum, minimum, mean, standard deviation, sum, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Boolean: Count, first and last."}),"\n",(0,n.jsx)(a.li,{children:"Text: Count, first and last.\n\u200d"}),"\n"]}),"\n",(0,n.jsx)(a.h4,{id:"appearance-3",children:"Appearance"}),"\n",(0,n.jsx)(a.p,{children:"The following appearance related options are available:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"Enable/disable value with unit marker."}),"\n",(0,n.jsx)(a.li,{children:"Conditions for different styles, applies the first that's true"}),"\n",(0,n.jsx)(a.li,{children:"Color"}),"\n",(0,n.jsx)(a.li,{children:"Text to display"}),"\n"]}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6407).A+"",width:"1164",height:"362"})})}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a state chart panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"appearance",src:i(6331).A+"",width:"462",height:"341"})})}),"\n",(0,n.jsx)(a.h3,{id:"device-map",children:"Device map"}),"\n",(0,n.jsx)(a.h4,{id:"query-builder-4",children:"Query builder"}),"\n",(0,n.jsx)(a.p,{children:"The query builder is used to define which data will the device map show."}),"\n",(0,n.jsx)(a.h5,{id:"query-builder-functionality",children:"Query Builder Functionality:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(514).A+"",width:"1162",height:"462"})})}),"\n",(0,n.jsx)(a.p,{children:"Defining the query requires the following configuration:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"In the query builder, you can first choose the type of device or have the option to select all devices. If you choose to select a specific device, you can name the type of device."}),"\n",(0,n.jsx)(a.li,{children:"In the appearance section, you cannot make any changes because The appearance of the panel cannot be configured."}),"\n"]}),"\n",(0,n.jsx)(a.h5,{id:"device-type-selection",children:"Device Type Selection:"}),"\n",(0,n.jsxs)(a.ul,{children:["\n",(0,n.jsx)(a.li,{children:"After choosing the device type you want, you can save the panel, and it should appear on the dashboard with a map and the selected device types."}),"\n"]}),"\n",(0,n.jsx)(a.p,{children:"This would be an example of a device map panel:"}),"\n",(0,n.jsx)("div",{class:"tutorial-image-container",children:(0,n.jsx)(a.p,{children:(0,n.jsx)(a.img,{alt:"Creating panels",src:i(7109).A+"",width:"620",height:"451"})})}),"\n",(0,n.jsx)(a.p,{children:"After creating one of these panels, you should select the dashboard for which you have created the panel, and you should see all the panels you have created for that dashboard. The panels vary depending on the type of panel and its configuration.\nd"})]})}function o(e={}){const{wrapper:a}={...(0,t.R)(),...e.components};return a?(0,n.jsx)(a,{...e,children:(0,n.jsx)(c,{...e})}):c(e)}},7710:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-gauge-840e14449c4e81361c2e1995628f9b00.png"},1606:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-pie-chart-2de0d52a02b4fefdb8ff5697b1111735.png"},6407:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-state-chart-bb2c541fda01a18ca96f91cfa4c98a74.png"},7728:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/appearance-12c7bb21cf25f28de36f919329a9886c.png"},5395:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/creating-panels-d690a4852755653dc95ba94237e71e5f.png"},7173:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/dashboards-fe506ed19f8bd0d7466a73e9365b4df2.png"},7109:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/device-map-c0afd4af6a8f7be21e7e3c0dadafeb59.png"},2968:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/empty-dashboard-8e6228026c297301c9ed2d262d10a1a0.png"},2634:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/gauge-52ae6f7980253334b74409783f763040.png"},2093:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/pie-chart-06c856df0d257654cd544c2195fdfaf4.png"},514:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-device-map-28de35f7a0a6bafea5becce573256993.png"},5736:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-gauge-a8b95a5cb9cf5bca0e31fb40a2bd9d07.png"},4776:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-pie-chart-40b85d3548fd3637e7d2f15e33986bfc.png"},6077:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-state-chart-1bfe6c538aece965dba410358f263839.png"},3618:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/query-builder-time-series-bddd971e0a35d433ace8721861687447.png"},6331:(e,a,i)=>{i.d(a,{A:()=>n});const n=""},7987:(e,a,i)=>{i.d(a,{A:()=>n});const n=i.p+"assets/images/time-series-ccd82d7b9d1311e8f87c44192bb9a82d.png"},8453:(e,a,i)=>{i.d(a,{R:()=>s,x:()=>r});var n=i(6540);const t={},l=n.createContext(t);function s(e){const a=n.useContext(l);return n.useMemo((function(){return"function"==typeof e?e(a):{...a,...e}}),[a,e])}function r(e){let a;return a=e.disableParentContext?"function"==typeof e.components?e.components(t):e.components||t:s(e.components),n.createElement(l.Provider,{value:a},e.children)}}}]);
\ No newline at end of file
diff --git a/assets/js/runtime~main.f83e6d4d.js b/assets/js/runtime~main.95748654.js
similarity index 93%
rename from assets/js/runtime~main.f83e6d4d.js
rename to assets/js/runtime~main.95748654.js
index 5493afc..5ac38b3 100644
--- a/assets/js/runtime~main.f83e6d4d.js
+++ b/assets/js/runtime~main.95748654.js
@@ -1 +1 @@
-(()=>{"use strict";var e,a,f,t,r,c={},b={};function d(e){var a=b[e];if(void 0!==a)return a.exports;var f=b[e]={exports:{}};return c[e].call(f.exports,f,f.exports,d),f.exports}d.m=c,e=[],d.O=(a,f,t,r)=>{if(!f){var c=1/0;for(i=0;i=r)&&Object.keys(d.O).every((e=>d.O[e](f[o])))?f.splice(o--,1):(b=!1,r0&&e[i-1][2]>r;i--)e[i]=e[i-1];e[i]=[f,t,r]},d.n=e=>{var a=e&&e.__esModule?()=>e.default:()=>e;return d.d(a,{a:a}),a},f=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,d.t=function(e,t){if(1&t&&(e=this(e)),8&t)return e;if("object"==typeof e&&e){if(4&t&&e.__esModule)return e;if(16&t&&"function"==typeof e.then)return e}var r=Object.create(null);d.r(r);var c={};a=a||[null,f({}),f([]),f(f)];for(var b=2&t&&e;"object"==typeof b&&!~a.indexOf(b);b=f(b))Object.getOwnPropertyNames(b).forEach((a=>c[a]=()=>e[a]));return c.default=()=>e,d.d(r,c),r},d.d=(e,a)=>{for(var f in a)d.o(a,f)&&!d.o(e,f)&&Object.defineProperty(e,f,{enumerable:!0,get:a[f]})},d.f={},d.e=e=>Promise.all(Object.keys(d.f).reduce(((a,f)=>(d.f[f](e,a),a)),[])),d.u=e=>"assets/js/"+({635:"b9a9e23a",748:"94375d41",1471:"de5aeb7c",1563:"e72b9bb3",1943:"519f47fb",1981:"1be0d2c3",2710:"e829bf52",2741:"8ebf884c",2750:"356a0ac6",3093:"3f776845",3338:"b5796db6",3438:"fbacb533",3473:"3c01fd32",3488:"8cb4ad27",3576:"3987870c",3590:"578ed02f",3832:"8f9e59a2",4224:"a5caed1a",4246:"f59d81ac",4300:"4cd738bd",4502:"4a070847",4541:"c4c20b15",4583:"1df93b7f",4712:"842fc954",4972:"bde2094a",5331:"c16f5663",5794:"303209e1",5968:"15c5b2e6",6061:"1f391b9e",6246:"498d4d26",6271:"ffd52dfa",6363:"f5546e3f",6583:"a165d0ef",6759:"f9aaae36",6875:"f760b48e",6969:"14eb3368",7098:"a7bd4aaa",8360:"0fea52e5",8401:"17896441",8581:"935f2afb",8767:"142bacfa",8837:"9fb72dca",8962:"4f6f0beb",9048:"a94703ab",9118:"ca79eafe",9476:"4ac74e3d",9647:"5e95c892",9814:"75a8a8f3"}[e]||e)+"."+{635:"0715ae2a",748:"58b4f9bf",1471:"d8e470f0",1563:"bd1a796a",1943:"4530d296",1981:"35e761f5",2237:"29ed07f9",2674:"862bdbf7",2710:"58752515",2741:"c2e474fa",2750:"b39a960b",3093:"3ae09d59",3338:"fe390bd2",3438:"e8c76029",3473:"6488b8bc",3488:"4e682ddc",3576:"c97af649",3590:"39c8bd1e",3832:"c87ee121",4224:"02237783",4246:"1e53bf09",4300:"ac79276c",4502:"9d22865b",4541:"a5e71ddc",4583:"b93928f5",4712:"6284c7eb",4972:"e94c9456",5331:"4338ba60",5794:"eb67fee4",5968:"571daa57",6061:"80ff34b9",6246:"6cc742f9",6271:"98e8f274",6363:"0cc3fb80",6583:"8616763f",6759:"f7588003",6875:"6860c039",6969:"9f439c7c",7098:"b2fb0e4e",8360:"59041bec",8401:"817d95ee",8581:"8eb606ef",8767:"38bd8473",8837:"82319d32",8962:"9af595e2",9048:"d2a4c9ab",9118:"585b4089",9476:"a9595a26",9647:"1ae668ac",9814:"587827f2"}[e]+".js",d.miniCssF=e=>{},d.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),d.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),t={},r="academy:",d.l=(e,a,f,c)=>{if(t[e])t[e].push(a);else{var b,o;if(void 0!==f)for(var n=document.getElementsByTagName("script"),i=0;i{b.onerror=b.onload=null,clearTimeout(s);var r=t[e];if(delete t[e],b.parentNode&&b.parentNode.removeChild(b),r&&r.forEach((e=>e(f))),a)return a(f)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:b}),12e4);b.onerror=l.bind(null,b.onerror),b.onload=l.bind(null,b.onload),o&&document.head.appendChild(b)}},d.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},d.p="/",d.gca=function(e){return e={17896441:"8401",b9a9e23a:"635","94375d41":"748",de5aeb7c:"1471",e72b9bb3:"1563","519f47fb":"1943","1be0d2c3":"1981",e829bf52:"2710","8ebf884c":"2741","356a0ac6":"2750","3f776845":"3093",b5796db6:"3338",fbacb533:"3438","3c01fd32":"3473","8cb4ad27":"3488","3987870c":"3576","578ed02f":"3590","8f9e59a2":"3832",a5caed1a:"4224",f59d81ac:"4246","4cd738bd":"4300","4a070847":"4502",c4c20b15:"4541","1df93b7f":"4583","842fc954":"4712",bde2094a:"4972",c16f5663:"5331","303209e1":"5794","15c5b2e6":"5968","1f391b9e":"6061","498d4d26":"6246",ffd52dfa:"6271",f5546e3f:"6363",a165d0ef:"6583",f9aaae36:"6759",f760b48e:"6875","14eb3368":"6969",a7bd4aaa:"7098","0fea52e5":"8360","935f2afb":"8581","142bacfa":"8767","9fb72dca":"8837","4f6f0beb":"8962",a94703ab:"9048",ca79eafe:"9118","4ac74e3d":"9476","5e95c892":"9647","75a8a8f3":"9814"}[e]||e,d.p+d.u(e)},(()=>{var e={5354:0,1869:0};d.f.j=(a,f)=>{var t=d.o(e,a)?e[a]:void 0;if(0!==t)if(t)f.push(t[2]);else if(/^(1869|5354)$/.test(a))e[a]=0;else{var r=new Promise(((f,r)=>t=e[a]=[f,r]));f.push(t[2]=r);var c=d.p+d.u(a),b=new Error;d.l(c,(f=>{if(d.o(e,a)&&(0!==(t=e[a])&&(e[a]=void 0),t)){var r=f&&("load"===f.type?"missing":f.type),c=f&&f.target&&f.target.src;b.message="Loading chunk "+a+" failed.\n("+r+": "+c+")",b.name="ChunkLoadError",b.type=r,b.request=c,t[1](b)}}),"chunk-"+a,a)}},d.O.j=a=>0===e[a];var a=(a,f)=>{var t,r,c=f[0],b=f[1],o=f[2],n=0;if(c.some((a=>0!==e[a]))){for(t in b)d.o(b,t)&&(d.m[t]=b[t]);if(o)var i=o(d)}for(a&&a(f);n{"use strict";var e,a,f,t,r,c={},b={};function d(e){var a=b[e];if(void 0!==a)return a.exports;var f=b[e]={exports:{}};return c[e].call(f.exports,f,f.exports,d),f.exports}d.m=c,e=[],d.O=(a,f,t,r)=>{if(!f){var c=1/0;for(i=0;i=r)&&Object.keys(d.O).every((e=>d.O[e](f[o])))?f.splice(o--,1):(b=!1,r0&&e[i-1][2]>r;i--)e[i]=e[i-1];e[i]=[f,t,r]},d.n=e=>{var a=e&&e.__esModule?()=>e.default:()=>e;return d.d(a,{a:a}),a},f=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,d.t=function(e,t){if(1&t&&(e=this(e)),8&t)return e;if("object"==typeof e&&e){if(4&t&&e.__esModule)return e;if(16&t&&"function"==typeof e.then)return e}var r=Object.create(null);d.r(r);var c={};a=a||[null,f({}),f([]),f(f)];for(var b=2&t&&e;"object"==typeof b&&!~a.indexOf(b);b=f(b))Object.getOwnPropertyNames(b).forEach((a=>c[a]=()=>e[a]));return c.default=()=>e,d.d(r,c),r},d.d=(e,a)=>{for(var f in a)d.o(a,f)&&!d.o(e,f)&&Object.defineProperty(e,f,{enumerable:!0,get:a[f]})},d.f={},d.e=e=>Promise.all(Object.keys(d.f).reduce(((a,f)=>(d.f[f](e,a),a)),[])),d.u=e=>"assets/js/"+({635:"b9a9e23a",748:"94375d41",1471:"de5aeb7c",1563:"e72b9bb3",1943:"519f47fb",1981:"1be0d2c3",2710:"e829bf52",2741:"8ebf884c",2750:"356a0ac6",3093:"3f776845",3338:"b5796db6",3438:"fbacb533",3473:"3c01fd32",3488:"8cb4ad27",3576:"3987870c",3590:"578ed02f",3832:"8f9e59a2",4224:"a5caed1a",4246:"f59d81ac",4300:"4cd738bd",4502:"4a070847",4541:"c4c20b15",4583:"1df93b7f",4712:"842fc954",4972:"bde2094a",5331:"c16f5663",5794:"303209e1",5968:"15c5b2e6",6061:"1f391b9e",6246:"498d4d26",6271:"ffd52dfa",6363:"f5546e3f",6583:"a165d0ef",6759:"f9aaae36",6875:"f760b48e",6969:"14eb3368",7098:"a7bd4aaa",8360:"0fea52e5",8401:"17896441",8581:"935f2afb",8767:"142bacfa",8837:"9fb72dca",8962:"4f6f0beb",9048:"a94703ab",9118:"ca79eafe",9476:"4ac74e3d",9647:"5e95c892",9814:"75a8a8f3"}[e]||e)+"."+{635:"0715ae2a",748:"58b4f9bf",1471:"d8e470f0",1563:"bd1a796a",1943:"4530d296",1981:"35e761f5",2237:"29ed07f9",2674:"862bdbf7",2710:"58752515",2741:"c2e474fa",2750:"b39a960b",3093:"3ae09d59",3338:"fe390bd2",3438:"e8c76029",3473:"6488b8bc",3488:"4e682ddc",3576:"c97af649",3590:"39c8bd1e",3832:"c87ee121",4224:"02237783",4246:"1e53bf09",4300:"ac79276c",4502:"9d22865b",4541:"a5e71ddc",4583:"b93928f5",4712:"6c6b9684",4972:"e94c9456",5331:"4338ba60",5794:"eb67fee4",5968:"571daa57",6061:"80ff34b9",6246:"029a96c8",6271:"98e8f274",6363:"00620e30",6583:"8616763f",6759:"f7588003",6875:"6860c039",6969:"9f439c7c",7098:"b2fb0e4e",8360:"59041bec",8401:"817d95ee",8581:"8eb606ef",8767:"38bd8473",8837:"82319d32",8962:"9af595e2",9048:"d2a4c9ab",9118:"585b4089",9476:"a9595a26",9647:"1ae668ac",9814:"ccbfd68f"}[e]+".js",d.miniCssF=e=>{},d.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),d.o=(e,a)=>Object.prototype.hasOwnProperty.call(e,a),t={},r="academy:",d.l=(e,a,f,c)=>{if(t[e])t[e].push(a);else{var b,o;if(void 0!==f)for(var n=document.getElementsByTagName("script"),i=0;i{b.onerror=b.onload=null,clearTimeout(s);var r=t[e];if(delete t[e],b.parentNode&&b.parentNode.removeChild(b),r&&r.forEach((e=>e(f))),a)return a(f)},s=setTimeout(l.bind(null,void 0,{type:"timeout",target:b}),12e4);b.onerror=l.bind(null,b.onerror),b.onload=l.bind(null,b.onload),o&&document.head.appendChild(b)}},d.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},d.p="/",d.gca=function(e){return e={17896441:"8401",b9a9e23a:"635","94375d41":"748",de5aeb7c:"1471",e72b9bb3:"1563","519f47fb":"1943","1be0d2c3":"1981",e829bf52:"2710","8ebf884c":"2741","356a0ac6":"2750","3f776845":"3093",b5796db6:"3338",fbacb533:"3438","3c01fd32":"3473","8cb4ad27":"3488","3987870c":"3576","578ed02f":"3590","8f9e59a2":"3832",a5caed1a:"4224",f59d81ac:"4246","4cd738bd":"4300","4a070847":"4502",c4c20b15:"4541","1df93b7f":"4583","842fc954":"4712",bde2094a:"4972",c16f5663:"5331","303209e1":"5794","15c5b2e6":"5968","1f391b9e":"6061","498d4d26":"6246",ffd52dfa:"6271",f5546e3f:"6363",a165d0ef:"6583",f9aaae36:"6759",f760b48e:"6875","14eb3368":"6969",a7bd4aaa:"7098","0fea52e5":"8360","935f2afb":"8581","142bacfa":"8767","9fb72dca":"8837","4f6f0beb":"8962",a94703ab:"9048",ca79eafe:"9118","4ac74e3d":"9476","5e95c892":"9647","75a8a8f3":"9814"}[e]||e,d.p+d.u(e)},(()=>{var e={5354:0,1869:0};d.f.j=(a,f)=>{var t=d.o(e,a)?e[a]:void 0;if(0!==t)if(t)f.push(t[2]);else if(/^(1869|5354)$/.test(a))e[a]=0;else{var r=new Promise(((f,r)=>t=e[a]=[f,r]));f.push(t[2]=r);var c=d.p+d.u(a),b=new Error;d.l(c,(f=>{if(d.o(e,a)&&(0!==(t=e[a])&&(e[a]=void 0),t)){var r=f&&("load"===f.type?"missing":f.type),c=f&&f.target&&f.target.src;b.message="Loading chunk "+a+" failed.\n("+r+": "+c+")",b.name="ChunkLoadError",b.type=r,b.request=c,t[1](b)}}),"chunk-"+a,a)}},d.O.j=a=>0===e[a];var a=(a,f)=>{var t,r,c=f[0],b=f[1],o=f[2],n=0;if(c.some((a=>0!==e[a]))){for(t in b)d.o(b,t)&&(d.m[t]=b[t]);if(o)var i=o(d)}for(a&&a(f);nIntro | Biotz Academy
-
+
diff --git a/docs/Examples/MQTTX/MQTTX configuration.html b/docs/Examples/MQTTX/MQTTX configuration.html
index 3f503b9..4bb0902 100644
--- a/docs/Examples/MQTTX/MQTTX configuration.html
+++ b/docs/Examples/MQTTX/MQTTX configuration.html
@@ -4,7 +4,7 @@
MQTTX configuration | Biotz Academy
-
+
diff --git a/docs/Examples/MQTTX/MQttx instalation.html b/docs/Examples/MQTTX/MQttx instalation.html
index 5c7dc45..0665401 100644
--- a/docs/Examples/MQTTX/MQttx instalation.html
+++ b/docs/Examples/MQTTX/MQttx instalation.html
@@ -4,7 +4,7 @@
MQttx instalation | Biotz Academy
-
+
diff --git a/docs/Examples/MQTTX/Message.html b/docs/Examples/MQTTX/Message.html
index d700bf9..05676d7 100644
--- a/docs/Examples/MQTTX/Message.html
+++ b/docs/Examples/MQTTX/Message.html
@@ -4,7 +4,7 @@
Publish data to Biotz | Biotz Academy
-
+
diff --git a/docs/Examples/POSTMAN/Getting the token.html b/docs/Examples/POSTMAN/Getting the token.html
index 766ec9c..c3466ff 100644
--- a/docs/Examples/POSTMAN/Getting the token.html
+++ b/docs/Examples/POSTMAN/Getting the token.html
@@ -4,7 +4,7 @@
Getting the token | Biotz Academy
-
+
diff --git a/docs/Examples/POSTMAN/Intro.html b/docs/Examples/POSTMAN/Intro.html
index cd45541..0594970 100644
--- a/docs/Examples/POSTMAN/Intro.html
+++ b/docs/Examples/POSTMAN/Intro.html
@@ -4,7 +4,7 @@
Intro | Biotz Academy
-
+
diff --git a/docs/Examples/POSTMAN/Postman instalation.html b/docs/Examples/POSTMAN/Postman instalation.html
index 0e12438..fd35042 100644
--- a/docs/Examples/POSTMAN/Postman instalation.html
+++ b/docs/Examples/POSTMAN/Postman instalation.html
@@ -4,7 +4,7 @@
Postman instalation | Biotz Academy
-
+
diff --git a/docs/Examples/POSTMAN/Sending the request.html b/docs/Examples/POSTMAN/Sending the request.html
index 7b8a90c..3d96a07 100644
--- a/docs/Examples/POSTMAN/Sending the request.html
+++ b/docs/Examples/POSTMAN/Sending the request.html
@@ -4,7 +4,7 @@
Sending the request | Biotz Academy
-
+
diff --git a/docs/How-to guides/How to configure and trigger a remote action in devices.html b/docs/How-to guides/How to configure and trigger a remote action in devices.html
index 47491d0..63fdd9d 100644
--- a/docs/How-to guides/How to configure and trigger a remote action in devices.html
+++ b/docs/How-to guides/How to configure and trigger a remote action in devices.html
@@ -4,7 +4,7 @@
Configure and trigger a 'remote actioning' | Biotz Academy
-
+
diff --git a/docs/How-to guides/How to create a dashboard.html b/docs/How-to guides/How to create a dashboard.html
index 3a9cc44..96ca0da 100644
--- a/docs/How-to guides/How to create a dashboard.html
+++ b/docs/How-to guides/How to create a dashboard.html
@@ -4,7 +4,7 @@
How to create a dashboard | Biotz Academy
-
+
@@ -170,7 +170,8 @@
Device
This would be an example of a device map panel:
-
After creating one of these panels, you should select the dashboard for which you have created the panel, and you should see all the panels you have created for that dashboard. The panels vary depending on the type of panel and its configuration.