Official browser tracking library for the Mutant Workspace.
npm install @mutant-ws/next
Attach data to track
calls. Find the productId
from your profile page, in the install section of your product.
import { set } from "@mutant-ws/next"
set({
productId: "UUID",
})
You can run set
multiple times.
Ex. Attach userId
to track
calls after a successful login.
import { set } from "@mutant-ws/next"
const login = ({ email, password }) =>
POST("/login", { body: { email, password } }).then(({ id }) => {
set({
userId: id,
})
})
Record an event your application.
name
is required - Name of the event that you'll use to plot inside Mutant. An error will be thrown if not passed.productId
- You can either setproductId
once viaset
or explicitly add it to thetrack
call.
If using BEM for naming events, when plotting an event, the legend label will only show the M (modifier) part of BEM. Ex. for
page__section--login
, onlylogin
will be displayed.
import { track } from "@mutant-ws/next"
track("page.section.action-name", {
context: "data such as",
userId: "can be added to",
events: "by adding it here",
})
Make a POST
at https://api.mutant.love/track
with the same requirements as the track
method (name
and productId
required).
Ex. Tracking CI deployment success and failure.
curl \
--header "Content-Type: application/json" \
--data '{"name": "ci.success", "productId": "uuid"}' \
https://api.mutant.love/track
mutant
- Unique client id. Created if not present.
We automatically collect the following data with every event.
- Screen size: width and height of viewport and screen
- User agent
- URL
- Referrer
- IP
- Timestamp
git clone git@github.com:mutant-ws/next.git && \
cd next && \
npm run setup
# run tests (any `*.test.js`) once
npm test
# watch `src` folder for changes and run test automatically
npm run tdd
See the releases section for details.