diff --git a/.eslintcache b/.eslintcache index e3c4fab..b2be5a0 100644 --- a/.eslintcache +++ b/.eslintcache @@ -1 +1 @@ -[{"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\index.js":"1","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\App.jsx":"2","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\reportWebVitals.js":"3","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\Home.jsx":"4","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\signup.jsx":"5","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\login.jsx":"6","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\friends-liste.jsx":"7","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\statistique.jsx":"8","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\chat.jsx":"9","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-gauche.jsx":"10","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\withAuth.jsx":"11","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\application2.jsx":"12","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\paramètre.jsx":"13","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\friend_nom.jsx":"14","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-amis-gauche.jsx":"15"},{"size":598,"mtime":1617782906946,"results":"16","hashOfConfig":"17"},{"size":1381,"mtime":1617782906902,"results":"18","hashOfConfig":"17"},{"size":375,"mtime":1617782906947,"results":"19","hashOfConfig":"17"},{"size":19033,"mtime":1617782906903,"results":"20","hashOfConfig":"17"},{"size":3383,"mtime":1617782906947,"results":"21","hashOfConfig":"17"},{"size":3384,"mtime":1617894076205,"results":"22","hashOfConfig":"17"},{"size":3960,"mtime":1617812043449,"results":"23","hashOfConfig":"17"},{"size":2462,"mtime":1617783472207,"results":"24","hashOfConfig":"17"},{"size":6856,"mtime":1617782906905,"results":"25","hashOfConfig":"17"},{"size":2380,"mtime":1617811969631,"results":"26","hashOfConfig":"17"},{"size":1566,"mtime":1617782906951,"results":"27","hashOfConfig":"17"},{"size":2934,"mtime":1617782906903,"results":"28","hashOfConfig":"17"},{"size":2179,"mtime":1617894055611,"results":"29","hashOfConfig":"17"},{"size":1818,"mtime":1617782906906,"results":"30","hashOfConfig":"17"},{"size":1508,"mtime":1617812117051,"results":"31","hashOfConfig":"17"},{"filePath":"32","messages":"33","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"34"},"15zyhu5",{"filePath":"35","messages":"36","errorCount":0,"warningCount":3,"fixableErrorCount":0,"fixableWarningCount":0,"source":"37","usedDeprecatedRules":"34"},{"filePath":"38","messages":"39","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"34"},{"filePath":"40","messages":"41","errorCount":0,"warningCount":25,"fixableErrorCount":0,"fixableWarningCount":0,"source":"42","usedDeprecatedRules":"34"},{"filePath":"43","messages":"44","errorCount":0,"warningCount":5,"fixableErrorCount":0,"fixableWarningCount":0,"source":"45","usedDeprecatedRules":"34"},{"filePath":"46","messages":"47","errorCount":0,"warningCount":5,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"48","messages":"49","errorCount":0,"warningCount":7,"fixableErrorCount":0,"fixableWarningCount":0,"source":"50","usedDeprecatedRules":"34"},{"filePath":"51","messages":"52","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":"53","usedDeprecatedRules":"34"},{"filePath":"54","messages":"55","errorCount":0,"warningCount":8,"fixableErrorCount":0,"fixableWarningCount":0,"source":"56","usedDeprecatedRules":"34"},{"filePath":"57","messages":"58","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":"59","usedDeprecatedRules":"34"},{"filePath":"60","messages":"61","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"34"},{"filePath":"62","messages":"63","errorCount":0,"warningCount":2,"fixableErrorCount":0,"fixableWarningCount":0,"source":"64","usedDeprecatedRules":"34"},{"filePath":"65","messages":"66","errorCount":0,"warningCount":2,"fixableErrorCount":0,"fixableWarningCount":0,"source":null},{"filePath":"67","messages":"68","errorCount":0,"warningCount":1,"fixableErrorCount":0,"fixableWarningCount":0,"source":"69","usedDeprecatedRules":"34"},{"filePath":"70","messages":"71","errorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0,"usedDeprecatedRules":"34"},"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\index.js",[],["72","73"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\App.jsx",["74","75","76"],"import React, { Component } from 'react';\r\nimport { BrowserRouter, Route, Router, Link, Switch } from \"react-router-dom\"\r\nimport Home from './Home.jsx';\r\nimport Login from './login.jsx';\r\nimport Signup from './signup.jsx'\r\nimport rockets from './components/statistique.jsx'\r\nimport Friendsliste from './friends-liste.jsx'\r\nimport Application2 from './application2'\r\nimport withAuth from './withAuth'\r\nimport Chat from './components/chat.jsx'\r\nimport Parametre from './components/paramètre'\r\nimport './style/app.css'\r\n\r\nclass App extends Component {\r\n // différente route renvoyant un composant react\r\n render() {\r\n return (\r\n \r\n
\r\n \r\n \r\n \r\n \r\n {/*withAuth permet de renvoyer le composant \"Application\" si la vérification des cookies est validé par le server*/}\r\n \r\n \r\n \r\n \r\n \r\n
\r\n
\r\n );\r\n }\r\n}\r\n\r\nexport default App;","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\reportWebVitals.js",[],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\Home.jsx",["77","78","79","80","81","82","83","84","85","86","87","88","89","90","91","92","93","94","95","96","97","98","99","100","101"],"import logoichat from './image/logo-ichat.png'\r\nimport fleche from './image/fleche.png'\r\nimport imagepage2 from './image/img-page2.png'\r\nimport imagepage3 from './image/img-page3.png'\r\nimport imagepage4 from './image/img-page4.png'\r\nimport imgprofil from './image/img-profil.jpg'\r\nimport fussée from './image/rocket.png'\r\nimport imgpage6 from './image/img-page6.png'\r\nimport imgLucas from './image/profil-Lucas.png'\r\nimport imgMatthieu from './image/profil-Matthieu.png'\r\nimport imglogotwitter from './image/logo-twitter.png'\r\nimport imglogoinsta from './image/logo-insta.png'\r\nimport imglogogithub from './image/003-github.png'\r\nimport logoichatblanc from './image/logo-ichat-white.png'\r\nimport { BrowserRouter, Route, Router, Link, Switch } from \"react-router-dom\"\r\nimport './style/Home.css';\r\nimport './style/responsive.css'\r\n\r\n// page de présentation du projet, le style n'est pas a jour\r\n\r\nfunction Home() {\r\n return (\r\n
\r\n
\r\n
\r\n
\r\n \"logo\r\n
\r\n
\r\n Application\r\n SIGN UP\r\n Login\r\n
\r\n
\r\n\r\n
\r\n
\r\n

Garder le contact

\r\n

Rejoignez vos amis pour des sessions de chat intense

\r\n
\r\n
\r\n En savoir plus\r\n Ouvrir iChat\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n \"fleche\"/\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \"image\r\n
\r\n
\r\n
\r\n

Gardez le contact

\r\n
\r\n
\r\n

Principe fondateur du projet iChat, gardez le contact avec vos amis pour des discussions sans fin au quotidien. Ichat vous permt d’être au près de vos amis tout le long de votre journée.

\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n

Discussion fluide

\r\n
\r\n
\r\n

Profite de différents canaux de discussions, selon avec qui tu souhaites discuter et partager tes folles histoires. Une interface agréable, privilégiant un thème sombre pour le confort visuel.\r\n

\r\n
\r\n
\r\n
\r\n \"image\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n \"image\r\n
\r\n
\r\n
\r\n \"image\r\n

Alexandre

\r\n
\r\n
\r\n

4

\r\n \"image\r\n
\r\n
\r\n
\r\n
\r\n \"image\r\n

Delphine

\r\n
\r\n
\r\n

12

\r\n \"image\r\n
\r\n
\r\n
\r\n
\r\n \"image\r\n

