update navbar style

This commit is contained in:
Amro Alfien 2024-11-15 15:02:52 +07:00
parent 02096d66a4
commit ec51d488ed
9 changed files with 100 additions and 41 deletions

View File

@ -8,6 +8,11 @@ static = [
{ {
"route" :"/css/<filepath:re:.*\.(css|sass|css.map)>", "route" :"/css/<filepath:re:.*\.(css|sass|css.map)>",
"root" :"./static/css" "root" :"./static/css"
},
# add javascript route
{
"route" :"/js/<filepath:re:.*\.(js)>",
"root" :"./static/js"
} }
] ]
template.add(static, "templates") template.add(static, "templates")

View File

@ -1,4 +1,4 @@
title = "CostaPy" title = "CostaCoffe"
menu = { menu = {
"public": { "public": {
@ -8,6 +8,18 @@ menu = {
"target":"_self", "target":"_self",
"href":"/", "href":"/",
"roles":["guest"] "roles":["guest"]
},
{
"name":"Our Product",
"target":"_self",
"href":"/product",
"roles":["guest"]
},
{
"name":"Blog",
"target":"_self",
"href":"/blog",
"roles":["guest"]
}, },
{ {
"name":"About", "name":"About",
@ -16,13 +28,13 @@ menu = {
"roles":["guest"] "roles":["guest"]
}, },
{ {
"name":"Docs", "name":"Contact",
"target":"_blank", "target":"_self",
"href":"https://costapy.ditaajipratama.net", "href":"/contact",
"roles":["guest"] "roles":["guest"]
} }
] ]
} }
} }
copyright = "Copyright (C) 2022 Dita Aji Pratama" copyright = "Copyright (C) 2024 Amro Alfien S.N"

View File

@ -1,8 +1,8 @@
host = "localhost" host = "localhost"
port = 11000 port = 11000
reloader = False reloader = True
debug = False debug = False
server = 'gunicorn' # default = 'wsgiref' server = 'wsgiref' # default = 'wsgiref'
session_opts = { session_opts = {
'session.type': 'file', 'session.type': 'file',

View File

@ -9,8 +9,10 @@ class main:
def html(self, params): def html(self, params):
return Template(params["mako"]["website"]['index']).render( return Template(params["mako"]["website"]['index']).render(
title = globalvar.title, title = globalvar.title,
header = "Welcome to CostaPy", header = "Welcome to CostaCoffe",
sub_header = "Best Place To Buy Coffe",
navbar = Template(params["mako"]["website"]['navbar']).render( navbar = Template(params["mako"]["website"]['navbar']).render(
title = globalvar.title,
menu = globalvar.menu['public']['navbar'], menu = globalvar.menu['public']['navbar'],
user_roles = ["guest"], user_roles = ["guest"],
active_page = "Home" active_page = "Home"

View File

@ -1 +0,0 @@
/* your style here */

13
static/js/feather.min.js vendored Normal file

File diff suppressed because one or more lines are too long

View File

@ -1,20 +1,30 @@
<!DOCTYPE html> <!DOCTYPE html>
<html> <html>
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>${title}</title> <title>${title}</title>
<link rel="stylesheet" href="/templates/plain/css/style.css"> <link rel="stylesheet" href="/templates/plain/css/style.css">
<!-- <link rel="stylesheet" href="/css/index.sass"> -->
<script src="/js/feather.min.js"></script>
</head> </head>
<body> <body>
${navbar}
<header> <header>
<h1>${header}</h1> <h1>${header}</h1>
</header> </header>
${navbar}
<main> <main>
${container} ${container}
</main> </main>
${footer} ${footer}
</body> </body>
</html> </html>
<script>
feather.replace();
</script>

View File

@ -1,4 +1,6 @@
<nav class="navbar"> <nav class="navbar">
<h2>${title}</h2>
<div class="nav-links">
% for item in menu: % for item in menu:
% if any(role in item['roles'] for role in user_roles): % if any(role in item['roles'] for role in user_roles):
<a class="${'active' if item['name'] == active_page else ''}" href="${item['href']}" target="${item['target']}"> <a class="${'active' if item['name'] == active_page else ''}" href="${item['href']}" target="${item['target']}">
@ -6,4 +8,8 @@
</a> </a>
% endif % endif
% endfor % endfor
</div>
<div class="nav-menu-icons">
<i data-feather="shopping-cart"></i>
</div>
</nav> </nav>

View File

@ -2,8 +2,6 @@ body {
font-family: "Arial", sans-serif; font-family: "Arial", sans-serif;
margin: 0; margin: 0;
padding: 0; padding: 0;
color: #333;
background-color: #f4f4f4;
} }
header { header {
@ -15,26 +13,40 @@ header {
.navbar { .navbar {
display: flex; display: flex;
background-color: #333; justify-content: space-between;
justify-content: center; align-items: center;
padding: 10px; padding: 1rem 3.2rem;
} }
.navbar a { .navbar .nav-links {
color: #fff; display: flex;
padding: 14px 20px; gap: 32px;
text-decoration: none;
text-align: center;
} }
.navbar a:hover { .navbar .nav-links a {
background-color: #ddd; display: inline-block;
position: relative;
padding: 0.4rem;
font-size: 1.1rem;
color: #000; color: #000;
text-decoration: none;
} }
.navbar a.active { .navbar .nav-links a::after {
background-color: #4CAF50; content: "";
color: #fff; position: absolute;
bottom: -5px;
left: 0;
right: 0;
margin: 0 auto;
width: 0;
height: 2px;
background-color: black;
transition: all 0.3s ease-in-out;
}
.navbar .nav-links a:is(:hover, .active)::after {
width: 40%;
} }
main { main {