-
Notifications
You must be signed in to change notification settings - Fork 4
/
weather-app
138 lines (129 loc) · 12.9 KB
/
weather-app
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
background: url();
background-repeat: no-repeat;
background-size: cover;
}
.h1{
color:black;
text-align: center;
}
.container input{
border-top-left-radius: 30%;
border-bottom-right-radius: 30%;
height: 15%;
/* width:20%; */
outline-color: goldenrod;
border-bottom: 15px goldenrod;
}
.result{
text-align: center;
color: white;
margin-top: 7%;
}
.container{
display: flex;
justify-content: center;
align-items: center;
margin-top: 10%;
}
.degree{
font-size: 100px;
}
.h2{
text-align: center;
}
</style>
</head>
<body>
<div>
<h1 class="h2">Sadiq's Weather App</h1>
<div class="container">
<form action="" id="form">
<input type="text" class="search" id="search">
</form>
</div>
</div>
<div class="result">
<h1 class="h1">Nellore, IN</h1>
<h2 class="h3">Thursday 27th July 2023</h2>
<p class="degree">29 <sup>0</sup> C</p>
<div class="loadingText">Waiting for response</div>
</div>
<script>
const search = document.getElementById("search")
const locationElem = document.querySelector(".h1")
const dateElem = document.querySelector(".h3")
const results = document.querySelector(".degree")
const loadingText = document.querySelector(".loadingText")
function getCurrentDate() {
const now = new Date();
// Day of the week
const days = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
const dayOfWeek = days[now.getDay()];
// Day of the month with suffix
const dayOfMonth = now.getDate();
let daySuffix;
if (dayOfMonth === 1 || dayOfMonth === 21 || dayOfMonth === 31) {
daySuffix = 'st';
} else if (dayOfMonth === 2 || dayOfMonth === 22) {
daySuffix = 'nd';
} else if (dayOfMonth === 3 || dayOfMonth === 23) {
daySuffix = 'rd';
} else {
daySuffix = 'th';
}
const formattedDay = `${dayOfMonth}${daySuffix}`;
// Month
const months = ['January', 'February', 'March', 'April', 'May', 'June',
'July', 'August', 'September', 'October', 'November', 'December'];
const month = months[now.getMonth()];
// Formatted date string
const formattedDate = `${dayOfWeek} ${formattedDay} ${month}`;
return formattedDate;
}
const currentDate = getCurrentDate();
dateElem.textContent = getCurrentDate() ;
function requestWeather(url){
locationElem.textContent = 'Waiting for response'
results.textContent = 'Waiting for response'
fetch(url).then(res => res.json())
.then(function(data){
console.log(data)
console.log(data.nearest_area[0].areaName[0].value)
console.log(data.nearest_area[0].areaName)
console.log(data.nearest_area[0].country[0].value)
locationElem.textContent = `${search.value} , ${data.nearest_area[0].country[0].value};`
results.textContent = `${data.weather[0].avgtempC} °C`
console.log(data.weather[0].date)
}
)
.catch(error => {
console.error('Error fetching weather:', error);
locationElem.textContent = "Location not found";
dateElem.textContent = "";
temperatureElem.textContent = "";
alert(`Error: ${error.message}`);
});
};
form.addEventListener('submit' , (e) =>{
e.preventDefault();
searchItem = search.value.trim()
console.log(searchItem)
if (!searchItem) {
alert("Please enter a location name to search for weather.");
return; // Exit the function if search bar is empty
}
const APILINK = `https://wttr.in/${searchItem}?format=j1`
console.log(APILINK)
requestWeather(APILINK)
});
</script>
</body>
</html>