diff --git a/app/controllers/lab-mashup.js b/app/controllers/lab-mashup.js index 3ebd302..8e1593a 100644 --- a/app/controllers/lab-mashup.js +++ b/app/controllers/lab-mashup.js @@ -1,4 +1,5 @@ import Ember from 'ember'; +import ENV from '../config/environment'; export default Ember.Controller.extend({ freq575GreenZones: [{from: 49.5, to: 50.5}], @@ -28,6 +29,11 @@ export default Ember.Controller.extend({ return this.get('state') === 2 || this.get('state') === 0; }.property('state'), + showExtendedView: function() { + Ember.debug(ENV.APP.SHOW_EXTENDED_VIEW); + return ENV.APP.SHOW_EXTENDED_VIEW; + }.property(), + _updateController: function() { // update attribute values this._updateAttributes(); @@ -35,21 +41,28 @@ export default Ember.Controller.extend({ // get new data file control state from store if (this._freezeState === false) { var control = this.store.peekRecord('data-file-control', 'DataFileControl'); + var reload = control.get('ForceReload'); - if (control.get('Filename') === '/share/data/m1_S1_ElectricalGrid_data.txt') { - // state 1 - if (this.get('state') !== 1) { - this.set('state', 1); - } - } else { - // state 2 - if (this.get('state') !== 2) { - this.set('state', 2); + if (reload === false || reload === 'false') { + if (control.get('Filename') === '/share/data/m1_S1_ElectricalGrid_data.txt') { + // state 1 + if (this.get('state') !== 1) { + this.set('state', 1); + + Ember.debug('update state (1)'); + } + } else { + // state 2 + if (this.get('state') !== 2) { + this.set('state', 2); + + Ember.debug('update state (2)'); + } } } var status = control.get('Status'); - var reload = control.get('ForceReload'); + /*Ember.debug('status: ' + status + ', reload: ' + reload);*/ @@ -67,7 +80,7 @@ export default Ember.Controller.extend({ } } - Ember.run.later(this, this._updateController, 100); + Ember.run.later(this, this._updateController, ENV.APP.UPDATE_RATE); }.on('init'), _updateAttributes: function() { diff --git a/app/routes/lab-mashup.js b/app/routes/lab-mashup.js index 2713847..3102b76 100644 --- a/app/routes/lab-mashup.js +++ b/app/routes/lab-mashup.js @@ -1,4 +1,5 @@ import Ember from 'ember'; +import ENV from '../config/environment'; export default Ember.Route.extend({ model() { @@ -21,7 +22,7 @@ export default Ember.Route.extend({ // first time call poll Ember.run.later(this, function() { this.refreshEntities(); - }, 100); + }, ENV.APP.UPDATE_RATE); }, refreshEntities: function() { @@ -43,6 +44,6 @@ export default Ember.Route.extend({ // reschedule refresh Ember.run.later(this, function() { this.refreshEntities(); - }, 100); + }, ENV.APP.UPDATE_RATE); } }); diff --git a/app/serializers/application.js b/app/serializers/application.js index a9f3851..afffeff 100644 --- a/app/serializers/application.js +++ b/app/serializers/application.js @@ -80,6 +80,20 @@ export default DS.RESTSerializer.extend({ } }, + normalizeSaveResponse: function(store, primaryModelClass, payload, id, requestType) { + if (payload.contextResponses) { + payload.contextResponses.forEach(function(response) { + if (response.statusCode.code !== 200 && response.statusCode.code !== '200') { + Ember.debug('Failed update DataFileControl: ' + response.statusCode.code + ', ' + response.statusCode.details); + } + }); + } + + Ember.debug('cb response'); + + return { data: {} }; + }, + _normalizePayload: function(payload, handleItem) { var propertyIndex = 0; @@ -145,11 +159,11 @@ export default DS.RESTSerializer.extend({ if (metadata.name === 'timestamp') { timestamp = Date.parse(metadata.value); } else if (metadata.name === 'source') { - source = metadata.value; + source = metadata.value; } else if (metadata.name === 'min') { - minValue = metadata.value; + minValue = metadata.value; } else if (metadata.name === 'max') { - maxValue = metadata.value; + maxValue = metadata.value; } }); } @@ -233,6 +247,12 @@ export default DS.RESTSerializer.extend({ record.get('values').push(value); }); + // erase old data + while (record.get('values').length > 500) { + record.get('values').shift(); + /*Ember.debug('Shift on ' + record.get('name'));*/ + } + record.set('timestamp', item.attributes.timestamp); record.set('currentValue', item.attributes.currentValue); } diff --git a/app/styles/app.css b/app/styles/app.css index 8e299db..155bda4 100644 --- a/app/styles/app.css +++ b/app/styles/app.css @@ -61,29 +61,29 @@ header { color: #103B7D; background-color: #fff; - height: 60px; + height: 80px; top: 0; border-bottom: 3px solid #bbb; } header #title { - font-size: 25px; + font-size: 30px; font-weight: 100; text-align: left; text-rendering: optimizeLegibility; -webkit-text-rendering: optimizeLegiblity; -moz-text-rendering: optimizeLegibitliy; - padding: 15px 0 20px 30px; + padding: 25px 0 20px 30px; float: left; } header #logos { - height: 60px; + height: 80px; - padding-top: 15px; + padding-top: 8px; float: right; } @@ -100,7 +100,7 @@ footer { } #main { - top: 60px; + top: 80px; bottom: 0px; left: 20px; @@ -108,13 +108,13 @@ footer { } .svg-image { - width: 60%; + width: 95%; height: auto; } .svg-logo { width: auto; - height: 30px; + height: 60px; padding-right: 30px; @@ -122,19 +122,19 @@ footer { } #rwth-logo { - margin-top: 10px; + margin-top: 15px; - height: 15px !important; + height: 30px !important; } #DS-image { width: auto; - height: 405px; + height: 395px; } #TS-image { width: auto; - height: 410px; + height: 395px; } h1 { diff --git a/app/templates/application.hbs b/app/templates/application.hbs index a0a0140..4ebf23f 100644 --- a/app/templates/application.hbs +++ b/app/templates/application.hbs @@ -6,8 +6,7 @@
- - +
diff --git a/app/templates/lab-mashup.hbs b/app/templates/lab-mashup.hbs index 91ded5a..f3f0318 100644 --- a/app/templates/lab-mashup.hbs +++ b/app/templates/lab-mashup.hbs @@ -63,13 +63,13 @@

Control Center

- +

- Distribution grid monitoring voltage measurement + Distribution grid monitoring: voltage measurement

{{line-chart data=voltage203937 height="90%" xaxisLength=120 minValue=0.90 maxValue=1.05 label="RMS voltage [pu]"}} @@ -81,9 +81,11 @@
-
- Technical -
+ {{#if showExtendedView}} +
+ Extended View +
+ {{/if}} @@ -120,7 +122,7 @@
  • Total length of lines: 38,54 km
  • - {{bar-chart data=totalPValue width='200px' height='250px' maxValue=30}} + {{bar-chart data=totalPValue width='200px' height='230px' maxValue=30}}

    Total Net Consumption [MW]

    @@ -140,7 +142,7 @@

    Prosumer behavior

    - + diff --git a/config/environment.js b/config/environment.js index 6592919..e201c17 100644 --- a/config/environment.js +++ b/config/environment.js @@ -17,7 +17,9 @@ module.exports = function(environment) { // Here you can pass flags/options to your application instance // when it is created - API_HOST: 'http://46.101.131.212:80' + API_HOST: '', + UPDATE_RATE: 200, + SHOW_EXTENDED_VIEW: true, }, contentSecurityPolicy: { @@ -31,6 +33,11 @@ module.exports = function(environment) { } }; + // disable mirage + ENV['ember-cli-mirage'] = { + enabled: false + } + if (environment === 'development') { // ENV.APP.LOG_RESOLVER = true; // ENV.APP.LOG_ACTIVE_GENERATION = true; @@ -38,12 +45,7 @@ module.exports = function(environment) { // ENV.APP.LOG_TRANSITIONS_INTERNAL = true; // ENV.APP.LOG_VIEW_LOOKUPS = true; - //ENV.APP.API_HOST = 'http://localhost:4200'; - - ENV['ember-cli-mirage'] = { - //enabled: true - enabled: false - } + ENV.APP.API_HOST = 'http://46.101.131.212:80'; } if (environment === 'test') { @@ -59,12 +61,15 @@ module.exports = function(environment) { } if (environment === 'production') { - ENV.APP.API_HOST = 'http://46.101.131.212:80'; ENV.baseURL = '/simple/'; + } - ENV['ember-cli-mirage'] = { - enabled: false - } + if (environment === 'simple') { + ENV.APP.SHOW_EXTENDED_VIEW = false; + } + + if (environment === 'extended') { + ENV.APP.SHOW_EXTENDED_VIEW = true; } return ENV; diff --git a/public/assets/images/DS_section/DS_fig1.svg b/public/assets/images/DS_section/DS_fig1.svg index 3b8e5a5..2ad4c02 100644 --- a/public/assets/images/DS_section/DS_fig1.svg +++ b/public/assets/images/DS_section/DS_fig1.svg @@ -14,61 +14,8 @@ height="403.98267" id="svg2" version="1.1" - inkscape:version="0.48.0 r9654" + inkscape:version="0.91 r13725" sodipodi:docname="DS_fig1.svg"> - - - - - - - - - - - - - - - - - + orientation="-0.70710678,0.70710678" /> + + + + + + + + + + + + + + + + + @@ -111,12441 +111,83600 @@ + inkscape:groupmode="layer" + inkscape:label="Ebene 1"> + x="-3572.856" + id="text3415-6"> Politecnico di Torino + sodipodi:role="line" + x="-3572.856" + style="font-size:85px;font-variant:normal;font-weight:bold;font-stretch:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle;fill:#aa0000;fill-opacity:1;fill-rule:nonzero;stroke:none;font-family:Arial;-inkscape-font-specification:Arial">Politecnico di Torino + transform="matrix(5.6319941,0,0,-5.7141574,-3333.2996,-6012.1306)" + id="g3129-0-8-0"> + clip-path="url(#clipPath3133-3-4-7)" + id="g3131-7-7"> + transform="matrix(61.054565,0,0,69.267319,36.933121,143.2047)" + id="g3139-0-8"> + xlink:href="" + transform="matrix(1,0,0,-1,0,1)" + height="1" + width="1" /> diff --git a/public/assets/images/PoliTo.svg b/public/assets/images/PoliTo.svg index 0a920b9..075a321 100644 --- a/public/assets/images/PoliTo.svg +++ b/public/assets/images/PoliTo.svg @@ -10,47 +10,15 @@ xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" - width="615" - height="260" - id="svg2" + id="svg3336" version="1.1" - inkscape:version="0.48.0 r9654" - sodipodi:docname="Neues Dokument 1"> - - - - - - + inkscape:version="0.91 r13725" + width="679.95001" + height="426.60001" + viewBox="0 0 679.95001 426.60001" + sodipodi:docname="logo.svg"> + id="metadata3342"> @@ -61,2108 +29,53177 @@ - - + + - + id="image3344" + x="0" + y="0" /> diff --git a/public/assets/images/Prosumer_section/Cnsmr_fig1.svg b/public/assets/images/Prosumer_section/Cnsmr_fig1.svg index 492884c..ce7bc6d 100644 --- a/public/assets/images/Prosumer_section/Cnsmr_fig1.svg +++ b/public/assets/images/Prosumer_section/Cnsmr_fig1.svg @@ -14,40 +14,8 @@ height="405.16147" id="svg2" version="1.1" - inkscape:version="0.48.0 r9654" + inkscape:version="0.91 r13725" sodipodi:docname="Cnsmr_fig1.svg"> - - - - - - - - - - - + + + + + + + + + + + @@ -83,571 +83,853 @@ + inkscape:groupmode="layer" + inkscape:label="Ebene 1"> + transform="matrix(1.1812552,0,0,1.1812552,-3607.6224,-7437.7077)"> + id="g3937"> + clip-path="url(#clipPath3943)" + id="g3941"> + transform="translate(10.4507,179.0083)" + id="g3947"> + inkscape:connector-curvature="0" /> + transform="translate(115.7349,192.1714)" + id="g3951"> + inkscape:connector-curvature="0" /> + transform="translate(129.4746,193.4189)" + id="g3955"> + inkscape:connector-curvature="0" /> + transform="translate(110.5361,167.0308)" + id="g3959"> + inkscape:connector-curvature="0" /> + transform="translate(112.2012,157.3735)" + id="g3963"> + inkscape:connector-curvature="0" /> + transform="translate(111.3936,148.9546)" + id="g3967"> + inkscape:connector-curvature="0" /> + transform="translate(110.6523,140.7002)" + id="g3971"> + inkscape:connector-curvature="0" /> + transform="translate(110.0659,132.4102)" + id="g3975"> + inkscape:connector-curvature="0" /> + transform="translate(109.5449,124.0684)" + id="g3979"> + inkscape:connector-curvature="0" /> + transform="translate(109.2129,115.8447)" + id="g3983"> + inkscape:connector-curvature="0" /> + transform="translate(92.1865,107.8984)" + id="g3987"> + inkscape:connector-curvature="0" /> + transform="translate(140.7427,98.959)" + id="g3991"> + inkscape:connector-curvature="0" /> + transform="translate(129.0107,183.8701)" + id="g3995"> + inkscape:connector-curvature="0" /> + d="m 64.606,48.754 114.129,0 0,50.754 -114.129,0 0,-50.754 z" + inkscape:connector-curvature="0" /> + inkscape:connector-curvature="0" /> + transform="translate(122.9189,162.7139)" + id="g4003"> + inkscape:connector-curvature="0" /> + transform="translate(123.0586,111.79)" + id="g4007"> + inkscape:connector-curvature="0" /> + transform="translate(135.6553,115.1621)" + id="g4011"> + inkscape:connector-curvature="0" /> + transform="translate(135.6553,159.3169)" + id="g4015"> + inkscape:connector-curvature="0" /> + transform="translate(145.0078,149.9653)" + id="g4019"> + inkscape:connector-curvature="0" /> + transform="translate(145.0078,124.3867)" + id="g4023"> + inkscape:connector-curvature="0" /> + transform="translate(148.5117,137.3711)" + id="g4027"> + inkscape:connector-curvature="0" /> + transform="translate(110.0762,159.2856)" + id="g4031"> + inkscape:connector-curvature="0" /> + transform="translate(100.9834,149.9341)" + id="g4035"> + inkscape:connector-curvature="0" /> + transform="translate(97.6084,137.3398)" + id="g4039"> + inkscape:connector-curvature="0" /> + transform="translate(100.9834,124.3555)" + id="g4043"> + inkscape:connector-curvature="0" /> + transform="translate(110.209,115.1309)" + id="g4047"> + d="M 0,0 3.971,0 0.77,-2.4 2.007,-6.207 -1.175,-3.858 -4.364,-6.207 -3.107,-2.4 -6.333,0 -2.375,0 -1.175,3.713 0,0 z" + inkscape:connector-curvature="0" /> + d="m 64.606,43.74 114.159,0 0,6.517 -114.159,0 0,-6.517 z" + inkscape:connector-curvature="0" /> + transform="translate(195.001,227.2148)" + id="g4053"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,216.6758)" + id="g4057"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,206.0908)" + id="g4061"> + inkscape:connector-curvature="0" /> + transform="translate(194.9551,195.6914)" + id="g4065"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,184.874)" + id="g4069"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,174.8462)" + id="g4073"> + inkscape:connector-curvature="0" /> + transform="translate(194.9541,164.1216)" + id="g4077"> + inkscape:connector-curvature="0" /> + transform="translate(194.9541,153.8618)" + id="g4081"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,143.6016)" + id="g4085"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,133.1563)" + id="g4089"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,122.5713)" + id="g4093"> + inkscape:connector-curvature="0" /> + transform="translate(194.9551,112.125)" + id="g4097"> + inkscape:connector-curvature="0" /> + transform="translate(195.001,101.3096)" + id="g4101"> + inkscape:connector-curvature="0" /> + transform="translate(71.2783,89.6855)" + id="g4105"> + inkscape:connector-curvature="0" /> + transform="translate(87.0483,78.0898)" + id="g4109"> + inkscape:connector-curvature="0" /> + transform="translate(90.8984,78.4316)" + id="g4113"> + inkscape:connector-curvature="0" /> + transform="translate(98.4771,85.3643)" + id="g4117"> + inkscape:connector-curvature="0" /> + transform="translate(107.8188,85.2559)" + id="g4121"> + inkscape:connector-curvature="0" /> + transform="translate(114.3701,83.3115)" + id="g4125"> + inkscape:connector-curvature="0" /> + transform="translate(126.377,82.1055)" + id="g4129"> + inkscape:connector-curvature="0" /> + transform="translate(137.1953,78.0898)" + id="g4133"> + inkscape:connector-curvature="0" /> + transform="translate(75.9775,71.1719)" + id="g4137"> + inkscape:connector-curvature="0" /> + transform="translate(83.6992,66.3643)" + id="g4141"> + inkscape:connector-curvature="0" /> + transform="translate(101.27,59.0898)" + id="g4145"> + inkscape:connector-curvature="0" /> + transform="translate(115.3818,59.0898)" + id="g4149"> + inkscape:connector-curvature="0" /> + transform="translate(119.1406,59.4316)" + id="g4153"> + inkscape:connector-curvature="0" /> + transform="translate(123.605,58.9453)" + id="g4157"> + inkscape:connector-curvature="0" /> + transform="translate(131.147,58.9453)" + id="g4161"> + inkscape:connector-curvature="0" /> + transform="translate(137.9512,59.4316)" + id="g4165"> + inkscape:connector-curvature="0" /> + transform="translate(143.1533,66.3643)" + id="g4169"> + inkscape:connector-curvature="0" /> + transform="translate(155.4307,59.0898)" + id="g4173"> + d="M 0,0 -1.296,0 C -1.53,0 -1.638,0.108 -1.638,0.342 l 0.018,5.059 c 0,1.063 -0.252,1.765 -1.297,1.765 -0.72,0 -1.98,-0.576 -2.466,-0.811 l 0,-6.013 C -5.383,0.126 -5.474,0 -5.726,0 l -1.278,0 c -0.252,0 -0.342,0.108 -0.342,0.342 l 0,8.121 c 0,0.233 0.09,0.359 0.342,0.359 l 1.278,0 c 0.252,0 0.343,-0.126 0.343,-0.359 l 0,-0.541 c 0.018,0 0.035,-0.018 0.054,-0.018 0.666,0.468 1.927,1.08 3.024,1.08 2.431,0 2.648,-1.602 2.648,-3.421 l 0,-5.221 C 0.343,0.126 0.271,0 0,0" + inkscape:connector-curvature="0" /> + x="-3966.4153" + id="text3415-6"> - + JRC Petten + sodipodi:role="line" + x="-3966.4153" + style="font-size:85px;font-variant:normal;font-weight:bold;font-stretch:normal;text-align:center;writing-mode:lr-tb;text-anchor:middle;fill:#aa0000;fill-opacity:1;fill-rule:nonzero;stroke:none;font-family:Arial;-inkscape-font-specification:Arial">JRC Petten + height="410" + width="347.96054" />