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.
- 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
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.
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.
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.
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.
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.
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.
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.