import React, { useState } from 'react'; import PropTypes from 'prop-types'; import { UncontrolledTooltip } from 'reactstrap'; import { withTranslation } from 'react-i18next'; import { createSubscribedElement } from '../UnstatedUtils'; import AppContainer from '../../services/AppContainer'; import PageContainer from '../../services/PageContainer'; import OutsideShareLinkModal from '../OutsideShareLinkModal'; import { toastError } from '../../util/apiNotification'; const PageShareManagement = (props) => { const { t, appContainer, pageContainer } = props; const { currentUser } = appContainer; const [isOutsideShareLinkModalShown, setIsOutsideShareLinkModalShown] = useState(false); function openOutsideShareLinkModalHandler() { setIsOutsideShareLinkModalShown(true); } function closeOutsideShareLinkModalHandler() { setIsOutsideShareLinkModalShown(false); } async function getExportPageFile(type) { const pageId = pageContainer.state.pageId; try { const res = await appContainer.apiv3Get('/pages/export', { pageId, type }); return res; } catch (err) { toastError(Error(t('export_bulk.failed_to_export'))); } } function exportPage(exportPageFile) { // TODO implement } function exportPageHundler(type) { const exportPageFile = getExportPageFile(type); exportPage(exportPageFile); } function renderModals() { return ( <> ); } function renderCurrentUser() { return ( <> ); } function renderGuestUser() { return ( <> {t('Not available for guest')} ); } return ( <> {currentUser == null ? renderGuestUser() : renderCurrentUser()}
{renderModals()} ); }; /** * Wrapper component for using unstated */ const PageShareManagementWrapper = (props) => { return createSubscribedElement(PageShareManagement, props, [AppContainer, PageContainer]); }; PageShareManagement.propTypes = { t: PropTypes.func.isRequired, // i18next appContainer: PropTypes.instanceOf(AppContainer).isRequired, pageContainer: PropTypes.instanceOf(PageContainer).isRequired, }; export default withTranslation()(PageShareManagementWrapper);