Skip to content

Book Recommendations is an SPA that allows users to enter/update book recommendations. The app will organize the listing of recommendations based on the data in the events and user choices.

Notifications You must be signed in to change notification settings

vykuntaharsha/book-recommendations

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

89 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Book Recommendations (Team Lavender)

Overview

Book Recommendations is an SPA that allows users to enter/update book recommendations. The app will organize the listing of recommendations based on the data in the events and user choices.

Purpose

The team project is intended to give experience:

  • sharing a code base with other coders
  • sharing responsibilities with other coders
  • prioritizing and tracking issues (bugs and feature requests)
  • dealing with changes in requirements

Minimum Functional Requirements

The page will allow the entry of a book recommendation

  • A book has a single-line title
  • A book has a genre from a list of the teams choice
  • A book has an author
  • The team may elect to have any of the above fields as optional, but the page must allow the above and must use the above when entered
  • The team may decide to have more fields on a book than these
  • The team must have these concepts, but does not have to show these labels to the user

The page will display all books, or books for a genre

  • The team may choose to have additional filters to view books

The page will allow the user to the displayed books sorted by upvotes

  • The team may choose to have additional ways to order the books

The page will allow a user to vote for a recommendation once.

  • When the page is reloaded the user is considered a new user and can again vote for books
  • When the page is reloaded any previous votes for a book are NOT lost
  • The user can tell which books they have voted for since they last reloaded

The page will allow a user to edit the title, author, or genre of a book

  • The team may choose to allow other fields to be edited
  • The team may choose to allow a book to be deleted
  • The team may choose the process a user takes to modify these fields
    • Example: a separate edit screen vs editing in-place on the main display

The page will assume it is being used by a single user

  • No login
  • This is one of the few restrictions on what you can add

The page will not have persistence beyond the service life

  • i.e. I can load the page and add data repeated
  • If I reload the page, the data entered is still displayed
  • If the service(s) restart, the data is lost
  • This is one of the few restrictions on what you can add

The page appearance

  • Will have an attractive and intuitive UI
    • This is subjective so avoid ugly, avoid confusing
  • Will display fine on a non-widescreen monitor
  • Will display fine on a widescreen monitor
  • Will display fine if the browser isn't full-screen
  • Is not required to work for very small browser windows
  • Is not required to work for mobile displays
  • The team may choose support additional viewport sizes
  • The team may choose to rearrange the layout based on viewport size

Technical Requirements

The page will be a Single Page Application

  • Meaning the user loads one HTML file and no additional page reload is required

The page will work in the latest Chrome

  • The team may elect to have it work in other modern browsers

The page will be written using plain HTML/JS/CSS

  • Not React (yet)
  • Webservice code in NodeJS
  • Webserver code in NodeJS
  • No outside JS libraries
    • Browserify may be used to bundle multiple JS files
    • Browserify usage must include source maps
    • Polyfills of JS standards, if needed, may use code from an external source
  • No outside CSS libraries (yet)

The project repository will follow common conventions. In particular:

  • The project can be full installed by cloning the repo and running npm install
  • The repo does not contain improper files, such as node_modules or IDE/OS-specific files

The project will use file structure practice required for this class. In particular:

  • lowercase filenames, except for JS files that represent classes
  • .html, .js, and .css file extensions
  • Project files not intended to be served are not available to web users
    • e.g. I cannot visit your webserver and see your package.json
  • The project will use package.json
  • The team may decide what additional directories, if any, they want for their served files

The page will use HTML best practices as outlined in class and assignments. In particular but not limited to:

  • Use HTML tags in a semantic fashion (choice of tags, grouping of content)
  • Indent when going to a newline inside a tag
    • html and body tags are not required to cause an indent
  • Use kebab-case class attributes
  • Avoid inline JS
  • Avoid inline CSS
  • Declare DOCTYPE html
  • Do not use table tags for layout
  • Do not use tags for layout due to the browser default rendering
    • Example: This means don't use <p> tags to line things up
  • Do not use non-breaking spaces (nbsp) to create space
  • Do not use <br> tags to create space

The page will use CSS best practices as outlined in class and assignments. In particular but not limited to:

  • kebab-case css class names
  • indented rules
  • class names reflect what the class content represents, not how it should be displayed
    • e.g. task-title is fine, red-bold is incorrect
  • Do not use the float property to create layout
  • Avoid hacks
  • Avoid browser-specific prefixes
  • Do not create styling that contradicts web conventions
    • e.g. creating something that looks like a button is fine
    • e.g. having blue underlined text that is not a link is incorrect
    • e.g. Clickable items should have the appropriate mouse icon (cursor property)
  • Avoid over-specifying CSS selectors
  • Avoid dramatic style changes to entire tags
    • It's fine to have a rule for a tag that just sets the specifics without violating expectations
    • e.g. specifying the bottom margin for all p tags is fine
    • e.g. specifying that all ul are now horizontal is incorrect

