810deb907b
Move all Etherpad's access control from Meteor to a separated [Node application](https://github.com/bigbluebutton/bbb-pads). This new app uses [Etherpad's API](https://etherpad.org/doc/v1.8.4/#index_overview) to create groups and manage session tokens for users to access them. Each group represents one distinct pad at the html5 client. - Removed locked users' access to pads: replaced readOnly pad's access with a new pad's content sharing routine - Pad's access is now controlled by [Etherpad's API](https://etherpad.org/doc/v1.8.4/#index_overview) - Closed captions edited content now reflects at it's live feedback - Improved closed caption's dictation mode live feedback - Moved all Etherpad's API control from Meteor to a separated [app](https://github.com/bigbluebutton/bbb-pads) - Included access control both in akka-apps and bbb-pads
67 lines
1.5 KiB
JavaScript
67 lines
1.5 KiB
JavaScript
import React, { useEffect, useState } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { defineMessages, injectIntl } from 'react-intl';
|
|
import PadContent from './content/container';
|
|
import Service from './service';
|
|
import Styled from './styles';
|
|
|
|
const intlMessages = defineMessages({
|
|
hint: {
|
|
id: 'app.pads.hint',
|
|
description: 'Label for hint on how to escape iframe',
|
|
},
|
|
});
|
|
|
|
const propTypes = {
|
|
externalId: PropTypes.string.isRequired,
|
|
hasSession: PropTypes.bool.isRequired,
|
|
intl: PropTypes.shape({
|
|
formatMessage: PropTypes.func.isRequired,
|
|
}).isRequired,
|
|
isResizing: PropTypes.bool.isRequired,
|
|
isRTL: PropTypes.bool.isRequired,
|
|
};
|
|
|
|
const Pad = ({
|
|
externalId,
|
|
hasSession,
|
|
intl,
|
|
isResizing,
|
|
isRTL,
|
|
}) => {
|
|
const [padURL, setPadURL] = useState();
|
|
|
|
useEffect(() => {
|
|
Service.getPadId(externalId).then((response) => {
|
|
setPadURL(Service.buildPadURL(response));
|
|
});
|
|
}, [isRTL, hasSession]);
|
|
|
|
if (!hasSession) {
|
|
return <PadContent externalId={externalId} />;
|
|
}
|
|
|
|
return (
|
|
<Styled.Pad>
|
|
<Styled.IFrame
|
|
title="pad"
|
|
src={padURL}
|
|
aria-describedby="padEscapeHint"
|
|
style={{
|
|
pointerEvents: isResizing ? 'none' : 'inherit',
|
|
}}
|
|
/>
|
|
<Styled.Hint
|
|
id="padEscapeHint"
|
|
aria-hidden
|
|
>
|
|
{intl.formatMessage(intlMessages.hint)}
|
|
</Styled.Hint>
|
|
</Styled.Pad>
|
|
);
|
|
};
|
|
|
|
Pad.propTypes = propTypes;
|
|
|
|
export default injectIntl(Pad);
|