heyiam 0.3.0 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/auth.js +29 -3
- package/dist/db.js +1 -1
- package/dist/export.js +84 -2
- package/dist/github.js +381 -0
- package/dist/parsers/index.js +22 -3
- package/dist/public/assets/index-Coilyhtr.css +1 -0
- package/dist/public/assets/index-D0noVMFu.js +44 -0
- package/dist/public/index.html +2 -2
- package/dist/render/templates/aurora/portfolio.liquid +10 -22
- package/dist/render/templates/aurora/project.liquid +1 -1
- package/dist/render/templates/aurora/styles.css +6 -0
- package/dist/render/templates/bauhaus/portfolio.liquid +9 -19
- package/dist/render/templates/bauhaus/styles.css +4 -0
- package/dist/render/templates/blueprint/portfolio.liquid +10 -24
- package/dist/render/templates/blueprint/styles.css +4 -0
- package/dist/render/templates/canvas/portfolio.liquid +17 -29
- package/dist/render/templates/canvas/styles.css +4 -0
- package/dist/render/templates/carbon/portfolio.liquid +9 -19
- package/dist/render/templates/carbon/styles.css +6 -0
- package/dist/render/templates/chalk/portfolio.liquid +9 -19
- package/dist/render/templates/chalk/styles.css +4 -0
- package/dist/render/templates/circuit/portfolio.liquid +10 -20
- package/dist/render/templates/circuit/project.liquid +1 -1
- package/dist/render/templates/circuit/styles.css +6 -0
- package/dist/render/templates/cosmos/portfolio.liquid +10 -20
- package/dist/render/templates/cosmos/project.liquid +1 -1
- package/dist/render/templates/cosmos/styles.css +6 -0
- package/dist/render/templates/daylight/portfolio.liquid +10 -20
- package/dist/render/templates/daylight/project.liquid +1 -1
- package/dist/render/templates/daylight/styles.css +4 -0
- package/dist/render/templates/editorial/portfolio.liquid +11 -27
- package/dist/render/templates/editorial/styles.css +4 -0
- package/dist/render/templates/ember/portfolio.liquid +11 -23
- package/dist/render/templates/ember/project.liquid +1 -1
- package/dist/render/templates/ember/styles.css +6 -0
- package/dist/render/templates/glacier/portfolio.liquid +10 -20
- package/dist/render/templates/glacier/project.liquid +1 -1
- package/dist/render/templates/glacier/styles.css +4 -0
- package/dist/render/templates/grid/portfolio.liquid +9 -19
- package/dist/render/templates/grid/styles.css +4 -0
- package/dist/render/templates/kinetic/portfolio.liquid +10 -22
- package/dist/render/templates/kinetic/project.liquid +1 -1
- package/dist/render/templates/kinetic/styles.css +4 -0
- package/dist/render/templates/meridian/portfolio.liquid +11 -23
- package/dist/render/templates/meridian/styles.css +6 -0
- package/dist/render/templates/minimal/portfolio.liquid +10 -10
- package/dist/render/templates/minimal/styles.css +4 -0
- package/dist/render/templates/mono/portfolio.liquid +9 -19
- package/dist/render/templates/mono/styles.css +6 -0
- package/dist/render/templates/neon/portfolio.liquid +10 -20
- package/dist/render/templates/neon/project.liquid +1 -1
- package/dist/render/templates/neon/styles.css +6 -0
- package/dist/render/templates/noir/portfolio.liquid +5 -5
- package/dist/render/templates/noir/styles.css +6 -0
- package/dist/render/templates/obsidian/portfolio.liquid +9 -19
- package/dist/render/templates/obsidian/styles.css +6 -0
- package/dist/render/templates/paper/portfolio.liquid +9 -19
- package/dist/render/templates/paper/styles.css +4 -0
- package/dist/render/templates/parallax/portfolio.liquid +9 -19
- package/dist/render/templates/parallax/styles.css +6 -0
- package/dist/render/templates/parchment/portfolio.liquid +9 -19
- package/dist/render/templates/parchment/styles.css +4 -0
- package/dist/render/templates/radar/portfolio.liquid +9 -19
- package/dist/render/templates/radar/styles.css +6 -0
- package/dist/render/templates/showcase/portfolio.liquid +9 -19
- package/dist/render/templates/showcase/styles.css +5 -0
- package/dist/render/templates/signal/portfolio.liquid +9 -19
- package/dist/render/templates/signal/styles.css +6 -0
- package/dist/render/templates/strata/portfolio.liquid +10 -22
- package/dist/render/templates/strata/styles.css +4 -0
- package/dist/render/templates/terminal/portfolio.liquid +10 -26
- package/dist/render/templates/terminal/styles.css +5 -0
- package/dist/render/templates/verdant/portfolio.liquid +11 -23
- package/dist/render/templates/verdant/project.liquid +1 -1
- package/dist/render/templates/verdant/styles.css +4 -0
- package/dist/render/templates/zen/portfolio.liquid +10 -22
- package/dist/render/templates/zen/styles.css +4 -0
- package/dist/routes/auth.js +7 -3
- package/dist/routes/context.js +2 -0
- package/dist/routes/delete.js +195 -0
- package/dist/routes/enhance.js +40 -0
- package/dist/routes/github.js +254 -0
- package/dist/routes/index.js +2 -0
- package/dist/routes/portfolio-render-data.js +160 -0
- package/dist/routes/preview.js +85 -10
- package/dist/routes/projects.js +50 -5
- package/dist/routes/publish.js +306 -15
- package/dist/routes/settings.js +102 -2
- package/dist/search.js +6 -0
- package/dist/server.js +3 -1
- package/dist/settings.js +95 -0
- package/package.json +2 -1
- package/dist/public/assets/index-BZ65TU_Y.js +0 -40
- package/dist/public/assets/index-CqCaW2cb.css +0 -1
|
@@ -7,35 +7,23 @@
|
|
|
7
7
|
<div class="hero-content">
|
|
8
8
|
<div class="eyebrow">Developer Portfolio</div>
|
|
9
9
|
<div class="hero-profile-row">
|
|
10
|
-
{%
|
|
11
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="profile-photo">
|
|
12
|
-
{% endif %}
|
|
10
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="profile-photo" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
13
11
|
<div>
|
|
14
12
|
{% if user.displayName != blank %}
|
|
15
|
-
<h1>{{ user.displayName }}</h1>
|
|
13
|
+
<h1 data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
16
14
|
{% endif %}
|
|
17
15
|
{% if user.bio %}
|
|
18
|
-
<p class="hero-bio">{{ user.bio }}</p>
|
|
16
|
+
<p class="hero-bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
19
17
|
{% endif %}
|
|
20
18
|
{% if user.location %}
|
|
21
|
-
<span class="hero-location">{{ user.location }}</span>
|
|
19
|
+
<span class="hero-location" data-portfolio-field="location">{{ user.location }}</span>
|
|
22
20
|
{% endif %}
|
|
23
21
|
<div class="contact-row">
|
|
24
|
-
{% if user.email %}
|
|
25
|
-
<a href="
|
|
26
|
-
{% endif %}
|
|
27
|
-
{% if user.
|
|
28
|
-
<a href="{{ user.
|
|
29
|
-
{% endif %}
|
|
30
|
-
{% if user.githubUrl %}
|
|
31
|
-
<a href="{{ user.githubUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg> GitHub</a>
|
|
32
|
-
{% endif %}
|
|
33
|
-
{% if user.twitterHandle %}
|
|
34
|
-
<a href="https://x.com/{{ user.twitterHandle }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg> @{{ user.twitterHandle }}</a>
|
|
35
|
-
{% endif %}
|
|
36
|
-
{% if user.websiteUrl %}
|
|
37
|
-
<a href="{{ user.websiteUrl }}" target="_blank" rel="noopener">{{ user.websiteUrl | stripProtocol }}</a>
|
|
38
|
-
{% endif %}
|
|
22
|
+
<a href="{% if user.email %}mailto:{{ user.email }}{% endif %}" data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 4 10 8 10-8"/></svg> <span data-portfolio-text>{{ user.email }}</span></a>
|
|
23
|
+
<a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" target="_blank" rel="noopener" data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg> LinkedIn</a>
|
|
24
|
+
<a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" target="_blank" rel="noopener" data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg> GitHub</a>
|
|
25
|
+
<a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" target="_blank" rel="noopener" data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg> <span data-portfolio-text>{% if user.twitterHandle %}@{{ user.twitterHandle }}{% endif %}</span></a>
|
|
26
|
+
<a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" target="_blank" rel="noopener" data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><span data-portfolio-text>{{ user.websiteUrl | stripProtocol }}</span></a>
|
|
39
27
|
{% if user.resumeUrl %}
|
|
40
28
|
<a href="{{ user.resumeUrl }}" class="resume-btn"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/><line x1="12" y1="18" x2="12" y2="12"/><polyline points="9 15 12 18 15 15"/></svg> Resume (PDF)</a>
|
|
41
29
|
{% endif %}
|
|
@@ -69,7 +57,7 @@
|
|
|
69
57
|
</div>
|
|
70
58
|
{% assign totalCombined = totalDurationMinutes | plus: totalAgentDurationMinutes %}
|
|
71
59
|
{% if totalCombined > 0 %}
|
|
72
|
-
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined %}
|
|
60
|
+
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined | round %}
|
|
73
61
|
{% assign agentPct = 100 | minus: humanPct %}
|
|
74
62
|
<div class="leverage-bar">
|
|
75
63
|
<div class="leverage-bar__human" style="width: {{ humanPct }}%;"></div>
|
|
@@ -53,7 +53,7 @@
|
|
|
53
53
|
</div>
|
|
54
54
|
{% assign totalCombined = project.totalDurationMinutes | plus: project.totalAgentDurationMinutes %}
|
|
55
55
|
{% if totalCombined > 0 %}
|
|
56
|
-
{% assign humanPct = project.totalDurationMinutes | times: 100 | divided_by: totalCombined %}
|
|
56
|
+
{% assign humanPct = project.totalDurationMinutes | times: 100 | divided_by: totalCombined | round %}
|
|
57
57
|
{% assign agentPct = 100 | minus: humanPct %}
|
|
58
58
|
<div class="leverage-bar">
|
|
59
59
|
<div class="leverage-bar__human" style="width: {{ humanPct }}%;"></div>
|
|
@@ -942,3 +942,7 @@ body {
|
|
|
942
942
|
transition-duration: 0.01ms !important;
|
|
943
943
|
}
|
|
944
944
|
}
|
|
945
|
+
|
|
946
|
+
/* Live-patcher empty-state hide marker. Set by the EditRail preview
|
|
947
|
+
patcher when a contact field clears, removed when it gets a value. */
|
|
948
|
+
[data-portfolio-empty="true"] { display: none !important; }
|
|
@@ -41,42 +41,30 @@
|
|
|
41
41
|
</div>
|
|
42
42
|
<div class="hero__profile">
|
|
43
43
|
{% if user.photoUrl %}
|
|
44
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero__photo" width="120" height="150">
|
|
44
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero__photo" width="120" height="150" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
45
45
|
{% endif %}
|
|
46
46
|
<div class="hero__info">
|
|
47
47
|
{% if user.displayName != blank %}
|
|
48
|
-
<h1 class="hero__name">{{ user.displayName }}</h1>
|
|
48
|
+
<h1 class="hero__name" data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
49
49
|
{% endif %}
|
|
50
50
|
<p class="hero__handle">@{{ user.username }}</p>
|
|
51
51
|
{% if user.bio != blank %}
|
|
52
|
-
<p class="hero__bio">{{ user.bio }}</p>
|
|
52
|
+
<p class="hero__bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
53
53
|
{% endif %}
|
|
54
54
|
{% if user.location != blank %}
|
|
55
55
|
<p class="hero__location">
|
|
56
56
|
<svg viewBox="0 0 24 24" aria-hidden="true"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7z" stroke-linecap="round" stroke-linejoin="round"/><circle cx="12" cy="9" r="2.5"/></svg>
|
|
57
|
-
{{ user.location }}
|
|
57
|
+
<span data-portfolio-field="location">{{ user.location }}</span>
|
|
58
58
|
</p>
|
|
59
59
|
{% endif %}
|
|
60
60
|
{% if user.email or user.linkedinUrl or user.githubUrl or user.twitterHandle or user.websiteUrl %}
|
|
61
61
|
<ul class="hero__contact" aria-label="Contact and social links">
|
|
62
|
-
{% if user.email %}
|
|
63
|
-
<li><a href="
|
|
64
|
-
{% endif %}
|
|
65
|
-
{% if user.
|
|
66
|
-
<li><a href="
|
|
67
|
-
{% endif %}
|
|
68
|
-
{% if user.linkedinUrl %}
|
|
69
|
-
<li><a href="{{ user.linkedinUrl }}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg>LinkedIn</a></li>
|
|
70
|
-
{% endif %}
|
|
71
|
-
{% if user.githubUrl %}
|
|
72
|
-
<li><a href="{{ user.githubUrl }}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
73
|
-
{% endif %}
|
|
74
|
-
{% if user.twitterHandle %}
|
|
75
|
-
<li><a href="https://x.com/{{ user.twitterHandle }}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
76
|
-
{% endif %}
|
|
77
|
-
{% if user.websiteUrl %}
|
|
78
|
-
<li><a href="{{ user.websiteUrl }}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"/><line x1="2" y1="12" x2="22" y2="12"/><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
79
|
-
{% endif %}
|
|
62
|
+
<li data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.email %}mailto:{{ user.email }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 4 10 8 10-8"/></svg>{{ user.email }}</a></li>
|
|
63
|
+
<li data-portfolio-field="phone"{% unless user.phone %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.phone %}tel:{{ user.phone }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.127.96.361 1.903.7 2.81a2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45c.907.339 1.85.573 2.81.7A2 2 0 0 1 22 16.92z"/></svg>{{ user.phone }}</a></li>
|
|
64
|
+
<li data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg>LinkedIn</a></li>
|
|
65
|
+
<li data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
66
|
+
<li data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
67
|
+
<li data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><circle cx="12" cy="12" r="10"/><line x1="2" y1="12" x2="22" y2="12"/><path d="M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
80
68
|
</ul>
|
|
81
69
|
{% endif %}
|
|
82
70
|
{% if user.resumeUrl %}
|
|
@@ -113,7 +101,7 @@
|
|
|
113
101
|
</div>
|
|
114
102
|
{% assign totalCombined = totalDurationMinutes | plus: totalAgentDurationMinutes %}
|
|
115
103
|
{% if totalCombined > 0 %}
|
|
116
|
-
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined %}
|
|
104
|
+
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined | round %}
|
|
117
105
|
{% assign agentPct = 100 | minus: humanPct %}
|
|
118
106
|
<div class="mer-leverage-bar">
|
|
119
107
|
<div class="mer-leverage-bar__human" style="width: {{ humanPct }}%"></div>
|
|
@@ -4,6 +4,8 @@
|
|
|
4
4
|
* Fonts: Space Grotesk (display), Inter (body), IBM Plex Mono (mono).
|
|
5
5
|
*/
|
|
6
6
|
|
|
7
|
+
body { background: var(--mer-bg); color: var(--mer-text); }
|
|
8
|
+
|
|
7
9
|
/* ── Meridian Design Tokens ── */
|
|
8
10
|
.meridian {
|
|
9
11
|
--mer-bg: #022c22;
|
|
@@ -1367,3 +1369,7 @@
|
|
|
1367
1369
|
.meridian .session-header__meta { gap: 0.75rem; }
|
|
1368
1370
|
.meridian .sidebar { grid-template-columns: 1fr; }
|
|
1369
1371
|
}
|
|
1372
|
+
|
|
1373
|
+
|
|
1374
|
+
/* Live-edit empty field hiding */
|
|
1375
|
+
[data-portfolio-empty="true"] { display: none; }
|
|
@@ -6,29 +6,29 @@
|
|
|
6
6
|
{%- comment -%} Optional photo {%- endcomment -%}
|
|
7
7
|
{% if user.photoUrl %}
|
|
8
8
|
<div class="mn-photo-wrap">
|
|
9
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="mn-photo portfolio-photo" width="96" height="96">
|
|
9
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="mn-photo portfolio-photo" width="96" height="96" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
10
10
|
</div>
|
|
11
11
|
{% endif %}
|
|
12
12
|
|
|
13
13
|
{%- comment -%} Big serif heading {%- endcomment -%}
|
|
14
14
|
{% if user.displayName != blank %}
|
|
15
|
-
<h1 class="mn-heading">{{ user.displayName }}</h1>
|
|
15
|
+
<h1 class="mn-heading" data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
16
16
|
{% endif %}
|
|
17
17
|
|
|
18
18
|
{% if user.bio != blank %}
|
|
19
|
-
<p class="mn-bio">{{ user.bio }}</p>
|
|
19
|
+
<p class="mn-bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
20
20
|
{% endif %}
|
|
21
21
|
|
|
22
22
|
{%- comment -%} Contact / links as middot-separated inline text {%- endcomment -%}
|
|
23
23
|
{% if user.location != blank or user.email != blank or user.phone != blank or user.githubUrl != blank or user.linkedinUrl != blank or user.twitterHandle != blank or user.websiteUrl != blank or user.resumeUrl != blank %}
|
|
24
24
|
<div class="mn-contact">
|
|
25
|
-
{%
|
|
26
|
-
{%
|
|
27
|
-
{%
|
|
28
|
-
{%
|
|
29
|
-
{%
|
|
30
|
-
{%
|
|
31
|
-
{%
|
|
25
|
+
<span data-portfolio-field="location"{% unless user.location %} data-portfolio-empty="true"{% endunless %}>{{ user.location }}</span>
|
|
26
|
+
<span data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.email %}mailto:{{ user.email }}{% endif %}">{{ user.email }}</a></span>
|
|
27
|
+
<span data-portfolio-field="phone"{% unless user.phone %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.phone %}tel:{{ user.phone }}{% endif %}">{{ user.phone }}</a></span>
|
|
28
|
+
<span data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" target="_blank" rel="noopener">GitHub</a></span>
|
|
29
|
+
<span data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" target="_blank" rel="noopener">LinkedIn</a></span>
|
|
30
|
+
<span data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" target="_blank" rel="noopener"><span data-portfolio-text>{% if user.twitterHandle %}@{{ user.twitterHandle }}{% endif %}</span></a></span>
|
|
31
|
+
<span data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" target="_blank" rel="noopener">{{ user.websiteUrl | stripProtocol }}</a></span>
|
|
32
32
|
{% if user.resumeUrl != blank %}<span><a href="{{ user.resumeUrl }}" download>Resume (PDF)</a></span>{% endif %}
|
|
33
33
|
</div>
|
|
34
34
|
{% endif %}
|
|
@@ -17,42 +17,32 @@
|
|
|
17
17
|
<div class="terminal-body">
|
|
18
18
|
<div class="hero-profile">
|
|
19
19
|
{% if user.photoUrl %}
|
|
20
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo" width="120" height="150">
|
|
20
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo" width="120" height="150" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
21
21
|
{% endif %}
|
|
22
22
|
<div class="hero-info">
|
|
23
23
|
{% if user.displayName != blank %}
|
|
24
|
-
<h1 class="hero-title" aria-label="{{ user.displayName }}">{{ user.displayName }}</h1>
|
|
24
|
+
<h1 class="hero-title" aria-label="{{ user.displayName }}" data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
25
25
|
{% endif %}
|
|
26
26
|
<p class="hero-handle">
|
|
27
27
|
<span style="color: var(--mono-accent, #4ade80);">@</span>{{ user.username }}
|
|
28
28
|
</p>
|
|
29
29
|
{% if user.bio %}
|
|
30
30
|
<p class="hero-bio">
|
|
31
|
-
<span class="comment">// </span>{{ user.bio }}
|
|
31
|
+
<span class="comment">// </span><span data-portfolio-field="bio">{{ user.bio }}</span>
|
|
32
32
|
</p>
|
|
33
33
|
{% endif %}
|
|
34
34
|
{% if user.location %}
|
|
35
35
|
<p class="hero-location">
|
|
36
|
-
<span class="comment">location: </span>{{ user.location }}
|
|
36
|
+
<span class="comment">location: </span><span data-portfolio-field="location">{{ user.location }}</span>
|
|
37
37
|
</p>
|
|
38
38
|
{% endif %}
|
|
39
39
|
{% if user.email or user.linkedinUrl or user.githubUrl or user.twitterHandle or user.websiteUrl %}
|
|
40
40
|
<ul class="hero-contact" aria-label="Contact and social links">
|
|
41
|
-
{% if user.email %}
|
|
42
|
-
<li><a href="
|
|
43
|
-
{% endif %}
|
|
44
|
-
{% if user.
|
|
45
|
-
<li><a href="{{ user.
|
|
46
|
-
{% endif %}
|
|
47
|
-
{% if user.githubUrl %}
|
|
48
|
-
<li><a href="{{ user.githubUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
49
|
-
{% endif %}
|
|
50
|
-
{% if user.twitterHandle %}
|
|
51
|
-
<li><a href="https://x.com/{{ user.twitterHandle }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
52
|
-
{% endif %}
|
|
53
|
-
{% if user.websiteUrl %}
|
|
54
|
-
<li><a href="{{ user.websiteUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7z"/><circle cx="12" cy="9" r="2.5"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
55
|
-
{% endif %}
|
|
41
|
+
<li data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.email %}mailto:{{ user.email }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 4 10 8 10-8"/></svg>{{ user.email }}</a></li>
|
|
42
|
+
<li data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg>LinkedIn</a></li>
|
|
43
|
+
<li data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
44
|
+
<li data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
45
|
+
<li data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7z"/><circle cx="12" cy="9" r="2.5"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
56
46
|
</ul>
|
|
57
47
|
{% endif %}
|
|
58
48
|
{% if user.resumeUrl %}
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
* Extracted from mockup HTML files.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
+
body { background: var(--mono-bg, #0a0a0a); color: var(--mono-text, #e0e0e0); }
|
|
7
|
+
|
|
6
8
|
/* ── Design Tokens (inherited from theme system, fallbacks here) ── */
|
|
7
9
|
|
|
8
10
|
/* ── Dark Wrapper ── */
|
|
@@ -1014,3 +1016,7 @@
|
|
|
1014
1016
|
transition: none;
|
|
1015
1017
|
}
|
|
1016
1018
|
}
|
|
1019
|
+
|
|
1020
|
+
|
|
1021
|
+
/* Live-edit empty field hiding */
|
|
1022
|
+
[data-portfolio-empty="true"] { display: none; }
|
|
@@ -6,34 +6,24 @@
|
|
|
6
6
|
{% if hasProfile %}
|
|
7
7
|
<section class="hero fade-in" aria-label="Profile">
|
|
8
8
|
{% if user.photoUrl %}
|
|
9
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo portfolio-photo">
|
|
9
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo portfolio-photo" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
10
10
|
{% endif %}
|
|
11
11
|
{% if user.displayName != blank %}
|
|
12
|
-
<h1>{{ user.displayName }}</h1>
|
|
12
|
+
<h1 data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
13
13
|
{% endif %}
|
|
14
14
|
{% if user.bio != blank %}
|
|
15
|
-
<p class="hero-bio portfolio-bio">{{ user.bio }}</p>
|
|
15
|
+
<p class="hero-bio portfolio-bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
16
16
|
{% endif %}
|
|
17
17
|
{% if user.location != blank %}
|
|
18
|
-
<p class="hero-location portfolio-location">{{ user.location }}</p>
|
|
18
|
+
<p class="hero-location portfolio-location" data-portfolio-field="location">{{ user.location }}</p>
|
|
19
19
|
{% endif %}
|
|
20
20
|
{% if user.email or user.linkedinUrl or user.githubUrl or user.twitterHandle or user.websiteUrl or user.resumeUrl %}
|
|
21
21
|
<ul class="hero-links" aria-label="Contact and social links">
|
|
22
|
-
{% if user.email %}
|
|
23
|
-
<li><a href="
|
|
24
|
-
{% endif %}
|
|
25
|
-
{% if user.
|
|
26
|
-
<li><a href="{{ user.
|
|
27
|
-
{% endif %}
|
|
28
|
-
{% if user.githubUrl %}
|
|
29
|
-
<li><a href="{{ user.githubUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
30
|
-
{% endif %}
|
|
31
|
-
{% if user.twitterHandle %}
|
|
32
|
-
<li><a href="https://x.com/{{ user.twitterHandle }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
33
|
-
{% endif %}
|
|
34
|
-
{% if user.websiteUrl %}
|
|
35
|
-
<li><a href="{{ user.websiteUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><circle cx="12" cy="12" r="10"/><path d="M2 12h20M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
36
|
-
{% endif %}
|
|
22
|
+
<li data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.email %}mailto:{{ user.email }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 4 10 8 10-8"/></svg>{{ user.email }}</a></li>
|
|
23
|
+
<li data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg>LinkedIn</a></li>
|
|
24
|
+
<li data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
25
|
+
<li data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
26
|
+
<li data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><circle cx="12" cy="12" r="10"/><path d="M2 12h20M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
37
27
|
{% if user.resumeUrl %}
|
|
38
28
|
<li><a href="{{ user.resumeUrl }}" download><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/><line x1="12" y1="18" x2="12" y2="12"/><polyline points="9 15 12 18 15 15"/></svg>Resume (PDF)</a></li>
|
|
39
29
|
{% endif %}
|
|
@@ -79,7 +69,7 @@
|
|
|
79
69
|
<div class="neon-leverage__context">{{ totalDurationMinutes | formatDuration }} you · <span>{{ totalAgentDurationMinutes | formatDuration }} agents</span></div>
|
|
80
70
|
{% assign totalCombined = totalDurationMinutes | plus: totalAgentDurationMinutes %}
|
|
81
71
|
{% if totalCombined > 0 %}
|
|
82
|
-
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined %}
|
|
72
|
+
{% assign humanPct = totalDurationMinutes | times: 100 | divided_by: totalCombined | round %}
|
|
83
73
|
{% assign agentPct = 100 | minus: humanPct %}
|
|
84
74
|
<div class="neon-leverage__bar"><div class="neon-leverage__human" style="width:{{ humanPct }}%"></div><div class="neon-leverage__agent" style="width:{{ agentPct }}%"></div></div>
|
|
85
75
|
{% endif %}
|
|
@@ -87,7 +87,7 @@
|
|
|
87
87
|
<div class="neon-leverage__context">{{ project.totalDurationMinutes | formatDuration }} you · <span>{{ project.totalAgentDurationMinutes | formatDuration }} agents</span></div>
|
|
88
88
|
{% assign totalCombined = project.totalDurationMinutes | plus: project.totalAgentDurationMinutes %}
|
|
89
89
|
{% if totalCombined > 0 %}
|
|
90
|
-
{% assign humanPct = project.totalDurationMinutes | times: 100 | divided_by: totalCombined %}
|
|
90
|
+
{% assign humanPct = project.totalDurationMinutes | times: 100 | divided_by: totalCombined | round %}
|
|
91
91
|
{% assign agentPct = 100 | minus: humanPct %}
|
|
92
92
|
<div class="neon-leverage__bar"><div class="neon-leverage__human" style="width:{{ humanPct }}%"></div><div class="neon-leverage__agent" style="width:{{ agentPct }}%"></div></div>
|
|
93
93
|
{% endif %}
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
* Dark theme with pink/cyan neon accents, Space Grotesk display font.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
+
body { background: var(--neon-bg); color: var(--neon-text); }
|
|
7
|
+
|
|
6
8
|
/* ── Design Tokens ── */
|
|
7
9
|
.neon {
|
|
8
10
|
--neon-bg: #0c0014;
|
|
@@ -1263,3 +1265,7 @@
|
|
|
1263
1265
|
}
|
|
1264
1266
|
.neon .contrib-chart { padding: 1rem; }
|
|
1265
1267
|
}
|
|
1268
|
+
|
|
1269
|
+
|
|
1270
|
+
/* Live-edit empty field hiding */
|
|
1271
|
+
[data-portfolio-empty="true"] { display: none; }
|
|
@@ -10,20 +10,20 @@
|
|
|
10
10
|
class="noir-hero__photo"
|
|
11
11
|
width="400"
|
|
12
12
|
height="500"
|
|
13
|
-
|
|
13
|
+
data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
14
14
|
{% endif %}
|
|
15
15
|
<div class="noir-hero__content">
|
|
16
16
|
{% if user.displayName != blank %}
|
|
17
|
-
<h1 class="noir-hero__name">{{ user.displayName }}</h1>
|
|
17
|
+
<h1 class="noir-hero__name" data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
18
18
|
{% endif %}
|
|
19
19
|
{% if user.bio != blank %}
|
|
20
|
-
<p class="noir-hero__bio">{{ user.bio }}</p>
|
|
20
|
+
<p class="noir-hero__bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
21
21
|
{% endif %}
|
|
22
22
|
{% if user.location != blank %}
|
|
23
|
-
<p class="noir-hero__location">{{ user.location }}</p>
|
|
23
|
+
<p class="noir-hero__location" data-portfolio-field="location">{{ user.location }}</p>
|
|
24
24
|
{% endif %}
|
|
25
25
|
<p class="noir-hero__contact">
|
|
26
|
-
{% if user.email
|
|
26
|
+
<a href="{% if user.email %}mailto:{{ user.email }}{% endif %}" data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><span data-portfolio-text>{{ user.email }}</span></a><span class="noir-middot" data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}>·</span><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}>LinkedIn</a><span class="noir-middot" data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}>·</span><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}>GitHub</a><span class="noir-middot" data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}>·</span><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><span data-portfolio-text>{% if user.twitterHandle %}@{{ user.twitterHandle }}{% endif %}</span></a><span class="noir-middot" data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}>·</span><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><span data-portfolio-text>{{ user.websiteUrl | stripProtocol }}</span></a>
|
|
27
27
|
</p>
|
|
28
28
|
{% if user.resumeUrl != blank %}
|
|
29
29
|
<a href="{{ user.resumeUrl }}" class="noir-hero__resume">
|
|
@@ -22,6 +22,8 @@
|
|
|
22
22
|
|
|
23
23
|
--radius: 0px;
|
|
24
24
|
}
|
|
25
|
+
body { background: var(--noir-bg); color: var(--noir-text); }
|
|
26
|
+
|
|
25
27
|
|
|
26
28
|
/* ── Page Shell ── */
|
|
27
29
|
.noir-page {
|
|
@@ -1221,3 +1223,7 @@
|
|
|
1221
1223
|
outline: 2px solid var(--noir-white);
|
|
1222
1224
|
outline-offset: 2px;
|
|
1223
1225
|
}
|
|
1226
|
+
|
|
1227
|
+
|
|
1228
|
+
/* Live-edit empty field hiding */
|
|
1229
|
+
[data-portfolio-empty="true"] { display: none; }
|
|
@@ -7,38 +7,28 @@
|
|
|
7
7
|
<section class="hero hero--portfolio container fade-up" aria-label="Profile">
|
|
8
8
|
<div class="hero-row">
|
|
9
9
|
{% if user.photoUrl %}
|
|
10
|
-
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo portfolio-photo">
|
|
10
|
+
<img src="{{ user.photoUrl }}" alt="{{ user.displayName }}" class="hero-photo portfolio-photo" data-portfolio-field="photoBase64"{% unless user.photoUrl %} data-portfolio-empty="true"{% endunless %}>
|
|
11
11
|
{% endif %}
|
|
12
12
|
<div class="hero-row-text">
|
|
13
13
|
{% if user.displayName != blank %}
|
|
14
|
-
<h1>{{ user.displayName }}</h1>
|
|
14
|
+
<h1 data-portfolio-field="displayName">{{ user.displayName }}</h1>
|
|
15
15
|
{% endif %}
|
|
16
16
|
{% if user.bio != blank %}
|
|
17
|
-
<p class="hero-bio portfolio-bio">{{ user.bio }}</p>
|
|
17
|
+
<p class="hero-bio portfolio-bio" data-portfolio-field="bio">{{ user.bio }}</p>
|
|
18
18
|
{% endif %}
|
|
19
19
|
{% if user.location != blank %}
|
|
20
20
|
<p class="hero-location portfolio-location">
|
|
21
21
|
<svg viewBox="0 0 24 24" aria-hidden="true"><path d="M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z"/><circle cx="12" cy="10" r="3"/></svg>
|
|
22
|
-
{{ user.location }}
|
|
22
|
+
<span data-portfolio-field="location">{{ user.location }}</span>
|
|
23
23
|
</p>
|
|
24
24
|
{% endif %}
|
|
25
25
|
{% if user.email or user.linkedinUrl or user.githubUrl or user.twitterHandle or user.websiteUrl or user.resumeUrl %}
|
|
26
26
|
<ul class="hero-links" aria-label="Contact and social links">
|
|
27
|
-
{% if user.email %}
|
|
28
|
-
<li><a href="
|
|
29
|
-
{% endif %}
|
|
30
|
-
{% if user.
|
|
31
|
-
<li><a href="{{ user.
|
|
32
|
-
{% endif %}
|
|
33
|
-
{% if user.githubUrl %}
|
|
34
|
-
<li><a href="{{ user.githubUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
35
|
-
{% endif %}
|
|
36
|
-
{% if user.twitterHandle %}
|
|
37
|
-
<li><a href="https://x.com/{{ user.twitterHandle }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
38
|
-
{% endif %}
|
|
39
|
-
{% if user.websiteUrl %}
|
|
40
|
-
<li><a href="{{ user.websiteUrl }}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><circle cx="12" cy="12" r="10"/><path d="M2 12h20M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
41
|
-
{% endif %}
|
|
27
|
+
<li data-portfolio-field="email"{% unless user.email %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.email %}mailto:{{ user.email }}{% endif %}"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="m2 4 10 8 10-8"/></svg>{{ user.email }}</a></li>
|
|
28
|
+
<li data-portfolio-field="linkedinUrl"{% unless user.linkedinUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.linkedinUrl %}{{ user.linkedinUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M20.5 2h-17A1.5 1.5 0 002 3.5v17A1.5 1.5 0 003.5 22h17a1.5 1.5 0 001.5-1.5v-17A1.5 1.5 0 0020.5 2zM8 19H5v-9h3zM6.5 8.25A1.75 1.75 0 118.3 6.5a1.78 1.78 0 01-1.8 1.75zM19 19h-3v-4.74c0-1.42-.6-1.93-1.38-1.93A1.74 1.74 0 0013 14.19V19h-3v-9h2.9v1.3a3.11 3.11 0 012.7-1.4c1.55 0 3.36.86 3.36 3.66z"/></svg>LinkedIn</a></li>
|
|
29
|
+
<li data-portfolio-field="githubUrl"{% unless user.githubUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.githubUrl %}{{ user.githubUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z"/></svg>GitHub</a></li>
|
|
30
|
+
<li data-portfolio-field="twitterHandle"{% unless user.twitterHandle %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.twitterHandle %}https://x.com/{{ user.twitterHandle }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true"><path d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"/></svg>@{{ user.twitterHandle }}</a></li>
|
|
31
|
+
<li data-portfolio-field="websiteUrl"{% unless user.websiteUrl %} data-portfolio-empty="true"{% endunless %}><a href="{% if user.websiteUrl %}{{ user.websiteUrl }}{% endif %}" target="_blank" rel="noopener"><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><circle cx="12" cy="12" r="10"/><path d="M2 12h20M12 2a15.3 15.3 0 0 1 4 10 15.3 15.3 0 0 1-4 10 15.3 15.3 0 0 1-4-10 15.3 15.3 0 0 1 4-10z"/></svg>{{ user.websiteUrl | stripProtocol }}</a></li>
|
|
42
32
|
{% if user.resumeUrl %}
|
|
43
33
|
<li><a href="{{ user.resumeUrl }}" download><svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" aria-hidden="true"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/><line x1="12" y1="18" x2="12" y2="12"/><polyline points="9 15 12 18 15 15"/></svg>Resume (PDF)</a></li>
|
|
44
34
|
{% endif %}
|
|
@@ -3,6 +3,8 @@
|
|
|
3
3
|
* Dark theme with purple accent, Space Grotesk display font.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
+
body { background: var(--obs-bg); color: var(--obs-text); }
|
|
7
|
+
|
|
6
8
|
/* ── Tokens ── */
|
|
7
9
|
.obsidian {
|
|
8
10
|
--bg: #09090b;
|
|
@@ -1399,3 +1401,7 @@
|
|
|
1399
1401
|
grid-template-columns: repeat(2, 1fr);
|
|
1400
1402
|
}
|
|
1401
1403
|
}
|
|
1404
|
+
|
|
1405
|
+
|
|
1406
|
+
/* Live-edit empty field hiding */
|
|
1407
|
+
[data-portfolio-empty="true"] { display: none; }
|