shareModalCtrl.js 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. define(['angular',
  2. 'lodash',
  3. 'jquery',
  4. 'moment',
  5. 'require',
  6. 'app/core/config',
  7. ],
  8. function (angular, _, $, moment, require, config) {
  9. 'use strict';
  10. var module = angular.module('grafana.controllers');
  11. module.controller('ShareModalCtrl', function($scope, $rootScope, $location, $timeout, timeSrv, templateSrv, linkSrv) {
  12. $scope.options = { forCurrent: true, includeTemplateVars: true, theme: 'current' };
  13. $scope.editor = { index: $scope.tabIndex || 0};
  14. $scope.init = function() {
  15. $scope.modeSharePanel = $scope.panel ? true : false;
  16. $scope.tabs = [{title: 'Link', src: 'shareLink.html'}];
  17. if ($scope.modeSharePanel) {
  18. $scope.modalTitle = 'Share Panel';
  19. $scope.tabs.push({title: 'Embed', src: 'shareEmbed.html'});
  20. } else {
  21. $scope.modalTitle = 'Share';
  22. }
  23. if (!$scope.dashboard.meta.isSnapshot) {
  24. $scope.tabs.push({title: 'Snapshot', src: 'shareSnapshot.html'});
  25. }
  26. if (!$scope.dashboard.meta.isSnapshot && !$scope.modeSharePanel) {
  27. $scope.tabs.push({title: 'Export', src: 'shareExport.html'});
  28. }
  29. $scope.buildUrl();
  30. };
  31. $scope.buildUrl = function() {
  32. var baseUrl = $location.absUrl();
  33. var queryStart = baseUrl.indexOf('?');
  34. if (queryStart !== -1) {
  35. baseUrl = baseUrl.substring(0, queryStart);
  36. }
  37. var params = angular.copy($location.search());
  38. var range = timeSrv.timeRange();
  39. params.from = range.from.valueOf();
  40. params.to = range.to.valueOf();
  41. if ($scope.options.includeTemplateVars) {
  42. templateSrv.fillVariableValuesForUrl(params);
  43. }
  44. if (!$scope.options.forCurrent) {
  45. delete params.from;
  46. delete params.to;
  47. }
  48. if ($scope.options.theme !== 'current') {
  49. params.theme = $scope.options.theme;
  50. }
  51. if ($scope.modeSharePanel) {
  52. params.panelId = $scope.panel.id;
  53. params.fullscreen = true;
  54. } else {
  55. delete params.panelId;
  56. delete params.fullscreen;
  57. }
  58. $scope.shareUrl = linkSrv.addParamsToUrl(baseUrl, params);
  59. var soloUrl = $scope.shareUrl;
  60. soloUrl = soloUrl.replace(config.appSubUrl + '/dashboard/', config.appSubUrl + '/dashboard-solo/');
  61. soloUrl = soloUrl.replace("&fullscreen", "").replace("&edit", "");
  62. $scope.iframeHtml = '<iframe src="' + soloUrl + '" width="450" height="200" frameborder="0"></iframe>';
  63. $scope.imageUrl = soloUrl.replace(config.appSubUrl + '/dashboard-solo/', config.appSubUrl + '/render/dashboard-solo/');
  64. $scope.imageUrl += '&width=1000';
  65. $scope.imageUrl += '&height=500';
  66. $scope.imageUrl += '&tz=UTC' + encodeURIComponent(moment().format("Z"));
  67. };
  68. });
  69. module.directive('clipboardButton',function() {
  70. return function(scope, elem) {
  71. require(['vendor/clipboard/dist/clipboard'], function(Clipboard) {
  72. scope.clipboard = new Clipboard(elem[0]);
  73. });
  74. scope.$on('$destroy', function() {
  75. if (scope.clipboard) {
  76. scope.clipboard.destroy();
  77. }
  78. });
  79. };
  80. });
  81. });