30 Commits

Author SHA1 Message Date
Max
08b1b8f641 feat: init tf 2025-01-09 15:20:49 -05:00
Max
3fb6801188 feat: portfolio terraform 2025-01-09 15:15:26 -05:00
Max
7003f25566 feat: added back Gemfile 2025-01-09 14:52:44 -05:00
Max
7f76759b03 feat: gitea-ize
Some checks failed
Prepare changes for deployment. / prepare (push) Has been cancelled
2025-01-08 19:59:29 -05:00
MajorDroolz
c1377d50a0 FIX: All large styles/fonts are now preloaded. 2023-01-06 23:42:22 -05:00
MajorDroolz
d2f424a7c9 FIX: Compressed images, removed most content layout shifting. 2023-01-06 23:26:00 -05:00
MajorDroolz
9697866181 FIX: Gemfiles still present 2023-01-06 20:06:31 -05:00
MajorDroolz
a793d7ce4b FIX: Removed unneeded files. 2023-01-06 19:59:36 -05:00
Max Hutz
aa4fdaf435 FEAT: Add meaningful description to README. 2023-01-06 19:53:59 -05:00
MajorDroolz
8f6d45ca53 FEAT: CRISIS, and with that all, project content complete. 2023-01-06 19:34:05 -05:00
MajorDroolz
de2506ad9d FEAT: Added Poll Buddy content. 2023-01-06 17:53:31 -05:00
MajorDroolz
cc4b87d9c5 FIX: Malung link removed, FreshManuals link fixed, all outside links create tab. 2023-01-06 15:51:57 -05:00
MajorDroolz
81f467e16a FEAT: Info for FreshManuals mobile app. 2023-01-06 04:52:52 -05:00
MajorDroolz
9ac21fac1e FIX: images correctly center, and shrink on screen size. 2023-01-06 04:01:55 -05:00
MajorDroolz
662bc0a2ed FEAT: Added Malung info. 2023-01-06 03:57:38 -05:00
MajorDroolz
1452840240 FIX: Removed duplicate jekyll code with include. 2023-01-05 00:22:03 -05:00
MajorDroolz
ec2e17cee1 FIX: Experiences don't have a description. 2023-01-05 00:08:41 -05:00
MajorDroolz
a554ca8fa6 FIX: Not text inside image boxes have inner padding. 2023-01-05 00:00:28 -05:00
MajorDroolz
9611cde594 FIX: Experiences don't have a description. 2023-01-04 23:49:15 -05:00
MajorDroolz
7edafd8677 FIX: Removed incompatible Jekyll plugin. 2023-01-04 23:43:05 -05:00
MajorDroolz
7463c1927a FIX: Remove HTML Minifier 2023-01-04 23:30:37 -05:00
MajorDroolz
fed3479ed1 TEST: prepare.yml 2023-01-04 23:30:24 -05:00
MajorDroolz
810ede3202 FIX: Image not available for project list. 2023-01-04 23:29:35 -05:00
MajorDroolz
a4a4e04ab2 FIX: Workflow to work with jekyll. 2023-01-04 23:16:48 -05:00
MajorDroolz
219a7543de FIX: Description for projects now works. 2023-01-04 22:47:52 -05:00
MajorDroolz
87a3c3d2b4 FIX: Only ready work in documented. Images added, view ubtton optional. 2023-01-04 22:18:53 -05:00
MajorDroolz
34e75a3748 Project pages now auto-generated with jekyll data. 2023-01-04 21:32:02 -05:00
MajorDroolz
f0b2bc0474 FEAT: Created first demo of project page for malung. 2023-01-04 04:26:14 -05:00
MajorDroolz
28e1dcc5d5 Pull from main. 2023-01-04 03:01:06 -05:00
MajorDroolz
e011480ad1 Merge pull request #17 from MajorDroolz/project-list
Project list
2023-01-04 02:36:26 -05:00
44 changed files with 800 additions and 200 deletions

BIN
.DS_Store vendored

Binary file not shown.

View File

@@ -19,7 +19,7 @@ jobs:
node-version: '16'
- name: Install dependencies.
run: npm i -g terser csso-cli html-minifier
run: npm i -g terser csso-cli
- name: "Copying changes over to build."
run: git checkout -b build
@@ -28,7 +28,6 @@ jobs:
run: |
find . -name "*.js" -type f -exec terser {} -c -o {} \;
find . -name "*.css" -type f -exec csso {} -o {} \;
find . -name "*.html" -type f -exec html-minifier --remove-comments --collapse-whitespace {} -o {} \;
- name: "Commiting changes."
run: |

43
.gitignore vendored
View File

