pgadmin4/web/pgadmin/static/js/ToolView.jsx

76 lines
2.2 KiB
JavaScript

/////////////////////////////////////////////////////////////
//
// pgAdmin 4 - PostgreSQL Tools
//
// Copyright (C) 2013 - 2024, The pgAdmin Development Team
// This software is released under the PostgreSQL Licence
//
//////////////////////////////////////////////////////////////
import React, { useEffect, useLayoutEffect, useRef } from 'react';
import ReactDOM from 'react-dom/client';
import { usePgAdmin } from './BrowserComponent';
import { BROWSER_PANELS } from '../../browser/static/js/constants';
import PropTypes from 'prop-types';
import LayoutIframeTab from './helpers/Layout/LayoutIframeTab';
function ToolForm({actionUrl, params}) {
const formRef = useRef(null);
useLayoutEffect(()=>{
formRef.current?.submit();
}, []);
return (
<form ref={formRef} id="tool-form" action={actionUrl} method="post" hidden>
{Object.keys(params).map((k)=>{
return k ? <input key={k} name={k} defaultValue={params[k]} /> : <></>;
})}
</form>
);
}
ToolForm.propTypes = {
actionUrl: PropTypes.string,
params: PropTypes.object,
};
export default function ToolView() {
const pgAdmin = usePgAdmin();
useEffect(()=>{
pgAdmin.Browser.Events.on('pgadmin:tool:show', (panelId, toolUrl, formParams, tabParams, newTab)=>{
if(newTab) {
if(formParams) {
const newWin = window.open('', '_blank');
const div = newWin.document.createElement('div');
newWin.document.body.appendChild(div);
const root = ReactDOM.createRoot(div);
root.render(
<ToolForm actionUrl={window.location.origin+toolUrl} params={formParams}/>, div
);
} else {
window.open(toolUrl);
}
} else {
pgAdmin.Browser.docker.openTab({
id: panelId,
title: panelId,
content: (
<LayoutIframeTab target={panelId} src={formParams ? undefined : toolUrl}>
{formParams && <ToolForm actionUrl={toolUrl} params={formParams}/>}
</LayoutIframeTab>
),
closable: true,
manualClose: true,
...tabParams,
cache: false,
group: 'playground'
}, BROWSER_PANELS.MAIN, 'middle', true);
}
});
}, []);
return <></>;
}