| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- import angular from 'angular';
- import { saveAs } from 'file-saver';
- import coreModule from 'app/core/core_module';
- import { DashboardExporter } from './exporter';
- export class DashExportCtrl {
- dash: any;
- exporter: DashboardExporter;
- dismiss: () => void;
- shareExternally: boolean;
- /** @ngInject */
- constructor(private dashboardSrv, datasourceSrv, private $scope, private $rootScope) {
- this.exporter = new DashboardExporter(datasourceSrv);
- this.dash = this.dashboardSrv.getCurrent();
- }
- saveDashboardAsFile() {
- if (this.shareExternally) {
- this.exporter.makeExportable(this.dash).then((dashboardJson: any) => {
- this.$scope.$apply(() => {
- this.openSaveAsDialog(dashboardJson);
- });
- });
- } else {
- this.openSaveAsDialog(this.dash.getSaveModelClone());
- }
- }
- viewJson() {
- if (this.shareExternally) {
- this.exporter.makeExportable(this.dash).then((dashboardJson: any) => {
- this.$scope.$apply(() => {
- this.openJsonModal(dashboardJson);
- });
- });
- } else {
- this.openJsonModal(this.dash.getSaveModelClone());
- }
- }
- private openSaveAsDialog(dash: any) {
- const blob = new Blob([angular.toJson(dash, true)], {
- type: 'application/json;charset=utf-8',
- });
- saveAs(blob, dash.title + '-' + new Date().getTime() + '.json');
- }
- private openJsonModal(clone: object) {
- const model = {
- object: clone,
- enableCopy: true,
- };
- this.$rootScope.appEvent('show-modal', {
- src: 'public/app/partials/edit_json.html',
- model: model,
- });
- this.dismiss();
- }
- }
- export function dashExportDirective() {
- return {
- restrict: 'E',
- templateUrl: 'public/app/features/dashboard/export/export_modal.html',
- controller: DashExportCtrl,
- bindToController: true,
- controllerAs: 'ctrl',
- scope: { dismiss: '&' },
- };
- }
- coreModule.directive('dashExportModal', dashExportDirective);
|