* WIP * document migration * fix: Handle clashing keyboard events * fix: convert getSummary * fix: parseDocumentIds * lint * fix: Remove unused plugin * Move editor version to header Add editor version check for API endpoints * fix: Editor update auto-reload Bump RME * test * bump rme * Remove slate flow types, improve themeing, bump rme * bump rme * fix: parseDocumentIds returning duplicate ID's, improved regression tests * test * fix: Missing code styles * lint * chore: Upgrade v2 migration to use AST * Bump RME * Update welcome doc * add highlight to keyboard shortcuts ref * theming improvements * fix: Code comments show as headings, closes #1255 * loop * fix: TOC highlighting * lint * add: Automated backup of docs before migration * Update embeds to new format * fix: React warning * bump to final editor version 10.0.0 * test
74 lines
1.6 KiB
JavaScript
74 lines
1.6 KiB
JavaScript
// @flow
|
|
import * as React from 'react';
|
|
|
|
const URL_REGEX = new RegExp(
|
|
'^https://gist.github.com/([a-zd](?:[a-zd]|-(?=[a-zd])){0,38})/(.*)$'
|
|
);
|
|
|
|
type Props = {|
|
|
attrs: {|
|
|
href: string,
|
|
matches: string[],
|
|
|},
|
|
|};
|
|
|
|
class Gist extends React.Component<Props> {
|
|
iframeNode: ?HTMLIFrameElement;
|
|
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
componentDidMount() {
|
|
this.updateIframeContent();
|
|
}
|
|
|
|
get id() {
|
|
const gistUrl = new URL(this.props.attrs.href);
|
|
return gistUrl.pathname.split('/')[2];
|
|
}
|
|
|
|
updateIframeContent() {
|
|
const id = this.id;
|
|
const iframe = this.iframeNode;
|
|
if (!iframe) return;
|
|
|
|
// $FlowFixMe
|
|
let doc = iframe.document;
|
|
if (iframe.contentDocument) doc = iframe.contentDocument;
|
|
else if (iframe.contentWindow) doc = iframe.contentWindow.document;
|
|
|
|
const gistLink = `https://gist.github.com/${id}.js`;
|
|
const gistScript = `<script type="text/javascript" src="${
|
|
gistLink
|
|
}"></script>`;
|
|
const styles =
|
|
'<style>*{ font-size:12px; } body { margin: 0; } .gist .blob-wrapper.data { max-height:150px; overflow:auto; }</style>';
|
|
const iframeHtml = `<html><head><base target="_parent">${
|
|
styles
|
|
}</head><body>${gistScript}</body></html>`;
|
|
|
|
doc.open();
|
|
doc.writeln(iframeHtml);
|
|
doc.close();
|
|
}
|
|
|
|
render() {
|
|
const id = this.id;
|
|
|
|
return (
|
|
<iframe
|
|
ref={ref => {
|
|
this.iframeNode = ref;
|
|
}}
|
|
type="text/html"
|
|
frameBorder="0"
|
|
width="100%"
|
|
height="200px"
|
|
id={`gist-${id}`}
|
|
title={`Github Gist (${id})`}
|
|
/>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default Gist;
|