|
@@ -1,240 +1,22 @@
|
|
|
import React, { useState } from "react";
|
|
|
import { EyeOutlined, EyeInvisibleOutlined } from "@ant-design/icons";
|
|
|
-// import { createStore } from "redux";
|
|
|
-// import { Provider, connect } from "react-redux";
|
|
|
-// import jwtDecode from "jwt-decode";
|
|
|
-import "./signUp.css";
|
|
|
-// import {actionLogin} from "../sign-in/sign-in";
|
|
|
-
|
|
|
-import { createStore, combineReducers, applyMiddleware } from "redux";
|
|
|
import { Provider, connect } from "react-redux";
|
|
|
-import thunk from "redux-thunk";
|
|
|
-
|
|
|
-// const getGQL = (url) => () => {
|
|
|
-// const email = document.getElementById("email").value;
|
|
|
-// const password = document.getElementById("password").value;
|
|
|
-// const nickname = document.getElementById("nickname").value;
|
|
|
-
|
|
|
-// fetch(url, {
|
|
|
-// method: "POST",
|
|
|
-// headers: {
|
|
|
-// Accept: "application/json",
|
|
|
-// "Content-Type": "application/json",
|
|
|
-// },
|
|
|
-// body: JSON.stringify({
|
|
|
-// email: email,
|
|
|
-// password: password,
|
|
|
-// nickname: nickname,
|
|
|
-// }),
|
|
|
-// })
|
|
|
-// .then((res) => res.json())
|
|
|
-// .then((data) => {
|
|
|
-// console.log("ok");
|
|
|
-// console.log(data);
|
|
|
-// });
|
|
|
-// };
|
|
|
-
|
|
|
-// function actionLogin(login, password) {
|
|
|
-// getGQL("http://localhost:3333/users");
|
|
|
-// }
|
|
|
-
|
|
|
-// const store = createStore((state, { type, token }) => {
|
|
|
-// if (!state) return {};
|
|
|
-// if (type === "LOGIN") return { pending: true, jwt: {} };
|
|
|
-// if (type === "LOGOUT") return { jwt: {}, data: {} };
|
|
|
-// if (type === "TOKEN") return { jwt: token, data: jwtDecode(token) };
|
|
|
-// return state;
|
|
|
-// });
|
|
|
-
|
|
|
-const promiseReducer = (state = {}, { type, name, status, payload, error }) => {
|
|
|
- if (type === "PROMISE") {
|
|
|
- return {
|
|
|
- ...state,
|
|
|
- [name]: {
|
|
|
- status,
|
|
|
- payload,
|
|
|
- error,
|
|
|
- },
|
|
|
- };
|
|
|
- }
|
|
|
- return state;
|
|
|
-};
|
|
|
-
|
|
|
-const actionPromise = (name, promise) => {
|
|
|
- const actionPending = () => ({
|
|
|
- type: "PROMISE",
|
|
|
- name,
|
|
|
- status: "PENDING",
|
|
|
- payload: null,
|
|
|
- error: null,
|
|
|
- });
|
|
|
- const actionResolved = (payload) => ({
|
|
|
- type: "PROMISE",
|
|
|
- name,
|
|
|
- status: "RESOLVED",
|
|
|
- payload,
|
|
|
- error: null,
|
|
|
- });
|
|
|
- const actionRejected = (error) => ({
|
|
|
- type: "PROMISE",
|
|
|
- name,
|
|
|
- status: "REJECTED",
|
|
|
- payload: null,
|
|
|
- error,
|
|
|
- });
|
|
|
- return async (dispatch) => {
|
|
|
- dispatch(actionPending());
|
|
|
- try {
|
|
|
- let payload = await promise;
|
|
|
- dispatch(actionResolved(payload));
|
|
|
- return payload;
|
|
|
- } catch (error) {
|
|
|
- dispatch(actionRejected(error));
|
|
|
- }
|
|
|
- };
|
|
|
-};
|
|
|
-
|
|
|
-const delay = (ms) => new Promise((ok) => setTimeout(() => ok(ms), ms));
|
|
|
-
|
|
|
-const store1 = createStore(promiseReducer, applyMiddleware(thunk));
|
|
|
-store1.subscribe(() => console.log(store1.getState()));
|
|
|
-
|
|
|
-store1.dispatch({
|
|
|
- type: "PROMISE",
|
|
|
- name: "login",
|
|
|
- status: "RESOLVED",
|
|
|
- payload: "hi",
|
|
|
-});
|
|
|
-
|
|
|
-store1.dispatch({
|
|
|
- type: "PROMISE",
|
|
|
- name: "chatList",
|
|
|
- status: "REJECTED",
|
|
|
- error: "bye",
|
|
|
-});
|
|
|
-
|
|
|
-// function actionToken(token) {
|
|
|
-// return {
|
|
|
-// type: "TOKEN",
|
|
|
-// token,
|
|
|
-// };
|
|
|
-// }
|
|
|
-
|
|
|
-// const actionLoginPromise = (email, password) => {
|
|
|
-// let promise = getGQL("http://localhost:3330/graphql")(
|
|
|
-// `query l($email:String, $password:String){
|
|
|
-// login(email:$email, password:$password)
|
|
|
-// }`,
|
|
|
-// { email, password }
|
|
|
-// );
|
|
|
-// return actionPromise("email", promise);
|
|
|
-// };
|
|
|
-
|
|
|
-// const actionLogin = (email, password) => {
|
|
|
-// return async (dispatch) => {
|
|
|
-// let token = await dispatch(actionLoginPromise(email, password));
|
|
|
-// if (token) {
|
|
|
-// dispatch(actionToken(token));
|
|
|
-// // window.location.assign("/my_profile")
|
|
|
-// }
|
|
|
-// };
|
|
|
-// };
|
|
|
-
|
|
|
-function actionRegisterPromise(email, password, nickname) {
|
|
|
- let promise = getGQL("http://localhost:3330/graphql")(
|
|
|
- `mutation reg($email:String, $password:String, $nickname:String){
|
|
|
- createUser(email:$email, password:$password, nickname:$nickname){ id }
|
|
|
- }`,
|
|
|
- { email, password, nickname }
|
|
|
- );
|
|
|
- return actionPromise("register", promise);
|
|
|
-}
|
|
|
-
|
|
|
-function actionRegister(email, password, nickname) {
|
|
|
- return async (dispatch) => {
|
|
|
- let user = await dispatch(actionRegisterPromise(email, password, nickname));
|
|
|
- if (user) {
|
|
|
- window.location.assign("/sign_in")
|
|
|
- // dispatch(actionLogin(email, password));
|
|
|
- }
|
|
|
- };
|
|
|
-}
|
|
|
-
|
|
|
-// const actionRegister = (email, password) => {
|
|
|
-// return async (dispatch) => {
|
|
|
-// let useer = await dispatch(actionLoginPromise(email, password));
|
|
|
-// if (token) dispatch(actionToken(token));
|
|
|
-// };
|
|
|
-// };
|
|
|
-
|
|
|
-const actionTimeouts = () => {
|
|
|
- return async (dispatch) => {
|
|
|
- let result = await dispatch(actionPromise("delay1", delay(1000)));
|
|
|
- console.log(result);
|
|
|
- result = await dispatch(actionPromise("delay" + result, delay(result * 2)));
|
|
|
- console.log(result);
|
|
|
- };
|
|
|
-};
|
|
|
|
|
|
-store1.dispatch(actionTimeouts());
|
|
|
-
|
|
|
-store1.dispatch(actionPromise("delay1000", delay(1000)));
|
|
|
-store1.dispatch(actionPromise("delay2000", delay(2000)));
|
|
|
-
|
|
|
-// const store = createStore((state, { type, token }) => {
|
|
|
-// if (!state) return {};
|
|
|
-// if (type === "LOGOUT") return { jwt: "" };
|
|
|
-// if (type === "LOGIN")
|
|
|
-// return {
|
|
|
-// pending: true,
|
|
|
-// jwt: "",
|
|
|
-// };
|
|
|
-// if (type === "TOKEN")
|
|
|
-// return {
|
|
|
-// jwt: token,
|
|
|
-// data: jwtDecode(token),
|
|
|
-// };
|
|
|
-// return state;
|
|
|
-// });
|
|
|
-
|
|
|
-const getGQL = (url, headers = {}) => (query = "", variables = {}) =>
|
|
|
- fetch(url, {
|
|
|
- method: "POST",
|
|
|
- headers: {
|
|
|
- Accept: "application/json",
|
|
|
- "Content-Type": "application/json",
|
|
|
- ...headers,
|
|
|
- },
|
|
|
- body: JSON.stringify({ query, variables }),
|
|
|
- }).then((res) => res.json());
|
|
|
-
|
|
|
-// function actionLogin(email, password) {
|
|
|
-// getGQL("http://localhost:3330/graphql")(
|
|
|
-// `query l($email:String, $password:String){
|
|
|
-// login(email:$email, password:$password)
|
|
|
-// }`,
|
|
|
-// { email, password }
|
|
|
-// ).then((data) => store.dispatch(actionToken(data.data.login)));
|
|
|
-// return {
|
|
|
-// type: "LOGIN",
|
|
|
-// };
|
|
|
-// }
|
|
|
-
|
|
|
-// function actionToken(token) {
|
|
|
-// return {
|
|
|
-// type: "TOKEN",
|
|
|
-// token,
|
|
|
-// };
|
|
|
-// }
|
|
|
-
|
|
|
-// store.subscribe(() => console.log(store.getState()));
|
|
|
-// store1.dispatch(actionLogin("1", "1"));
|
|
|
+import {
|
|
|
+ validateEmail,
|
|
|
+ borderEmailDischarge,
|
|
|
+ borderPasswordDischarge,
|
|
|
+ validatePassword,
|
|
|
+ signUpValidate,
|
|
|
+} from "./signUpValidate/signUpValidate";
|
|
|
+import {actionRegister, store} from "./actionRegister/actionRegister"
|
|
|
+import "./signUp.css";
|
|
|
|
|
|
const Register1 = (props) => {
|
|
|
- const [email, setEmail] = useState("");
|
|
|
- const [password, setPassword] = useState("");
|
|
|
+ const [registerEmail, setEmail] = useState("");
|
|
|
+ const [registerPassword, setPassword] = useState("");
|
|
|
const [confirmPassword, setConfirmPassword] = useState("");
|
|
|
- const [nickname, setNickname] = useState("");
|
|
|
+ const [login, setLogin] = useState("");
|
|
|
|
|
|
return (
|
|
|
<div className="register">
|
|
@@ -247,24 +29,42 @@ const Register1 = (props) => {
|
|
|
<div className="block-input">
|
|
|
<span>E-mail:</span>
|
|
|
<input
|
|
|
- value={email}
|
|
|
+ value={registerEmail}
|
|
|
type="email"
|
|
|
id="registerEmail"
|
|
|
name="email"
|
|
|
- // pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,}$"
|
|
|
+ pattern={validateEmail(registerEmail)}
|
|
|
+ onClick={() => borderEmailDischarge()}
|
|
|
onChange={(e) => setEmail(e.target.value)}
|
|
|
/>
|
|
|
</div>
|
|
|
|
|
|
+ <div className="pattern-email">
|
|
|
+ <p></p>
|
|
|
+ <div>
|
|
|
+ <p>Неверный формат почты</p>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ <div className="block-input">
|
|
|
+ <span>Логин:</span>
|
|
|
+ <input
|
|
|
+ value={login}
|
|
|
+ type="text"
|
|
|
+ id="loginCreate"
|
|
|
+ name="login"
|
|
|
+ onChange={(e) => setLogin(e.target.value)}
|
|
|
+ />
|
|
|
+ </div>
|
|
|
+
|
|
|
<div className="block-input">
|
|
|
<span>Пароль:</span>
|
|
|
<div className="password-block">
|
|
|
<input
|
|
|
- value={password}
|
|
|
+ value={registerPassword}
|
|
|
type="password"
|
|
|
id="registerPassword"
|
|
|
name="password"
|
|
|
- // pattern="(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}"
|
|
|
onChange={(e) => setPassword(e.target.value)}
|
|
|
/>
|
|
|
<div className="not-see" onClick={props.registerEye}>
|
|
@@ -283,6 +83,8 @@ const Register1 = (props) => {
|
|
|
value={confirmPassword}
|
|
|
type="password"
|
|
|
id="confirmPassword"
|
|
|
+ onClick={() => borderPasswordDischarge()}
|
|
|
+ pattern={validatePassword(registerPassword, confirmPassword)}
|
|
|
name="confirmPassword"
|
|
|
onChange={(e) => setConfirmPassword(e.target.value)}
|
|
|
/>
|
|
@@ -295,22 +97,28 @@ const Register1 = (props) => {
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
- <div className="block-input">
|
|
|
- <span>Ник:</span>
|
|
|
- <input
|
|
|
- value={nickname}
|
|
|
- type="text"
|
|
|
- id="nickname"
|
|
|
- name="nickname"
|
|
|
- onChange={(e) => setNickname(e.target.value)}
|
|
|
- />
|
|
|
+ <div className="pattern-password">
|
|
|
+ <p></p>
|
|
|
+ <div>
|
|
|
+ <p>Неверный формат</p>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
|
|
|
<div className="block-input-btn">
|
|
|
<p></p>
|
|
|
<button
|
|
|
- onClick={()=>props.register(email, password, nickname)}
|
|
|
- disabled={!email || !password || !confirmPassword || !nickname}
|
|
|
+ onClick={() =>
|
|
|
+ signUpValidate(
|
|
|
+ registerEmail,
|
|
|
+ registerPassword,
|
|
|
+ confirmPassword,
|
|
|
+ login,
|
|
|
+ props
|
|
|
+ )
|
|
|
+ }
|
|
|
+ disabled={
|
|
|
+ !registerEmail || !registerPassword || !confirmPassword || !login
|
|
|
+ }
|
|
|
>
|
|
|
Регистрация
|
|
|
</button>
|
|
@@ -320,9 +128,12 @@ const Register1 = (props) => {
|
|
|
);
|
|
|
};
|
|
|
|
|
|
-const Register = () => (
|
|
|
- <Provider store={store1}>
|
|
|
- <ConnectedRegisterForm />
|
|
|
+const Register = (props) => (
|
|
|
+ <Provider store={store}>
|
|
|
+ <ConnectedRegisterForm
|
|
|
+ registerEye={props.registerEye}
|
|
|
+ registerConfirmEye={props.registerConfirmEye}
|
|
|
+ />
|
|
|
</Provider>
|
|
|
);
|
|
|
|