Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yatozuki/steam-game-page
Steam Game Page is a Node.js app using the Steam API to create dynamic game pages with descriptions, images, and metadata. Built with HTML, CSS, Bootstrap, EJS, and Express.js.
https://github.com/yatozuki/steam-game-page
axios bootstrap5 compression css ejs-template-engine express html5 javasc nodejs nsfw steam-api
Last synced: 16 days ago
JSON representation
Steam Game Page is a Node.js app using the Steam API to create dynamic game pages with descriptions, images, and metadata. Built with HTML, CSS, Bootstrap, EJS, and Express.js.
- Host: GitHub
- URL: https://github.com/yatozuki/steam-game-page
- Owner: yatozuki
- Created: 2024-12-19T11:39:39.000Z (2 months ago)
- Default Branch: master
- Last Pushed: 2025-01-02T09:23:52.000Z (about 2 months ago)
- Last Synced: 2025-01-02T10:33:26.674Z (about 2 months ago)
- Topics: axios, bootstrap5, compression, css, ejs-template-engine, express, html5, javasc, nodejs, nsfw, steam-api
- Language: JavaScript
- Homepage:
- Size: 3.46 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Steam Game Page
data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="License"
data:image/s3,"s3://crabby-images/16128/16128e434e30bf5bb3389ef47d0439a52f7916e0" alt="Contributions"
data:image/s3,"s3://crabby-images/3c405/3c40525c22954a47a0ff77b0a23700a20009d8b3" alt="HTML5"
data:image/s3,"s3://crabby-images/2b0fc/2b0fcbd200023655985e381fb24fbb8a4e4058fa" alt="CSS3"
data:image/s3,"s3://crabby-images/b859e/b859eb900453a883294072aa31be408eb5d20cd5" alt="JavaScript"
data:image/s3,"s3://crabby-images/77617/77617d31c0dce14e3c6745a20cfafa1fe0fd62b1" alt="Bootstrap"
data:image/s3,"s3://crabby-images/8a3b3/8a3b371b2535ad7580f90f88fd9172df3647b576" alt="NodeJS"
data:image/s3,"s3://crabby-images/e426d/e426d30f8791059ee3b0ee9357dc94f267299c34" alt="Express.js"
data:image/s3,"s3://crabby-images/35498/35498e1d939631586513cb645274a87fca787f04" alt="EJS"
data:image/s3,"s3://crabby-images/1e728/1e7287df4d12554c093e3455921d05e7654d14b5" alt="Axios"
data:image/s3,"s3://crabby-images/69c7e/69c7e984e66c6446e45df2654bcdbc678f3a8236" alt="Compression"
data:image/s3,"s3://crabby-images/ddce9/ddce976024e18d85ed66677819e3afbca172727d" alt="Steam API"---
## 📝 Description
Steam Game Page Generator is a Node.js application that creates dynamic game pages using data fetched from the Steam Public API. The website allows users to browse and explore detailed information about Steam games, such as game descriptions, images, and metadata, in a clean and visually appealing layout.
This project is built with HTML5, CSS3, and Bootstrap for the front end, while EJS templates and Express.js handle server-side rendering for smooth performance. Axios is used to fetch data from the API, and Compression helps optimize server response times.
The primary goal of this project is to provide a functional and responsive interface for exploring game data while keeping the implementation simple and beginner-friendly.
---
## ⚠️ Warning
This website **does not filter or censor NSFW (Not Safe For Work) content** fetched from the Steam Public API. Games and content displayed on the website are sourced directly from the Steam database and may include mature or inappropriate material. Users should exercise caution while browsing, especially in public or shared environments. Viewer discretion is advised.
---
## 💻 Compatibility
Currently, this project is optimized for **1920x1080 screen resolution**. While it is functional at other resolutions, users may experience misalignment, overlapping elements, or other layout issues. Future updates may include improvements for better responsiveness across multiple devices and screen sizes.
---
## 🚧 Known Bug
**External CSS Issue**: When the server is first started, the external CSS may not load properly. This results in unstyled pages when the website is initially accessed.
**Temporary Solution**:
1. Navigate to any game page by clicking on a game link.
2. Reload the page.
3. Return to the homepage. The CSS will be correctly applied.This issue occurs due to an asynchronous loading conflict between the server and static files. A long-term fix is planned for future updates.
---
## 🚀 Setup
1. Clone the repository:
```
git clone https://github.com/yatozuki/Steam-Game-Page.git
```2. Navigate to the project directory:
```
cd Steam-Game-Page
```3. Create a directory for data storage:
```
mkdir data
```4. Install dependencies:
```
npm i
```5. Start the server:
```
nodemon app.js
```6. Open the website in your browser:
```
localhost:3000
```**First-Time Setup Steps:**
- On the first run, the application will create a `games.json` file in the `data` directory automatically.
- If you see a connection error, reload the website to allow the `prices.json` file to generate.
- Reload the page once more to fully load the game data and display the content.**Navigate Directly to a Specific Page:**
Append `?page=pagenumber` to the URL to skip to a specific page. For example:
```
localhost:3000?page=2
```---
## 🖼️ Screenshots
### Homepage
### Game Details Page
---
## 🤝 Contributing
I welcome contributions from everyone! If you have ideas for improvements, new features, or spot any issues, feel free to open a pull request or raise an issue. Your suggestions and efforts to enhance the project are greatly appreciated!---
## 🛡️ License
This project is licensed under the MIT License. This means you are free to:- **Use**: You can use the project for personal or commercial purposes.
- **Modify**: You can make changes to the code as needed.
- **Distribute**: You can share the project, either in its original state or with modifications, with others.However, all usage, modification, and distribution must include proper attribution to the original authors. For more details, see the [MIT License](https://opensource.org/licenses/MIT).