UNPKG

@fluent-windows/core

Version:

React components that inspired by Microsoft's Fluent Design System.

93 lines (89 loc) 4.56 kB
import { space, color, typography, layout, background, border, position, shadow, flexbox, grid, compose, breakpoints, themeGet } from '@fluent-windows/styles'; const base = { '-webkit-overflow-scrolling': 'touch' }; const mosaic = ''; const breakpoint = theme => breakpoints({ sm: { '&::-webkit-scrollbar': { width: 8, background: 'transparent' }, '&::-webkit-scrollbar-thumb': { borderRadius: 8, backgroundColor: themeGet(`colors.standard.transparent2`, 'rgba(0, 0, 0, 0.2)')(theme), '&:hover': { backgroundColor: themeGet(`colors.standard.transparent3`, 'rgba(0, 0, 0, 0.4)')(theme) } } } })(theme); const system = compose(space, color, typography, layout, background, border, position, shadow, flexbox, grid); const acrylic = theme => props => { const bg = props.backgroundColor || props.background || props.bg; const themeBg = themeGet(`colors.${bg}`, bg)(theme); return { position: 'relative', overflow: 'hidden', '@supports ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px)))': { background: 'none !important', backdropFilter: 'blur(10px)', '&::before, &::after': { content: `''`, position: 'absolute', left: 0, right: 0, top: 0, bottom: 0, width: '100%', height: '100%' }, '&::before': { zIndex: -2, opacity: 0.5, background: themeBg }, '&::after': { zIndex: -1, opacity: 0.25, backgroundImage: `url(${mosaic})` } }, '@supports (not ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))))': { background: 'inherit', zIndex: 1, '&::before': { background: 'inherit', filter: 'blur(10px)', content: `''`, position: 'absolute', left: -10, top: -10, width: 'calc(100% + 20px)', height: 'calc(100% + 20px)', zIndex: -1 }, '&::after': { content: `''`, position: 'absolute', left: 0, top: 0, right: 0, bottom: 0, width: '100%', height: '100%', zIndex: -1, opacity: 0.5, backgroundColor: themeBg, backgroundImage: `url(${mosaic})` } } }; }; export const styles = theme => ({ root: { ...base, ...breakpoint(theme) }, system, acrylic: acrylic(theme) });