Skip to content

Instantly share code, notes, and snippets.

@thomasplevy
Created May 9, 2019 19:55
Show Gist options
  • Save thomasplevy/8dfff9bb60b548f5b09142e1001ea351 to your computer and use it in GitHub Desktop.
Save thomasplevy/8dfff9bb60b548f5b09142e1001ea351 to your computer and use it in GitHub Desktop.
WIP: JS Local Storage user interaction/event tracking for LifterLMS
/**
* Store information in Local Storage by group.
*
* @since [version]
*
* @param string group Storage group id/name.
*/
var Storage = function( group ) {
var store = window.localStorage;
/**
* Retrieve (and parse) all data stored for the group.
*
* @since [version]
*
* @return obj
*/
function getAll() {
return JSON.parse( store.getItem( group ) ) || {};
}
/**
* Store an item in the group by key.
*
* @since [version]
*
* @param string key Item key name.
* @param mixed val Item value
* @return void
*/
this.set = function( key, val ) {
var data = getAll();
data[ key ] = val;
store.setItem( group, JSON.stringify( data ) );
};
/**
* Retrieve an item from the group by key.
*
* @since [version]
*
* @param string key Item key/name.
* @param mixed default_val Item default value to be returned when item not found in the group.
* @return mixed
*/
this.get = function( key, default_val ) {
var data = getAll();
return data[ key ] ? data[ key ] : default_val;
}
}
/**
* User event/interaction tracking.
*
* @since [version]
*
* @see {Reference}
* @link {URL}
*/
var Tracking = function() {
var self = this,
store = new Storage( 'llms-tracking' );
/**
* Initialize / Bind all tracking event listeners.
*
* @since [version]
*
* @return {[type]}
*/
function init() {
console.log( store.get( 'events' ) );
// Page load event goes in here since this all loads on page load.
self.addEvent( 'page.load' );
// Other event listeners.
window.addEventListener( 'beforeunload', onBeforeUnload );
window.addEventListener( 'unload', onUnload );
document.addEventListener( 'visibilitychange', onVisibilityChange );
};
/**
* Add an event.
*
* @since [version]
*
* @param string|obj event Event Id (type.event) as a full event object from `this.makeEventObj()`.
* @param int obj_id Optional object ID.
*/
this.addEvent = function( event, obj_id ) {
event = 'string' === typeof event ? self.makeEventObj( event, obj_id ) : event;
var all = store.get( 'events', [] );
all.push( event );
store.set( 'events', all );
}
/**
* Create an event object suitable to save as an event.
*
* @since [version]
*
* @param string event Event id (type.event) EG: `page.load`.
* @param int obj_id Optional object ID.
* @return obj
*/
this.makeEventObj = function( event, obj_id ) {
return {
obj_id: obj_id,
url: window.location.href,
event: event,
time: new Date().getTime() / 1000,
};
}
/**
* Remove the visibility change event listener on window.beforeunload
*
* Prevents actual unloading from recording a blur event from the visibility change listener
*
* @since [version]
*
* @param obj e JS event object.
* @return void
*/
function onBeforeUnload( e ) {
document.removeEventListener( 'visibilitychange', onVisibilityChange );
}
/**
* Record a `page.exit` event on window.unload.
*
* @since [version]
*
* @param obj e JS event object.
* @return void
*/
function onUnload( e ) {
self.addEvent( 'page.exit' );
}
/**
* Record `page.blur` and `page.focus` events via document.visilibitychange events.
*
* @since [version]
*
* @param obj e JS event object.
* @return void
*/
function onVisibilityChange( e ) {
var event = document.hidden ? 'page.blur' : 'page.focus';
self.addEvent( event );
}
// Go.
init();
};
LLMS.Tracking = new Tracking();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment