Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bazaarvoice/api-analytics
API Analytics
https://github.com/bazaarvoice/api-analytics
Last synced: 3 months ago
JSON representation
API Analytics
- Host: GitHub
- URL: https://github.com/bazaarvoice/api-analytics
- Owner: bazaarvoice
- License: other
- Created: 2015-06-10T21:50:16.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2018-10-09T17:57:01.000Z (over 6 years ago)
- Last Synced: 2023-04-14T14:40:45.101Z (almost 2 years ago)
- Language: CSS
- Size: 798 KB
- Stars: 1
- Watchers: 7
- Forks: 4
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: Contributing.md
- License: LICENSE.md
Awesome Lists containing this project
README
Bazaarvoice API Analytics starter kit
================The Bazaarvoice API Analytics starter kit is a sample consisting of static HTML, CSS, and js that demonstrates how API users should implement the required analytics tags when using the Bazaarvoice API.
Before Downloading:
-------------
1. Implementing the API Analytics Tags is required according to the [API terms and conditions](http://www.bazaarvoice.com/legal/conversations-api-terms-of-use.html)
2. Read the [API Analytics tutorial](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel) documentation. Developers should also be familiar with the [API Terms of Use](http://www.bazaarvoice.com/legal/api-terms-of-use.html).
3. Install the [Bazaarvoice Analytics Inspector for Chrome](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd).
4. The code in this GitHub repo is also [hosted on a web server](http://api-analytics-kit.bazaarvoice.com/). Both the [product description page](http://api-analytics-kit.bazaarvoice.com/) and the [conversion page](http://api-analytics-kit.bazaarvoice.com/conversion.html) can be considered working samples of the API Analytics starter kit. Users should interact with the pages with the [Bazaarvoice Analytics Inspector for Chrome](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd) enabled to help understand the implementation.
5. Realize that the starter kit is meant as a sample. It is static, and by no means optimized for speed and scale. There are no calls made to the Conversations API to get product data. The key/value are hard coded in the js file. The code is provided as a means to help API users better understand API analytics.What is the sample doing?
-------------------------
This tutorial captures a user's actions on the product details page. Accompanying the code on the product details page, is code associated with the conversion event. Bazaarvoice supports various definitions of conversion, both non-commercial conversion and traditional e-commerce conversion. By connecting the user's behavior on the product details page to the conversion page, we are able to track the site conversion rate of those who have interacted with user generated content.All this is accomplished by adding code that captures how user's interact with the consumer generated content. User events (e.g. viewing the page, scrolling the page, and interacting with the different web inputs) should all be captured within the site. Attaching client-side javascript code to these different events is the responsibility of the site developer.
After the custom code capturing the different parameters is completed and associated with HTML event, the final step is a simple call using the [Bazaarvoice API Tracker library](http://analytics-static.ugc.bazaarvoice.com/prod/static/latest/bv-analytics.js). This is injected onto the page by the Bazaarvoice scoutfile, which is required. To find out more, contact us at [email protected].
The tracking code requires 2 arguments:
- the tag name
- an object containing the key/value pairs.
The following samples demonstrate some of the analytic calls:
```js
BV.pixel.trackViewedCGC(InViewData, {
minPixels: 100,
minTime: 5000,
containerId: 'CGC_Container'
});
BV.pixel.trackEvent('Feature', {
type: 'Used',
name: name,
brand: featureObject.brand,
productId: featureObject.productId,
bvProduct: null,
categoryId: featureObject.categoryId,
detail1: detail1,
detail2: detail2
});
BV.pixel.trackConversion(conversionData);
BV.pixel.trackTransaction(transactionData);
```
The [bv-analytics.js](http://analytics-static.ugc.bazaarvoice.com/prod/static/latest/bv-analytics.js) file send the analytics data to Bazaarvoice servers after collecting from the product details page and the user defined 'conversion' page.
#### Sample Product Details Page
The javascript on the [sample product description page](http://api-analytics-kit.bazaarvoice.com/) listens for different events. The API Analytics code executes when they occur. The required analytics tags are required for each Bazaarvoice API instance.
##### [Page View Product](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/product-display-page-overview)
Each time a product details page is rendered, the transaction analytics tag '[page view product](https://developer.bazaarvoice.com/conversations-api/tutorials/analytics#page-view-product)' is executed. In this sample, the '[page view product](https://github.com/bazaarvoice/api-analytics/blob/master/js/main.js#L51-L53)' is associated with the page load event. When page load is complete, the analytics code is called and passes an object. The object's key/values pairs are [hard coded](https://github.com/bazaarvoice/api-analytics/blob/master/js/main.js#L2-L14) and are not obtained from a Conversations API call.
___
##### [Feature Used in View](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/product-display-page-overview/featured-used-events)
Not all Product Details Pages have Consumer Generated Content (CGC) within the browser's viewable area when the page is rendered. Often, users must scroll to view the CGC. As part of the API Analytics requirements, when the CGC comes in view, must also be captured. This is done by calling the transactional analytics tag '[feature used in view](https://github.com/bazaarvoice/api-analytics/blob/master/js/main.js#L46)'. This object's key/value pairs differs slightly from the previous 'page view product' by:
1. having additional keys that identify the CGC container Id
2. allow to specify the minimum pixel height that must be viewed before executing
3. specifying a time (milliseconds) the CGC container must be viewed before executing
___
##### [Feature Used](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/product-display-page-overview/featured-used-events)
Event handlers are also attached to the various CGC inputs. This aims to capture how users interact with the Conversations data. In order to complete this.
Included in the sample are:
1. Clicking "Show/Hide Filter"
2. Selecting an Age or Gender sub-filter
3. Clicking "Write a Review"
4. Interacting with the "Sort"
5. Expanding/contracting the "Read more/less"
6. Voting if the review was helpful
7. Reporting the review
8. Clicking the pagination
9. Clicking the "See All" button
10. Clicking the "Staff" button
___
#### Conversion Page
The [conversion page](http://api-analytics-kit.bazaarvoice.com/conversion.html) simulates a page a user would reach upon completing a purchase. With conversion complete, the conversion analytic tags are executed. Both the '[ConversionTransaction](https://github.com/bazaarvoice/api-analytics/blob/master/js/conversion.js#L32-L33)' and the '[PIIConversionTransaction](https://github.com/bazaarvoice/api-analytics/blob/master/js/conversion.js#L32-L33)' are called in this sample. At a minimim one of the three conversion tags must be included in each Bazaarvoice API instance.
##### [ConversionTransaction](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/transaction-conversion-overview/ecommerce-transactions)
##### [PIIConversionTransaction](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/transaction-conversion-overview/non-commerce-conversions)
##### [Non Transactional Conversion](https://developer.bazaarvoice.com/conversations-api/tutorials/bv-pixel/transaction-conversion-overview/non-commerce-conversions)
Hosted Sample:
---------------
In addition to providing the starter kit for download, the tutorial is hosted for client interaction.
First, download and install the [Bazaarvoice Analytics Inspector for Chrome](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd). Once install you will see the Analytics Inspector icon in the Chrome browser.
Next, visit the product description page [hosted API Analytics solutions](http://api-analytics-kit.bazaarvoice.com/). Open the [Bazaarvoice Analytics Inspector](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd) and interact with the page. The tool documents each time an analytics event is captured and sent to Bazaarvoice. Notice the red counter on the icon.
Scroll and click different HTML inputs. Notice Feature events being populated. Event handlers are attached to several HTML inputs which in-turn queue the analytics code.
Also available within the hosted site is a sample [conversion](http://api-analytics-kit.bazaarvoice.com/conversion.html) page. Again open the page in a browser with the [Bazaarvoice Analytics Inspector](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd) open. The analytics on this page are executed on page load. There are several options available for defining and capturing conversion events. Conversion is described in detail in the [conversion analytics tags](https://developer.bazaarvoice.com/apis/conversations/tutorials/analytics#conversion-analytics-tags) section.
Console logs are displayed because within the [hosted API Analytics solutions](http://api-analytics-kit.bazaarvoice.com/) the 'environment' variable is set to ['staging'](https://github.com/bazaarvoice/api-analytics/blob/master/js/main.js#L3). This flag is used in the js code to enable console.logs. When the 'environment' flag is set to anything else (including the other accepted value 'production') logging will not occur.
Things to Note
----------------
This sample does not make API calls to retrieve and bind client data. Values that should be obtained from the API are hard coded in the HTML and js files. Comments have been added where the values should be obtained from the API.
The sample works in conjunction with the [Bazaarvoice Analytics Inspector](https://chrome.google.com/webstore/detail/bazaarvoice-analytics-ins/olmofcadoappjkcnnhomdlnpmpbleekd) to aid clients in making sure the implementation is complete.
It is required that a Bazaarvoice team member verify the completion of each implementation.