Compare commits

...

3 Commits

Author SHA1 Message Date
098777bb02 Use hosted backend 2023-11-14 03:51:09 +08:00
2c31cf8820 Change title to Photos 2023-11-14 00:32:09 +08:00
9d3d3530ea Fix handling of thumbnail urls, so that original url is still linked on
the top of image.
2023-11-14 00:31:10 +08:00
3 changed files with 45 additions and 16 deletions

View File

@ -1,5 +1,6 @@
{
"name": "react-photo-viewer",
"homepage": "https://dundun.ddns.net/photos",
"version": "0.1.0",
"private": true,
"dependencies": {

View File

@ -24,7 +24,7 @@
work correctly both with client-side routing and a non-root public URL.
Learn how to configure a non-root public URL by running `npm run build`.
-->
<title>React App</title>
<title>Photos</title>
</head>
<body>
<noscript>You need to enable JavaScript to run this app.</noscript>

View File

@ -60,7 +60,9 @@ function getContents(
return getDir == item.is_dir;
})
.map((item: galleryItemInfo, index: number) => {
const url = item.thumbnail_url === null ? item.url : item.thumbnail_url;
const url = item.url;
const thumbnail_url =
item.thumbnail_url === null ? item.url : item.thumbnail_url;
let onClick = () => {};
if (item.is_dir) {
onClick = () => {
@ -73,27 +75,49 @@ function getContents(
setCategory(category);
};
return <DirectoryItem key={index} url={url} onClick={onClick} />;
return (
<DirectoryItem
key={index}
thumbnail_url={thumbnail_url}
url={url}
onClick={onClick}
/>
);
}
if (url.endsWith('.mp4')) {
return <VideoItem key={index} url={url} onClick={onClick} />;
return (
<VideoItem
key={index}
thumbnail_url={thumbnail_url}
url={url}
onClick={onClick}
/>
);
}
return <ImageItem key={index} url={url} onClick={onClick} />;
return (
<ImageItem
key={index}
thumbnail_url={thumbnail_url}
url={url}
onClick={onClick}
/>
);
});
}
interface galleryItem {
url: string;
thumbnail_url: string;
onClick: () => void;
}
function ImageItem({ url }: galleryItem) {
function ImageItem({ thumbnail_url, url }: galleryItem) {
return (
<div className="GalleryItem">
<a href={url} target="_blank">
{getFileName(url)}
</a>
<img src={url} loading="lazy" />
<img src={thumbnail_url} loading="lazy" />
</div>
);
}
@ -130,15 +154,19 @@ function getFileName(string: string): string {
}
function post(category: string, callback: (text: string) => void) {
fetch('http://localhost/photo-viewer-backend/php/get.php', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
category: category,
}),
})
fetch(
//'http://localhost/photo-viewer-backend/php/get.php',
'https://dundun.ddns.net/photo-viewer/photo-viewer-backend/php/get.php',
{
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
category: category,
}),
}
)
.then((response) => {
if (!response.ok) {
throw new Error('Network response was not ok');