frontend/app/components/ui/form/FormItem.vue

20 lines
466 B
Vue
Raw Normal View History

<script lang="ts" setup>
import { useId } from "reka-ui";
import { type HTMLAttributes, provide } from "vue";
2025-06-26 22:39:02 +02:00
import { cn } from "@/lib/utils";
import { FORM_ITEM_INJECTION_KEY } from "./injectionKeys";
const props = defineProps<{
class?: HTMLAttributes["class"];
}>();
const id = useId();
provide(FORM_ITEM_INJECTION_KEY, id);
</script>
<template>
2025-12-09 22:32:22 +01:00
<div data-slot="form-item" :class="cn('grid gap-2', props.class)">
<slot/>
</div>
</template>