InputGroup.vue 1.4 KB

1234567891011121314151617181920212223242526272829303132333435
  1. <script setup lang="ts">
  2. import type { HTMLAttributes } from "vue"
  3. import { cn } from '@/Packages/Shadcn/Lib/utils'
  4. const props = defineProps<{
  5. class?: HTMLAttributes["class"]
  6. }>()
  7. </script>
  8. <template>
  9. <div
  10. data-slot="input-group"
  11. role="group"
  12. :class="cn(
  13. 'group/input-group border-input dark:bg-input/30 relative flex w-full items-center rounded-md border shadow-xs transition-[color,box-shadow] outline-none',
  14. 'h-9 min-w-0 has-[>textarea]:h-auto',
  15. // Variants based on alignment.
  16. 'has-[>[data-align=inline-start]]:[&>input]:pl-2',
  17. 'has-[>[data-align=inline-end]]:[&>input]:pr-2',
  18. 'has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3',
  19. 'has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3',
  20. // Focus state.
  21. 'has-[[data-slot=input-group-control]:focus-visible]:border-ring has-[[data-slot=input-group-control]:focus-visible]:ring-ring/50 has-[[data-slot=input-group-control]:focus-visible]:ring-[3px]',
  22. // Error state.
  23. 'has-[[data-slot][aria-invalid=true]]:ring-destructive/20 has-[[data-slot][aria-invalid=true]]:border-destructive dark:has-[[data-slot][aria-invalid=true]]:ring-destructive/40',
  24. props.class,
  25. )"
  26. >
  27. <slot />
  28. </div>
  29. </template>