mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-14 15:14:56 -04:00

* Change copyright year from 2020 to 2021 Signed-off-by: Tilman Vatteroth <tilman.vatteroth@tu-dortmund.de> * Change copyright year in jetbrains copyright template Signed-off-by: Tilman Vatteroth <tilman.vatteroth@tu-dortmund.de>
69 lines
1.9 KiB
TypeScript
69 lines
1.9 KiB
TypeScript
/*
|
|
SPDX-FileCopyrightText: 2021 The HedgeDoc developers (see AUTHORS file)
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import React, { Fragment, useCallback, useEffect, useRef, useState } from 'react'
|
|
import { Alert } from 'react-bootstrap'
|
|
import { useTranslation } from 'react-i18next'
|
|
import { VisualizationSpec } from 'vega-embed'
|
|
import { ShowIf } from '../../../common/show-if/show-if'
|
|
|
|
export interface VegaChartProps {
|
|
code: string
|
|
}
|
|
|
|
export const VegaChart: React.FC<VegaChartProps> = ({ code }) => {
|
|
const diagramContainer = useRef<HTMLDivElement>(null)
|
|
const [error, setError] = useState<string>()
|
|
const { t } = useTranslation()
|
|
|
|
const showError = useCallback((error: string) => {
|
|
if (!diagramContainer.current) {
|
|
return
|
|
}
|
|
console.error(error)
|
|
setError(error)
|
|
}, [])
|
|
|
|
useEffect(() => {
|
|
if (!diagramContainer.current) {
|
|
return
|
|
}
|
|
import(/* webpackChunkName: "vega" */ 'vega-embed').then((embed) => {
|
|
try {
|
|
if (!diagramContainer.current) {
|
|
return
|
|
}
|
|
|
|
const spec = JSON.parse(code) as VisualizationSpec
|
|
embed.default(diagramContainer.current, spec, {
|
|
actions: {
|
|
export: true,
|
|
source: false,
|
|
compiled: false,
|
|
editor: false
|
|
},
|
|
i18n: {
|
|
PNG_ACTION: t('renderer.vega-lite.png'),
|
|
SVG_ACTION: t('renderer.vega-lite.svg')
|
|
}
|
|
})
|
|
.then(() => setError(undefined))
|
|
.catch(err => showError(err))
|
|
} catch (err) {
|
|
showError(t('renderer.vega-lite.errorJson'))
|
|
}
|
|
}).catch(() => { console.error('error while loading vega-light') })
|
|
}, [code, showError, t])
|
|
|
|
return <Fragment>
|
|
<ShowIf condition={!!error}>
|
|
<Alert variant={'danger'}>{error}</Alert>
|
|
</ShowIf>
|
|
<div className={'text-center'}>
|
|
<div ref={diagramContainer}/>
|
|
</div>
|
|
</Fragment>
|
|
}
|