* 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
43 lines
994 B
TypeScript
43 lines
994 B
TypeScript
import * as React from "react";
|
|
import Frame from "../components/Frame";
|
|
|
|
const URL_REGEX = new RegExp("https?://open.spotify.com/(.*)$");
|
|
import { EmbedProps as Props } from ".";
|
|
|
|
export default class Spotify extends React.Component<Props> {
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
get pathname() {
|
|
try {
|
|
const parsed = new URL(this.props.attrs.href);
|
|
return parsed.pathname;
|
|
} catch (err) {
|
|
return "";
|
|
}
|
|
}
|
|
|
|
render() {
|
|
const normalizedPath = this.pathname.replace(/^\/embed/, "/");
|
|
let height;
|
|
|
|
if (normalizedPath.includes("episode") || normalizedPath.includes("show")) {
|
|
height = 232;
|
|
} else if (normalizedPath.includes("track")) {
|
|
height = 80;
|
|
} else {
|
|
height = 380;
|
|
}
|
|
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
width="100%"
|
|
height={`${height}px`}
|
|
src={`https://open.spotify.com/embed${normalizedPath}`}
|
|
title="Spotify Embed"
|
|
allow="encrypted-media"
|
|
/>
|
|
);
|
|
}
|
|
}
|