mirror of
https://github.com/sysadminsmedia/homebox.git
synced 2025-12-21 21:33:02 +01:00
* feat: add shadcn * feat: add themes * feat: make sidebar use shadcn * feat: sort bg * feat: lint fixes * feat: make daisyui toggleable, add tooltips to sidebar, add work in progress docs page * fix: theme switching for shadcn * Fix minor profile.vue issue * feat: update docs, enlarge SidebarMenuButton and refine profile layout * feat: add testing page * feat: update css and remove comments from template * fix: create dropdown not opening due to tooltip interference also lint * fix: correct CSS selector for homebox in main.css to ensure proper theming functionality * feat: make theme switching actually kinda work for shadcn * fix: sidebar colours * fix: remove unused router import, made sidebar indicate active page and sort tailwind config linting * style: update styles * chore: remove unused duplicate code * style: refine theme management, CSS variables, get styles closer to original * feat: implement suggested changes * feat: better button size --------- Co-authored-by: Matt Kilgore <tankerkiller125@users.noreply.github.com>
27 lines
767 B
Vue
27 lines
767 B
Vue
<script setup lang="ts">
|
|
import { computed, type HTMLAttributes } from "vue";
|
|
import { Skeleton } from "@/components/ui/skeleton";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
const props = defineProps<{
|
|
showIcon?: boolean;
|
|
class?: HTMLAttributes["class"];
|
|
}>();
|
|
|
|
const width = computed(() => {
|
|
return `${Math.floor(Math.random() * 40) + 50}%`;
|
|
});
|
|
</script>
|
|
|
|
<template>
|
|
<div data-sidebar="menu-skeleton" :class="cn('rounded-md h-8 flex gap-2 px-2 items-center', props.class)">
|
|
<Skeleton v-if="showIcon" class="size-4 rounded-md" data-sidebar="menu-skeleton-icon" />
|
|
|
|
<Skeleton
|
|
class="h-4 max-w-[--skeleton-width] flex-1"
|
|
data-sidebar="menu-skeleton-text"
|
|
:style="{ '--skeleton-width': width }"
|
|
/>
|
|
</div>
|
|
</template>
|