2020-12-15 13:54:35 -05:00
|
|
|
// @flow
|
2022-03-21 12:20:33 -04:00
|
|
|
import { IMAGE_PROXY_URL, THUMBNAIL_CDN_URL, THUMBNAIL_HEIGHT, THUMBNAIL_WIDTH, THUMBNAIL_QUALITY } from 'config';
|
2020-12-15 13:54:35 -05:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
thumbnail: ?string,
|
|
|
|
height?: number,
|
|
|
|
width?: number,
|
|
|
|
quality?: number,
|
|
|
|
};
|
|
|
|
|
|
|
|
export function getThumbnailCdnUrl(props: Props) {
|
|
|
|
const { thumbnail, height = THUMBNAIL_HEIGHT, width = THUMBNAIL_WIDTH, quality = THUMBNAIL_QUALITY } = props;
|
|
|
|
|
|
|
|
if (!THUMBNAIL_CDN_URL || !thumbnail) {
|
|
|
|
return thumbnail;
|
|
|
|
}
|
|
|
|
|
2022-03-19 16:04:51 -04:00
|
|
|
if (thumbnail.includes(THUMBNAIL_CDN_URL)) {
|
|
|
|
return thumbnail;
|
2020-12-15 13:54:35 -05:00
|
|
|
}
|
2021-10-07 16:38:56 -04:00
|
|
|
|
2022-03-19 16:04:51 -04:00
|
|
|
if (thumbnail) {
|
|
|
|
return `${THUMBNAIL_CDN_URL}s:${width}:${height}/quality:${quality}/plain/${thumbnail}`;
|
2021-10-07 16:38:56 -04:00
|
|
|
}
|
2020-12-15 13:54:35 -05:00
|
|
|
}
|
2022-03-21 12:20:33 -04:00
|
|
|
|
|
|
|
export function getImageProxyUrl(thumbnail: ?string) {
|
2022-03-29 21:51:22 +08:00
|
|
|
if (
|
|
|
|
IMAGE_PROXY_URL &&
|
|
|
|
thumbnail &&
|
|
|
|
!thumbnail.startsWith(THUMBNAIL_CDN_URL) &&
|
|
|
|
!thumbnail.startsWith(IMAGE_PROXY_URL)
|
|
|
|
) {
|
2022-03-21 12:20:33 -04:00
|
|
|
return `${IMAGE_PROXY_URL}?${thumbnail}`;
|
|
|
|
}
|
|
|
|
return thumbnail;
|
|
|
|
}
|