switch web analytics from ga to segment

This commit is contained in:
Jeff Escalante 2018-03-08 15:48:43 -05:00
parent 9bef659c14
commit db959c16c5
8 changed files with 49 additions and 21 deletions

View File

@ -1,3 +1,3 @@
source "https://rubygems.org" source "https://rubygems.org"
gem "middleman-hashicorp", "~> 0.3.30" gem "middleman-hashicorp", "0.3.35"

View File

@ -6,7 +6,7 @@ GEM
minitest (~> 5.1) minitest (~> 5.1)
thread_safe (~> 0.3, >= 0.3.4) thread_safe (~> 0.3, >= 0.3.4)
tzinfo (~> 1.1) tzinfo (~> 1.1)
autoprefixer-rails (8.1.0.1) autoprefixer-rails (8.2.0)
execjs execjs
bootstrap-sass (3.3.7) bootstrap-sass (3.3.7)
autoprefixer-rails (>= 5.2.1) autoprefixer-rails (>= 5.2.1)
@ -113,9 +113,9 @@ GEM
padrino-support (0.12.9) padrino-support (0.12.9)
activesupport (>= 3.1) activesupport (>= 3.1)
rack (1.6.9) rack (1.6.9)
rack-livereload (0.3.16) rack-livereload (0.3.17)
rack rack
rack-test (0.8.3) rack-test (1.0.0)
rack (>= 1.0, < 3) rack (>= 1.0, < 3)
rb-fsevent (0.10.3) rb-fsevent (0.10.3)
rb-inotify (0.9.10) rb-inotify (0.9.10)
@ -153,7 +153,7 @@ PLATFORMS
ruby ruby
DEPENDENCIES DEPENDENCIES
middleman-hashicorp (~> 0.3.30) middleman-hashicorp (= 0.3.35)
BUNDLED WITH BUNDLED WITH
1.16.1 1.16.1

View File

@ -1,4 +1,4 @@
VERSION?="0.3.29" VERSION?="0.3.35"
build: build:
@echo "==> Starting build in Docker..." @echo "==> Starting build in Docker..."
@ -7,6 +7,7 @@ build:
--rm \ --rm \
--tty \ --tty \
--volume "$(shell pwd):/website" \ --volume "$(shell pwd):/website" \
-e "ENV=production" \
hashicorp/middleman-hashicorp:${VERSION} \ hashicorp/middleman-hashicorp:${VERSION} \
bundle exec middleman build --verbose --clean bundle exec middleman build --verbose --clean

View File

@ -11,6 +11,16 @@ activate :hashicorp do |h|
end end
helpers do helpers do
# Returns a segment tracking ID such that local development is not
# tracked to production systems.
def segmentId()
if (ENV['ENV'] == 'production')
'wFMyBE4PJCZttWfu0pNhYdWr7ygW0io4'
else
'0EXTgkNx0Ydje2PGXVbRhpKKoe5wtzcE'
end
end
# Returns the FQDN of the image URL. # Returns the FQDN of the image URL.
# #
# @param [String] path # @param [String] path

View File

