33 lines
994 B
TypeScript
33 lines
994 B
TypeScript
import * as React from "react";
|
|
import styled from "styled-components";
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
const Iframe = styled.iframe`
|
|
margin-top: 8px;
|
|
`;
|
|
|
|
function Gist(props: Props) {
|
|
const gistUrl = new URL(props.attrs.href);
|
|
const id = gistUrl.pathname.split("/")[2];
|
|
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>`;
|
|
|
|
return (
|
|
<Iframe
|
|
src={`data:text/html;base64,${btoa(iframeHtml)}`}
|
|
className={props.isSelected ? "ProseMirror-selectednode" : ""}
|
|
frameBorder="0"
|
|
width="100%"
|
|
height="200px"
|
|
scrolling="no"
|
|
id={`gist-${id}`}
|
|
title="GitHub Gist"
|
|
/>
|
|
);
|
|
}
|
|
|
|
export default Gist;
|