From 66ed7806e34679581fd9d83892bcaacb9f331de4 Mon Sep 17 00:00:00 2001 From: Himangshu Sharma <120270398+HS202022@users.noreply.github.com> Date: Tue, 8 Oct 2024 13:06:20 +0530 Subject: [PATCH] Added the login sign up page and the dashboard section --- dashboard.css | 112 +++++++++++++ dashboard.html | 38 +++++ index.html | 1 + login.css | 415 +++++++++++++++++++++++++++++++++++++++++++++++++ login.html | 104 +++++++++++++ login.js | 94 +++++++++++ 6 files changed, 764 insertions(+) create mode 100644 dashboard.css create mode 100644 dashboard.html create mode 100644 login.css create mode 100644 login.html create mode 100644 login.js diff --git a/dashboard.css b/dashboard.css new file mode 100644 index 00000000..53570dfb --- /dev/null +++ b/dashboard.css @@ -0,0 +1,112 @@ +@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700;800&display=swap"); + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body, input { + font-family: "Poppins", sans-serif; +} + +.container { + min-height: 100vh; + width: 100%; + background-color: #f4f4f4; + display: flex; + justify-content: center; + align-items: center; + position: relative; + overflow: hidden; +} + +.dashboard-content { + background-color: #ffffff; + padding: 2rem; + border-radius: 10px; + box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); + text-align: center; + width: 100%; + max-width: 700px; +} + +h1 { + font-size: 2.5rem; + color: #333; + margin-bottom: 1.5rem; +} + +h2 { + font-size: 1.8rem; + color: #444; + margin-bottom: 1rem; +} + +ul { + list-style-type: disc; + padding-left: 20px; + text-align: left; + color: #555; +} + +ul li { + margin-bottom: 10px; +} + +ul li a { + color: #007bff; + text-decoration: none; + font-weight: 500; +} + +ul li a:hover { + text-decoration: underline; + color: #0056b3; +} + +.section { + margin: 2rem 0; +} + +.homeBtn { + position: absolute; + top: 20px; + left: 20px; + background: #000000; + color: #ffffff; + padding: 10px 20px; + border-radius: 10px; + font-size: 1rem; + font-weight: 500; + text-decoration: none; + cursor: pointer; + transition: 0.3s; +} + +.homeBtn:hover { + background-color: #444444; +} + +/* Responsive styles */ +@media (max-width: 768px) { + .dashboard-content { + padding: 1.5rem; + } + + h1 { + font-size: 2rem; + } + + h2 { + font-size: 1.6rem; + } + + ul li { + font-size: 0.9rem; + } + + .homeBtn { + font-size: 0.9rem; + } +} diff --git a/dashboard.html b/dashboard.html new file mode 100644 index 00000000..798e5729 --- /dev/null +++ b/dashboard.html @@ -0,0 +1,38 @@ + + + + + + Dashboard + + + +
+ + +
+

Welcome,User

+
+

DASHBOARD

+

Achievements

+
    +
  • 100 Days Coding Challenge - Completed
  • +
  • 200 Days Coding Challenge - In Progress
  • +
  • Top Performer in Python - 2023
  • +
+
+ +
+

Projects

