This is an Angular wrapper library for ackee-tracker, the client-side piece of Ackee analytics.
This version is now (ONLY) compatible with Ackee v3, including event tracking! See Release Notes for v3
🚨 BREAKING CHANGES: the
.create()
method was renamed to.visit()
for better naming consistency with.event()
- one tracks a visit and the other an event. Both create the instance if it does not exist. Also, the interfaceAckeeOptions
has been renamedAckeeConfig
.
Please make sure you read Ackee's docs before you use this lib.
For more insights on how this wrapper works, you can clone its repository which contains a test app.
⚠️ There are 2 ways to get ackee-tracker: from your Ackee instance (i.e: https://yourackeeinstance.com/**tracker.js**) or from npm. This library only supports getting it from your instance, which is the way that is reccomended by the Ackee devs.
$ npm install ngx-ackee-wrapper
Or
$ yarn add ngx-ackee-wrapper
import { BrowserModule } from "@angular/platform-browser";
import { NgModule } from "@angular/core";
import { AppComponent } from "./app.component";
import { AckeeModule, AckeeOptions } from "ngx-ackee-wrapper"; // <-- 1. ADD THIS
// 2. Configure to your Ackee instance:
const ACKEE_CONFIG: AckeeOptions = {
tracker: "https://yourackeeinstance.com/tracker.js",
server: "https://yourackeeinstance.com",
domainId: "12312311-1234-1234-1234-123412341234",
options: {
// ignoreLocalhost: false,
// detailed: true,
// ignoreOwnVisits: true,
},
dev: true,
ignore: false,
};
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, AckeeModule.forRoot(ACKEE_CONFIG)], // <-- 3. Add AckeeModule & config to imports
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
Configuration:
-
tracker: (string) The full url to your instance's tracker (you can configure a custom name other than tracker.js). See here.
-
server (string), domainId (string) & options (object): same as in ackee-tracker, see the docs.
-
dev (boolean): optional, will add a message to console log - just a check to see if it runs
-
ignore (boolean): optional, will completely ignore Ackee: useful in dev when you don't want to run a local instance (or point to the prod) while working on something else - using environment variables for this is recommended (see demo app)
Note: You can also use environment variables as demonstrated in the demo app.
In your Component:
import { Component } from "@angular/core";
import { NavigationEnd, Router } from "@angular/router";
import { AckeeService } from "projects/lib/src/public-api";
import { filter } from "rxjs/operators";
@Component({
selector: "app-root",
templateUrl: "./app.component.html",
styleUrls: ["./app.component.scss"],
})
export class AppComponent {
constructor(private ackeeServ: AckeeService, private router: Router) {
// Don't track route changes:
// this.ackeeServ.visit();
// Track route changes:
this.ackeeServ.visit(
this.router.events.pipe(filter((evt) => evt instanceof NavigationEnd))
);
// Track route changes & override attributes:
// this.ackeeServ.visit(
// this.router.events.pipe(filter((evt) => evt instanceof NavigationEnd)), {
// siteLocation: window.location.href,
// siteReferrer: document.referrer
// }
// );
}
}
Parameters:
obs
(Observable<Event>)
: to track changes, see below;attributes
(AckeeAttributesObject)
: Overrides the user-related information transferred to the server.
🚨 If you pass attributes here, only that information will be sent to the server, use with caution 🚨;
To track route changes, we get the router's events (an Observable<Event>
) and we filter them to get only the events of type NavigationEnd. If you want, you can use NavigationStart instead. In fact you can pass any Observable you want to get fancy with the tracking. I personally prefer NavigationEnd so that I only track the pages that have effectively loaded.
If you don't want to track route changes, just don't pass anything in .visit()
:
this.ackeeServ.visit();
This will result in only one page or visit recorded for your entire Angular app, no mater how many routes were opened (unless the user reloads the page). The upside of this option however, is that the recorded "duration" of the visit will be for the entire session of the use of the app.
You can track any event you want. Please read the docs to understand how that translates to the Ackee reporting.
For example, to track a click on a button, in your HTML Template:
<button (click)="triggerAction()">Click for Event</button>
In your Component:
triggerAction() {
this.ackeeServ.event(
'evnt-id-from-ackee-instance-settings-page',
{
key: 'your-event-key',
value: 1,
},
(actionId: string) => (this.actionId = actionId)
);
}
Parameters:
eventId
(string)
: get it from you Ackee's instance settings page;attributes
({key:string; value:number})
: record whatever you want;callback
(optional): will receive theactionId (string)
that lets you update your event later, if required.
You can change the attibutes of any past event as long as you have its actionId
that you get from the callback in .event()
.
In your Component:
this.ackeeServ.eventUpdate("the-action-id-from-event-method", {
key: "your-key",
value: 42,
});
Parameters:
actionId
(string)
: get it from the callback in.event()
- see above;attributes
({key:string; value:number})
: update the record with whatever you want;
MIT - Software is provided as is, no liability to the developer.
Please consider donating to the developer of Ackee to keep this amazing project going. They are working hard, continuously developing and maintaining Ackee as a free, self hosted, privacy-first analytics solution.