2016-12-01 11:40:28 +02:00
|
|
|
/*
|
2017-01-09 23:11:09 +02:00
|
|
|
* Copyright © 2016-2017 The Thingsboard Authors
|
2016-12-01 11:40:28 +02:00
|
|
|
*
|
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
|
*
|
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
*
|
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
|
* limitations under the License.
|
|
|
|
|
*/
|
2017-02-22 21:34:28 +02:00
|
|
|
|
|
|
|
|
import './widget.scss';
|
|
|
|
|
|
2017-03-03 18:09:14 +02:00
|
|
|
import thingsboardLegend from './legend.directive';
|
2016-12-01 11:40:28 +02:00
|
|
|
import thingsboardTypes from '../common/types.constant';
|
|
|
|
|
import thingsboardApiDatasource from '../api/datasource.service';
|
|
|
|
|
|
|
|
|
|
import WidgetController from './widget.controller';
|
|
|
|
|
|
2017-03-03 18:09:14 +02:00
|
|
|
export default angular.module('thingsboard.directives.widget', [thingsboardLegend, thingsboardTypes, thingsboardApiDatasource])
|
2016-12-01 11:40:28 +02:00
|
|
|
.controller('WidgetController', WidgetController)
|
|
|
|
|
.directive('tbWidget', Widget)
|
|
|
|
|
.name;
|
|
|
|
|
|
|
|
|
|
/*@ngInject*/
|
2017-03-03 18:09:14 +02:00
|
|
|
function Widget($controller, $compile, types, widgetService) {
|
2016-12-01 11:40:28 +02:00
|
|
|
return {
|
|
|
|
|
scope: true,
|
|
|
|
|
link: function (scope, elem, attrs) {
|
|
|
|
|
|
|
|
|
|
var locals = scope.$eval(attrs.locals);
|
|
|
|
|
var widget = locals.widget;
|
2017-02-09 18:33:03 +02:00
|
|
|
|
|
|
|
|
var widgetController;
|
2016-12-01 11:40:28 +02:00
|
|
|
var gridsterItem;
|
|
|
|
|
|
2017-02-09 18:33:03 +02:00
|
|
|
//TODO: widgets visibility
|
|
|
|
|
/*scope.$on('visibleRectChanged', function (event, newVisibleRect) {
|
2016-12-22 18:51:40 +02:00
|
|
|
locals.visibleRect = newVisibleRect;
|
|
|
|
|
if (widgetController) {
|
|
|
|
|
widgetController.visibleRectChanged(newVisibleRect);
|
|
|
|
|
}
|
2017-02-09 18:33:03 +02:00
|
|
|
});*/
|
2016-12-22 18:51:40 +02:00
|
|
|
|
2016-12-01 11:40:28 +02:00
|
|
|
scope.$on('gridster-item-initialized', function (event, item) {
|
|
|
|
|
gridsterItem = item;
|
|
|
|
|
if (widgetController) {
|
|
|
|
|
widgetController.gridsterItemInitialized(gridsterItem);
|
|
|
|
|
}
|
2016-12-22 18:51:40 +02:00
|
|
|
});
|
2016-12-01 11:40:28 +02:00
|
|
|
|
2017-03-03 18:09:14 +02:00
|
|
|
//TODO:
|
|
|
|
|
//elem.html('<div id="progress-cover" flex layout="column" layout-align="center center" style="height: 100%;">' +
|
|
|
|
|
// ' <md-progress-circular md-mode="indeterminate" class="md-accent md-hue-2" md-diameter="120"></md-progress-circular>' +
|
|
|
|
|
// '</div>');
|
|
|
|
|
|
|
|
|
|
//var progressElement = angular.element(elem[0].querySelector('#progress-cover'));
|
|
|
|
|
//var progressScope = scope.$new();
|
|
|
|
|
//$compile(elem.contents())(progressScope);
|
2016-12-01 11:40:28 +02:00
|
|
|
|
|
|
|
|
widgetService.getWidgetInfo(widget.bundleAlias, widget.typeAlias, widget.isSystemType).then(
|
|
|
|
|
function(widgetInfo) {
|
|
|
|
|
loadFromWidgetInfo(widgetInfo);
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
function loadFromWidgetInfo(widgetInfo) {
|
|
|
|
|
|
2017-03-01 20:02:01 +02:00
|
|
|
scope.loadingData = true;
|
|
|
|
|
|
2016-12-01 11:40:28 +02:00
|
|
|
elem.addClass("tb-widget");
|
|
|
|
|
|
|
|
|
|
var widgetNamespace = "widget-type-" + (widget.isSystemType ? 'sys-' : '')
|
|
|
|
|
+ widget.bundleAlias + '-'
|
|
|
|
|
+ widget.typeAlias;
|
|
|
|
|
|
|
|
|
|
elem.addClass(widgetNamespace);
|
2017-03-03 18:09:14 +02:00
|
|
|
|
|
|
|
|
var html = '<div class="tb-absolute-fill tb-widget-error" ng-if="widgetErrorData">' +
|
|
|
|
|
'<span>Widget Error: {{ widgetErrorData.name + ": " + widgetErrorData.message}}</span>' +
|
|
|
|
|
'</div>' +
|
|
|
|
|
'<div class="tb-absolute-fill tb-widget-loading" ng-show="loadingData" layout="column" layout-align="center center">' +
|
|
|
|
|
'<md-progress-circular md-mode="indeterminate" ng-disabled="!loadingData" class="md-accent" md-diameter="40"></md-progress-circular>' +
|
|
|
|
|
'</div>';
|
|
|
|
|
|
|
|
|
|
scope.displayLegend = angular.isDefined(widget.config.showLegend) ?
|
|
|
|
|
widget.config.showLegend : widget.type === types.widgetType.timeseries.value;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var containerHtml = '<div id="container">' + widgetInfo.templateHtml + '</div>';
|
|
|
|
|
if (scope.displayLegend) {
|
|
|
|
|
scope.legendConfig = widget.config.legendConfig ||
|
|
|
|
|
{
|
|
|
|
|
position: types.position.bottom.value,
|
|
|
|
|
showMin: false,
|
|
|
|
|
showMax: false,
|
|
|
|
|
showAvg: widget.type === types.widgetType.timeseries.value,
|
|
|
|
|
showTotal: false
|
|
|
|
|
};
|
|
|
|
|
scope.legendData = {
|
|
|
|
|
keys: [],
|
|
|
|
|
data: []
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
var layoutType;
|
|
|
|
|
if (scope.legendConfig.position === types.position.top.value ||
|
|
|
|
|
scope.legendConfig.position === types.position.bottom.value) {
|
|
|
|
|
layoutType = 'column';
|
|
|
|
|
} else {
|
|
|
|
|
layoutType = 'row';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var legendStyle;
|
|
|
|
|
switch(scope.legendConfig.position) {
|
|
|
|
|
case types.position.top.value:
|
|
|
|
|
legendStyle = 'padding-bottom: 8px;';
|
|
|
|
|
break;
|
|
|
|
|
case types.position.bottom.value:
|
|
|
|
|
legendStyle = 'padding-top: 8px;';
|
|
|
|
|
break;
|
|
|
|
|
case types.position.left.value:
|
|
|
|
|
legendStyle = 'padding-right: 0px;';
|
|
|
|
|
break;
|
|
|
|
|
case types.position.right.value:
|
|
|
|
|
legendStyle = 'padding-left: 0px;';
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var legendHtml = '<tb-legend style="'+legendStyle+'" legend-config="legendConfig" legend-data="legendData"></tb-legend>';
|
|
|
|
|
containerHtml = '<div flex id="widget-container">' + containerHtml + '</div>';
|
|
|
|
|
html += '<div class="tb-absolute-fill" layout="'+layoutType+'">';
|
|
|
|
|
if (scope.legendConfig.position === types.position.top.value ||
|
|
|
|
|
scope.legendConfig.position === types.position.left.value) {
|
|
|
|
|
html += legendHtml;
|
|
|
|
|
html += containerHtml;
|
|
|
|
|
} else {
|
|
|
|
|
html += containerHtml;
|
|
|
|
|
html += legendHtml;
|
|
|
|
|
}
|
|
|
|
|
html += '</div>';
|
|
|
|
|
} else {
|
|
|
|
|
html += containerHtml;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//TODO:
|
|
|
|
|
/*if (progressElement) {
|
|
|
|
|
progressScope.$destroy();
|
|
|
|
|
progressScope = null;
|
|
|
|
|
|
|
|
|
|
progressElement.remove();
|
|
|
|
|
progressElement = null;
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
elem.html(html);
|
|
|
|
|
|
|
|
|
|
var containerElement = scope.displayLegend ? angular.element(elem[0].querySelector('#widget-container')) : elem;
|
2016-12-01 11:40:28 +02:00
|
|
|
|
|
|
|
|
$compile(elem.contents())(scope);
|
|
|
|
|
|
2017-02-22 21:34:28 +02:00
|
|
|
var widgetType = widgetService.getWidgetTypeFunction(widget.bundleAlias, widget.typeAlias, widget.isSystemType);
|
|
|
|
|
|
2017-03-03 18:09:14 +02:00
|
|
|
angular.extend(locals, {$scope: scope, $element: containerElement, widgetType: widgetType});
|
2017-02-22 21:34:28 +02:00
|
|
|
|
|
|
|
|
widgetController = $controller('WidgetController', locals);
|
2017-02-09 18:33:03 +02:00
|
|
|
|
2016-12-01 11:40:28 +02:00
|
|
|
if (gridsterItem) {
|
|
|
|
|
widgetController.gridsterItemInitialized(gridsterItem);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|