Paul

\r\n
\r\n
\r\n

26

\r\n \"image\r\n\r\n
\r\n
\r\n
\r\n
\r\n \"image\r\n

Louis

\r\n
\r\n
\r\n

8

\r\n \"image\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n

Un suivi de tes relations

\r\n
\r\n
\r\n

Chaque jour suplémentaire où tu vas avoir des conversations avec un ami iChat, un compteur sera mis en place. Ce dernier se nomme le iChat Score. Chaque jour le compteur s’incrémente pour connaître la durée de vos relations.

\r\n
\r\n
\r\n
\r\n
\r\n
\r\n \r\n
\r\n
\r\n
\r\n

Pour suivre le projet

\r\n Star\r\n
\r\n
\r\n\r\n\r\n\r\n
\r\n \r\n \r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n

Projet supervisé par ....

\r\n \"image\r\n
\r\n
\r\n
\r\n
\r\n \"image\r\n CV Lucas\r\n
\r\n
\r\n \"image\r\n CV Matthieu\r\n
\r\n
\r\n
\r\n
\r\n\r\n
\r\n
\r\n
\r\n \"image\r\n
\r\n

Nom : L'Homme

\r\n

Prénom : Lucas

\r\n

Âge : 16 ans

\r\n

Numéro de Téléphone : 06.07.45.98.22

\r\n

Adresse e-mail : lucas.lhomme@gmail.com

\r\n
\r\n
\r\n
\r\n

Parcours scolaire

