mirror of
https://github.com/hubHarmony/servii-frontend.git
synced 2024-11-17 21:40:30 +00:00
better login page and fix css
This commit is contained in:
parent
7f4ce95c13
commit
ef0660bb9e
Binary file not shown.
Before Width: | Height: | Size: 1.8 KiB After Width: | Height: | Size: 108 KiB |
Binary file not shown.
Before Width: | Height: | Size: 88 KiB |
79
src/components/Banner/Banner.jsx
Normal file
79
src/components/Banner/Banner.jsx
Normal file
@ -0,0 +1,79 @@
|
||||
// src/components/Banner/Banner.js
|
||||
import React, { useEffect, useRef, useState } from 'react';
|
||||
import styles from './Banner.module.scss';
|
||||
|
||||
const shuffleArray = (array) => {
|
||||
return array.sort(() => Math.random() - 0.5);
|
||||
};
|
||||
|
||||
const Banner = ({ messages, speed = 1 }) => {
|
||||
const [shuffledMessages, setShuffledMessages] = useState([]);
|
||||
const bannerRef = useRef(null);
|
||||
const containerRef = useRef(null);
|
||||
const animationRef = useRef(null);
|
||||
const startPositionRef = useRef(0);
|
||||
|
||||
useEffect(() => {
|
||||
setShuffledMessages(shuffleArray([...messages, ...messages]));
|
||||
|
||||
const banner = bannerRef.current;
|
||||
const container = containerRef.current;
|
||||
const messagesWidth = banner.scrollWidth;
|
||||
startPositionRef.current = container.offsetWidth;
|
||||
|
||||
const scrollBanner = () => {
|
||||
startPositionRef.current -= speed;
|
||||
if (startPositionRef.current <= -messagesWidth) {
|
||||
startPositionRef.current = container.offsetWidth;
|
||||
}
|
||||
banner.style.transform = `translateX(${startPositionRef.current}px)`;
|
||||
animationRef.current = requestAnimationFrame(scrollBanner);
|
||||
};
|
||||
|
||||
animationRef.current = requestAnimationFrame(scrollBanner);
|
||||
|
||||
return () => cancelAnimationFrame(animationRef.current);
|
||||
}, [messages, speed]);
|
||||
|
||||
const handleMouseEnter = () => {
|
||||
if (animationRef.current) {
|
||||
cancelAnimationFrame(animationRef.current);
|
||||
}
|
||||
};
|
||||
|
||||
const handleMouseLeave = () => {
|
||||
const banner = bannerRef.current;
|
||||
const container = containerRef.current;
|
||||
const messagesWidth = banner.scrollWidth;
|
||||
|
||||
const scrollBanner = () => {
|
||||
startPositionRef.current -= speed;
|
||||
if (startPositionRef.current <= -messagesWidth) {
|
||||
startPositionRef.current = container.offsetWidth;
|
||||
}
|
||||
banner.style.transform = `translateX(${startPositionRef.current}px)`;
|
||||
animationRef.current = requestAnimationFrame(scrollBanner);
|
||||
};
|
||||
|
||||
animationRef.current = requestAnimationFrame(scrollBanner);
|
||||
};
|
||||
|
||||
return (
|
||||
<div
|
||||
className={styles.bannerContainer}
|
||||
ref={containerRef}
|
||||
onMouseEnter={handleMouseEnter}
|
||||
onMouseLeave={handleMouseLeave}
|
||||
>
|
||||
<div className={styles.bannerContent} ref={bannerRef}>
|
||||
{shuffledMessages.map((message, index) => (
|
||||
<span key={index} className={styles.message}>
|
||||
{message}
|
||||
</span>
|
||||
))}
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
export default Banner;
|
24
src/components/Banner/Banner.module.scss
Normal file
24
src/components/Banner/Banner.module.scss
Normal file
@ -0,0 +1,24 @@
|
||||
/* src/components/Banner/Banner.module.scss */
|
||||
.bannerContainer {
|
||||
overflow: hidden;
|
||||
white-space: nowrap;
|
||||
width: 98%;
|
||||
background-color: #f0f0f0;
|
||||
padding: 10px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.bannerContent {
|
||||
display: inline-block;
|
||||
white-space: nowrap;
|
||||
min-width: 100%;
|
||||
display: flex;
|
||||
}
|
||||
|
||||
.message {
|
||||
display: inline-block;
|
||||
margin-right: 5rem;
|
||||
font-size: 1.2rem;
|
||||
font-weight: bold;
|
||||
color: #333;
|
||||
}
|
@ -92,7 +92,7 @@ const CreateServer = ({ user, onCreateServer, onSubdomainUpdate, onCancel, noSer
|
||||
<div className={styles.container}>
|
||||
{noServers ? (
|
||||
<div className={styles.mainCardNoserveur}>
|
||||
<div className={styles.nsSubTitle}>Erreur</div>
|
||||
<div className={styles.nsSubTitle}>Bonjour</div>
|
||||
<div className={styles.nsTitle}>Aucun serveur </div>
|
||||
<button className={styles.btnnoServCreate} onClick={onCreateServer}>Créer un nouveau serveur</button>
|
||||
</div>
|
||||
|
@ -147,7 +147,6 @@
|
||||
height: 5rem;
|
||||
object-fit: cover;
|
||||
display: block;
|
||||
border: 1px solid black;
|
||||
cursor: pointer;
|
||||
transition: transform 0.2s;
|
||||
}
|
||||
|
@ -2,6 +2,7 @@
|
||||
import { useNavigate } from 'react-router-dom';
|
||||
import { auth, googleProvider, signInWithPopup } from '../../service/firebase';
|
||||
import styles from './LoginPage.module.scss';
|
||||
import Banner from '../../components/Banner/Banner';
|
||||
|
||||
const LoginPage = () => {
|
||||
const navigate = useNavigate();
|
||||
@ -15,15 +16,36 @@ const LoginPage = () => {
|
||||
}
|
||||
};
|
||||
|
||||
const messages = [
|
||||
"Bienvenue sur notre application !",
|
||||
"Découvrez nos nouvelles fonctionnalités",
|
||||
"Contactez le support pour toute assistance",
|
||||
"Merci de votre confiance",
|
||||
"Amusez-vous bien !",
|
||||
"L'équipe Servii",
|
||||
"Connectez-vous pour continuer",
|
||||
"Connexion sécurisée avec Google",
|
||||
"Bonne journée !",
|
||||
"Bienvenue sur Servii !",
|
||||
"N'hésitez pas à nous contacter",
|
||||
|
||||
];
|
||||
|
||||
return (
|
||||
<div>
|
||||
<div className={styles.nav}>
|
||||
<Banner messages={messages} speed={1.3} />
|
||||
</div>
|
||||
<div className={styles.container}>
|
||||
<div className={styles.mainCard}>
|
||||
<div className={styles.title}>Page de connexion</div>
|
||||
<div className={styles.pretitle}>Servii - hebergement facile</div>
|
||||
<div className={styles.title}>Bienvenue </div>
|
||||
<button onClick={handleLogin} className={styles.logbtn}>
|
||||
Se connecter avec Google
|
||||
Continuer avec Google
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
||||
|
@ -1,46 +1,71 @@
|
||||
$primary-color: #1D1836;
|
||||
$text-color: black;
|
||||
$background-color: white;
|
||||
$border-radius: 1rem;
|
||||
$padding: 1rem;
|
||||
$font-family: 'Poppins', sans-serif;
|
||||
|
||||
html, body {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
font-family: 'Poppins', sans-serif;
|
||||
font-family: $font-family;
|
||||
height: 100%;
|
||||
background-color: $background-color !important;
|
||||
}
|
||||
|
||||
.container {
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
height: 100vh;
|
||||
background-color: $background-color;
|
||||
height: 93vh;
|
||||
|
||||
}
|
||||
|
||||
.mainCard {
|
||||
width: 70rem;
|
||||
padding: 1rem;
|
||||
background-color: #100D25;
|
||||
width: 60rem;
|
||||
padding: 3rem 0;
|
||||
background-color: $background-color;
|
||||
display: flex;
|
||||
justify-content: center;
|
||||
align-items: center;
|
||||
flex-direction: column;
|
||||
border-radius: 1rem;
|
||||
padding: 3rem 0rem 3rem 0rem;
|
||||
border-radius: $border-radius;
|
||||
margin-bottom: 10rem;
|
||||
}
|
||||
|
||||
.pretitle {
|
||||
font-size: 2rem;
|
||||
font-weight: 700;
|
||||
margin-bottom: 4rem;
|
||||
color: $text-color;
|
||||
}
|
||||
|
||||
.title {
|
||||
font-size: 5rem;
|
||||
font-weight: 700;
|
||||
margin-bottom: 1rem;
|
||||
color: white;
|
||||
margin-bottom: 4rem;
|
||||
font-size: 2.5rem;
|
||||
font-weight: 400;
|
||||
margin-bottom: 2rem;
|
||||
color: $text-color;
|
||||
}
|
||||
|
||||
.logbtn {
|
||||
width: 100%;
|
||||
background-color: #090325;
|
||||
border: none;
|
||||
color : white;
|
||||
padding: 10px;
|
||||
width: 30rem;
|
||||
background-color: white;
|
||||
border: .1rem solid #C2C8D0;
|
||||
color: black;
|
||||
padding: $padding;
|
||||
cursor: pointer;
|
||||
border-radius: 5px;
|
||||
font-size: 1.5rem;
|
||||
font-weight: 700;
|
||||
margin-top: 1rem;
|
||||
font-weight: 400;
|
||||
}
|
||||
|
||||
.logbtn:hover {
|
||||
background-color: #E5E5E5;
|
||||
}
|
||||
|
||||
.nav {
|
||||
color: $text-color;
|
||||
background-color: $background-color;
|
||||
font-size: 2rem;
|
||||
}
|
@ -83,7 +83,11 @@
|
||||
}
|
||||
|
||||
.saveButton {
|
||||
background-color: var(--button-bg-color);
|
||||
background-color: #05a771;
|
||||
}
|
||||
|
||||
.saveButton:hover {
|
||||
background-color: #05a77183;
|
||||
}
|
||||
|
||||
.quitButton {
|
||||
@ -91,19 +95,6 @@
|
||||
margin-left: 1rem;
|
||||
}
|
||||
|
||||
.saveButton:hover,
|
||||
.quitButton:hover {
|
||||
transform: translateY(-3px);
|
||||
}
|
||||
|
||||
.saveButton:active,
|
||||
.quitButton:active {
|
||||
transform: translateY(0);
|
||||
}
|
||||
|
||||
.saveButton:hover {
|
||||
background-color: var(--button-bg-hover-color);
|
||||
}
|
||||
|
||||
.error {
|
||||
color: var(--error-color);
|
||||
|
Loading…
Reference in New Issue
Block a user