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 @@
+
+
+
+
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