mirror of
https://github.com/kevinveenbirkenbach/homepage.veen.world.git
synced 2025-07-17 15:04:23 +02:00
PortUI 🖥️✨
A lightweight, Docker-powered portfolio/landing-page generator—fully customizable via YAML! Showcase your projects, skills, and online presence in minutes.
🚀 You can also pair PortUI with JavaScript for sleek, web-based desktop-style interfaces.
💻 Example in action: CyMaIS.Cloud (demo)
🌐 Another live example: veen.world (Kevin’s personal site)
✨ Key Features
- 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 simpleconfig.yaml
. - CLI Control
Manage Docker containers via theportfolio
command.
🌐 Quick Access
- Local Preview:
http://127.0.0.1:5000
🏁 Getting Started
🔧 Prerequisites
- Docker & Docker Compose
- Basic Python & YAML knowledge
🛠️ Installation via Git
-
Clone & enter repo
git clone <repository_url> cd <repository_directory>
-
Configure Copy
config.sample.yaml
→config.yaml
& customize. -
Build & run
docker-compose up --build
-
Browse Open http://localhost:5000
📦 Installation via Kevin’s Package Manager
pkgmgr install portui
Once installed, the portui
CLI is available system-wide.
🖥️ CLI Commands
portui --help
build
Build the Docker imageup
Start containers (with build)down
Stop & remove containersrun-dev
Dev mode (hot-reload)run-prod
Production modelogs
View container logsdev
Docker-Compose dev environmentprod
Docker-Compose prod environmentcleanup
Prune stopped containers
🔧 YAML Configuration Guide
Define your site’s structure in config.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:
- name: Mastodon
description: Follow me on Mastodon.
icon:
class: fa-brands fa-mastodon
url: https://microblog.veen.world/@kevinveenbirkenbach
identifier: "@kevinveenbirkenbach@microblog.veen.world"
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
company:
title: Kevin Veen-Birkenbach
subtitle: Consulting & Coaching Solutions
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
children
enables multi-level menus.link
references other YAML paths to avoid duplication.
🚢 Production Deployment
- Use a reverse proxy (NGINX/Apache).
- Secure with SSL/TLS.
- Swap to a production database if needed.
📜 License
Licensed under GNU AGPLv3. See LICENSE for details.
✍️ Author
Created by Kevin Veen-Birkenbach
Enjoy building your portfolio! 🌟
Languages
JavaScript
56.7%
Python
19.8%
Jinja
14.8%
CSS
6%
Makefile
2.4%
Other
0.3%