compile.tscircuit.com
Compiles tscircuit user code into Circuit JSON.
API Usage
The API provides endpoints to compile tscircuit JSX/TSX code into circuit JSON.
Compile Endpoint
GET /compile
Compile tscircuit code via GET request with compressed code parameter.
GET /compile?code={compressed_code}
- code: Compressed Base64 string of tscircuit JSX/TSX code (generated using- @tscircuit/create-snippet-url)
- Alternatively, you can use fs_mapparameter with a compressed JSON object mapping filenames to code
Example using fetch:
import { getCompressedBase64SnippetString } from "@tscircuit/create-snippet-url"
const circuitCode = `
export default () => (
  <resistor name="R1" resistance="1k" />
)`
const compressedCode = getCompressedBase64SnippetString(circuitCode)
const response = await fetch(
  `https://compile.tscircuit.com/api/compile?code=${encodeURIComponent(
    compressedCode
  )}`
)
const data = await response.json()
// data.circuit_json contains the compiled circuit
The response also includes a logs array detailing events during the compile process. The first entry records the version of tscircuit used for the build.
POST /compile
Compile tscircuit code via POST request with an filesystem map.
POST /compile
Content-Type: application/json
{
  "fs_map": {
    "user-code.tsx": "export default () => <resistor name=\"R1\" resistance=\"1k\" />"
  }
}
- Request body should contain a JSON object with an fs_mapproperty
- fs_mapis an object mapping filenames to their content as strings
Example using fetch:
const response = await fetch("https://compile.tscircuit.com/api/compile", {
  method: "POST",
  headers: {
    "Content-Type": "application/json",
  },
  body: JSON.stringify({
    fs_map: {
      "user-code.tsx": `
        export default () => (
          <capacitor name="C1" capacitance="10uF" />
        )
      `,
    },
  }),
})
const data = await response.json()
// data.circuit_json contains the compiled circuit
Health Check
GET /api/health
Returns a status indicating if the service is operational. The response also includes the version of tscircuit used by the compile server:
{
  "ok": true,
  "compile_server_health": { "tscircuit_version": "<version>" }
}
Development
bun run start