KEMBAR78
FSWD Lab Manual 2 | PDF | Websites | Databases
0% found this document useful (0 votes)
24 views92 pages

FSWD Lab Manual 2

The document is a lab manual for a Full Stack Web Development course at Mohamed Sathak A.J College of Engineering for the academic year 2023-2024. It outlines course objectives, a list of experiments for students to complete, and expected outcomes, including the development of various web applications. Additionally, it includes a detailed example of a portfolio website project, complete with an algorithm and sample code.

Uploaded by

saisuganya
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
24 views92 pages

FSWD Lab Manual 2

The document is a lab manual for a Full Stack Web Development course at Mohamed Sathak A.J College of Engineering for the academic year 2023-2024. It outlines course objectives, a list of experiments for students to complete, and expected outcomes, including the development of various web applications. Additionally, it includes a detailed example of a portfolio website project, complete with an algorithm and sample code.

Uploaded by

saisuganya
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 92

lOMoARcPSD|51219696

Full Stack Lab Manual - r2021

full stack web development (Anna University)

Scan to open on Studocu

Studocu is not sponsored or endorsed by any college or university


Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)
lOMoARcPSD|51219696

MOHAMED SATHAK A.J COLLEGE OF ENGINEERING

(Approved by AICTE, New Delhi and Affiliated to Anna University)


34, Old Mahabalipuram Road, Egattur, Chennai – 603103.

ISO 9001:2008 Certified Institution

Sponsored By: MOHAMED SATHAK TRUST, Chennai –600034.

(ACADEMICYEAR:2023-2024)

IT3511 – FULL STACK WEB DEVELOPMENT LABORATORY

Name :

Register Number :

Department : INFORMATION TECHNOLOGY

Year/Semester : III/V

(ANNA UNIVERSITY : CHENNAI-600025)

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

MOHAMED SATHAK A.J COLLEGE OFENGINEERING


(Approved by AICTE, New Delhi and AfÏliated to Anna University)

34, Old Mahabalipuram Road, Egattur, Chennai–603103.

ISO9001:2008 Certified Institution

Sponsored By: MOHAMED SATHAK TRUST,

Chennai–600034.

BONAFIDE CERTIFICATE

This is to certify that this is the Bonafide Record of work done by


Mr./Ms......................................................…………………………………………………………………………..

Register Number......................................................................................................………..of

IIIYEAR/V Semester – INFORMATION AND TECHNOLOGY


IT3511 – FULL STACK WEB DEVELOPMENT LABORATORY during the academic year 2023-2024.

StaffIn-Charge Head of the Department

Submitted for the Anna University B.E Practical Examination held on.
…….................................

Internal Examiner External Examiner

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

IT3511 FULL STACK WEB DEVELOPMENT LAB LT PC 0 0 4 2

COURSE OBJECTIVES:
• To develop full stack applications with clear understanding of user interface, business logic and data storage.
• To design and develop user interface screens for a given scenario
• To develop the functionalities as web components as per the requirements
• To implement the database according to the functional requirements
• To integrate the user interface with the functionalities and data storage.

LIST OF EXPERIMENTS:
The Instructor can choose the technology stack to develop the following full stack experiments – based on the
Full Stack Web Development Theory Course.
1. Develop a portfolio website for yourself which gives details about yourself for a potential recruiter.
2. Create a web application to manage the TO-DO list of users, where users can login and manage their to-do
items
3. Create a simple micro blogging application (like twitter) that allows people to post their content which can be
viewed by people who follow them.
4. Create a food delivery website where users can order food from a particular restaurant listed in the website.
5. Develop a classifieds web application to buy and sell used products.
6. Develop a leave management system for an organization where users can apply different types of leaves such
as casual leave and medical leave. They also can view the available number of days.
7. Develop a simple dashboard for project management where the statuses of various tasks are available. New
tasks can be added and the status of existing tasks can be changed among Pending, InProgress or Completed.
8. Develop an online survey application where a collection of questions is available and users are asked to answer
any random 5 questions.
TOTAL: 60 PERIODS

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

COURSE OUTCOMES:
CO1: Design full stack applications with clear understanding of user interface, business logic and data storage.
CO2: Design and develop user interface screens
CO3: Implement the functional requirements using appropriate tool
CO4: Design and develop database based on the requirements
CO5: Integrate all the necessary components of the application

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Index
Marks Awarded-Day to Day
activities
Sign of the

(5
Record
Faculty

experiment

(5
Attendance
(5 Marks)
Technical
Completion

Knowledg
(5 Marks)
Performing
S.No Date Name of the Experiment with Date

Marks)
Marks)
Work
the

e
of
1
Develop a portfolio website for yourself
which gives details about yourself for a
potential recruiter
2 Create a web application to manage the
TO-DO list of users, where users can login
and manage their to-do items

3 Create a simple micro blogging


application (like twitter) that allows
people to post their content which can be
viewed by people who follow them.

4 Create a food delivery website where users


can order food from a particular restaurant
listed in the website.
5 Develop a classifieds web application to
buy and sell used products.
6 Develop a leave management system for
an organization where users can apply
different types of leaves such as casual
leave and medical leave. They also can
view the available number of days.

7 Develop a simple dashboard for project


management where the statuses of various
tasks are available. New tasks can be
added and the status of existing tasks can
be changed among Pending, InProgress or
Completed.

8 Develop an online survey application


where a collection of questions is
available and users are asked to answer
any random 5 questions
Content Beyond the Syllabus

1. Develop To-Do Application Using MERN

2. Develop Weather Application using


Reactjs

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Marks Sign of the


Internal Calculation Max. Marks
Awarded Faculty

Average of Day to Day Activity 20

Mini Project 10

Model Exam 10

Assignment/Simulation 10

Total 50

Sign of the Student Sign of Lab In - Charge

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Ex.No: 1 DEVELOP A PORTFOLIO WEBSITE FOR YOURSELF WHICH GIVES DETAILS ABOUT Date:
YOURSELF FOR A POTENTIAL RECRUITER

Aim:
To Develop a portfolio website for yourself which gives details about yourself for a potential
Recruiter.

Algorithm:
 Purpose: Showcase skills, projects, and experience.
 Audience: Recruiters and potential employers.
 Sections: Home, About Me, Projects, Skills, Contact.
 Logical order: Organize content coherently.
 Domain: Reflects your name or brand.
 Hosting: Select a reliable provider.
 Technologies: HTML, CSS, JavaScript, maybe a front-end framework.
 Layout: Rough sketch using tools like Adobe XD or Figma.
 Style: Pick colors, typography that complements your brand.
 Set up development environment.
 Write HTML structure and apply CSS styles.
 Add interactive elements using JavaScript.
 Ensure the website looks good on different devices.
 Create a separate page with project details, screenshots, links.
 Introduce yourself, highlight skills, add a professional photo.
 Offer a downloadable PDF link.
 Provide contact details and social media links.
 Check compatibility and fix errors.
 Improve loading times by optimizing images, CSS, JS.
 Consider using a CDN.
 Use relevant keywords, create meta tags.
 Ensure domain is linked to hosting server.
 Double-check content and links.
 Regularly check for issues and update with new experiences.
 Optionally, add a blog section to share thoughts.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
index.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Personal Portfolio Website - Easy Tutorials</title>
<link rel="stylesheet" href="style.css">
<script src="https://kit.fontawesome.com/c4254e24a8.js" crossorigin="anonymous"></script>
</head>
<body>
<div id="header">
<div class="container">
<nav>
<img src="images/logo.png" class="logo">
<ul id="sidemenu">
<li><a href="#header">Home</a></li>
<li><a href="#about">About</a></li>
<li><a href="#services">Services</a></li>
<li><a href="#portfolio">Portfolio</a></li>
<li><a href="#contact">Contact</a></li>
<i class="fas fa-times" onclick="closemenu()"></i>
</ul>
<i class="fas fa-bars" onclick="openmenu()"></i>
</nav>
<div class="header-text">
<p>UI/UX Designer</p>
<h1>Hi, I'm <span>User</span><br> From Chennai</h1>
</div>
</div>
</div>
<!-- -----------about---------- -->
<div id="about">
<div class="container">
<div class="row">
<div class="about-col-1">
<img src="images/user.jpg">
</div>
<div class="about-col-2">
<h1 class="sub-title">About Me</h1>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed nulla nibh, tincidunt
sit amet sapien quis, elementum molestie tellus. Pellentesque habitant morbi tristique senectus et

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

