/radio-service

A client's responsive webpage that allows users to find and listen to dozens of recordings from a radio talk show.

Primary LanguageJavaScript

Spanish Radio And Podcast

This website allows users to find and listen to dozens of recordings from a radio talk show.

Open deployed site

Desktop View

Tablet View

Mobile View

Tech Stack

Frontend Built Using:

Using the Application

Requirements:

  • Node
  • Package Manager (such as Yarn or npm)

Follow these steps:

  1. Fork and clone repo

  2. In the terminal, cd into 'tuhoradivina'

  3. Run yarn or npm install to install the necessary node_modules on the frontend.

  4. Run yarn start or npm start on the client folder to run the frontend on localhost:3000

How Data is Structured

There's quite a bit of data, but it is "normalized" for constant time lookups (Not including network latency).

 

example - data.js

const data = {
  // ********* 2016 *************************************************
  sixteen: {
    yearTitle: '2016',
    year: 'sixteen',
    allMonths: ['enero', 'febrero', 'marzo', 'abril', 'mayo', 'junio', 'julio', 'agosto', 'septiembre', 'octubre', 'noviembre', 'diciembre' ],
    monthsData: {
      // ************** Enero 2016
      enero: {
        monthTitle: 'Enero 2016',
        audioData: [{
          audioTitle: "02-01-2016",
          audioFile: sixteenEnero1
        }, {
          audioTitle: "09-01-2016",
          audioFile: sixteenEnero2
        }, {
          audioTitle: "16-01-2016",
          audioFile: sixteenEnero3,
        }, {
          audioTitle: "23-01-2016",
          audioFile: sixteenEnero4
        }],
      },
      // ************** Febrero 2016
      febrero: { ..... 

 

We can use the above example data to handle our years and months to update the state

 

handleMonth - App.js

  const handleMonth = (month) => {
    const monthData = data[year].monthsData[month];
    const { monthTitle, audioData } = monthData;
    setMonthTitle(monthTitle);
    setAudioData(audioData);
  }

 

handleYear - App.js

  const handleYear = (yearSelected) => {
    const { yearTitle, year, allMonths, monthsData } = data[yearSelected];

    // 2016 and 2016 both begin in Janurary, while 2015 begins in July. 
    // (according to the data available, obviously not on an actual calendar lol) 
    const { monthTitle, audioData } = 
      yearSelected === 'fifteen' ? monthsData.julio : monthsData.enero;

    setAllMonths(allMonths);
    setYearTitle(yearTitle);
    setYear(year);
    setMonthTitle(monthTitle);
    setAudioData(audioData);
  }