+ +
+
+
+ + diff --git a/index.html b/index.html index 2aeca609..9324b578 100644 --- a/index.html +++ b/index.html @@ -32,6 +32,7 @@ Events Learn Compare + Login
diff --git a/login.css b/login.css new file mode 100644 index 00000000..639f4c72 --- /dev/null +++ b/login.css @@ -0,0 +1,415 @@ +@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700;800&display=swap"); + +* { + margin: 0; + padding: 0; + box-sizing: border-box; +} + +body, +input { + font-family: "Poppins", sans-serif; +} + +.container { + position: relative; + width: 100%; + background-color: #ffffff; + min-height: 100vh; + overflow: hidden; +} + +.forms-container { + position: absolute; + width: 100%; + height: 100%; + top: 0; + left: 0; +} + +.signin-signup { + position: absolute; + top: 50%; + transform: translate(-50%, -50%); + left: 75%; + width: 50%; + transition: 1s 0.7s ease-in-out; + display: grid; + grid-template-columns: 1fr; + z-index: 5; +} + +form { + display: flex; + align-items: center; + justify-content: center; + flex-direction: column; + padding: 0rem 5rem; + transition: all 0.2s 0.7s; + overflow: hidden; + grid-column: 1 / 2; + grid-row: 1 / 2; +} + +form.sign-up-form { + opacity: 0; + z-index: 1; +} + +form.sign-in-form { + z-index: 2; +} + +.title { + font-size: 2.2rem; + color: #444; + margin-bottom: 10px; +} + +.input-field { + max-width: 380px; + width: 100%; + background-color: #f0f0f0; + margin: 10px 0; + height: 55px; + border-radius: 55px; + display: grid; + grid-template-columns: 15% 85%; + padding: 0 0.4rem; + position: relative; +} + +.input-field i { + text-align: center; + line-height: 55px; + color: #acacac; + transition: 0.5s; + font-size: 1.1rem; +} + +.input-field input { + background: none; + outline: none; + border: none; + line-height: 1; + font-weight: 600; + font-size: 1.1rem; + color: #333; +} + +.input-field input::placeholder { + color: #aaa; + font-weight: 500; +} + +.social-text { + padding: 0.7rem 0; + font-size: 1rem; +} + +.social-media { + display: flex; + justify-content: center; +} + +.social-icon { + height: 46px; + width: 46px; + display: flex; + justify-content: center; + align-items: center; + margin: 0 0.45rem; + color: #333; + /* border-radius: 50%; + border: 1px solid #333; */ + text-decoration: none; + font-size: 1.1rem; + transition: 0.3s; +} + +.social-icon:hover { + color: #0b3174; + border-color: #000000; +} + +.btn { + width: 150px; + background-color: #000000; + border: none; + outline: none; + height: 49px; + border-radius: 49px; + color: #fff; + text-transform: uppercase; + font-weight: 600; + margin: 10px 0; + cursor: pointer; + transition: 0.5s; +} + +.btn:hover { + background-color: #161618; +} +.panels-container { + position: absolute; + height: 100%; + width: 100%; + top: 0; + left: 0; + display: grid; + grid-template-columns: repeat(2, 1fr); +} + +.container:before { + content: ""; + position: absolute; + height: 2000px; + width: 2000px; + top: -10%; + right: 48%; + transform: translateY(-50%); + background-image: linear-gradient(-45deg, #000000 0%, #000000 100%); + transition: 1.8s ease-in-out; + border-radius: 50%; + z-index: 6; +} + +.image { + width: 100%; + transition: transform 1.1s ease-in-out; + transition-delay: 0.4s; +} + +.panel { + display: flex; + flex-direction: column; + justify-content: space-around; + text-align: center; + z-index: 6; +} + +.left-panel { + pointer-events: all; + padding: 4rem 17% 2rem 12%; +} + +.right-panel { + pointer-events: none; + padding: 3rem 12% 2rem 17%; +} + +.panel .content { + color: #ffffff; + transition: transform 0.9s ease-in-out; + transition-delay: 0.6s; +} + +.panel h3 { + font-weight: 600; + line-height: 1; + font-size: 1.5rem; +} + +.panel p { + font-size: 0.95rem; + padding: 0.7rem 0; +} + +.btn.transparent { + margin: 0; + background: none; + border: 2px solid #fff; + width: 130px; + height: 41px; + font-weight: 600; + font-size: 0.8rem; +} + +.right-panel .image, +.right-panel .content { + transform: translateX(800px); +} + +/* ANIMATION */ + +.container.sign-up-mode:before { + transform: translate(100%, -50%); + right: 52%; +} + +.container.sign-up-mode .left-panel .image, +.container.sign-up-mode .left-panel .content { + transform: translateX(-800px); +} + +.container.sign-up-mode .signin-signup { + left: 25%; +} + +.container.sign-up-mode form.sign-up-form { + opacity: 1; + z-index: 2; +} + +.container.sign-up-mode form.sign-in-form { + opacity: 0; + z-index: 1; +} + +.container.sign-up-mode .right-panel .image, +.container.sign-up-mode .right-panel .content { + transform: translateX(0%); +} + +.container.sign-up-mode .left-panel { + pointer-events: none; +} + +.container.sign-up-mode .right-panel { + pointer-events: all; +} + +@media (max-width: 870px) { + .container { + min-height: 800px; + height: 100vh; + } + .signin-signup { + width: 100%; + top: 95%; + transform: translate(-50%, -100%); + transition: 1s 0.8s ease-in-out; + } + + .signin-signup, + .container.sign-up-mode .signin-signup { + left: 50%; + } + + .panels-container { + grid-template-columns: 1fr; + grid-template-rows: 1fr 2fr 1fr; + } + + .panel { + flex-direction: row; + justify-content: space-around; + align-items: center; + padding: 2.5rem 8%; + grid-column: 1 / 2; + } + + .right-panel { + grid-row: 3 / 4; + } + + .left-panel { + grid-row: 1 / 2; + } + + .image { + width: 200px; + transition: transform 0.9s ease-in-out; + transition-delay: 0.6s; + } + + .panel .content { + padding-right: 15%; + transition: transform 0.9s ease-in-out; + transition-delay: 0.8s; + } + + .panel h3 { + font-size: 1.2rem; + } + + .panel p { + font-size: 0.7rem; + padding: 0.5rem 0; + } + + .btn.transparent { + width: 110px; + height: 35px; + font-size: 0.7rem; + } + + .container:before { + width: 1500px; + height: 1500px; + transform: translateX(-50%); + left: 30%; + bottom: 68%; + right: initial; + top: initial; + transition: 2s ease-in-out; + } + + .container.sign-up-mode:before { + transform: translate(-50%, 100%); + bottom: 32%; + right: initial; + } + + .container.sign-up-mode .left-panel .image, + .container.sign-up-mode .left-panel .content { + transform: translateY(-300px); + } + + .container.sign-up-mode .right-panel .image, + .container.sign-up-mode .right-panel .content { + transform: translateY(0px); + } + + .right-panel .image, + .right-panel .content { + transform: translateY(300px); + } + + .container.sign-up-mode .signin-signup { + top: 5%; + transform: translate(-50%, 0); + } +} + +@media (max-width: 570px) { + form { + padding: 0 1.5rem; + } + + .image { + display: none; + } + .panel .content { + padding: 0.5rem 1rem; + } + .container { + padding: 1.5rem; + } + + .container:before { + bottom: 72%; + left: 50%; + } + + .container.sign-up-mode:before { + bottom: 28%; + left: 50%; + } +} + + + +.homeBtn { + position: absolute; + top: 20px; + left: 20px; + background: #ffffff; + color: #ffffff; + padding: 10px; + border-radius: 10px; + cursor: pointer; + transition: 0.3s; + text-decoration: none; +} + diff --git a/login.html b/login.html new file mode 100644 index 00000000..ba5b47f8 --- /dev/null +++ b/login.html @@ -0,0 +1,104 @@ + + + + + + Register & Login + + + + +
+
+ +
+ +
+ + + + + +
+
+

