website-mcknight-tech/site_mcknight_tech/__main__.py

71 lines
2.2 KiB
Python
Raw Normal View History

# Copyright (C) 2025 Daniel McKnight - All Rights Reserved
2025-01-30 20:05:16 -08:00
from os.path import isfile, join, dirname
2025-01-30 20:05:16 -08:00
from nicegui import ui
# TODO: Read from configuration
2025-01-30 20:05:16 -08:00
_tab_to_content = {
"Home": "page_content/home.md",
"Portfolio": "page_content/portfolio.md",
"Resume": "page_content/resume.md",
"Bio": "page_content/bio.md"
}
_error_page = "page_content/404.md"
_footer_block = "page_content/footer.html"
2025-01-30 20:05:16 -08:00
def _get_content_from_file(file_name: str) -> str:
"""
Take a file name/path and return its contents
:param file_name: Relative or absolute path to a file
"""
file_name = join(dirname(__file__), file_name)
if not isfile(file_name):
2025-01-30 20:05:16 -08:00
file_name = _error_page
with open(file_name, 'r') as f:
2025-01-30 20:05:16 -08:00
return f.read()
2025-02-04 20:41:41 -08:00
2025-01-30 20:05:16 -08:00
def render_tab(tab_name: str):
2025-02-04 20:41:41 -08:00
"""
Render a simple webpage tab from a single file
:param tab_name: Tab name to render
"""
2025-01-30 20:05:16 -08:00
file_name = _tab_to_content.get(tab_name, _error_page)
with ui.scroll_area().classes('w-full h-screen no-wrap'):
2025-02-04 20:41:41 -08:00
ui.markdown(_get_content_from_file(file_name),
extras=['cuddled-lists', 'fenced-code-blocks', 'tables'])
2025-01-30 20:05:16 -08:00
def render_main() -> ui.tab_panels:
2025-01-30 20:05:16 -08:00
"""
Render sticky page header with navigation
"""
tab_names = _tab_to_content.keys()
with ui.tabs().classes('w-full') as tabs:
tab_list = {name: ui.tab(name) for name in tab_names}
with ui.tab_panels(tabs).classes('w-full h-screen no-wrap') as header:
for name, t in tab_list.items():
2025-01-30 20:05:16 -08:00
with ui.tab_panel(t):
render_tab(name)
2025-01-30 20:05:16 -08:00
return header
def main():
header = render_main()
2025-01-30 20:05:16 -08:00
header.set_value(list(_tab_to_content.keys())[0])
ui.query('.nicegui-content').classes('h-screen no-wrap')
ui.html(_get_content_from_file(_footer_block), tag="footer").classes("rounded-lg shadow-sm m-4 w-full text-center")
2025-02-04 20:41:41 -08:00
ui.add_css("""
.fa {
font-size: 30px;
text-decoration: none;
margin: 10px 5px;
vertical-align: bottom;
}
""")
2025-01-31 22:28:45 -08:00
ui.run(dark=None, reload=False, title="Daniel McKnight")
if __name__ == "__main__":
main()