Files
port-ui/README.md

162 lines
4.3 KiB
Markdown
Raw Normal View History

2025-07-12 18:24:49 +02:00
# PortWebUI 🖥️✨
2025-03-12 20:52:48 +01:00
2025-07-12 18:24:49 +02:00
[![GitHub Sponsors](https://img.shields.io/badge/Sponsor-GitHub%20Sponsors-blue?logo=github)](https://github.com/sponsors/kevinveenbirkenbach)
[![Patreon](https://img.shields.io/badge/Support-Patreon-orange?logo=patreon)](https://www.patreon.com/c/kevinveenbirkenbach)
[![Buy Me a Coffee](https://img.shields.io/badge/Buy%20me%20a%20Coffee-Funding-yellow?logo=buymeacoffee)](https://buymeacoffee.com/kevinveenbirkenbach)
[![PayPal](https://img.shields.io/badge/Donate-PayPal-blue?logo=paypal)](https://s.veen.world/paypaldonate)
2025-01-16 22:56:02 +01:00
2025-07-12 18:24:49 +02:00
A lightweight, Docker-powered portfolio/landing-page generator—fully customizable via YAML! Showcase your projects, skills, and online presence in minutes.
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
> 🚀 You can also pair PortWebUI with JavaScript for sleek, web-based desktop-style interfaces.
> 💻 Example in action: [CyMaIS.Cloud](https://cymais.cloud/) (demo)
> 🌐 Another live example: [veen.world](https://www.veen.world/) (Kevins personal site)
2025-07-12 18:22:19 +02:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## ✨ Key Features
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
- **Dynamic Navigation**
Create dropdowns & nested menus with ease.
- **Customizable Cards**
Highlight skills, projects, or services—with icons, titles, and links.
- **Smart Cache Management**
Auto-cache assets for lightning-fast loading.
- **Responsive Design**
Built on Bootstrap; looks great on desktop, tablet & mobile.
- **YAML-Driven**
All content & structure defined in a simple `config.yaml`.
- **CLI Control**
Manage Docker containers via the `portfolio` command.
2025-01-08 14:59:36 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## 🌐 Quick Access
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
- **Local Preview:**
[http://127.0.0.1:5000](http://127.0.0.1:5000)
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## 🏁 Getting Started
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
### 🔧 Prerequisites
2025-03-20 00:23:35 +01:00
2025-07-12 18:24:49 +02:00
- Docker & Docker Compose
- Basic Python & YAML knowledge
### 🛠️ Installation via Git
1. **Clone & enter repo**
2025-01-16 23:12:49 +01:00
```bash
git clone <repository_url>
cd <repository_directory>
2025-07-12 18:26:51 +02:00
```
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
2. **Configure**
Copy `config.sample.yaml``config.yaml` & customize.
3. **Build & run**
2025-01-16 23:12:49 +01:00
```bash
docker-compose up --build
```
2025-07-12 18:24:49 +02:00
4. **Browse**
Open [http://localhost:5000](http://localhost:5000)
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
### 📦 Installation via Kevins Package Manager
2025-03-20 00:23:35 +01:00
```bash
pkgmgr install portfolio
```
2025-07-12 18:24:49 +02:00
Once installed, the `portfolio` CLI is available system-wide.
2025-03-20 00:23:35 +01:00
2025-07-12 18:24:49 +02:00
---
2025-03-20 00:23:35 +01:00
2025-07-12 18:24:49 +02:00
## 🖥️ CLI Commands
2025-03-20 00:23:35 +01:00
```bash
portfolio --help
```
2025-07-12 18:24:49 +02:00
* `build`Build the Docker image
* `up`Start containers (with build)
* `down`Stop & remove containers
* `run-dev`Dev mode (hot-reload)
* `run-prod`Production mode
* `logs`View container logs
* `dev`Docker-Compose dev environment
* `prod`Docker-Compose prod environment
* `cleanup`Prune stopped containers
2025-03-20 00:23:35 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## 🔧 YAML Configuration Guide
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
Define your sites structure in `config.yaml`:
2025-01-16 23:12:49 +01:00
```yaml
accounts:
name: Online Accounts
description: Discover my online presence.
icon:
class: fa-solid fa-users
children:
- name: Channels
description: Platforms where I share content.
icon:
class: fas fa-newspaper
children:
2025-07-12 18:24:49 +02:00
- name: Mastodon
description: Follow me on Mastodon.
2025-01-16 23:12:49 +01:00
icon:
2025-07-12 18:24:49 +02:00
class: fa-brands fa-mastodon
url: https://microblog.veen.world/@kevinveenbirkenbach
identifier: "@kevinveenbirkenbach@microblog.veen.world"
2025-01-16 23:12:49 +01:00
cards:
- icon:
source: https://cloud.veen.world/s/logo_agile_coach_512x512/download
title: Agile Coach
text: I lead agile transformations and improve team dynamics through Scrum and Agile Coaching.
url: https://www.agile-coach.world
link_text: www.agile-coach.world
2025-07-12 18:24:49 +02:00
2025-01-16 23:12:49 +01:00
company:
2025-07-12 18:24:49 +02:00
title: Kevin Veen-Birkenbach
subtitle: Consulting & Coaching Solutions
2025-01-16 23:12:49 +01:00
logo:
source: https://cloud.veen.world/s/logo_face_512x512/download
favicon:
source: https://cloud.veen.world/s/veen_world_favicon/download
address:
street: Afrikanische Straße 43
postal_code: DE-13351
city: Berlin
country: Germany
imprint_url: https://s.veen.world/imprint
```
2025-07-12 18:24:49 +02:00
* **`children`** enables multi-level menus.
* **`link`** references other YAML paths to avoid duplication.
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## 🚢 Production Deployment
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
* Use a reverse proxy (NGINX/Apache).
* Secure with SSL/TLS.
* Swap to a production database if needed.
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## 📜 License
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
Licensed under **GNU AGPLv3**. See [LICENSE](./LICENSE) for details.
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
---
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
## ✍️ Author
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
Created by [Kevin Veen-Birkenbach](https://www.veen.world/)
2025-01-16 23:12:49 +01:00
2025-07-12 18:24:49 +02:00
Enjoy building your portfolio! 🌟