import React from 'react'; import '../App.css'; import placeholderPng from './placeholder.png'; import { useState, useEffect } from 'react'; function Gallery() { const [data, setData] = useState([]); const [category, setCategory] = useState(''); useEffect(() => { post(category, (data: galleryItemInfo[]) => { setData(data); }); }, [category]); const updateCategory = (category: string) => { setData(getPlaceholderData); setCategory(category); }; return (
{Contents(data, true, category, updateCategory)}
{Contents(data, false, category, updateCategory)}
); } interface galleryItemInfo { is_dir: boolean; url: string; thumbnail_url: string; isPlaceholder: boolean; } function Contents( data: galleryItemInfo[], getDir: boolean, category: string, setCategory: (category: string) => void ) { if (data === null) return; return data .sort((a: galleryItemInfo, b: galleryItemInfo): number => { if (a.is_dir && b.is_dir) return 0; if (a.is_dir && !b.is_dir) return -1; if (!a.is_dir && b.is_dir) return 1; if (!a.is_dir && !b.is_dir) return 0; return 0; }) .filter((item: galleryItemInfo) => { return getDir == item.is_dir; }) .map((item: galleryItemInfo, index: number) => { const itemProps = { key: index, url: item.url, thumbnail_url: item.thumbnail_url === null ? item.url : item.thumbnail_url, onClick: () => {}, isPlaceholder: item.isPlaceholder, }; if (item.is_dir) { itemProps.onClick = item.isPlaceholder ? () => {} : () => { const subCategory = getFileName(itemProps.url); if (category !== '') category = `${category}/${subCategory}`; else category = subCategory; if (subCategory === '..') category = category.split('/').slice(0, -2).join('/'); setCategory(category); }; return ; } if (itemProps.url.endsWith('.mp4')) { return ; } return ; }); } interface galleryItem { url: string; thumbnail_url: string; onClick: () => void; isPlaceholder: boolean; } function ImageItem({ thumbnail_url, url, isPlaceholder }: galleryItem) { const placeholderClass = isPlaceholder ? 'PlaceholderItem' : ''; return (
{getFileName(url)}
); } function VideoItem({ url }: galleryItem) { return (
{getFileName(url)}
); } function DirectoryItem({ url, onClick, isPlaceholder }: galleryItem) { let buttonText = getFileName(url); const isBackButton = buttonText === '..'; const placeholderClass = isPlaceholder ? 'PlaceholderItem' : ''; buttonText = isBackButton ? 'Back' : `${buttonText}`; const backButtonClass = isBackButton ? 'ParentDirectoryItem' : ''; return (
); } function getFileName(string: string): string { return string.split('/').at(-1) as unknown as string; } function getPlaceholderData(): galleryItemInfo[] { const backDir = (): galleryItemInfo => { return { is_dir: true, url: '..', thumbnail_url: '', isPlaceholder: true, }; }; const placeholderDir = (): galleryItemInfo => { return { is_dir: true, url: '', thumbnail_url: '', isPlaceholder: true, }; }; const placeholderImg = (): galleryItemInfo => { return { is_dir: false, url: '', thumbnail_url: `${placeholderPng}`, isPlaceholder: true, }; }; return [ backDir(), placeholderDir(), placeholderDir(), placeholderImg(), placeholderImg(), placeholderImg(), ]; } async function post( category: string, setDataCallback: (data: galleryItemInfo[]) => void ) { try { const response = await 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, }), } ); setDataCallback(await response.json()); } catch (error) { console.error('Error fetching data: ', error); setDataCallback([ { is_dir: false, url: 'error_fetching', thumbnail_url: '', isPlaceholder: false, }, ]); } } export default Gallery;