From c2025cfdf07a56859c447a4eac7e1546f4a168ae Mon Sep 17 00:00:00 2001 From: Biswakalyan Bhuyan Date: Fri, 28 Jun 2024 12:31:31 +0530 Subject: arranged dir --- client/src/App.js | 102 +++++++++++++++++++++++++++++++++------------ client/src/Influencers.css | 22 ++++++++++ client/src/Influencers.js | 102 +++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 199 insertions(+), 27 deletions(-) create mode 100644 client/src/Influencers.css create mode 100644 client/src/Influencers.js (limited to 'client/src') diff --git a/client/src/App.js b/client/src/App.js index eaeca2c..2d19281 100644 --- a/client/src/App.js +++ b/client/src/App.js @@ -1,9 +1,13 @@ import React, { useEffect, useState } from 'react'; +import { BrowserRouter as Router, Route, Link, Routes } from 'react-router-dom'; import axios from 'axios'; import './App.css'; +import Influencers from './Influencers'; function App() { const [downloadedFiles, setDownloadedFiles] = useState([]); + const [isAuthenticated, setIsAuthenticated] = useState(false); + const [adminPassword, setAdminPassword] = useState(''); useEffect(() => { fetchDownloadedFiles(); @@ -22,35 +26,79 @@ function App() { } }; + const handleLogin = (password) => { + setAdminPassword(password); + setIsAuthenticated(true); + }; + return ( -
-
-

Insta Local

-
- {downloadedFiles.length === 0 ? ( -

No content available

- ) : ( - downloadedFiles.map((file, index) => { - const fileUrl = `http://localhost:5001/static/${file}`; - console.log('Fetching file:', fileUrl); // Log the file URL - return ( -
- {file.endsWith('.mp4') ? ( - - ) : ( - {file} - )} -
- ); - }) - )} -
-
-
+ +
+
+

Insta Local

+ +
+ + + {downloadedFiles.length === 0 ? ( +

No content available

+ ) : ( + downloadedFiles.map((file, index) => { + const fileUrl = `http://localhost:5001/static/${file}`; + return ( +
+ {file.endsWith('.mp4') ? ( + + ) : ( + {file} + )} +
+ ); + }) + )} +
+ } /> + + ) : ( + + ) + } /> + + +
); } +const Login = ({ onLogin }) => { + const [password, setPassword] = useState(''); + + const handleSubmit = (event) => { + event.preventDefault(); + onLogin(password); + }; + + return ( +
+ + +
+ ); +}; + export default App; diff --git a/client/src/Influencers.css b/client/src/Influencers.css new file mode 100644 index 0000000..443762e --- /dev/null +++ b/client/src/Influencers.css @@ -0,0 +1,22 @@ +.influencers { + padding: 20px; +} + +.password-input, .add-profile, .export-import { + margin-bottom: 20px; +} + +.profile-list ul { + list-style-type: none; + padding: 0; +} + +.profile-list li { + display: flex; + justify-content: space-between; + margin-bottom: 10px; +} + +button { + margin-left: 10px; +} diff --git a/client/src/Influencers.js b/client/src/Influencers.js new file mode 100644 index 0000000..a72d654 --- /dev/null +++ b/client/src/Influencers.js @@ -0,0 +1,102 @@ +import React, { useState, useEffect, useCallback } from 'react'; +import axios from 'axios'; + +function Influencers({ adminPassword }) { + const [profiles, setProfiles] = useState([]); + const [newProfile, setNewProfile] = useState(''); + + const fetchProfiles = useCallback(async () => { + try { + const response = await axios.get('http://localhost:5001/profiles', { + headers: { Authorization: `Bearer ${adminPassword}` } + }); + console.log('Fetched profiles:', response.data); + setProfiles(response.data); + } catch (error) { + console.error('Error fetching profiles:', error); + } + }, [adminPassword]); + + useEffect(() => { + fetchProfiles(); + }, [fetchProfiles]); + + const addProfile = async () => { + try { + await axios.post( + 'http://localhost:5001/profiles', + { username: newProfile }, + { headers: { Authorization: `Bearer ${adminPassword}` } } + ); + setNewProfile(''); + fetchProfiles(); + } catch (error) { + console.error('Error adding profile:', error); + } + }; + + const handleJsonUpload = async (event) => { + const file = event.target.files[0]; + if (file) { + const formData = new FormData(); + formData.append('file', file); + + try { + await axios.post('http://localhost:5001/upload', formData, { + headers: { + 'Content-Type': 'multipart/form-data', + Authorization: `Bearer ${adminPassword}` + } + }); + fetchProfiles(); + } catch (error) { + console.error('Error uploading JSON file:', error); + } + } + }; + + const exportJson = async () => { + try { + const response = await axios.get('http://localhost:5001/export', { + headers: { Authorization: `Bearer ${adminPassword}` }, + responseType: 'blob' + }); + const url = window.URL.createObjectURL(new Blob([response.data])); + const link = document.createElement('a'); + link.href = url; + link.setAttribute('download', 'influencers.json'); + document.body.appendChild(link); + link.click(); + } catch (error) { + console.error('Error exporting JSON file:', error); + } + }; + + return ( +
+

Add Influencers

+ setNewProfile(e.target.value)} + placeholder="Enter Instagram username" + /> + +

Current Influencers

+ +

Import/Export Influencers

+ + +
+ ); +} + +export default Influencers; -- cgit v1.2.3-59-g8ed1b