Coder Social home page Coder Social logo

rivasbolinga / my-things Goto Github PK

View Code? Open in Web Editor NEW
2.0 1.0 1.0 690 KB

Console app that helps to keep a record of different type of things we can own like books, music albums movies and games

Ruby 100.00%
capstone-project collaboration postgresql ruby team-work

my-things's Introduction

logo

Ruby Group Capstone: Catalog of My Things

๐Ÿ“— Table of Contents

๐Ÿ“– Catalog of My Things

Catalog of My Things is a console app that will help a user to keep a record of different types of things he owns: books, music albums, and games. Everything will be based on the UML class diagram presented above. The data will be stored in JSON files but we will also prepare a database with tables structure analogical to our program's class structure.

๐Ÿ›  Built With

Tech Stack

Client
Database

Key Features

  • 1 - User interface where the user can choose between a variety of options

    Screenshot 2023-08-10 at 16 31 22
  • 2 - All the data is preserved in json files

  • 3 - Create as part of a collaborative project

  • 4 - All data is stored in a database

(back to top)

๐ŸŽฅ Video Demonstration

You can see the Video demonstration ๐Ÿ“ here.

(back to top)

๐Ÿ’ป Getting Started

Prerequisites

In order to run this project you need:

 gem install bundler

Setup

Clone this repository to your desired folder:

  cd my-folder
  git https://github.com/rivasbolinga/my-things.git

Install

Install this project with:

  cd my-things
  bundle install

Usage

To run the project, execute the following command:

  ruby main.rb

Run tests

To run tests, run the following command:

  rspec spec

(back to top)

๐Ÿ‘ฅ Authors

๐Ÿ‘ค Andrea Rivas

๐Ÿ‘ค Christian Romuald Momo Tonfack

๐Ÿ‘ค Mohamad Almeari

(back to top)

๐Ÿ”ญ Future Features

  • Add Movie class
  • Remove and update options
  • Create more relationships between the classes

(back to top)

๐Ÿค Contributing

Contributions, issues, and feature requests are welcome!

Feel free to check the issues page.

(back to top)

โญ๏ธ Show your support

If you like this project, please give it a star โญ๏ธ.

(back to top)

๐Ÿ™ Acknowledgments

I would like to thank the Microverse community for their supports.

(back to top)

๐Ÿ“ License

This project is MIT licensed.

(back to top)

my-things's People

Contributors

mohametalmeari avatar momo-87 avatar rivasbolinga avatar

Stargazers

 avatar  avatar

Watchers

 avatar

Forkers

momo-87

my-things's Issues

[4pt] Implement methods for Game and Author classes.

  • Implement methods:
    • add_item method in the Author class
      • should take an instance of the Item class as an input
      • should add the input item to the collection of items
      • should add self as a property of the item object (by using the correct setter from the item object)
    • can_be_archived?() in the Game class
      • should override the method from the parent class
      • should return true if parent's method returns true AND if last_played_at is older than 2 years
      • otherwise, it should return false

[4pt] Implement methods for Label and Book classes.

  • Implement methods:
    • add_item method in the Label class
      • should take an instance of the Item class as an input
      • should add the input item to the collection of items
      • should add self as a property of the item object (by using the correct setter from the item object)
    • can_be_archived?() in the Book class
      • should override the method from the parent class
      • should return true if parent's method returns true OR if cover_state equals to "bad"
      • otherwise, it should return false

[3pts] Create Schema.sql file.

  • Create a schema.sql file with tables that will be analogical to the structure of the classes that you created:
    • books table (add all properties and associations from the parent Item class as table columns)
    • labels table

[2pt] Create Game and Author classes.

  • Create a Game class in a separate .rb file.
  • Create an Author class with an association to the Item class (in a separate .rb file).
  • All Game class properties visible in the diagram should be defined and set up in the constructor method.
  • All Author class properties visible in the diagram should be defined and set up in the constructor method.

[2pts] Create MusicAlbum and Genre classes

  • Create MusicAlbum class in a separate .rb file.
  • Create Genre class with an association to the Item class (in a separate .rb file).
  • All MusicAlbum class properties visible in the diagram should be defined and set up in the constructor method.
  • All Genre class properties visible in the diagram should be defined and set up in the constructor method.

[3pts] Create schema.sql file.

  • Create a schema.sql file with tables that will be analogical to the structure of the classes that you created:
    • games table (add all properties and associations from the parent Item class as table columns)
    • authors table

[3pts] Creating data model

Build the project schema by creating and running the necessary migration files following the ERD diagram.

[5pts] Preserve All Data

  • The following options should be available:
    • List all music albums
    • List all genres (e.g 'Comedy', 'Thriller')
    • Add a music album
  • All data should be preserved by saving collections in .json files.

[5pts] Preserve all data.

  • The following options should be available:
    • List of games
    • List all authors (e.g. 'Stephen King')
    • Add a game
  • All data should be preserved by saving collections in .json files.

[2pt] Create Book and Label classes.

  • Create a Book class in a separate .rb file.
  • Create a Label class with an association to the Item class (in a separate .rb file).
  • All Book class properties visible in the diagram should be defined and set up in the constructor method.
  • All Label class properties visible in the diagram should be defined and set up in the constructor method.

[3pts] Create Schema.sql file

  • Create a schema.sql file with tables that will be analogical to the structure of the classes that you created:
    • music_albums table (add all properties and associations from the parent Item class as table columns)
    • genres table

[2pt] Implement Methods (Group task)

Description to be added- Implement methods:
- can_be_archived?() in the Item class
- should return true if published_date is older than 10 years
- otherwise, it should return false
- move_to_archive() in the Item class
- should reuse can_be_archived?() method
- should change the archived property to true if the result of the can_be_archived?() method is true
- should do nothing if the result of the can_be_archived?() method is false

[5pts] Preserve all data.

The following options should be available:
- List all books
- List all labels (e.g. 'Gift', 'New')
- Add a book

  • All data should be preserved by saving collections in .json files.

[2pt] Create UI (Group task)

  • Create a main.rb file that will serve as your console app entry-point.
  • Implement startup actions:
    • Present the user with a list of options to perform.
    • Let users choose an option.
    • If needed, ask for parameters for the option.
    • Have a way to quit the app.

[2pt] Create Item class (Group task)

  • Create Item class in a separate .rb file.
  • All Item class properties visible in the diagram should be defined and set up in the constructor method. Exception: properties for the 1-to-many relationships should NOT be set in the constructor method. Instead, they should have a custom setter method created.
  • Add all methods visible in the diagram.

[4pts] Implement Methods for MusicAlbum and Genre Class

  • Implement methods:
    • add_item method in the Genre class
      • should take an instance of the Item class as an input
      • should add the input item to the collection of items
      • should add self as a property of the item object (by using the correct setter from the item object)
    • can_be_archived?() in the MusicAlbum class
      • should override the method from the parent class
      • should return true if parent's method returns true AND if on_spotify equals true
      • otherwise, it should return false

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.