From ac612775f377e7ca2f11b0af3070a5a0e7b5d2a0 Mon Sep 17 00:00:00 2001 From: Till Steinbach Date: Sun, 6 Mar 2022 20:21:14 +0100 Subject: [PATCH] fix warning for hybrid cars --- grafana/dashboards/vwsfriend/VWsFriend/overview.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/grafana/dashboards/vwsfriend/VWsFriend/overview.json b/grafana/dashboards/vwsfriend/VWsFriend/overview.json index 99eb78bc..3d7fa28a 100644 --- a/grafana/dashboards/vwsfriend/VWsFriend/overview.json +++ b/grafana/dashboards/vwsfriend/VWsFriend/overview.json @@ -46,7 +46,7 @@ "editable": true, "fiscalYearStartMonth": 0, "graphTooltip": 1, - "iteration": 1646511156133, + "iteration": 1646594325117, "links": [ { "asDropdown": false, @@ -1182,7 +1182,7 @@ "html": "
\n
\n

Warnings:

\n
    \n
      \n
\n\n
\n

News:

\n
\n\n
\n

Recent Events:

\n
    \n
      \n
\n
", "onInit": "", "onInitOnResize": false, - "onRender": "const warningsDiv = htmlNode.getElementById('warningsDiv');\nconst warningsList = htmlNode.getElementById('warningsList');\nwarningsDiv.style.display = 'none'\nwhile (warningsList.firstChild) {\n warningsList.firstChild.remove()\n}\nconst logsDiv = htmlNode.getElementById('logDiv');\nconst logsList = htmlNode.getElementById('logsList');\nlogsDiv.style.display = 'none'\nwhile (logsList.firstChild) {\n logsList.firstChild.remove()\n}\n\nfunction addWarning(html) {\n warningsDiv.style.display = ''\n warning = document.createElement(\"li\")\n warning.style.color = 'yellow'\n var template = document.createElement('template');\n html = html.trim();\n template.innerHTML = html;\n warning.append(template.content);\n warningsList.appendChild(warning)\n}\n\nfunction addLog(html) {\n logsDiv.style.display = ''\n log = document.createElement(\"li\")\n var template = document.createElement('template');\n html = html.trim();\n template.innerHTML = html;\n log.append(template.content);\n logsList.appendChild(log)\n}\n\nfunction getMetric(seriesName, metricName) {\n const filteredSeries = data.series.filter((series) => series.refId == seriesName);\n if(filteredSeries.length > 0 && filteredSeries[0].fields != null\n && filteredSeries[0].fields.length > 0){\n const filteredFields = filteredSeries[0].fields.filter((fields) => fields.name == metricName)\n if(filteredFields.length > 0){\n return filteredFields[0].values.get(0)\n }\n }\n return null\n}\n\nconst vwsfriend_url = getTemplateSrv().replace(`$vwsfriend_url`);\nconst vin = getTemplateSrv().replace(`$VIN`);\nif(vwsfriend_url == null || vwsfriend_url== ''){\n addWarning(\"You have to set the URL for the VWsFriend user interface correctly: Go to the user interface on port 4000 and select \\\"Database\\\" > \\”Connection Settings\\\"\")\n}\n\nconst carType = getMetric('vehicle_settings', 'carType')\nconst nickname = getMetric('vehicle_settings', 'nickname')\nconst primaryCapacity = getMetric('vehicle_settings', 'primary_capacity')\nconst primaryCapacityTotal = getMetric('vehicle_settings', 'primary_capacity_total')\nconst secondaryCapacity = getMetric('vehicle_settings', 'secondary_capacity')\nconst secondaryCapacityTotal = getMetric('vehicle_settings', 'secondary_capacity_total')\n\nif(carType == null){\n addWarning(\"The engine type of \"+nickname+\" could not be detected yet. This should happen soon when receiving data.\")\n}\nelse{\n switch (carType) {\n case 'HYBRID':\n if(primaryCapacity == null || primaryCapacityTotal == null){\n addWarning(\"Some panels need the tank size of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n if(secondaryCapacity == null || secondaryCapacityTotal == null){\n addWarning(\"Some panels need the battery capacity of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n break;\n default:\n if(primaryCapacity == null || primaryCapacityTotal == null){\n addWarning(\"Some panels need the battery capacity of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n break;\n }\n}\nconst hasError = getMetric('error', 'has_error')\nif(hasError){\n addWarning(\"There were more then two errors in the last 30 minutes when fetching data from the servers.
It seems that there are technical issues.\")\n}\n\n//Log\nconst filteredSeries = data.series.filter((series) => series.refId == 'log');\n if(filteredSeries.length > 0 && filteredSeries[0].fields != null\n && filteredSeries[0].fields.length > 0){\n const filteredFields = filteredSeries[0].fields.filter((fields) => (fields.name == 'logtime' || fields.name == 'log'))\n timeZone = htmlGraphics.props.timeZone;\n if(filteredFields.length == 2){\n time = filteredFields[0];\n logstring = filteredFields[1];\n var options = { dateStyle: 'short' };\n if(timeZone!='browser'){\n options.timeZone = timeZone;\n }\n var timeOptions = { timeStyle: 'short' };\n if(timeZone!='browser'){\n timeOptions.timeZone = timeZone;\n }\n var beforedate = new Intl.DateTimeFormat('default', options).format(new Date());\n for(let i = 0; i < time.values.length; i++) {\n var date = new Intl.DateTimeFormat('default', options).format(new Date(time.values.get(i)));\n if(beforedate != date){\n addLog(''+date+'');\n }\n beforedate = date;\n var timestr = new Intl.DateTimeFormat('default', timeOptions).format(new Date(time.values.get(i)));\n addLog(timestr+\": \"+logstring.values.get(i));\n }\n }\n }", + "onRender": "const warningsDiv = htmlNode.getElementById('warningsDiv');\nconst warningsList = htmlNode.getElementById('warningsList');\nwarningsDiv.style.display = 'none'\nwhile (warningsList.firstChild) {\n warningsList.firstChild.remove()\n}\nconst logsDiv = htmlNode.getElementById('logDiv');\nconst logsList = htmlNode.getElementById('logsList');\nlogsDiv.style.display = 'none'\nwhile (logsList.firstChild) {\n logsList.firstChild.remove()\n}\n\nfunction addWarning(html) {\n warningsDiv.style.display = ''\n warning = document.createElement(\"li\")\n warning.style.color = 'yellow'\n var template = document.createElement('template');\n html = html.trim();\n template.innerHTML = html;\n warning.append(template.content);\n warningsList.appendChild(warning)\n}\n\nfunction addLog(html) {\n logsDiv.style.display = ''\n log = document.createElement(\"li\")\n var template = document.createElement('template');\n html = html.trim();\n template.innerHTML = html;\n log.append(template.content);\n logsList.appendChild(log)\n}\n\nfunction getMetric(seriesName, metricName) {\n const filteredSeries = data.series.filter((series) => series.refId == seriesName);\n if(filteredSeries.length > 0 && filteredSeries[0].fields != null\n && filteredSeries[0].fields.length > 0){\n const filteredFields = filteredSeries[0].fields.filter((fields) => fields.name == metricName)\n if(filteredFields.length > 0){\n return filteredFields[0].values.get(0)\n }\n }\n return null\n}\n\nconst vwsfriend_url = getTemplateSrv().replace(`$vwsfriend_url`);\nconst vin = getTemplateSrv().replace(`$VIN`);\nif(vwsfriend_url == null || vwsfriend_url== ''){\n addWarning(\"You have to set the URL for the VWsFriend user interface correctly: Go to the user interface on port 4000 and select \\\"Database\\\" > \\”Connection Settings\\\"\")\n}\n\nconst carType = getMetric('vehicle_settings', 'carType')\nconst nickname = getMetric('vehicle_settings', 'nickname')\nconst primaryCapacity = getMetric('vehicle_settings', 'primary_capacity')\nconst primaryCapacityTotal = getMetric('vehicle_settings', 'primary_capacity_total')\nconst secondaryCapacity = getMetric('vehicle_settings', 'secondary_capacity')\nconst secondaryCapacityTotal = getMetric('vehicle_settings', 'secondary_capacity_total')\n\nif(carType == null){\n addWarning(\"The engine type of \"+nickname+\" could not be detected yet. This should happen soon when receiving data.\")\n}\nelse{\n switch (carType) {\n case 'HYBRID':\n if(primaryCapacity == null){\n addWarning(\"Some panels need the tank size of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n if(secondaryCapacity == null || secondaryCapacityTotal == null){\n addWarning(\"Some panels need the battery capacity of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n break;\n case 'ELECTRIC':\n if(primaryCapacity == null || primaryCapacityTotal == null){\n addWarning(\"Some panels need the battery capacity of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n break;\n default:\n if(primaryCapacity == null){\n addWarning(\"Some panels need the battery capacity of \"+nickname+\" to be set. Please set the size here: Vehicle Parameters\")\n }\n break;\n }\n}\nconst hasError = getMetric('error', 'has_error')\nif(hasError){\n addWarning(\"There were more then two errors in the last 30 minutes when fetching data from the servers.
It seems that there are technical issues.\")\n}\n\n//Log\nconst filteredSeries = data.series.filter((series) => series.refId == 'log');\n if(filteredSeries.length > 0 && filteredSeries[0].fields != null\n && filteredSeries[0].fields.length > 0){\n const filteredFields = filteredSeries[0].fields.filter((fields) => (fields.name == 'logtime' || fields.name == 'log'))\n timeZone = htmlGraphics.props.timeZone;\n if(filteredFields.length == 2){\n time = filteredFields[0];\n logstring = filteredFields[1];\n var options = { dateStyle: 'short' };\n if(timeZone!='browser'){\n options.timeZone = timeZone;\n }\n var timeOptions = { timeStyle: 'short' };\n if(timeZone!='browser'){\n timeOptions.timeZone = timeZone;\n }\n var beforedate = new Intl.DateTimeFormat('default', options).format(new Date());\n for(let i = 0; i < time.values.length; i++) {\n var date = new Intl.DateTimeFormat('default', options).format(new Date(time.values.get(i)));\n if(beforedate != date){\n addLog(''+date+'');\n }\n beforedate = date;\n var timestr = new Intl.DateTimeFormat('default', timeOptions).format(new Date(time.values.get(i)));\n addLog(timestr+\": \"+logstring.values.get(i));\n }\n }\n }", "overflow": "scroll", "panelupdateOnMount": true, "reduceOptions": {