5898bc6d5a
new file: easySite/easy-site/README.md new file: easySite/easy-site/package-lock.json new file: easySite/easy-site/package.json new file: easySite/easy-site/public/favicon.ico new file: easySite/easy-site/public/index.html new file: easySite/easy-site/public/logo192.png new file: easySite/easy-site/public/logo512.png new file: easySite/easy-site/public/manifest.json new file: easySite/easy-site/public/robots.txt new file: easySite/easy-site/src/App.css new file: easySite/easy-site/src/App.js new file: easySite/easy-site/src/App.test.js new file: easySite/easy-site/src/contexts/AuthContext.js new file: easySite/easy-site/src/contexts/useAuth.js new file: easySite/easy-site/src/index.css new file: easySite/easy-site/src/index.js new file: easySite/easy-site/src/logo.svg new file: easySite/easy-site/src/pages/AddObject.js new file: easySite/easy-site/src/pages/Dashboard.js new file: easySite/easy-site/src/pages/EditObject.js new file: easySite/easy-site/src/pages/Home.js new file: easySite/easy-site/src/pages/Login.js new file: easySite/easy-site/src/pages/Register.js new file: easySite/easy-site/src/reportWebVitals.js new file: easySite/easy-site/src/setupTests.js new file: package-lock.json new file: package.json modified: valitovgaziz/html/saveContactsButtonStyle.css Add the easy_site site on react
28 lines
974 B
JavaScript
28 lines
974 B
JavaScript
// src/pages/Login.js
|
|
import React, { useState } from 'react';
|
|
import { Link } from 'react-router-dom';
|
|
import useAuth from '../contexts/useAuth';
|
|
|
|
const Login = () => {
|
|
const auth = useAuth();
|
|
const [formData, setFormData] = useState({ email: '', password: '' });
|
|
|
|
const handleSubmit = async e => {
|
|
e.preventDefault();
|
|
await auth.login(formData.email, formData.password);
|
|
};
|
|
|
|
return (
|
|
<div className="container">
|
|
<h2>Вход</h2>
|
|
<form onSubmit={handleSubmit}>
|
|
<input type="email" placeholder="Email" required onChange={(e) => setFormData({...formData, email: e.target.value})} />
|
|
<input type="password" placeholder="Пароль" required onChange={(e) => setFormData({...formData, password: e.target.value})} />
|
|
<button type="submit">Войти</button>
|
|
<p>Нет аккаунта? <Link to="/register">Зарегистрируйтесь</Link></p>
|
|
</form>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Login; |