@@ -3,3 +3,46 @@ _site
.jekyll-cache
vendor
.vscode
.DS_Store
secrets
secret.tfvars
# ---> Terraform
# Local .terraform directories
.terraform
# .tfstate files
*.tfstate
*.tfstate.*
# Crash log files
crash.log
crash.*.log
# Exclude all .tfvars files, which are likely to contain sensitive data, such as
# password, private keys, and other secrets. These should not be part of version
# control as they are data points which are potentially sensitive and subject
# to change depending on the environment.
*.tfvars
*.tfvars.json
# Ignore override files as they are usually used to override resources locally and so
# are not checked in
override.tf
override.tf.json
*_override.tf
*_override.tf.json
# Include override files you do wish to add to version control using negated pattern
# !example_override.tf
# Include tfplan files to ignore the plan output of command: terraform plan -out=tfplan
# example: *tfplan*
# Ignore CLI configuration files
*.terraformrc
terraform.rc
# ---------------------------------------------------------------------------- #
# Custom ignores.

33
Gemfile
View File

@@ -1,2 +1,33 @@
source "https://rubygems.org"
gem "jekyll", "~> 4.3"
# Hello! This is where you manage which Jekyll version is used to run.
# When you want to use a different version, change it below, save the
# file and run `bundle install`. Run Jekyll with `bundle exec`, like so:
#
# bundle exec jekyll serve
#
# This will help ensure the proper Jekyll version is running.
# Happy Jekylling!
gem "jekyll", "~> 4.3.4"
# This is the default theme for new Jekyll sites. You may change this to anything you like.
gem "minima", "~> 2.5"
# If you want to use GitHub Pages, remove the "gem "jekyll"" above and
# uncomment the line below. To upgrade, run `bundle update github-pages`.
# gem "github-pages", group: :jekyll_plugins
# If you have any plugins, put them here!
group :jekyll_plugins do
gem "jekyll-feed", "~> 0.12"
end
# Windows and JRuby does not include zoneinfo files, so bundle the tzinfo-data gem
# and associated library.
platforms :mingw, :x64_mingw, :mswin, :jruby do
gem "tzinfo", ">= 1", "< 3"
gem "tzinfo-data"
end
# Performance-booster for watching directories on Windows
gem "wdm", "~> 0.1", :platforms => [:mingw, :x64_mingw, :mswin]
# Lock `http_parser.rb` gem to `v0.6.x` on JRuby builds since newer versions of the gem
# do not have a Java counterpart.
gem "http_parser.rb", "~> 0.6.0", :platforms => [:jruby]

View File

@@ -1,21 +1,49 @@
GEM
remote: https://rubygems.org/
specs:
addressable (2.8.1)
public_suffix (>= 2.0.2, < 6.0)
addressable (2.8.7)
public_suffix (>= 2.0.2, < 7.0)
bigdecimal (3.1.9)
colorator (1.1.0)
concurrent-ruby (1.1.10)
concurrent-ruby (1.3.4)
em-websocket (0.5.3)
eventmachine (>= 0.12.9)
http_parser.rb (~> 0)
eventmachine (1.2.7)
ffi (1.15.5)
ffi (1.17.1)
ffi (1.17.1-aarch64-linux-gnu)
ffi (1.17.1-aarch64-linux-musl)
ffi (1.17.1-arm-linux-gnu)
ffi (1.17.1-arm-linux-musl)
ffi (1.17.1-arm64-darwin)
ffi (1.17.1-x86-linux-gnu)
ffi (1.17.1-x86-linux-musl)
ffi (1.17.1-x86_64-darwin)
ffi (1.17.1-x86_64-linux-gnu)
ffi (1.17.1-x86_64-linux-musl)
forwardable-extended (2.6.0)
google-protobuf (3.21.12)
google-protobuf (4.29.3)
bigdecimal
rake (>= 13)
google-protobuf (4.29.3-aarch64-linux)
bigdecimal
rake (>= 13)
google-protobuf (4.29.3-arm64-darwin)
bigdecimal
rake (>= 13)
google-protobuf (4.29.3-x86-linux)
bigdecimal
rake (>= 13)
google-protobuf (4.29.3-x86_64-darwin)
bigdecimal
rake (>= 13)
google-protobuf (4.29.3-x86_64-linux)
bigdecimal
rake (>= 13)
http_parser.rb (0.8.0)
i18n (1.12.0)
i18n (1.14.6)
concurrent-ruby (~> 1.0)
jekyll (4.3.1)
jekyll (4.3.4)
addressable (~> 2.4)
colorator (~> 1.0)
em-websocket (~> 0.5)
@@ -31,40 +59,111 @@ GEM
safe_yaml (~> 1.0)
terminal-table (>= 1.8, < 4.0)
webrick (~> 1.7)
jekyll-feed (0.17.0)
jekyll (>= 3.7, < 5.0)
jekyll-sass-converter (3.0.0)
sass-embedded (~> 1.54)
jekyll-seo-tag (2.8.0)
jekyll (>= 3.8, < 5.0)
jekyll-watch (2.2.1)
listen (~> 3.0)
kramdown (2.4.0)
rexml
kramdown (2.5.1)
rexml (>= 3.3.9)
kramdown-parser-gfm (1.1.0)
kramdown (~> 2.0)
liquid (4.0.3)
listen (3.7.1)
liquid (4.0.4)
listen (3.9.0)
rb-fsevent (~> 0.10, >= 0.10.3)
rb-inotify (~> 0.9, >= 0.9.10)
mercenary (0.4.0)
minima (2.5.2)
jekyll (>= 3.5, < 5.0)
jekyll-feed (~> 0.9)
jekyll-seo-tag (~> 2.1)
pathutil (0.16.2)
forwardable-extended (~> 2.6)
public_suffix (5.0.1)
public_suffix (6.0.1)
rake (13.2.1)
rb-fsevent (0.11.2)
rb-inotify (0.10.1)
rb-inotify (0.11.1)
ffi (~> 1.0)
rexml (3.2.5)
rouge (3.30.0)
rexml (3.4.0)
rouge (4.5.1)
safe_yaml (1.0.5)
sass-embedded (1.57.1-arm64-darwin)
google-protobuf (~> 3.21)
sass-embedded (1.83.1)
google-protobuf (~> 4.29)
rake (>= 13)
sass-embedded (1.83.1-aarch64-linux-android)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-aarch64-linux-gnu)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-aarch64-linux-musl)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-aarch64-mingw-ucrt)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-arm-linux-androideabi)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-arm-linux-gnueabihf)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-arm-linux-musleabihf)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-arm64-darwin)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-riscv64-linux-android)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-riscv64-linux-gnu)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-riscv64-linux-musl)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-x86_64-cygwin)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-x86_64-darwin)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-x86_64-linux-android)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-x86_64-linux-gnu)
google-protobuf (~> 4.29)
sass-embedded (1.83.1-x86_64-linux-musl)
google-protobuf (~> 4.29)
terminal-table (3.0.2)
unicode-display_width (>= 1.1.1, < 3)
unicode-display_width (2.4.1)
webrick (1.7.0)
unicode-display_width (2.6.0)
webrick (1.9.1)
PLATFORMS
arm64-darwin-21
aarch64-linux
aarch64-linux-android
aarch64-linux-gnu
aarch64-linux-musl
aarch64-mingw-ucrt
arm-linux-androideabi
arm-linux-gnu
arm-linux-gnueabihf
arm-linux-musl
arm-linux-musleabihf
arm64-darwin
riscv64-linux-android
riscv64-linux-gnu
riscv64-linux-musl
ruby
x86-linux
x86-linux-gnu
x86-linux-musl
x86_64-cygwin
x86_64-darwin
x86_64-linux
x86_64-linux-android
x86_64-linux-gnu
x86_64-linux-musl
DEPENDENCIES
jekyll (~> 4.3)
http_parser.rb (~> 0.6.0)
jekyll (~> 4.3.4)
jekyll-feed (~> 0.12)
minima (~> 2.5)
tzinfo (>= 1, < 3)
tzinfo-data
wdm (~> 0.1)
BUNDLED WITH
2.4.2
2.6.2

