References

CLI Reference

You can use the Command-Line Interface (CLI) provided by Panda to develop, build, and preview your project from a terminal window.

panda init

Initialize Panda in a project. This process will:

  • Create a panda.config.ts file in your project with the default settings and presets.
  • Emit CSS utilities for your project in the specified output directory.

Flags

--interactive, -i

Whether to run the interactive mode

--force, -f

Whether to overwrite existing files

--postcss, -p

Whether to emit a postcss (opens in a new tab) config file

--config, -c <path>

Path to Panda config file

Related: config

--cwd <dir>

Path to current working direcory

--silent

Whether to suppress all output

--no-gitignore

Whether to update gitignorew with the output directory

--no-codegen

Whether to run the codegen process

--out-extension <ext>

The extension of the generated js files (default: 'mjs')

Related: config.outExtension

--outdir <dir>

The output directory for the generated files

Related: config.outdir

--jsx-framework <framework>

The jsx framework to use

Related: config.jsxFramework

--syntax <syntax>

The css syntax preference

Related: config.syntax

--strict-tokens

Set strictTokens to true

Related: config.strictTokens

--logfile <file>

Outputs logs to a file

Related: Debugging


panda

Run the extract process to generate static CSS from your project.

By default it will scan and generate CSS for the entire project depending on your include and exclude options from your config file.

pnpm panda
# You can also scan a specific file or folder
# using the optional glob argument
pnpm panda src/components/Button.tsx
pnpm panda "./src/components/**"

Flags

--outdir, -o [dir]

The output directory for the generated CSS utilities

Related: config.outdir

--minify, -m

Whether to minify the generated CSS

Related: config.minify

--watch, -w

Whether to watch for changes in the project

Related: config.watch

--poll

Whether to poll for file changes

Related: config.poll

--config, -c <path>

The path to the config file

Related: config

--cwd <path>

The current working directory

Related: config.cwd

--preflight

Whether to emit the preflight or reset CSS

Related: config.preflight

--silent

Whether to suppress all output

Related: config.logLevel

--exclude, -e <files>

Files to exclude from the extract process

Related: config

--clean

Whether to clean the output directory before emitting

Related: config.clean

--hash

Whether to hash the output classnames

Related: config.hash

--lightningcss

Use lightningcss instead of postcss for css optimization.

Related: config.lightningcss

--polyfill

Polyfill CSS @layers at-rules for older browsers.

Related: config.polyfill

--emitTokensOnly

Whether to only emit the tokens directory

Related: config.emitTokensOnly

--cpu-prof

This will generate a panda-{command}-{timestamp}.cpuprofile file in the current working directory, which can be opened in tools like Speedscope (opens in a new tab)

pnpm panda --cpu-prof

Related: Debugging

--logfile <file>

Outputs logs to a file


panda codegen

Generate new CSS utilities for your project based on the configuration file.

Flags

--silent

Whether to suppress all output

Related: config.logLevel

--clean

Whether to clean the output directory before emitting

Related: config.clean

--config, -c <path>

Path to Panda config file

Related: config

--watch, -w

Whether to watch for changes in the project

Related: config.watch

--poll, -p

Whether to poll for file changes

Related: config.poll

--cwd <path>

Current working directory

Related: config.cwd

--cpu-prof

This will generate a panda-{command}-{timestamp}.cpuprofile file in the current working directory, which can be opened in tools like Speedscope (opens in a new tab)

pnpm panda --cpu-prof

Related: Debugging

--logfile <file>

Outputs logs to a file

Related: Debugging

panda cssgen

Generate the CSS from files.

You can use a glob to override the config.include option like this:

panda cssgen "src/**/*.css" --outfile dist.css

or you can use it with a {type} argument to generate only a specific type of CSS:

  • preflight
  • tokens
  • static
  • global
  • keyframes
💡

Note that this only works when passing an --outfile.

You can use it like this:

panda cssgen "static" --outfile dist/static.css

Flags

--outfile, -o <file>

Output file for extracted css, default to './styled-system/styles.css'

--silent

Whether to suppress all output

Related: config.logLevel

--minify, -m

Whether to minify the generated CSS

