| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100 |
- /** @scratch /panels/5
- * include::panels/text.asciidoc[]
- */
- /** @scratch /panels/text/0
- * == text
- * Status: *Stable*
- *
- * The text panel is used for displaying static text formated as markdown, sanitized html or as plain
- * text.
- *
- */
- define([
- 'angular',
- 'app',
- 'lodash',
- 'require',
- 'services/filterSrv'
- ],
- function (angular, app, _, require) {
- 'use strict';
- var module = angular.module('grafana.panels.text', []);
- app.useModule(module);
- module.controller('text', function($scope, filterSrv, $sce, panelSrv) {
- $scope.panelMeta = {
- description : "A static text panel that can use plain text, markdown, or (sanitized) HTML"
- };
- // Set and populate defaults
- var _d = {
- mode : "markdown", // 'html', 'markdown', 'text'
- content : "",
- style: {},
- };
- _.defaults($scope.panel, _d);
- $scope.init = function() {
- panelSrv.init(this);
- $scope.ready = false;
- $scope.$on('refresh', $scope.render);
- $scope.render();
- };
- $scope.render = function() {
- if ($scope.panel.mode === 'markdown') {
- $scope.renderMarkdown($scope.panel.content);
- }
- else if ($scope.panel.mode === 'html') {
- $scope.updateContent($scope.panel.content);
- }
- else if ($scope.panel.mode === 'text') {
- $scope.renderText($scope.panel.content);
- }
- };
- $scope.renderText = function(content) {
- content = content
- .replace(/&/g, '&')
- .replace(/>/g, '>')
- .replace(/</g, '<')
- .replace(/\n/g, '<br/>');
- $scope.updateContent(content);
- };
- $scope.renderMarkdown = function(content) {
- require(['./lib/showdown'], function (Showdown) {
- var converter = new Showdown.converter();
- var text = content
- .replace(/&/g, '&')
- .replace(/>/g, '>')
- .replace(/</g, '<');
- $scope.updateContent(converter.makeHtml(text));
- });
- };
- $scope.updateContent = function(html) {
- try {
- $scope.content = $sce.trustAsHtml(filterSrv.applyTemplateToTarget(html));
- } catch(e) {
- console.log('Text panel error: ', e);
- $scope.content = $sce.trustAsHtml(html);
- }
- if(!$scope.$$phase) {
- $scope.$digest();
- }
- };
- $scope.openEditor = function() {
- };
- $scope.init();
- });
- });
|