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 or brisa 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 or brisa 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 or brisa 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 the static output, and for desktop / mobile applications integrated with Tauri, use the desktop / ios / android output.