View File

@@ -1,3 +1,9 @@
# The Personal Website of Maxim Voldman Hutz
This website serves as an exhibit of who I am, what I've done, what I'm doing,
and what I plan to do.
# 🖼️ Max Hutz's Digital Portfolio
Hey!
I'm Max Hutz, and this is my personal website.
It details who I am, what I've done, and were I'm headed in the field of software engineering. (And it looks cool too!)
Check it out now at [www.maximhutz.me](https://www.maximhutz.me)!

15
Taskfile.yml Normal file
View File

@@ -0,0 +1,15 @@
version: 3
env: { TF: terraform -chdir=terraform }
silent: true
tasks:
tf/init: $TF init -backend-config=../secrets/backend.json
tf/plan: $TF plan
tf/destroy: $TF destroy
tf/format: $TF fmt -recursive
tf/apply:
- $TF apply
- $TF output -json > secrets/terraform.json
action: act -W .gitea/workflows --container-architecture linux/amd64

79
_data/techs.yml Normal file
View File

@@ -0,0 +1,79 @@
html:
name: HTML
fore: '#FFFFFF'
back: '#E44D26'
link: https://html.spec.whatwg.org/multipage/
css:
name: CSS
fore: '#FFFFFF'
back: '#2965F1'
link: https://www.w3.org/Style/CSS/Overview.en.html
js:
name: JavaScript
fore: '#323330'
back: '#F0DB4F'
link: https://en.wikipedia.org/wiki/JavaScript
php:
name: PHP
fore: '#242434'
back: '#8B93BB'
link: https://www.php.net
docker:
name: Docker
fore: '#2494EC'
back: '#FFFFFF'
link: https://www.docker.com
azure:
name: Azure
fore: '#EEEEEE'
back: 'linear-gradient(-45deg, #2892DF, #3CCBF4)'
link: https://azure.microsoft.com/en-us/
mariadb:
name: MariaDB
fore: '#1C335C'
back: '#C4745C'
link: https://mariadb.org
#*----------------------------------------------------------------------------*#
react:
name: React
fore: '#04D8F8'
back: '#242323'
link: https://reactjs.org
swift:
name: Swift
fore: white
back: 'linear-gradient(-45deg, #FF3527, #FBAB3F)'
link: https://www.swift.org
objective-c:
name: Objective-C
fore: '#000000'
back: '#EEEEEE'
link: https://developer.apple.com/library/archive/documentation/Cocoa/Conceptual/ProgrammingWithObjectiveC/Introduction/Introduction.html
firebase:
name: Firebase
fore: '#F57C00'
back: '#EEF3F5'
link: https://firebase.google.com
python:
name: Python
fore: '#FFD94B'
back: '#346C94'
link: https://www.python.org
bs:
name: Beautiful Soup
fore: '#97DACB'
back: '#1C4E63'
link: https://www.crummy.com/software/BeautifulSoup/bs4/doc/

View File

@@ -1,151 +1,116 @@
malung:
title:
Example
id: malung
title: Malung
subtitle: COVID-19 Classifier
stack: [ html, css, js, php, docker, mariadb, azure ]
color: malung
image: /res/projects/malung.webp
subtitle:
Just A Test
stack:
[ PHP, JS, CSS, HTML, Docker, MariaDB, Azure ]
ready: true
description:
Lorem Ipsum is simply dummy text of the printing and typesetting industry.
Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book. It has survived not only five centuries, but also
the leap into electronic typesetting, remaining essentially unchanged.
Led a team of 3 to create Malung, an <b>online COVID-19 classifier</b>. With
Malung, you can detect COVID-19 in lung scans using machine learning, and
<b>manage patient data on the cloud</b>. <br><br> Doubled as the <b>backend
/ DevOps lead</b> during development, managing the site and its database.
outcomes:
- Lorem Ipsum is simply dummy text of the printing and typesetting industry.
- Hosted site through Microsoft Azure.
- Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book.
- Managed database with MariaDB; Containerized on Docker instance for local
development.
- It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged.
- Built account system with PHP, which interfaced with frontend through
backend API.
image:
/res/avatar.svg
link:
/
color:
yellow
- Collaboratively designed sites UI with Figma, focusing on responsive
design.
#*----------------------------------------------------------------------------*#
freshmanual:
title:
Example
id: freshmanual
title: FreshManual
subtitle: Mobile App
stack: [ react, js, firebase, swift, objective-c ]
link: https://apps.apple.com/us/app/freshmanuals/id1627091250
color: freshmanual
image: /res/projects/freshmanual.webp
subtitle:
Just A Test
stack:
[ PHP, JS, CSS, HTML, Docker, MariaDB, Azure ]
ready: false
description:
Lorem Ipsum is simply dummy text of the printing and typesetting industry.
Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book. It has survived not only five centuries, but also
the leap into electronic typesetting, remaining essentially unchanged.
Lead developer during the initial development of the FreshManuals app.
Worked with <b>team of 5</b> at Tightrope Interactive to design, build, and
test the <b>mobile product manual aggregator</b>.<br><br>FreshManuals is
currently available for download on the <b>iPhone app store</b>.
outcomes:
- Lorem Ipsum is simply dummy text of the printing and typesetting industry.
- User interface built using React/React-Native, for multiplatform
integration.
- Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book.
- Used Firestore/Firebase to store and access user account data.
- It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged.
- Integrated paid yahoo search results into mobile search results.
image:
/res/avatar.svg
link:
/
color:
blue
- Used Fetch API to request user manual data from website API endpoints.
#*----------------------------------------------------------------------------*#
pollbuddy:
title:
Example
id: pollbuddy
title: Poll Buddy
stack: [ react, js, docker ]
link: https://pollbuddy.app
color: pollbuddy
image: /res/projects/pollbuddy.webp
subtitle:
Just A Test
stack:
[ PHP, JS, CSS, HTML, Docker, MariaDB, Azure ]
ready: false
description:
Lorem Ipsum is simply dummy text of the printing and typesetting industry.
Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book. It has survived not only five centuries, but also
the leap into electronic typesetting, remaining essentially unchanged.
React developer for Poll Buddy, an <b>online questionnaire service</b> used by
hundreds of students and teachers on the Rensselaer Polytechnic Institute
campus. Worked on <b>cleaning source code</b>, transitioning from legacy
technology, and <b>improving the sites user experience</b>.
outcomes:
- Lorem Ipsum is simply dummy text of the printing and typesetting industry.
- Cut 30% of the front-end codebase by switching to the modern, functional
style.
- Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book.
- Wrote and refined dozens of front-end tests using Jest for React
components.
- It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged.
image:
/res/avatar.svg
link:
/
color:
green
- Ran discount usability study on Poll Buddys UI, to isolate and correct
flaws that novel users encountered.
#*----------------------------------------------------------------------------*#
rpi-crisis:
title:
Example
id: rpi-crisis
title: CRISIS
stack: [ python, bs ]
link: https://rpicrisis.org
color: rpi-crisis
image: /res/projects/rpi-crisis.webp
subtitle:
Just A Test
stack:
[ PHP, JS, CSS, HTML, Docker, MariaDB, Azure ]
ready: false
description:
Lorem Ipsum is simply dummy text of the printing and typesetting industry.
Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book. It has survived not only five centuries, but also
the leap into electronic typesetting, remaining essentially unchanged.
<b>Backend developer</b> for Correcting Rensselaers Insufferable Student
Information System (CRISIS), a web-app to help students organize and <b>manage
their curriculum</b> at Rensselaer Polytechnic Institute (RPI). Worked to
<b>expand data collection</b> system, and decipher information from RPIs
legacy SIS.
outcomes:
- Lorem Ipsum is simply dummy text of the printing and typesetting industry.
- Wrote web-scrapers using Beautiful Soup to pull data from QuACS, another
well-known course scheduler, jump-starting the sites backend.
- Lorem Ipsum has been the industry's standard dummy text ever since the
1500s, when an unknown printer took a galley of type and scrambled it to
make a type specimen book.
- Wrote web-scrapers to extract course templates from RPIs numerous
major-specific websites.
- It has survived not only five centuries, but also the leap into electronic
typesetting, remaining essentially unchanged.
image:
/res/avatar.svg
link:
/
color:
red
- Used Lark to parse course requirements from RPIs convoluted course
catalog.
#*----------------------------------------------------------------------------*#

33
_includes/default.html Normal file
View File

@@ -0,0 +1,33 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="{{ include.description }}">
<meta name="cache-control" content="max-age=31536000">
<link rel="shortcut icon" type="image/png" href="/res/favicon.png">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link rel="preload stylesheet" as="font" href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,500,1,200&display=swap">
<link rel="preload stylesheet" as="font" href="https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap">
<link rel="preload stylesheet" as="font" href="https://fonts.googleapis.com/css2?family=Source+Code+Pro:wght@400;900&display=swap">
<link rel="preload stylesheet" as="style" href="/styles/global.css">
<link rel="preload stylesheet" as="style" href="/styles/default.css">
<title>{{ include.title }} ─ Max Hutz</title>
</head>
<body>
{% include header.html %}
{{ include.content }}
<div class="flex dark back npad"></div>
{% include footer.html %}
</body>
</html>

View File

@@ -1,13 +1,13 @@
<link rel="stylesheet" href="/styles/footer.css">
<link rel="preload stylesheet" as="style" href="/styles/footer.css">
<footer class="dark back">
<h2>&copy; 2022</h2>
<div class="flex"></div>
<a href="https://github.com/MajorDroolz" class="png-icon" target="_blank">
<img src="/res/icons/github.png" alt="GitHub" width="30" height="30">
<img src="/res/icons/github.webp" alt="GitHub" width="30" height="30">
</a>
<a href="https://www.linkedin.com/in/maximhutz/" class="png-icon" target="_blank">
<img src="/res/icons/linkedin.png" alt="LinkedIn" width="30" height="30">
<img src="/res/icons/linkedin.webp" alt="LinkedIn" width="30" height="30">
</a>
<a href="mailto:maximhutz@gmail.com" class="nav-link white icon" data-i="mail" aria-label="Contact" target="_blank"></a>
</footer>

View File

@@ -4,10 +4,10 @@
<a href="/" class="nav-link dark">MAX HUTZ</a>
<div class="flex"></div>
<a href="/experiences" class="nav-link dark icon nav3" data-i="work">Experience</a>
<a href="/resume" class="nav-link dark icon nav3" data-i="clinical_notes">Resume</a>
<a href="/resume" class="nav-link dark icon nav3" data-i="clinical_notes" target="_blank">Resume</a>
<a href="mailto:maximhutz@gmail.com" class="nav-link dark icon nav3" data-i="mail">Contact</a>
<a href="/experiences" class="nav-link dark icon nav2" data-i="work" aria-label="Experience"></a>
<a href="/resume" class="nav-link dark icon nav2" data-i="clinical_notes" aria-label="Resume"></a>
<a href="/resume" class="nav-link dark icon nav2" data-i="clinical_notes" aria-label="Resume" target="_blank"></a>
<a href="mailto:maximhutz@gmail.com" class="nav-link dark icon nav2" data-i="mail" aria-label="Contact"></a>
<button class="nav-link dark icon nav1" data-i="menu" aria-label="Menu" onclick="document.getElementById('menu')?.showModal()"></button>
</header>
@@ -23,7 +23,7 @@
</form>
</div>
<a href="/experiences" class="nav-link dark icon" data-i="work">Experience</a>
<a href="/resume" class="nav-link dark icon" data-i="clinical_notes">Resume</a>
<a href="/resume" class="nav-link dark icon" data-i="clinical_notes" target="_blank">Resume</a>
<a href="mailto:maximhutz@gmail.com" class="nav-link dark icon" data-i="mail">Contact</a>
</div>
</div>

View File

@@ -1,30 +1 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="{{ page.description }}">
<link rel="shortcut icon" type="image/png" href="/res/favicon.png">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@48,500,1,200">
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300;1,400;1,500;1,600;1,700;1,800&display=swap">
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Source+Code+Pro:wght@400;900&display=swap">
<link rel="stylesheet" href="/styles/global.css">
<link rel="stylesheet" href="/styles/default.css">
<title>{{ page.title }} ─ Max Hutz</title>
</head>
<body>
{% include header.html %}
{{ content }}
{% include footer.html %}
</body>
</html>
{% include default.html title=page.title content=content description=page.description %}

54
_layouts/experience.html Normal file
View File

@@ -0,0 +1,54 @@
{% capture description %}
A description of work done by Maxim Voldman Hutz for {{page.title}}.
{% endcapture %}
{% capture inner %}
{% assign malung = site.data.work[page.project_id] %}
{% assign techs = site.data.techs %}
<link rel="preload stylesheet" href="/styles/experience.css">
<link rel="preload stylesheet" href="/styles/tech.css">
<section id="experience" class="dark back">
<section id="banner" class="{{malung.color}} back">
<div>
<h1>{{malung.title}}</h1>
<i>{{malung.subtitle}}</i>
</div>
<button id="close-icon" class="nav-link dark icon" data-i="close" aria-label="Exit" type="button" onclick="history.back(-1)"></button>
</section>
<div id="content">
<div id="description">
<p>
{{malung.description}}
</p>
<hr class="lighter">
<ul>
{% for outcome in malung.outcomes %}
<li>{{outcome}}</li>
{% endfor %}
</ul>
{% if malung.link %}
<a href="{{malung.link}}" id="experience-button" class="nav-link white button r-icon" data-i="arrow_right" target="_blank">View {{malung.title}}</a>
{% endif %}
</div>
<div id="image-side">
<div id="image" class="shadow">
{% if malung.image %}
<img id="image-inner" src="{{malung.image}}" alt="Image of {{malung.title}}">
{% else %}
<h1 aria-hidden="true">Image Not Available</h1>
{% endif %}
</div>
<div id="stack">
{% for tech in malung.stack %}
{% assign data = techs[tech] %}
<a class="chip {{tech}} shadow" href="{{data.link}}" target="_blank">{{data.name}}</a>
{% endfor %}
</div>
</div>
</div>
</section>
{% endcapture %}
{% include default.html content=inner description=description title=page.title %}

View File

@@ -0,0 +1,5 @@
---
layout: experience
project_id: freshmanual
title: FreshManual
---

5
experience/malung.html Normal file
View File

@@ -0,0 +1,5 @@
---
layout: experience
project_id: malung
title: Malung
---

View File

@@ -0,0 +1,5 @@
---
layout: experience
project_id: pollbuddy
title: Poll Buddy
---

View File

@@ -0,0 +1,5 @@
---
layout: experience
project_id: rpi-crisis
title: CRISIS
---

View File

@@ -1,6 +1,6 @@
---
title: Experiences
description: A list of past and current work and projects from Maxim Voldman Hutz.
description: A list of work and projects done by Maxim Voldman Hutz.
layout: default
---
@@ -14,8 +14,21 @@ layout: default
{% assign data = item[1] %}
<a class="{{ data.color }} project-item shadow" href="/experience/{{ id }}">
<div class="space"></div>
<div class="nav-link project-link r-icon" data-i="arrow_right">{{ data.title }}: {{ data.subtitle }}
{% if data.image %}
<div class="space project-image-outer">
<img src="{{data.image}}" alt="{{data.title}}" class="project-image">
</div>
{% else %}
<div class="project-noimage" aria-hidden="true">Image Not Available</div>
{% endif %}
<div class="nav-link project-link r-icon" data-i="arrow_right">
{{ data.title }}
<!-- Add the subtitle, if it exists. -->
{% if data.subtitle %}
<span>:</span>
&nbsp;
<p>{{ data.subtitle }}</p>
{% endif %}
</div>
</a>
{% endfor %}

View File

@@ -26,15 +26,26 @@ layout: default
<div class="flex"></div>
</section>
<!-- ----------------------------------------------------------------------- -->
<section id="projects" class="dark back">
<h2>Worked on:</h2>
<div id="project-list">
{% for project in home.featured %}
<a class="{{ work[project].color }} project-item shadow" href="/experience/{{ project }}">
<div class="space"></div>
<div class="nav-link project-link r-icon" data-i="arrow_right">{{ work[project].title }}: {{ work[project].subtitle }}
{% if work[project].image %}
<div class="space project-image-outer">
<img src="{{work[project].image}}" alt="{{work[project].title}}" class="project-image">
</div>
{% else %}
<div class="project-noimage" aria-hidden="true">Image Not Available</div>
{% endif %}
<div class="nav-link project-link r-icon" data-i="arrow_right">
{{ work[project].title }}
<!-- Add the subtitle, if it exists. -->
{% if work[project].subtitle %}
<span>:</span>
&nbsp;
<p>{{ work[project].subtitle }}</p>
{% endif %}
</div>
</a>
{% endfor %}

BIN
res/.DS_Store vendored

Binary file not shown.

BIN
res/icons/.DS_Store vendored

Binary file not shown.

BIN
res/icons/github.webp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

View File

Before

Width:  |  Height:  |  Size: 8.5 KiB

After

Width:  |  Height:  |  Size: 8.5 KiB

BIN
res/icons/linkedin.webp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.0 KiB

View File

Before

Width:  |  Height:  |  Size: 8.6 KiB

After

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 80 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 683 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 550 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 351 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 330 KiB

BIN
res/projects/malung.webp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 119 KiB

BIN
res/projects/pollbuddy.webp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 41 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 39 KiB

View File

@@ -3,7 +3,7 @@
<head>
<title>Resume of Maxim Voldman Hutz</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="This page holds a preview of the resume of Maxim Voldman Hutz.">
<meta name="description" content="A preview of the resume of Maxim Voldman Hutz.">
<!-- Header metadata. -->
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

View File

@@ -1,6 +1,6 @@
#notfound {
--color: var(--dark) linear-gradient(#0000, #0003);
flex: 1;
flex: 99999999999999;
display: flex;
justify-content: center;
align-items: center;

View File

@@ -11,6 +11,8 @@ body {
width: min(100vw, 1024px);
box-sizing: border-box;
margin: auto;
padding: 0 20px;
line-height: 1.2;
}
/*----------------------------------------------------------------------------*/
@@ -43,18 +45,21 @@ button {
display: inline-flex;
align-items: center;
justify-content: center;
cursor: pointer;
}
.icon::before {
font-family: 'Material Symbols Outlined';
content: attr(data-i);
font-size: 36px;
width: 1em;
margin-right: 5px;
}
.r-icon::after {
font-family: 'Material Symbols Outlined';
content: attr(data-i);
width: 1em;
margin-left: 5px;
}
@@ -72,15 +77,24 @@ h2 {
i {
font-size: 20px;
font-size: "Source Serif Pro";
font-family: "Source Serif Pro";
}
p {
p, section {
font-size: 20px;
font-family: "Open Sans";
font-weight: 100;
}
ul {
list-style-type: "- ";
padding-left: 2ch;
}
li {
padding-bottom: 20px;
}
.lighter {
background: #fff4;
}
@@ -99,7 +113,6 @@ hr {
position: relative;
padding: 10px 30px;
font-size: 20px;
cursor: pointer;
}
.button::before {
@@ -161,7 +174,7 @@ nav {
/*----------------------------------------------------------------------------*/
#projects {
padding: 30px auto;
padding: 30px 0;
position: relative;
display: flex;
flex-direction: column;
@@ -182,7 +195,7 @@ nav {
}
.project-item {
min-width: max(40%, 300px);
min-width: min(max(40%, 400px), 100%);
flex: 1;
height: 300px;
background-color: var(--color);
@@ -252,3 +265,32 @@ nav {
display: none;
}
}
.project-noimage {
color: #0002;
font-size: 40px;
font-family: "Open Sans";
font-weight: 900;
display: flex;
flex: 1000;
justify-content: center;
align-items: center;
text-align: center;
box-sizing: border-box;
padding: 10px;
}
.project-image-outer {
position: relative;
justify-content: center;
align-items: center;
}
.project-image {
position: absolute;
max-height: 100%;
max-width: 100%;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}

83
styles/experience.css Normal file
View File

@@ -0,0 +1,83 @@
#banner {
margin-top: 10px;
padding: 20px 0;
display: flex;
justify-content: space-between;
align-items: center;
line-height: 1;
}
#experience {
color: white;
gap: 30px;
display: flex;
flex-direction: column;
align-items: flex-start;
}
#content {
display: flex;
flex-wrap: wrap-reverse;
align-items: flex-end;
gap: 30px;
padding-bottom: 30px;
}
#image {
background-color: #ccc;
border-radius: 10px;
height: 300px;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
color: #aaa;
position: relative;
text-align: center;
padding: 10px;
hyphens: manual;
box-sizing: border-box;
}
#description {
flex: 1;
gap: 30px;
display: flex;
flex-direction: column;
align-items: flex-start;
min-width: min(300px, 100%);
}
#image-side {
flex: 1;
gap: 20px;
display: flex;
flex-direction: column;
align-items: flex-start;
min-width: min(500px, 100%);
}
#stack {
display: flex;
gap: 10px;
flex-flow: row wrap;
}
#stack .chip {
flex-grow: 1;
}
#stack::after {
content: "";
flex: 1000000;
}
#image-inner {
max-width: 100%;
max-height: 100%;
}
#close-icon {
font-size: 36px;
line-height: 1;
}

