You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
20 lines
600 B
JavaScript
20 lines
600 B
JavaScript
import { normalizeScreens } from '../util/normalizeScreens'
|
|
import buildMediaQuery from '../util/buildMediaQuery'
|
|
|
|
export default function ({ tailwindConfig: { theme } }) {
|
|
return function (css) {
|
|
css.walkAtRules('screen', (atRule) => {
|
|
let screen = atRule.params
|
|
let screens = normalizeScreens(theme.screens)
|
|
let screenDefinition = screens.find(({ name }) => name === screen)
|
|
|
|
if (!screenDefinition) {
|
|
throw atRule.error(`No \`${screen}\` screen found.`)
|
|
}
|
|
|
|
atRule.name = 'media'
|
|
atRule.params = buildMediaQuery(screenDefinition)
|
|
})
|
|
}
|
|
}
|