2015-05-06 17:21:29 +00:00
|
|
|
<span ng-controller="PlotController as plot"
|
|
|
|
ng-mouseleave="representation.showControls = false">
|
|
|
|
|
|
|
|
<div class="gl-plot"
|
|
|
|
ng-style="{ height: 100 / plot.getSubPlots().length + '%'}"
|
|
|
|
ng-repeat="subplot in plot.getSubPlots()">
|
|
|
|
<div class="gl-plot-legend">
|
2015-05-06 23:55:25 +00:00
|
|
|
<!-- ng-class is temporarily hard-coded in next element -->
|
2015-05-06 17:21:29 +00:00
|
|
|
<span
|
|
|
|
class='plot-legend-item'
|
|
|
|
ng-repeat="telemetryObject in subplot.getTelemetryObjects()"
|
2015-05-06 23:55:25 +00:00
|
|
|
ng-class="{ 's-limit-lwr': $index < 1, 's-limit-yellow' : 1 }"
|
2015-05-06 17:21:29 +00:00
|
|
|
>
|
|
|
|
<span class='plot-color-swatch'
|
|
|
|
ng-style="{ 'background-color': plot.getColor($index) }">
|
2014-12-11 02:29:18 +00:00
|
|
|
</span>
|
2015-05-06 17:21:29 +00:00
|
|
|
<span class='title-label'>{{telemetryObject.getModel().name}}</span>
|
|
|
|
</span>
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div
|
|
|
|
class="gl-plot-coords"
|
|
|
|
ng-if="subplot.isHovering() && subplot.getHoverCoordinates()"
|
|
|
|
>
|
|
|
|
{{subplot.getHoverCoordinates()}}
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-axis-area gl-plot-y">
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-label gl-plot-y-label">
|
|
|
|
{{axes[1].active.name}}
|
|
|
|
</div>
|
2014-12-11 02:29:18 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div ng-repeat="tick in subplot.getRangeTicks()"
|
|
|
|
class="gl-plot-tick gl-plot-y-tick-label"
|
|
|
|
ng-style="{ bottom: (100 * $index / (subplot.getRangeTicks().length - 1)) + '%' }">
|
|
|
|
{{tick.label}}
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-y-options gl-plot-local-controls"
|
|
|
|
ng-show="representation.showControls"
|
|
|
|
ng-if="axes[1].options.length > 0">
|
|
|
|
<div class='form-control shell select'>
|
|
|
|
<select class="form-control input shell select"
|
|
|
|
ng-model="axes[1].active"
|
|
|
|
ng-options="option.name for option in axes[1].options">
|
|
|
|
</select>
|
2014-12-11 02:55:47 +00:00
|
|
|
</div>
|
2014-12-11 02:29:18 +00:00
|
|
|
</div>
|
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
</div>
|
2014-12-01 17:41:39 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-display-area"
|
|
|
|
ng-mouseenter="subplot.isHovering(true); representation.showControls = true;"
|
|
|
|
ng-mouseleave="subplot.isHovering(false)">
|
|
|
|
|
|
|
|
<!-- Out-of-bounds data indicators -->
|
2015-05-06 23:55:25 +00:00
|
|
|
<!-- ng-show is temporarily hard-coded in next element -->
|
2015-05-06 17:21:29 +00:00
|
|
|
<div ng-show="1" class="l-oob-data l-oob-data-up"></div>
|
|
|
|
<div ng-show="1" class="l-oob-data l-oob-data-dwn"></div>
|
|
|
|
|
|
|
|
<div class="gl-plot-hash hash-v"
|
|
|
|
ng-repeat="tick in subplot.getDomainTicks()"
|
|
|
|
ng-style="{ left: (100 * $index / (subplot.getDomainTicks().length - 1)) + '%', height: '100%' }"
|
|
|
|
ng-show="$index > 0 && $index < (subplot.getDomainTicks().length - 1)">
|
|
|
|
</div>
|
|
|
|
<div class="gl-plot-hash hash-h"
|
|
|
|
ng-repeat="tick in subplot.getRangeTicks()"
|
|
|
|
ng-style="{ bottom: (100 * $index / (subplot.getRangeTicks().length - 1)) + '%', width: '100%' }"
|
|
|
|
ng-show="$index > 0 && $index < (subplot.getRangeTicks().length - 1)">
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<mct-chart draw="subplot.getDrawingObject()"
|
|
|
|
ng-mousemove="subplot.hover($event)"
|
|
|
|
ng-mousedown="subplot.startMarquee($event)"
|
|
|
|
ng-mouseup="subplot.endMarquee($event); plot.update()">
|
|
|
|
</mct-chart>
|
|
|
|
|
|
|
|
<!-- TODO: Move into correct position; make part of group; infer from set of actions -->
|
|
|
|
<div class="gl-plot-local-controls"
|
|
|
|
ng-if="$first"
|
|
|
|
ng-show="representation.showControls"
|
|
|
|
style="position: absolute; top: 8px; right: 8px;">
|
|
|
|
|
|
|
|
<a href=""
|
|
|
|
class="t-btn l-btn s-btn s-icon-btn s-very-subtle"
|
|
|
|
ng-click="plot.stepBackPanZoom()"
|
|
|
|
ng-show="plot.isZoomed()"
|
|
|
|
title="Restore previous pan/zoom">
|
|
|
|
<span class="ui-symbol icon"><</span>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<a href=""
|
|
|
|
class="t-btn l-btn s-btn s-icon-btn s-very-subtle"
|
|
|
|
ng-click="plot.unzoom()"
|
|
|
|
ng-show="plot.isZoomed()"
|
|
|
|
title="Reset pan/zoom">
|
|
|
|
<span class="ui-symbol icon">I</span>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<div class="menu-element btn icon-btn very-subtle btn-menu dropdown click-invoke"
|
|
|
|
ng-if="plot.getModeOptions().length > 1"
|
|
|
|
ng-controller="ClickAwayController as toggle">
|
|
|
|
|
|
|
|
<span class="l-click-area" ng-click="toggle.toggle()"></span>
|
|
|
|
|
|
|
|
<span class="ui-symbol icon type-icon">{{plot.getMode().glyph}}</span>
|
|
|
|
<span>{{plot.getMode().name}}</span>
|
|
|
|
<span class='ui-symbol icon invoke-menu'>v</span>
|
|
|
|
|
|
|
|
<div class="menu dropdown" ng-show="toggle.isActive()">
|
|
|
|
<ul>
|
|
|
|
<li ng-repeat="option in plot.getModeOptions()">
|
|
|
|
<a href="" ng-click="plot.setMode(option); toggle.setState(false)">
|
|
|
|
<span class="ui-symbol type-icon icon">
|
|
|
|
{{option.glyph}}
|
|
|
|
</span>
|
|
|
|
{{option.name}}
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
</ul>
|
2014-12-11 02:55:47 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2014-12-01 17:41:39 +00:00
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<span class="t-wait-spinner loading" ng-show="plot.isRequestPending()">
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
<div ng-if="$last" class="gl-plot-axis-area gl-plot-x">
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div ng-repeat="tick in subplot.getDomainTicks()"
|
|
|
|
class="gl-plot-tick gl-plot-x-tick-label"
|
|
|
|
ng-show="$index > 0 && $index < (subplot.getDomainTicks().length - 1)"
|
|
|
|
ng-style="{ left: (100 * $index / (subplot.getDomainTicks().length - 1)) + '%' }">
|
|
|
|
{{tick.label}}
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-label gl-plot-x-label">
|
|
|
|
{{axes[0].active.name}}
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
|
|
|
|
|
2015-05-06 17:21:29 +00:00
|
|
|
<div class="gl-plot-x-options gl-plot-local-controls"
|
|
|
|
ng-show="representation.showControls"
|
|
|
|
ng-if="axes[0].options.length > 0">
|
|
|
|
<div class='form-control shell select'>
|
|
|
|
<select class="form-control input shell select"
|
|
|
|
ng-model="axes[0].active"
|
|
|
|
ng-options="option.name for option in axes[0].options">
|
|
|
|
</select>
|
|
|
|
</div>
|
2014-12-11 02:55:47 +00:00
|
|
|
</div>
|
2015-05-06 17:21:29 +00:00
|
|
|
|
2015-01-29 17:05:40 +00:00
|
|
|
</div>
|
2015-05-06 17:21:29 +00:00
|
|
|
</div>
|
|
|
|
</span>
|
2014-12-01 17:41:39 +00:00
|
|
|
|