Files
anyame-frontend-vue/app/components/ui/frame/Frame.vue

30 lines
855 B
Vue

<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>