{"version":3,"sources":["api/fetchMovies.js","api/fetchMoviePoster.js","images/placeholder-movie-poster.jpg","contexts/MoviesContext.js","images/loading-animation.gif","components/Card/Card.js","views/MovieList/MovieList.view.js","components/Banner/Banner.js","views/Movie/Movie.view.js","views/Movie/Movie.controller.js","views/UserList/UserList.view.js","views/UserList/UserList.controller.js","components/Item/Item.js","views/User/User.view.js","views/User/User.controller.js","components/Menu/Menu.js","App.js","reportWebVitals.js","index.js"],"names":["fetchMovies","searchTerm","a","requestOptions","method","headers","fetch","process","then","response","status","Promise","reject","statusText","json","movies","catch","error","console","fetchMoviePoster","title","year","res","data","poster","Poster","test","e","posterURLUponResolve","MoviesContext","createContext","MoviesProvider","children","useState","setMovies","selectedMovie","setSelectedMovie","useEffect","undefined","all","map","movie","posters","moviesWithPosters","index","Provider","value","Card","pic","shape","className","src","loadingAnimation","alt","MovieListView","useContext","setSearchTerm","inputRef","useRef","containerRef","updateMovies","event","preventDefault","current","scrollTo","focus","ref","type","placeholder","onChange","target","onKeyDown","key","onClick","to","pathname","state","origin","Banner","imgType","subtitle","isMutable","handleTitleChange","handleSubtitleChange","update","id","MovieView","location","navigation","director","wiki_page","crew","genre","plot","handleAddToList","listName","stopPropagation","listItems","JSON","parse","localStorage","getItem","Array","from","Set","setItem","stringify","addToLocalStorage","alert","document","querySelector","href","rel","UserListView","username","setUsername","setPic","watchlist","completed","dropped","favorites","Item","text","deleteCallback","UserView","setLocation","setWatchList","setCompleted","setDropped","setFavorites","removeMovieFromList","storageKeys","updatedList","filter","updateProfile","length","Menu","App","path","component","reportWebVitals","onPerfEntry","Function","getCLS","getFID","getFCP","getLCP","getTTFB","ReactDOM","render","StrictMode","getElementById"],"mappings":"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","file":"static/js/main.a5b7a4d1.chunk.js","sourcesContent":["/**\n * Attempts to retreive list of movie titles w / year.\n * Returns an array of objects containing \"title\" and \"year\" for movie.\n * @param {String=} searchTerm - Title of movie to retreive.\n */\nexport const fetchMovies = async (searchTerm) => {\n const requestOptions = {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json'\n }\n };\n \n const movies = await fetch(`${process.env.REACT_APP_MYMOVIELIST_API_ENDPOINT}/get-movies${searchTerm ? \"?search=\" + searchTerm : \"\"}`, requestOptions)\n .then(response => {\n if (response.status !== 200) {\n return Promise.reject(`${response.status} ${response.statusText}`);\n };\n\n return response.json();\n })\n .then(movies => movies)\n .catch(error => {\n console.error(error);\n\n return [];\n });\n\n return movies;\n };","import placeholderPoster from \"../images/placeholder-movie-poster.jpg\"\n\nconst apiKey = process.env.REACT_APP_OMDB_API_KEY;\n\n/**\n * Attempts to retreive url for movie poster via www.omdbapi.com API\n * Returns Promise object that resolves to url for movie poster\n * @param {String} title - Title of movie to retreive poster for.\n * @param {String} year - Year movie released for movie to retreive poster for.\n */\nexport const fetchMoviePoster = async (title, year) => {\n const posterURLUponResolve = await fetch(`https://www.omdbapi.com/?apikey=${apiKey}&t=${title}&y=${year}`)\n .then(res => res.json())\n .then((data) => {\n const poster = data.Poster;\n\n if (!poster || /^http/.test(poster) === false) {\n return Promise.reject(`No poster found for ${title} ${year}`);\n }\n\n return poster;\n })\n .catch(e => {\n // console.log(e);\n\n return placeholderPoster;\n });\n\n return posterURLUponResolve;\n}","export default \"\"","// React\nimport { createContext, useState, useEffect } from \"react\";\n\n// API\nimport { fetchMovies } from '../api/fetchMovies';\nimport { fetchMoviePoster } from \"../api/fetchMoviePoster\";\n\nexport const MoviesContext = createContext();\n\nexport default function MoviesProvider({children}) {\n const [movies, setMovies] = useState([]);\n const [selectedMovie, setSelectedMovie] = useState();\n\n useEffect(() => {\n fetchMovies()\n .then((movies) => {\n setMovies(movies);\n })\n .catch(e => console.error(e));\n // eslint-disable-next-line\n }, []);\n\n useEffect(() => {\n // Needed to avoid undefined error.\n if (movies[0] !== undefined) {\n // Checks to see if current array of movies have a .poster property.\n const hasAlreadyFetchedPosters = movies[0].poster;\n\n // Essentially assigns .poster property to movies array.\n // Checks to see if property exists already before running as to avoind infinite loop.\n if (!hasAlreadyFetchedPosters) {\n // Fetches all posters at once, but only resolves when all fetches are complete.\n Promise.all(\n [...movies].map(movie => fetchMoviePoster(movie.title, movie.year))\n )\n .then(posters => {\n const moviesWithPosters = [...movies].map((movie, index) => {\n return { ...movie, \"poster\": posters[index] };\n })\n\n setMovies(moviesWithPosters);\n setSelectedMovie(moviesWithPosters[0]);\n })\n .catch(e => console.error(e))\n ;\n }\n }\n }, [movies]);\n\n return (\n \n {children}\n \n )\n}","export default __webpack_public_path__ + \"static/media/loading-animation.96b6ce3e.gif\";","import './Card.css';\n\nimport loadingAnimation from \"../../images/loading-animation.gif\";\n\nexport default function Card({ title, pic, shape = \"rect\" }) {\n return (\n \n \n

{title}

\n \n );\n }","// React\nimport { useEffect,\n useState,\n useRef,\n useContext\n} from 'react';\nimport { NavLink } from 'react-router-dom';\n\n// Styles\nimport './MovieList.view.css';\n\n// Context\nimport { MoviesContext } from '../../contexts/MoviesContext';\n\n// Components\nimport Card from '../../components/Card/Card';\n\n// API\nimport { fetchMovies } from '../../api/fetchMovies';\n\n// Icons\nimport { CgSearch } from \"react-icons/cg\";\n\nexport default function MovieListView() {\n const { movies, setMovies } = useContext(MoviesContext);\n const [searchTerm, setSearchTerm] = useState(\"\");\n const inputRef = useRef();\n const containerRef = useRef();\n\n const updateMovies = async (event) => {\n event.preventDefault();\n\n const movies = await fetchMovies(searchTerm)\n .then(movies => movies)\n .catch(e => console.error(e));\n \n setMovies(movies);\n }\n\n useEffect(() => {\n containerRef.current.scrollTo(0, 0); // Scroll to top of page.\n inputRef.current.focus();\n }, []);\n\n return (\n
\n
\n

