Skip to content

Commit

Permalink
Merge pull request hotosm#53 from varun2948/feat-osm-download
Browse files Browse the repository at this point in the history
fix: add metadata check for clickable link
  • Loading branch information
varun2948 authored Jan 29, 2024
2 parents e9b5a33 + 8ba86a1 commit 20ed67e
Showing 1 changed file with 20 additions and 8 deletions.
28 changes: 20 additions & 8 deletions frontend/src/components/projectDetail/downloadOsmData.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
import React, { useEffect, useState } from 'react';
import PropTypes from 'prop-types';
import { RoadIcon, HomeIcon, WavesIcon, TaskIcon, DownloadIcon } from '../svgIcons';
import { RoadIcon, HomeIcon, WavesIcon, TaskIcon, DownloadIcon, InfoIcon } from '../svgIcons';
import FileFormatCard from './fileFormatCard';
import Popup from 'reactjs-popup';
import { EXPORT_TOOL_S3_URL } from '../../config';
import messages from './messages';
import { FormattedMessage } from 'react-intl';
import formatBytes from '../../utils/formatBytes';
import { AnimatedLoadingIcon } from '../button';

export const TITLED_ICONS = [
{
Expand Down Expand Up @@ -79,8 +80,9 @@ export const DownloadOsmData = ({ projectMappingTypes, project }) => {
try {
// Fetch the file from the S3 URL
const responsehead = await fetch(downloadUrl, { method: 'HEAD' });
window.location.href = downloadUrl;

var handle = window.open(downloadUrl);
handle.blur();
window.focus();
// Check if the request was successful
if (responsehead.ok) {
setIsDownloadingState({ title: title, fileFormat: fileFormat, isDownloading: false });
Expand Down Expand Up @@ -280,7 +282,7 @@ export const DownloadOsmData = ({ projectMappingTypes, project }) => {
)
}
style={
loadingState
loadingState || !typ.lastmod
? { cursor: 'not-allowed', pointerEvents: 'none', gap: '10px' }
: { cursor: 'pointer', gap: '10px' }
}
Expand All @@ -292,15 +294,25 @@ export const DownloadOsmData = ({ projectMappingTypes, project }) => {
<span className="ml2">
{typ.type} {selectedCategoryFormat.format}
</span>
<span className="ml1 f7 black">{`(${
typ.size ? formatBytes(typ.size) : 'N/A'
})`}</span>
<span className="ml1 f7 black">
{loadingState ? (
<AnimatedLoadingIcon />
) : (
`(${typ.size ? formatBytes(typ.size) : 'N/A'})`
)}
</span>
</p>
<span className="f7 mid-gray">
{`Last Generated:`}
<span className="black">
{' '}
{typ.lastmod ? typ.lastmod : 'No data Available'}
{loadingState ? (
<AnimatedLoadingIcon />
) : typ.lastmod ? (
typ.lastmod
) : (
'No data Available'
)}
</span>
</span>
</div>
Expand Down

0 comments on commit 20ed67e

Please sign in to comment.