1.0.3 • Published 1 year ago

vantevo-analytics-tracker v1.0.3

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

The analytics of your website, but simpler

Vantevo Analytics is the alternative platform to Google Analytics that respects privacy, because it does not need cookies not compliant with the GDPR. Easy to use, light and can be integrated into any website and back-end.

For more information visit the website vantevo.io.

Installation

npm install vantevo-analytics-tracker

Usage

To start tracking page views and events, you need to initialize your tracker first:

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({
 "excludePath": [],
 "dev": false,
 "hash": false,
 "domain": null,
 "proxyServer": null,
 "proxyServerEcommerce": null,
});

These are the parameters available for the tracker settings, all fields are optional.

OptionTypeDescriptionDefault
excludePatharray (Optional)You can exclude one or more pages from the statistics, settings[]
devboolean (Optional)Tracker will not send data to server, please check browser console to view request information.false
hashboolean (Optional)Allows tracking based on URL hash changes.false
domainstring (Optional)Use this option when the script is installed on a different domain than the one entered on Vantevo Analytics. To use this function remember to authorize the domain to be able to save the statistics, for more information read more.null
proxyServerstring (Optional)If you want to use a proxy server for requests sent to Vantevo.https://api.vantevo.io/event
proxyServerEcommercestring (Optional)If you want to use a proxy server for requests sent to Vantevo for ecommerce events.https://api.vantevo.io/event-ecommerce

VantevoAnalytics() returns the functions you can use to keep track of your events.

  • vantevo(): Page views monitoring, event management and goals.

  • enableTracker(): Allows you to track page views automatically, the script uses the popstate event to navigate the site.

  • enableOutboundLinks(): Allows you to monitor all outbound links from your site automatically, the script uses the click andauxclick events.

  • enableTrackFiles(extensions , saveExtension): It allows you to automatically monitor all files to be downloaded from your site. The function has 2 parameters: extensions and saveExtension.

OptionTypeDescriptionDefault
extensionsstring (required)extensions consists of a comma separated list of extensions, example: zip, mp4, avi, mp3. Whenever a user clicks on a link, the script checks if the file extension is in the list you entered in the parameter and sends a File Download event with the value url.null
saveExtensionboolean (optional)saveExtension allows you to save in the event detail together with the url also the name of the file extension as meta_key to get more information and statistics about your files to download.false

The script uses the click andauxclick events.

The script uses the addEventListener () method for the enableTracker, enableOutboundLinks and enableTrackFiles functions, to remove the registered event listener each function will return a clean function removeEventListener():

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { enableTracker, enableOutboundLinks, enableTrackFiles } = VantevoAnalytics({...});
 
const cleanTracker = enableTracker();
const cleanOutboundLinks = enableOutboundLinks();
const cleanEnableTrackFiles = enableTrackFiles("zip,mp4,avi", true);
 
cleanTracker();
cleanOutboundLinks();
cleanEnableTrackFiles();

Page view monitoring and event management

Simple Pageview

Submit a pageview using location.href as the request URL anddocument.title for the page title.

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({...});
 
vantevo();
/*** or ***/
vantevo("pageview");

Pageview change pathname of url

You can submit a custom pageview where you can change the pathname of the page. In the example below, the page URL is https://example.com/blog?page=2 with the pathname=/blog and thepage=2 parameter (the page = 2 parameter will be ignored, see guide), using the pageview event with themeta parameter of type {path:"/blog/page/2"} , the script will save as page pathname: /blog/page/2.

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({...});
 
vantevo("pageview", { path: "/blog/page/2" }, () => {});

Pageview change title page

Vantevo uses document.title to get the full title of the page, in this example you will see how you can change the page title.

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({...});
 
vantevo("pageview", { title: "New Title Page" }, () => {});

Event

An example of how to send an event with the name "Download" and with the information meta_key=pdf andmeta_value=presentation, the meta parameter is a simple json.

Vantevo Analytics handles the meta_key=duration, the value of this field is of type Number. With the duration parameter it is possible to send a number (seconds) with the event that will be used to calculate the average duration of the event itself.

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({...});
 
vantevo("download", { pdf: "presentation" }, () => {});
/*** or ***/
vantevo("video", { title: "presentation", duration: 30 }, () => {});
 

Parameters

OptionTypeDescriptionDefault
eventstring (required)Event Name.pageview
valuesobject (required)An object with custom properties for events.{}
callbackfunction (optional)A function that is called once the event has been successfully logged.null

Monitoring Ecommerce

In the ecommerce section of Vantevo you can monitor specific actions affecting your ecommerce website and the sources of traffic that lead to sales.

Parameters

OptionTypeDescriptionDefault
eventstring (required)Event Name. See below the list of events you can use for monitoring your ecommerce.pageview
valuesobject (required)An object with custom properties for events.{}
callbackfunction (optional)A function that is called once the event has been successfully logged.null

List events

These are the events to use to monitor your ecommerce:

EventDescription
add_to_wishlista user adds a product to the favorites list
view_itema user views a product
remove_item_carta user removes a product from the cart
add_item_carta user adds product to the cart
start_checkouta user has started the checkout process
checkout_infoa user submits personal data
checkout_shipa user submits shipments data
checkout_paymenta user initiated the payment process
purchasea user has completed a purchase

Example

An example for how to use the trackEcommerce function.

const { trackEcommerce } = VantevoAnalytics({...});

trackEcommerce("add_to_wishlist", { 
    "items": [
         {
            'item_id': "SKU_123",
            'item_name': "Samsung Galaxy",
            'currency': "EUR",
            'quantity': 1,
            'price': 199.99,
            'discount': 0,
            'position': 1,
            'brand': "Samsung",
            'category_1': "Smartphone",
            'category_2': "Samsung",
            'category_3': "Galaxy",
            'category_4': "",
            'category_5': "",
            'variant_1': "Black",
            'variant_2': "5.5 inch",
            'variant_3': ""
        }
    ]
});

Read our guide for more information of how to use the ecommerce tracking function.

404 - Page Not Found

For the management of the error 404 - Page Not Found page we have created a specific event. This function will automatically save a 404 event and thepathname of the page as a value.

You can find the information collected through this function on the Events page.

import VantevoAnalytics from "vantevo-analytics-tracker";
 
const { vantevo } = VantevoAnalytics({...});
 
vantevo("404", {}, () => {}));

Vantevo Analytics guide

To see all the features and settings of Vantevo Analytics we recommend that you read our complete guide here.

1.0.3

1 year ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.1-beta.16

2 years ago

1.0.1-beta.11

2 years ago

1.0.1-beta.14

2 years ago

1.0.1-beta.15

2 years ago

1.0.1-beta.12

2 years ago

1.0.1-beta.13

2 years ago

1.0.1-beta.10

2 years ago

1.0.1-beta.9

2 years ago

1.0.1-beta.8

2 years ago

1.0.1-beta.7

2 years ago

1.0.1-beta.6

2 years ago

1.0.1-beta.5

2 years ago

1.0.1-beta.4

2 years ago

1.0.1-beta.3

2 years ago

1.0.1-beta.2

2 years ago

1.0.1-beta.1

2 years ago

1.0.0

2 years ago