mirror of
https://github.com/getredash/redash.git
synced 2025-12-19 17:37:19 -05:00
95 lines
3.3 KiB
JavaScript
95 lines
3.3 KiB
JavaScript
import React from "react";
|
|
import PropTypes from "prop-types";
|
|
import Dropdown from "antd/lib/dropdown";
|
|
import Menu from "antd/lib/menu";
|
|
import Button from "antd/lib/button";
|
|
import { clientConfig } from "@/services/auth";
|
|
|
|
import PlusCircleFilledIcon from "@ant-design/icons/PlusCircleFilled";
|
|
import ShareAltOutlinedIcon from "@ant-design/icons/ShareAltOutlined";
|
|
import FileOutlinedIcon from "@ant-design/icons/FileOutlined";
|
|
import FileExcelOutlinedIcon from "@ant-design/icons/FileExcelOutlined";
|
|
import EllipsisOutlinedIcon from "@ant-design/icons/EllipsisOutlined";
|
|
|
|
import QueryResultsLink from "./QueryResultsLink";
|
|
|
|
export default function QueryControlDropdown(props) {
|
|
const menu = (
|
|
<Menu>
|
|
{!props.query.isNew() && (!props.query.is_draft || !props.query.is_archived) && (
|
|
<Menu.Item>
|
|
<a target="_self" onClick={() => props.openAddToDashboardForm(props.selectedTab)}>
|
|
<PlusCircleFilledIcon /> Add to Dashboard
|
|
</a>
|
|
</Menu.Item>
|
|
)}
|
|
{!clientConfig.disablePublicUrls && !props.query.isNew() && (
|
|
<Menu.Item>
|
|
<a onClick={() => props.showEmbedDialog(props.query, props.selectedTab)} data-test="ShowEmbedDialogButton">
|
|
<ShareAltOutlinedIcon /> Embed Elsewhere
|
|
</a>
|
|
</Menu.Item>
|
|
)}
|
|
<Menu.Item>
|
|
<QueryResultsLink
|
|
fileType="csv"
|
|
disabled={props.queryExecuting || !props.queryResult.getData || !props.queryResult.getData()}
|
|
query={props.query}
|
|
queryResult={props.queryResult}
|
|
embed={props.embed}
|
|
apiKey={props.apiKey}>
|
|
<FileOutlinedIcon /> Download as CSV File
|
|
</QueryResultsLink>
|
|
</Menu.Item>
|
|
<Menu.Item>
|
|
<QueryResultsLink
|
|
fileType="tsv"
|
|
disabled={props.queryExecuting || !props.queryResult.getData || !props.queryResult.getData()}
|
|
query={props.query}
|
|
queryResult={props.queryResult}
|
|
embed={props.embed}
|
|
apiKey={props.apiKey}>
|
|
<FileOutlinedIcon /> Download as TSV File
|
|
</QueryResultsLink>
|
|
</Menu.Item>
|
|
<Menu.Item>
|
|
<QueryResultsLink
|
|
fileType="xlsx"
|
|
disabled={props.queryExecuting || !props.queryResult.getData || !props.queryResult.getData()}
|
|
query={props.query}
|
|
queryResult={props.queryResult}
|
|
embed={props.embed}
|
|
apiKey={props.apiKey}>
|
|
<FileExcelOutlinedIcon /> Download as Excel File
|
|
</QueryResultsLink>
|
|
</Menu.Item>
|
|
</Menu>
|
|
);
|
|
|
|
return (
|
|
<Dropdown trigger={["click"]} overlay={menu} overlayClassName="query-control-dropdown-overlay">
|
|
<Button data-test="QueryControlDropdownButton">
|
|
<EllipsisOutlinedIcon rotate={90} />
|
|
</Button>
|
|
</Dropdown>
|
|
);
|
|
}
|
|
|
|
QueryControlDropdown.propTypes = {
|
|
query: PropTypes.object.isRequired, // eslint-disable-line react/forbid-prop-types
|
|
queryResult: PropTypes.object, // eslint-disable-line react/forbid-prop-types
|
|
queryExecuting: PropTypes.bool.isRequired,
|
|
showEmbedDialog: PropTypes.func.isRequired,
|
|
embed: PropTypes.bool,
|
|
apiKey: PropTypes.string,
|
|
selectedTab: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
|
|
openAddToDashboardForm: PropTypes.func.isRequired,
|
|
};
|
|
|
|
QueryControlDropdown.defaultProps = {
|
|
queryResult: {},
|
|
embed: false,
|
|
apiKey: "",
|
|
selectedTab: "",
|
|
};
|