File size: 5,500 Bytes
617a965 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 | class CustomSidebar extends HTMLElement {
connectedCallback() {
this.attachShadow({ mode: 'open' });
this.shadowRoot.innerHTML = `
<style>
.sidebar {
width: 250px;
transition: all 0.3s ease;
position: sticky;
top: 0;
height: calc(100vh - 4rem);
}
@media (max-width: 768px) {
.sidebar {
width: 0;
overflow: hidden;
}
.sidebar.open {
width: 250px;
}
}
.sidebar-link {
transition: all 0.2s ease;
}
.sidebar-link:hover {
background-color: #e2e8f0;
transform: translateX(4px);
}
.sidebar-link.active {
background-color: #e2e8f0;
border-left: 4px solid #4f46e5;
}
.mobile-sidebar-toggle {
display: none;
}
@media (max-width: 768px) {
.mobile-sidebar-toggle {
display: block;
position: fixed;
bottom: 20px;
left: 20px;
z-index: 40;
}
}
</style>
<div class="sidebar bg-white border-r border-gray-200 p-4 hidden md:block">
<div class="space-y-4">
<div class="px-3 py-2">
<h3 class="text-xs font-semibold text-gray-500 uppercase tracking-wider">
Menu Principal
</h3>
</div>
<nav class="space-y-1">
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700 active">
<i data-feather="home" class="mr-3 text-gray-500"></i>
Dashboard
</a>
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="upload" class="mr-3 text-gray-500"></i>
Importar Dados
</a>
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="bar-chart-2" class="mr-3 text-gray-500"></i>
Relatórios
</a>
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="settings" class="mr-3 text-gray-500"></i>
Configurações
</a>
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="help-circle" class="mr-3 text-gray-500"></i>
Ajuda
</a>
</nav>
<div class="px-3 py-2 mt-8">
<h3 class="text-xs font-semibold text-gray-500 uppercase tracking-wider">
Ferramentas
</h3>
</div>
<nav class="space-y-1">
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="calculator" class="mr-3 text-gray-500"></i>
Calculadora
</a>
<a href="#" class="sidebar-link flex items-center px-3 py-2 text-sm font-medium rounded-md text-gray-700">
<i data-feather="columns" class="mr-3 text-gray-500"></i>
Conversor
</a>
</nav>
</div>
</div>
<!-- Mobile sidebar toggle (only visible on mobile) -->
<button class="mobile-sidebar-toggle md:hidden bg-indigo-600 text-white p-3 rounded-full shadow-lg focus:outline-none">
<i data-feather="menu"></i>
</button>
<script>
feather.replace();
// Mobile sidebar toggle
const mobileToggle = this.shadowRoot.querySelector('.mobile-sidebar-toggle');
const sidebar = this.shadowRoot.querySelector('.sidebar');
mobileToggle.addEventListener('click', () => {
sidebar.classList.toggle('open');
});
</script>
`;
}
}
customElements.define('custom-sidebar', CustomSidebar); |