import React, { useState } from 'react';
import PropTypes from 'prop-types';
import { UncontrolledTooltip } from 'reactstrap';
import { withTranslation } from 'react-i18next';
import { withUnstatedContainers } 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 exportPageHundler(format) {
const { pageId, revisionId } = pageContainer.state;
try {
const { data } = await appContainer.apiv3Get('/page/export', { format, pageId, revisionId });
const blob = new Blob([data.markdown]);
const link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = `${revisionId}.${format}`;
link.click();
link.remove();
}
catch (err) {
toastError(Error(t('export_bulk.failed_to_export')));
}
}
function renderModals() {
if (currentUser == null) {
return null;
}
return (
<>