diff --git a/superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.js b/superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.test.js
similarity index 96%
rename from superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.js
rename to superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.test.js
index 011930f3ad348..ac0f5da5cd683 100644
--- a/superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.js
+++ b/superset-frontend/cypress-base/cypress/integration/sqllab/sourcePanel.index.test.js
@@ -34,9 +34,7 @@ describe('SqlLab datasource panel', () => {
cy.get('.sql-toolbar .Select').should('have.length', 3);
cy.get('.sql-toolbar .table-schema').should('not.exist');
- cy.get('.SouthPane .tab-content .filterable-table-container').should(
- 'not.exist',
- );
+ cy.get('[data-test="filterable-table-container"]').should('not.exist');
cy.get('.sql-toolbar .Select')
.eq(0) // database select
diff --git a/superset-frontend/src/SqlLab/components/SouthPane.jsx b/superset-frontend/src/SqlLab/components/SouthPane.jsx
index ec79973351c71..2d1db63bd0e4a 100644
--- a/superset-frontend/src/SqlLab/components/SouthPane.jsx
+++ b/superset-frontend/src/SqlLab/components/SouthPane.jsx
@@ -23,7 +23,8 @@ import { Alert } from 'react-bootstrap';
import Tabs from 'src/common/components/Tabs';
import { connect } from 'react-redux';
import { bindActionCreators } from 'redux';
-import { t } from '@superset-ui/core';
+import { t, styled } from '@superset-ui/core';
+
import { isFeatureEnabled, FeatureFlag } from 'src/featureFlags';
import Label from 'src/components/Label';
@@ -36,7 +37,7 @@ import {
LOCALSTORAGE_MAX_QUERY_AGE_MS,
} from '../constants';
-const TAB_HEIGHT = 44;
+const TAB_HEIGHT = 64;
/*
editorQueries are queries executed by users passed from SqlEditor component
@@ -59,6 +60,29 @@ const defaultProps = {
offline: false,
};
+const StyledPane = styled.div`
+ width: 100%;
+
+ .ant-tabs .ant-tabs-content-holder {
+ overflow: visible;
+ }
+
+ .SouthPaneTabs {
+ height: 100%;
+ display: flex;
+ flex-direction: column;
+ }
+ .tab-content {
+ .alert {
+ margin-top: ${({ theme }) => theme.gridUnit * 2}px;
+ }
+
+ button.fetch {
+ margin-top: ${({ theme }) => theme.gridUnit * 2}px;
+ }
+ }
+`;
+
export class SouthPane extends React.PureComponent {
constructor(props) {
super(props);
@@ -158,7 +182,7 @@ export class SouthPane extends React.PureComponent {
));
return (
-
+
{dataPreviewTabs}
-
+
);
}
}
diff --git a/superset-frontend/src/SqlLab/main.less b/superset-frontend/src/SqlLab/main.less
index 7123ed033f9fd..dffc599308f64 100644
--- a/superset-frontend/src/SqlLab/main.less
+++ b/superset-frontend/src/SqlLab/main.less
@@ -235,10 +235,6 @@ div.Workspace {
.ace_content {
height: 100%;
}
-
- .SouthPane {
- height: 100%;
- }
}
.SqlEditorTabs li {
@@ -318,7 +314,7 @@ div.Workspace {
.queryPane {
flex: 1 1 auto;
padding-left: 10px;
- overflow: auto;
+ overflow: visible;
}
.schemaPane-enter-done,
@@ -405,10 +401,6 @@ div.tablePopover {
padding-top: 16px;
}
-.filterable-table-container {
- margin-top: 48px;
-}
-
.ace_editor.ace_editor {
//double class is better than !important
border: 1px solid @gray-light;
@@ -493,20 +485,6 @@ a.Link {
margin: 3px 5px;
}
-.SouthPane {
- width: 100%;
-
- .SouthPaneTabs {
- height: 100%;
- display: flex;
- flex-direction: column;
- }
-
- .ant-tabs-tabpane {
- overflow-y: auto; // scroll the query history pane
- }
-}
-
.nav-tabs .ddbtn-tab {
padding: 0;
border: none;
@@ -537,14 +515,6 @@ a.Link {
}
}
-.SouthPane .tab-content .alert {
- margin-top: 10px;
-}
-
-.SouthPane .tab-content button.fetch {
- margin-top: 10px;
-}
-
.cost-estimate {
font-size: @font-size-s;
}
diff --git a/superset-frontend/src/components/FilterableTable/FilterableTable.tsx b/superset-frontend/src/components/FilterableTable/FilterableTable.tsx
index 77b27108e5106..5b51f9915b016 100644
--- a/superset-frontend/src/components/FilterableTable/FilterableTable.tsx
+++ b/superset-frontend/src/components/FilterableTable/FilterableTable.tsx
@@ -29,7 +29,7 @@ import {
SortIndicator,
Table,
} from 'react-virtualized';
-import { getMultipleTextDimensions, t } from '@superset-ui/core';
+import { getMultipleTextDimensions, t, styled } from '@superset-ui/core';
import Button from '../Button';
import CopyToClipboard from '../CopyToClipboard';
@@ -83,6 +83,11 @@ const JSON_TREE_THEME = {
base0F: '#cc6633',
};
+const StyledFilterableTable = styled.div`
+ overflow-x: auto;
+ margin-top: ${({ theme }) => theme.gridUnit * 12}px;
+`;
+
// when more than MAX_COLUMNS_FOR_TABLE are returned, switch from table to grid view
export const MAX_COLUMNS_FOR_TABLE = 50;
@@ -463,6 +468,7 @@ export default class FilterableTable extends PureComponent<
@@ -551,7 +557,7 @@ export default class FilterableTable extends PureComponent<
const rowGetter = ({ index }: { index: number }) =>
this.getDatum(sortedAndFilteredList, index);
return (
-
)}
-
+
);
}