netus et malesuada fames ac turpis egestas. Mauris eleifend magna id ante convallis mattis.
Quisque in sem tristique, dictum sapien et, accumsan libero.</p>

<div class="tab-titles">
<p class="tab-links active-link" onclick="opentab('skills')">Skills</p>
<p class="tab-links" onclick="opentab('experience')">Experience</p>
<p class="tab-links" onclick="opentab('education')">Education</p>
</div>
<div class="tab-contents active-tab" id="skills">
<ul>
<li><span>UI/UX</span><br>Designing Web/App interfaces</li>
<li><span>Web Development</span><br>Web app Development</li>
<li><span>App Development</span><br>Building Android/iOS apps</li>
</ul>
</div>
<div class="tab-contents" id="experience">
<ul>
<li><span>2021 - Current</span><br>UI/UX Design Training at MSAJCE</li>
</ul>
</div>
<div class="tab-contents" id="education">
<ul>
<li><span>2023</span><br>UI/UX Design Training at MSAJCE </li>
<li><span>2020</span><br>Started Course in BTECH IT.</li>
</ul>
</div>
</div>
</div>
</div>
</div>
<!-- ---------services---------------- -->
<div id="services">
<div class="container">
<h1 class="sub-title">My Services</h1>
<div class="services-list">
<div>
<i class="fas fa-code"></i>
<h2>Web Design</h2>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed nulla nibh, tincidunt
sit amet sapien quis.</p>
<a href="#">Learn more</a>
</div>
<div>
<i class="fas fa-crop-alt"></i>
<h2>UI/UX Design</h2>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed nulla nibh, tincidunt
sit amet sapien quis.</p>
<a href="#">Learn more</a>
</div>
<div>
<i class="fab fa-app-store"></i>
<h2>App Design</h2>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Sed nulla nibh, tincidunt
sit amet sapien quis.</p>
<a href="#">Learn more</a>
</div>
</div>
</div>
</div>
<!-- ----------portfolio------------ -->
<div id="portfolio">
<div class="container">
<h1 class="sub-title">My Work</h1>
<div class="work-list">
<div class="work">
<img src="images/work-1.png">
<div class="layer">
<h3>Social Media App</h3>
<p>The app connects you yo the talented people around the world. Download it
from play store.</p>
<a href="#"><i class="fas fa-external-link-alt"></i></a>
</div>
</div>
<div class="work">
<img src="images/work-2.png">
<div class="layer">
<h3>Music App</h3>
<p>The app connects you yo the talented people around the world. Download it
from play store.</p>
<a href="#"><i class="fas fa-external-link-alt"></i></a>
</div>
</div>
<div class="work">
<img src="images/work-3.png">
<div class="layer">
<h3>Online Shopping App</h3>
<p>The app connects you yo the talented people around the world. Download it
from play store.</p>
<a href="#"><i class="fas fa-external-link-alt"></i></a>
</div>
</div>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

</div>
<a href="#" class="btn">See more</a>
</div>
</div>
<!-- ----------contact------------- -->
<div id="contact">
<div class="container">
<div class="row">
<div class="contact-left">
<h1 class="sub-title">Contact Me</h1>
<p><i class="fas fa-paper-plane"></i> contact@example.com</p>
<p><i class="fas fa-phone-square-alt"></i> 0123456789</p>
<div class="social-icons">
<a href="https://facebook.com/"><i class="fab fa-facebook"></i></a>
<a href=""><i class="fab fa-twitter-square"></i></a>
<a href=""><i class="fab fa-instagram"></i></a>
<a href=""><i class="fab fa-linkedin"></i></a>
</div>
<a href="images/my-cv.pdf" download class="btn btn2">Download CV</a>
</div>
<div class="contact-right">
<form name="submit-to-google-sheet">
<input type="text" name="Name" placeholder="Your Name" required>
<input type="email" name="Email" placeholder="Your Email" required>
<textarea name="Message" rows="6" placeholder="Your Message"></textarea>
<button type="submit" class="btn btn2">Submit</button>
</form>
<span id="msg"></span>
</div>
</div>
</div>
<div class="copyright">
<p>Copyright © User. Made wtih <i class="fas fa-heart"></i> by <a
href="https://www.youtube.com/channel/UCkjoHfkLEy7ZT4bA2myJ8xA?
sub_confirmation=1">Trainning</a></p>
</div>
</div>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<script src="script.js"></script>

</body>
</html>

Style.css
*{
margin: 0;
padding: 0;
font-family: 'Poppins', sans-serif;
box-sizing: border-box;
}
html{
scroll-behavior: smooth;
}
body{
background: #080808;
color: #fff;
}
#header{
width: 100%;
height: 100vh;
background-image: url(images/background.jpg);
background-size: cover;
background-position: center;
background-attachment: fixed;
}
.container{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

padding: 10px 10%;


}

nav{
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
}

.logo{
width: 140px;
}

nav ul li{
display: inline-block;
list-style: none;
margin: 10px 20px;
}