New here ?

+

+ Discover new experiences with Awesome-github-profiles
Get inspired by the top github profiles and add one .
Create your account. +

+ + + + + + +
+ +
+
+ +
+ +

One of us ?

+

+ Welcome Back! +

+ + +
+ +
+ +
+ +
+ + + diff --git a/login.js b/login.js new file mode 100644 index 00000000..fab96e16 --- /dev/null +++ b/login.js @@ -0,0 +1,94 @@ +const sign_in_btn = document.querySelector("#sign-in-btn"); +const sign_up_btn = document.querySelector("#sign-up-btn"); +const container = document.querySelector(".container"); + +sign_up_btn.addEventListener("click", () => { + container.classList.add("sign-up-mode"); +}); + +sign_in_btn.addEventListener("click", () => { + container.classList.remove("sign-up-mode"); +}); + +// Sign in form submission +document.querySelector(".sign-in-form").addEventListener('submit', function(event) { + event.preventDefault(); + + // Get the input values + const username = document.querySelector(".sign-in-form input[type='text']").value; + const password = document.querySelector(".sign-in-form input[type='password']").value; + + // Dummy login logic for demo purposes + if (username === 'admin' && password === 'password') { + alert('Login successful!'); + // Redirect to dashboard page + window.location.href = 'index.html'; + } else { + alert('Invalid username or password'); + } +}); + +// Sign up form submission +document.querySelector(".sign-up-form").addEventListener('submit', function(event) { + event.preventDefault(); + + // Get the input values + const username = document.querySelector(".sign-up-form input[type='text']").value; + const email = document.querySelector(".sign-up-form input[type='email']").value; + const password = document.querySelector(".sign-up-form input[type='password']").value; + + if (username === '' || email === '' || password === '') { + alert('Please fill in all fields'); + return; + } + + // Dummy signup logic for demo purposes + localStorage.setItem('username', username); + localStorage.setItem('email', email); + localStorage.setItem('password', password); + localStorage.setItem('isLoggedIn', 'true'); + + alert('Signup successful!'); + // Redirect to dashboard page + window.location.href = 'index.html'; +}); + +// Toggle password visibility +function togglePassword(fieldId, icon) { + const field = document.getElementById(fieldId); + const isPassword = field.type === 'password'; + + // Toggle between 'password' and 'text' + field.type = isPassword ? 'text' : 'password'; + + // Change the icon class between eye and eye-slash + icon.classList.toggle('fa-eye-slash', isPassword); + icon.classList.toggle('fa-eye', !isPassword); +} + +// Check password strength +function checkPasswordStrength() { + const password = document.querySelector(".sign-up-form input[type='password']").value; + const strengthWeak = document.getElementById('strength-weak'); + const strengthMedium = document.getElementById('strength-medium'); + const strengthStrong = document.getElementById('strength-strong'); + + let strength = 0; + + if (password.length >= 8) strength++; + if (password.match(/[A-Z]/)) strength++; + if (password.match(/[a-z]/)) strength++; + if (password.match(/[0-9]/)) strength++; + if (password.match(/[^a-zA-Z0-9]/)) strength++; + + strengthWeak.className = ''; + strengthMedium.className = ''; + strengthStrong.className = ''; + + if (strength >= 1) strengthWeak.className = 'weak'; + if (strength >= 3) strengthMedium.className = 'medium'; + if (strength >= 5) strengthStrong.className = 'strong'; +} + +// Call the checkPasswordStrength function on password input +document.querySelector(".sign-up-form input[type='password']").addEventListener('input', checkPasswordStrength); \ No newline at end of file