{
  "annotations": {
    "list": [
      {
        "builtIn": 1,
        "datasource": {
          "type": "grafana",
          "uid": "-- Grafana --"
        },
        "enable": true,
        "hide": true,
        "iconColor": "rgba(0, 211, 255, 1)",
        "name": "Annotations & Alerts",
        "type": "dashboard"
      }
    ]
  },
  "editable": true,
  "fiscalYearStartMonth": 0,
  "graphTooltip": 0,
  "id": 13,
  "links": [],
  "panels": [
    {
      "datasource": {
        "type": "influxdb",
        "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
      },
      "fieldConfig": {
        "defaults": {
          "color": {
            "mode": "thresholds"
          },
          "decimals": 3,
          "mappings": [],
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green"
              }
            ]
          },
          "unit": "kwatth"
        },
        "overrides": []
      },
      "gridPos": {
        "h": 9,
        "w": 24,
        "x": 0,
        "y": 0
      },
      "id": 1,
      "options": {
        "colorMode": "value",
        "graphMode": "none",
        "justifyMode": "auto",
        "orientation": "horizontal",
        "percentChangeColorMode": "standard",
        "reduceOptions": {
          "calcs": [
            "lastNotNull"
          ],
          "fields": "",
          "values": false
        },
        "showPercentChange": false,
        "textMode": "auto",
        "wideLayout": true
      },
      "pluginVersion": "12.0.0",
      "targets": [
        {
          "datasource": {
            "type": "influxdb",
            "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
          },
          "query": "import \"math\"\n\n\na = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"solar_generated_total\")\n  |> last()\n  |> set(key: \"_field\", value: \"1. Wygenerowano z paneli\")\n\nb = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_reverse_active_energy_total\")\n  |> last()\n  |> set(key: \"_field\", value: \"2. Oddano do sieci\")\n\nc = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_active_energy_total\")\n  |> last()\n  |> set(key: \"_field\", value: \"3. Pobrano z sieci\")\n\nunion(tables: [a, b, c])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> map(fn: (r) => ({r with _value: math.abs(x: r._value)}))\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [])\n  |> map(fn: (r) => ({ r with\n    \"4. Zużyto w domu\": r[\"1. Wygenerowano z paneli\"] - r[\"2. Oddano do sieci\"] + r[\"3. Pobrano z sieci\"],\n    \"5. Do pobrania z magazynu\": r[\"2. Oddano do sieci\"] * 4.0 / 5.0 - r[\"3. Pobrano z sieci\"]\n  }))",
          "refId": "A"
        }
      ],
      "title": "Statystyki",
      "type": "stat"
    },
    {
      "collapsed": false,
      "gridPos": {
        "h": 1,
        "w": 24,
        "x": 0,
        "y": 9
      },
      "id": 6,
      "panels": [],
      "title": "Fotowoltaika",
      "type": "row"
    },
    {
      "datasource": {
        "type": "influxdb",
        "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
      },
      "fieldConfig": {
        "defaults": {
          "color": {
            "mode": "palette-classic"
          },
          "custom": {
            "axisBorderShow": false,
            "axisCenteredZero": false,
            "axisColorMode": "text",
            "axisLabel": "",
            "axisPlacement": "auto",
            "barAlignment": 0,
            "barWidthFactor": 0.6,
            "drawStyle": "line",
            "fillOpacity": 0,
            "gradientMode": "none",
            "hideFrom": {
              "legend": false,
              "tooltip": false,
              "viz": false
            },
            "insertNulls": false,
            "lineInterpolation": "linear",
            "lineWidth": 1,
            "pointSize": 5,
            "scaleDistribution": {
              "type": "linear"
            },
            "showPoints": "auto",
            "spanNulls": false,
            "stacking": {
              "group": "A",
              "mode": "none"
            },
            "thresholdsStyle": {
              "mode": "off"
            }
          },
          "mappings": [],
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green"
              },
              {
                "color": "red",
                "value": 80
              }
            ]
          },
          "unit": "kwatth"
        },
        "overrides": []
      },
      "gridPos": {
        "h": 8,
        "w": 12,
        "x": 0,
        "y": 10
      },
      "id": 2,
      "options": {
        "legend": {
          "calcs": [],
          "displayMode": "list",
          "placement": "bottom",
          "showLegend": true
        },
        "tooltip": {
          "hideZeros": false,
          "mode": "single",
          "sort": "none"
        }
      },
      "pluginVersion": "12.0.0",
      "targets": [
        {
          "query": "a = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_reverse_active_energy_total\")\n  |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: true)\n  |> set(key: \"_field\", value: \"return\")\n\nb = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_forward_active_energy_total\")\n  |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: true)\n  |> set(key: \"_field\", value: \"consumption\")\n\nunion(tables: [a, b])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [\"_time\"])\n  |> fill(usePrevious: true, column: \"return\")\n  |> fill(usePrevious: true, column: \"consumption\")\n  |> filter(fn: (r) => exists r[\"return\"] and exists r[\"consumption\"])\n  |> map(fn: (r) => ({\n    _time: r._time,\n    _value: r[\"return\"] * 4.0 / 5.0 - r[\"consumption\"],\n    _field: \"Do pobrania\"\n  }))",
          "refId": "A"
        }
      ],
      "title": "Nadwyżka do pobrania z sieci",
      "type": "timeseries"
    },
    {
      "datasource": {
        "type": "influxdb",
        "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
      },
      "fieldConfig": {
        "defaults": {
          "color": {
            "mode": "palette-classic"
          },
          "custom": {
            "axisBorderShow": false,
            "axisCenteredZero": false,
            "axisColorMode": "text",
            "axisLabel": "",
            "axisPlacement": "auto",
            "barAlignment": 0,
            "barWidthFactor": 0.6,
            "drawStyle": "bars",
            "fillOpacity": 100,
            "gradientMode": "none",
            "hideFrom": {
              "legend": false,
              "tooltip": false,
              "viz": false
            },
            "insertNulls": false,
            "lineInterpolation": "linear",
            "lineWidth": 1,
            "pointSize": 5,
            "scaleDistribution": {
              "type": "linear"
            },
            "showPoints": "never",
            "spanNulls": false,
            "stacking": {
              "group": "A",
              "mode": "none"
            },
            "thresholdsStyle": {
              "mode": "off"
            }
          },
          "mappings": [],
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green"
              },
              {
                "color": "red",
                "value": 80
              }
            ]
          },
          "unit": "kwatth"
        },
        "overrides": []
      },
      "gridPos": {
        "h": 8,
        "w": 12,
        "x": 12,
        "y": 10
      },
      "id": 3,
      "interval": "1d",
      "options": {
        "legend": {
          "calcs": [],
          "displayMode": "list",
          "placement": "bottom",
          "showLegend": true
        },
        "tooltip": {
          "hideZeros": false,
          "mode": "single",
          "sort": "none"
        }
      },
      "pluginVersion": "12.0.0",
      "targets": [
        {
          "query": "from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"solar_generated\")\n  |> aggregateWindow(every: v.windowPeriod, fn: sum, createEmpty: false)\n  |> yield(name: \"mean\")",
          "refId": "A"
        }
      ],
      "title": "Produkcja energii",
      "type": "timeseries"
    },
    {
      "datasource": {
        "type": "influxdb",
        "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
      },
      "fieldConfig": {
        "defaults": {
          "color": {
            "mode": "palette-classic"
          },
          "custom": {
            "axisBorderShow": false,
            "axisCenteredZero": false,
            "axisColorMode": "text",
            "axisLabel": "",
            "axisPlacement": "auto",
            "barAlignment": 0,
            "barWidthFactor": 0.6,
            "drawStyle": "bars",
            "fillOpacity": 100,
            "gradientMode": "none",
            "hideFrom": {
              "legend": false,
              "tooltip": false,
              "viz": false
            },
            "insertNulls": false,
            "lineInterpolation": "linear",
            "lineWidth": 1,
            "pointSize": 5,
            "scaleDistribution": {
              "type": "linear"
            },
            "showPoints": "never",
            "spanNulls": false,
            "stacking": {
              "group": "A",
              "mode": "none"
            },
            "thresholdsStyle": {
              "mode": "off"
            }
          },
          "mappings": [],
          "max": 1,
          "min": 0,
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green"
              },
              {
                "color": "red",
                "value": 80
              },
              {
                "color": "#EAB839",
                "value": 90
              }
            ]
          },
          "unit": "percentunit"
        },
        "overrides": [
          {
            "matcher": {
              "id": "byRegexp",
              "options": "/od początku.*/"
            },
            "properties": [
              {
                "id": "custom.drawStyle",
                "value": "line"
              },
              {
                "id": "custom.fillOpacity",
                "value": 0
              }
            ]
          }
        ]
      },
      "gridPos": {
        "h": 8,
        "w": 12,
        "x": 0,
        "y": 18
      },
      "id": 4,
      "interval": "1d",
      "options": {
        "legend": {
          "calcs": [],
          "displayMode": "list",
          "placement": "bottom",
          "showLegend": true
        },
        "tooltip": {
          "hideZeros": false,
          "mode": "single",
          "sort": "none"
        }
      },
      "pluginVersion": "12.0.0",
      "targets": [
        {
          "query": "a = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_reverse_active_energy_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: true, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"return\")\n\naDiff = a\n  |> difference()\n\nb = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_forward_active_energy_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: true, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"consumption\")\n\nbDiff = b\n  |> difference()\n\nc = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"solar_generated_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: true, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"generation\")\n\ncDiff = c\n  |> difference()\n\nunion(tables: [a, b, c])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [\"_time\"])\n  |> fill(usePrevious: true, column: \"return\")\n  |> fill(usePrevious: true, column: \"consumption\")\n  |> fill(usePrevious: true, column: \"generation\")\n  |> filter(fn: (r) => exists r[\"return\"] and exists r[\"consumption\"] and exists r[\"generation\"])\n  |> map(fn: (r) => ({\n    _time: r._time,\n    \"od początku\": (r[\"generation\"] - r[\"return\"]) / (r[\"generation\"] - r[\"return\"] + r[\"consumption\"]),\n    _field: \"od początku\"\n  }))\n  |> yield(name: \"od początku\")\n\nunion(tables: [aDiff, bDiff, cDiff])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [\"_time\"])\n  |> fill(usePrevious: true, column: \"return\")\n  |> fill(usePrevious: true, column: \"consumption\")\n  |> fill(usePrevious: true, column: \"generation\")\n  |> filter(fn: (r) => exists r[\"return\"] and exists r[\"consumption\"] and exists r[\"generation\"])\n  |> map(fn: (r) => ({\n    _time: r._time,\n    \"chwilowe\": (r[\"generation\"] - r[\"return\"]) / (r[\"generation\"] - r[\"return\"] + r[\"consumption\"]),\n    _field: \"Chwilowe\"\n  }))\n  |> yield(name: \"chwilowe\")",
          "refId": "A"
        }
      ],
      "title": "Samowystarczalność",
      "type": "timeseries"
    },
    {
      "datasource": {
        "type": "influxdb",
        "uid": "a49a2345-4e76-4b69-827e-2ab573073ebe"
      },
      "fieldConfig": {
        "defaults": {
          "color": {
            "mode": "palette-classic"
          },
          "custom": {
            "axisBorderShow": false,
            "axisCenteredZero": false,
            "axisColorMode": "text",
            "axisLabel": "",
            "axisPlacement": "auto",
            "barAlignment": 0,
            "barWidthFactor": 0.6,
            "drawStyle": "bars",
            "fillOpacity": 100,
            "gradientMode": "none",
            "hideFrom": {
              "legend": false,
              "tooltip": false,
              "viz": false
            },
            "insertNulls": false,
            "lineInterpolation": "linear",
            "lineWidth": 1,
            "pointSize": 5,
            "scaleDistribution": {
              "type": "linear"
            },
            "showPoints": "never",
            "spanNulls": false,
            "stacking": {
              "group": "A",
              "mode": "none"
            },
            "thresholdsStyle": {
              "mode": "off"
            }
          },
          "mappings": [],
          "max": 1,
          "min": 0,
          "thresholds": {
            "mode": "absolute",
            "steps": [
              {
                "color": "green"
              },
              {
                "color": "red",
                "value": 80
              },
              {
                "color": "#EAB839",
                "value": 90
              }
            ]
          },
          "unit": "percentunit"
        },
        "overrides": [
          {
            "matcher": {
              "id": "byRegexp",
              "options": "/od początku.*/"
            },
            "properties": [
              {
                "id": "custom.drawStyle",
                "value": "line"
              },
              {
                "id": "custom.fillOpacity",
                "value": 0
              }
            ]
          }
        ]
      },
      "gridPos": {
        "h": 8,
        "w": 12,
        "x": 12,
        "y": 18
      },
      "id": 5,
      "interval": "1d",
      "options": {
        "legend": {
          "calcs": [],
          "displayMode": "list",
          "placement": "bottom",
          "showLegend": true
        },
        "tooltip": {
          "hideZeros": false,
          "mode": "multi",
          "sort": "none"
        }
      },
      "pluginVersion": "12.0.0",
      "targets": [
        {
          "query": "a = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_reverse_active_energy_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: true, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"return\")\n\naDiff = a\n  |> difference()\n\nb = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"balanced_forward_active_energy_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: true, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"consumption\")\n\nbDiff = b\n  |> difference()\n\nc = from(bucket: \"grid_stats\")\n  |> range(start: v.timeRangeStart, stop: v.timeRangeStop)\n  |> filter(fn: (r) => r[\"_measurement\"] == \"kWh\" and r[\"_field\"] == \"solar_generated_total\")\n  |> aggregateWindow(every: 1d, fn: last, createEmpty: false, location: {zone: \"Europe/Warsaw\", offset: 1s})\n  |> set(key: \"_field\", value: \"generation\")\n\ncDiff = c\n  |> difference()\n\nunion(tables: [a, b, c])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [\"_time\"])\n  |> fill(usePrevious: true, column: \"return\")\n  |> fill(usePrevious: true, column: \"consumption\")\n  |> fill(usePrevious: true, column: \"generation\")\n  |> filter(fn: (r) => exists r[\"return\"] and exists r[\"consumption\"] and exists r[\"generation\"])\n  |> map(fn: (r) => ({\n    _time: r._time,\n    \"od początku\": (r[\"generation\"] - r[\"return\"]) / r[\"generation\"],\n    _field: \"od początku\"\n  }))\n  |> yield(name: \"od początku\")\n\nunion(tables: [aDiff, bDiff, cDiff])\n  |> keep(columns: [\"_time\", \"_value\", \"_field\"])\n  |> pivot(columnKey: [\"_field\"], valueColumn: \"_value\", rowKey: [\"_time\"])\n  |> fill(usePrevious: true, column: \"return\")\n  |> fill(usePrevious: true, column: \"consumption\")\n  |> fill(usePrevious: true, column: \"generation\")\n  |> filter(fn: (r) => exists r[\"return\"] and exists r[\"consumption\"] and exists r[\"generation\"])\n  |> map(fn: (r) => ({\n    _time: r._time,\n    \"chwilowe\": (r[\"generation\"] - r[\"return\"]) / r[\"generation\"],\n    _field: \"Chwilowe\"\n  }))\n  |> yield(name: \"chwilowe\")",
          "refId": "A"
        }
      ],
      "title": "Autokonsumpcja",
      "type": "timeseries"
    }
  ],
  "preload": false,
  "schemaVersion": 41,
  "tags": [],
  "templating": {
    "list": []
  },
  "time": {
    "from": "now-30d",
    "to": "now"
  },
  "timepicker": {},
  "timezone": "Europe/Warsaw",
  "title": "Prąd",
  "uid": "beaovo5dmse0wa",
  "version": 16
}