avancement image profil
continuous-integration/drone/push Build encountered an error Details

master
Darius BERTRAND 3 years ago
parent 3399527a49
commit 5753570ae7

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

@ -11,11 +11,10 @@ const ConfigurationDuProfil = ()=>{
const userData = useSelector((state) => state.user.user); const userData = useSelector((state) => state.user.user);
const [pseudo, setPseudo] = useState(userData.pseudo); const [pseudo, setPseudo] = useState(userData.pseudo);
const[userPicture, setUserPicture] = useState(null); const [userPicture, setUserPicture] = useState(userData.picture.data);
const [tmpImage, setTmpImage] =useState(null); const [tmpImage, setTmpImage] =useState(null);
const [tmpAffichageImage, setTmpAffichageImage]=useState(PLUS) const [tmpAffichageImage, setTmpAffichageImage]=useState(PLUS);
const [displayAdd, setDisplayAdd] = useState(false); const [displayAdd, setDisplayAdd] = useState(false);
const uid = useContext(UidContext);
const [message, setMessage] = useState(''); const [message, setMessage] = useState('');
const handleLoadFile=(e)=>{ const handleLoadFile=(e)=>{
@ -31,25 +30,11 @@ const ConfigurationDuProfil = ()=>{
console.log("eeee"); console.log("eeee");
}; };
console.log("rrrrrr"); console.log("rrrrrr");
setTmpAffichageImage(`${tmpImage.data}`) setTmpAffichageImage(`${tmpImage.data}`);
console.log("uuuuuuuuuuuu"); console.log("uuuuuuuuuuuu");
console.log(tmpImage);
}; };
useEffect(() => {
const fetchImage = async () => {
try {
const { data } = await axios.get(`/api/users/${uid}/image`);
setUserPicture(`data:${data.contentType};base64,${data.data}`);
} catch (err) {
console.error(err);
}
};
fetchImage();
}, [uid]);
const handleTPM =()=> { const handleTPM =()=> {
console.log("test"); console.log("test");
console.log(tmpImage); console.log(tmpImage);
@ -60,7 +45,7 @@ const ConfigurationDuProfil = ()=>{
e.preventDefault(); e.preventDefault();
try { try {
await axios.patch( `${process.env.REACT_APP_API_URL}api/user/${uid}/image`, tmpImage); await axios.patch( `${process.env.REACT_APP_API_URL}api/user/${userData.id}/image`, tmpImage);
setMessage("Image de profil mise à jour avec succès!"); setMessage("Image de profil mise à jour avec succès!");
} catch (err) { } catch (err) {
setMessage("Erreur lors de la mise à jour de l'image de profil"); setMessage("Erreur lors de la mise à jour de l'image de profil");

@ -1,5 +1,5 @@
import React, { useState } from 'react'; import React, { useState } from 'react';
import { NavLink, redirect} from "react-router-dom"; import { NavLink} from "react-router-dom";
import axios from "axios"; import axios from "axios";
import Connexion from "./Connexion"; import Connexion from "./Connexion";

@ -8,7 +8,6 @@ import FollowHandler from "./UserProfil/FollowHandler";
const MiniProfil = ({uid} ) => { const MiniProfil = ({uid} ) => {
const [userData, setUserData] = useState(null); const [userData, setUserData] = useState(null);
useEffect(() => { useEffect(() => {
async function fetchData() { async function fetchData() {
const response = await fetch(`${process.env.REACT_APP_API_URL}api/user/${uid}`); const response = await fetch(`${process.env.REACT_APP_API_URL}api/user/${uid}`);
@ -25,7 +24,7 @@ const MiniProfil = ({uid} ) => {
return ( return (
<div className="ListReco"> <div className="ListReco">
<div className="UtiReco"> <div className="UtiReco">
<img className="image" src={userData.picture}/> <img className="image" src={userData.picture.data}/>
<a href={`/Profil/${uid}`}>{userData.pseudo}</a> <a href={`/Profil/${uid}`}>{userData.pseudo}</a>
</div> </div>
</div> </div>

@ -91,10 +91,8 @@ module.exports.signIn = async (req, res) => {
console.log("signin: ",req.body); console.log("signin: ",req.body);
const {email, password} = req.body const {email, password} = req.body
try { try {
console.log("test user1 ");
const user = await UserModel.login({email, password}); const user = await UserModel.login({email, password});
console.log("test user2 ");
//creation d'un token //creation d'un token

@ -1,6 +1,6 @@
const UserModel = require("../models/user.model"); const UserModel = require("../models/user.model");
const ObjectID = require("mongoose").Types.ObjectId; const ObjectID = require("mongoose").Types.ObjectId;
/*const Image = mongoose.model('Image', ImageSchema);*/
//-password pour ne pas donner le password //-password pour ne pas donner le password
module.exports.getAllUsers = async (req, res) => { module.exports.getAllUsers = async (req, res) => {
@ -77,10 +77,12 @@ module.exports.compteUpdatePseudo = async (req, res) => {
} }
module.exports.getImage = async (req, res) => { module.exports.getImage = async (req, res) => {
try { try {
const image = await Image.findById(req.params.id); const user = await UserModel.findById(req.params.id);
res.status(200).json(image); if (!user) {
return res.status(404).json({ message: 'User not found' });
}
res.status(200).json(user.picture);
} catch (err) { } catch (err) {
res.status(500).json({ message: 'Error getting image' }); res.status(500).json({ message: 'Error getting image' });
} }
@ -89,7 +91,7 @@ module.exports.getImage = async (req, res) => {
module.exports.saveImage = async (req, res) => { module.exports.saveImage = async (req, res) => {
try { try {
const { data, contentType } = req.body; const { data, contentType } = req.body;
const image = new Image({ data, contentType }); const image = new UserModel.picture({ data, contentType });
await image.save(); await image.save();
res.status(201).json(image); res.status(201).json(image);
} catch (err) { } catch (err) {

@ -63,7 +63,7 @@ const userSchema = new mongoose.Schema(
}, },
picture: { picture: {
type: PictureSchema, type: PictureSchema,
default: "./random-user.png" default: { data: "", contentType: "image/png" }
}, },
bio :{ bio :{
type: String, type: String,
@ -89,6 +89,7 @@ const userSchema = new mongoose.Schema(
// play function before save into display: 'block', // play function before save into display: 'block',
userSchema.pre("save", async function(next) { userSchema.pre("save", async function(next) {
const salt = await bcrypt.genSalt(); const salt = await bcrypt.genSalt();
this.password = await bcrypt.hash(this.password, salt); this.password = await bcrypt.hash(this.password, salt);
next(); next();

Loading…
Cancel
Save