@flow-industries/biome-config
Shared Biome configuration and a reusable CI workflow for Flow's TypeScript projects.
This repo is the single source of truth for code-quality rules across auth, site, docs, and ui. Each repo carries only a tiny stub that points here — the actual rules and CI steps live here once.
Biome config
Two presets are published as @flow-industries/biome-config:
@flow-industries/biome-config/biome — the self-contained core (formatter + recommended lint, no framework domain)
@flow-industries/biome-config/react — additive: adds only Biome's react lint domain on top of the core
Use it
bun add -d @flow-industries/biome-config @biomejs/biome@2.4.12
Add a biome.json to the repo root. React projects extend both presets (Biome merges them left to right):
{
"extends": [
"@flow-industries/biome-config/biome",
"@flow-industries/biome-config/react"
],
"files": { "includes": ["**", "!dist"] }
}
A non-React project extends just the core:
{ "extends": ["@flow-industries/biome-config/biome"], "files": { "includes": ["**", "!dist"] } }
The react preset is additive on purpose — it carries only the domain, never its own copy of the formatter/core rules. (A relative extends inside a published package does not resolve from a consumer's node_modules, so the core can't be pulled in transitively; listing both presets in the consumer is the reliable pattern.) Per-repo ignores (generated dirs, vendored code) go in the local stub via files.includes — Biome merges these arrays additively with the shared presets. Keep @biomejs/biome pinned to the exact version above so every repo lints with an identical rule set.
Recommended package.json scripts:
{
"lint": "biome check",
"format": "biome format --write",
"check": "biome check --write"
}
Reusable CI workflow
.github/workflows/ts-check.yml is a workflow_call workflow that sets up Bun, installs with a frozen lockfile, then runs bun run lint and a typecheck. Call it from a repo:
name: CI
on:
pull_request:
push:
branches: [main]
concurrency:
group: ci-${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
jobs:
check:
uses: flow-industries/lint/.github/workflows/ts-check.yml@v1
with:
runner: flow-arc
typecheck-cmd: "bun run typecheck"
Inputs:
runner | ubuntu-latest | Use a self-hosted runner label (e.g. flow-arc) for private repos; public repos stay on ubuntu-latest. |
typecheck-cmd | bun run typecheck | Override for repos whose typecheck needs codegen first. |
run-build | false | Set true to also run bun run build. |