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(type) {
const { pageId, revisionId } = pageContainer.state;
try {
// TODO GW-3062 現状では pdf ファイル形式の場合空のデータがダウンロードされるので要修正
// const responseType = type === 'pdf' ? 'arraybuffer' : 'json';
const axios = require('axios').create({
responseType: 'arraybuffer',
headers: {
'Content-Type': 'application/pdf',
},
});
const data = await axios.get('/_api/v3/page/export', {
// const data = await appContainer.apiv3Get('/page/export',
params:
{
pageId,
revisionId,
type,
},
});
console.log(data.data);
const blobType = type === 'pdf' ? 'application/pdf' : 'application/json';
const blob = new Blob(
[data.data],
{ type: blobType },
);
const link = document.createElement('a');
link.href = window.URL.createObjectURL(blob);
link.download = `${pageId}.${type}`;
link.click();
link.remove();
}
catch (err) {
toastError(Error(t('export_bulk.failed_to_export')));
}
}
function renderModals() {
return (
<>