* stash * refactor, working in non-collab + collab editor * attachment styling * Avoid crypto require in browser * AttachmentIcon, handling unknown types * Do not allow attachment creation for file sizes over limit * Allow image as file attachment * Upload placeholder styling * lint * Refactor: Do not use placeholder for file attachmentuploads * Add loading spinner * fix: Extra paragraphs around attachments on insert * Bump editor * fix build error * Remove attachment placeholder when upload fails * Remove unused styles * fix: Attachments on shared pages * Merge fixes
29 lines
765 B
TypeScript
29 lines
765 B
TypeScript
import * as React from "react";
|
|
import Frame from "../components/Frame";
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
const URL_REGEX = /(http|https)?:\/\/(www\.)?vimeo.com\/(?:channels\/(?:\w+\/)?|groups\/([^/]*)\/videos\/|)(\d+)(?:\/|\?)?([\d\w]+)?/;
|
|
|
|
export default class Vimeo extends React.Component<Props> {
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
render() {
|
|
const { matches } = this.props.attrs;
|
|
const videoId = matches[4];
|
|
const hId = matches[5];
|
|
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
src={`https://player.vimeo.com/video/${videoId}?byline=0${
|
|
hId ? `&h=${hId}` : ""
|
|
}`}
|
|
title={`Vimeo Embed (${videoId})`}
|
|
height="412px"
|
|
border={false}
|
|
referrerPolicy="origin"
|
|
/>
|
|
);
|
|
}
|
|
}
|