UNPKG

@instructure/canvas-rce

Version:

A component wrapping Canvas's usage of Tinymce

44 lines (43 loc) 1.52 kB
/* * Copyright (C) 2020 - present Instructure, Inc. * * This file is part of Canvas. * * Canvas is free software: you can redistribute it and/or modify it under * the terms of the GNU Affero General Public License as published by the Free * Software Foundation, version 3 of the License. * * Canvas is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR * A PARTICULAR PURPOSE. See the GNU Affero General Public License for more * details. * * You should have received a copy of the GNU Affero General Public License along * with this program. If not, see <http://www.gnu.org/licenses/>. */ import React from 'react'; import ReactDOM from 'react-dom'; import Bridge from '../../../bridge'; export default function (ed, document) { return import('./components/Embed').then(({ Embed }) => { let container = document.querySelector('.canvas-rce-embed-container'); if (!container) { container = document.createElement('div'); container.className = 'canvas-rce-embed-container'; document.body.appendChild(container); } const handleDismiss = () => { ReactDOM.unmountComponentAtNode(container); ed.focus(false); }; const handleEmbedCode = embedCode => { Bridge.insertEmbedCode(embedCode); }; ReactDOM.render(/*#__PURE__*/React.createElement(Embed, { onSubmit: handleEmbedCode, onDismiss: handleDismiss }), container); }); }