Initial codebase commit

This commit is contained in:
2025-10-31 04:44:30 +05:00
commit 73a3be7539
69 changed files with 3812 additions and 0 deletions

View File

@@ -0,0 +1,29 @@
<script setup lang="ts">
import type { PrimitiveProps } from "reka-ui"
import type { HTMLAttributes } from "vue"
import type { ContainerVariants } from "."
import { cn } from "@/lib/utils"
import { containerVariants } from "."
interface Props extends PrimitiveProps {
border?: ContainerVariants["border"]
borderRadius?: ContainerVariants["borderRadius"]
borderPlacement?: ContainerVariants["borderPlacement"]
background?: ContainerVariants["background"]
padding?: ContainerVariants["padding"]
margin?: ContainerVariants["margin"]
class?: HTMLAttributes["class"]
}
const props = withDefaults(defineProps<Props>(), {
as: "container",
})
</script>
<template>
<div :as="as" :as-child="asChild"
:class="cn(containerVariants({ border, borderRadius, borderPlacement, background, padding, margin }), props.class)">
<slot />
</div>
</template>

View File

@@ -0,0 +1,59 @@
import type { VariantProps } from "class-variance-authority"
import { cva } from "class-variance-authority"
export { default as Container } from "./Container.vue"
export const containerVariants = cva(
"border-solid",
{
variants: {
border: {
default: "border-border",
input: "border-input",
},
borderRadius: {
default: "rounded-md",
round: "rounded-2xl",
circle: "rounded-full",
none: "",
},
borderPlacement: {
default: "border-2",
bottom: "border-b-2",
left: "border-l-2",
right: "border-r-2",
top: "border-t-2",
},
background: {
default: "bg-background",
muted: "bg-muted",
primary: "bg-primary"
},
padding: {
default: "p-8",
loose: "p-12",
dense: "p-3",
none: "",
},
margin: {
default: "m-12",
dense: "m-8",
none: "",
},
},
defaultVariants: {
border: "default",
borderRadius: "default",
borderPlacement: "default",
background: "default",
padding: "default",
margin: "default",
},
},
)
export type ContainerVariants = VariantProps<typeof containerVariants>