View File

@@ -29,9 +29,15 @@
.green { --color: var(--green) }
.blue { --color: var(--blue) }
.white { --color: white }
.malung { --color: #F76F8E }
.freshmanual { --color: #3b91db }
.pollbuddy { --color: #7f6491 }
.rpi-crisis { --color: #a06ce4 }
.flex-space, .flex, br { flex-grow: 1 }
.flex.dark { background-color: var(--dark) }
.space { flex: 1000 }
.npad { padding: 0 !important }
/*----------------------------------------------------------------------------*/
@@ -43,8 +49,8 @@ html {
.back {
position: relative;
padding: 10px 20px;
width: min(100vw, 1024px);
padding: 10px 0;
width: min(100vw, 1024px, 100%);
box-sizing: border-box;
}
@@ -63,5 +69,3 @@ html {
.dark-back::before {
filter: brightness(0.8);
}
/*----------------------------------------------------------------------------*/

24
styles/tech.scss Normal file
View File

@@ -0,0 +1,24 @@
---
---
.chip {
font-size: 15px;
font-family: "Open Sans";
font-weight: 900;
display: inline-flex;
justify-content: center;
align-items: center;
padding: 5px 20px;
border-radius: 10px;
text-decoration: none;
}
{% for tech in site.data.techs %}
{% assign id = tech[0] %}
{% assign data = tech[1] %}
.chip.{{id}} {
background: {{data.back}};
color: {{data.fore}};
}
{% endfor %}

24
terraform/.terraform.lock.hcl generated Normal file
View File

@@ -0,0 +1,24 @@
# This file is maintained automatically by "terraform init".
# Manual edits may be lost in future updates.
provider "registry.terraform.io/hashicorp/aws" {
version = "5.83.0"
hashes = [
"h1:uh/57vwauk96J9HjqvjmWV9sLXbX0YXbYnqUBWooiwQ=",
"zh:03a1d4cb151efd9279a3348ecb5e26fe99eb5d217b254e544c7f768a03020d0e",
"zh:07637e75abd0809454d9b51b4499059e6fd3eb58d4723c99bc71d21595a9b897",
"zh:415868ead3d9b9527418c68468972dd0c9614e69240133d8b1d77641259eb396",
"zh:52f343f08881fc88fcbd731cdf480c02edd6eb335934107bbcfb0d97c2a575df",
"zh:60d19aed16142fce6fd95087d9de8d8f59681db98588f9384112045ce533f3ce",
"zh:62775ba5933b41d00df59fe7ae02027d328ccedc06ff5363ff8d2f48633c4012",
"zh:95c7a13b5ef625a672f0ac94d1a20858f60bf09a6517b180f031b707f37d862d",
"zh:9adf0d9f349e692b9f51375713c316d28d217f72d2b86deb49e48c3834a41539",
"zh:9b12af85486a96aedd8d7984b0ff811a4b42e3d88dad1a3fb4c0b580d04fa425",
"zh:b605deb6d3eff97218b6b16b153038ac8e7bd0b8506ae469f2368281dca46cab",
"zh:b8542b3672bca0c6ed522b8f65d92ef5720786301abc7d7dae07f07296398b4c",
"zh:d975790f409234f9791633adba3ffcfbb2526bc04aed1f379fc8f90370366907",
"zh:e621bd43f3a46f122ec450828d590ee2f34c0be5603120876ddfc218861b1802",
"zh:e87e2989e99aa21bbfdb603e1325afe11af126684c64821eca8d014f8b762ca5",
"zh:f7f6f149d6e1e9d4b979b23b248df14bfe3c497052ec41a6dd40d19bcd9cde9a",
]
}

59
terraform/main.tf Normal file
View File

@@ -0,0 +1,59 @@
# Create the S3 bucket.
resource "aws_s3_bucket" "portfolio_bucket" {
bucket = var.bucket_name
tags = {
Name = "Portfolio Bucket"
Environment = "Production"
}
}
resource "aws_s3_bucket_public_access_block" "portfolio_bucket_access" {
bucket = aws_s3_bucket.portfolio_bucket.id
block_public_acls = false
block_public_policy = false
}
resource "aws_s3_bucket_versioning" "portfolio_bucket_access_versioning" {
bucket = aws_s3_bucket.portfolio_bucket.id
versioning_configuration {
status = "Disabled"
}
}
#------------------------------------------------------------------------------#
# Give a user access.
data "aws_iam_policy_document" "portfolio_bucket_policy_doc" {
statement {
effect = "Allow"
actions = ["s3:*", "s3-object-lambda:*"]
resources = [
"${aws_s3_bucket.portfolio_bucket.arn}/*",
"${aws_s3_bucket.portfolio_bucket.arn}"
]
}
}
resource "aws_iam_policy" "portfolio_bucket_policy" {
name = "${var.role_name}Policy"
description = "The policy that manages the Portfolio Bucket."
policy = data.aws_iam_policy_document.portfolio_bucket_policy_doc.json
}
resource "aws_iam_user" "portfolio_bucket_user" {
name = "${var.role_name}User"
}
resource "aws_iam_user_policy_attachment" "portfolio_bucket_attachment" {
user = aws_iam_user.portfolio_bucket_user.name
policy_arn = aws_iam_policy.portfolio_bucket_policy.arn
}
resource "aws_iam_access_key" "portfolio_bucket_key" {
user = aws_iam_user.portfolio_bucket_user.name
}

16
terraform/outputs.tf Normal file
View File

@@ -0,0 +1,16 @@
output "access_region" {
value = aws_s3_bucket.portfolio_bucket.region
description = "This is the region of the bucket."
}
output "access_id" {
value = aws_iam_access_key.portfolio_bucket_key.id
description = "This is the access ID to modify the bucket."
sensitive = true
}
output "access_secret" {
value = aws_iam_access_key.portfolio_bucket_key.secret
description = "This is the access secret to modify the bucket."
sensitive = true
}

9
terraform/variables.tf Normal file
View File

@@ -0,0 +1,9 @@
variable "bucket_name" {
type = string
description = "The name of the bucket to create."
}
variable "role_name" {
type = string
description = "The base name for the role to modify the bucket."
}