diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 0000000..f673a71
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,3 @@
+{
+ "liveServer.settings.port": 5502
+}
\ No newline at end of file
diff --git a/index.html b/index.html
index e69de29..6c3f03b 100644
--- a/index.html
+++ b/index.html
@@ -0,0 +1,61 @@
+
+
+
+
+
+ 8.4 Nights Weather App
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ Choose a location to view the weather
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/main.js b/main.js
new file mode 100644
index 0000000..7b78411
--- /dev/null
+++ b/main.js
@@ -0,0 +1,308 @@
+const url = "http://wttr.in";
+const urlFormat = "?format=j1";
+
+
+
+let data;
+const form = document.querySelector('form'); // <= selecting form
+const ul = document.querySelector("ul");
+const currentWeather = document.querySelector("#currentWeather");
+const previousSearch = document.querySelector("section p");//no previous searches
+
+//temperature widget =>
+Widget(data);
+
+
+form.addEventListener('submit', (event) => {
+ event.preventDefault();
+ const location = document.querySelector('#location');
+ let input = location.value;
+ userInput(input);
+ previousSearch.remove();
+ });
+
+
+function userInput (input) {
+ fetch(`${url}/${input}${urlFormat}`)
+ .then((response) => response.json())
+ .then((json) => {
+ data = json;
+
+ findWeatherInfo(data,input);
+ previousHistory(data,input);
+
+ })
+ .catch((err) => {
+ console.log(err);
+ })
+ form.reset();
+}
+
+
+function findWeatherInfo(data,input) {
+currentWeather.innerHTML = "";
+
+const img = document.createElement("img");
+
+if (data.weather[0].hourly[0].chanceofsunshine >= 50) {
+
+ img.src = "./assets/icons8-summer.gif";
+ img.alt = "sun";
+ currentWeather.append(img);
+
+} else if (data.weather[0].hourly[0].chanceofrain >= 50) {
+
+ img.src = "./assets/icons8-torrential-rain.gif";
+ img.alt = "rain";
+ currentWeather.append(img);
+} else if (data.weather[0].hourly[0].chanceofsnow >= 50) {
+
+ img.src = "./assets/icons8-light-snow.gif";
+ img.alt = "snow"
+ currentWeather.append(img);
+}
+
+if (input === data.nearest_area[0].areaName[0].value){
+
+const h2 = document.createElement("h2");
+h2.textContent = data.nearest_area[0].areaName[0].value;
+currentWeather.append(h2);
+
+
+const area = document.createElement("p");
+area.innerHTML = ` Area: ${data.nearest_area[0].areaName[0].value}`;
+currentWeather.append(area);
+
+} else {
+
+
+const h2 = document.createElement("h2");
+h2.textContent = input;
+currentWeather.append(h2);
+
+
+const area = document.createElement("p");
+area.innerHTML = ` Nearest Area: ${data.nearest_area[0].areaName[0].value}`;
+currentWeather.append(area);
+}
+const region = document.createElement("p");
+region.innerHTML = ` Region: ${data.nearest_area[0].region[0].value}`;
+currentWeather.append(region);
+
+const country = document.createElement("p");
+country.innerHTML = ` Country: ${data.nearest_area[0].country[0].value}`;
+currentWeather.append(country);
+
+const currently = document.createElement("p");
+currently.innerHTML = ` Currently: Feels Like ${data.current_condition[0].FeelsLikeF}°F`;
+currentWeather.append(currently);
+
+
+const sunshine = document.createElement("p");
+sunshine.innerHTML = ` Chance of Sunshine: ${data.weather[0].hourly[0].chanceofsunshine}`;
+currentWeather.append(sunshine);
+
+const rain = document.createElement("p");
+rain.innerHTML = ` Chance of Rain: ${data.weather[0].hourly[0].chanceofrain}`;
+currentWeather.append(rain);
+
+const snow = document.createElement("p");
+snow.innerHTML = ` Chance of Snow: ${data.weather[0].hourly[0].chanceofsnow}`;
+currentWeather.append(snow);
+
+const futureWeather = document.querySelectorAll(".futureWeather");
+
+const weather1 = futureWeather[0];
+const weather2 = futureWeather[1];
+const weather3 = futureWeather[2];
+
+weather1.innerHTML = "";
+weather1.style = "3px dotted rgb(0, 0, 0)";
+
+const today = document.createElement("h2");
+today.textContent = "Today";
+weather1.append(today);
+
+const avgTemp = document.createElement("p");
+avgTemp.innerHTML = ` Average Temperature: ${data.weather[0].avgtempF}°F`;
+weather1.append(avgTemp);
+
+const maxTemp = document.createElement("p");
+maxTemp.innerHTML = ` Max Temperature: ${data.weather[0].maxtempF}°F`;
+weather1.append(maxTemp);
+
+const minTemp = document.createElement("p");
+minTemp.innerHTML = ` Min Temperature: ${data.weather[0].mintempF}°F`;
+weather1.append(minTemp);
+
+
+
+weather2.innerHTML = "";
+weather2.style = "3px dotted rgb(0, 0, 0)";
+
+
+const tomorrowWeather = document.createElement("h2");
+tomorrowWeather.textContent = "Tomorrow";
+weather2.append(tomorrowWeather);
+
+const tomorrowAvgTemp = document.createElement("p");
+tomorrowAvgTemp.innerHTML = ` Average Temperature: ${data.weather[1].avgtempF}°F`;
+weather2.append(tomorrowAvgTemp);
+
+const tomorrowMaxTemp = document.createElement("p");
+tomorrowMaxTemp.innerHTML = ` Max Temperature: ${data.weather[1].maxtempF}°F`;
+weather2.append(tomorrowMaxTemp);
+
+const tomorrowMinTemp = document.createElement("p");
+tomorrowMinTemp.innerHTML = ` Min Temperature: ${data.weather[1].mintempF}°F`;
+weather2.append(tomorrowMinTemp);
+
+
+weather3.innerHTML = "";
+weather3.style = "3px dotted rgb(0, 0, 0)";
+
+const dayAfterTomorrow = document.createElement("h2");
+dayAfterTomorrow.textContent = "Day After Tomorrow";
+weather3.append(dayAfterTomorrow);
+
+const dayAfterTomorrowAvgTemp = document.createElement("p");
+dayAfterTomorrowAvgTemp.innerHTML = ` Average Temperature: ${data.weather[2].avgtempF}°F`;
+weather3.append(dayAfterTomorrowAvgTemp);
+
+const dayAfterTomorrowMaxTemp = document.createElement("p");
+dayAfterTomorrowMaxTemp.innerHTML = ` Max Temperature: ${data.weather[2].maxtempF}°F`;
+weather3.append(dayAfterTomorrowMaxTemp);
+
+const dayAfterTomorrowMinTemp = document.createElement("p");
+dayAfterTomorrowMinTemp.innerHTML = ` Min Temperature: ${data.weather[2].mintempF}°F`;
+weather3.append(dayAfterTomorrowMinTemp);
+}
+
+// use span, look back**
+
+function previousHistory (data,input){
+ const span = document.createElement("span");
+ const li = document.createElement("li");
+ const a = document.createElement("a");
+
+a.textContent = `${data.nearest_area[0].areaName[0].value}`;
+a.setAttribute ("href", "#");
+//console.log(data.nearest_area[0].areaName[0].value)
+li.textContent = ` - ${data.current_condition[0].FeelsLikeF}°F`;
+
+ ul.append(li);
+ li.prepend(a);
+
+
+
+a.addEventListener("click", (event) => {
+ findWeatherInfo(data,input);
+})
+
+}
+
+
+function Widget(data) {
+ const Widget = document.querySelector("#Widget");
+
+ //seperate form ***
+
+ const formForWidget = document.createElement("form");
+ Widget.append(formForWidget);
+
+
+ const label = document.createElement("label");
+ label.textContent = "convert the temperature:";
+ formForWidget.append(label);
+
+ //seperate input ***
+
+ const input = document.createElement('input');
+ input.type = "number";
+ input.id = "temp-to-convert";
+ formForWidget.append(input);
+
+
+ //button for celsius radio ***
+
+ const celsiusRadiobutton = document.createElement("input");
+ celsiusRadiobutton.type = 'radio';
+ celsiusRadiobutton.id = "to-c";
+ celsiusRadiobutton.name = "convert-temp";
+ celsiusRadiobutton.value = "c";
+ formForWidget.append(celsiusRadiobutton);
+
+ //label for celsius ***
+
+ const celsiusLabel = document.createElement("label");
+ celsiusLabel.textContent = "to celsius";
+ celsiusLabel.setAttribute('for', "to-c");
+ formForWidget.append(celsiusLabel);
+
+
+ const br = document.createElement('br');
+ formForWidget.append(br);
+
+ // button for farenheit ***
+
+ const fahrenheitRadiobutton = document.createElement("input");
+ fahrenheitRadiobutton.type = 'radio';
+ fahrenheitRadiobutton.id = "to-f";
+ fahrenheitRadiobutton.name = "convert-temp";
+ fahrenheitRadiobutton.value = "f";
+ formForWidget.append(fahrenheitRadiobutton);
+
+ // label for farenheit ***
+
+ const fahrenheitLabel = document.createElement("label");
+ fahrenheitLabel.textContent = "to fahrenheit";
+ fahrenheitLabel.setAttribute('for', "to-f");
+ formForWidget.append(fahrenheitLabel);
+
+ //submit button widget ***
+ const inputForWidget = document.createElement("input");
+ inputForWidget.type = "submit";
+ formForWidget.append(inputForWidget);
+
+ // result
+ const h4 = document.createElement("h4");
+ h4.textContent = "0.00";
+ formForWidget.append(h4);
+
+
+ // adds click event to converion***
+
+ formForWidget.addEventListener('submit', (event) => {
+ event.preventDefault();
+
+ const temperature = document.querySelector("#temp-to-convert").value;
+ const celsiusOutput = document.querySelector('input[name="convert-temp"]:checked');
+ calculatedTemp(temperature, celsiusOutput);
+ formForWidget.reset();
+
+ });
+
+
+}
+
+function calculatedTemp(temperature,celsiusOutput) {
+ let convertedTemp = 0;
+ let h4temp = document.querySelector('h4');
+
+ if (celsiusOutput === null && temperature === "") {
+ h4temp.textContent = "Please provide temp and conversion";
+ } else if (temperature === "") {
+ h4temp.textContent = "Empty Temperature";
+
+ } else if (celsiusOutput === null) {
+ h4temp.textContent = "Empty Radio";
+
+ } else if (celsiusOutput.value === "c") {
+ convertedTemp = (temperature - 32) * (5/9);
+ h4temp.textContent = convertedTemp.toFixed(2);
+
+ } else if (celsiusOutput.value === "f") {
+ convertedTemp = (temperature* 1.8) + 32;
+ h4temp.textContent = convertedTemp.toFixed(2);
+ }
+}
diff --git a/readme.md b/readme.md
index eb83082..37dd762 100644
--- a/readme.md
+++ b/readme.md
@@ -69,13 +69,16 @@ In particular, make sure the following is true:
- [ ] There is a header that includes
- [ ] The application's title
- [ ] a search form with a label, text input, and submit input
+
- [ ] `aside` (will contain a temperature conversion widget), starts empty
- [ ] The `main `section of the page contains placeholder text and contain the following elements:
+
- [ ] `article` - this will contain the current weather (starts empty)
- [ ] `aside` - this will contain 3 `article` elements that will have upcoming weather (starts empty)
- [ ] `aside` (will contain weather history)
- [ ] `section`
- [ ] `h4` with the text `Previous Searches`
+
- [ ] The sidebar includes an empty `ul` and a message inside a `p` element that lets the user know no searches have been made yet
- [ ] CSS Grid should be used to structure the page
@@ -83,10 +86,9 @@ In particular, make sure the following is true:
After searching, your page should look similar to the screenshot below.
-
+
In particular, make sure to include the following:
-
- [ ] The main section of the page should be filled in with relevant information received from the API. (More detailed information below.)
- [ ] Three sections below the main section should show information for the next few days.
- [ ] CSS Grid should be used throughout to structure the page.
diff --git a/style.css b/style.css
new file mode 100644
index 0000000..bc193bd
--- /dev/null
+++ b/style.css
@@ -0,0 +1,105 @@
+header {
+ opacity: 80%;
+ width: 80%;
+ padding: 12px 0px;
+ border: 3px dotted rgb(6, 6, 6);
+ margin-left: auto;
+ margin-right: auto;
+ background-color: cyan;
+ text-align: center;
+ color: white;
+ display: block;
+ font-family: sans-serif;
+}
+
+main {
+ opacity: 90%;
+ display: grid;
+ grid-template-columns: repeat(7, 8fr);
+ grid-template-rows: 1fr 1fr;
+}
+
+#infoBoxes {
+ opacity: 90%;
+ display: grid;
+ grid-column: 3/6;
+}
+
+#previousSearch {
+ opacity: 90%;
+text-align: left;
+background-color: cyan;
+}
+
+#currentWeather {
+ opacity: 90%;
+ display: grid;
+ grid-row: 1/2;
+ padding-left: 30px;
+ text-align: center;
+ border: 3px dotted rgb(0, 0, 0);
+ margin: 10px;
+ background-color:cyan ;
+ height: auto;
+
+}
+
+.futureWeather {
+ display:grid;
+ grid-column: repeat(7,1fr);
+ text-align: center;
+ background-color: cyan;
+}
+
+#history {
+ display: grid;
+ grid-column: 1;
+ text-align: center;
+ padding-left: 30px;
+ background-color: cyan;
+}
+
+ul {
+ text-align: left;
+ background-color: cyan;
+}
+
+#upcoming {
+
+ display: grid;
+ grid-template-columns: repeat(3, 1fr);
+ height:auto;
+ background-color: cyan;
+}
+
+.days {
+ opacity: 80%;
+ display:grid;
+ grid-template-columns:1fr 1fr 1.50fr;
+ text-align: center;
+}
+
+img {
+ margin-left: auto;
+ margin-right: auto;
+}
+
+#Widget {
+ opacity: 80%;
+ width: 80%;
+ padding: 15px 0px;
+ margin-left: auto;
+ margin-right: auto;
+ margin-top: 12px;
+ display: grid;
+ grid-column: 2/3;
+ background-color: cyan;
+ border: 3px dotted rgb(0, 0, 0);
+ color: black;
+ padding: 10px;
+}
+
+body {
+ background-image: url('');
+ }
+