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 ( <> ); } function renderCurrentUser() { return ( <> ); } function renderGuestUser() { return ( <> {t('Not available for guest')} ); } return ( <> {currentUser == null ? renderGuestUser() : renderCurrentUser()}
{renderModals()} ); }; /** * Wrapper component for using unstated */ const PageShareManagementWrapper = withUnstatedContainers(PageShareManagement, [AppContainer, PageContainer]); PageShareManagement.propTypes = { t: PropTypes.func.isRequired, // i18next appContainer: PropTypes.instanceOf(AppContainer).isRequired, pageContainer: PropTypes.instanceOf(PageContainer).isRequired, }; export default withTranslation()(PageShareManagementWrapper);