25 lines
665 B
TypeScript
25 lines
665 B
TypeScript
import * as React from "react";
|
|
import Frame from "../components/Frame";
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
const URL_REGEX = /^https:\/\/(realtimeboard|miro)\.com\/app\/board\/(.*)$/;
|
|
|
|
export default class RealtimeBoard extends React.Component<Props> {
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
render() {
|
|
const { matches } = this.props.attrs;
|
|
const domain = matches[1];
|
|
const boardId = matches[2];
|
|
const titleName = domain === "realtimeboard" ? "RealtimeBoard" : "Miro";
|
|
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
src={`https://${domain}.com/app/embed/${boardId}`}
|
|
title={`${titleName} (${boardId})`}
|
|
/>
|
|
);
|
|
}
|
|
}
|