Movies

\n
\n setSearchTerm(event.target.value)}\n onKeyDown={event => {\n if (event.key === \"Enter\") updateMovies(event);\n }}\n />\n updateMovies(event)}\n />\n \n
\n
    \n {\n movies.map((movie) => {\n return (\n \n \n \n\n )\n })\n }\n
\n
\n );\n}","// Styles\nimport './Banner.css';\n\nexport default function Banner({ title, pic, imgType, subtitle, isMutable, handleTitleChange, handleSubtitleChange, update }) {\n return (\n
\n {title}\n
\n {\n isMutable\n ? <>\n handleTitleChange(e)} />\n handleSubtitleChange(e)} />\n update()}\n >\n Update\n \n \n : <>\n

\n {title}\n

\n

\n {subtitle}\n

\n \n }\n
\n
\n );\n}","// React\nimport { useContext, useEffect, useRef } from 'react';\n\n// Components\nimport Banner from '../../components/Banner/Banner';\n\n// Styles\nimport './Movie.view.css';\n\n// Context\nimport { MoviesContext } from '../../contexts/MoviesContext';\n\n// Controller\nimport { addToLocalStorage } from './Movie.controller';\n\nexport default function MovieView({ location, navigation }) {\n const { selectedMovie, setSelectedMovie } = useContext(MoviesContext);\n const { \n title,\n year,\n poster,\n director,\n origin,\n wiki_page,\n crew,\n genre,\n plot\n } = selectedMovie ? selectedMovie : {};\n\n const containerRef = useRef();\n\n const handleAddToList = (event, listName) => {\n event.stopPropagation();\n\n addToLocalStorage(listName, title);\n alert(`Added \"${title}\" to ${listName}.`);\n }\n\n useEffect(() => {\n document.querySelector(\".content\").scrollTo(0, 0);\n \n if (location.state) {\n setSelectedMovie(location.state);\n }\n // eslint-disable-next-line\n }, []);\n\n return (\n
\n \n
\n \n \n \n \n
\n

