mirror of
https://github.com/apache/superset.git
synced 2026-04-26 19:44:58 +00:00
refactor: Share sql lab query (#13630)
This commit is contained in:
@@ -17,7 +17,6 @@
|
||||
* under the License.
|
||||
*/
|
||||
import React from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
import { Tooltip } from 'src/common/components/Tooltip';
|
||||
import { t, styled, supersetTheme } from '@superset-ui/core';
|
||||
import cx from 'classnames';
|
||||
@@ -30,17 +29,17 @@ import { storeQuery } from 'src/utils/common';
|
||||
import { getClientErrorObject } from 'src/utils/getClientErrorObject';
|
||||
import { FeatureFlag, isFeatureEnabled } from '../../featureFlags';
|
||||
|
||||
const propTypes = {
|
||||
queryEditor: PropTypes.shape({
|
||||
dbId: PropTypes.number,
|
||||
title: PropTypes.string,
|
||||
schema: PropTypes.string,
|
||||
autorun: PropTypes.bool,
|
||||
sql: PropTypes.string,
|
||||
remoteId: PropTypes.number,
|
||||
}).isRequired,
|
||||
addDangerToast: PropTypes.func.isRequired,
|
||||
};
|
||||
interface ShareSqlLabQueryPropTypes {
|
||||
queryEditor: {
|
||||
dbId: number;
|
||||
title: string;
|
||||
schema: string;
|
||||
autorun: boolean;
|
||||
sql: string;
|
||||
remoteId: number | null;
|
||||
};
|
||||
addDangerToast: (msg: string) => void;
|
||||
}
|
||||
|
||||
const Styles = styled.div`
|
||||
.btn-disabled {
|
||||
@@ -56,16 +55,12 @@ const Styles = styled.div`
|
||||
}
|
||||
`;
|
||||
|
||||
class ShareSqlLabQuery extends React.Component {
|
||||
getCopyUrl(callback) {
|
||||
if (isFeatureEnabled(FeatureFlag.SHARE_QUERIES_VIA_KV_STORE)) {
|
||||
return this.getCopyUrlForKvStore(callback);
|
||||
}
|
||||
return this.getCopyUrlForSavedQuery(callback);
|
||||
}
|
||||
|
||||
getCopyUrlForKvStore(callback) {
|
||||
const { dbId, title, schema, autorun, sql } = this.props.queryEditor;
|
||||
function ShareSqlLabQuery({
|
||||
queryEditor,
|
||||
addDangerToast,
|
||||
}: ShareSqlLabQueryPropTypes) {
|
||||
const getCopyUrlForKvStore = (callback: Function) => {
|
||||
const { dbId, title, schema, autorun, sql } = queryEditor;
|
||||
const sharedQuery = { dbId, title, schema, autorun, sql };
|
||||
|
||||
return storeQuery(sharedQuery)
|
||||
@@ -74,28 +69,34 @@ class ShareSqlLabQuery extends React.Component {
|
||||
})
|
||||
.catch(response => {
|
||||
getClientErrorObject(response).then(() => {
|
||||
this.props.addDangerToast(t('There was an error with your request'));
|
||||
addDangerToast(t('There was an error with your request'));
|
||||
});
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
getCopyUrlForSavedQuery(callback) {
|
||||
const getCopyUrlForSavedQuery = (callback: Function) => {
|
||||
let savedQueryToastContent;
|
||||
|
||||
if (this.props.queryEditor.remoteId) {
|
||||
if (queryEditor.remoteId) {
|
||||
savedQueryToastContent = `${
|
||||
window.location.origin + window.location.pathname
|
||||
}?savedQueryId=${this.props.queryEditor.remoteId}`;
|
||||
}?savedQueryId=${queryEditor.remoteId}`;
|
||||
callback(savedQueryToastContent);
|
||||
} else {
|
||||
savedQueryToastContent = t('Please save the query to enable sharing');
|
||||
callback(savedQueryToastContent);
|
||||
}
|
||||
}
|
||||
};
|
||||
const getCopyUrl = (callback: Function) => {
|
||||
if (isFeatureEnabled(FeatureFlag.SHARE_QUERIES_VIA_KV_STORE)) {
|
||||
return getCopyUrlForKvStore(callback);
|
||||
}
|
||||
return getCopyUrlForSavedQuery(callback);
|
||||
};
|
||||
|
||||
buildButton() {
|
||||
const buildButton = () => {
|
||||
const canShare =
|
||||
this.props.queryEditor.remoteId ||
|
||||
queryEditor.remoteId ||
|
||||
isFeatureEnabled(FeatureFlag.SHARE_QUERIES_VIA_KV_STORE);
|
||||
return (
|
||||
<Styles>
|
||||
@@ -114,36 +115,38 @@ class ShareSqlLabQuery extends React.Component {
|
||||
</Button>
|
||||
</Styles>
|
||||
);
|
||||
}
|
||||
};
|
||||
|
||||
render() {
|
||||
const canShare =
|
||||
this.props.queryEditor.remoteId ||
|
||||
isFeatureEnabled(FeatureFlag.SHARE_QUERIES_VIA_KV_STORE);
|
||||
return (
|
||||
<Tooltip
|
||||
id="copy_link"
|
||||
placement="top"
|
||||
title={
|
||||
canShare
|
||||
? t('Copy query link to your clipboard')
|
||||
: t('Save the query to copy the link')
|
||||
}
|
||||
>
|
||||
{canShare ? (
|
||||
<CopyToClipboard
|
||||
getText={callback => this.getCopyUrl(callback)}
|
||||
wrapped={false}
|
||||
copyNode={this.buildButton()}
|
||||
/>
|
||||
) : (
|
||||
this.buildButton()
|
||||
)}
|
||||
</Tooltip>
|
||||
);
|
||||
}
|
||||
const canShare =
|
||||
queryEditor.remoteId ||
|
||||
isFeatureEnabled(FeatureFlag.SHARE_QUERIES_VIA_KV_STORE);
|
||||
|
||||
return (
|
||||
<Tooltip
|
||||
id="copy_link"
|
||||
placement="top"
|
||||
overlayStyle={{
|
||||
fontSize: supersetTheme.typography.sizes.s,
|
||||
lineHeight: '1.6',
|
||||
maxWidth: '125px',
|
||||
}}
|
||||
title={
|
||||
canShare
|
||||
? t('Copy query link to your clipboard')
|
||||
: t('Save the query to enable this feature')
|
||||
}
|
||||
>
|
||||
{canShare ? (
|
||||
<CopyToClipboard
|
||||
getText={getCopyUrl}
|
||||
wrapped={false}
|
||||
copyNode={buildButton()}
|
||||
/>
|
||||
) : (
|
||||
buildButton()
|
||||
)}
|
||||
</Tooltip>
|
||||
);
|
||||
}
|
||||
|
||||
ShareSqlLabQuery.propTypes = propTypes;
|
||||
|
||||
export default withToasts(ShareSqlLabQuery);
|
||||
Reference in New Issue
Block a user