aboutsummaryrefslogtreecommitdiffstats
path: root/client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx
diff options
context:
space:
mode:
Diffstat (limited to 'client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx')
-rw-r--r--client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx44
1 files changed, 44 insertions, 0 deletions
diff --git a/client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx b/client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx
new file mode 100644
index 00000000000..7ec6683afa3
--- /dev/null
+++ b/client/js/app/src/app/pages/querybuilder/Components/Buttons/DownloadJSONButton.jsx
@@ -0,0 +1,44 @@
+import React, { useContext } from 'react';
+import { ResponseContext } from '../Contexts/ResponseContext';
+import transform from '../../TransformVespaTrace';
+import SimpleButton from './SimpleButton';
+
+export default function DownloadJSONButton({ children }) {
+ const { response } = useContext(ResponseContext);
+
+ const transformResponse = (response) => {
+ return transform(response);
+ };
+
+ const handleClick = () => {
+ if (response != '') {
+ let transformedResponse = JSON.stringify(
+ transformResponse(JSON.parse(response), undefined, '\t')
+ );
+ // copied from safakeskinĀ“s answer on SO, link: https://stackoverflow.com/questions/55613438/reactwrite-to-json-file-or-export-download-no-server
+ const fileName = 'vespa-response';
+ const blob = new Blob([transformedResponse], {
+ type: 'application/json',
+ });
+ const href = URL.createObjectURL(blob);
+
+ // create "a" HTLM element with href to file
+ const link = document.createElement('a');
+ link.href = href;
+ link.download = fileName + '.json';
+ document.body.appendChild(link);
+ link.click();
+
+ // clean up "a" element & remove ObjectURL
+ document.body.removeChild(link);
+ URL.revokeObjectURL(href);
+
+ // open Jaeger in a new tab
+ window.open('http://localhost:16686/search', '__blank');
+ } else {
+ alert('Response was empty');
+ }
+ };
+
+ return <SimpleButton onClick={handleClick}>{children}</SimpleButton>;
+}