nav ul li a{
color: #fff;
text-decoration: none;
font-size: 18px;
position: relative;
}
nav ul li a::after{
content: '';

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

width: 0;
height: 3px;
background: #ff004f;
position: absolute;
left: 0;
bottom: -6px;
transition: 0.5s;
}
nav ul li a:hover::after{
width: 100%;
}
.header-text{
margin-top: 20%;
font-size: 30px;
}
.header-text h1{
font-size: 60px;
margin-top: 20px;
}
.header-text h1 span{
color: #ff004f;
}
/* -----------about--------------- */
#about{
padding: 80px 0;
color: #ababab;
}
.row{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.about-col-1{
flex-basis: 35%;
}
.about-col-1 img{
width: 100%;
border-radius: 15px;
}
.about-col-2{
flex-basis: 60%;
}

.sub-title{
font-size: 60px;
font-weight: 600;
color: #fff;
}

.tab-titles{
display: flex;
margin: 20px 0 40px;
}
.tab-links{
margin-right: 50px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

font-size: 18px;
font-weight: 500;
cursor: pointer;
position: relative;
}
.tab-links::after{
content: '';
width: 0;
height: 3px;
background: #ff004f;
position: absolute;
left: 0;
bottom: -8px;
transition: 0.5s;
}

.tab-links.active-link::after{
width: 50%;
}

.tab-contents ul li{
list-style: none;
margin: 10px 0;
}
.tab-contents ul li span{
color: #b54769;
font-size: 14px;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.tab-contents{
display: none;
}
.tab-contents.active-tab{
display: block;
}

/* ----------------services------------- */
#services{
padding: 30px 0;
}
.services-list{
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
grid-gap: 40px;
margin-top: 50px;
}
.services-list div{
background: #262626;
padding: 40px;
font-size: 13px;
font-weight: 300;
border-radius: 10px;
transition: background 0.5s, transform 0.5s;
}
.services-list div i{
font-size: 50px;
margin-bottom: 30px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

}
.services-list div h2{
font-size: 30px;
font-weight: 500;
margin-bottom: 15px;
}
.services-list div a{
text-decoration: none;
color: #fff;
font-size: 12px;
margin-top: 20px;
display: inline-block;
}
.services-list div:hover{
background: #ff004f;
transform: translateY(-10px);
}
/* -------portfolio----------- */
#portfolio{
padding: 50px 0;
}
.work-list{
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
grid-gap: 40px;
margin-top: 50px;
}
.work{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

border-radius: 10px;
position: relative;
overflow: hidden;
}
.work img{
width: 100%;
border-radius: 10px;
display: block;
transition: transform 0.5s;
}
.layer{
width: 100%;
height: 0;
background: linear-gradient(rgba(0,0,0,0.6), #ff004f);
border-radius: 10px;
position: absolute;
left: 0;
bottom: 0;
overflow: hidden;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
padding: 0 40px;
text-align: center;
font-size: 14px;
transition: height 0.5s;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.layer h3{
font-weight: 500;
margin-bottom: 20px;
}
.layer a{
margin-top: 20px;
color: #ff004f;
text-decoration: none;
font-size: 18px;
line-height: 60px;
background: #fff;
width: 60px;
height: 60px;
border-radius: 50%;
text-align: center;
}
.work:hover img{
transform: scale(1.1);
}
.work:hover .layer{
height: 100%;
}
.btn{
display: block;
margin: 50px auto;
width: fit-content;
border: 1px solid #ff004f;
padding: 14px 50px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

border-radius: 6px;
text-decoration: none;
color: #fff;
transition: background 0.5s;
}
.btn:hover{
background: #ff004f;
}

/* ---------contact-------- */
.contact-left{
flex-basis: 35%;
}
.contact-right{
flex-basis: 60%;
}
.contact-left p{
margin-top: 30px;
}
.contact-left p i{
color: #ff004f;
margin-right: 15px;
font-size: 25px;
}
.social-icons{
margin-top: 30px;
}
.social-icons a{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

text-decoration: none;
font-size: 30px;
margin-right: 15px;
color: #ababab;
display: inline-block;
transition: transform 0.5s;
}
.social-icons a:hover{
color: #ff004f;
transform: translateY(-5px);
}
.btn.btn2{
display: inline-block;
background: #ff004f;
}
.contact-right form{
width: 100%;
}
form input, form textarea{
width: 100%;
border: 0;
outline: none;
background: #262626;
padding: 15px;
margin: 15px 0;
color: #fff;
font-size: 18px;
border-radius: 6px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

}
form .btn2{
padding: 14px 60px;
font-size: 18px;
margin-top: 20px;
cursor: pointer;
}
.copyright{
width: 100%;
text-align: center;
padding: 25px 0;
background: #262626;
font-weight: 300;
margin-top: 20px;
}
.copyright i{
color: #ff004f;
}
.copyright a{
color: #ff004f;
text-decoration: none;
}
/* -----------------css for small screens--------- */
nav .fas{
display: none;
}

@media only screen and (max-width: 600px){

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

#header{
background-image: url(images/phone-background.jpeg);
}
.header-text{
margin-top: 100%;
font-size: 16px;
}
.header-text h1{
font-size: 30px;
}
nav .fas{
display: block;
font-size: 25px;
}
nav ul{
background: #ff004f;
position: fixed;
top: 0;
right: -200px;
width: 200px;
height: 100vh;
padding-top: 50px;
z-index: 2;
transition: right 0.5s;
}
nav ul li{
display: block;
margin: 25px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

}
nav ul .fas{
position: absolute;
top: 25px;
left: 25px;
cursor: pointer;
}
.sub-title{
font-size: 40px;
}
.about-col-1, .about-col-2{
flex-basis: 100%;
}
.about-col-1{
margin-bottom: 30px;
}
.about-col-2{
font-size: 14px;
}
.tab-links{
font-size: 16px;
margin-right: 20px;
}
.contact-left, .contact-right{
flex-basis: 100%;
}
.copyright{
font-size: 14px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

}
}
#msg{
color: #61b752;
margin-top: -40px;
display: block;
}

Script.js
let tablinks = document.getElementsByClassName("tab-links");
let tabcontents = document.getElementsByClassName("tab-contents");

function opentab(tabname){
for(tablink of tablinks){
tablink.classList.remove("active-link");
}
for(tabcontent of tabcontents){
tabcontent.classList.remove("active-tab");
}
event.currentTarget.classList.add("active-link");
document.getElementById(tabname).classList.add("active-tab");
}

let sidemeu = document.getElementById("sidemenu");


