@usermaven/sdk-js v1.5.5
Usermaven SDK
Usermaven SDK is a powerful and flexible JavaScript/TypeScript library for tracking user behavior and events in web applications. It supports both client-side and server-side usage, with a focus on privacy, configurability, and robustness.
Features
- Cross-platform compatibility (browser and server-side)
- Flexible event tracking with custom payloads
- Automatic tracking of page views, form submissions, and user interactions
- Privacy-focused with configurable data sanitization
- Robust error handling and retry mechanisms
- Extensible architecture for custom tracking features
- Performance optimizations including event batching and debouncing
Installation
NPM or Yarn
You can install the Usermaven SDK using npm:
npm install @usermaven/sdk-js
Or using yarn:
yarn add @usermaven/sdk-js
UMD (Universal Module Definition)
For quick integration without a module bundler, you can include the SDK directly in your HTML using a script tag:
<script src="https://cdn.usermaven.com/sdk/v1/lib.js"
data-key="your-api-key"
data-tracking-host="https://events.yourdomain.com"
data-log-level="debug"
data-autocapture="true"
data-form-tracking="true"
data-auto-pageview="true"></script>
Replace https://cdn.usermaven.com/sdk/v1/lib.js
with the actual URL where the Usermaven SDK is hosted.
Basic Usage
Using as a module
import { usermavenClient } from '@usermaven/sdk-js';
const client = usermavenClient({
apiKey: 'your-api-key',
trackingHost: 'https://events.yourdomain.com',
// Add other configuration options as needed
});
// Track an event
client.track('button_click', {
buttonId: 'submit-form',
pageUrl: window.location.href
});
// Identify a user
client.id({
id: 'user123',
email: 'user@example.com',
name: 'John Doe'
});
// Track a page view
client.pageview();
Using via UMD
When you include the SDK via a script tag, it automatically initializes with the configuration provided in the data attributes. You can then use the global usermaven
function to interact with the SDK:
<script>
// Track an event
usermaven('track', 'button_click', {
buttonId: 'submit-form',
pageUrl: window.location.href
});
// Identify a user
usermaven('id', {
id: 'user123',
email: 'user@example.com',
name: 'John Doe'
});
// Track a page view (if not set to automatic in the script tag)
usermaven('pageview');
</script>
Advanced Configuration
The SDK supports various configuration options to customize its behavior. When using as a module:
const client = usermavenClient({
apiKey: 'your-api-key',
trackingHost: 'https://events.yourdomain.com',
cookieDomain: '.yourdomain.com',
logLevel: 'DEBUG',
useBeaconApi: true,
autocapture: true,
formTracking: 'all',
autoPageview: true,
// ... other options
});
When using via UMD, you can set these options using data attributes on the script tag:
<script src="https://cdn.usermaven.com/sdk/v1/lib.js"
data-key="your-api-key"
data-tracking-host="https://events.yourdomain.com"
data-log-level="debug"
data-autocapture="true"
data-form-tracking="all"
data-auto-pageview="true"
data-use-beacon-api="true"
data-cookie-domain=".yourdomain.com"></script>
Refer to the Config
interface in src/core/config.ts
for a full list of configuration options.
Server-Side Usage
The SDK can also be used in server-side environments:
const { usermavenClient } = require('@usermaven/sdk-js');
const client = usermavenClient({
apiKey: 'your-api-key',
trackingHost: 'https://events.yourdomain.com'
});
client.track('server_event', {
userId: 'user123',
action: 'item_purchased'
});
Development
To set up the project for development:
- Clone the repository
- Install dependencies:
npm install
- Run tests:
npm test
- Build the project:
npm run build
Contributing
Contributions are welcome! Please read our contributing guidelines and code of conduct before submitting pull requests.
4 months ago
4 months ago
4 months ago
4 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
6 months ago
7 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
8 months ago
9 months ago
9 months ago
9 months ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
4 years ago