\n {plot}\n

\n
    \n
  • \n

    Cast

    \n

    {crew}

    \n
  • \n
  • \n

    Director

    \n

    {director}

    \n
  • \n
  • \n

    Origin

    \n

    {origin}

    \n
  • \n
  • \n

    Genre

    \n

    {genre}

    \n
  • \n
\n \n \n

Wiki

\n \n
\n );\n}\n","export const addToLocalStorage = (listName, movie) => {\n let listItems = JSON.parse(localStorage.getItem(listName)) || [];\n listItems = Array.from(\n new Set([...listItems, movie])\n );\n\n localStorage.setItem(listName, JSON.stringify(listItems));\n}","// React\nimport { useEffect, useState, useRef } from 'react';\n\n// Styles\nimport './UserList.view.css';\n\n// Controllers\nimport { init } from './UserList.controller';\n\n// Components\nimport Card from '../../components/Card/Card';\n\nexport default function UserListView() {\n const [username, setUsername] = useState(\"\");\n const [pic, setPic] = useState(\"\");\n const containerRef = useRef();\n\n useEffect(() => {\n containerRef.current.scrollTo(0, 0); // Scroll to top of page.\n init();\n\n const {\n username,\n pic\n } = JSON.parse(localStorage.getItem(\"profile\"));\n\n setUsername(username);\n setPic(pic);\n }, []);\n\n return (\n
\n

Just you

\n \n
\n );\n}","export const init = () => {\n const profile = localStorage.getItem(\"profile\");\n\n if (!profile) {\n const username = \"demo user\";\n const pic = \"https://images.pexels.com/photos/4681107/pexels-photo-4681107.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1\";\n const location = \"Saint Louis, MO\";\n const watchlist = [];\n const completed = [];\n const dropped = [];\n const favorites = [];\n\n localStorage.setItem(\"profile\", JSON.stringify({ username, pic, location, watchlist, completed, dropped, favorites }));\n }\n}","import './Item.css';\n\nexport default function Item({ listName, text, deleteCallback }) {\n return (\n \n

{text}

\n deleteCallback(e, listName, text)}\n >\n x\n \n \n );\n }","// React\nimport { useEffect, useState, useRef } from 'react';\n\n// Controllers\nimport {\n init,\n updateProfile\n} from \"./User.controller\";\n\n// Styles\nimport './User.view.css';\n\n// Components\nimport Banner from '../../components/Banner/Banner';\nimport Item from '../../components/Item/Item';\n\nexport default function UserView() {\n const [username, setUsername] = useState(\"\");\n const [pic, setPic] = useState(\"\");\n const [location, setLocation] = useState(\"\");\n const [watchlist, setWatchList] = useState([]);\n const [completed, setCompleted] = useState([]);\n const [dropped, setDropped] = useState([]);\n const [favorites, setFavorites] = useState([]);\n\n const containerRef = useRef();\n\n const handleTitleChange = (e) => {\n const value = e.target.value;\n\n setUsername(value);\n }\n\n const handleSubtitleChange = (e) => {\n const value = e.target.value;\n\n setLocation(value);\n }\n\n const update = () => {\n updateProfile({ username, pic, location });\n alert(\"Username and location updated.\");\n }\n\n const removeMovieFromList = (e, listName, text) => {\n const storageKeys = {\n \"favorites\": setFavorites,\n \"watchlist\": setWatchList,\n \"completed\": setCompleted,\n \"dropped\": setDropped\n };\n const list = JSON.parse(localStorage.getItem(listName));\n const updatedList = list.filter(title => title !== text);\n\n storageKeys[listName](updatedList);\n localStorage.setItem(listName, JSON.stringify(updatedList));\n }\n\n useEffect(() => {\n containerRef.current.scrollTo(0, 0); // Scroll to top of page.\n init();\n\n const {\n username,\n pic,\n location\n } = JSON.parse(localStorage.getItem(\"profile\"));\n\n setUsername(username);\n setPic(pic);\n setLocation(location);\n\n setWatchList(JSON.parse(localStorage.getItem(\"watchlist\")) || []);\n setCompleted(JSON.parse(localStorage.getItem(\"completed\")) || []);\n setDropped(JSON.parse(localStorage.getItem(\"dropped\")) || []);\n setFavorites(JSON.parse(localStorage.getItem(\"favorites\")) || []);\n }, []);\n\n return (\n
\n \n
    \n
  • \n

    Favorites

    \n
      \n {\n favorites.length > 0\n ? favorites.map(e => \n \n )\n :
    • \n

      \n Nothing added to favorites.\n

      \n
    • \n }\n
    \n
  • \n
  • \n

    Watchlist

    \n
      \n {\n watchlist.length > 0\n ? watchlist.map(e => \n \n )\n :
    • \n

      \n Nothing added to watchlist.\n

      \n
    • \n }\n
    \n
  • \n
  • \n

    Completed

    \n
      \n {\n completed.length > 0\n ? completed.map(e => \n \n )\n :
    • \n

      \n Nothing added to completed.\n

      \n
    • \n }\n
    \n
  • \n
  • \n

    Dropped

    \n
      \n {\n dropped.length > 0\n ? dropped.map(e => \n \n )\n :
    • \n

      \n Nothing added to dropped.\n

      \n
    • \n }\n
    \n
  • \n
