Output
Brisa, offers versatile output configuration options to tailor your build output according to your deployment needs. The output
configuration property in brisa.config.ts
allows you to define the type of output you desire, with options such as bun
, node
, deno
, static
, desktop
, android
and ios
.
Understanding Output Types
1. Bun.js Server Output (bun
)
The bun
output type generates a deployable server that can be hosted on a server infrastructure (Bun runtime). This is the default output type. To utilize this output type in your Brisa project, ensure that your brisa.config.ts
file includes the following:
import type { Configuration } from "brisa";
export default {
// "bun" is the default value when this configuration is not set
output: "bun",
} satisfies Configuration;
It is recommended to use the
bun
output type to leverage the complete set of features Brisa provides, enhancing your project with middleware capabilities, API endpoints, web sockets, and server-specific functionalities.
2. Node.js Server Output (node
)
The node
output type is designed for creating deployable Node.js applications. To configure your Brisa project for Node.js server output, adjust your brisa.config.ts
as follows:
import type { Configuration } from "brisa";
export default {
output: "node",
} satisfies Configuration;
You can use specific Bun.js features only related with building the application, like Macros, but not runtime features like
bun:ffi
, for that you need to find the equivalent in Node.js.
2. Deno Server Output (deno
)
The deno
output type is designed for creating deployable Deno applications. To configure your Brisa project for Deno server output, adjust your brisa.config.ts
as follows:
import type { Configuration } from "brisa";
export default {
output: "deno",
} satisfies Configuration;
You can use specific Bun.js features only related with building the application, like Macros, but not runtime features like
bun:ffi
, for that you need to find the equivalent in Deno.
3. Static Output (static
)
The static
output type creates a static export suitable for deployment to static hosting services. To configure your Brisa project for static output, adjust your brisa.config.ts
as follows:
import type { Configuration } from "brisa";
export default {
output: "static",
} satisfies Configuration;
Pure server stuff like api endpoints and server interactions will not work in runtime. All the interaction part should be in web-components only.
4. Desktop Output (desktop
)
The desktop
output type is designed for creating deployable desktop applications, integrated with Tauri. To set up your Brisa project for desktop output, modify your brisa.config.ts
as shown below:
import type { Configuration } from "brisa";
export default {
output: "desktop",
} satisfies Configuration;
Once activated you can call brisa dev
to work locally with hotreloading in the desktop app or brisa build
to build the desktop app native executables.
You can do
brisa dev --skip-tauri
orbrisa build --skip-tauri
if you want to avoid creating and loading the desktop application.
In production the build is done as static export, since there is no server. Pure server stuff like api endpoints and server interactions will not work in runtime. All the interaction part should be in web-components only.
Lean how to build a desktop app here.
5. Android Output (android
)
The android
output type is designed for creating deployable android applications, integrated with Tauri. To set up your Brisa project for desktop output, modify your brisa.config.ts
as shown below:
import type { Configuration } from "brisa";
export default {
output: "android",
} satisfies Configuration;
Prerequisits: You need to download Android Studio and follow these steps from Tauri documentation.
Once activated you can call brisa dev
to work locally with hotreloading in the android app or brisa build
to build the android app native executables.
You can do
brisa dev --skip-tauri
orbrisa build --skip-tauri
if you want to avoid creating and loading the android application.
In production the build is done as static export, since there is no server. Pure server stuff like api endpoints and server interactions will not work in runtime. All the interaction part should be in web-components only.
Lean how to build a android app here.
6. iOS Output (ios
)
The ios
output type is designed for creating deployable iOS applications, integrated with Tauri. To set up your Brisa project for desktop output, modify your brisa.config.ts
as shown below:
import type { Configuration } from "brisa";
export default {
output: "ios",
} satisfies Configuration;
Prerequisits: You need to download iOS targets and follow these steps from Tauri documentation.
Once activated you can call brisa dev
to work locally with hotreloading in the iOS app or brisa build
to build the iOS app native executables.
You can do
brisa dev --skip-tauri
orbrisa build --skip-tauri
if you want to avoid creating and loading the iOS application.
In production the build is done as static export, since there is no server. Pure server stuff like api endpoints and server interactions will not work in runtime. All the interaction part should be in web-components only.
Lean how to build a iOS app here.
Additional Considerations
When configuring your output type, it's crucial to consider the deployment environment and requirements. Each output type serves a distinct purpose, and choosing the right one ensures optimal performance and compatibility.
To view the changes in the output, run the brisa build
command. In the case of server
output, the build is generated in the build
folder, while for static
and desktop
output, an additional out
folder is created. The build
folder is retained as it is needed to generate the initial build before generating static files or the desktop app in the separate out
folder.
Learn more details about static export here.
If your application requires server-side features, like middleware or API endpoints, opt for the
bun
/node
/deno
output. For static websites, select thestatic
output, and for desktop / mobile applications integrated with Tauri, use thedesktop
/ios
/android
output.