/** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ import React from 'react'; import PropTypes from 'prop-types'; import { t } from '@superset-ui/core'; import Popover from 'src/common/components/Popover'; import FormLabel from 'src/components/FormLabel'; import CopyToClipboard from 'src/components/CopyToClipboard'; import { getShortUrl } from 'src/utils/common'; import { getExploreLongUrl, getURIDirectory } from '../exploreUtils'; const propTypes = { latestQueryFormData: PropTypes.object.isRequired, }; export default class EmbedCodeButton extends React.Component { constructor(props) { super(props); this.state = { height: '400', width: '600', shortUrlId: 0, }; this.handleInputChange = this.handleInputChange.bind(this); this.getCopyUrl = this.getCopyUrl.bind(this); this.onShortUrlSuccess = this.onShortUrlSuccess.bind(this); } onShortUrlSuccess(shortUrl) { const shortUrlId = shortUrl.substring(shortUrl.indexOf('/r/') + 3); this.setState(() => ({ shortUrlId, })); } getCopyUrl() { return getShortUrl(getExploreLongUrl(this.props.latestQueryFormData)) .then(this.onShortUrlSuccess) .catch(this.props.addDangerToast); } handleInputChange(e) { const { value, name } = e.currentTarget; const data = {}; data[name] = value; this.setState(data); } generateEmbedHTML() { const srcLink = `${window.location.origin + getURIDirectory()}?r=${ this.state.shortUrlId }&standalone=true&height=${this.state.height}`; return ( '' ); } renderPopoverContent() { const html = this.generateEmbedHTML(); return (