Guides
Minimal Setup
The default Panda setup includes utilities and design tokens by default. In this guide, you'll see how to strip out the defaults and start from scratch.
Removing default tokens
To remove the default design tokens injected by Panda, set the presets
key to an empty array:
export default defineConfig({
// ...
presets: []
})
This allows you to define your own tokens, without having to use the extend
key in the theme.
export default defineConfig({
// ...
theme: {
tokens: {
colors: {
primary: { value: '#ff0000' }
}
}
}
})
Removing default utilities
Use the eject: true
property to remove all the default utilities.
Panda doesn't automatically know which tokens are valid for which CSS properties, so it is necessary to tell Panda that my tokens from the "colors" category are valid for the CSS property "color". This is what utilities do.
export default defineConfig({
// ...
utilities: {
color: {
values: 'colors'
}
},
theme: {
tokens: {
colors: {
primary: { value: '#ff0000' }
}
}
}
})
This makes <p className={css({ color: 'primary' })}> Text </p>
work as expected.
Re-using Panda presets
Panda offers 2 presets:
@pandacss/preset-base
: This is a relatively unopinionated set of utilities for mapping CSS properties to values (almost everyone will want these)
You can use these presets by installing them via npm and adding them to your presets
key:
export default defineConfig({
// ...
presets: ['@pandacss/preset-base']
})
@pandacss/preset-panda
as an opinionated set of tokens if you don't want to define your own colors/spacing/fonts etc.
export default defineConfig({
// ...
presets: ['@pandacss/preset-panda']
})
Note: You don't need to install @pandacss/preset-base
or @pandacss/preset-panda
. Panda will automatically resolve them for you.