The page will use JS best practices as outlined in class and assignments. In particular but not limited to:

  • No pollution of the global namespace
    • Explicit settings of limited global variables is permitted to expose self-written libraries
  • Never use var
    • If Browserify generates var, this is fine
  • Use const when possible, let when necessary
  • No unnecessary String(), Object(), Array() etc uses
  • Use whitespace to improve clarity
  • Make your code skimmable as well as readable
  • Use meaningful and helpful variable names and function names
  • Use small functions
  • Follow the Principle of Least Knowledge
  • Use modern ES6 conventions
  • Use fetch() instead of XHR or an external library

The JS is not required to have unit tests

  • But it is not a bad idea

The page will communicate with at least one webservice written by the team

  • The team may use additional services they write
  • The services have no required paradigm (REST, GraphQL, whatever)
    • GET requests must be idempotent, however

Design

The /admin/design directory of your repo is where you'll store any documentation of your design (if you have hand-written sketches, drop in some pictures from a cellphone). Do not get overly complicated in the design at the start - just identify the general layout, what actions the user can take, and what the app does in reaction.

The goal of the initial design documentation is NOT to have everything perfect, or even good. In fact, rough and general is ideal at this step. You just need to have a shared basic understanding of what the app will do, and the experience of describing an actual app with a team will make our coverage later more meaningful.

Here are some samples of what I expect at different levels of effort. Any of these would be acceptable, as would non-visual descriptions, lots of arrows, multiple images, whatever works for your team.

Very Minimal Design sketch

Basic Design sketch

Fancy Design sketch

Responsibilities

Fill in the /admin/roles.md file and list the expected "job" of each member of the team. This is not a commitment of any kind, just an expectation. We will use it later to match what really happened to this initial expectation.

Delivery Milestones

This list will expand:

  • Feb 19, 11:59 pm - Have the initial design design concept in the /admin/design/ directory. Have the /admin/roles.md file filled in.
  • Feb 26, 6:29 pm - Have JS, HTML, and CSS for both the front-end and the services in the /src/ directory (subdirectories are fine). A package.json at your repo root should let me try the app with npm install; npm start. The page should work well enough to be usable, but bugs are expected.
  • Mar 5 - Spring Break. No deadline, but you should make sure you'll be able to make the Mar 12 deadline.
  • Mar 12, 6:29 pm - Bugs are expected to be corrected. The requirements of Added Requirements and Modified Requirements are complete. All of this is in your master branch.

Ongoing Requirements

Added Requirements

  • Create a service call that returns an id that returns 1, 2, or 3. Each call will return the number in the list after the previous number it sent, wrapping around to the beginning as needed. So on the first call (from anywhere) it will return 1, and on the second call (from the same page or not) returns 2, then 3, then 1 again and so forth. Do so as a POST, not a GET (be sure to understand why I'm saying that).
  • The page will, when the page is loaded, call the above fake id service. This will simulate a login - on page load the user is considered "logged in". On page reload the user is considered "logged in" as a different user;
  • The service may return this number inside whatever data structure you wish (e.g. it might return "2" or it could return "{ userId: 2 }")
  • The page will let the user know what their id for this page load is (example: text in the header "Welcome User 2!")

Modified Requirements

  • User votes now persist between page reloads.
    • Because the logged in user changes when you reload the page it will take a few reloads to see the page for the same user.
    • Example: User 1 votes for a book "Famous Cats of the Internet" but no one else has. On page reload the page displays as User 2. User 2 will see the effect of User 1's votes, but is not considered to have voted for it. Another reload will do the same as User 3. One more reload and the page displays as User 1, and they are unable to vote for Famous Cats of the Internet again
  • When a recommendation is initially entered, it records the user id that created it. This is displayed on the UI for all users looking at that recommendation.
  • The project MAY be in React, but does not have to be for the due date. The projects will eventually be required to be in React. This does not otherwise change the restrictions saying you cannot use outside JS or CSS libraries, which includes (for now) any React components that come from an outside source (Bootstrap, for example, is still forbidden). Note that moving to React will require some changes - either the services will have to run on a different port than the React webpack-dev-server, yet allow the page to access it despite CORS, or you will have to have the webpack dev server manage some of the task. The README That is created by create-react-app, not this one has some info on using a proxy configuration it has - you may, but are not required to, use this. Make sure that npm install, npm start continues to work. Do not 'eject' any create-react-app.

About

Book Recommendations is an SPA that allows users to enter/update book recommendations. The app will organize the listing of recommendations based on the data in the events and user choices.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •