I am following this example here for the Google Analytics Embed API to implement a GA third party dashboard via Chart.js in my app and I am having trouble on Step 3
where we are including all the javascript libraries.
I was able to load the Embed API in my application.js
as so
(function(w,d,s,g,js,fs){
g=w.gapi||(w.gapi={});g.analytics={q:[],ready:function(f){this.q.push(f);}};
js=d.createElement(s);fs=d.getElementsByTagName(s)[0];
js.src='https://apis.google.com/js/platform.js';
fs.parentNode.insertBefore(js,fs);js.onload=function(){g.load('analytics');};
}(window,document,'script'));
//= require /public/javascript/Chart.min.j
//= require /public/javascript/moment.min.js
//= require /public/javascript/embed-api/date-range-selector.js
//= require /public/javascript/embed-api/active-users.js
It shows in Networks
section in the dev tools that the cb=gapi.loaded_0
is getting loaded. However, the other libraries are not. Charts.min.js
and moments.min.js
are available online but I wan't sure where I can find embed-api/date-range-selector.js
or embed-api/active-users.js
to retrieve into my app?
EDIT1 Found the files here: https://github.com/googleanalytics/ga-dev-tools
I did about the same thing in Rails Admin.
First of all I did this Rails Admin Customization: embed html view into dashboard but I think it can be any view you like.
In this .html.erb file I have inserted the GA code from their website:
Next I added all the GA JS and CSS and HTML to Vendor:
I hope this helps :)
EDIT1: More information about GA Dashboarding is found here: https://ga-dev-tools.appspot.com/embed-api/
I could be wrong, but I believe the Rails asset pipeline needs to have some sort of
//= require_self
or something like that to ensure the code in the current file is included. It looks to me like the loading snippet in that file isn't being run or is being run in the wrong order.It's probably easier and simpler to just save it into a separate file so you can ensure the order is correct.
Then put the rest of your code in a setup file like so:
Now your manifest should look like this:
Also, you said:
Actually, the
gapi.analytics.auth.authorize
part is not in theActiveUsers
component, the auth part is something you have to write yourself (because the client ID needs to be specific to you), and it should go in theembed-api-setup.js
file as I've described above.The setup code for the example you're referencing can be found here.