Files
cv-site/templates/partials/sections/courses.html
T
juanatsap b5a50ca3ef feat: implement CSS sprite system for image optimization
Reduces HTTP requests from 44+ individual images to 3 sprite sheets
(~93% reduction). Includes Go sprite generator tool, CSS classes,
template integration, and E2E tests.

- Add cmd/sprites/main.go for sprite generation (60x60px + 120x120px @2x)
- Add _sprites.css with responsive sizing and retina support
- Update templates to use sprites with logoIndex fallback
- Add Makefile targets: sprites, sprites-clean
- Add 9-test E2E suite for sprite functionality
- Add doc/22-SPRITES.md with usage documentation
2025-12-04 11:38:36 +00:00

86 lines
3.7 KiB
HTML

{{define "section-courses"}}
<!-- Courses Section -->
{{if .CV.Courses}}
<section id="courses" class="cv-section component-wrapper">
<!-- Actual Content -->
<div class="actual-content">
<details open>
<summary>
<h3 class="section-title">
<iconify-icon icon="mdi:school" width="24" height="24" class="section-icon"></iconify-icon>
{{.UI.Navigation.Courses}}
</h3>
</summary>
{{range .CV.Courses}}
<div class="course-item" id="course-{{.CourseID}}" data-course="{{.CourseID}}" data-title="{{.Title}}" data-institution="{{.Institution}}">
<div class="course-icon">
{{if .LogoIndex}}
<span class="icon-sprite icon-section icon-course" style="--icon-index: {{.LogoIndex}};" role="img" aria-label="{{.Title}} logo"></span>
{{else if .CourseLogo}}
<img src="/static/images/courses/{{.CourseLogo}}" alt="{{.Title}} logo" onerror="this.parentElement.innerHTML='<iconify-icon icon=\'mdi:school\' width=\'80\' height=\'80\' class=\'default-course-icon\'></iconify-icon>'">
{{else}}
<iconify-icon icon="mdi:school" width="80" height="80" class="default-course-icon"></iconify-icon>
{{end}}
</div>
<div class="course-content">
<strong>{{.Title}}</strong><br>
<small>{{.Institution}} - {{.Date}} - ({{.Location}})</small>
{{if .ShortDescription}}
<p class="course-desc short-desc">{{.ShortDescription}}</p>
{{end}}
{{if .Responsibilities}}
<ul class="responsibilities long-only">
{{range .Responsibilities}}
<li>{{. | safeHTML}}</li>
{{end}}
</ul>
{{end}}
</div>
</div>
{{end}}
</details>
</div>
<!-- Skeleton Content -->
<div class="skeleton-content">
<div class="skeleton-section">
<div class="skeleton skeleton-section-title"></div>
<!-- Course Item 1 - With description and responsibilities -->
<div class="skeleton-course-item">
<div class="skeleton skeleton-course-icon"></div>
<div class="skeleton-course-content">
<div class="skeleton skeleton-course-title-line"></div>
<div class="skeleton skeleton-course-info-line"></div>
<div class="skeleton skeleton-description-line"></div>
<div class="skeleton skeleton-responsibility-line"></div>
<div class="skeleton skeleton-responsibility-line" style="width: 94%;"></div>
</div>
</div>
<!-- Course Item 2 - Shorter -->
<div class="skeleton-course-item">
<div class="skeleton skeleton-course-icon"></div>
<div class="skeleton-course-content">
<div class="skeleton skeleton-course-title-line"></div>
<div class="skeleton skeleton-course-info-line"></div>
<div class="skeleton skeleton-description-line" style="width: 85%;"></div>
</div>
</div>
<!-- Course Item 3 -->
<div class="skeleton-course-item">
<div class="skeleton skeleton-course-icon"></div>
<div class="skeleton-course-content">
<div class="skeleton skeleton-course-title-line"></div>
<div class="skeleton skeleton-course-info-line"></div>
</div>
</div>
</div>
</div>
</section>
{{end}}
{{end}}