mirror of
https://bitbucket.org/wisemapping/wisemapping-frontend.git
synced 2025-04-03 03:33:20 +02:00
238 lines
10 KiB
TypeScript
238 lines
10 KiB
TypeScript
import React, { useEffect } from 'react'
|
|
import { FormattedMessage, useIntl } from 'react-intl'
|
|
import BaseDialog from '../base-dialog'
|
|
import { useStyles } from './style'
|
|
import Alert from '@material-ui/lab/Alert'
|
|
import { fetchMapById } from '../../../../redux/clientSlice'
|
|
import FormControl from '@material-ui/core/FormControl'
|
|
import RadioGroup from '@material-ui/core/RadioGroup'
|
|
import FormControlLabel from '@material-ui/core/FormControlLabel'
|
|
import Radio from '@material-ui/core/Radio'
|
|
import Select from '@material-ui/core/Select'
|
|
import MenuItem from '@material-ui/core/MenuItem'
|
|
|
|
type ExportFormat = 'pdf' | 'svg' | 'jpg' | 'png' | 'txt' | 'mm' | 'wxml' | 'xls' | 'txt'
|
|
type ExportGroup = 'image' | 'document' | 'mindmap-tool'
|
|
|
|
type ExportDialogProps = {
|
|
mapId: number
|
|
enableImgExport: boolean
|
|
svgXml?: string
|
|
onClose: () => void
|
|
}
|
|
|
|
const ExportDialog = ({
|
|
mapId,
|
|
onClose,
|
|
enableImgExport,
|
|
svgXml,
|
|
}: ExportDialogProps): React.ReactElement => {
|
|
const intl = useIntl()
|
|
const [submit, setSubmit] = React.useState<boolean>(false)
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
const [formExportRef, setExportFormRef] = React.useState<any>()
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
const [formTransformtRef, setTransformFormRef] = React.useState<any>()
|
|
const [exportGroup, setExportGroup] = React.useState<ExportGroup>(
|
|
enableImgExport ? 'image' : 'document'
|
|
)
|
|
const [exportFormat, setExportFormat] = React.useState<ExportFormat>(
|
|
enableImgExport ? 'svg' : 'xls'
|
|
)
|
|
const classes = useStyles()
|
|
|
|
const handleOnExportFormatChange = (event) => {
|
|
setExportFormat(event.target.value)
|
|
}
|
|
|
|
const handleOnGroupChange = (event) => {
|
|
const value: ExportGroup = event.target.value
|
|
setExportGroup(value)
|
|
|
|
let defaultFormat: ExportFormat
|
|
switch (value) {
|
|
case 'document':
|
|
defaultFormat = 'pdf'
|
|
break
|
|
case 'image':
|
|
defaultFormat = 'svg'
|
|
break
|
|
case 'mindmap-tool':
|
|
defaultFormat = 'wxml'
|
|
break
|
|
}
|
|
setExportFormat(defaultFormat)
|
|
}
|
|
|
|
const handleOnClose = (): void => {
|
|
onClose()
|
|
}
|
|
|
|
const handleOnSubmit = (): void => {
|
|
setSubmit(true)
|
|
}
|
|
|
|
useEffect(() => {
|
|
if (submit) {
|
|
// Depending on the type of export. It will require differt POST.
|
|
if (
|
|
exportFormat == 'pdf' ||
|
|
exportFormat == 'svg' ||
|
|
exportFormat == 'jpg' ||
|
|
exportFormat == 'png'
|
|
) {
|
|
formTransformtRef?.submit()
|
|
} else {
|
|
formExportRef?.submit()
|
|
}
|
|
onClose()
|
|
}
|
|
}, [submit])
|
|
|
|
const { map } = fetchMapById(mapId)
|
|
return (
|
|
<div>
|
|
<BaseDialog
|
|
onClose={handleOnClose}
|
|
onSubmit={handleOnSubmit}
|
|
title={intl.formatMessage({ id: 'export.title', defaultMessage: 'Export' })}
|
|
description={
|
|
'Export this map in the format that you want and start using it in your presentations or sharing by email'
|
|
}
|
|
submitButton={intl.formatMessage({ id: 'export.title', defaultMessage: 'Export' })}
|
|
>
|
|
<Alert severity="info">
|
|
<FormattedMessage
|
|
id="export.warning"
|
|
defaultMessage="Exporting to Image (SVG,PNG,JPEG,PDF) is only available in the editor toolbar."
|
|
/>
|
|
</Alert>
|
|
|
|
<FormControl component="fieldset">
|
|
<RadioGroup name="export" value={exportGroup} onChange={handleOnGroupChange}>
|
|
<FormControl>
|
|
<FormControlLabel
|
|
className={classes.label}
|
|
value="image"
|
|
disabled={!enableImgExport}
|
|
control={<Radio color="primary" />}
|
|
label={intl.formatMessage({
|
|
id: 'export.image',
|
|
defaultMessage:
|
|
'Image: Get a graphic representation of your map including all colors and shapes.',
|
|
})}
|
|
color="secondary"
|
|
style={{ fontSize: '9px' }}
|
|
/>
|
|
{exportGroup == 'image' && (
|
|
<Select
|
|
onSelect={handleOnExportFormatChange}
|
|
variant="outlined"
|
|
value={exportFormat}
|
|
className={classes.label}
|
|
>
|
|
<MenuItem value="svg" className={classes.menu}>
|
|
Scalable Vector Graphics (SVG)
|
|
</MenuItem>
|
|
<MenuItem value="pdf" className={classes.select}>
|
|
Portable Document Format (PDF)
|
|
</MenuItem>
|
|
<MenuItem value="png" className={classes.menu}>
|
|
Portable Network Graphics (PNG)
|
|
</MenuItem>
|
|
<MenuItem value="jpg" className={classes.menu}>
|
|
JPEG Image (JPEG)
|
|
</MenuItem>
|
|
</Select>
|
|
)}
|
|
</FormControl>
|
|
|
|
<FormControl>
|
|
<FormControlLabel
|
|
className={classes.label}
|
|
value="document"
|
|
control={<Radio color="primary" />}
|
|
label={intl.formatMessage({
|
|
id: 'export.document-label',
|
|
defaultMessage:
|
|
'Document: Export your mindmap in a self-contained document ready to share',
|
|
})}
|
|
color="secondary"
|
|
/>
|
|
{exportGroup == 'document' && (
|
|
<Select
|
|
onChange={handleOnExportFormatChange}
|
|
variant="outlined"
|
|
value={exportFormat}
|
|
className={classes.select}
|
|
>
|
|
<MenuItem className={classes.select} value="xls">
|
|
Microsoft Excel (XLS)
|
|
</MenuItem>
|
|
<MenuItem className={classes.select} value="txt">
|
|
Plain Text File (TXT)
|
|
</MenuItem>
|
|
</Select>
|
|
)}
|
|
</FormControl>
|
|
|
|
<FormControl>
|
|
<FormControlLabel
|
|
className={classes.label}
|
|
value="mindmap-tool"
|
|
control={<Radio color="primary" />}
|
|
label={intl.formatMessage({
|
|
id: 'export.document',
|
|
defaultMessage:
|
|
'Mindmap Tools: Export your mindmap in thirdparty mindmap tool formats',
|
|
})}
|
|
color="secondary"
|
|
/>
|
|
{exportGroup == 'mindmap-tool' && (
|
|
<Select
|
|
onChange={handleOnExportFormatChange}
|
|
variant="outlined"
|
|
className={classes.select}
|
|
value={exportFormat}
|
|
>
|
|
<MenuItem className={classes.select} value="wxml">
|
|
WiseMapping (WXML)
|
|
</MenuItem>
|
|
<MenuItem className={classes.select} value="mm">
|
|
Freemind 1.0.1 (MM)
|
|
</MenuItem>
|
|
<MenuItem className={classes.select} value="mmap">
|
|
MindManager (MMAP)
|
|
</MenuItem>
|
|
</Select>
|
|
)}
|
|
</FormControl>
|
|
</RadioGroup>
|
|
</FormControl>
|
|
</BaseDialog>
|
|
|
|
{/* Hidden form for the purpose of summit */}
|
|
<form
|
|
action={`/c/restful/maps/${mapId}.${exportFormat}`}
|
|
ref={setExportFormRef}
|
|
method="GET"
|
|
>
|
|
<input name="download" type="hidden" value={exportFormat} />
|
|
<input name="filename" type="hidden" value={map?.title} />
|
|
</form>
|
|
|
|
<form
|
|
action={`/c/restful/transform.${exportFormat}`}
|
|
ref={setTransformFormRef}
|
|
method="POST"
|
|
>
|
|
<input name="download" type="hidden" value={exportFormat} />
|
|
<input name="filename" type="hidden" value={map?.title} />
|
|
<input name="svgXml" id="svgXml" value={svgXml} type="hidden" />
|
|
</form>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default ExportDialog
|