bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/pads/component.jsx
Pedro Beschorner Marin 810deb907b refactor(etherpad): access control et al.
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
2022-01-21 16:56:01 -03:00

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);