Config Provider
- Enables all primitives to inherit global reading direction.
- Enables changing the behavior of scroll body when setting body lock.
- Much more controls to prevent layout shifts.
Anatomy
Import the component.
<script setup lang="ts">
import { ConfigProvider } from 'reka-ui'
</script>
<template>
<ConfigProvider>
<slot />
</ConfigProvider>
</template>
API Reference
Config Provider
When creating localized apps that require right-to-left (RTL) reading direction, you need to wrap your application with the ConfigProvider
component to ensure all of the primitives adjust their behavior based on the dir
prop.
You can also change the global behavior of bodylock
for components such as Alert
, DropdownMenu
and etc to fit your layout to prevent any content shifts.
Prop | Default | Type |
---|---|---|
dir | 'ltr' | 'ltr' | 'rtl' The global reading direction of your application. This will be inherited by all primitives. |
locale | 'en' | string The global locale of your application. This will be inherited by all primitives. |
nonce | string The global | |
scrollBody | true | boolean | ScrollBodyOption The global scroll body behavior of your application. This will be inherited by the related primitives. |
useId | (() => string) The global |
Methods | Type |
---|---|
useId | () => string The global |
Example
Use the config provider.
Set global direction to rtl
, and scroll body behavior to false
(will not set any padding/margin).
<script setup lang="ts">
import { ConfigProvider } from 'reka-ui'
</script>
<template>
<ConfigProvider
dir="rtl"
:scroll-body="false"
>
<slot />
</ConfigProvider>
</template>
Hydration issue (Vue < 3.5)
We expose a temporary workaround to allow current Nuxt (with version >3.10) project fix the current hydration issue by using useId
provided by Nuxt.
Inspired by Headless UI
<!-- in Nuxt's app.vue -->
<script setup lang="ts">
import { ConfigProvider } from 'reka-ui'
const useIdFunction = () => useId()
</script>
<template>
<ConfigProvider :use-id="useIdFunction">
…
</ConfigProvider>
</template>