Fix colors, replace Dropdown with Select, add clear layout

This commit is contained in:
2025-11-06 00:31:47 +05:00
parent 73a3be7539
commit 86b41eb5e0
51 changed files with 1248 additions and 164 deletions

View File

@ -0,0 +1,29 @@
<script setup lang="ts">
import type { PrimitiveProps } from "reka-ui"
import type { HTMLAttributes } from "vue"
import type { FrameVariants } from "."
import { cn } from "@/lib/utils"
import { frameVariants } from "."
interface Props extends PrimitiveProps {
border?: FrameVariants["border"]
borderRadius?: FrameVariants["borderRadius"]
borderPlacement?: FrameVariants["borderPlacement"]
background?: FrameVariants["background"]
padding?: FrameVariants["padding"]
margin?: FrameVariants["margin"]
class?: HTMLAttributes["class"]
}
const props = withDefaults(defineProps<Props>(), {
as: "frame",
})
</script>
<template>
<div :as="as" :as-child="asChild"
:class="cn(frameVariants({ 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 Frame } from "./Frame.vue"
export const frameVariants = 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 FrameVariants = VariantProps<typeof frameVariants>