* 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
46 lines
954 B
TypeScript
46 lines
954 B
TypeScript
import * as React from "react";
|
|
import Frame from "../components/Frame";
|
|
import Image from "../components/Image";
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
const URL_REGEX = /^https:\/\/viewer\.diagrams\.net\/.*(title=\\w+)?/;
|
|
|
|
export default class Diagrams extends React.Component<Props> {
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
get embedUrl() {
|
|
return this.props.attrs.matches[0];
|
|
}
|
|
|
|
get title() {
|
|
let title = "Diagrams.net";
|
|
const url = new URL(this.embedUrl);
|
|
const documentTitle = url.searchParams.get("title");
|
|
|
|
if (documentTitle) {
|
|
title += ` (${documentTitle})`;
|
|
}
|
|
|
|
return title;
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
src={this.embedUrl}
|
|
title={this.title}
|
|
border
|
|
icon={
|
|
<Image
|
|
src="/images/diagrams.png"
|
|
alt="Diagrams.net"
|
|
width={16}
|
|
height={16}
|
|
/>
|
|
}
|
|
/>
|
|
);
|
|
}
|
|
}
|