* feat: Support importing .docx or .html files as new documents (#1551) * Support importing .docx as new documents * Add html file support, build types and interface for easily adding file types to importer * fix: Upload embedded images in docx to storage * refactor: Bulk of logic to command * refactor: Do all importing on server, so we're not splitting logic for import into two places * test: Add documentImporter tests Co-authored-by: Lance Whatley <whatl3y@gmail.com> * fix: Accessibility audit * fix: Quick fix, non editable title closes #1560 * fix: Embed selection Co-authored-by: Lance Whatley <whatl3y@gmail.com>
31 lines
602 B
JavaScript
31 lines
602 B
JavaScript
// @flow
|
|
import * as React from "react";
|
|
import Frame from "./components/Frame";
|
|
|
|
const URL_REGEX = new RegExp("https://airtable.com/(?:embed/)?(shr.*)$");
|
|
|
|
type Props = {|
|
|
attrs: {|
|
|
href: string,
|
|
matches: string[],
|
|
|},
|
|
|};
|
|
|
|
export default class Airtable extends React.Component<Props> {
|
|
static ENABLED = [URL_REGEX];
|
|
|
|
render() {
|
|
const { matches } = this.props.attrs;
|
|
const shareId = matches[1];
|
|
|
|
return (
|
|
<Frame
|
|
{...this.props}
|
|
src={`https://airtable.com/embed/${shareId}`}
|
|
title={`Airtable (${shareId})`}
|
|
border
|
|
/>
|
|
);
|
|
}
|
|
}
|