mirror of
				https://github.com/kevinveenbirkenbach/homepage.veen.world.git
				synced 2025-11-04 01:18:09 +00:00 
			
		
		
		
	Updated README.md
This commit is contained in:
		
							
								
								
									
										173
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										173
									
								
								README.md
									
									
									
									
									
								
							@@ -1,42 +1,183 @@
 | 
				
			|||||||
# Portfolio
 | 
					# Portfolio: Flask-based Portfolio 🚀
 | 
				
			||||||
 | 
					
 | 
				
			||||||
This software allows people and institutions to setup an easy landingpage\homepage to show their portfolio. It's configured via an yaml file.
 | 
					This software allows individuals and institutions to set up an easy portfolio/landingpage/homepage to showcase their projects and online presence. It is highly customizable via a YAML configuration file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Features ✨
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- **Dynamic Navigation**: Easily create dropdown menus and nested links.
 | 
				
			||||||
 | 
					- **Customizable Cards**: Showcase your skills, projects, or services.
 | 
				
			||||||
 | 
					- **Cache Management**: Optimize your assets with automatic caching.
 | 
				
			||||||
 | 
					- **Responsive Design**: Beautiful on any device with Bootstrap.
 | 
				
			||||||
 | 
					- **Easy Configuration**: Update content using a YAML file.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Access 🌐
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Access
 | 
					 | 
				
			||||||
### Locale
 | 
					### Locale
 | 
				
			||||||
