Files
herolib/lib/web/ui/utils.v
Mahmoud-Emad 68dd957421 feat: add modular web UI features
- Enable `web` command to start UI server
- Centralize web server setup and static serving
- Implement modular UI for chat and script editor
- Refactor Heroprompt UI into its own module
- Introduce dynamic theme switching and mobile menu
2025-08-21 18:28:17 +03:00

56 lines
1.5 KiB
V

module ui
import os
// Recursive menu renderer
pub fn menu_html(items []MenuItem, depth int, prefix string) string {
mut out := []string{}
for i, it in items {
id := '${prefix}_${depth}_${i}'
if it.children.len > 0 {
// expandable group
out << '<div class="item">'
out << '<a class="list-group-item list-group-item-action d-flex justify-content-between align-items-center" data-bs-toggle="collapse" href="#${id}" role="button" aria-expanded="${if depth == 0 {
'true'
} else {
'false'
}}" aria-controls="${id}">'
out << '<span>${it.title}</span><span class="chev">&rsaquo;</span>'
out << '</a>'
out << '<div class="collapse ${if depth == 0 { 'show' } else { '' }}" id="${id}">'
out << '<div class="ms-2 mt-1">'
out << menu_html(it.children, depth + 1, id)
out << '</div>'
out << '</div>'
out << '</div>'
} else {
// leaf
out << '<a href="${it.href}" class="list-group-item list-group-item-action">${it.title}</a>'
}
}
return out.join('\n')
}
// Language detection utility for code files
pub fn detect_lang(path string) string {
ext := os.file_ext(path).trim_left('.')
return match ext.to_lower() {
'v' { 'v' }
'js' { 'javascript' }
'ts' { 'typescript' }
'py' { 'python' }
'rs' { 'rust' }
'go' { 'go' }
'java' { 'java' }
'c', 'h' { 'c' }
'cpp', 'hpp', 'cc', 'hh' { 'cpp' }
'sh', 'bash' { 'bash' }
'json' { 'json' }
'yaml', 'yml' { 'yaml' }
'html', 'htm' { 'html' }
'css' { 'css' }
'md' { 'markdown' }
else { 'text' }
}
}