/* eslint jsx-a11y/no-noninteractive-element-interactions: 0 */ import React from 'react'; import ReactDOM from 'react-dom'; import PropTypes from 'prop-types'; import { FormattedMessage } from 'react-intl'; import CopyToClipboard from 'react-copy-to-clipboard'; import classNames from 'classnames'; import LZString from 'lz-string'; import { Icon, Tooltip } from 'antd'; import CodePreview from './CodePreview'; import EditButton from '../EditButton'; import ErrorBoundary from '../ErrorBoundary'; import BrowserFrame from '../../BrowserFrame'; function compress(string) { return LZString.compressToBase64(string) .replace(/\+/g, '-') // Convert '+' to '-' .replace(/\//g, '_') // Convert '/' to '_' .replace(/=+$/, ''); // Remove ending '=' } export default class Demo extends React.Component { static contextTypes = { intl: PropTypes.object, }; state = { codeExpand: false, copied: false, copyTooltipVisible: false, }; componentDidMount() { const { meta, location } = this.props; if (meta.id === location.hash.slice(1)) { this.anchor.click(); } } shouldComponentUpdate(nextProps, nextState) { const { codeExpand, copied, copyTooltipVisible } = this.state; const { expand } = this.props; return ( (codeExpand || expand) !== (nextState.codeExpand || nextProps.expand) || copied !== nextState.copied || copyTooltipVisible !== nextState.copyTooltipVisible ); } getSourceCode() { const { highlightedCode } = this.props; if (typeof document !== 'undefined') { const div = document.createElement('div'); div.innerHTML = highlightedCode[1].highlighted; return div.textContent; } return ''; } handleCodeExpand = demo => { const { codeExpand } = this.state; this.setState({ codeExpand: !codeExpand }); this.track({ type: 'expand', demo, }); }; saveAnchor = anchor => { this.anchor = anchor; }; handleCodeCopied = demo => { this.setState({ copied: true }); this.track({ type: 'copy', demo, }); }; onCopyTooltipVisibleChange = visible => { if (visible) { this.setState({ copyTooltipVisible: visible, copied: false, }); return; } this.setState({ copyTooltipVisible: visible, }); }; // eslint-disable-next-line track({ type, demo }) { if (!window.gtag) { return; } window.gtag('event', 'demo', { event_category: type, event_label: demo, }); } render() { const { state } = this; const { props } = this; const { meta, src, content, preview, highlightedCodes, style, highlightedStyle, expand, } = props; const { copied } = state; if (!this.liveDemo) { this.liveDemo = meta.iframe ? (