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

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. -![Weather App after making a single search.](./assets/single-search.png) +![Weather App after making a single search.](./assets/si,,,,,,,,,,,,,ngle-search.png) 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(''); + } +