Related: config.minify

--clean

Whether to clean the output directory before emitting

Related: config.clean

--config, -c <path>

Path to Panda config file

Related: config

--watch, -w

Whether to watch for changes in the project

Related: config.watch

--minimal

Skip generating CSS for theme tokens, preflight, keyframes, static and global css.

This means that the generated CSS will only contain the CSS related to the styles found in the included files.

💡

Note that you can use a glob to override the config.include option like this: panda cssgen "src/**/*.css" --minimal

This is useful when you want to split your CSS into multiple files, for example if you want to split by pages.

Use it like this:

panda cssgen "src/**/pages/*.css" --minimal --outfile dist/pages.css

--poll, -p

Whether to poll for file changes

Related: config.poll

--cwd <path>

Current working directory

Related: config.cwd

--lightningcss

Use lightningcss instead of postcss for css optimization.

Related: config.lightningcss

--polyfill

Polyfill CSS @layers at-rules for older browsers.

Related: config.polyfill

--cpu-prof

This will generate a panda-{command}-{timestamp}.cpuprofile file in the current working directory, which can be opened in tools like Speedscope (opens in a new tab)

pnpm panda --cpu-prof

Related: Debugging

--logfile <file>

Outputs logs to a file

Related: Debugging

panda studio

Realtime documentation for your design tokens.

Flags

--build

Build

--preview

Preview

--port <port>

Use custom port

--host

Expose to custom host

--config, -c <path>

Path to Panda config file

Related: config

--cwd <path>

Current working directory

Related: config.cwd

--outdir <dir>

Output directory for static files

--base <path>

Base path of project

panda analyze

Analyze design token and recipe usage.

By default, it will analyze your project based on the include and exclude config options.

pnpm panda analyze
 
# analyze a specific file
pnpm panda analyze src/components/Button.tsx
 
# analyze a specific glob
pnpm panda analyze "src/components/**"

Flags

--outfile <filepath>

Output analyze report in given JSON filepath

💡

panda analyze --outfile report.json

--silent

Whether to suppress all output

Related: config.logLevel

--config, -c <path>

Path to Panda config file

Related: config

--cwd <path>

Current working directory

Related: config.cwd

panda debug

Debug design token extraction & CSS generated from files in glob.

More details in Debugging docs.

Flags

--silent

Whether to suppress all output

--dry

Output debug files in stdout without writing to disk

--outdir <dir>

Output directory for debug files, defaults to ../styled-system/debug

--only-config

Should only output the config file, default to 'false'

--config, -c <path>

Path to Panda config file

Related: config

--cwd <path>

Current working directory

Related: config.cwd

--cpu-prof

This will generate a panda-{command}-{timestamp}.cpuprofile file in the current working directory, which can be opened in tools like Speedscope (opens in a new tab)

pnpm panda --cpu-prof

Related: Debugging

--logfile <file>

Outputs logs to a file

Related: Debugging

panda ship

Ship extract result from files in glob.

By default it will extract from the entire project depending on your include and exclude options from your config file.

pnpm panda ship
# You can also analyze a specific file or folder
# using the optional glob argument
pnpm panda ship src/components/Button.tsx
pnpm panda ship "./src/components/**"

Flags

--outfile <filepath>

Output path for the JSON build info file, default to './styled-system/panda.buildinfo.json'

💡

panda ship --outfile report.json

--silent

Whether to suppress all output

Related: config.logLevel

--minify, -m

Whether to minify the generated JSON

--config, -c <path>

Path to Panda config file

Related: config

--cwd <path>

Current working directory

Related: config.cwd

--watch, -w

Whether to watch for changes in the project

Related: config.watch

--poll, -p

Whether to poll for file changes

Related: config.poll

panda emit-pkg

Emit package.json with entrypoints, can be used to create a workspace package dedicated to the config.outdir, in combination with config.importMap

Flags

--outdir <dir>

The output directory for the generated CSS utilities

Related: config.outdir

--base <path>

The base directory of the package.json entrypoints

--silent

Whether to suppress all output

Related: config.logLevel

--cwd <path>

Current working directory

Related: config.cwd