Features:
- Global template configuration (sqlite_global_templates directive)
- Template path resolution relative to location
- Automatic template loading from directories
- Local templates override global templates
- Content handler installation via directive setter
Book Catalog Example:
- Complete working example with 10 technical books
- SQLite database with setup script
- 4 browseable pages (all, programming, databases, computer-science)
- Shared global templates (header, footer, book_card partial)
- Category-specific local templates with unique theming
- Responsive gradient UI design
- Working navigation and filtering
Configuration:
- sqlite_global_templates: HTTP main-level directive for shared templates
- sqlite_template: Location-level directive (sets content handler)
- Template resolution: {doc_root}{uri}/{template_name}
- All .hbs files in directories auto-loaded as partials
Technical improvements:
- Fixed content handler setup (not phase handler)
- Proper HttpModuleMainConf and HttpModuleLocationConf traits
- Template directory scanning and registration
- Error handling with debug logging
108 lines
2.4 KiB
Handlebars
108 lines
2.4 KiB
Handlebars
{{> header}}
|
|
|
|
<style>
|
|
.book-grid {
|
|
display: grid;
|
|
grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
|
|
gap: 1.5rem;
|
|
margin-top: 1.5rem;
|
|
}
|
|
.book-card {
|
|
background: #fff;
|
|
border: 2px solid #e9ecef;
|
|
border-radius: 8px;
|
|
padding: 1.5rem;
|
|
transition: all 0.3s;
|
|
}
|
|
.book-card:hover {
|
|
transform: translateY(-4px);
|
|
box-shadow: 0 8px 16px rgba(239, 68, 68, 0.2);
|
|
border-color: #ef4444;
|
|
}
|
|
.book-header {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: start;
|
|
margin-bottom: 0.5rem;
|
|
}
|
|
.book-title {
|
|
color: #2d3748;
|
|
font-size: 1.25rem;
|
|
margin-bottom: 0.25rem;
|
|
flex: 1;
|
|
}
|
|
.book-rating {
|
|
background: #fef3c7;
|
|
color: #92400e;
|
|
padding: 0.25rem 0.75rem;
|
|
border-radius: 20px;
|
|
font-weight: bold;
|
|
font-size: 0.9rem;
|
|
white-space: nowrap;
|
|
margin-left: 0.5rem;
|
|
}
|
|
.book-author {
|
|
color: #ef4444;
|
|
font-weight: 500;
|
|
margin-bottom: 0.75rem;
|
|
}
|
|
.book-description {
|
|
color: #4a5568;
|
|
margin-bottom: 1rem;
|
|
line-height: 1.5;
|
|
}
|
|
.book-details {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: 0.5rem;
|
|
font-size: 0.875rem;
|
|
}
|
|
.book-genre {
|
|
background: #ef4444;
|
|
color: white;
|
|
padding: 0.25rem 0.75rem;
|
|
border-radius: 4px;
|
|
font-weight: 500;
|
|
}
|
|
.book-year {
|
|
background: #e9ecef;
|
|
color: #495057;
|
|
padding: 0.25rem 0.75rem;
|
|
border-radius: 4px;
|
|
}
|
|
.book-isbn {
|
|
color: #6c757d;
|
|
font-family: monospace;
|
|
font-size: 0.8rem;
|
|
}
|
|
.category-header {
|
|
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
|
|
color: white;
|
|
padding: 1.5rem;
|
|
border-radius: 8px;
|
|
margin-bottom: 2rem;
|
|
}
|
|
.category-header h2 {
|
|
font-size: 2rem;
|
|
margin-bottom: 0.5rem;
|
|
}
|
|
</style>
|
|
|
|
<div class="category-header">
|
|
<h2>🗄️ Database Books</h2>
|
|
<p>Deep dive into database systems, design, and data management</p>
|
|
</div>
|
|
|
|
<div class="book-grid">
|
|
{{#each results}}
|
|
{{> book_card}}
|
|
{{/each}}
|
|
</div>
|
|
|
|
{{#unless results}}
|
|
<p style="text-align: center; color: #6c757d; padding: 2rem;">No database books found.</p>
|
|
{{/unless}}
|
|
|
|
{{> footer}}
|
|
|