Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/angulartics/angulartics2
Vendor-agnostic analytics for Angular2 applications.
https://github.com/angulartics/angulartics2
analytics angular angular2 angular4 angular5 angulartics angulartics2 application-insights baidu-analytics facebook-pixel google-analytics google-tag-manager hack hacktoberfest kissmetrics mixpanel ngx piwik segmentio
Last synced: 4 days ago
JSON representation
Vendor-agnostic analytics for Angular2 applications.
- Host: GitHub
- URL: https://github.com/angulartics/angulartics2
- Owner: angulartics
- License: mit
- Created: 2015-12-30T19:56:55.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2024-09-06T06:58:01.000Z (5 months ago)
- Last Synced: 2024-10-29T15:18:58.588Z (3 months ago)
- Topics: analytics, angular, angular2, angular4, angular5, angulartics, angulartics2, application-insights, baidu-analytics, facebook-pixel, google-analytics, google-tag-manager, hack, hacktoberfest, kissmetrics, mixpanel, ngx, piwik, segmentio
- Language: TypeScript
- Homepage:
- Size: 3.25 MB
- Stars: 1,013
- Watchers: 34
- Forks: 192
- Open Issues: 85
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-angular-components - angulartics2 - Vendor-agnostic analytics for Angular2 applications. (Uncategorized / Uncategorized)
- awesome-angular-components - angulartics2 - Vendor-agnostic analytics for Angular2 applications. (Uncategorized / Uncategorized)
- awesome-ionic2-components - Analytics (Google, Piwik, Kissmetrics and more)
- Awesome - Analytics (Google, Piwik, Kissmetrics and more)
- awesome-angular-components - angulartics/angulartics2 - Vendor-agnostic analytics for Angular2 applications. (UI Components / Miscellaneous)
- awesome-angular - angulartics2 - Vendor-agnostic analytics for Angular2 applications. (Table of contents / Angular)
- fucking-awesome-angular - angulartics2 - Vendor-agnostic analytics for Angular2 applications. (Table of contents / Angular)
- fucking-awesome-angular - angulartics2 - Vendor-agnostic analytics for Angular2 applications. (Table of contents / Angular)
README
# angulartics2
[![NPM version](https://img.shields.io/npm/v/angulartics2.svg)](https://npmjs.org/package/angulartics2) [![NPM downloads](https://img.shields.io/npm/dm/angulartics2.svg)](https://npmjs.org/package/angulartics2)
[![Build Status](https://api.travis-ci.org/angulartics/angulartics2.svg?branch=master)](https://travis-ci.org/angulartics/angulartics2)
[![MIT license](http://img.shields.io/badge/license-MIT-blue.svg)](LICENSE)[![Gitter Chat](https://img.shields.io/gitter/room/nwjs/nw.js.svg)](https://gitter.im/angulartics/angulartics2)
Vendor-agnostic Analytics for Angular Applications. [angulartics.github.io/angulartics2](https://angulartics.github.io/angulartics2 "Angulartics Docs")
- [Installation](#installation)
- [Include it in your application](#include-it-in-your-application)
- [Usage](#usage)
- [Tracking events in templates/HTML](#tracking-events-in-templateshtml)
- [Tracking events in the code](#tracking-events-in-the-code)
- [Configuring the Module](#configuring-the-module)
- [Exclude routes from automatic pageview tracking](#exclude-routes-from-automatic-pageview-tracking)
- [Remove IDs from url paths](#remove-ids-from-url-paths)
- [Remove Query Params from url paths](#remove-query-params-from-url-paths)
- [Remove Hash from url paths](#remove-hash-from-url-paths)
- [Using Without A Router](#using-without-a-router)
- [Using With UI-Router](#using-with-ui-router)
- [SystemJS](#systemjs)
- [Supported providers](#supported-providers)
- [For other providers](#for-other-providers)
- [Minimal setup for Google Analytics](#minimal-setup-for-google-analytics)
- [Contributing](#contributing)
- [License](#license)## Dependencies
Latest version available for each version of Angular| Angulartics2 | Angular |
| ------------ | --------- |
| 8.3.0 | 8.x |
| 9.1.0 | 9.x |
| 10.1.0 | 10.x |
| 11.0.0 | 12.x |
| 12.0.0 | 13.x |
| 13.0.0 | 14.x |
| latest | 15.x |## Installation
```sh
npm install angulartics2 --save
```### Include it in your application
1. Add `Angulartics2Module` to your root NgModule passing any options desired
```ts
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule, Routes } from '@angular/router';import { Angulartics2Module } from 'angulartics2';
import { Angulartics2GoogleAnalytics } from 'angulartics2';const ROUTES: Routes = [
{ path: '', component: HomeComponent },
{ path: 'about', component: AboutComponent },
];@NgModule({
imports: [
BrowserModule,
RouterModule.forRoot(ROUTES),// added to imports
Angulartics2Module.forRoot(),
],
declarations: [AppComponent],
bootstrap: [AppComponent],
})
```
> Note the different imports when [Using Without A Router](#using-without-a-router) or [Using With UI-Router](#using-with-ui-router).2. __Required__: Import your providers in the root component. Call `startTracking()` to start the tracking of route changes.
```ts
// component
import { Angulartics2GoogleAnalytics } from 'angulartics2';@Component({ ... })
export class AppComponent {
constructor(angulartics2GoogleAnalytics: Angulartics2GoogleAnalytics) {
angulartics2GoogleAnalytics.startTracking();
}
}
```## Usage
### Tracking events in templates/HTML
To track events you can inject the directive ```angulartics2On``` into any component and use the attributes ```angulartics2On```, ```angularticsAction``` and ```angularticsCategory```:
```ts
// component
import { Component } from '@angular/core';@Component({
selector: 'song-download-box',
template: `
Click Me
`,
})
export class SongDownloadBox {}import { NgModule } from '@angular/core';
import { Angulartics2Module } from 'angulartics2';@NgModule({
imports: [
Angulartics2Module,
],
declarations: [
SongDownloadBox,
]
})
```If you need event label, you can use
```html
Click Me
```### Tracking events in the code
```ts
import { Angulartics2 } from 'angulartics2';constructor(private angulartics2: Angulartics2) {
this.angulartics2.eventTrack.next({
action: 'myAction',
properties: { category: 'myCategory' },
});
}
```If you need event label, you can use
```ts
this.angulartics2.eventTrack.next({
action: 'myAction',
properties: {
category: 'myCategory',
label: 'myLabel',
},
});
```### Configuring the Module
#### Exclude routes from automatic pageview tracking
Pass string literals or regular expressions to exclude routes from automatic pageview tracking.
````ts
Angulartics2Module.forRoot({
pageTracking: {
excludedRoutes: [
/\/[0-9]{4}\/[0-9]{2}\/[a-zA-Z0-9|\-]*/,
'2017/03/article-title'
],
}
}),
````#### Remove IDs from url paths
`/project/12981/feature` becomes `/project/feature`
````ts
Angulartics2Module.forRoot({
pageTracking: {
clearIds: true,
}
}),
````
By default, it removes IDs matching this pattern (ie. either all numeric or UUID) : `^\d+$|^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$`.You can set your own regexp if you need to :
`/project/a01/feature` becomes `/project/feature`
````ts
Angulartics2Module.forRoot({
pageTracking: {
clearIds: true,
idsRegExp: new RegExp('^[a-z]\\d+$') /* Workaround: No NgModule metadata found for 'AppModule' */
}
}),
````#### Remove Query Params from url paths
This can be combined with clearIds and idsRegExp
`/project/12981/feature?param=12` becomes `/project/12981/feature`
````ts
Angulartics2Module.forRoot({
pageTracking: {
clearQueryParams: true,
}
}),
````#### Remove Hash from url paths
`/callback#authcode=123&idToken=456` becomes `/callback`
````ts
Angulartics2Module.forRoot({
pageTracking: {
clearHash: true,
}
}),
````### Using Without A Router
__Warning:__ this support is still experiemental
`@angular/router` must still be installed! However, it will not be used.
````ts
import { Angulartics2RouterlessModule } from 'angulartics2';
@NgModule({
// ...
imports: [
BrowserModule,
Angulartics2RouterlessModule.forRoot(),
],
})
````### Using With UI-Router
__Warning:__ this support is still experiemental
`@angular/router` must still be installed! However, it will not be used.
````ts
import { Angulartics2UirouterModule } from 'angulartics2';
@NgModule({
// ...
imports: [
BrowserModule,
Angulartics2UirouterModule.forRoot(),
],
})
````### SystemJS
Using SystemJS? If you aren't using `defaultJSExtensions: true` you may need to use:
```ts
System.config({
packages: {
"/angulartics2": {"defaultExtension": "js"},
},
});
```## Supported providers
* [Google Analytics](/src/lib/providers/ga) (`analytics.js`)
* [Google Tag Manager](/src/lib/providers/gtm)
* [Google Enhanced Ecom](/src/lib/providers/ga-enhanced-ecom)
* [Google Global Site Tag](/src/lib/providers/gst) (`gtag.js`)
* [Kissmetrics](/src/lib/providers/kissmetrics)
* [Mixpanel](/src/lib/providers/mixpanel)
* [Matomo](/src/lib/providers/matomo)
* [Segment](/src/lib/providers/segment)
* [Baidu Analytics](/src/lib/providers/baidu)
* [Facebook Pixel](/src/lib/providers/facebook)
* [Application Insights](/src/lib/providers/appinsights)
* [Hubspot](/src/lib/providers/hubspot)
* [Adobe Analytics (Omniture)](/src/lib/providers/adobeanalytics)
* [Launch, by Adobe](src/lib/providers/launch) (works with DTM, too)
* [Incendium](/src/lib/providers/incendium)
* [Intercom](/src/lib/providers/intercom)
* [Woopra](/src/lib/providers/woopra)
* [Clicky](/src/lib/providers/clicky)
* [IBM Digital Analytics](/src/lib/providers/ibm-digital-analytics)
* [Splunk](/src/lib/providers/splunk)
* [Pyze](/src/lib/providers/pyze)
* [Posthog](/src/lib/providers/posthog)### For other providers
If there's no Angulartics2 plugin for your analytics vendor of choice, please feel free to write yours and PR it!
### Minimal setup for Google Analytics
- See [Google Analytics](/src/lib/providers/ga) if your code snippet contains `analytics.js`
- See [Google Tag Manager](/src/lib/providers/gtm) if your code snippet contains `gtag.js`
- See [Google Global Site Tag](/src/lib/providers/gst) if your code snippet contains `gtag.js`## Contributing
Please see the [CONTRIBUTING](https://github.com/angulartics/angulartics2/blob/master/.github/CONTRIBUTING.md) and [CODE_OF_CONDUCT](https://github.com/angulartics/angulartics2/blob/master/.github/CODE_OF_CONDUCT.md) files for guidelines.
## License
[MIT](LICENSE)
## Related Projects
+ [analytics-angular](https://github.com/segmentio/analytics-angular): Write analytics code once, collect customer data from any source, and send it to over 250+ destinations with [Segment](https://segment.com/).