/* * Copyright © 2016-2017 The Thingsboard Authors * * 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. */ import './widget.scss'; import thingsboardTypes from '../common/types.constant'; import thingsboardApiDatasource from '../api/datasource.service'; import WidgetController from './widget.controller'; export default angular.module('thingsboard.directives.widget', [thingsboardTypes, thingsboardApiDatasource]) .controller('WidgetController', WidgetController) .directive('tbWidget', Widget) .name; /*@ngInject*/ function Widget($controller, $compile, widgetService) { return { scope: true, link: function (scope, elem, attrs) { var locals = scope.$eval(attrs.locals); var widget = locals.widget; var widgetController; var gridsterItem; //TODO: widgets visibility /*scope.$on('visibleRectChanged', function (event, newVisibleRect) { locals.visibleRect = newVisibleRect; if (widgetController) { widgetController.visibleRectChanged(newVisibleRect); } });*/ scope.$on('gridster-item-initialized', function (event, item) { gridsterItem = item; if (widgetController) { widgetController.gridsterItemInitialized(gridsterItem); } }); elem.html('
' + ' ' + '
'); $compile(elem.contents())(scope); widgetService.getWidgetInfo(widget.bundleAlias, widget.typeAlias, widget.isSystemType).then( function(widgetInfo) { loadFromWidgetInfo(widgetInfo); } ); function loadFromWidgetInfo(widgetInfo) { elem.addClass("tb-widget"); var widgetNamespace = "widget-type-" + (widget.isSystemType ? 'sys-' : '') + widget.bundleAlias + '-' + widget.typeAlias; elem.addClass(widgetNamespace); elem.html('
' + 'Widget Error: {{ widgetErrorData.name + ": " + widgetErrorData.message}}' + '
' + '
' + widgetInfo.templateHtml + '
'); $compile(elem.contents())(scope); var widgetType = widgetService.getWidgetTypeFunction(widget.bundleAlias, widget.typeAlias, widget.isSystemType); angular.extend(locals, {$scope: scope, $element: elem, widgetType: widgetType}); widgetController = $controller('WidgetController', locals); if (gridsterItem) { widgetController.gridsterItemInitialized(gridsterItem); } } } }; }