diff options
| author | Magdalena GrodziĆska <mag.grodzinska@gmail.com> | 2019-11-27 22:32:10 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-11-27 22:32:10 +0100 | 
| commit | 3ce9014da9d789b1ba9c03c6dcc8c663576353e3 (patch) | |
| tree | 3e89872865bf97362d96deceae08552ac2fd39bd /src/main/resources/pl/edu | |
| parent | 6d27310b2cdbd6f412157eee25cc68df9486db14 (diff) | |
| parent | 27c8f61e15e63aa100ed8b7366784cd58b668064 (diff) | |
Merge pull request #44 from m-chrzan/rearrange_charts
Rearrange charts
Diffstat (limited to 'src/main/resources/pl/edu')
4 files changed, 92 insertions, 22 deletions
| diff --git a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribChart.html b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribChart.html index 1a49261..ab83053 100644 --- a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribChart.html +++ b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribChart.html @@ -6,13 +6,12 @@      <title>Attributes chart</title>      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">      <script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script> -    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script> -    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>      <script type="text/javascript"> -        google.charts.load('current', {'packages':['table']}); -        google.charts.load('current', {'packages':['corechart']}); +        google.charts.load('current', {'packages':['corechart', 'table', 'controls', 'charteditor']});          google.charts.setOnLoadCallback(refreshChart()); +        var chartState = []; +          function refreshChart() {              setInterval(getData, 5000);          } @@ -29,16 +28,71 @@          function drawChart(jsonData) {              var data = google.visualization.arrayToDataTable(jsonData); +            var columnsTable = new google.visualization.DataTable(); +            columnsTable.addColumn('number', 'colIndex'); +            columnsTable.addColumn('string', 'colLabel'); +            var initState= {selectedValues: []}; + +            for (var i = 1; i < data.getNumberOfColumns(); i++) { +                columnsTable.addRow([i, data.getColumnLabel(i)]); +                initState.selectedValues.push(data.getColumnLabel(i)); +            } + +            if (chartState === undefined || chartState.length === 0) { +                chartState = initState; +            } +              var options = { -                title: 'Attribute values', +                width : '70%',                  hAxis: {title: 'Timestamp',  titleTextStyle: {color: '#333'}}, -                vAxis: {scaleType: 'log'},                  interpolateNulls: true,                  crosshair: {trigger: 'both', orientation: 'vertical'}              }; -            var chart = new google.visualization.LineChart(document.getElementById('chart_div')); -            chart.draw(data, options); +            var chart  = new google.visualization.ChartWrapper({ +                chartType : 'LineChart', +                containerId : 'programmatic_chart_div', +                options : options, +                dataTable : data +            }); + +            var columnFilter = new google.visualization.ControlWrapper({ +                controlType : 'CategoryFilter', +                containerId : 'programmatic_control_div', +                dataTable : columnsTable, +                options: { +                    filterColumnLabel: 'colLabel', +                    ui : { +                        label : 'Attribute', +                        allowTyping : false, +                        allowMultiple : false, +                        allowNone : false, +                        selectedValuesLayout : 'below', +                        cssClass : 'google-visualization-controls-categoryfilter' +                    } +                }, +                state : chartState +            }); + +            function drawChartHandler() { +                var state = columnFilter.getState(); +                var row; +                var columnIndices = [0]; +                for (var i = 0; i < state.selectedValues.length; i++) { +                    row = columnsTable.getFilteredRows([{column: 1, value: state.selectedValues[i]}])[0]; +                    columnIndices.push(columnsTable.getValue(row, 0)); +                } +                columnIndices.sort(function (a, b) { +                    return (a - b); +                }); +                chartState = state; +                chart.setView({columns: columnIndices}); +                chart.draw(); +            } + +            google.visualization.events.addListener(columnFilter, 'statechange', drawChartHandler); +            columnFilter.draw(); +            drawChartHandler();          }          function drawTable(jsonData) { @@ -47,11 +101,11 @@                  data.addColumn('string', col);              }              jsonData.shift(); -            data.addRows(jsonData); +            data.addRow(jsonData[0]);              var table = new google.visualization.Table(document.getElementById('table_div')); -            table.draw(data, {width: '100%', height: '100%'}); +            table.draw(data, {width: '80%', height: '100%'});          }      </script> @@ -60,11 +114,12 @@  <body>  <div th:replace="fragments/navbar :: navbar"></div> -<h4 th:text="${currentZone}"></h4> -<div id="zoneAttribForm"> + +<h4 th:text="${currentZone}" class="d-flex justify-content-center mt-2"></h4> +<div id="zoneAttribForm" class="d-flex justify-content-center mt-2">      <form action="#" th:action="@{/values}" th:object="${zoneName}" method="post">          <div class="form-group"> -            <label for="ZoneName1">Enter zone name to get attribute values</label> +            <label for="ZoneName1">Change zone name</label>              <input type="text" class="form-control" id="ZoneName1" rows="3" th:field="*{string}"/>              <small id="passwordHelpBlock" class="form-text text-muted" th:text="${availableZones}">              </small> @@ -72,10 +127,17 @@          <button type="submit" class="btn btn-primary">Submit</button>      </form>  </div> -<div id="table_div"></div> -<div id="chart_div" style="width: 100%; height: 500px;"></div> + +<div id="programmatic_dashboard_div" class="d-flex flex-column justify-content-center mt-5"> +    <h4 class="d-flex justify-content-center mt-2">Attribute values</h4> +    <div id="programmatic_control_div" class="d-flex justify-content-center mt-3"></div> +    <div id="programmatic_chart_div" class="d-flex justify-content-center mt-1"></div> +    <div id="table_div" class="d-flex justify-content-center mt-5"></div> +</div>  <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script> +<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script> +<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>  </body> diff --git a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribForm.html b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribForm.html index e348a11..88842be 100644 --- a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribForm.html +++ b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/attribForm.html @@ -10,7 +10,9 @@  <body>  <div th:replace="fragments/navbar :: navbar"></div> -<div id="queryForm"> + +<h4 class="d-flex justify-content-center mt-2">Add attributes</h4> +<div id="queryForm" class="d-flex justify-content-center mt-2">      <form action="#" th:action="@{/attribs}" th:object="${attributeObject}" method="post">          <div class="form-group">              <label for="ZoneName1">Enter zone name</label> @@ -49,7 +51,6 @@                  Time: 3600 <br>                  Duration: 3600 <br>                  Contact: { "/contactName" : [ 1, 1, 1, 1 ] } <br> -                Query: { "&queryName" : "query" } <br>                  List: [ 1, 2, 3 ] <br>                  Set: [ [1, 2], [3, 4], [5, 6] ] <br>              </small> diff --git a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/contactsForm.html b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/contactsForm.html index ba0a3a8..e20975f 100644 --- a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/contactsForm.html +++ b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/contactsForm.html @@ -10,7 +10,9 @@  <body>  <div th:replace="fragments/navbar :: navbar"></div> -<div id="queryForm"> + +<h4 class="d-flex justify-content-center mt-2">Install fallback contacts</h4> +<div id="queryForm" class="d-flex justify-content-center mt-2">      <form action="#" th:action="@{/contacts}" th:object="${contactsObject}" method="post">          <div class="form-group">              <label for="Textarea1">Enter contacts</label> diff --git a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/queryForm.html b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/queryForm.html index f31ef6b..af3a501 100644 --- a/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/queryForm.html +++ b/src/main/resources/pl/edu/mimuw/cloudatlas/client/templates/queryForm.html @@ -10,8 +10,9 @@  <body>  <div th:replace="fragments/navbar :: navbar"></div> -<div id="installQueryForm"> -    <h2 class="display-7">Install query</h2> + +<h4 class="d-flex justify-content-center mt-2">Install query</h4> +<div id="installQueryForm" class="d-flex justify-content-center mt-2">      <form action="#" th:action="@{/installQuery}" th:object="${queryObject}" method="post">          <div class="form-group">              <label for="InstallQueryName1">Enter query name</label> @@ -20,13 +21,17 @@          <div class="form-group">              <label for="InstallTextarea1">Enter query</label>              <textarea class="form-control" id="InstallTextarea1" rows="3" th:field="*{value}"></textarea> +            <small id="attributeValueHelpBlock" class="form-text text-muted"> +                Enter query in a Json format. Example: +                Query: { "&queryName" : "query" } <br> +            </small>          </div>          <button type="submit" class="btn btn-primary">Submit</button>      </form>  </div> -<div id="uninstallQueryForm"> -    <h2 class="display-7">Uninstall query</h2> +<h4 class="d-flex justify-content-center mt-5">Uninstall query</h4> +<div id="uninstallQueryForm" class="d-flex justify-content-center mt-2">      <form action="#" th:action="@{/uninstallQuery}" th:object="${queryObject}" method="post">          <div class="form-group">              <label for="UninstallQueryName1">Enter query name</label> |