Skip to content

chuckkainrath/cardgames

Repository files navigation

Welcome to Blak-Jak

To view the live project click here.

Technologies used: Python, JavaScript, React, Redux, Flask, SQLAlchemy, SocketIO, Tailwind, CSS.

Developed by:

Jeb Griffin

LinkedIn
GitHub
Portfolio

Chuck Kainrath

LinkedIn
GitHub
Portfolio

Tristan San Juan

LinkedIn
GitHub
Portfolio

Main Features

  • Single Player: All logged in users can play the AI in black jack.
  • Multiplayer: Up to 4 people can chanllenge the dealer in a live game.
  • Leader Board: All users are automatically ranked and the top 10 are displayed on the home page.

Splash Page

All logged out users will land here and must sign up or login to start playing.

Screen-Shot-2021-08-03-at-3-19-30-AM

Home Page

Displays nav functionality, users may view leaderboard, or start a game.

Single Player Game

A user can battle the AI in a single player game.

Multi-Player Game

Up to four users can battle the AI in a live game.

To Deploy:

  1. Clone this repository (only this branch)

    git clone https://github.com/chuckkainrath/cardgames.git
  2. Install dependencies

    pipenv install --dev -r dev-requirements.txt && pipenv install -r requirements.txt
  3. Create a .env file based on the example with proper settings for your development environment

  4. Setup your PostgreSQL user, password and database and make sure it matches your .env file

  5. Get into your pipenv, migrate your database, seed your database, and run your flask app

    pipenv shell
    flask db upgrade
    flask seed all
    flask run
  6. To run the React App in development, checkout the README inside the react-app directory.


IMPORTANT! If you add any python dependencies to your pipfiles, you'll need to regenerate your requirements.txt before deployment. You can do this by running:

pipenv lock -r > requirements.txt

ALSO IMPORTANT! psycopg2-binary MUST remain a dev dependency because you can't install it on apline-linux. There is a layer in the Dockerfile that will install psycopg2 (not binary) for us.


Deploy to Heroku

  1. Create a new project on Heroku

  2. Under Resources click "Find more add-ons" and add the add on called "Heroku Postgres"

  3. Install the Heroku CLI

  4. Run

    heroku login
  5. Login to the heroku container registry

    heroku container:login
  6. Update the REACT_APP_BASE_URL variable in the Dockerfile. This should be the full URL of your Heroku app: i.e. "https://flask-react-aa.herokuapp.com"

  7. Push your docker container to heroku from the root directory of your project. This will build the dockerfile and push the image to your heroku container registry

    heroku container:push web -a {NAME_OF_HEROKU_APP}
  8. Release your docker container to heroku

    heroku container:release web -a {NAME_OF_HEROKU_APP}
  9. set up your database:

    heroku run -a {NAME_OF_HEROKU_APP} flask db upgrade
    heroku run -a {NAME_OF_HEROKU_APP} flask seed all
  10. Under Settings find "Config Vars" and add any additional/secret .env variables.

  11. profit

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •