2018-12-15 04:16:15 +08:00
|
|
|
import React from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import { defineMessages, injectIntl, intlShape } from 'react-intl';
|
|
|
|
import Button from '/imports/ui/components/button/component';
|
2019-02-01 23:32:43 +08:00
|
|
|
import MediaService from '/imports/ui/components/media/service';
|
2018-12-15 04:16:15 +08:00
|
|
|
|
|
|
|
const propTypes = {
|
|
|
|
intl: intlShape.isRequired,
|
|
|
|
toggleSwapLayout: PropTypes.func.isRequired,
|
|
|
|
};
|
|
|
|
|
|
|
|
const intlMessages = defineMessages({
|
|
|
|
restorePresentationLabel: {
|
|
|
|
id: 'app.actionsBar.actionsDropdown.restorePresentationLabel',
|
|
|
|
description: 'Restore Presentation option label',
|
|
|
|
},
|
|
|
|
restorePresentationDesc: {
|
|
|
|
id: 'app.actionsBar.actionsDropdown.restorePresentationDesc',
|
|
|
|
description: 'button to restore presentation after it has been closed',
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2019-08-19 21:44:36 +08:00
|
|
|
const shouldUnswapLayout = () => MediaService.shouldShowScreenshare() || MediaService.shouldShowExternalVideo();
|
2019-02-01 23:32:43 +08:00
|
|
|
|
2019-07-08 22:33:32 +08:00
|
|
|
const PresentationOptionsContainer = ({ intl, toggleSwapLayout, isThereCurrentPresentation }) => {
|
2019-02-01 23:32:43 +08:00
|
|
|
if (shouldUnswapLayout()) toggleSwapLayout();
|
|
|
|
return (
|
|
|
|
<Button
|
|
|
|
icon="presentation"
|
|
|
|
label={intl.formatMessage(intlMessages.restorePresentationLabel)}
|
|
|
|
description={intl.formatMessage(intlMessages.restorePresentationDesc)}
|
|
|
|
color="primary"
|
|
|
|
hideLabel
|
|
|
|
circle
|
|
|
|
size="lg"
|
|
|
|
onClick={toggleSwapLayout}
|
|
|
|
id="restore-presentation"
|
2019-07-08 22:33:32 +08:00
|
|
|
disabled={!isThereCurrentPresentation}
|
2019-02-01 23:32:43 +08:00
|
|
|
/>
|
|
|
|
);
|
2019-08-19 21:44:36 +08:00
|
|
|
};
|
2018-12-15 04:16:15 +08:00
|
|
|
|
|
|
|
PresentationOptionsContainer.propTypes = propTypes;
|
|
|
|
export default injectIntl(PresentationOptionsContainer);
|