import React from 'react'; import PropTypes from 'prop-types'; import json5 from 'json5'; import {uuid} from 'core/helpers/uuid'; import {extend} from 'lodash'; import {appConfig} from 'appConfig'; // String identifying embed codes that are Qumu widgets. const QumuString = 'KV.widget'; function getQumuData(html) { const configString = getQumuConfigString(html); return extend( json5.parse(configString), { selector: `#qumu-${uuid()}`, }, ); } export const isQumuWidget = (html) => { return appConfig.features != null && appConfig.features.qumu && html.includes(QumuString); }; const getQumuConfigString = (html) => html.slice(html.indexOf('{'), html.lastIndexOf('}') + 1); export function postProccessQumuEmbed(html) { const data = getQumuData(html); const configString = getQumuConfigString(html); const htmlWithDataReplaced = html.replace(configString, JSON.stringify(data)); return htmlWithDataReplaced + `
`; } export class QumuWidget extends React.Component