TypeScript SDK for the Outlit events ingestion API. Track user interactions, page views, and custom events across web and server applications.
This monorepo contains these packages under the @outlit scope:
- @outlit/core - Core SDK functionality and base client
- @outlit/browser - Browser-specific SDK with automatic page view tracking
- @outlit/node - Node.js SDK for server-side event tracking
- @outlit/cli - CLI for Outlit customer intelligence
- @outlit/tools - Customer intelligence tool contracts and client helpers
- @outlit/pi - Pi package for Outlit customer intelligence tools
Choose the package that matches your environment:
# For browser applications
npm install @outlit/browser
# For Node.js applications
npm install @outlit/node
# For custom implementations
npm install @outlit/coreimport { Outlit } from '@outlit/browser'
const outlit = new Outlit({
publicKey: 'pk_xxx',
trackPageviews: true,
trackForms: true,
})
// Identify a user
outlit.user.identify({
email: 'user@example.com',
traits: { name: 'John Doe' },
customerId: 'cust_123', // Your app's account/workspace/customer ID
customerTraits: { plan: 'pro' },
})
// Track events
outlit.track('button_clicked', {
button_id: 'signup',
page: '/homepage',
})
// Mark billing status on a customer
outlit.customer.trialing({
customerId: 'cust_123', // Your app's account/workspace/customer ID
properties: { plan: 'pro' },
})import { init, track, user, customer } from '@outlit/browser'
// Initialize once at app startup
init({ publicKey: 'pk_xxx' })
// Then use anywhere
track('page_viewed', { page: '/home' })
user().identify({
email: 'user@example.com',
customerId: 'cust_123', // Your app's account/workspace/customer ID
})
customer().paid({
customerId: 'cust_123', // Your app's account/workspace/customer ID
properties: { plan: 'pro' },
})import { OutlitProvider, useOutlit } from '@outlit/browser/react'
// Wrap your app
function App() {
return (
<OutlitProvider publicKey="pk_xxx">
<MyComponent />
</OutlitProvider>
)
}
// Use in components
function MyComponent() {
const { track, user } = useOutlit()
return (
<button onClick={() => user.activate({ milestone: 'onboarding' })}>
Click me
</button>
)
}import { Outlit } from '@outlit/node'
const outlit = new Outlit({
publicKey: 'pk_xxx',
})
// Track server-side events (requires identity)
outlit.track({
customerId: 'cust_123', // Your app's account/workspace/customer ID
eventName: 'api_request',
properties: {
endpoint: '/api/users',
method: 'GET',
status: 200,
},
})
// `customerId`-only track events are valid immediately.
// When you later call identify() with the same customerId and an email,
// Outlit can link that account/workspace to the customer resolved from email.
// Identify a user
outlit.user.identify({
email: 'user@example.com',
traits: { plan: 'pro' },
customerId: 'cust_123', // Your app's account/workspace/customer ID
customerTraits: { plan: 'pro' },
})
// Mark customer billing status
outlit.customer.paid({
customerId: 'cust_123', // Your app's account/workspace/customer ID
properties: { plan: 'pro' },
})
// Flush events before shutdown
await outlit.flush()- Modern TypeScript - Full TypeScript support with type definitions
- Tree-shakeable - Optimized bundle size with dual ESM/CJS exports
- Event Queueing - Automatic batching and flushing of events
- Multi-platform - Separate packages for browser and Node.js
- Auto-tracking - Automatic page view tracking in browser
- Middleware Support - Easy integration with Express and similar frameworks
- Persistent Identity - User and anonymous ID persistence
- High Performance - Minimal overhead and efficient batching
- Type Safe - Full TypeScript support with strict types
- Pi agents - Build customer intelligence agents in Pi with
@outlit/pi
This project uses a modern monorepo setup with the following tools:
- Bun - Fast all-in-one JavaScript runtime and package manager
- Turbo - Build system for monorepo orchestration
- TypeScript - Type-safe JavaScript
- tsup - Fast TypeScript bundler
- Biome - Fast linter and formatter
- Playwright - End-to-end testing
- Changesets - Version management and changelogs
# Install dependencies
bun install
# Build all packages
bun run build
# Run tests
bun run test
# Lint code
bun run lint
# Type check
bun run typecheck
# Format code
bun run formatoutlit-sdk/
├── .github/workflows/ # CI/CD workflows
├── examples/
│ └── pi-agents/ # Example Pi agents using @outlit/pi
├── packages/
│ ├── browser/ # Browser SDK with React bindings
│ ├── cli/ # Outlit CLI
│ ├── core/ # Shared types and utilities
│ ├── node/ # Node.js SDK
│ ├── pi/ # Pi package for Outlit tools
│ ├── tools/ # Customer intelligence tool contracts
│ └── typescript-config/ # Shared TypeScript configs
├── package.json # Root package with workspace config
├── bun.lock # Bun lockfile
├── turbo.json # Turbo build configuration
└── biome.json # Biome linter/formatter config
When making changes that should be released, create a changeset:
bunx changesetThis will prompt you to:
- Select which packages are affected
- Choose the version bump type (patch, minor, major)
- Write a description of the change
The changeset file will be committed with your PR and used to generate changelogs on release.
- CI (
ci.yml) - Runs on PRs: lint, typecheck, build, test - Release (
release.yml) - Runs on main: publish canary to npm + CDN, create version PR or publish stable releases
For maintainers setting up the repository:
| Secret | Description |
|---|---|
NPM_TOKEN |
npm access token with publish permission for @outlit scope |
GCP_CREDENTIALS |
Service account JSON key with Storage Object Admin on cdn.outlit.ai bucket |
- Go to npmjs.com and sign in
- Navigate to Access Tokens → Generate New Token → Granular Access Token
- Set permissions: Read and write for
@outlitpackages - Copy the token and add as
NPM_TOKENsecret in GitHub
- Go to Google Cloud Console
- Navigate to IAM & Admin → Service Accounts
- Create a new service account (e.g.,
github-actions-deployer) - Grant "Storage Object Admin" role on the
cdn.outlit.aibucket - Create a JSON key for the service account
- Copy the entire JSON content and add as
GCP_CREDENTIALSsecret in GitHub
The browser SDK IIFE bundle is deployed to Google Cloud Storage:
| Path | Description |
|---|---|
/canary/outlit.js |
Latest from main branch (5 min cache) |
/stable/outlit.js |
Latest stable release (1 year cache) |
/v{version}/outlit.js |
Immutable versioned release (1 year cache) |
npm tags:
| Tag | Description |
|---|---|
latest |
Stable release (npm install @outlit/browser) |
canary |
Latest from main (npm install @outlit/browser@canary) |
Manual deployment (requires gcloud CLI):
cd packages/browser && bun run deploy:canary # Deploy to canary
cd packages/browser && bun run deploy:stable # Deploy to stable (requires confirmation)
cd packages/browser && bun run deploy:version # Deploy versioned releaseWe welcome contributions! Please see CONTRIBUTING.md for guidelines.
Apache-2.0 - see LICENSE for details.
- Issues: GitHub Issues
- Docs: Documentation