https://github.com/dimanu-py/advent-py
  
  
     
    https://github.com/dimanu-py/advent-py
  
        Last synced: 2 months ago 
        JSON representation
    
- Host: GitHub
- URL: https://github.com/dimanu-py/advent-py
- Owner: dimanu-py
- Created: 2023-12-06T18:39:32.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-12-21T17:01:54.000Z (almost 2 years ago)
- Last Synced: 2025-02-13T21:47:22.017Z (8 months ago)
- Language: HTML
- Homepage: https://advent-py.vercel.app
- Size: 619 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
 
Awesome Lists containing this project
README
          # DEVcember Programming Calendar
[](https://python.org)
[](https://reflex.dev)
[](https://nostalgic-css.github.io/NES.css)
[](https://vercel.com)
## What is it about?
Recently I've been interested in web development with Python. Found a tutorial from [Mouredev](https://github.com/mouredev) in YouTube where he shows how to make a web page with Python and Reflex. The main porpouse of his project is to give away a present every day related to the worl of programming.
I followed the tutorial and develop the web page with a similar format and style. However, I wanted to modify something and not just copy a project, so instead of opening a present each day, a python exercise would be open every day!
#### [Checkout Mouredev's tutorial](https://github.com/mouredev/adeviento-web/tree/main)
#### [Checkout my final project](https://advent-py.vercel.app/)
## Project
The structure of the project is as follows
* **advent_py**: main codebase
	* **advent_py.py**: web site index
	* **constants.py**: global constants
	* **styles**: styles directory (css, colors and fonts)
	* **views**: views directory (graphical sections)
	* **components**: components directory (graphic elements with less entity than a view)
* **assets**: graphic resources and JavaScript utilities (snow and countdown)
* **rxconfig.py**: main project configuration (set by default with reflex)
* **requirements.txt**: project dependencies
* **build.sh**: script to generate the static web to deploy it to production
* **[created] public**: static package of the project that would be deployed to production (HTML, CSS, JS and images)
## Configuration
1. `Fork` the repository
2. Clone this forked repo into your local machine. I recommend using SSH:
   ```bash
   git clone git@github.com:/advent-py.git
   ```
3. Go to the project root directory
   ```bash
   cd advent-py
   ```
4. Create a virtual environment and activate it
   ```bash
   python -m venv venv
   source venv/bin/activate
   ```
5. Install the project dependencies
   ```bash
   pip install -r requirements.txt
   ```
6. Initialize Reflex project
   ```bash
   reflex init
   ```
7. Run the project in your local machine
    ```bash
    reflex run
    ```
   It will prompt the ip link where the project is deployed. Click it directly or type in your browser `http://localhost:3000/`
## Resources




* Language: [Python](https://www.python.org/)
* Framework: [Reflex](https://reflex.dev/)
* CSS: [NES.css](https://nostalgic-css.github.io/NES.css/)
* Font: [Press Start 2P](https://fonts.google.com/specimen/Press+Start+2P)
* Hosting: [Vercel](https://vercel.com/)
### Visit my GitHub profile for more projects 🚀
[](https://github.com/dimanu-py)