How do you run Google Charts locally?
Asked Answered
A

3

6

I am looking at using Google Charts to have scatter plot. All of the examples have external dependency, and I would like to avoid that as this is an intranet application that doesn't have external Internet access.

<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
 <script type="text/javascript">
   google.charts.load('current', {packages: ['corechart']});
   google.charts.setOnLoadCallback(drawChart);
...
</script>

Can I simply just copy loader.js locally or is there something more complicated that I need to worry about here? The reason I ask is that I tried doing that and it's not working so I am trying to figure out if what I am doing is fundamentally flawed or I might have an unrelated issue.

Anabelanabella answered 16/12, 2016 at 14:36 Comment(2)
When I implement JQuery's DatePicker offiline,I had to check in the .css file because the file has relatives URL's to images, I say this because you can check the downloaded files (js, css, etc) and check if those has other (online) references. Also, I suggest you make this test: run your example and check the navigation and console tabs (F12 developer tool) and check if there are lost requests and or errors. Hope it helps.Bent
I would use a javascript charting library such as d3 (free), jqplot (free) or highcharts (pay)Undercarriage
Q
9

No. It is not allowed per the Google agreements https://developers.google.com/chart/interactive/faq

Off line use is not allowed.

Qp answered 17/12, 2016 at 18:14 Comment(2)
Although this is the right answer, I do find Google linking to developer terms a bit misleading since the also clearly state that this is licensed under the Creative Commons Attribution 3.0 License creativecommons.org/licenses/by/3.0 which not only would allow you to load it locally but also allow you to freely change it to your liking.Delbert
It's interesting that Google, again, hits it's own legs. Their CSP Evaluator tool raises as high risk of allowing www.gstatic.com on script-src in Content Security PolicyNotice
H
4

You should be able to run charts/loader.js locally and have it work just fine. I just copied and pasted its contents into a new js file and my charts rendered as normal.

The source code is too large for me to use as a snippet in the answer, but here's a working fiddle that uses the pasted code from charts/loader.js to create a table: https://jsfiddle.net/q078fvw1/

If you right click on the file in your header that reads

<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>

This ought to work.

If not, then it's probably something on your system that's causing the interference.

Edit: While my answer might be literally correct vis a vis being able to use the source code locally, I wasn't making any recommendations with regards to whether or not this is the best thing to do.

As another poster pointed out, if it's in their service agreement not to use it locally then it's wise to comply with their terms.

Howlyn answered 17/12, 2016 at 18:34 Comment(2)
I'm not so sure since they also clearly state it is released under the Creative Commons Attribution 3.0 License creativecommons.org/licenses/by/3.0 which not only would allow you to load it locally but also allow you to freely change it to your liking.Delbert
"You should be able to run charts/loader.js locally and have it work just fine." is technically correct... but that Google Charts loader will load a couple of other JavaScript assets - hence the name "loader". Those assets still will be requested from https://www.gstatic.com (if you didn't modify loader.js). Nevertheless, hosting Google Charts library files locally is against the ToS.Jeramie
B
2

No you can not check the url and attach imageScreenshot of google faq Google FAQ

Bustamante answered 11/9, 2019 at 4:57 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.