Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Shaun Harris #125

Open
wants to merge 1 commit into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
3 changes: 3 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
{
"liveServer.settings.port": 5502
}
114 changes: 114 additions & 0 deletions App.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
//State Management Aims
// We need a way to store the fetched breweries.
//This state object will hold the list of breweries.
const state = {
breweries: [] // Initialize with an empty array
}

//API Endpoint
// Define the base URL for the Open Brewery DB API.
const root = "https://api.openbrewerydb.org/v1/breweries"

// DOM Elements:
// Cache frequently used DOM elements for better performance.
const breweryList = document.querySelector('.breweries-list') // List container
const selectStateForm = document.querySelector('#select-state-form') // Form for state selection
const filterByType = document.querySelector('#filter-by-type') // Dropdown for brewery type
const selectState = document.querySelector('#select-state') // Dropdown for state selection

//Brewery Element Creation:
//Define a function to create HTML elements for displaying brewery details.
function createBreweryElement(brewery) {
// Create elements for brewery details
const li = document.createElement('li')
const breweryName = document.createElement('h2')
const breweryType = document.createElement('div')
const sectionAddress = document.createElement('section')
const sectionPhone = document.createElement('section')
const sectionLink = document.createElement('section')

// Populate elements with brewery data
breweryName.innerText = brewery.name
breweryType.classList.add('type')
breweryType.innerText = brewery.brewery_type
sectionAddress.classList.add('address')
sectionAddress.innerHTML = `<h3>Address:</h3><p>${brewery.street}</p><p><strong>${brewery.city}, ${brewery.postal_code}</strong></p>`
sectionPhone.classList.add('phone')
sectionPhone.innerHTML = `<h3>Phone:</h3><p>${brewery.phone || 'N/A'}</p>`
sectionLink.classList.add('link')
const link = document.createElement('a')
link.href = brewery.website_url
link.target = '_blank'
link.innerText = 'Visit Website'
sectionLink.appendChild(link)

// Append elements to list item
li.append(breweryName, breweryType, sectionAddress, sectionPhone, sectionLink)

return li
}

// Render Brewery List:
// Define a function to render the list of breweries.
function renderBreweryList() {
// Clear existing list
breweryList.innerHTML = ''
// Filter breweries by type and render each one
state.breweries
.filter(brewery => ['micro', 'regional', 'brewpub'].includes(brewery.brewery_type))
.forEach(brewery => {
const breweryElement = createBreweryElement(brewery)
breweryList.appendChild(breweryElement)
})
}

//Fetch Breweries from API
//Define an async function to fetch breweries from the API.
async function fetchBreweries(query = '') {
// Fetch data from API
const response = await fetch(`${root}${query}`)
// Parse JSON response
const data = await response.json()
// Update state with fetched data
state.breweries = data
// Render the updated list
renderBreweryList()
}

//Remove Existing List:
//Define a function to remove existing brewery list items.
function remove() {
breweryList.innerHTML = '' // Clear existing list
}

//Filter Breweries:
//Define an async function to filter breweries based on state and type.
async function filter() {
const stateValue = selectState.value
const typeValue = filterByType.value
let query = `?by_state=${stateValue}` // Construct query with state
if (typeValue) {
query += `&by_type=${typeValue}` // Add type filter to the query if selected
}
await fetchBreweries(query) // Fetch and update list
}

// Event Listeners:
// Add event listeners for form submission and type filter change.
selectStateForm.addEventListener('submit', async (event) => {
event.preventDefault() // Prevent default form submission
remove() // Clear current list
await filter() // Fetch and display filtered list
})

filterByType.addEventListener('change', async () => {
remove() // Clear current list
await filter() // Fetch and display filtered list
})

// Initial Fetch:
//Perform an initial fetch of breweries when the page loads.
(async function main() {
await fetchBreweries()
})()

1 change: 1 addition & 0 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="stylesheet" href="./styles/reset.css" />
<link rel="stylesheet" href="./styles/index.css" />
<script defer src="./App.js"></script>
<title>Brewery Tours</title>
</head>
<body>
Expand Down
1 change: 1 addition & 0 deletions node_modules/.bin/json-server

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions node_modules/.bin/json5

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions node_modules/.bin/mime

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading