aboutsummaryrefslogtreecommitdiffstats
path: root/src/components
diff options
context:
space:
mode:
Diffstat (limited to 'src/components')
-rw-r--r--src/components/UploadForm.jsx45
-rw-r--r--src/components/ViewAds.jsx33
2 files changed, 78 insertions, 0 deletions
diff --git a/src/components/UploadForm.jsx b/src/components/UploadForm.jsx
new file mode 100644
index 0000000..9bb16e7
--- /dev/null
+++ b/src/components/UploadForm.jsx
@@ -0,0 +1,45 @@
+import React, { useState } from 'react';
+import { ref, uploadBytesResumable, getDownloadURL } from 'firebase/storage';
+import { storage } from '../firebase';
+
+const UploadForm = ({ onUploadComplete }) => {
+ const [file, setFile] = useState(null);
+ const [progress, setProgress] = useState(0);
+
+ const handleFileChange = (e) => {
+ setFile(e.target.files[0]);
+ };
+
+ const handleUpload = () => {
+ if (!file) return;
+
+ const storageRef = ref(storage, `ads/${file.name}`);
+ const uploadTask = uploadBytesResumable(storageRef, file);
+
+ uploadTask.on(
+ 'state_changed',
+ (snapshot) => {
+ const progress = (snapshot.bytesTransferred / snapshot.totalBytes) * 100;
+ setProgress(progress);
+ },
+ (error) => {
+ console.error('Upload failed', error);
+ },
+ () => {
+ getDownloadURL(uploadTask.snapshot.ref).then((downloadURL) => {
+ onUploadComplete(downloadURL);
+ });
+ }
+ );
+ };
+
+ return (
+ <div>
+ <input type="file" onChange={handleFileChange} />
+ <button onClick={handleUpload}>Upload</button>
+ <div>Upload Progress: {progress}%</div>
+ </div>
+ );
+};
+
+export default UploadForm;
diff --git a/src/components/ViewAds.jsx b/src/components/ViewAds.jsx
new file mode 100644
index 0000000..719d1b2
--- /dev/null
+++ b/src/components/ViewAds.jsx
@@ -0,0 +1,33 @@
+import React, { useEffect, useState } from 'react';
+import { ref, listAll, getDownloadURL } from 'firebase/storage';
+import { storage } from '../firebase';
+
+const ViewAds = () => {
+ const [ads, setAds] = useState([]);
+
+ useEffect(() => {
+ const fetchAds = async () => {
+ const adsRef = ref(storage, 'ads/');
+ const adList = await listAll(adsRef);
+ const adUrls = await Promise.all(adList.items.map((item) => getDownloadURL(item)));
+ setAds(adUrls);
+ };
+
+ fetchAds();
+ }, []);
+
+ return (
+ <div>
+ <h2>View Ads</h2>
+ <div>
+ {ads.map((url, index) => (
+ <div key={index}>
+ <img src={url} alt={`Ad ${index + 1}`} style={{ maxWidth: '200px' }} />
+ </div>
+ ))}
+ </div>
+ </div>
+ );
+};
+
+export default ViewAds;