Skip to content

shayanahmad7/sweeterthanfiction

Repository files navigation

Sweeter Than Fiction

Overview

Sweeter Than Fiction is a community web app designed exclusively for Taylor Swift enthusiasts. It serves as a hub for fans to explore Taylor Swift's extensive discography, engage in discussions, and document their Swiftie journey. Here are the key features:

  • Users can create an account and log in.
  • Access a comprehensive database of Taylor Swift's songs and albums.
  • Search for songs directly or explore albums to view their tracklists.
  • View detailed information about each song, including lyrics and descriptions.
  • Engage in discussions about songs, albums, and Taylor Swift in general.
  • Create and edit wishlists, allowing users to document their current favorite songs and share their thoughts with the community.

Features Achieved

User Authentication

Sweeter Than Fiction has implemented a straightforward user authentication process. Users can register by providing the following information:

  • Name
  • Email
  • Username
  • Birthday
  • Password (hashed)

To log in, users can enter either their email or username along with their password.

Passwords are securely hashed before being stored in the database to ensure user security.

User Dashboard

The user dashboard provides the following features:

  • Profile page displaying user information.
  • Access to a list of albums with details.
  • Access to song details including lyrics and descriptions.
  • Participation in discussions.
  • Creation and editing of wishlists.

Discussions

Sweeter Than Fiction allows users to engage in discussions on various topics, including general discussions, album discussions, and song discussions.

Client-Side Form Validation

Client-side form validation has been implemented to enhance the user experience. The following fields are validated:

  • Name (All letters)
  • Username (Letters and numbers, unique)
  • Password (8 characters, alphanumeric)

Features Pending Due to Time Constraints

  • Utilization of vue.js as the frontend framework for dynamic user interactions.

Data Model

Sweeter Than Fiction utilizes the following data model:

  • Users

    • Name
    • Email
    • Username
    • Birthday
    • Password (hashed)
  • Albums

    • Title
    • Release Date
    • Awards
    • List of Songs
  • Songs

    • Title
    • Lyrics
    • Description
    • Album
    • Discussion Comments
  • Discussion Posts

    • User
    • Content
    • Timestamp
  • Wishlist

    • User
    • Song
    • Description
    • Timestamp (for each edit)

User Stories or Use Cases

  1. As a Taylor Swift fan, I want to be able to create an account on the website so that I can engage with the community and access the features.
  2. As a registered user, I want to log in to the site with my email or username and password.
  3. As a user, I want to explore Taylor Swift's albums and view the tracklists.
  4. As a user, I want to view detailed information about each song, including lyrics and descriptions.
  5. As a user, I want to participate in discussions about songs, albums, and Taylor Swift in general.
  6. As a user, I want to create and edit wishlists to document my current favorite songs and share my thoughts with the community.

Research Topics

  • (5 points) Integrate user authentication

    • Utilize basic user information (Name, Email, Username, Birthday, Password) for registration and login.
  • (4 points) Implement client-side form validation using JavaScript library.

  • (5 points) Utilize vue.js as the frontend framework for a dynamic user experience.

Total Points: 14 (Exceeding the required 8 points)

Link to Initial Main Project File

Link to Initial Main Project File

Annotations / References Used

  1. passport.js authentication docs - (add link to source code that was based on this)
  2. tutorial on vue.js - (add link to source code that was based on this)