Skip to content

hunterwinterton/startup

Repository files navigation

Photo Galleries

Specification Deliverable

Elevator Pitch

Have you ever wanted an easy way to upload photos and share them with your friends or clients? Photo Galleries allows you to upload your pictures to a simple interface and automatically formats them into a pretty gallery. A link is also generated to allow others to view the gallery and download all the images into a zip file. You are able to create multiple galleries and modify them later after creating an account.

Design

Mockup of Photo Galleries

Key Features

  • Secure login over HTTPS
  • Ability to upload jpeg or png filetypes
  • Edit existing galleries after logging in
  • Images stored securely on the server
  • Generate unique, shareable links for each gallery
  • Ability to view the gallery in realtime
  • Analytics provide information on views and downloads

Key Technologies

I will use the required technology in the following ways.

  • HTML - Five HTML pages. One for users to login or register, one for users to upload photos, one for users to view a single gallery, one for users to view all of their galleries, and one for visitors to view shared galleries.
  • CSS - Clean and professional styling responsive on mobile and desktop. Hovering and clicking on photos will produce various effects.
  • React - Provides login functionality, displays photos in a grid view, allows uploading multiple photos at once, and navigating through the galleries.
  • Web Services - Backend services will handle:
    • Login
    • Uploading and storing photos
    • Managing galleries
    • Generating shareable links
    • Showing image location on a map
    • Retrieving general visitor location for analytics
  • Authentication - Register and login users. Requires a user to be logged in to create a gallery.
  • Database - Store users, galleries, photos, and links in the database.
  • WebSocket - Provides real time updates for analytics, new galleries and upload status.

HTML deliverable

For this deliverable I built out the structure of my application using HTML.

  • HTML pages - Five HTML pages that allow user to login/register, upload photos, view their gallery with analytics, view all of their galleries, and where visitors view a shared gallery
  • Links - The login page links to where the users can create a gallery. After creating a gallery, the user is redirected to a page with all of their galleries. Clicking on a gallery here will bring up an analytics page where the user can view their gallery and delete it.
  • Text - There is text for the titles and buttons of each page, but otherwise there isn't much text.
  • Images - I added a logo to all of the pages.
  • DB/Login - Input box and submit button for login.
  • WebSocket - The analytics page has a table that will show live visitors with downloads and views. I have not implemented this feature yet.

CSS deliverable

For this deliverable I styled my website using CSS.

  • Header, footer, and main content body
  • Navigation elements - I dropped the underlines and changed the color for anchor elements.
  • Responsive to window resizing - Most pages of my website are responsive, I have one that is mostly responsive but could still use some work.
  • Application elements - I made sure to align things properly and leave plenty of white space.
  • Application text content - I am using consistent fonts across all pages of my website.
  • Application images - I made the images in my app look good with rounded corners.

React deliverable

For this deliverable I converted my website to use React for flexibility. I also added placeholders for future technology.

  • Bundled and transpiled - done!
  • Components - Login, creating a gallery, viewing all galleries, viewing a specific gallery, and a public view of a gallery have been added as components.
    • login - When you press enter or the login button it takes you to the create a gallery page.
    • database - Stores whether or not the user is currently logged in, currently in local storage.
  • Router - Routing between login and gallery components.

Service deliverable

For this deliverable I added backend endpoints that creates users and galleries.

  • Node.js/Express HTTP service - done!
  • Static middleware for frontend - done!
  • Calls to third party endpoints - There is a random fact displayed on the bottom of the homepage.
  • Backend service endpoints - Placeholders for login that stores the current user on the server. Endpoints for gallery info.
  • Frontend calls service endpoints - Allows you to create a gallery on the frontend that saves to the backend. View galleries page is reactive to show all the users galleries.

DB/Login deliverable

For this deliverable I made user and gallery data persist in a database.

  • MongoDB Atlas database created - done!
  • Stores data in MongoDB - done!
  • User registration - Creates a new account in the database.
  • Use MongoDB to store credentials - Stores both users and their galleries.
  • Restricts functionality - You cannot create or view galleries until you have logged in.

WebSocket deliverable

For this deliverable I used webSocket to update the viewers of a shared gallery page in realtime.

  • Backend listens for WebSocket connection - done!
  • Frontend makes WebSocket connection - done!
  • Data sent over WebSocket connection - done!
  • WebSocket data displayed - The amount of people viewing a public gallery is shown on the view gallery page. There are a few minor bugs, such as it goes to 0 if you reload.

About

Startup application for BYU CS 260

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published