\r\n
\r\n
  • \r\n 2016-2017 jusqu'à 2018/2019, collège du klosterwald Villé\r\n
  • \r\n
      \r\n
    • \r\n Brevet des collèges : Mention Très bien\r\n
    • \r\n
    \r\n
  • \r\n 2019/2020 jusqu'à 2020/2021, lycée Polyvalent Jean-Baptiste Schwilgué\r\n
      \r\n
    • Enseignement de spécialité :
    • \r\n
        \r\n
      • Maths
      • \r\n
      • Physique
      • \r\n
      • Numérique et Science de l'Informatique
      • \r\n
      \r\n
    \r\n
  • \r\n
    \r\n

    Profil

    \r\n

    \r\n Je suis actuellement au Schwilgué, en première général, étant interessé par les nouvelles technologies, mon choix a donc été influencé. De cette façon j'ai pris les enseignements de spécialités suivants: Maths, Physique, NSI. C'est pour cela que je souhaite\r\n m'orienter vers un métier centré sur cette thématique.Durant mon temps libre je m'investis dans divers projets numériques. De plus je sais utiliser divers outils de bureautique tels, que la suite microsoft ou les logiciels de montage photo/vidéo.\r\n

    \r\n

    Compétences

    \r\n
    \r\n
    \r\n

    Coding

    \r\n 65% \r\n
    \r\n
    \r\n

    Photo montage

    \r\n 50% \r\n
    \r\n
    \r\n

    Créativité

    \r\n 50% \r\n
    \r\n
    \r\n

    Loisirs

    \r\n
    \r\n
  • Sport:
  • \r\n
      \r\n
    • Ski
    • \r\n
    • Snowboard
    • \r\n
    • Vélo
    • \r\n
    \r\n
  • Autre :
  • \r\n
      \r\n
    • pilotage de drone
    • \r\n
    • programmation
    • \r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n\r\n
    \r\n
    \r\n
    \r\n

    Parcours scolaire

    \r\n
    \r\n
  • \r\n 2016/2017 jusqu'à 2018/2019, collège du Bernstein Dambach-la-ville\r\n
  • \r\n
      \r\n
    • \r\n Brevet des collèges : Mention bien\r\n
    • \r\n
    \r\n
  • \r\n 2019/2020 jusqu'à 2020/2021, lycée Polyvalent Jean-Baptiste Schwilgué\r\n
      \r\n
    • Enseignement de spécialité :
    • \r\n
        \r\n
      • Maths
      • \r\n
      • Physique
      • \r\n
      • Numérique et Science de l'Informatique
      • \r\n
      \r\n
    \r\n
  • \r\n
    \r\n

    Profil

    \r\n

    Je suis actuellement en premiere générale au lycée Schwilgué de Sélestat .Ayant un profil scientifique, j'ai choisi les spécialités suivantes: Maths Physique et Nsi. Je voudrais m'orienter vers un métier dans le domaine de l'informatique.\r\n

    \r\n

    Compétences

    \r\n
    \r\n
    \r\n

    Coding

    \r\n 35% \r\n
    \r\n
    \r\n

    video montage

    \r\n 40% \r\n
    \r\n
    \r\n

    Créativité

    \r\n 60% \r\n
    \r\n
    \r\n

    Loisirs

    \r\n
    \r\n
  • Sport:
  • \r\n
      \r\n
    • Football
    • \r\n
    • Vélo
    • \r\n
    \r\n
  • Autre :
  • \r\n
      \r\n
    • Jeux video
    • \r\n
    • Pilotage de drone
    • \r\n
    \r\n
    \r\n
    \r\n
    \r\n \"image\r\n
    \r\n

    Nom : Diebolt

    \r\n

    Prénom : Matthieu

    \r\n

    Âge : 16 ans

    \r\n

    Numéro de téléphone : 06.47.55.58.32

    \r\n

    Adresse e-mail : matthieu.diebolt@gmail.com

    \r\n
    \r\n
    \r\n
    \r\n
    \r\n\r\n \r\n
    \r\n );\r\n}\r\n\r\n\r\nconst styles = {\r\n \"list-style-type\":\"none\"\r\n }\r\n \r\nexport default Home;\r\n\r\n","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\signup.jsx",["102","103","104","105","106"],"import React, { Component } from 'react';\r\nimport axios from 'axios';\r\nimport { BrowserRouter, Route, Router, Link, Switch } from \"react-router-dom\"\r\nimport './style/singup.css';\r\n\r\nexport default class signup extends Component {\r\n // création des states suivant\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n email : '',\r\n mdp: '',\r\n pseudo:'',\r\n message:''\r\n };\r\n }\r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n // quand bouton submit pressé, envoyé une requête POST au serveur pour insérer le nouvel utilisateur dans la base de donnée\r\n onSubmit = (event) => {\r\n event.preventDefault();\r\n console.log(\"state signup : \",this.state);\r\n\r\n fetch('http://localhost:4000/authentification/signup', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include',\r\n body: JSON.stringify({\r\n pseudo:this.state.pseudo,\r\n email:this.state.email,\r\n mdp:this.state.mdp\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n }\r\n })\r\n .then((value) => {\r\n if (value.status === 200) {\r\n // s'il y a eu aucune erreur redirigé à l'acceuil\r\n this.props.history.push('/app/friendlist');\r\n console.log(\"info envoyé\");\r\n } else {\r\n // s'il y a eu une erreur, renvoyer le message suivant\r\n this.setState({message:'Pseudo ou email déjà utilisé'});\r\n }\r\n })\r\n\r\n }\r\n \r\n render() {\r\n return (\r\n
    \r\n
    \r\n
    \r\n
    \r\n

    Create Account

    \r\n \r\n

    \r\n \r\n

    \r\n \r\n

    \r\n \r\n
    \r\n

    {this.state.message}

    \r\n
    \r\n
    \r\n

    Welcome back

    \r\n

    Si tu as déjà un compte, il te suffit de te connecter !

    \r\n SIGN IN\r\n
    \r\n
    \r\n
    \r\n );\r\n\r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\login.jsx",["107","108","109","110","111"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\friends-liste.jsx",["112","113","114","115","116","117","118"],"import React, { Component } from 'react';\r\nimport { BrowserRouter, Route, Router, Link, Switch } from \"react-router-dom\"\r\nimport './style/app.css';\r\nimport Chat from './components/chat';\r\nimport { withRouter } from \"react-router-dom\";\r\nimport Barregauche from './barre-gauche.jsx';\r\nimport StatWithFriend from './components/statistique'\r\n\r\n\r\n\r\nexport default class friendsliste extends Component {\r\n \r\n // création du State \"friend\"\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n friend : '',\r\n message : '',\r\n amislist: [{_id:0, _pseudo:\"\"}],\r\n firstFriend:\"\",\r\n room:''\r\n };\r\n }\r\n \r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n\r\n // fonction permettant de faire une requête POST au serveur et d'envoyer les données\r\n onSubmit = (event) => {\r\n event.preventDefault();\r\n console.log(\"state envois demande amis : \",this.state)\r\n // requête POST\r\n fetch('http://localhost:4000/app/newfriend', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n new_friend: this.state.friend\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n }\r\n })\r\n // renvois message de réussite ou non\r\n .then(res => {\r\n if (res.status === 200) {\r\n this.setState({message: \"\"})\r\n } else if(res.status === 400){\r\n this.setState({message : \"l'utilisateur rechercher n'existe pas\"})\r\n } else if(res.status === 402){\r\n this.setState({message: \" vous avez déja cette utilisateur en amis\"})\r\n } else{\r\n console.log(\"erreur\")\r\n }\r\n })\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n console.log(response)\r\n this.setState({amislist:response.data})\r\n this.setState({firstFriend:response.firstFriend})\r\n console.log(\"state\", this.state.amislist)\r\n })\r\n }\r\n\r\n render() {\r\n const {message} = this.state\r\n const {amislist} = this.state\r\n console.log(\"here\",amislist)\r\n return (\r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n \r\n \r\n

    {message}

    \r\n
    \r\n
    \r\n
    \r\n {amislist.map((amis)=>(\r\n \r\n
    \r\n

    {amis.pseudo}

    \r\n
    \r\n \r\n ))}\r\n
    \r\n
    \r\n
    \r\n ); \r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\statistique.jsx",["119"],"import React, { Component } from 'react';\r\nimport { Link } from 'react-router-dom';\r\nimport Barregauche from '../barre-gauche.jsx';\r\nimport rockets from '../image/rockets.png'\r\n\r\nexport default class StatWithFriend extends Component {\r\n\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n statistique_amis: [{}], \r\n amislist: [{}],\r\n FirstFriend:\"\"\r\n };\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/statByUser', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => { \r\n this.setState({statistique_amis:response})\r\n console.log(\"statistique : \",this.state.statistique_amis)\r\n })\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n console.log(response)\r\n this.setState({amislist:response.data})\r\n this.setState({FirstFriend:response.firstFriend})\r\n })\r\n }\r\n\r\n\r\n\r\n render(){\r\n const {statistique_amis} = this.state\r\n return(\r\n
    \r\n \r\n
    \r\n
    \r\n

    Nombre de message échanger : Ichat rockets \"amis\"/

    \r\n
    \r\n
    \r\n {statistique_amis.map((amis)=>(\r\n
    \r\n

    {amis.friend_name} : {amis.nbr_message} \"amis\"/

    \r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\chat.jsx",["120","121","122","123","124","125","126","127"],"import React, { Component } from 'react';\r\n\r\nimport { io } from \"socket.io-client\"; \r\nimport { withRouter } from \"react-router-dom\";\r\nimport FriendNom from './friend_nom'\r\n\r\n\r\n\r\nconst socket = io('http://localhost:4000');\r\nexport default class Chat extends Component {\r\n // création du state \"message\"\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n message : '',\r\n friendid:'',\r\n groupetext:[{_id:0, text:\"\", author:\"\"}],\r\n room:'',\r\n user_nom:'',\r\n change:false\r\n };\r\n }\r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n componentDidMount(){\r\n this.setState({friendid:this.props.valeur})\r\n this.setState({user_nom:this.props.nom})\r\n fetch('http://localhost:4000/app/getgroupechatlist', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n friendID: this.props.valeur\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({groupetext:response[0].message})\r\n //console.log(response[0].message)\r\n this.setState({room:response[0]._id})\r\n //console.log(this.state.room)\r\n socket.emit('joinRoom', this.state.room)\r\n })\r\n }\r\n\r\n componentDidUpdate(){\r\n if(this.state.friendid !== this.props.valeur){\r\n this.setState({friendid:this.props.valeur})\r\n fetch('http://localhost:4000/app/getgroupechatlist', {\r\n method: 'POST',\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n friendID: this.props.valeur\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({groupetext:response[0].message})\r\n //console.log(response[0].message)\r\n this.setState({room:response[0]._id})\r\n //console.log(this.state.room) \r\n socket.emit('leave')\r\n socket.emit('joinRoom', this.state.room)\r\n })\r\n }\r\n }\r\n\r\n componentDidMount(){\r\n socket.on('message', message =>{\r\n console.log(message)\r\n let {groupetext} = this.state\r\n groupetext.push(message)\r\n //console.log(groupetext)\r\n this.setState({change:true})\r\n console.log(groupetext)\r\n })\r\n socket.on('messageDelete',value =>{\r\n console.log('le message suprimé : ',value)\r\n let {groupetext} = this.state\r\n const index = groupetext.findIndex(mess => mess._id === value)\r\n if(index != -1){\r\n groupetext.splice(index,1)\r\n this.setState({change:true})\r\n }\r\n })\r\n socket.on('info', message =>{\r\n console.log(message)\r\n })\r\n }\r\n onSubmit = () => {\r\n if(this.state.message != ''){\r\n socket.emit(\"sendmessage\", {\r\n message:this.state.message,\r\n author:this.props.nom,\r\n room:this.state.room\r\n })\r\n this.setState({message:''})\r\n }\r\n }\r\n deleteMessage = (event) =>{\r\n const { value } = event.target;\r\n socket.emit('getMessageToDelete',{\r\n value: value,\r\n room: this.state.room\r\n })\r\n\r\n }\r\n render() {\r\n const BLOCK = {diplay: 'block'}\r\n const NONE= {diplay: 'none'}\r\n if(this.state.change === true){\r\n this.setState({change:false})\r\n return(\r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n {this.state.groupetext.map((mess)=>(\r\n
    \r\n

    {mess.author}

    \r\n

    {mess.text}

    \r\n { this.props.nom == mess.author ? : console.log('')}\r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n )\r\n } else{\r\n return (\r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n {this.state.groupetext.map((mess)=>(\r\n
    \r\n

    {mess.author}

    \r\n

    {mess.text}

    \r\n { this.props.nom == mess.author ? : console.log('')}\r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n ); \r\n }\r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-gauche.jsx",["128"]," import React, { Component } from 'react';\r\nimport { Link } from 'react-router-dom';\r\nimport './style/barre-gauche.css';\r\nimport profil from './image/img-profil.jpg'\r\nimport envelope from './image/envelope.png'\r\nimport users from './image/user.png'\r\nimport rouage from './image/settings.png'\r\nimport logout from './image/logout.png'\r\nimport rockets from './image/rockets.png'\r\n\r\n\r\nexport default class barregauche extends Component {\r\n\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n firstFriend:\"\"\r\n };\r\n }\r\n\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({firstFriend:response.firstFriend})\r\n })\r\n }\r\n render(){\r\n return(\r\n
    \r\n
    \r\n
    \r\n \"photo\r\n
    \r\n
    \r\n \r\n \"message\"/\r\n \r\n \r\n \"amis\"/\r\n \r\n \r\n \"amis\"/\r\n \r\n \r\n \"paramétres\"/\r\n \r\n
    \r\n
    \r\n \"déconextion\"/\r\n
    \r\n
    \r\n
    \r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\withAuth.jsx",[],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\application2.jsx",["129","130"],"import React, { Component } from 'react';\r\n\r\nimport Chat from './components/chat';\r\nimport { Link } from 'react-router-dom';\r\nimport './style/app.css';\r\nimport Barregauche from './barre-gauche.jsx';\r\nimport Barreamisgauche from './barre-amis-gauche';\r\n\r\n\r\nexport default class Application2 extends Component {\r\n \r\n \r\n // création du State \"friend\"\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n friend : '',\r\n message : '',\r\n amislist: [{_id:0, _pseudo:\"\"}],\r\n firstFriend:\"\",\r\n user_nom : ''\r\n };\r\n }\r\n \r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n\r\n // fonction permettant de faire une requête POST au serveur et d'envoyer les données\r\n onSubmit = (event) => {\r\n event.preventDefault();\r\n console.log(\"state envois demande amis : \",this.state)\r\n // requête POST\r\n fetch('http://localhost:4000/app/newfriend', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n new_friend: this.state.friend\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n }\r\n })\r\n // renvois message de réussite ou non\r\n .then(res => {\r\n if (res.status === 200) {\r\n this.setState({message: \"\"})\r\n } else if(res.status === 400){\r\n this.setState({message : \"l'utilisateur rechercher n'existe pas\"})\r\n }\r\n else{\r\n console.log(\"erreur\")\r\n }\r\n })\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n //console.log(response)\r\n this.setState({amislist:response.friends})\r\n this.setState({user_nom:response.pseudo})\r\n this.setState({firstFriend:response.firstFriend})\r\n //let test = this.state.amislist\r\n\r\n })\r\n }\r\n\r\n render() {\r\n const {message} = this.state\r\n const { id } = this.props.match.params;\r\n return (\r\n
    \r\n
    \r\n \r\n \r\n
    \r\n \r\n
    \r\n ); \r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\paramètre.jsx",["131","132"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\friend_nom.jsx",["133"],"import React, { Component } from 'react';\r\n\r\n\r\nexport default class friend_nom extends Component {\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n nom:'',\r\n id:''\r\n };\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/getFriendName', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n name: this.props.id\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({nom:response})\r\n this.setState({id:this.props.id})\r\n })\r\n }\r\n componentDidUpdate(){\r\n if(this.state.id != this.props.id){\r\n fetch('http://localhost:4000/app/getFriendName', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n name: this.props.id\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({nom:response})\r\n this.setState({id:this.props.id})\r\n })\r\n }\r\n }\r\n render(){\r\n return(\r\n

    \r\n {this.state.nom}\r\n

    \r\n\r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-amis-gauche.jsx",[],{"ruleId":"134","replacedBy":"135"},{"ruleId":"136","replacedBy":"137"},{"ruleId":"138","severity":1,"message":"139","line":2,"column":32,"nodeType":"140","messageId":"141","endLine":2,"endColumn":38},{"ruleId":"138","severity":1,"message":"142","line":2,"column":40,"nodeType":"140","messageId":"141","endLine":2,"endColumn":44},{"ruleId":"138","severity":1,"message":"143","line":10,"column":8,"nodeType":"140","messageId":"141","endLine":10,"endColumn":12},{"ruleId":"138","severity":1,"message":"144","line":15,"column":10,"nodeType":"140","messageId":"141","endLine":15,"endColumn":23},{"ruleId":"138","severity":1,"message":"145","line":15,"column":25,"nodeType":"140","messageId":"141","endLine":15,"endColumn":30},{"ruleId":"138","severity":1,"message":"139","line":15,"column":32,"nodeType":"140","messageId":"141","endLine":15,"endColumn":38},{"ruleId":"138","severity":1,"message":"146","line":15,"column":46,"nodeType":"140","messageId":"141","endLine":15,"endColumn":52},{"ruleId":"147","severity":1,"message":"148","line":30,"column":17,"nodeType":"149","endLine":30,"endColumn":32},{"ruleId":"147","severity":1,"message":"148","line":31,"column":17,"nodeType":"149","endLine":31,"endColumn":32},{"ruleId":"147","severity":1,"message":"148","line":32,"column":17,"nodeType":"149","endLine":32,"endColumn":32},{"ruleId":"147","severity":1,"message":"148","line":43,"column":17,"nodeType":"149","endLine":43,"endColumn":49},{"ruleId":"150","severity":1,"message":"151","line":67,"column":17,"nodeType":"149","endLine":67,"endColumn":91},{"ruleId":"150","severity":1,"message":"151","line":96,"column":17,"nodeType":"149","endLine":96,"endColumn":94},{"ruleId":"150","severity":1,"message":"151","line":108,"column":17,"nodeType":"149","endLine":108,"endColumn":86},{"ruleId":"150","severity":1,"message":"151","line":112,"column":29,"nodeType":"149","endLine":112,"endColumn":108},{"ruleId":"150","severity":1,"message":"151","line":117,"column":29,"nodeType":"149","endLine":117,"endColumn":92},{"ruleId":"150","severity":1,"message":"151","line":122,"column":29,"nodeType":"149","endLine":122,"endColumn":106},{"ruleId":"150","severity":1,"message":"151","line":127,"column":29,"nodeType":"149","endLine":127,"endColumn":92},{"ruleId":"150","severity":1,"message":"151","line":132,"column":29,"nodeType":"149","endLine":132,"endColumn":98},{"ruleId":"150","severity":1,"message":"151","line":137,"column":29,"nodeType":"149","endLine":137,"endColumn":92},{"ruleId":"150","severity":1,"message":"151","line":143,"column":29,"nodeType":"149","endLine":143,"endColumn":100},{"ruleId":"150","severity":1,"message":"151","line":148,"column":29,"nodeType":"149","endLine":148,"endColumn":92},{"ruleId":"152","severity":1,"message":"153","line":164,"column":9,"nodeType":"149","endLine":164,"endColumn":108},{"ruleId":"150","severity":1,"message":"151","line":185,"column":21,"nodeType":"149","endLine":185,"endColumn":91},{"ruleId":"150","severity":1,"message":"151","line":190,"column":21,"nodeType":"149","endLine":190,"endColumn":93},{"ruleId":"150","severity":1,"message":"151","line":194,"column":21,"nodeType":"149","endLine":194,"endColumn":106},{"ruleId":"150","severity":1,"message":"151","line":204,"column":17,"nodeType":"149","endLine":204,"endColumn":91},{"ruleId":"150","severity":1,"message":"151","line":332,"column":17,"nodeType":"149","endLine":332,"endColumn":96},{"ruleId":"138","severity":1,"message":"154","line":2,"column":8,"nodeType":"140","messageId":"141","endLine":2,"endColumn":13},{"ruleId":"138","severity":1,"message":"144","line":3,"column":10,"nodeType":"140","messageId":"141","endLine":3,"endColumn":23},{"ruleId":"138","severity":1,"message":"145","line":3,"column":25,"nodeType":"140","messageId":"141","endLine":3,"endColumn":30},{"ruleId":"138","severity":1,"message":"139","line":3,"column":32,"nodeType":"140","messageId":"141","endLine":3,"endColumn":38},{"ruleId":"138","severity":1,"message":"146","line":3,"column":46,"nodeType":"140","messageId":"141","endLine":3,"endColumn":52},{"ruleId":"138","severity":1,"message":"154","line":2,"column":8,"nodeType":"140","messageId":"141","endLine":2,"endColumn":13},{"ruleId":"138","severity":1,"message":"144","line":3,"column":10,"nodeType":"140","messageId":"141","endLine":3,"endColumn":23},{"ruleId":"138","severity":1,"message":"145","line":3,"column":25,"nodeType":"140","messageId":"141","endLine":3,"endColumn":30},{"ruleId":"138","severity":1,"message":"139","line":3,"column":32,"nodeType":"140","messageId":"141","endLine":3,"endColumn":38},{"ruleId":"138","severity":1,"message":"146","line":3,"column":46,"nodeType":"140","messageId":"141","endLine":3,"endColumn":52},{"ruleId":"138","severity":1,"message":"144","line":2,"column":10,"nodeType":"140","messageId":"141","endLine":2,"endColumn":23},{"ruleId":"138","severity":1,"message":"145","line":2,"column":25,"nodeType":"140","messageId":"141","endLine":2,"endColumn":30},{"ruleId":"138","severity":1,"message":"139","line":2,"column":32,"nodeType":"140","messageId":"141","endLine":2,"endColumn":38},{"ruleId":"138","severity":1,"message":"146","line":2,"column":46,"nodeType":"140","messageId":"141","endLine":2,"endColumn":52},{"ruleId":"138","severity":1,"message":"143","line":4,"column":8,"nodeType":"140","messageId":"141","endLine":4,"endColumn":12},{"ruleId":"138","severity":1,"message":"155","line":5,"column":10,"nodeType":"140","messageId":"141","endLine":5,"endColumn":20},{"ruleId":"138","severity":1,"message":"156","line":7,"column":8,"nodeType":"140","messageId":"141","endLine":7,"endColumn":22},{"ruleId":"138","severity":1,"message":"142","line":2,"column":10,"nodeType":"140","messageId":"141","endLine":2,"endColumn":14},{"ruleId":"138","severity":1,"message":"155","line":4,"column":10,"nodeType":"140","messageId":"141","endLine":4,"endColumn":20},{"ruleId":"157","severity":1,"message":"158","line":81,"column":7,"nodeType":"159","messageId":"160","endLine":102,"endColumn":8},{"ruleId":"161","severity":1,"message":"162","line":94,"column":20,"nodeType":"163","messageId":"160","endLine":94,"endColumn":22},{"ruleId":"161","severity":1,"message":"162","line":104,"column":31,"nodeType":"163","messageId":"160","endLine":104,"endColumn":33},{"ruleId":"138","severity":1,"message":"164","line":122,"column":13,"nodeType":"140","messageId":"141","endLine":122,"endColumn":18},{"ruleId":"138","severity":1,"message":"165","line":123,"column":13,"nodeType":"140","messageId":"141","endLine":123,"endColumn":17},{"ruleId":"161","severity":1,"message":"166","line":138,"column":36,"nodeType":"163","messageId":"160","endLine":138,"endColumn":38},{"ruleId":"161","severity":1,"message":"166","line":173,"column":36,"nodeType":"163","messageId":"160","endLine":173,"endColumn":38},{"ruleId":"150","severity":1,"message":"151","line":41,"column":25,"nodeType":"149","endLine":41,"endColumn":86},{"ruleId":"138","severity":1,"message":"142","line":4,"column":10,"nodeType":"140","messageId":"141","endLine":4,"endColumn":14},{"ruleId":"138","severity":1,"message":"167","line":83,"column":14,"nodeType":"140","messageId":"141","endLine":83,"endColumn":21},{"ruleId":"138","severity":1,"message":"142","line":2,"column":10,"nodeType":"140","messageId":"141","endLine":2,"endColumn":14},{"ruleId":"138","severity":1,"message":"168","line":27,"column":13,"nodeType":"140","messageId":"141","endLine":27,"endColumn":17},{"ruleId":"161","severity":1,"message":"162","line":32,"column":26,"nodeType":"163","messageId":"160","endLine":32,"endColumn":28},"no-native-reassign",["169"],"no-negated-in-lhs",["170"],"no-unused-vars","'Router' is defined but never used.","Identifier","unusedVar","'Link' is defined but never used.","'Chat' is defined but never used.","'BrowserRouter' is defined but never used.","'Route' is defined but never used.","'Switch' is defined but never used.","jsx-a11y/anchor-is-valid","The href attribute is required for an anchor to be keyboard accessible. Provide a valid, navigable address as the href value. If you cannot provide an href, but still need the element to resemble a link, use a button and change it with appropriate styles. Learn more: https://github.com/evcohen/eslint-plugin-jsx-a11y/blob/master/docs/rules/anchor-is-valid.md","JSXOpeningElement","jsx-a11y/img-redundant-alt","Redundant alt attribute. Screen-readers already announce `img` tags as an image. You don’t need to use the words `image`, `photo,` or `picture` (or any specified custom words) in the alt prop.","jsx-a11y/iframe-has-title","\r\n \r\n
    \r\n
    \r\n

    Pour suivre le projet

    \r\n Star\r\n
    \r\n
    \r\n\r\n\r\n\r\n
    \r\n \r\n \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n

    Projet supervisé par ....

    \r\n \"image\r\n
    \r\n
    \r\n
    \r\n
    \r\n \"image\r\n CV Lucas\r\n
    \r\n
    \r\n \"image\r\n CV Matthieu\r\n
    \r\n
    \r\n
    \r\n
    \r\n\r\n
    \r\n
    \r\n
    \r\n \"image\r\n
    \r\n

    Nom : L'Homme

    \r\n

    Prénom : Lucas

    \r\n

    Âge : 16 ans

    \r\n

    Numéro de Téléphone : 06.07.45.98.22

    \r\n

    Adresse e-mail : lucas.lhomme@gmail.com

    \r\n
    \r\n
    \r\n
    \r\n

    Parcours scolaire

    \r\n
    \r\n
  • \r\n 2016-2017 jusqu'à 2018/2019, collège du klosterwald Villé\r\n
  • \r\n
      \r\n
    • \r\n Brevet des collèges : Mention Très bien\r\n
    • \r\n
    \r\n
  • \r\n 2019/2020 jusqu'à 2020/2021, lycée Polyvalent Jean-Baptiste Schwilgué\r\n
      \r\n
    • Enseignement de spécialité :
    • \r\n
        \r\n
      • Maths
      • \r\n
      • Physique
      • \r\n
      • Numérique et Science de l'Informatique
      • \r\n
      \r\n
    \r\n
  • \r\n
    \r\n

    Profil

    \r\n

    \r\n Je suis actuellement au Schwilgué, en première général, étant interessé par les nouvelles technologies, mon choix a donc été influencé. De cette façon j'ai pris les enseignements de spécialités suivants: Maths, Physique, NSI. C'est pour cela que je souhaite\r\n m'orienter vers un métier centré sur cette thématique.Durant mon temps libre je m'investis dans divers projets numériques. De plus je sais utiliser divers outils de bureautique tels, que la suite microsoft ou les logiciels de montage photo/vidéo.\r\n

    \r\n

    Compétences

    \r\n
    \r\n
    \r\n

    Coding

    \r\n 65% \r\n
    \r\n
    \r\n

    Photo montage

    \r\n 50% \r\n
    \r\n
    \r\n

    Créativité

    \r\n 50% \r\n
    \r\n
    \r\n

    Loisirs

    \r\n
    \r\n
  • Sport:
  • \r\n
      \r\n
    • Ski
    • \r\n
    • Snowboard
    • \r\n
    • Vélo
    • \r\n
    \r\n
  • Autre :
  • \r\n
      \r\n
    • pilotage de drone
    • \r\n
    • programmation
    • \r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n\r\n
    \r\n
    \r\n
    \r\n

    Parcours scolaire

    \r\n
    \r\n
  • \r\n 2016/2017 jusqu'à 2018/2019, collège du Bernstein Dambach-la-ville\r\n
  • \r\n
      \r\n
    • \r\n Brevet des collèges : Mention bien\r\n
    • \r\n
    \r\n
  • \r\n 2019/2020 jusqu'à 2020/2021, lycée Polyvalent Jean-Baptiste Schwilgué\r\n
      \r\n
    • Enseignement de spécialité :
    • \r\n
        \r\n
      • Maths
      • \r\n
      • Physique
      • \r\n
      • Numérique et Science de l'Informatique
      • \r\n
      \r\n
    \r\n
  • \r\n
    \r\n

    Profil

    \r\n

    Je suis actuellement en premiere générale au lycée Schwilgué de Sélestat .Ayant un profil scientifique, j'ai choisi les spécialités suivantes: Maths Physique et Nsi. Je voudrais m'orienter vers un métier dans le domaine de l'informatique.\r\n

    \r\n

    Compétences

    \r\n
    \r\n
    \r\n

    Coding

    \r\n 35% \r\n
    \r\n
    \r\n

    video montage

    \r\n 40% \r\n
    \r\n
    \r\n

    Créativité

    \r\n 60% \r\n
    \r\n
    \r\n

    Loisirs

    \r\n
    \r\n
  • Sport:
  • \r\n
      \r\n
    • Football
    • \r\n
    • Vélo
    • \r\n
    \r\n
  • Autre :
  • \r\n
      \r\n
    • Jeux video
    • \r\n
    • Pilotage de drone
    • \r\n
    \r\n
    \r\n
    \r\n
    \r\n \"image\r\n
    \r\n

    Nom : Diebolt

    \r\n

    Prénom : Matthieu

    \r\n

    Âge : 16 ans

    \r\n

    Numéro de téléphone : 06.47.55.58.32

    \r\n

    Adresse e-mail : matthieu.diebolt@gmail.com

    \r\n
    \r\n
    \r\n
    \r\n
    \r\n\r\n \r\n \r\n );\r\n}\r\n\r\n\r\nconst styles = {\r\n \"list-style-type\":\"none\"\r\n }\r\n \r\nexport default Home;\r\n\r\n","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\signup.jsx",["101","102","103","104","105"],"import React, { Component } from 'react';\r\nimport axios from 'axios';\r\nimport { BrowserRouter, Route, Router, Link, Switch } from \"react-router-dom\"\r\nimport './style/singup.css';\r\n\r\nexport default class signup extends Component {\r\n // création des states suivant\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n email : '',\r\n mdp: '',\r\n pseudo:'',\r\n message:''\r\n };\r\n }\r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n // quand bouton submit pressé, envoyé une requête POST au serveur pour insérer le nouvel utilisateur dans la base de donnée\r\n onSubmit = (event) => {\r\n event.preventDefault();\r\n console.log(\"state signup : \",this.state);\r\n\r\n fetch('http://localhost:4000/authentification/signup', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include',\r\n body: JSON.stringify({\r\n pseudo:this.state.pseudo,\r\n email:this.state.email,\r\n mdp:this.state.mdp\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n }\r\n })\r\n .then((value) => {\r\n if (value.status === 200) {\r\n // s'il y a eu aucune erreur redirigé à l'acceuil\r\n this.props.history.push('/app/friendlist');\r\n console.log(\"info envoyé\");\r\n } else {\r\n // s'il y a eu une erreur, renvoyer le message suivant\r\n this.setState({message:'Pseudo ou email déjà utilisé'});\r\n }\r\n })\r\n\r\n }\r\n \r\n render() {\r\n return (\r\n
    \r\n
    \r\n
    \r\n
    \r\n

    Create Account

    \r\n \r\n

    \r\n \r\n

    \r\n \r\n

    \r\n \r\n
    \r\n

    {this.state.message}

    \r\n
    \r\n
    \r\n

    Welcome back

    \r\n

    Si tu as déjà un compte, il te suffit de te connecter !

    \r\n SIGN IN\r\n
    \r\n
    \r\n
    \r\n );\r\n\r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\login.jsx",["106","107","108","109","110"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\friends-liste.jsx",["111","112","113","114","115","116","117"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\statistique.jsx",["118"],"import React, { Component } from 'react';\r\nimport { Link } from 'react-router-dom';\r\nimport Barregauche from '../barre-gauche.jsx';\r\nimport rockets from '../image/rockets.png'\r\n\r\nexport default class StatWithFriend extends Component {\r\n\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n statistique_amis: [{}], \r\n amislist: [{}],\r\n FirstFriend:\"\"\r\n };\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/statByUser', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => { \r\n this.setState({statistique_amis:response})\r\n console.log(\"statistique : \",this.state.statistique_amis)\r\n })\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n console.log(response)\r\n this.setState({amislist:response.data})\r\n this.setState({FirstFriend:response.firstFriend})\r\n })\r\n }\r\n\r\n\r\n\r\n render(){\r\n const {statistique_amis} = this.state\r\n return(\r\n
    \r\n \r\n
    \r\n
    \r\n

    Nombre de message échanger : Ichat rockets \"amis\"/

    \r\n
    \r\n
    \r\n {statistique_amis.map((amis)=>(\r\n
    \r\n

    {amis.friend_name} : {amis.nbr_message} \"amis\"/

    \r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\chat.jsx",["119","120","121","122","123","124","125","126"],"import React, { Component } from 'react';\r\n\r\nimport { io } from \"socket.io-client\"; \r\nimport { withRouter } from \"react-router-dom\";\r\nimport FriendNom from './friend_nom'\r\n\r\n\r\n\r\nconst socket = io('http://localhost:4000');\r\nexport default class Chat extends Component {\r\n // création du state \"message\"\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n message : '',\r\n friendid:'',\r\n groupetext:[{_id:0, text:\"\", author:\"\"}],\r\n room:'',\r\n user_nom:'',\r\n change:false\r\n };\r\n }\r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n componentDidMount(){\r\n this.setState({friendid:this.props.valeur})\r\n this.setState({user_nom:this.props.nom})\r\n fetch('http://localhost:4000/app/getgroupechatlist', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n friendID: this.props.valeur\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({groupetext:response[0].message})\r\n //console.log(response[0].message)\r\n this.setState({room:response[0]._id})\r\n //console.log(this.state.room)\r\n socket.emit('joinRoom', this.state.room)\r\n })\r\n }\r\n\r\n componentDidUpdate(){\r\n if(this.state.friendid !== this.props.valeur){\r\n this.setState({friendid:this.props.valeur})\r\n fetch('http://localhost:4000/app/getgroupechatlist', {\r\n method: 'POST',\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n friendID: this.props.valeur\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({groupetext:response[0].message})\r\n //console.log(response[0].message)\r\n this.setState({room:response[0]._id})\r\n //console.log(this.state.room) \r\n socket.emit('leave')\r\n socket.emit('joinRoom', this.state.room)\r\n })\r\n }\r\n }\r\n\r\n componentDidMount(){\r\n socket.on('message', message =>{\r\n console.log(message)\r\n let {groupetext} = this.state\r\n groupetext.push(message)\r\n //console.log(groupetext)\r\n this.setState({change:true})\r\n console.log(groupetext)\r\n })\r\n socket.on('messageDelete',value =>{\r\n console.log('le message suprimé : ',value)\r\n let {groupetext} = this.state\r\n const index = groupetext.findIndex(mess => mess._id === value)\r\n if(index != -1){\r\n groupetext.splice(index,1)\r\n this.setState({change:true})\r\n }\r\n })\r\n socket.on('info', message =>{\r\n console.log(message)\r\n })\r\n }\r\n onSubmit = () => {\r\n if(this.state.message != ''){\r\n socket.emit(\"sendmessage\", {\r\n message:this.state.message,\r\n author:this.props.nom,\r\n room:this.state.room\r\n })\r\n this.setState({message:''})\r\n }\r\n }\r\n deleteMessage = (event) =>{\r\n const { value } = event.target;\r\n socket.emit('getMessageToDelete',{\r\n value: value,\r\n room: this.state.room\r\n })\r\n\r\n }\r\n render() {\r\n const BLOCK = {diplay: 'block'}\r\n const NONE= {diplay: 'none'}\r\n if(this.state.change === true){\r\n this.setState({change:false})\r\n return(\r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n {this.state.groupetext.map((mess)=>(\r\n
    \r\n

    {mess.author}

    \r\n

    {mess.text}

    \r\n { this.props.nom == mess.author ? : console.log('')}\r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n )\r\n } else{\r\n return (\r\n
    \r\n
    \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n {this.state.groupetext.map((mess)=>(\r\n
    \r\n

    {mess.author}

    \r\n

    {mess.text}

    \r\n { this.props.nom == mess.author ? : console.log('')}\r\n
    \r\n ))}\r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n \r\n \r\n
    \r\n
    \r\n
    \r\n
    \r\n
    \r\n ); \r\n }\r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-gauche.jsx",["127"]," import React, { Component } from 'react';\r\nimport { Link } from 'react-router-dom';\r\nimport './style/barre-gauche.css';\r\nimport profil from './image/img-profil.jpg'\r\nimport envelope from './image/envelope.png'\r\nimport users from './image/user.png'\r\nimport rouage from './image/settings.png'\r\nimport logout from './image/logout.png'\r\nimport rockets from './image/rockets.png'\r\n\r\n\r\nexport default class barregauche extends Component {\r\n\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n firstFriend:\"\"\r\n };\r\n }\r\n\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({firstFriend:response.firstFriend})\r\n })\r\n }\r\n render(){\r\n return(\r\n
    \r\n
    \r\n
    \r\n \"photo\r\n
    \r\n
    \r\n \r\n \"message\"/\r\n \r\n \r\n \"amis\"/\r\n \r\n \r\n \"amis\"/\r\n \r\n \r\n \"paramétres\"/\r\n \r\n
    \r\n
    \r\n \"déconextion\"/\r\n
    \r\n
    \r\n
    \r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\withAuth.jsx",[],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\application2.jsx",["128","129"],"import React, { Component } from 'react';\r\n\r\nimport Chat from './components/chat';\r\nimport { Link } from 'react-router-dom';\r\nimport './style/app.css';\r\nimport Barregauche from './barre-gauche.jsx';\r\nimport Barreamisgauche from './barre-amis-gauche';\r\n\r\n\r\nexport default class Application2 extends Component {\r\n \r\n \r\n // création du State \"friend\"\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n friend : '',\r\n message : '',\r\n amislist: [{_id:0, _pseudo:\"\"}],\r\n firstFriend:\"\",\r\n user_nom : ''\r\n };\r\n }\r\n \r\n // ajout des changement lorsque le texte de l'input change\r\n handleInputChange = (event) => {\r\n const { value, name } = event.target;\r\n this.setState({\r\n [name]: value\r\n });\r\n }\r\n\r\n // fonction permettant de faire une requête POST au serveur et d'envoyer les données\r\n onSubmit = (event) => {\r\n event.preventDefault();\r\n console.log(\"state envois demande amis : \",this.state)\r\n // requête POST\r\n fetch('http://localhost:4000/app/newfriend', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n new_friend: this.state.friend\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json'\r\n }\r\n })\r\n // renvois message de réussite ou non\r\n .then(res => {\r\n if (res.status === 200) {\r\n this.setState({message: \"\"})\r\n } else if(res.status === 400){\r\n this.setState({message : \"l'utilisateur rechercher n'existe pas\"})\r\n }\r\n else{\r\n console.log(\"erreur\")\r\n }\r\n })\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/friendlist', {\r\n method: 'GET',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include',\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n //console.log(response)\r\n this.setState({amislist:response.friends})\r\n this.setState({user_nom:response.pseudo})\r\n this.setState({firstFriend:response.firstFriend})\r\n //let test = this.state.amislist\r\n\r\n })\r\n }\r\n\r\n render() {\r\n const {message} = this.state\r\n const { id } = this.props.match.params;\r\n return (\r\n
    \r\n
    \r\n \r\n \r\n
    \r\n \r\n
    \r\n ); \r\n }\r\n }","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\paramètre.jsx",["130","131"],"D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\components\\friend_nom.jsx",["132"],"import React, { Component } from 'react';\r\n\r\n\r\nexport default class friend_nom extends Component {\r\n constructor(props) {\r\n super(props)\r\n this.state = {\r\n nom:'',\r\n id:''\r\n };\r\n }\r\n componentDidMount(){\r\n fetch('http://localhost:4000/app/getFriendName', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n name: this.props.id\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({nom:response})\r\n this.setState({id:this.props.id})\r\n })\r\n }\r\n componentDidUpdate(){\r\n if(this.state.id != this.props.id){\r\n fetch('http://localhost:4000/app/getFriendName', {\r\n method: 'POST',\r\n // credentials : include permet d'intégrer les cookie avec la requête\r\n credentials: 'include', \r\n body: JSON.stringify({\r\n name: this.props.id\r\n }),\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n 'Accept': 'application/json'\r\n }\r\n })\r\n .then(response => response.json())\r\n .then(response => {\r\n this.setState({nom:response})\r\n this.setState({id:this.props.id})\r\n })\r\n }\r\n }\r\n render(){\r\n return(\r\n

    \r\n {this.state.nom}\r\n

    \r\n\r\n );\r\n }\r\n}","D:\\Donnees\\Lucas\\Documents\\Ecole\\1er\\NSI\\myapp\\src\\barre-amis-gauche.jsx",[],{"ruleId":"133","replacedBy":"134"},{"ruleId":"135","replacedBy":"136"},{"ruleId":"137","severity":1,"message":"138","line":2,"column":32,"nodeType":"139","messageId":"140","endLine":2,"endColumn":38},{"ruleId":"137","severity":1,"message":"141","line":2,"column":40,"nodeType":"139","messageId":"140","endLine":2,"endColumn":44},{"ruleId":"137","severity":1,"message":"142","line":10,"column":8,"nodeType":"139","messageId":"140","endLine":10,"endColumn":12},{"ruleId":"137","severity":1,"message":"143","line":15,"column":10,"nodeType":"139","messageId":"140","endLine":15,"endColumn":23},{"ruleId":"137","severity":1,"message":"144","line":15,"column":25,"nodeType":"139","messageId":"140","endLine":15,"endColumn":30},{"ruleId":"137","severity":1,"message":"138","line":15,"column":32,"nodeType":"139","messageId":"140","endLine":15,"endColumn":38},{"ruleId":"137","severity":1,"message":"145","line":15,"column":46,"nodeType":"139","messageId":"140","endLine":15,"endColumn":52},{"ruleId":"146","severity":1,"message":"147","line":30,"column":17,"nodeType":"148","endLine":30,"endColumn":32},{"ruleId":"146","severity":1,"message":"147","line":31,"column":17,"nodeType":"148","endLine":31,"endColumn":32},{"ruleId":"146","severity":1,"message":"147","line":32,"column":17,"nodeType":"148","endLine":32,"endColumn":32},{"ruleId":"146","severity":1,"message":"147","line":43,"column":17,"nodeType":"148","endLine":43,"endColumn":49},{"ruleId":"149","severity":1,"message":"150","line":67,"column":17,"nodeType":"148","endLine":67,"endColumn":91},{"ruleId":"149","severity":1,"message":"150","line":96,"column":17,"nodeType":"148","endLine":96,"endColumn":94},{"ruleId":"149","severity":1,"message":"150","line":108,"column":17,"nodeType":"148","endLine":108,"endColumn":86},{"ruleId":"149","severity":1,"message":"150","line":112,"column":29,"nodeType":"148","endLine":112,"endColumn":108},{"ruleId":"149","severity":1,"message":"150","line":117,"column":29,"nodeType":"148","endLine":117,"endColumn":92},{"ruleId":"149","severity":1,"message":"150","line":122,"column":29,"nodeType":"148","endLine":122,"endColumn":106},{"ruleId":"149","severity":1,"message":"150","line":127,"column":29,"nodeType":"148","endLine":127,"endColumn":92},{"ruleId":"149","severity":1,"message":"150","line":132,"column":29,"nodeType":"148","endLine":132,"endColumn":98},{"ruleId":"149","severity":1,"message":"150","line":137,"column":29,"nodeType":"148","endLine":137,"endColumn":92},{"ruleId":"149","severity":1,"message":"150","line":143,"column":29,"nodeType":"148","endLine":143,"endColumn":100},{"ruleId":"149","severity":1,"message":"150","line":148,"column":29,"nodeType":"148","endLine":148,"endColumn":92},{"ruleId":"151","severity":1,"message":"152","line":164,"column":9,"nodeType":"148","endLine":164,"endColumn":108},{"ruleId":"149","severity":1,"message":"150","line":185,"column":21,"nodeType":"148","endLine":185,"endColumn":91},{"ruleId":"149","severity":1,"message":"150","line":190,"column":21,"nodeType":"148","endLine":190,"endColumn":93},{"ruleId":"149","severity":1,"message":"150","line":194,"column":21,"nodeType":"148","endLine":194,"endColumn":106},{"ruleId":"149","severity":1,"message":"150","line":204,"column":17,"nodeType":"148","endLine":204,"endColumn":91},{"ruleId":"149","severity":1,"message":"150","line":332,"column":17,"nodeType":"148","endLine":332,"endColumn":96},{"ruleId":"137","severity":1,"message":"153","line":2,"column":8,"nodeType":"139","messageId":"140","endLine":2,"endColumn":13},{"ruleId":"137","severity":1,"message":"143","line":3,"column":10,"nodeType":"139","messageId":"140","endLine":3,"endColumn":23},{"ruleId":"137","severity":1,"message":"144","line":3,"column":25,"nodeType":"139","messageId":"140","endLine":3,"endColumn":30},{"ruleId":"137","severity":1,"message":"138","line":3,"column":32,"nodeType":"139","messageId":"140","endLine":3,"endColumn":38},{"ruleId":"137","severity":1,"message":"145","line":3,"column":46,"nodeType":"139","messageId":"140","endLine":3,"endColumn":52},{"ruleId":"137","severity":1,"message":"153","line":2,"column":8,"nodeType":"139","messageId":"140","endLine":2,"endColumn":13},{"ruleId":"137","severity":1,"message":"143","line":3,"column":10,"nodeType":"139","messageId":"140","endLine":3,"endColumn":23},{"ruleId":"137","severity":1,"message":"144","line":3,"column":25,"nodeType":"139","messageId":"140","endLine":3,"endColumn":30},{"ruleId":"137","severity":1,"message":"138","line":3,"column":32,"nodeType":"139","messageId":"140","endLine":3,"endColumn":38},{"ruleId":"137","severity":1,"message":"145","line":3,"column":46,"nodeType":"139","messageId":"140","endLine":3,"endColumn":52},{"ruleId":"137","severity":1,"message":"143","line":2,"column":10,"nodeType":"139","messageId":"140","endLine":2,"endColumn":23},{"ruleId":"137","severity":1,"message":"144","line":2,"column":25,"nodeType":"139","messageId":"140","endLine":2,"endColumn":30},{"ruleId":"137","severity":1,"message":"138","line":2,"column":32,"nodeType":"139","messageId":"140","endLine":2,"endColumn":38},{"ruleId":"137","severity":1,"message":"145","line":2,"column":46,"nodeType":"139","messageId":"140","endLine":2,"endColumn":52},{"ruleId":"137","severity":1,"message":"142","line":4,"column":8,"nodeType":"139","messageId":"140","endLine":4,"endColumn":12},{"ruleId":"137","severity":1,"message":"154","line":5,"column":10,"nodeType":"139","messageId":"140","endLine":5,"endColumn":20},{"ruleId":"137","severity":1,"message":"155","line":7,"column":8,"nodeType":"139","messageId":"140","endLine":7,"endColumn":22},{"ruleId":"137","severity":1,"message":"141","line":2,"column":10,"nodeType":"139","messageId":"140","endLine":2,"endColumn":14},{"ruleId":"137","severity":1,"message":"154","line":4,"column":10,"nodeType":"139","messageId":"140","endLine":4,"endColumn":20},{"ruleId":"156","severity":1,"message":"157","line":81,"column":7,"nodeType":"158","messageId":"159","endLine":102,"endColumn":8},{"ruleId":"160","severity":1,"message":"161","line":94,"column":20,"nodeType":"162","messageId":"159","endLine":94,"endColumn":22},{"ruleId":"160","severity":1,"message":"161","line":104,"column":31,"nodeType":"162","messageId":"159","endLine":104,"endColumn":33},{"ruleId":"137","severity":1,"message":"163","line":122,"column":13,"nodeType":"139","messageId":"140","endLine":122,"endColumn":18},{"ruleId":"137","severity":1,"message":"164","line":123,"column":13,"nodeType":"139","messageId":"140","endLine":123,"endColumn":17},{"ruleId":"160","severity":1,"message":"165","line":138,"column":36,"nodeType":"162","messageId":"159","endLine":138,"endColumn":38},{"ruleId":"160","severity":1,"message":"165","line":173,"column":36,"nodeType":"162","messageId":"159","endLine":173,"endColumn":38},{"ruleId":"149","severity":1,"message":"150","line":41,"column":25,"nodeType":"148","endLine":41,"endColumn":86},{"ruleId":"137","severity":1,"message":"141","line":4,"column":10,"nodeType":"139","messageId":"140","endLine":4,"endColumn":14},{"ruleId":"137","severity":1,"message":"166","line":83,"column":14,"nodeType":"139","messageId":"140","endLine":83,"endColumn":21},{"ruleId":"137","severity":1,"message":"141","line":2,"column":10,"nodeType":"139","messageId":"140","endLine":2,"endColumn":14},{"ruleId":"137","severity":1,"message":"167","line":27,"column":13,"nodeType":"139","messageId":"140","endLine":27,"endColumn":17},{"ruleId":"160","severity":1,"message":"161","line":32,"column":26,"nodeType":"162","messageId":"159","endLine":32,"endColumn":28},"no-native-reassign",["168"],"no-negated-in-lhs",["169"],"no-unused-vars","'Router' is defined but never used.","Identifier","unusedVar","'Link' is defined but never used.","'Chat' is defined but never used.","'BrowserRouter' is defined but never used.","'Route' is defined but never used.","'Switch' is defined but never used.","jsx-a11y/anchor-is-valid","The href attribute is required for an anchor to be keyboard accessible. Provide a valid, navigable address as the href value. If you cannot provide an href, but still need the element to resemble a link, use a button and change it with appropriate styles. Learn more: https://github.com/evcohen/eslint-plugin-jsx-a11y/blob/master/docs/rules/anchor-is-valid.md","JSXOpeningElement","jsx-a11y/img-redundant-alt","Redundant alt attribute. Screen-readers already announce `img` tags as an image. You don’t need to use the words `image`, `photo,` or `picture` (or any specified custom words) in the alt prop.","jsx-a11y/iframe-has-title","