-
Notifications
You must be signed in to change notification settings - Fork 2
/
half_gauge.json
22 lines (22 loc) · 20.7 KB
/
half_gauge.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
{
"alias": "half_gauge",
"name": "half gauge",
"descriptor": {
"type": "latest",
"sizeX": 6,
"sizeY": 6.5,
"resources": [
{
"url": "https://code.jscharting.com/latest/jscharting.js"
}
],
"templateHtml": "<div id=\"chartDiv5\"\r\n style=\"max-width: 100%;height: 100%;margin: 0px auto\">\r\n</div>\r\n",
"templateCss": "g:nth-child(5){\n display: none;\n}\ndiv:nth-child(5){\n display: none;\n}\n",
"controllerScript": "self.onInit = function() {\r\n var minValue = parseInt(self.ctx.settings.minValue)\r\n var maxValue = parseInt(self.ctx.settings.maxValue)\r\n var $scope = self.ctx.$scope;\r\n var markers = \"gray\";\r\n var data = String(self.ctx.data[0].data[0]).split(\r\n \",\");\r\n //var data2 = self.ctx.data;\r\n var data1 = parseInt(data[1])\r\n for (var key in self.ctx.settings.highlights) {\r\n console.log(self.ctx.settings.highlights[key]\r\n .from)\r\n console.log(self.ctx.settings.highlights[key]\r\n .to)\r\n if (self.ctx.settings.highlights[key].from <\r\n data1 && self.ctx.settings.highlights[key]\r\n .to > data1) {\r\n markers = self.ctx.settings.highlights[key]\r\n .color\r\n console.log(markers)\r\n }\r\n }\r\n $scope.color1 = self.ctx.settings.color1;\r\n var data = String(self.ctx.data[0].data[0]).split(\r\n \",\");\r\n\r\n var data4 = data[1]\r\n var chart = JSC.chart('chartDiv5', {\r\n debug: false,\r\n defaultSeries_type: 'gauge',\r\n legend: {\r\n position: 'inside top',\r\n boxVisible: false,\r\n visible: false\r\n },\r\n yAxis: [{\r\n scale_range: [0, 35000]\r\n },\r\n {\r\n id: 'ax2',\r\n scale: {\r\n range: [minValue,\r\n maxValue\r\n ],\r\n invert: true\r\n }\r\n }\r\n ],\r\n defaultTooltip_enabled: false,\r\n series: [\r\n\r\n {\r\n shape: {\r\n fill: [markers, 'white',\r\n 60\r\n ],\r\n outline: {\r\n color: markers,\r\n width: 2\r\n },\r\n },\r\n angle_sweep: 100,\r\n yAxis: 'ax2',\r\n shape_label_text: data[1],\r\n points: [{\r\n y: parseInt(\r\n data4)\r\n }]\r\n }\r\n ]\r\n });\r\n setTimeout(function() {\r\n document.getElementById(\"brandingLogo\")\r\n .style.display = \"none\"\r\n }, 500);\r\n}\r\n\r\nself.typeParameters = function() {\r\n return {\r\n maxDatasources: 1,\r\n maxDataKeys: 1,\r\n singleEntity: true\r\n };\r\n}\r\nself.getSettingsSchema = function() {\r\n return TbAnalogueRadialGauge.settingsSchema;\r\n}",
"settingsSchema": "{\n \"schema\": {\n \"type\": \"object\",\n \"title\": \"Settings\",\n \"properties\": {\n \n \"color1\":{\n \"title\": \"Background color\",\n \"type\": \"string\",\n \"default\": \"#eddbff\"\n }\n }\n },\n \"form\": [\n \n {\n \"key\": \"color1\",\n \"type\": \"color\"\n }\n ]\n}",
"dataKeySettingsSchema": "{}\n",
"defaultConfig": "{\"datasources\":[{\"type\":\"function\",\"name\":\"function\",\"entityAliasId\":null,\"filterId\":null,\"dataKeys\":[{\"name\":\"f(x)\",\"type\":\"function\",\"label\":\"Sin\",\"color\":\"#2196f3\",\"settings\":{},\"_hash\":0.4957858443463219,\"funcBody\":\"return Math.round(1000*Math.sin(time/5000));\"}]}],\"timewindow\":{\"realtime\":{\"timewindowMs\":60000}},\"showTitle\":false,\"backgroundColor\":\"rgb(255, 255, 255)\",\"color\":\"rgba(0, 0, 0, 0.87)\",\"padding\":\"8px\",\"settings\":{\"maxValue\":100,\"startAngle\":45,\"ticksAngle\":270,\"showBorder\":true,\"defaultColor\":\"#e65100\",\"needleCircleSize\":10,\"highlights\":[{\"from\":10,\"to\":30,\"color\":\"#fc0c0c\"},{\"from\":30,\"to\":60,\"color\":\"#0c6bfa\"},{\"from\":60,\"to\":100,\"color\":\"#2dfc07\"}],\"showUnitTitle\":true,\"colorPlate\":\"#fff\",\"colorMajorTicks\":\"#444\",\"colorMinorTicks\":\"#666\",\"minorTicks\":10,\"valueInt\":3,\"highlightsWidth\":15,\"valueBox\":true,\"animation\":true,\"animationDuration\":500,\"animationRule\":\"cycle\",\"colorNeedleShadowUp\":\"rgba(2, 255, 255, 0)\",\"numbersFont\":{\"family\":\"Roboto\",\"size\":18,\"style\":\"normal\",\"weight\":\"500\",\"color\":\"#616161\"},\"titleFont\":{\"family\":\"Roboto\",\"size\":24,\"style\":\"normal\",\"weight\":\"500\",\"color\":\"#888\"},\"unitsFont\":{\"family\":\"Roboto\",\"size\":22,\"style\":\"normal\",\"weight\":\"500\",\"color\":\"#616161\"},\"valueFont\":{\"family\":\"Segment7Standard\",\"size\":36,\"style\":\"normal\",\"weight\":\"normal\",\"shadowColor\":\"rgba(0, 0, 0, 0.49)\",\"color\":\"#444\"},\"minValue\":-100,\"colorNeedleShadowDown\":\"rgba(188,143,143,0.45)\",\"colorValueBoxRect\":\"#888\",\"colorValueBoxRectEnd\":\"#666\",\"colorValueBoxBackground\":\"#babab2\",\"colorValueBoxShadow\":\"rgba(0,0,0,1)\"},\"title\":\"half gauge\",\"dropShadow\":true,\"enableFullscreen\":false,\"titleStyle\":{\"fontSize\":\"16px\",\"fontWeight\":400},\"showTitleIcon\":false,\"iconColor\":\"rgba(0, 0, 0, 0.87)\",\"iconSize\":\"24px\",\"titleTooltip\":\"\",\"enableDataExport\":false,\"widgetStyle\":{},\"showLegend\":false}"
},
"image": "",
"description": "Preconfigured gauge to display any value reading. Allows to configure value range, gradient colors and other settings."
}