@ -3,6 +3,7 @@
"aws_access_key_id": "{{ env `AWS_ACCESS_KEY_ID` }}", "aws_access_key_id": "{{ env `AWS_ACCESS_KEY_ID` }}",
"aws_secret_access_key": "{{ env `AWS_SECRET_ACCESS_KEY` }}", "aws_secret_access_key": "{{ env `AWS_SECRET_ACCESS_KEY` }}",
"aws_region": "{{ env `AWS_REGION` }}", "aws_region": "{{ env `AWS_REGION` }}",
"website_environment": "production",
"fastly_api_key": "{{ env `FASTLY_API_KEY` }}" "fastly_api_key": "{{ env `FASTLY_API_KEY` }}"
}, },
"builders": [ "builders": [
@ -22,6 +23,7 @@
"AWS_ACCESS_KEY_ID={{ user `aws_access_key_id` }}", "AWS_ACCESS_KEY_ID={{ user `aws_access_key_id` }}",
"AWS_SECRET_ACCESS_KEY={{ user `aws_secret_access_key` }}", "AWS_SECRET_ACCESS_KEY={{ user `aws_secret_access_key` }}",
"AWS_REGION={{ user `aws_region` }}", "AWS_REGION={{ user `aws_region` }}",
"ENV={{ user `website_environment` }}",
"FASTLY_API_KEY={{ user `fastly_api_key` }}" "FASTLY_API_KEY={{ user `fastly_api_key` }}"
], ],
"inline": [ "inline": [

View File

@ -0,0 +1,14 @@
document.addEventListener('DOMContentLoaded', function() {
track('.downloads .download .details li a', function(el) {
var m = el.href.match(/vagrant_(.*?)_(.*?)_(.*?)\.zip/)
return {
event: 'Download',
category: 'Button',
label: 'Vagrant | v' + m[1] + ' | ' + m[2] + ' | ' + m[3],
version: m[1],
os: m[2],
architecture: m[3],
product: 'vagrant'
}
})
})

View File

@ -3,5 +3,7 @@
//= require hashicorp/mega-nav //= require hashicorp/mega-nav
//= require hashicorp/sidebar //= require hashicorp/sidebar
//= require hashicorp/analytics
//= require _vmware //= require _vmware
//= require analytics

View File

@ -34,13 +34,6 @@
<![endif]--> <![endif]-->
<%= javascript_include_tag "application" %> <%= javascript_include_tag "application" %>
<!-- Google Tag Manager -->
<script>(function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start':
new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0],
j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src=
'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f);
})(window,document,'script','dataLayer','GTM-NR2SD7C');</script>
<!-- Typekit script to import Klavika font --> <!-- Typekit script to import Klavika font -->
<script src="https://use.typekit.net/wxf7mfi.js"></script> <script src="https://use.typekit.net/wxf7mfi.js"></script>
<script>try{Typekit.load({ async: true });}catch(e){}</script> <script>try{Typekit.load({ async: true });}catch(e){}</script>
@ -121,14 +114,20 @@
</div> </div>
<script> <script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ // ga async load
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), window['GoogleAnalyticsObject'] = 'ga';
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) window['ga'] = window['ga'] || function() {
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); (window['ga'].q = window['ga'].q || []).push(arguments)
};
ga('create', 'UA-15091924-1', 'vagrantup.com'); // analytics.js
ga('require', 'linkid'); !function(){var analytics=window.analytics=window.analytics||[];if(!analytics.initialize)if(analytics.invoked)window.console&&console.error&&console.error("Segment snippet included twice.");else{analytics.invoked=!0;analytics.methods=["trackSubmit","trackClick","trackLink","trackForm","pageview","identify","reset","group","track","ready","alias","debug","page","once","off","on"];analytics.factory=function(t){return function(){var e=Array.prototype.slice.call(arguments);e.unshift(t);analytics.push(e);return analytics}};for(var t=0;t<analytics.methods.length;t++){var e=analytics.methods[t];analytics[e]=analytics.factory(e)}analytics.load=function(t){var e=document.createElement("script");e.type="text/javascript";e.async=!0;e.src=("https:"===document.location.protocol?"https://":"http://")+"cdn.segment.com/analytics.js/v1/"+t+"/analytics.min.js";var n=document.getElementsByTagName("script")[0];n.parentNode.insertBefore(e,n)};analytics.SNIPPET_VERSION="4.0.0";
ga('send', 'pageview', location.pathname); analytics.load("<%= segmentId %>");
analytics.page();
}}();
// optinmonster
var om597a24292a958,om597a24292a958_poll=function(){var b=0;return function(d,c){clearInterval(b);b=setInterval(d,c)}}();
!function(b,d,c){if(b.getElementById(c))om597a24292a958_poll(function(){if(window.om_loaded&&!om597a24292a958)return om597a24292a958=new OptinMonsterApp,om597a24292a958.init({s:"35109.597a24292a958",staging:0,dev:0,beta:0})},25);else{var e=!1,a=b.createElement(d);a.id=c;a.src="//a.optnmstr.com/app/js/api.min.js";a.async=!0;a.onload=a.onreadystatechange=function(){if(!(e||this.readyState&&"loaded"!==this.readyState&&"complete"!==this.readyState))try{e=om_loaded=!0,om597a24292a958=new OptinMonsterApp,
om597a24292a958.init({s:"35109.597a24292a958",staging:0,dev:0,beta:0}),a.onload=a.onreadystatechange=null}catch(f){}};(document.getElementsByTagName("head")[0]||document.documentElement).appendChild(a)}}(document,"script","omapi-script");
</script> </script>
<script type="application/ld+json"> <script type="application/ld+json">