| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- /*
- ## Text
- A simple panel of static content
- ### Parameters
- * mode :: 'text', 'html', 'markdown'
- * content :: Content of the panel
- * style :: Hash containing css properties
-
- */
- angular.module('kibana.text', [])
- .controller('text', function($scope, $rootScope) {
- // Set and populate defaults
- var _d = {
- group : "default",
- mode : "markdown",
- content : "",
- style: {},
- }
- _.defaults($scope.panel,_d);
- $scope.init = function() {
- $scope.ready = false;
- }
-
- }).directive('markdown', function() {
- return {
- restrict: 'E',
- link: function(scope, element, attrs) {
- scope.$on('render', function() {
- render_panel();
- })
- function render_panel() {
- var scripts = $LAB.script("panels/text/lib/showdown.js")
- scripts.wait(function(){
- scope.ready = true;
- var converter = new Showdown.converter();
- var text = scope.panel.content.replace(/&/g, '&')
- .replace(/>/g, '>')
- .replace(/</g, '<');
- var htmlText = converter.makeHtml(text);
- element.html(htmlText);
- // For whatever reason, this fixes chrome. I don't like it, I think
- // it makes things slow?
- scope.$apply()
- });
- }
- render_panel();
- }
- }
- })
- .filter('newlines', function(){
- return function (input) {
- return input.replace(/\n/g, '<br/>');
- }
- })
- .filter('striphtml', function () {
- return function(text) {
- return text
- .replace(/&/g, '&')
- .replace(/>/g, '>')
- .replace(/</g, '<');
- }
- });
|