gdq-archive/frontend/components/DownloadButton.tsx

51 lines
1.6 KiB
TypeScript
Raw Normal View History

2021-01-05 15:25:09 +00:00
/**
* Copyright (C) 2019-2021 Carl Kittelberger <icedream@icedream.pw>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2021-01-03 17:43:50 +00:00
import { IconProp } from '@fortawesome/fontawesome-svg-core';
2023-01-09 03:02:23 +00:00
import { faDownload } from '@fortawesome/free-solid-svg-icons';
2020-08-22 20:25:57 +00:00
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import React from 'react';
import { Button } from 'react-bootstrap';
import { getDownloadURL } from 'util/api';
import { FormattedMessage } from './localization';
2021-01-03 17:43:50 +00:00
export default function DownloadButton({
2023-01-09 01:31:33 +00:00
icon,
2021-01-03 17:43:50 +00:00
id,
fileName,
}: {
icon?: IconProp,
id: string,
fileName: string
}) {
2020-08-22 20:25:57 +00:00
return (
<Button variant="success" href={getDownloadURL(id, fileName)}>
2021-01-03 17:43:50 +00:00
<FontAwesomeIcon icon={icon} className="mr-2" />
2023-01-09 03:02:23 +00:00
{' '}
2020-08-22 20:25:57 +00:00
<FormattedMessage
id="DownloadButton.download"
defaultMessage="Download"
description="Text of the download button"
/>
</Button>
);
}
2023-01-09 01:31:33 +00:00
DownloadButton.defaultProps = {
2023-01-09 03:02:23 +00:00
icon: faDownload,
2023-01-09 01:31:33 +00:00
};