Skip to content

How to capture Analytics for your plugin

Ahmad Farouq Hamed edited this page Dec 10, 2018 · 14 revisions

How to capture Analytics for your plugin

BuildFire provides a way for developers to track plugin views and user actions with minimal setup so they can retrieve all these analytical data later.

These events will be sent to our analytics server and then forwarded to the developer segment.io account which will be set by the developer. Our Intergration with segment.io, will allows developers to receive events at any of the endpoints supported by segment.io.

** Events will be also accessible to BuildFire, White Label owners and the app owner so it is very important NOT to use it to send sensitive information such as user passwords or anything that may violate users privacy.**


Tracking Views:

Views can be tracked using the trackView function:

buildfire.analytics.trackView([event name],[meta data obj]);

arguments:

  1. [event name]: The name of the view you wish to track

  2. [meta data obj]: Any extra information you would like to add to the user event (optional):

    To have aggregation reports in Control-Side, you need to pass aggregation value inside metadata obj like so:

    _buildfire: {
      aggregationValue: 10 // this needs to be inside _buildfire key
    }
    

example:

buildfire.analytics.trackView('contact-us');

buildfire.analytics.trackView('contact-us', { _buildfire: { aggregationValue: 10 } });


Tracking Actions:

User actions, such as a button click, can be tracked by using the trackAction function:

buildfire.analytics.trackAction([event name],[meta data obj]);

arguments:

  1. [event name]: The name of the action you wish to track

  2. [meta data obj]: Any extra information you would like to add to the user event (optional):

    To have aggregation reports in Control-Side, you need to pass aggregation value inside metadata obj like so:

    _buildfire: {
      aggregationValue:10 // this needs to be inside _buildfire key
    }
    

example:

buildfire.analytics.trackAction('add-entry', { totalEntries : myTotalEntries } );

buildfire.analytics.trackAction('add-entry'', { _buildfire: { aggregationValue: 10 } });


How to create Custom Event for your plugin

Plugin events are useful to give the customer detailed analytics of the user's behavior in your plugin. You can do that by registering your plugin events in the control side of your plugin. Once you register your custom events, you can track them using the above examples using buildfire.analytics.trackAction([event name],[meta data obj]);.

The Analytics tab in the Control side, will have three reports:

  1. Daily Report: Will show the total count of the selected event.

    Daily report without Aggregation value:

    Daily Report

    Daily report with Aggregation value:

    Daily Report Aggregation

  2. Top Users Report: Will show the top users for the selected event.

Top Users

  1. Details Report: will show detail info about each user.

Details Report

These three reports will recalculate the data depending on the selected event from the list on the left top corner, or when changing the selected days period on the right top corner.

Registered Events

buildfire.analytics.registerEvent(event, options, callback);

This function used to register an event for your plugin.

You can use this in the Control Side only.

arguments

  • event: (Object)

    • title: Event name, customer will see this on the control side under analytics tab. (String)
    • key: Unique key for the registered event. (String)
    • description: Description of the plugin event. (String)
  • options: (Object)

    • silentNotification: Determine wether you want to display a notification to the customer, with the new registered event. (Boolian, Default: false)
  • callback(err,result): (Function)

Example:

 //register plugin events for analytics
 function registerEvent(title, key, description, silentNotification) {
     buildfire.analytics.registerEvent({
         title: title,
         key: key,
         description: description
     }, {silentNotification: silentNotification});
 }


 registerEvent('Contact Us', 'contact_us', 'Customers who clicked on Contact Us');
 registerEvent('Purchase', 'purchase', 'Customers who clicked on Purchase');
 registerEvent('Add To Cart', 'add_to_cart', 'Customers who clicked on Add To Cart');
 registerEvent('Help', 'help', 'Customers who clicked on Help');

Once you register your plugins in the control side, the customers will see a notification in the Analytics tab, to inform them that there is a new event registered to the plugin, so they can check the reports related to the new event.

Notification

buildfire.analytics.unregisterEvent(key,callback);

This function used to unregister an event for your plugin.

You can use this in the Control Side only.

arguments

  • key: Your plugin event key. (String)

  • callback(err,result): (Function)

Example (Control Side):

//unregister plugin events for analytics
buildfire.analytics.unregisterEvent('contact_us');
buildfire.analytics.unregisterEvent('purchase');
buildfire.analytics.unregisterEvent('add_to_cart');
buildfire.analytics.unregisterEvent('help');

buildfire.analytics.showReports(params, callback);

This function used to show the analytic reports for specific event.

You can use this in the Control Side only.

arguments

  • params: (Object)

    • eventKey: The Unique key for the registered event. (String)
  • callback(err,result): (Function)

Example (Control Side):

//show reports for specific event
buildfire.analytics.showReports({key:'contact_us'});
Clone this wiki locally