diff --git a/web/pgadmin/misc/bgprocess/static/js/Processes.jsx b/web/pgadmin/misc/bgprocess/static/js/Processes.jsx index 3c6bda8ac4a..30ea735778c 100644 --- a/web/pgadmin/misc/bgprocess/static/js/Processes.jsx +++ b/web/pgadmin/misc/bgprocess/static/js/Processes.jsx @@ -117,7 +117,7 @@ export default function Processes() { /> ) - }, pgAdmin.Browser.stdW.md); + }, pgAdmin.Browser.stdW.md, pgAdmin.Browser.stdH.md); }, []); diff --git a/web/pgadmin/misc/statistics/static/js/Statistics.jsx b/web/pgadmin/misc/statistics/static/js/Statistics.jsx index be2a093778e..548a63dcae0 100644 --- a/web/pgadmin/misc/statistics/static/js/Statistics.jsx +++ b/web/pgadmin/misc/statistics/static/js/Statistics.jsx @@ -157,7 +157,6 @@ function createSingleLineStatistics(data, prettifyFields) { return res; } -// {nodeData, node, treeNodeInfo, isActive, isStale, setIsStale} function Statistics({ nodeData, nodeItem, node, treeNodeInfo, isActive, isStale, setIsStale }) { const classes = useStyles(); const [tableData, setTableData] = React.useState([]); diff --git a/web/pgadmin/preferences/static/js/components/PreferencesComponent.jsx b/web/pgadmin/preferences/static/js/components/PreferencesComponent.jsx index b03676c4f76..02aa30c2414 100644 --- a/web/pgadmin/preferences/static/js/components/PreferencesComponent.jsx +++ b/web/pgadmin/preferences/static/js/components/PreferencesComponent.jsx @@ -559,7 +559,6 @@ export default function PreferencesComponent({ ...props }) { function () { pgAdmin.Browser.tree.destroy({ success: function () { - // pgAdmin.Browser.initializeBrowserTree(pgAdmin.Browser); return true; }, }); diff --git a/web/pgadmin/static/bundle/app.js b/web/pgadmin/static/bundle/app.js index 48fb830e78d..1cacf50e3ec 100644 --- a/web/pgadmin/static/bundle/app.js +++ b/web/pgadmin/static/bundle/app.js @@ -50,21 +50,6 @@ define('app', [ // Create menus after all modules are initialized. MainMenuFactory.createMainMenus(); - // const menuContainerEle = document.querySelector('#main-menu-container'); - // if(menuContainerEle) { - // ReactDOM.render( - // - // - // , menuContainerEle - // ); - // } - - // ReactDOM.render( - // - // - // , document.querySelector('#object-breadcrumbs') - // ); - ReactDOM.render( diff --git a/web/pgadmin/static/js/BrowserComponent.jsx b/web/pgadmin/static/js/BrowserComponent.jsx index 29e5a636b62..077cfa1eb11 100644 --- a/web/pgadmin/static/js/BrowserComponent.jsx +++ b/web/pgadmin/static/js/BrowserComponent.jsx @@ -43,7 +43,7 @@ export const defaultTabsData = [ id: BROWSER_PANELS.DASHBOARD, title: gettext('Dashboard'), content: , closable: true, group: 'main' }, { - id: BROWSER_PANELS.PROPERTIES, title: gettext('Properties'), content: , closable: true, + id: BROWSER_PANELS.PROPERTIES, title: gettext('Properties'), content: , closable: true, group: 'main' }, { id: BROWSER_PANELS.SQL, title: gettext('SQL'), content: , closable: true, group: 'main' diff --git a/web/pgadmin/static/js/Dialogs/ConnectServerContent.jsx b/web/pgadmin/static/js/Dialogs/ConnectServerContent.jsx index 1e4cde83a3f..a9998047137 100644 --- a/web/pgadmin/static/js/Dialogs/ConnectServerContent.jsx +++ b/web/pgadmin/static/js/Dialogs/ConnectServerContent.jsx @@ -31,7 +31,7 @@ export default function ConnectServerContent({closeModal, data, onOK, setHeight} const onTextChange = (e, id) => { let val = e; - if(e && e.target) { + if(e?.target) { val = e.target.value; } setFormData((prev)=>({...prev, [id]: val})); diff --git a/web/pgadmin/static/js/Dialogs/MasterPasswordContent.jsx b/web/pgadmin/static/js/Dialogs/MasterPasswordContent.jsx index 585ad066dd2..eadcbd9d1fb 100644 --- a/web/pgadmin/static/js/Dialogs/MasterPasswordContent.jsx +++ b/web/pgadmin/static/js/Dialogs/MasterPasswordContent.jsx @@ -34,7 +34,7 @@ export default function MasterPasswordContent({ closeModal, onResetPassowrd, onO const onTextChange = (e, id) => { let val = e; - if (e && e.target) { + if (e?.target) { val = e.target.value; } setFormData((prev) => ({ ...prev, [id]: val })); diff --git a/web/pgadmin/static/js/Dialogs/NamedRestoreContent.jsx b/web/pgadmin/static/js/Dialogs/NamedRestoreContent.jsx index 57c6b60db30..8606ca83a0a 100644 --- a/web/pgadmin/static/js/Dialogs/NamedRestoreContent.jsx +++ b/web/pgadmin/static/js/Dialogs/NamedRestoreContent.jsx @@ -29,7 +29,7 @@ export default function NamedRestoreContent({closeModal, onOK, setHeight}) { const onTextChange = (e, id) => { let val = e; - if(e && e.target) { + if(e?.target) { val = e.target.value; } setFormData((prev)=>({...prev, [id]: val})); diff --git a/web/pgadmin/static/js/Dialogs/RenameTabContent.jsx b/web/pgadmin/static/js/Dialogs/RenameTabContent.jsx index 5c311f970e4..50710512787 100644 --- a/web/pgadmin/static/js/Dialogs/RenameTabContent.jsx +++ b/web/pgadmin/static/js/Dialogs/RenameTabContent.jsx @@ -33,7 +33,7 @@ export default function RenameTabContent({ panelId, panelDocker, closeModal}) { const onTextChange = (e, id) => { let val = e; - if (e && e.target) { + if (e?.target) { val = e.target.value; } setFormData((prev) => ({ ...prev, [id]: val })); diff --git a/web/pgadmin/static/js/SchemaView/MappedControl.jsx b/web/pgadmin/static/js/SchemaView/MappedControl.jsx index 17e4ea387c8..03b8bbe0519 100644 --- a/web/pgadmin/static/js/SchemaView/MappedControl.jsx +++ b/web/pgadmin/static/js/SchemaView/MappedControl.jsx @@ -25,7 +25,7 @@ function MappedFormControlBase({ type, value, id, onChange, className, visible, const name = id; const onTextChange = useCallback((e) => { let val = e; - if(e && e.target) { + if(e?.target) { val = e.target.value; } onChange && onChange(val); @@ -124,7 +124,7 @@ function MappedCellControlBase({ cell, value, id, optionsLoaded, onCellChange, v const name = id; const onTextChange = useCallback((e) => { let val = e; - if (e && e.target) { + if (e?.target) { val = e.target.value; } @@ -133,7 +133,7 @@ function MappedCellControlBase({ cell, value, id, optionsLoaded, onCellChange, v const onRadioChange = useCallback((e) => { let val =e; - if(e && e.target) { + if(e?.target) { val = e.target.checked; } onCellChange && onCellChange(val); diff --git a/web/pgadmin/static/js/Theme/index.jsx b/web/pgadmin/static/js/Theme/index.jsx index 8eeef438e3a..6b543097a20 100644 --- a/web/pgadmin/static/js/Theme/index.jsx +++ b/web/pgadmin/static/js/Theme/index.jsx @@ -320,6 +320,10 @@ function getFinalTheme(baseTheme) { textarea: { fontFamily: 'inherit', }, + iframe: { + margin: 0, + padding: 0, + }, ...pickrOverride(baseTheme), ...uplotOverride(baseTheme), ...rcdockOverride(baseTheme), diff --git a/web/pgadmin/static/js/UtilityView.jsx b/web/pgadmin/static/js/UtilityView.jsx index ed1268ea910..6ea221ffcbc 100644 --- a/web/pgadmin/static/js/UtilityView.jsx +++ b/web/pgadmin/static/js/UtilityView.jsx @@ -195,7 +195,7 @@ function UtilityViewContent({panelId, schema, treeNodeInfo, actionType, formType onHelp={onHelp} onDataChange={()=>{/*This is intentional (SonarQube)*/}} confirmOnCloseReset={confirmOnReset} - hasSQL={nodeObj?nodeObj.hasSQL:false && (actionType === 'create' || actionType === 'edit')} + hasSQL={nodeObj?.hasSQL && (actionType === 'create' || actionType === 'edit')} getSQLValue={getSQLValue} isTabView={isTabView} disableSqlHelp={sqlHelpUrl == undefined || sqlHelpUrl == ''} diff --git a/web/pgadmin/static/js/components/ContextMenu.jsx b/web/pgadmin/static/js/components/ContextMenu.jsx index 2b64dd97855..09258c29ce7 100644 --- a/web/pgadmin/static/js/components/ContextMenu.jsx +++ b/web/pgadmin/static/js/components/ContextMenu.jsx @@ -34,7 +34,7 @@ export default function ContextMenu({menuItems, position, onClose, label='contex {menuItems.length !=0 && menuItems.map((menuItem, i)=>{ const submenus = menuItem.getMenuItems?.(); if(submenus) { - return + return {submenus.map((submenuItem, si)=>{ return getPgMenuItem(submenuItem, i+'-'+si); })} diff --git a/web/pgadmin/static/js/components/ObjectBreadcrumbs.jsx b/web/pgadmin/static/js/components/ObjectBreadcrumbs.jsx index 3a99f2382fb..5da83dab12f 100644 --- a/web/pgadmin/static/js/components/ObjectBreadcrumbs.jsx +++ b/web/pgadmin/static/js/components/ObjectBreadcrumbs.jsx @@ -13,7 +13,7 @@ const useStyles = makeStyles((theme)=>({ bottom: 0, width: 'auto', maxWidth: '99%', - zIndex: 9999, + zIndex: 1004, padding: '0.25rem 0.5rem', fontSize: '0.95em', color: theme.palette.background.default, diff --git a/web/pgadmin/static/js/helpers/Layout/LayoutIframeTab.jsx b/web/pgadmin/static/js/helpers/Layout/LayoutIframeTab.jsx index da5fcbc32c6..b097cabf86c 100644 --- a/web/pgadmin/static/js/helpers/Layout/LayoutIframeTab.jsx +++ b/web/pgadmin/static/js/helpers/Layout/LayoutIframeTab.jsx @@ -16,6 +16,7 @@ export default function LayoutIframeTab({target, src, children}) { const updatePositionAndSize = () => { if (!selfRef.current) return; const rect = selfRef.current.getBoundingClientRect(); + rect.visibility = selfRef.current.closest('#'+target).style.visibility; // Only update the iframe's position if the position has actually changed if ( @@ -23,13 +24,15 @@ export default function LayoutIframeTab({target, src, children}) { rect.top !== lastKnownPosition.top || rect.left !== lastKnownPosition.left || rect.width !== lastKnownPosition.width || - rect.height !== lastKnownPosition.height + rect.height !== lastKnownPosition.height || + rect.visibility !== lastKnownPosition.visibility ) { iframeTarget.style.position = 'fixed'; // You can adjust this if needed iframeTarget.style.top = `${rect.top}px`; iframeTarget.style.left = `${rect.left}px`; iframeTarget.style.width = `${rect.width}px`; iframeTarget.style.height = `${rect.height}px`; + iframeTarget.style.display = rect.visibility == 'hidden' ? 'none' : ''; lastKnownPosition = rect; } @@ -45,17 +48,18 @@ export default function LayoutIframeTab({target, src, children}) { }, [iframeTarget]); return <> -
- { - if(r) setIframeTarget(r.querySelector('#'+target)); - }} container={document.querySelector('#layout-portal')}> - {src ? -