mirror of
https://github.com/grafana/grafana.git
synced 2025-02-11 16:15:42 -06:00
116 lines
3.2 KiB
JavaScript
116 lines
3.2 KiB
JavaScript
define([
|
|
'angular',
|
|
'lodash',
|
|
'require',
|
|
'config',
|
|
],
|
|
function (angular, _, require, config) {
|
|
'use strict';
|
|
|
|
var module = angular.module('grafana.controllers');
|
|
|
|
module.controller('ShareModalCtrl', function($scope, $rootScope, $location, $timeout, timeSrv, $element, templateSrv) {
|
|
$scope.options = { forCurrent: true, includeTemplateVars: true, theme: 'current' };
|
|
$scope.editor = { index: 0 };
|
|
|
|
$scope.init = function() {
|
|
$scope.modeSharePanel = $scope.panel ? true : false;
|
|
|
|
$scope.tabs = [{title: 'Link', src: 'shareLink.html'}];
|
|
|
|
if ($scope.modeSharePanel) {
|
|
$scope.modalTitle = 'Share Panel';
|
|
$scope.tabs.push({title: 'Embed', src: 'shareEmbed.html'});
|
|
} else {
|
|
$scope.modalTitle = 'Share Dashboard';
|
|
}
|
|
|
|
if (!$scope.dashboardMeta.isSnapshot) {
|
|
$scope.tabs.push({title: 'Snapshot sharing', src: 'shareSnapshot.html'});
|
|
}
|
|
|
|
$scope.buildUrl();
|
|
};
|
|
|
|
$scope.buildUrl = function() {
|
|
var baseUrl = $location.absUrl();
|
|
var queryStart = baseUrl.indexOf('?');
|
|
|
|
if (queryStart !== -1) {
|
|
baseUrl = baseUrl.substring(0, queryStart);
|
|
}
|
|
|
|
var params = angular.copy($location.search());
|
|
|
|
var range = timeSrv.timeRangeForUrl();
|
|
params.from = range.from;
|
|
params.to = range.to;
|
|
|
|
if ($scope.options.includeTemplateVars) {
|
|
_.each(templateSrv.variables, function(variable) {
|
|
params['var-' + variable.name] = variable.current.text;
|
|
});
|
|
}
|
|
else {
|
|
_.each(templateSrv.variables, function(variable) {
|
|
delete params['var-' + variable.name];
|
|
});
|
|
}
|
|
|
|
if (!$scope.options.forCurrent) {
|
|
delete params.from;
|
|
delete params.to;
|
|
}
|
|
|
|
if ($scope.options.theme !== 'current') {
|
|
params.theme = $scope.options.theme;
|
|
}
|
|
|
|
if ($scope.modeSharePanel) {
|
|
params.panelId = $scope.panel.id;
|
|
params.fullscreen = true;
|
|
} else {
|
|
delete params.panelId;
|
|
delete params.fullscreen;
|
|
}
|
|
|
|
var paramsArray = [];
|
|
_.each(params, function(value, key) {
|
|
if (value === null) { return; }
|
|
if (value === true) {
|
|
paramsArray.push(key);
|
|
} else {
|
|
key += '=' + encodeURIComponent(value);
|
|
paramsArray.push(key);
|
|
}
|
|
});
|
|
|
|
var queryParams = "?" + paramsArray.join('&');
|
|
$scope.shareUrl = baseUrl + queryParams;
|
|
|
|
var soloUrl = $scope.shareUrl;
|
|
soloUrl = soloUrl.replace('/dashboard/db/', '/dashboard/solo/db/');
|
|
soloUrl = soloUrl.replace('/dashboard/snapshot/', '/dashboard/solo/snapshot/');
|
|
|
|
$scope.iframeHtml = '<iframe src="' + soloUrl + '" width="450" height="200" frameborder="0"></iframe>';
|
|
|
|
$scope.imageUrl = soloUrl.replace('/dashboard/', '/render/dashboard/');
|
|
$scope.imageUrl += '&width=1000';
|
|
$scope.imageUrl += '&height=500';
|
|
};
|
|
|
|
});
|
|
|
|
module.directive('clipboardButton',function() {
|
|
return function(scope, elem) {
|
|
require(['ZeroClipboard'], function(ZeroClipboard) {
|
|
ZeroClipboard.config({
|
|
swfPath: config.appSubUrl + '/public/vendor/ZeroClipboard.swf'
|
|
});
|
|
new ZeroClipboard(elem[0]);
|
|
});
|
|
};
|
|
});
|
|
|
|
});
|