-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathindex.html
More file actions
476 lines (455 loc) · 18.8 KB
/
index.html
File metadata and controls
476 lines (455 loc) · 18.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
<!DOCTYPE html>
<html lang="en">
<head>
<meta name="google-site-verification" content="G4xgpb4nOfGShosuh1Tg0z-702kfJqP3tuqbhh_2YRE" />
<!-- Favicon - SVG for modern browsers, PNG fallbacks -->
<link rel="icon" type="image/svg+xml" href="/favicon.svg" />
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png" />
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png" />
<link rel="manifest" href="/manifest.json" />
<!-- Yandex specific meta tags -->
<meta name="yandex-verification" content="afc26132c437731c" />
<meta name="geo.region" content="US-CA" />
<meta name="geo.placename" content="Campbell, California" />
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-Q62Q3E20Y0"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {
dataLayer.push(arguments);
}
gtag('js', new Date());
gtag('config', 'G-Q62Q3E20Y0');
</script>
<script src="/analytics.js"></script>
<title>Joe Heyming - UI Engineer</title>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta charset="utf-8" />
<meta
name="description"
content="Joe Heyming - UI Engineer at Roblox. UCSB graduate. Games, tools, and side projects."
/>
<!-- Enhanced SEO Meta Tags -->
<meta name="author" content="Joe Heyming" />
<!-- Aligns with OAuth consent “App name” (use “Joe Heyming” in Google Cloud, not the GCP project id). -->
<meta name="application-name" content="Joe Heyming" />
<meta name="robots" content="index, follow" />
<meta name="language" content="English" />
<meta name="theme-color" content="#8b5cf6" />
<meta
name="keywords"
content="Joe Heyming, UI Engineer, Roblox, Software Engineer, UCSB, Web Developer, JavaScript, React, Frontend"
/>
<!-- Open Graph Meta Tags -->
<meta property="og:type" content="website" />
<meta property="og:site_name" content="Joe Heyming" />
<meta property="og:title" content="Joe Heyming - UI Engineer" />
<meta
property="og:description"
content="Joe Heyming - UI Engineer at Roblox. Side projects, games, and experiments."
/>
<meta property="og:url" content="https://joeheyming.github.io/" />
<meta
property="og:image"
content="https://joeheyming.github.io/assets/joe-heyming-og-image.png"
/>
<meta property="og:image:width" content="1200" />
<meta property="og:image:height" content="630" />
<meta property="og:image:alt" content="Joe Heyming - UI Engineer" />
<meta property="og:locale" content="en_US" />
<!-- Twitter Card Meta Tags -->
<meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:site" content="@joeheyming" />
<meta name="twitter:creator" content="@joeheyming" />
<meta name="twitter:title" content="Joe Heyming - UI Engineer" />
<meta
name="twitter:description"
content="Joe Heyming - UI Engineer at Roblox. Side projects and experiments."
/>
<meta
name="twitter:image"
content="https://joeheyming.github.io/assets/joe-heyming-og-image.jpeg"
/>
<!-- Canonical URL -->
<link rel="canonical" href="https://joeheyming.github.io/" />
<!-- Additional SEO -->
<meta name="format-detection" content="telephone=no" />
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="default" />
<meta name="apple-mobile-web-app-title" content="Joe Heyming" />
<script src="https://cdn.tailwindcss.com"></script>
<script src="mime-handlers.js"></script>
<script src="app.js"></script>
<script src="index.js"></script>
<link rel="stylesheet" href="index.css" />
<!-- Structured Data (JSON-LD) -->
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@type": "Person",
"name": "Joe Heyming",
"jobTitle": "UI Engineer",
"worksFor": {
"@type": "Organization",
"name": "Roblox"
},
"alumniOf": {
"@type": "CollegeOrUniversity",
"name": "University of California, Santa Barbara",
"department": "Computer Science"
},
"url": "https://joeheyming.github.io/",
"sameAs": [
"https://www.linkedin.com/in/joeheyming/",
"https://github.com/joeheyming",
"https://twitter.com/joeheyming"
],
"knowsAbout": [
"JavaScript",
"React",
"Frontend Development",
"UI Engineering",
"Trust & Safety",
"Machine Learning Platforms",
"Web Development"
],
"description": "UI Engineer at Roblox.",
"image": "https://joeheyming.github.io/assets/joe-heyming-og-image.png",
"address": {
"@type": "PostalAddress",
"addressLocality": "Campbell",
"addressRegion": "California",
"addressCountry": "US"
}
}
</script>
</head>
<body
class="min-h-screen bg-gradient-to-br from-indigo-500 via-purple-500 to-pink-500 overflow-x-hidden"
>
<!--
OAuth / crawler visibility: plain HTML + inline styles so a link to the privacy policy exists
even if Tailwind CDN is slow or blocked. Use the same app name here as on the OAuth consent screen.
-->
<nav
style="
font-size: 0.875rem;
padding: 0.5rem 1rem;
text-align: center;
background: rgba(0, 0, 0, 0.35);
color: #fff;
font-family: system-ui, -apple-system, sans-serif;
"
aria-label="Site identity and policies"
>
<strong>Joe Heyming</strong>
<span style="color: rgba(255, 255, 255, 0.45); margin: 0 0.5rem">·</span>
<a
href="https://joeheyming.github.io/privacy-policy.html"
style="color: #bfdbfe; text-decoration: underline"
>Privacy Policy</a
>
<span style="color: rgba(255, 255, 255, 0.45); margin: 0 0.5rem">·</span>
<a
href="https://joeheyming.github.io/terms-of-service.html"
style="color: #bfdbfe; text-decoration: underline"
>Terms of Service</a
>
</nav>
<!-- Hamburger Menu -->
<div id="hamburger-menu" class="fixed top-4 right-4 sm:top-6 sm:right-6 z-[100]">
<!-- Hamburger Icon -->
<button
id="hamburger-toggle"
class="w-14 h-14 sm:w-12 sm:h-12 bg-gray-900/90 backdrop-blur-sm border border-green-500/50 rounded-lg flex flex-col justify-center items-center space-y-1 hover:bg-gray-800/90 transition-all duration-300 shadow-lg"
aria-label="Toggle navigation menu"
>
<span
class="hamburger-line w-7 h-0.5 sm:w-6 bg-green-400 transition-all duration-300"
></span>
<span
class="hamburger-line w-7 h-0.5 sm:w-6 bg-green-400 transition-all duration-300"
></span>
<span
class="hamburger-line w-7 h-0.5 sm:w-6 bg-green-400 transition-all duration-300"
></span>
</button>
<!-- Menu Panel -->
<div
id="hamburger-panel"
class="absolute top-16 sm:top-14 right-0 w-[90vw] max-w-80 bg-gray-900/95 backdrop-blur-md border border-green-500/50 rounded-xl shadow-2xl transform translate-x-full transition-all duration-300 opacity-0"
>
<div class="p-6">
<!-- Menu Header -->
<div class="flex items-center justify-between mb-4">
<h3 class="text-green-400 font-mono text-lg font-bold">🚀 Applications</h3>
<button
id="menu-close"
class="text-green-400 hover:text-green-300 text-xl transition-colors duration-200"
aria-label="Close menu"
>
×
</button>
</div>
<!-- Filter Input -->
<div class="relative mb-4">
<input
type="text"
id="hamburger-filter"
placeholder="Filter apps..."
class="w-full bg-gray-800/80 border border-green-500/30 rounded-lg px-4 py-2 pl-10 text-green-400 font-mono text-sm placeholder-gray-500 focus:outline-none focus:border-green-400/60 focus:ring-1 focus:ring-green-400/30 transition-all duration-200"
autocomplete="off"
autocapitalize="off"
spellcheck="false"
/>
<span class="absolute left-3 top-1/2 -translate-y-1/2 text-gray-500">🔍</span>
<button
id="filter-clear"
class="absolute right-3 top-1/2 -translate-y-1/2 text-gray-500 hover:text-green-400 transition-colors duration-200 hidden"
aria-label="Clear filter"
>
×
</button>
</div>
<nav id="hamburger-app-links" class="space-y-2 max-h-80 overflow-y-auto pr-2"></nav>
<!-- No Results Message -->
<div id="no-results" class="hidden text-center text-gray-500 py-4 font-mono text-sm">
No apps match your filter 🤷
</div>
<!-- Menu Footer -->
<div class="mt-6 pt-4 border-t border-gray-700">
<div class="text-center text-gray-400 text-sm font-mono">Side Projects</div>
</div>
</div>
</div>
</div>
<div id="main-content" class="max-w-7xl mx-auto px-4 sm:px-6 py-6 sm:py-8">
<!-- Hero Section -->
<div
class="hero-bg relative bg-white/95 backdrop-blur-sm rounded-3xl p-6 sm:p-12 lg:p-20 mb-12 shadow-2xl text-center overflow-hidden"
>
<div class="relative z-10">
<h1
class="text-4xl sm:text-5xl md:text-6xl lg:text-7xl font-bold mb-4 sm:mb-6 gradient-text animate-pulse-slow pb-2"
>
🦄 Joe Heyming 🦄
</h1>
<div
class="text-lg sm:text-xl md:text-2xl lg:text-3xl text-gray-600 mb-6 sm:mb-8 animate-fade-in-up"
>
UI Engineer
</div>
<p
class="text-lg sm:text-xl md:text-2xl text-gray-700 mb-6 sm:mb-8 max-w-3xl mx-auto px-2"
>
Building user experiences at Roblox 🎮
<br />
<em class="text-indigo-600">"Lots of hard work."</em>
</p>
<div
class="fun-fact inline-block text-sm sm:text-base lg:text-lg font-bold text-indigo-600 bg-indigo-50 px-4 sm:px-6 py-2 sm:py-3 rounded-full cursor-pointer transition-all duration-300 hover:scale-110 hover:bg-indigo-100 hover:shadow-lg mx-2"
onclick="changeFunFact()"
>
🚀 Trust & Safety UI at Roblox
</div>
</div>
</div>
<!-- Professional Highlights -->
<div class="bg-white/90 backdrop-blur-sm rounded-3xl p-6 sm:p-10 mb-12 shadow-xl">
<h2 class="text-3xl sm:text-4xl font-bold text-center mb-6 sm:mb-10 gradient-text">
Places I've Worked
</h2>
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6 mb-8">
<div
class="bg-gradient-to-r from-red-500 to-pink-500 text-white p-6 rounded-2xl transform transition-all duration-300 hover:-translate-y-2 hover:shadow-2xl animate-float"
>
<h3 class="text-xl font-bold mb-2">🎮 Roblox</h3>
<p class="text-sm opacity-90">
UI Engineer
<br />
<span class="text-xs">Trust & Safety Platform</span>
</p>
</div>
<div
class="bg-gradient-to-r from-blue-500 to-indigo-600 text-white p-6 rounded-2xl transform transition-all duration-300 hover:-translate-y-2 hover:shadow-2xl animate-float"
style="animation-delay: 0.2s"
>
<h3 class="text-xl font-bold mb-2">☁️ Cloudera</h3>
<p class="text-sm opacity-90">
Staff/Principal Engineer
<br />
<span class="text-xs">7+ years of ML & Data platforms</span>
</p>
</div>
<div
class="bg-gradient-to-r from-green-500 to-teal-500 text-white p-6 rounded-2xl transform transition-all duration-300 hover:-translate-y-2 hover:shadow-2xl animate-float"
style="animation-delay: 0.4s"
>
<h3 class="text-xl font-bold mb-2">📡 Aruba Networks</h3>
<p class="text-sm opacity-90">
Staff Software Engineer
<br />
<span class="text-xs">VisualRF & "Take it to the cloud!"</span>
</p>
</div>
<div
class="bg-gradient-to-r from-purple-500 to-indigo-600 text-white p-6 rounded-2xl transform transition-all duration-300 hover:-translate-y-2 hover:shadow-2xl animate-float"
style="animation-delay: 0.6s"
>
<h3 class="text-xl font-bold mb-2">💻 Hewlett Packard</h3>
<p class="text-sm opacity-90">
Performance & Scalability
<br />
<span class="text-xs">HPSA/Opsware optimization</span>
</p>
</div>
</div>
<div class="text-center space-y-2">
<p class="text-xl font-semibold text-indigo-600">
Been doing this for
<strong id="years-experience">18+ years</strong>
</p>
<p class="text-lg text-purple-600">UCSB CS · Campbell, CA</p>
</div>
</div>
<!-- Featured Projects -->
<div
class="bg-gradient-to-r from-purple-600 to-indigo-700 text-white rounded-3xl p-6 sm:p-10 mb-12 shadow-xl"
>
<h2 class="text-3xl sm:text-4xl font-bold text-center mb-4">
🎮 Try My Interactive Projects
</h2>
<p class="text-center text-white/90 mb-8 text-lg">
Games, tools, and experiments built with JavaScript
</p>
<div
id="featured-projects-grid"
class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6"
></div>
<div class="text-center mt-8">
<button
id="view-all-projects-btn"
data-event="view_all_projects"
data-event-category="Engagement"
data-event-label="From Featured Section"
class="bg-white/20 hover:bg-white/30 backdrop-blur-sm px-8 py-4 rounded-full text-lg font-bold transition-all duration-300 hover:scale-105 inline-flex items-center gap-2"
>
<span>🚀 View All Projects</span>
<span class="text-sm opacity-75">(20+ apps!)</span>
</button>
</div>
</div>
<!-- Fun Facts -->
<div
class="bg-gradient-to-r from-cyan-400 to-blue-500 text-white rounded-3xl p-6 sm:p-10 mb-12 shadow-xl"
>
<h2 class="text-3xl sm:text-4xl font-bold text-center mb-6 sm:mb-10">Random Stuff</h2>
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-4 gap-6">
<div
class="bg-white/20 backdrop-blur-sm p-6 rounded-2xl hover:bg-white/30 transition-all duration-300"
>
<h3 class="text-xl font-bold mb-3">📺 I was in a commercial once</h3>
<p class="text-sm">Said "Why don't you take it to the cloud?" for Aruba Networks</p>
</div>
<div
class="bg-white/20 backdrop-blur-sm p-6 rounded-2xl hover:bg-white/30 transition-all duration-300"
>
<h3 class="text-xl font-bold mb-3">🎯 Got a patent</h3>
<p class="text-sm">
<a
href="https://www.freepatentsonline.com/y2015/0381434.html"
target="_blank"
class="underline hover:text-yellow-200 transition-colors duration-200"
>
WiFi heatmap visualization thing
</a>
</p>
</div>
<div
class="bg-white/20 backdrop-blur-sm p-6 rounded-2xl hover:bg-white/30 transition-all duration-300"
>
<h3 class="text-xl font-bold mb-3">🏕️ Was a Cubmaster</h3>
<p class="text-sm">
Pack 333, Campbell CA
<br />
2018-2020
</p>
</div>
<div
class="bg-white/20 backdrop-blur-sm p-6 rounded-2xl hover:bg-white/30 transition-all duration-300"
>
<h3 class="text-xl font-bold mb-3">🔧 Some open source</h3>
<p class="text-sm">
<a
href="https://github.com/joeheyming"
target="_blank"
class="underline hover:text-yellow-200 transition-colors duration-200"
>
Emacs stuff, Python tools
</a>
</p>
</div>
</div>
</div>
</div>
<!-- Footer -->
<footer id="main-footer" class="text-center py-12 text-white">
<p class="text-xl mb-6">Built with JavaScript and too much coffee ☕</p>
<div class="flex justify-center space-x-8 mb-6">
<a
href="https://www.linkedin.com/in/joeheyming/"
target="_blank"
class="text-white hover:scale-125 transition-transform duration-300 text-2xl"
>
🔗 LinkedIn
</a>
<a
href="https://github.com/joeheyming"
target="_blank"
class="text-white hover:scale-125 transition-transform duration-300 text-2xl"
>
🐙 GitHub
</a>
<a
href="https://twitter.com/joeheyming"
target="_blank"
class="text-white hover:scale-125 transition-transform duration-300 text-2xl"
>
🐦 Twitter
</a>
</div>
<nav class="mb-6 text-sm" aria-label="Legal">
<a
href="https://joeheyming.github.io/privacy-policy.html"
class="text-white/90 underline underline-offset-2 hover:text-white"
>Privacy Policy</a
>
<span class="text-white/50 mx-2" aria-hidden="true">·</span>
<a
href="https://joeheyming.github.io/terms-of-service.html"
class="text-white/90 underline underline-offset-2 hover:text-white"
>Terms of Service</a
>
</nav>
<p class="text-sm opacity-80">"Lots of hard work."</p>
</footer>
<!-- Floating Easter Egg Button -->
<button
onclick="triggerEasterEgg()"
class="fixed bottom-6 right-6 w-16 h-16 bg-gradient-to-r from-pink-500 to-red-500 text-white rounded-full text-2xl shadow-2xl hover:scale-110 hover:rotate-12 transition-all duration-300 z-50"
title="Click for unicorn magic!"
>
🦄
</button>
<!-- Heyming OS Button -->
<a
id="heyming-os-btn"
href="/os/"
class="fixed bottom-6 left-6 px-6 py-3 bg-gradient-to-r from-gray-800 to-black text-green-400 rounded-lg text-sm font-mono shadow-2xl hover:scale-105 hover:from-gray-700 hover:to-gray-900 transition-all duration-300 z-50 border border-green-500/50 no-underline"
title="Launch Heyming OS"
>
💻 Heyming OS
</a>
</body>
</html>