* 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
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import * as React from "react";
|
|
import ImageZoom from "react-medium-image-zoom";
|
|
import Frame from "../components/Frame";
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
const IFRAME_REGEX = /^https:\/\/(invis\.io\/.*)|(projects\.invisionapp\.com\/share\/.*)$/;
|
|
const IMAGE_REGEX = /^https:\/\/(opal\.invisionapp\.com\/static-signed\/live-embed\/.*)$/;
|
|
|
|
export default class InVision extends React.Component<Props> {
|
|
static ENABLED = [IFRAME_REGEX, IMAGE_REGEX];
|
|
|
|
render() {
|
|
if (IMAGE_REGEX.test(this.props.attrs.href)) {
|
|
return (
|
|
<ImageZoom
|
|
// @ts-expect-error ts-migrate(2769) FIXME: No overload matches this call.
|
|
className={this.props.isSelected ? "ProseMirror-selectednode" : ""}
|
|
image={{
|
|
src: this.props.attrs.href,
|
|
alt: "InVision Embed",
|
|
style: {
|
|
maxWidth: "100%",
|
|
maxHeight: "75vh",
|
|
},
|
|
}}
|
|
shouldRespectMaxDimension
|
|
/>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
src={this.props.attrs.href}
|
|
title="InVision Embed"
|
|
/>
|
|
);
|
|
}
|
|
}
|