mirror of
https://github.com/hedgedoc/hedgedoc.git
synced 2025-05-20 18:25:21 -04:00

Doing this BEFORE the merge prevents a lot of merge conflicts. Signed-off-by: Tilman Vatteroth <git@tilmanvatteroth.de>
38 lines
1.4 KiB
TypeScript
38 lines
1.4 KiB
TypeScript
/*
|
|
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import React, { useEffect, useState } from 'react'
|
|
import { getProxiedUrl } from '../../../../api/media'
|
|
import { useApplicationState } from '../../../../hooks/common/use-application-state'
|
|
import { Logger } from '../../../../utils/logger'
|
|
|
|
const log = new Logger('ProxyImageFrame')
|
|
|
|
/**
|
|
* Renders an image using the image proxy.
|
|
*
|
|
* @param src The image source
|
|
* @param title The title of the image
|
|
* @param alt The alt text of the image
|
|
* @param props Additional props directly given to the image
|
|
*/
|
|
export const ProxyImageFrame: React.FC<React.ImgHTMLAttributes<HTMLImageElement>> = ({ src, title, alt, ...props }) => {
|
|
const [imageUrl, setImageUrl] = useState('')
|
|
const imageProxyEnabled = useApplicationState((state) => state.config.useImageProxy)
|
|
|
|
useEffect(() => {
|
|
if (!imageProxyEnabled || !src) {
|
|
return
|
|
}
|
|
getProxiedUrl(src)
|
|
.then((proxyResponse) => setImageUrl(proxyResponse.url))
|
|
.catch((err) => log.error(err))
|
|
}, [imageProxyEnabled, src])
|
|
|
|
// The next image processor works with a whitelist of origins. Therefore, we can't use it for general images.
|
|
// eslint-disable-next-line @next/next/no-img-element
|
|
return <img src={imageProxyEnabled ? imageUrl : src ?? ''} title={title ?? alt ?? ''} alt={alt} {...props} />
|
|
}
|