A plugin to provide UnoCSS CSS utilities for named grid areas.
# Using npm
npm install unocss-preset-grid-areas --save-dev
# Using yarn
yarn add unocss-preset-grid-areas -D
# Using pnpm
pnpm add unocss-preset-grid-areas -D
Import plugin in your unocss.config.(js|ts) file, and define your template areas, along with any row/column specifications:
// unocss.config.(js|ts)
import { defineConfig } from 'unocss'
import { presetGridAreas } from 'unocss-preset-grid-areas'
export default defineConfig({
presets: [
presetUno(),
// ...
presetGridAreas({
gridTemplateAreas: {
'layout': [
'header header header',
'nav main main',
'nav footer footer',
],
},
gridTemplateColumns: {
'layout': '24rem 1fr 2rem',
},
gridTemplateRows: {
'layout': '6rem 3rem 1fr auto',
},
})
]
})
This will generate the following utilities:
grid-areas-layout
grid-in-footer
grid-in-header
grid-in-main
grid-in-nav
col-start-footer
col-start-header
col-start-main
col-start-nav
col-end-footer
col-end-header
col-end-main
col-start-nav
row-start-footer
row-start-header
row-start-main
row-start-nav
row-end-footer
row-end-header
row-end-main
row-end-nav
<body class="grid grid-areas-layout grid-cols-layout grid-rows-layout h-full">
<header class="grid-in-header"></header>
<nav class="grid-in-nav"></nav>
<main class="grid-in-main"></main>
<footer class="grid-in-footer"></footer>
</body>
Note If used with UnoPreset or other similar preset, call
presetGridAreas()
at the bottom
- .grid-areas-none
- .grid-areas-inherit
- .grid-areas-initial
- .grid-areas-revert
- .grid-areas-revert-layer
- .grid-areas-unset
- .grid-in-auto
- .grid-in-inherit
- .grid-in-initial
- .grid-in-revert
- .grid-in-revert-layer
- .grid-in-unset
export interface GridOptions {
gridTemplateAreas: {
[key: string]: string[];
};
gridTemplateColumns: {
[key: string]: string;
};
gridTemplateRows: {
[key: string]: string;
};
}
Currently partial supported. But PR welcome :)