warden 0.9.0
warden: ^0.9.0 copied to clipboard
Static Builder CLI

Static builder & bundler for Dart projects. Inspired by Webpack.
Warden is a lightweight CLI tool to watch and compile Dart and Sass files for frontend projects that donβt use Flutter, are focused on building to JavaScript for server-side rendered apps, and work with Node-installed packages. Itβs ideal for projects that still want custom JS/CSS assets compiled automatically.
π Docs: pub.dev/packages/warden
β¨ Features #
- π Watches your Dart and Sass files and recompiles on change
- π¦ Moves specified dependencies (e.g. node_modules assets) into your build output
- ποΈ Moves specified asset directories (e.g.
assets/img/
) into your build output - π οΈ Bundles your dependency JS files into a single
bundle.js
(optional) - π§± Fully configurable via a
warden.yaml
file - π― Supports multiple tasks like compiling Dart to JS and Sass to CSS
- π§ͺ Debug mode logging to see every file operation and build step
- π Production mode for optimised builds with minified output
#
π¦ Installation #
dart pub global activate warden
Then run:
warden --file=warden.yaml
βΆοΈ Running #
Run Warden in watch mode:
warden --watch
# Or define the file path is not in the project root.
warden --file=warden.yaml --watch
Or for a one-off build:
warden --build
# Or define the file path is not in the project root.
warden --file=warden.yaml --build
Debug mode (development) will show verbose file change and build logs.
Switch to production to build optimised/minified JS and CSS.
dart run warden --file=warden.yaml --watch --debug
βοΈ Setup #
Create a warden.yaml
in your project root:
# ==============================
# Warden Configuration
# ==============================
# The root directory of your source files
source_dir: example
# The environment mode to run in (choose 'development' or 'production')
# π§ͺ development β Local dev settings, debug logging enabled
# π production β Live site settings, minified builds
mode: development # Default is development
# Where to output built files (JavaScript, CSS, etc.)
destination: example/static/
# Main Dart-built JS file (output location)
main_file: example/static/main.js
# ==============================
# Dependencies
# ==============================
dependencies:
- source: example/node_modules
bundle: true
files:
- "poppyjs/dist/Poppy.min.js"
- "bootstrap/dist/js/bootstrap.min.js"
- "bootstrap/scss/bootstrap.scss"
# ==============================
# Static Assets
# ==============================
assets:
source: example/assets
directories:
- img # Copies `example/assets/img` β `example/static/img`
# ==============================
# Build Tasks
# ==============================
tasks:
frontend:
executable: dart
args: ["compile", "js", "bin/main.dart", "-O4", "-o", "static/main.js"]
src: example
styles:
executable: dart
args: ["run", "sass", "sass/index.scss:static/index.css"]
src: example
warnings: false
# ==============================
# Environment Variables
# These are injected at compile time for Dart
# ==============================
environment:
dev:
API_URL: "http://localhost:1234/api/v1"
CAT_TYPE: "siberian"
DEBUG_MODE: "true"
prod:
API_URL: "https://www.google.com"
DEBUG_MODE: "false"
π§ͺ Example Project Structure #
examples/
βββ bin/
β βββ main.dart
βββ lib/
β βββ examples.dart
βββ sass/
β βββ index.scss
βββ node_modules/
βββ warden.yaml
Contributions
Please open an issue or reply to an existing issue requesting that you would like
to work on it. PRs that do not fix a known bug or add new features will be closed.
License
MIT Β© 2025 joegasewicz