Shadows
EUI provides 5 shadow sizes (xs, s, m, l, xl) that can be applied in two directions: down (default) and up.
The provided EUI shadow utilities use the underlying theme shadow tokens and automatically add required adjustments for dark mode and high contrast mode that ensure expected visibility.
Never use the underlying shadow tokens separately
Always use the shadow utilities to ensure proper styling.
These shadow utilities handle the following additional style adjustments:
- adds a light, 4-sidedborderstyle in Dark mode to increase elevated item visibility
- replaces thebox-shadowin High Contrast mode withborderto ensure visibility in high contrast themes
Usage
ts code block:import { euiShadow } from '@elastic/eui'; const styles = css` ${euiShadow(euiThemeContext, 's')}; ${euiShadow(euiThemeContext, 's', { direction: 'down' })}; `;
Direction: down
| Sample | Utility | Style output | 
|---|---|---|
| euiShadow(euiThemeContext, 'xs', { direction: 'down' }) | euiShadow(euiThemeContext, 'xs', { direction: 'down' }) | Style output 
 | 
| euiShadow(euiThemeContext, 's', { direction: 'down' }) | euiShadow(euiThemeContext, 's', { direction: 'down' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'm', { direction: 'down' }) | euiShadow(euiThemeContext, 'm', { direction: 'down' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'l', { direction: 'down' }) | euiShadow(euiThemeContext, 'l', { direction: 'down' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'xl', { direction: 'down' }) | euiShadow(euiThemeContext, 'xl', { direction: 'down' }) | Style output 
 | 
| euiShadowFlat(euiThemeContext, { direction: 'down' })) | euiShadowFlat(euiThemeContext, { direction: 'down' })) | Style output 
 | 
Direction: up
| Sample | Utility | Style output | 
|---|---|---|
| euiShadow(euiThemeContext, 'xs', { direction: 'up' }) | euiShadow(euiThemeContext, 'xs', { direction: 'up' }) | Style output 
 | 
| euiShadow(euiThemeContext, 's', { direction: 'up' }) | euiShadow(euiThemeContext, 's', { direction: 'up' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'm', { direction: 'up' }) | euiShadow(euiThemeContext, 'm', { direction: 'up' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'l', { direction: 'up' }) | euiShadow(euiThemeContext, 'l', { direction: 'up' }) | Style output 
 | 
| euiShadow(euiThemeContext, 'xl', { direction: 'up' }) | euiShadow(euiThemeContext, 'xl', { direction: 'up' }) | Style output 
 | 
| euiShadowFlat(euiThemeContext, { direction: 'up' })) | euiShadowFlat(euiThemeContext, { direction: 'up' })) | Style output 
 | 
Dark mode floating border customization
By default the shadow utilities add a light, 4-sided border style in Dark mode. In some cases where different shadowed elements are being composed together,
this might result in duplicate neighboring borders. To adjust this, use the border option on the euiShadow utility to adjust or remove the border output.
The additional border is only applied and visible in dark mode.
ts code block:import { euiShadow } from '@elastic/eui'; const styles = css` ${euiShadow(euiThemeContext, 's', { border: 'none'})} ${euiShadow(euiThemeContext, 's', { border: 'all'})} ${euiShadow(euiThemeContext, 's', { border: 'top'})} ${euiShadow(euiThemeContext, 's', { border: 'bottom'})} ${euiShadow(euiThemeContext, 's', { border: 'left'})} ${euiShadow(euiThemeContext, 's', { border: 'right'})} ${euiShadow(euiThemeContext, 's', { border: 'horizontal'})} ${euiShadow(euiThemeContext, 's', { border: 'vertical'})} `;
Scroll behavior
Do not combine shadow utils and scroll behavior styles on the same element
Combining EUI shadow utils like euiShadow() and scroll behavior (e.g. via overflow: scroll or overflow: auto) on the same element will cause the floating border
in DARK mode to be scrolled. If you want to combine both, separate the styles onto different elements by placing the shadow util on the outer wrapper and the scroll
behavior on the inner one.
ts code block:import { euiShadow } from '@elastic/eui'; import { css } from '@emotion/react'; const Component = () => { const euiThemeContext = useEuiTheme(); const shadowStyles = css` ${euiShadow(euiThemeContext, 's')}; `; const scrollContainerStyles = css` max-height: 100px; overflow-y: auto; /* specific scroll bar styling */ ${useEuiScrollBar()}; `; return ( <div css={shadowStyles}> <div css={scrollContainerStyles}> // scrollable content </div> </div> ); }
Hover states
Each shadowed surface, when interactive, follows the same hover effect rule: it moves up one level.
- xshovered →- s
- shovered →- m
- mhovered →- l
- lhovered →- xl
- xlhovered →- hover.xl
You don't need to remember this rule though. You can instead use the available euiShadowHover utility which
applies the expected hover shadow based on the base size.