function openmenu(){
sidemeu.style.right = "0";
}
function closemenu(){
sidemeu.style.right = "-200px";

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

const scriptURL = '< add you own link here >' // add your own app script link here
const form = document.forms['submit-to-google-sheet']
const msg = document.getElementById("msg")

form.addEventListener('submit', e => {
e.preventDefault()
fetch(scriptURL, { method: 'POST', body: new FormData(form)})
.then(response => {
msg.innerHTML = "Message sent successfully"
setTimeout(function(){
msg.innerHTML = ""
},5000)
form.reset()
})
.catch(error => console.error('Error!', error.message))
})

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Thus, the portfolio website for yourself which gives details about yourself for a potential
recruiter using Html,Css and Javascript to created Web Application and output was executed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Ex.No:2 CREATE A WEB APPLICATION TO MANAGE THE TO-DO LIST OF USERS, WHERE USERS CAN LOGIN
AND MANAGE THEIR TO-DO ITEMS
Date:

Aim :
To Create a web application to manage the TO-DO list of users, where users can login and
manage their to-do items.
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a login page where users can enter their credentials to access their TO-DO list.
• Design a dashboard where users can view, add, edit, and delete their TO-DO items.
• Set up a user authentication system using JWT (JSON Web Tokens) or a similar mechanism.
• Store user data securely (e.g., password hashing) in a database.
• Design a database schema to store TO-DO items associated with each user.
• Set up a database connection (e.g., MongoDB).
• Create a registration page where new users can sign up.
• Implement a login functionality to authenticate users.
• Allow users to view their existing TO-DO items on the dashboard.
• Add an option to create new TO-DO items with a title, description, and due date.
• Provide the ability to edit or mark tasks as complete.
• Implement form validation on the registration and login pages.
• Ensure proper error handling throughout the application.
• Provide a logout button to allow users to securely log out from their accounts.
• Add sorting and filtering options for TO-DO items.
• Implement pagination for a better user experience if the list becomes lengthy.
• Thoroughly test the application for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the application for any performance or security issues.
• Update the application with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
App.js
import { useEffect, useState} from 'react'
import './App.css'
import Form from './Components/Form'
import Todo from './Components/Todo'

let App = () => {


let [ToDoArray, setToDoArray] = useState([]);
let [In,setIn]=useState(-1);
let [Str,setStr]=useState('');

let CollectInput = (Value) =>


{
if(Str!=='')
{
let Temp=[...ToDoArray];
Temp[In]=Value;
localStorage.setItem("Todo",JSON.stringify(Temp));
setToDoArray(Temp);

setStr('');
setIn(-1);
}
else
{
let Temp=[Value,...ToDoArray];
localStorage.setItem("Todo",JSON.stringify(Temp));
setToDoArray(Temp);
}
}

let Delete=(Ind)=>
{
let newArr=[...ToDoArray];
newArr.splice(Ind,1);
localStorage.setItem("Todo",JSON.stringify(newArr));
setToDoArray(newArr);
}

let EditText=(Ind,Elem)=>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

{
setIn(Ind);
setStr(Elem);
};
useEffect(()=>
{
let Ar=JSON.parse(localStorage.getItem("Todo"));
if(Ar)
setToDoArray(Ar);
},[])
return (
<div className='App'>
<div className="App-Content">
<Form Take={CollectInput}
Icon={In===-1?"fa-solid fa-plus":"fa-solid fa-marker"}
String={Str===''? '':Str}

/>

{
ToDoArray.length === 0 ? <div className="alert alert-success mt-2" role="alert">
No To Do Available Yet !!
</div> :

<Todo GetTodos={ToDoArray} Del={Delete} Edit={EditText}/>


}
</div>
</div>
)
}
export default App;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

/Components/Form.js
import { useEffect, useState } from 'react'
import './Form.css'

let Form=(Props)=>
{
let [Text,setText]=useState('');
let HandleInput=(Inp)=>
{
setText(Inp);
}
let HandleClick=()=>
{
Text===''?alert("Text Filed Can't Be Empty"):Props.Take(Text)
setText('');
}
useEffect(() => {
setText(Props.String)
}, [Props.String])

return(
<div className="Form">
<input type="text" placeholder='Enter any To Do ...' value={Text}
onChange={(Event)=>{HandleInput(Event.target.value)}}/>
<div className='Plus' onClick={()=>{HandleClick()}}>

<i className={Props.Icon} ></i>


</div>
</div>
)
}

export default Form;

/Components/Todo.js
import React from 'react'
import './Todo.css'

const Todo = (Props) => {


return (
<div className='Todo'>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

{
Props.GetTodos.map((Elem,Ind)=>
{
return(
<div className="All-Todo" key={Ind}>
<p>{Elem}</p>
<i className="fa-solid fa-marker E "
onClick={()=>{Props.Edit(Ind,Elem)}}></i>
<i className="fa-solid fa-circle-xmark X"
onClick={()=>{Props.Del(Ind)}}></i>
</div>
)
})
}
</div>
)
}

export default Todo;

Output:

Result:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

EX.NO : 3 CREATE A SIMPLE MICRO BLOGGING APPLICATION (LIKE TWITTER) THAT ALLOWS PEOPLE TO POST THEIR
Thus the Create a web application to manage the TO-DO list of users, where users can login and
CONTENT WHICH CAN BE VIEWED BY PEOPLE WHO FOLLOW THEM.
manage their to-do items successfully developed.
DATE :

Aim :
To Create a simple micro blogging application (like twitter) that allows people to post their
content which can be viewed by people who follow them.
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a landing page where users can log in or sign up.
• Design a dashboard where users can view and post their micro-blog content.
• Set up a user authentication system using JWT (JSON Web Tokens) or a similar mechanism.
• Store user data securely (e.g., password hashing) in a database.
• Design a database schema to store user information, followers, and micro-blog posts.
• Set up a database connection (e.g., MongoDB).
• Create a registration page where new users can sign up.
• Implement a login functionality to authenticate users.
• Allow users to create new micro-blog posts with a limited character count (like Twitter).
• Display the latest posts on the dashboard in reverse chronological order.
• Add buttons or links to follow or unfollow other users.
• Update the user's dashboard to show posts from people they follow.
• Implement form validation on the registration and login pages.
• Ensure proper error handling throughout the application.
• Implement real-time updates using WebSockets for new posts and notifications.
• Allow users to like, comment, or share posts.
• Thoroughly test the application for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the application for any performance or security issues.
• Update the application with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
App.js
import React, { useState } from "react";

const App = () => {


const [posts, setPosts] = useState([]);
const [following, setFollowing] = useState(false);

const handlePostSubmit = (content) => {


const newPost = {
id: Date.now(),
content: content,
};
setPosts([...posts, newPost]);
};

const handleFollowToggle = () => {


setFollowing((prevFollowing) => !prevFollowing);
};

return (
<div
style={{
margin: "20px",
padding: "10px",
maxWidth: "500px",
textAlign: "center",
border: "1px solid #ccc",
borderRadius: "10px",
}}
>
<h1 style={{ color: "teal" }}>Colorful Micro Blogging App</h1>

<button
onClick={handleFollowToggle}
style={{
backgroundColor: following ? "red" : "green",
color: "white",
borderRadius: "5px",
padding: "5px 10px",

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

marginBottom: "10px",
}}
>
{following ? "Unfollow" : "Follow"}
</button>
<PostForm onSubmit={handlePostSubmit} />
<div>
{posts.map((post) => (
<Post key={post.id} content={post.content} />
))}
</div>
</div>
);
};

const PostForm = ({ onSubmit }) => {


const [content, setContent] = useState("");

const handleSubmit = (e) => {


e.preventDefault();
onSubmit(content);
setContent("");
};

return (

<form onSubmit={handleSubmit}>
<textarea
value={content}
onChange={(e) => setContent(e.target.value)}
placeholder="What's on your mind?"
rows="4"
cols="50"
required
style={{ marginBottom: "10px", padding: "5px" }}
/>
<br />
<button
type="submit"
style={{
backgroundColor: "teal",
color: "white",
borderRadius: "5px",

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

padding: "5px 10px",


}}
>
Post
</button>
</form>
);
};

const Post = ({ content }) => {


return (
<div
style={{
backgroundColor: "lightblue",
padding: "10px",
marginBottom: "10px",
borderRadius: "5px",
}}
>
{content}
</div>
);
};

export default App;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Output:

Result:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

EX.NO :Thus
4 CREATE A FOOD
the Create DELIVERY
a simple WEBSITE
micro WHERE
blogging USERS CAN
application (likeORDER
twitter)FOOD FROM Apeople
that allows PARTICULAR
to postRESTAURANT
their
LISTED IN THE WEBSITE
content which can be viewed by people who follow them. successfully developed.
DATE :

Aim :
To Create a food delivery website where users can order food from a particular restaurant listed
in the website.
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a homepage where users can view the list of restaurants.
• Design restaurant pages with their menus and food items.
• If required, set up a user authentication system using JWT (JSON Web Tokens) or a similar
mechanism.
• Allow users to sign up, log in, and manage their profiles.
• Design a database schema to store restaurant information, menus, and food items.
• Set up a database connection (e.g., MongoDB).
• Display a list of restaurants on the homepage.
• Allow users to click on a restaurant to view its menu and food items.
• Allow users to add food items to their cart.
• Calculate the total order amount and display it in the cart.
• Create a checkout page where users can review their order and provide delivery details.
• Integrate a payment gateway to process payments securely.
• Display an order confirmation page after successful payment.
• Send a confirmation email to the user and the restaurant.
• Implement form validation on the checkout page and other user input forms.
• Ensure proper error handling throughout the application.
• Provide search and filter options for restaurants and food items.
• Implement real-time updates for order status (e.g., "Order placed," "Out for delivery").
• Create an admin panel for restaurant owners to manage their menus and orders.
• Thoroughly test the website for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the website for any performance or security issues.
• Update the website with new features and improvements as needed

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
import React, { useState } from "react";

const restaurantsData = [
{
id: 1,
name: "Delicious Diner",
menu: [
{ id: 101, name: "Burger", price: 8.99 },
{ id: 102, name: "Pizza", price: 12.99 },
{ id: 103, name: "Salad", price: 6.99 },
],
},
// Add more restaurant data as needed
];

const App = () => {


const [selectedRestaurant, setSelectedRestaurant] = useState(null);
const [order, setOrder] = useState([]);

const handleRestaurantSelect = (restaurant) => {


setSelectedRestaurant(restaurant);
setOrder([]);
};

const handleOrderItemAdd = (item) => {


setOrder([...order, item]);
};

const handleOrderItemRemove = (itemId) => {


setOrder(order.filter((item) => item.id !== itemId));

};

const handleOrderSubmit = () => {


// Handle order submission (e.g., display a confirmation, send to backend, etc.)
alert("Order placed successfully!");
};

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

return (
<div style={{ backgroundColor: "#f9f9f9", padding: "20px" }}>
<h1 style={{ color: "#3f51b5", marginBottom: "20px" }}>
Food Delivery Website
</h1>
<div>
<h2 style={{ color: "#009688", marginBottom: "10px" }}>Restaurants</h2>
<ul style={{ listStyle: "none", padding: "0" }}>
{restaurantsData.map((restaurant) => (
<li key={restaurant.id}>
<button
style={{
backgroundColor: "#4caf50",
color: "#fff",
padding: "8px 16px",
border: "none",
marginRight: "10px",
marginBottom: "10px",
}}
onClick={() => handleRestaurantSelect(restaurant)}
>
{restaurant.name}
</button>
</li>
))}

</ul>
</div>

{selectedRestaurant && (
<div>
<h2 style={{ color: "#009688", marginBottom: "10px" }}>
Menu - {selectedRestaurant.name}
</h2>
<ul style={{ listStyle: "none", padding: "0" }}>
{selectedRestaurant.menu.map((item) => (
<li key={item.id}>
<span style={{ color: "#3f51b5", marginRight: "10px" }}>
{item.name}
</span>
<span style={{ color: "#009688" }}>₹{item.price}</span>
<button
style={{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

backgroundColor: "#3f51b5",
color: "#fff",
padding: "5px 10px",
border: "none",
marginLeft: "10px",
margin: "20px",
}}
onClick={() => handleOrderItemAdd(item)}
>
Add to Order
</button>
</li>
))}
</ul>
</div>

)}

{order.length > 0 && (


<div>
<h2 style={{ color: "#009688", marginBottom: "10px" }}>Your Order</h2>
<ul style={{ listStyle: "none", padding: "0" }}>
{order.map((item) => (
<li key={item.id} style={{ marginBottom: "5px" }}>
<span style={{ color: "#3f51b5", marginRight: "10px" }}>
{item.name}
</span>
<span style={{ color: "#009688" }}>₹{item.price}</span>
<button
style={{
backgroundColor: "#e91e63",
color: "#fff",
padding: "5px 10px",
border: "none",
marginLeft: "10px",
}}
onClick={() => handleOrderItemRemove(item.id)}
>
Remove
</button>
</li>
))}
</ul>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<button
style={{
backgroundColor: "#4caf50",
color: "#fff",
padding: "8px 16px",

border: "none",
marginTop: "10px",
}}
onClick={handleOrderSubmit}
>
Place Order
</button>
</div>
)}
</div>
);
};

export default App;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result :
EX.NO : 5Thus the CreateDEVELOP A CLASSIFIEDS
a food delivery WEB
website APPLICATION
where users canTO BUYfood
order AND from
SELL USED PRODUCTS.
a particular restaurant
DATE : listed in the website successfully developed.

Aim :
To Develop a classifieds web application to buy and sell used products.
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a homepage where users can view the list of available products.
• Design pages for product listings, product details, and user profiles.
• If required, set up a user authentication system using JWT (JSON Web Tokens) or a similar
mechanism.
• Allow users to sign up, log in, and manage their profiles.
• Design a database schema to store product information, user data, and product categories.
• Set up a database connection (e.g., MongoDB).
• Allow users to create new product listings with details like title, description, price, and
category. • Display a list of available products on the homepage.
• Provide search and filter functionality for users to find specific products easily.
• Create a product details page with more information about each product.
• Include a contact option for users interested in buying a product.
• Implement a messaging system to allow users to communicate securely within the platform.
• Allow users to edit or delete their own product listings.
• Implement real-time updates for new product listings and messages (if applicable).
• Provide a user-friendly interface and intuitive navigation.
• Create an admin panel to manage reported listings and user accounts.
• Implement form validation on the product creation and user input forms.
• Ensure proper error handling throughout the application.
• Thoroughly test the application for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the website for any performance or security issues.
• Update the application with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
app.component.ts
import { Component } from '@angular/core';

@Component({ selector: 'app-root',


templateUrl: './app.component.html', styleUrls: ['./app.component.css'],
})
export class AppComponent { title = 'Classifieds App'; products = [
{
id: 1,
name: 'Used Laptop',
description: 'Good condition, 8GB RAM, 256GB SSD', price: 400,
},
{
id: 2,
name: 'Smartphone',
description: 'Brand new, 128GB storage, 5.5" display', price: 250,
},
{
id: 3,
name: 'Gaming Console',
description: 'Includes two controllers and three games', price: 300,
},
{
id: 4,

name: 'Wireless Headphones',


description: 'Noise-cancelling, 20-hour battery life', price: 100,
},
];

onBuyClick(product: any) {
alert(`You have bought ${product.name} for $${product.price}`);
}
}
app.component.html
<div class="app-container">

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<h1 class="app-title">{{ title }}</h1>


<div class="vie">
<div class="product-details" *ngFor="let product of products">
<h2 class="product-name">{{ product.name }}</h2>
<p class="product-description">{{ product.description }}</p>
<p class="product-price">Price: ${{ product.price }}</p>
<button class="buy-button" (click)="onBuyClick(product)">Buy Now</button>
</div>
</div>
</div>
app.component.css
/* Global styles */ body {
font-family: Arial, sans-serif; margin: 0;
padding: 0;
}
/* App container styles */
.app-container { background-color: #f9f9f9;

padding: 20px; text-align: center;


}

/* Title styles */
.app-title { color: #3f51b5;
margin-bottom: 20px;
}
.vie {
display: flex;
}
/* Product details styles */
.product-details { background-color: #fff; border: 1px solid #ccc; padding: 20px;
max-width: 400px; margin: 0 auto;
}

.product-name { color: #009688;


margin-bottom: 10px;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.product-description { color: #3f51b5;


}

.product-price { color: #009688;

.buy-button {
background-color: #4caf50; color: #fff;
padding: 8px 16px; border: none; cursor: pointer; margin-top: 10px; font-size: 16px; border-
radius: 4px;
transition: background-color 0.2s ease;
}

.buy-button:hover { background-color: #45a049;


}

Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Thus the Develop a classifieds web application to buy and sell used products successfully
EX.NO : 6developed. DEVELOP A LEAVE MANAGEMENT SYSTEM FOR AN ORGANIZATION WHERE USERS CAN APPLY
DIFFERENT TYPES OF LEAVES SUCH AS CASUAL LEAVE AND MEDICAL LEAVE. THEY
ALSO CAN VIEW THE AVAILABLE NUMBER OF DAYS
DATE :

Aim:
To Develop a leave management system for an organization where users can apply different
types of leaves such as casual leave and medical leave. They also can view the available number
of days.
Algorithm:
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a login page where users (employees) can log in to the system.
• Design a dashboard where users can view their leave balance and apply for different types of
leaves.
• Set up a user authentication system using JWT (JSON Web Tokens) or a similar mechanism.
• Store user data securely (e.g., password hashing) in a database.
• Design a database schema to store user information, leave types, and leave applications.
• Set up a database connection (e.g., MongoDB).
• Fetch and display the available number of days for each leave type (casual, medical) on the
user's dashboard.
• Implement a leave application form where users can request specific leave types with start and
end dates.
• Validate leave applications to ensure they fall within the available leave balance.
• Create an admin panel where authorized personnel can view and approve leave applications.
• Allow admins to accept or reject leave requests, updating the leave balance accordingly.
• Implement form validation on the leave application and user input forms.
• Ensure proper error handling throughout the application.
• Provide real-time updates for leave application status (e.g., "Pending," "Approved,"
"Rejected"). • Send notifications to users for application status changes.
• Differentiate between regular users and admin users to access the admin panel.
• Create a leave history page where users can view their past leave applications and their
statuses. • Thoroughly test the system for functionality and usability.
• Fix any bugs or issues that arise during testing.Choose a hosting provider and deploy the
application on a web server.
• Regularly monitor the system for any performance or security issues.
• Update the system with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
app.component.ts
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'leave-management-system';
}

app.component.html
<div class="app-container">
<h1 class="app-title">Leave Management System</h1>
<nav>
<ul class="nav-links">
<li><a routerLink="/apply-leave">Apply Leave</a></li>
<li><a routerLink="/leave-balance">Leave Balance</a></li>
</ul>
</nav>
<router-outlet></router-outlet>
</div>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

app.component.css
/* Reset default margin and padding for the entire page */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
li {
margin: 0;
padding: 0;
}

/* Set a background color for the app-container */


.app-container {
background-color: #f9f9f9;
padding: 20px;
font-family: Arial, sans-serif;
}

/* Style the title */


.app-title {
color: #3f51b5;
margin-bottom: 20px;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

/* Style the navigation menu */


.nav-links {
list-style: none;
display: flex;
gap: 20px;
}

.nav-links li {
display: inline;
}

.nav-links li a {
text-decoration: none;
color: #009688;
font-weight: bold;
padding: 10px 15px;
border-radius: 5px;
transition: background-color 0.2s ease;
}

.nav-links li a:hover {
background-color: #009688;
color: #fff;
}

Leave-application.component.ts
import { Component } from '@angular/core';

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

@Component({
selector: 'app-leave-application',
templateUrl: './leave-application.component.html',
styleUrls: ['./leave-application.component.css'],
})
export class LeaveApplicationComponent {
leaveTypes = ['Casual Leave', 'Medical Leave'];
selectedLeaveType!: string;
startDate!: string;
endDate!: string;
reason!: string;
value: string = '';
casualLeaveBalance = 10;
medicalLeaveBalance = 5;

applyLeave() {
if (this.selectedLeaveType === 'Casual Leave' && this.casualLeaveBalance > 0) {
this.casualLeaveBalance -= 1;

console.log('Casual Leave applied.');


} else if (this.selectedLeaveType === 'Medical Leave' && this.medicalLeaveBalance > 0) {
this.medicalLeaveBalance -= 1;
this.value = `Medical Leave applied.
Leave Type: ${this.selectedLeaveType}
Start Date: ${this.startDate}
End Date: ${this.endDate}
Reason: ${this.reason}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Remaining Leave Balance In Casual:${this.casualLeaveBalance}


Remaining Leave Balance In Medical:${this.medicalLeaveBalance}`;

} else {
console.log('Insufficient leave balance for the selected leave type.');
}
}
}
leave-application.component.html
<div class="leave-application">
<h2 class="app-title">Apply for Leave</h2>
<div>
<label for="leaveType" class="input-label">Leave Type:</label>
<select id="leaveType" class="input-field" [(ngModel)]="selectedLeaveType">
<option *ngFor="let type of leaveTypes" [value]="type">{{ type }}</option>
</select>
</div>
<div>
<label for="startDate" class="input-label">Start Date:</label>
<input
type="date"
id="startDate"
class="input-field"
[(ngModel)]="startDate"
/>
</div>
<div>
<label for="endDate" class="input-label">End Date:</label>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<input type="date" id="endDate" class="input-field" [(ngModel)]="endDate" />


</div>
<div>
<label for="reason" class="input-label">Reason:</label>
<textarea
id="reason"
class="input-field"
[(ngModel)]="reason"
required
></textarea>
</div>
<button class="apply-button" (click)="applyLeave()">Apply</button>
<div *ngIf="value">
<h2 class="app-title">Leave Approved Details:</h2>
<p>{{ value }}</p>
</div>
</div>

leave-application.component.css
.leave-application {
background-color: #f9f9f9;
padding: 20px;
max-width: 400px;
margin: 0 auto;
border: 1px solid #ccc;
border-radius: 8px;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.app-title {

color: #3f51b5;
margin-bottom: 20px;
}

.input-label {
color: #009688;
margin-bottom: 8px;
}

.input-field {
width: 100%;
padding: 8px;
margin-bottom: 15px;
border: 1px solid #ccc;
border-radius: 4px;
}

.apply-button {
background-color: #4caf50;
color: #fff;
padding: 8px 16px;
border: none;
cursor: pointer;
font-size: 16px;
border-radius: 4px;
transition: background-color 0.2s ease;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.apply-button:hover {
background-color: #45a049;
}

leave-balance.component.ts
import { Component } from '@angular/core';

@Component({
selector: 'app-leave-balance',
templateUrl: './leave-balance.component.html',
styleUrls: ['./leave-balance.component.css'],
})
export class LeaveBalanceComponent {
casualLeaveBalance = 10;
medicalLeaveBalance = 5;
}
leave-balance.component.html
<div class="leave-balance">
<h2 class="app-title">Leave Balance</h2>
<p class="leave-details">Casual Leave: {{ casualLeaveBalance }} days</p>
<p class="leave-details">Medical Leave: {{ medicalLeaveBalance }} days</p>
</div>
leave-balance.component.css
.leave-balance {
background-color: #f9f9f9;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

padding: 20px;
max-width: 400px;
margin: 0 auto;
border: 1px solid #ccc;
border-radius: 8px;
}

.leave-details {
color: #009688;
margin-bottom: 8px;
}
.app-title {
color: #3f51b5;
margin-bottom: 20px;
}
Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Thus the Develop a leave management system for an organization where users can apply
EX.NO : 7different types
DEVELOP A SIMPLE
of leaves DASHBOARD
such FOR PROJECT
as casual leave MANAGEMENT
and medical leave. TheyWHERE THEview
also can STATUSES OF VARIOUS
the available
DATE : number of TASKS
days successfully developed.
ARE AVAILABLE. NEW TASKS CAN BE ADDED AND THE STATUS OF EXISTING TASKS CAN BE

CHANGED AMONG PENDING, INPROGRESS OR COMPLETED.

Aim :
To Develop a simple dashboard for project management where the statuses of various tasks are
available. New tasks can be added and the status of existing tasks can be changed among
Pending, InProgress or Completed.
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a dashboard page where users can view the list of tasks and their statuses.
• Design a form to add new tasks and allow users to change the status of existing tasks.
• Design a data model to represent each task with attributes such as title, description, and status
(Pending, InProgress, Completed).
• Set up a database connection (e.g., MongoDB) to store task data.
• Fetch and display the list of tasks and their corresponding statuses on the dashboard.
• Implement a form to allow users to add new tasks with a title, description, and default status
(e.g., Pending).
• Provide options or buttons for users to change the status of existing tasks among Pending,
InProgress, or Completed.
• Update the task status in the database when a user makes changes.
• Implement form validation for adding new tasks.
• Ensure proper error handling throughout the application.
• Use visual cues (e.g., color-coding) to differentiate between task statuses.
• Implement real-time updates using WebSockets for status changes.
• Thoroughly test the dashboard for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the dashboard for any performance or security issues.
• Update the dashboard with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
App.js:
import React, { useState } from "react";
import './App.css'

const StatusColors = {
Pending: "#ff5252",
InProgress: "#ffc107",
Completed: "#4caf50",
};

const App = () => {


const [tasks, setTasks] = useState([
{ id: 1, title: "Task 1", status: "Pending" },
{ id: 2, title: "Task 2", status: "InProgress" },
{ id: 3, title: "Task 3", status: "Completed" },
]);

const [inputText, setInputText] = useState("");


const [editingTaskId, setEditingTaskId] = useState(null);

const handleStatusChange = (taskId, newStatus) => {


const updatedTasks = tasks.map((task) =>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

task.id === taskId ? { ...task, status: newStatus } : task


);
setTasks(updatedTasks);
};

const handleTaskAdd = (newTaskTitle) => {


const newTask = {
id: tasks.length + 1,
title: newTaskTitle,

status: "Pending",
};
setTasks([...tasks, newTask]);
setInputText("");
};

const handleTaskEdit = (taskId, newTitle) => {


const updatedTasks = tasks.map((task) =>
task.id === taskId ? { ...task, title: newTitle } : task
);
setTasks(updatedTasks);
setEditingTaskId(null);
};

const handleTaskRemove = (taskId) => {


const updatedTasks = tasks.filter((task) => task.id !== taskId);
setTasks(updatedTasks);
};

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

return (
<div className="app-container">
<h1 className="app-title">Project Management Dashboard</h1>
<div className="task-list">
{tasks.map((task) => (
<div key={task.id} className="task">
<h3 onClick={() => setEditingTaskId(task.id)}>{task.title}</h3>
<div className="status-buttons">
<button
style={{ backgroundColor: StatusColors.Pending }}
onClick={() => handleStatusChange(task.id, "Pending")}
>
Pending
</button>
<button
style={{ backgroundColor: StatusColors.InProgress }}
onClick={() => handleStatusChange(task.id, "InProgress")}
>
In Progress
</button>
<button
style={{ backgroundColor: StatusColors.Completed }}
onClick={() => handleStatusChange(task.id, "Completed")}
>
Completed
</button>
</div>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<button
className="remove-task-button"
onClick={() => handleTaskRemove(task.id)}
>
Remove Task
</button>
</div>
))}
</div>
<div className="add-task">
<input
type="text"
placeholder="New Task Title"
value={inputText}
onChange={(e) => setInputText(e.target.value)}
/>
<button onClick={() => handleTaskAdd(inputText)}>Add Task</button>
</div>

{editingTaskId !== null && (


<div className="modal">
<div className="modal-content">
<h2>Edit Task</h2>
<input
type="lable"
value={
tasks.find((task) => task.id === editingTaskId)?.title || ""
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

onChange={(e) => setInputText(e.target.value)}


/>
<div className="modal-buttons">
<button onClick={() => setEditingTaskId(null)}>Cancel</button>
<button
onClick={() => {
const editedTask = tasks.find(
(task) => task.id === editingTaskId
);
if (editedTask) {
handleTaskEdit(editingTaskId, inputText);
}
}}
>
Save
</button>
</div>
</div>
</div>
)}
</div>
);
};

export default App;


App.css
body {

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

margin: 0;
padding: 0;
font-family: Arial, sans-serif;
}

.app-container {
background-color: #f1f1f1;
padding: 20px;
}

.app-title {
color: #333;
margin-bottom: 20px;
text-align: center;
}

.task-list {
display: flex;
flex-wrap: wrap;
}

.task {
border: 1px solid #ccc;
background-color: #fff;
padding: 10px;
margin: 10px;
width: 400px;
border-radius: 8px;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);


}

/* ... (existing styles) ... */

.remove-task-button {
background-color: #f44336;
color: #fff;
border: none;
padding: 8px 16px;
cursor: pointer;
border-radius: 4px;
margin-top: 10px;
}

.remove-task-button:hover {
background-color: #d32f2f;
}

.remove-task-button:focus {
outline: none;
}

h3 {
margin-top: 0;
margin-bottom: 10px;
}

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

.status-buttons {
display: flex;
justify-content: space-between;
margin-top: 10px;
}

.status-buttons button {
color: #fff;
border: none;
padding: 5px 10px;
cursor: pointer;
border-radius: 4px;
}

.pending {
background-color: #ff5252;
}

.inprogress {
background-color: #ffc107;
}

.completed {
background-color: #4caf50;
}

.add-task {
display: flex;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

margin-top: 20px;
align-items: center;
}

.add-task input {
padding: 8px;
margin-right: 10px;
border: 1px solid #ccc;
border-radius: 4px;
}

.add-task button {
background-color: #3f51b5;
color: #fff;
border: none;
padding: 8px 16px;
cursor: pointer;
border-radius: 4px;
}
Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Thus the Develop a simple dashboard for project management where the statuses of various tasks
are available. New tasks can be added and the status of existing tasks can be changed among
Ex.No: 8Pending, InProgress
DEVELOP ANor Completed
ONLINE successfully
SURVEY developed.WHERE A COLLECTION OF QUESTIONS
APPLICATION
Date: IS AVAILABLE AND USERS ARE ASKED TO ANSWER ANY RANDOM
5 QUESTIONS

Aim:
To Develop an online survey application where a collection of questions is available and users
are asked to answer any random 5 questions
Algorithm:
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files). • Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a landing page where users can start the survey.
• Design a page to display random survey questions to the users.
• Design a data model to store survey questions along with their options and correct answers.
• Set up a database connection (e.g., MongoDB) to store survey data.
• Fetch random survey questions from the database when the user starts the survey.
• Display these questions one by one to the user.
• Provide options for users to select answers for each question.
• Store the user's answers in the database for further analysis.
• Set a limit of 5 random questions per survey for users to answer.
• If desired, calculate the user's score based on their answers and store it in the database.
• Implement proper validation to ensure users answer all the questions.
• Ensure proper error handling throughout the application.
• Provide a progress indicator to show users how many questions are left.
• Add visual feedback to indicate correct and incorrect answers (if applicable).
• Thoroughly test the survey application for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server.
• Regularly monitor the application for any performance or security issues.
• Update the application with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Program:
Surveymain.js
import React, { useState } from "react"; import questions from "./questions"; import
"./Survey.css";
function App() {
const [questionIndex, setQuestionIndex] = useState(0); const [score, setScore] = useState(0);
const [results, setResults] = useState(false);
const [wrongAnswers, setWrongAnswers] = useState([]); const replay = () => {
setQuestionIndex(0); setScore(0); setResults(false); setWrongAnswers([]);
};

const presentQuestion = questions[questionIndex]; const getChoice = (index) => {


if (presentQuestion.answer === index) { setScore(score + 1);
} else {
setWrongAnswers([...wrongAnswers, questionIndex]);
}

const nextQuestion = questionIndex + 1; if (nextQuestion < questions.length)


{ setQuestionIndex(nextQuestion);
} else { setResults(true);
}

};

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

const prevQuestion = () => { if (questionIndex > 0) {


setQuestionIndex(questionIndex - 1);
}
};

return (
<>
<h1>Online Survey Application</h1>
<div className="quiz_box">
{results ? (
<>
<h1>Score: {score}</h1>
<p>Correct Answers: {score}</p>
<p>Wrong Answers: {wrongAnswers.length}</p>
<br />
<button onClick={replay}>Play Again</button>
</>
):(
<>
<div className="quiz_question">
{presentQuestion.question}
<div className="quiz_box_options"></div>
<ul className="quiz_ul">
{presentQuestion.options.map((option, i) => { return (
<li className="quiz_li" onClick={() => getChoice(i)}>
{option}
</li>
);

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

})}
</ul>
</div>
<button
className="previous-question" // Add the class name here onClick={prevQuestion}
disabled={questionIndex === 0}
>
Previous Question
</button>
</>
)}
</div>
</>
);
}

export default App; questions.js export default [


{
question: "What is the purpose of JavaScript?", options: [
"To style HTML elements",
"To add interactivity to web pages", "To create database queries",
"To define the structure of a web page",
],
answer: 1, // The correct answer is option 2
},
{
question: "What does CSS stand for?",

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

options: [
"Cascading Style Sheet", "Creative Style Sheet", "Computer Style Sheet", "Colorful Style
Sheet",
],
answer: 0, // The correct answer is option 1
},
{
question:
"Which programming language is used for building web applications?", options: ["Python",
"Java", "C#", "JavaScript"],
answer: 3, // The correct answer is option 4
},
{
question: "What does HTML stand for?", options: [
"Hypertext Markup Language", "Hypertext Model Language", "Hyperloop Model Language",
"High-level Markup Language",
],
answer: 0, // The correct answer is option 1
},
{
question: "What is the primary function of a database management system?", options: [
"To create and format web pages", "To manage data and databases",
"To handle network communication", "To design graphical user interfaces",
],

answer: 1, // The correct answer is option 2


},
{

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

question:
"Which data type is used for storing whole numbers in JavaScript?", options: ["number",
"string", "boolean", "integer"],
answer: 0, // The correct answer is option 1
},
{
question: "Which symbol is used for single-line comments in JavaScript?", options: ["//", "/*",
"#", "%%"],
answer: 0, // The correct answer is option 1
},
{
question: "What is the latest version of ECMAScript?", options: ["ES5", "ES6", "ES7", "ES8"],
answer: 3, // The correct answer is option 4
},
{
question: "Which keyword is used for declaring variables in JavaScript?", options: ["let", "var",
"const", "int"],
answer: 1, // The correct answer is option 2
},
{
question: "Which programming language is used for developing Android apps?", options:
["Java", "Python", "C#", "Swift"],
answer: 0, // The correct answer is option 1
},
];

Survey.css
/* Survey.css */
body {
font-family: Arial, sans-serif;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

background-color: #f0f0f0;
margin: 0;
padding: 0;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
}
.quiz_box {
background-color: #ffffff;
border-radius: 10px;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
padding: 20px;
max-width: 500px;
width: 100%;
text-align: center;
}

.quiz_question {
margin-bottom: 20px;
}

.quiz_box_options {
margin-bottom: 20px;
}

.quiz_ul {

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

list-style: none;
padding: 0;
display: flex;
flex-direction: column;
align-items: center;
}

.quiz_li {
background-color: #3f51b5;
color: #ffffff;
border-radius: 5px;
padding: 10px 20px;
cursor: pointer;
margin: 5px;
transition: background-color 0.3s ease;
}
.quiz_li:hover {
background-color: #2c387e;
}
h1 {
color: #3f51b5;
font-size: 40px;
margin-bottom: 10px;
}

button {
background-color: #3f51b5;
color: #ffffff;

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

border: none;
border-radius: 5px;
padding: 10px 20px;
cursor: pointer;
font-size: 16px;
transition: background-color 0.3s ease;
}
button:hover {
background-color: #2c387e;
}
.quiz_box button.previous-question {
background-color: green;
color: white;
padding: 10px 20px;
border: none;
cursor: pointer;
margin-top: 10px;
}
.quiz_box button.previous-question:hover {
background-color: darkgreen;
}
Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:

Thus the Develop an online survey application where a collection of questions is available and
users are asked to answer any random 5 questions successfully developed.
Ex.No:9 DEVELOP TO-DO APPLICATION USING NODE JS,EXPRESS JS AND
Date:
MONGODB

Aim :
To Create a web application to manage the TO-DO list of users, where users can login
and manage their to-do items
Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files).
• Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a login page where users can enter their credentials to access their TO-DO list.
• Design a dashboard where users can view, add, edit, and delete their TO-DO items.
• Set up a user authentication system using JWT (JSON Web Tokens) or a similar mechanism.
• Store user data securely (e.g., password hashing) in a database.
• Design a database schema to store TO-DO items associated with each user.
• Set up a database connection (e.g., MongoDB).
• Create a registration page where new users can sign up.
• Implement a login functionality to authenticate users.
• Allow users to view their existing TO-DO items on the dashboard.
• Add an option to create new TO-DO items with a title, description, and due date. • Provide the
ability to edit or mark tasks as complete.
• Implement form validation on the registration and login pages.
• Ensure proper error handling throughout the application.
• Provide a logout button to allow users to securely log out from their accounts.
• Add sorting and filtering options for TO-DO items.
• Implement pagination for a better user experience if the list becomes lengthy.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

• Thoroughly test the application for functionality and usability.


• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server
• Regularly monitor the application for any performance or security issues.
• Update the application with new features and improvements as needed.

//FrontEnd
Create.jsx

import React, {useState} from 'react'


import axios from 'axios'

function Create() {
const[task,setTask]=useState()
const handleAdd=(e)=>{
e.preventDefault()
axios.post("http://localhost:3001/add",{task} )
.then(result=>location.reload())
.catch(err=>console.log(err))
}
return (
<div className='create_form'>
<input type="text"
placeholder='Enter Task'
onChange={(e)=>setTask(e.target.value)}/>
<button type="button" onClick={handleAdd}>Add</button>
</div>
)
}

export default Create

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Home.jsx

import React, {useState, useEffect} from 'react'


import Create from './Create'
import axios from 'axios'
import { BsCircleFill } from 'react-icons/bs'
import { BsFillTrashFill, BsFillCheckCircleFill} from 'react-icons/bs'

function Home() {
const [todos,setTodos]=useState([])
useEffect(()=>{
axios.get('http://localhost:3001/get')
.then(result=>setTodos(result.data))
.catch(err=>console.log(err))
},[])

const handleEdit=(id)=>{
axios.put('http://localhost:3001/update/'+id)
.then(result=>location.reload())
.catch(err=>console.log(err))
}

const handleDelete=(id)=>{
axios.delete('http://localhost:3001/delete/'+id)
.then(result=>location.reload())
.catch(err=>console.log(err))
}
return (
<div className='home'>
<h1>Todo List</h1>
<Create/>
<br/>
{
todos.length === 0
?
<div><h2>No Record</h2></div>
:
todos.map(todo=>(
<div key={todo.id} className='task'>
<div className='checkbox' onClick={()=>handleEdit(todo._id)}>
{todo.done ? <BsFillCheckCircleFill></BsFillCheckCircleFill>
:
<BsCircleFill className='icon'/>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

<p className={todo.done ? "line_through" : ""}>{todo.task}</p>


</div>
<div>
<span><BsFillTrashFill className='icon'
onClick={()=>handleDelete(todo._id)}/></span>
</div>
</div>
))
}
</div>
)
}

export default Home

//BackEnd
index.js

const express=require('express')
const mongoose= require('mongoose')
const cors=require('cors')
const TodoModel = require('./Models/Todo')

const app=express()
app.use(cors())
app.use(express.json())

mongoose.connect('mongodb://127.0.0.1:27017/test')

app.get('/get',(req,res)=>{
TodoModel.find()
.then(result=>res.json(result))
.catch(err=>res.json(err))
})
app.put('/update/:id',(req,res)=>{
const{id}=req.params;
TodoModel.findByIdAndUpdate({_id:id}, {done:true})
.then(result=>res.json(result))
.catch(err=>res.json(err))
})

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

app.delete('/delete/:id',(req,res)=>{
const{id}=req.params;
TodoModel.findByIdAndDelete({_id:id})
.then(result=>res.json(result))
.catch(err=>res.json(err))
})

app.post('/add',(req,res)=>{
const task=req.body.task;
TodoModel.create({
task:task
})
.then(result=>res.json(result))
.catch(err=>res.json(err))
})
app.listen(3001,()=>{
console.log("Server is Running")
})

Models/Todo.js

const mongoose=require('mongoose')
const TodoSchema = new mongoose.Schema({
task:String,
done:{
type:Boolean,
default:false
}
})
const TodoModel=mongoose.model("todos",TodoSchema)
module.exports=TodoModel

Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Ex.No:10Thus, the to create a web application
DEVELOPtoA manage
WEATHER theAPPLICATION
TO-DO listUSING
of users, by using MERN
REACTJS
application and manage their to-do items are executed.
Date:

Aim:
To Create a web application by using weather app to monitoring temperature, speed,
humidity.

Algorithm :
• Create a new project folder and set up the basic file structure (e.g., HTML, CSS, JavaScript
files).
• Include necessary libraries or frameworks (e.g., React, Express, MongoDB).
• Create a location where users find location can enter their credentials to access their weather
app.
• Design a dashboard where users can view, add, edit, and delete their weather app items.
• Set up a user authentication system using JWT (JSON Web Tokens) or a similar mechanism.
• Design a database schema to store weather application items associated with each city.
• Set up a database connection (e.g., MongoDB).
• Allow users to view their existing weather application items on the dashboard.
• Add an option to create new weather app items with a title, description, and due date.
• Provide the ability to edit or mark tasks as complete.
• Ensure proper error handling throughout the application.
• Add sorting and filtering options for weather app items.
• Implement pagination for a better user experience if the list becomes lengthy.
• Thoroughly test the application for functionality and usability.
• Fix any bugs or issues that arise during testing.
• Choose a hosting provider and deploy the application on a web server
• Regularly monitor the application for any performance or security issues.
• Update the application with new features and improvements as needed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Algorithm:
Program:
Header.js

import React from 'react';

const Header = ({onSearch}) => {

return (
<header>
<div className="city">
<i className="fas fa-location-crosshairs"></i>
<input type="text" id="cityname" placeholder="Enter city" />
<button onClick={e=>onSearch(city)}>Search</button>
</div>
<div className="weatherResult">
<i className="far fa-sun"></i> Sunny day
</div>
</header>
);
};

export default Header;

Info.js

import React from 'react';

const Info = ({ weatherData }) => {


const config = [
{ label: 'Real Feel', field: 'feels_like', suffix: '°C' },
{ label: 'Humidity', field: 'humidity', suffix: '%' },
{ label: 'Pressure', field: 'pressure', suffix: 'mmHG' },
{ label: 'Wind Speed', field: 'speed', suffix: 'm/s' },
{ label: 'UV Index', field: 'uvi' },

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

{ label: 'Water Temperature', field: 'water' }


];

return (
<section>
<div className="layout">

{/* {weatherData &&config.map(w =>{


<div
className="gridLayout">{w.label}<span>{Math.round(weatherData.main[w.field])}<sup>{w.s
uffix}</sup></span></div> */}

{weatherData &&config.map((w, index) => ( <div key={index}


className="gridlayout">{w.label}{' '}
<span>
{w.field == 'NAN' || w.field == 'NAN'? weatherData[w.field]: w.field === 'speed'?
weatherData.wind[w.field]: Math.round(weatherData.main[w.field])}
{w.suffix && <sup>{w.suffix}</sup>}
</span>
</div>
)
)};
</div>
</section>
)
};

export default Info;

Main.js

import React from 'react';

const Main = ({ currentDate }) => {


return (
<main>
<div className="weekday" dangerouslySetInnerHTML={{ __html: currentDate }}></div>
<div className="temperature">0<sup>&deg;</sup></div>
<div className="msgcontent">
<div className="msg">Clear evening sky.</div>
<div className="degreeunit">18<sup>&deg;</sup>&mdash; 24<sup>&deg;</sup></div>
</div>
</main>

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

);
};

export default Main;

Output:

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)


lOMoARcPSD|51219696

Result:
Thus, the to create a weather app, by using application and manage their temperature and
locations are executed.

Downloaded by SAI SUGANYA B IT (saisuganya@nscet.org)

You might also like