[http://127.0.0.1:5000](http://127.0.0.1:5000)
 | 
					Access the application locally at [http://127.0.0.1:5000](http://127.0.0.1:5000).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Configure
 | 
					## Getting Started 🏁
 | 
				
			||||||
To configure this app create an config.yaml you can use config.sample.yaml as an example
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Prerequisites 📋
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Docker and Docker Compose installed on your system.
 | 
				
			||||||
 | 
					- Basic knowledge of Python and YAML for configuration.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Installation 🛠️
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					1. **Clone the repository:**
 | 
				
			||||||
 | 
					   ```bash
 | 
				
			||||||
 | 
					   git clone <repository_url>
 | 
				
			||||||
 | 
					   cd <repository_directory>
 | 
				
			||||||
 | 
					   ```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					2. **Update the configuration:**
 | 
				
			||||||
 | 
					   Create a `config.yaml` file. You can use `config.sample.yaml` as an example (see below for details on the configuration).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					3. **Build and run the Docker container:**
 | 
				
			||||||
 | 
					   ```bash
 | 
				
			||||||
 | 
					   docker-compose up --build
 | 
				
			||||||
 | 
					   ```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					4. **Access your portfolio:** Open your browser and navigate to `http://localhost:5000`.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Configuration Guide 🔧
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The portfolio is powered by a YAML configuration file (`config.yaml`). This file allows you to define the structure and content of your site, including cards, navigation, and company details.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### YAML Configuration Example 📄
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```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: Microblogs
 | 
				
			||||||
 | 
					          description: Stay updated with my microblog posts.
 | 
				
			||||||
 | 
					          icon:
 | 
				
			||||||
 | 
					            class: fa-solid fa-pen-nib
 | 
				
			||||||
 | 
					          children:
 | 
				
			||||||
 | 
					            - name: Mastodon
 | 
				
			||||||
 | 
					              description: Follow my updates 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:
 | 
				
			||||||
 | 
					  titel: Kevin Veen-Birkenbach
 | 
				
			||||||
 | 
					  subtitel: Consulting and 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
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Understanding the `children` Key 🔍
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The `children` key allows hierarchical nesting of elements. Each child can itself have children, enabling the creation of multi-level navigation menus or grouped content. Example:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```yaml
 | 
				
			||||||
 | 
					children:
 | 
				
			||||||
 | 
					  - name: Parent Item
 | 
				
			||||||
 | 
					    description: Parent description.
 | 
				
			||||||
 | 
					    icon:
 | 
				
			||||||
 | 
					      class: fa-solid fa-folder
 | 
				
			||||||
 | 
					    children:
 | 
				
			||||||
 | 
					      - name: Child Item
 | 
				
			||||||
 | 
					        description: Child description.
 | 
				
			||||||
 | 
					        icon:
 | 
				
			||||||
 | 
					          class: fa-solid fa-file
 | 
				
			||||||
 | 
					        url: https://example.com
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					This structure will render a parent menu or section containing nested child elements. Each child can be further customized with icons, descriptions, and links.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Understanding the `link` Key 🔗
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The `link` key allows you to reference another part of the YAML configuration by its path. This is useful for avoiding duplication and maintaining consistency. Example:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```yaml
 | 
				
			||||||
 | 
					children:
 | 
				
			||||||
 | 
					  - name: Blog
 | 
				
			||||||
 | 
					    description: My blog posts.
 | 
				
			||||||
 | 
					    icon:
 | 
				
			||||||
 | 
					      class: fa-solid fa-blog
 | 
				
			||||||
 | 
					    url: https://example.com/blog
 | 
				
			||||||
 | 
					  - name: Featured Blog
 | 
				
			||||||
 | 
					    link: accounts.children[0].children[0]  # References the "Blog" item above
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					In this example, `Featured Blog` will inherit all properties from the `Blog` item, including its name, description, and URL. This feature ensures that any updates to the `Blog` item are automatically reflected in all linked entries.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Administrate Docker 🐳
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Administrate Docker
 | 
					 | 
				
			||||||
### Stop and Destroy
 | 
					### Stop and Destroy
 | 
				
			||||||
```bash 
 | 
					```bash
 | 
				
			||||||
docker stop landingpage
 | 
					docker stop portfolio
 | 
				
			||||||
docker rm landingpage
 | 
					docker rm portfolio
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Build
 | 
					### Build
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
docker build -t application-landingpage .
 | 
					docker build -t application-portfolio .
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Run
 | 
					### Run
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Run Development Environment
 | 
					#### Run Development Environment
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
docker run -d -p 5000:5000 --name landingpage -v $(pwd)/app/:/app -e FLASK_APP=app.py -e FLASK_ENV=development application-landingpage
 | 
					docker run -d -p 5000:5000 --name portfolio -v $(pwd)/app/:/app -e FLASK_APP=app.py -e FLASK_ENV=development application-portfolio
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#### Run Production Environment
 | 
					#### Run Production Environment
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
docker run -d -p 5000:5000 --name landingpage application-landingpage
 | 
					docker run -d -p 5000:5000 --name portfolio application-portfolio
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
### Debug
 | 
					### Debug
 | 
				
			||||||
```bash
 | 
					```bash
 | 
				
			||||||
docker logs -f landingpage
 | 
					docker logs -f portfolio
 | 
				
			||||||
```
 | 
					```
 | 
				
			||||||
## Author
 | 
					
 | 
				
			||||||
This software was created from [Kevin Veen-Birkenbach](https://www.veen.world/).
 | 
					## Development Mode 🧑💻
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					To run the app in development mode with hot-reloading:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					```bash
 | 
				
			||||||
 | 
					FLASK_ENV=development docker-compose up
 | 
				
			||||||
 | 
					```
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Deployment 🚢
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					For production deployment, ensure to:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- Use a reverse proxy like NGINX or Apache.
 | 
				
			||||||
 | 
					- Secure your site with SSL/TLS.
 | 
				
			||||||
 | 
					- Use a production-ready database if required.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## Author ✍️
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					This software was created by [Kevin Veen-Birkenbach](https://www.veen.world/).
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					## License 📜
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					This project is licensed under the GNU Affero General Public License Version 3. See the [LICENSE](./LICENSE) file for details.
 | 
				
			||||||
		Reference in New Issue
	
	Block a user