- create layout
- header
- logo/name
- nav
- searchbar
- content area
- header
- create empty pages
- /
- /scope
- /details
- implement plain text search (first page results are enough).
- create movie detail page content
Don't know how to filter and sort at all, as the /search/movie
api has no options for that. Could request all pages, but the API is limited to 40 requests per 10s (4/1s), page size is 20.
The /discover/movie
has many filter and sorting options but not a text query filter. There is the with_keywords
filter but it lead to 0 results when testing it.
This means to keep it simple I would only allow to either search by text or filter and sort. Could create a minimalistic search UI in the header, which would redirect to the details page. (will go this way)
Otherwise: If search field and a filter or the sorting has a value i'd have to request all pages of /search/movie
and all pages of /discover/movie
and filter out every result of /search/movie
, which is not included in every result of /discover/movie
.
- create categories filter ui (table vs dropdowns?)
- prev-next pagination
- add sort ui
- title (asc)
- title (desc)
- release_date
- ... other
- add more filters
- dropdown UI instead of table UI
- finish dark/light mode & material colors
- tablet & mobile optimizations, breakpoints thereby make use of these features and maybe more: - https://vueuse.org/core/useScreenOrientation/ - https://vueuse.org/core/useScreenSafeArea/ - https://vueuse.org/core/useSSRWidth/
- RTL?
- material typography
- create logo as svg
- prettier
- resolve all 'TODO' comments
- for a11y use vue-axe-next but take a look at WAVE aswell
- check and improve on web vitals
- i18n
- serve fonts statically
- git commit and push hooks
Not a part of the task.
- Current Cinema Program -> /movie/now_playing
- Popular -> /movie/popular
- Top Rated -> /movie/top_rated
- ... other
Absolut abartig gute library... wirklich unglaublich. Braucht einiges an Zeit, die library ist riesig und deckt echt alles mögliche sauber ab. Muss man sich Zeit zum stöbern nehmen, sonst verpasst man einiges und schreib code den es bereits gibt. Einfach heftigster Kraftschock(?). :o