\n
\n );\n}","export const init = () => {\n const profile = localStorage.getItem(\"profile\");\n\n if (!profile) {\n const username = \"Demo User\";\n const pic = \"https://images.pexels.com/photos/4681107/pexels-photo-4681107.jpeg?auto=compress&cs=tinysrgb&w=1260&h=750&dpr=1\";\n const location = \"Saint Louis, MO\";\n\n localStorage.setItem(\"profile\", JSON.stringify({ username, pic, location }));\n }\n}\n\nexport const updateProfile = ({ username, pic, location }) => {\n localStorage.setItem(\"profile\", JSON.stringify({ username, pic, location }));\n}","import { NavLink } from 'react-router-dom';\n\n// Icons\nimport { \n CgFilm,\n CgProfile,\n CgUserList\n } from \"react-icons/cg\";\n\n// Styles\nimport './Menu.css';\n\nexport default function Menu() {\n return (\n
\n

\n \n MyMovieList\n

\n
    \n \n
  • \n \n Profile\n
  • \n
    \n \n
  • \n \n Movies\n
  • \n
    \n \n
  • \n \n Users\n
  • \n
    \n
\n
\n );\n}","// React\nimport React from 'react';\nimport { \n HashRouter, \n Route, \n Redirect, \n Switch \n} from 'react-router-dom';\n\n// Styles\nimport './reset.css';\nimport './App.css';\n\n// Context\nimport MoviesProvider from \"./contexts/MoviesContext\";\n\n// Views\nimport MovieListView from './views/MovieList/MovieList.view';\nimport MovieView from './views/Movie/Movie.view';\nimport UserListView from './views/UserList/UserList.view';\nimport UserView from './views/User/User.view';\n\n// Components\nimport Menu from './components/Menu/Menu';\n\nexport default function App() {\n return (\n
\n \n \n
\n \n \n \n \n \n \n \n \n \n
\n \n
\n );\n}","const reportWebVitals = onPerfEntry => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport App from './App';\nimport reportWebVitals from './reportWebVitals';\n\nReactDOM.render(\n \n \n ,\n document.getElementById('root')\n);\n\n// If you want to start measuring performance in your app, pass a function\n// to log results (for example: reportWebVitals(console.log))\n// or send to an analytics endpoint. Learn more: https://bit.ly/CRA-vitals\nreportWebVitals();\n"],"sourceRoot":""}