Merge pull request #272 from Michael-F-Bryan/google-analytics

Support for Google Analytics
This commit is contained in:
Mathieu David 2017-05-16 09:13:57 +02:00 committed by GitHub
commit 4ad6fab5e3
5 changed files with 50 additions and 0 deletions

View file

@ -21,6 +21,7 @@ pub struct BookConfig {
pub indent_spaces: i32, pub indent_spaces: i32,
multilingual: bool, multilingual: bool,
pub google_analytics: Option<String>,
} }
impl BookConfig { impl BookConfig {
@ -37,6 +38,7 @@ impl BookConfig {
indent_spaces: 4, // indentation used for SUMMARY.md indent_spaces: 4, // indentation used for SUMMARY.md
multilingual: false, multilingual: false,
google_analytics: None,
} }
} }
@ -154,6 +156,11 @@ impl BookConfig {
self.set_theme_path(&theme_path); self.set_theme_path(&theme_path);
} }
// Google analytics code
if let Some(id) = config.get("google_analytics_id") {
self.google_analytics = Some(id.to_string().replace("\"", ""));
}
self self
} }

View file

@ -347,3 +347,25 @@ fn it_parses_json_arrays_to_toml() {
assert_eq!(format!("{:#?}", result), expected); assert_eq!(format!("{:#?}", result), expected);
} }
#[test]
fn it_fetches_google_analytics_from_toml() {
let text = r#"
title = "mdBook Documentation"
description = "Create book from markdown files. Like Gitbook but implemented in Rust"
author = "Mathieu David"
google_analytics_id = "123456"
"#;
let mut config = BookConfig::new(Path::new("."));
config.parse_from_toml_string(&text.to_string());
let mut expected = BookConfig::new(Path::new("."));
expected.title = "mdBook Documentation".to_string();
expected.author = "Mathieu David".to_string();
expected.description = "Create book from markdown files. Like Gitbook but implemented in Rust".to_string();
expected.google_analytics = Some("123456".to_string());
assert_eq!(format!("{:#?}", config), format!("{:#?}", expected));
}

View file

@ -36,6 +36,8 @@ pub struct MDBook {
/// Should `mdbook build` create files referenced from SUMMARY.md if they /// Should `mdbook build` create files referenced from SUMMARY.md if they
/// don't exist /// don't exist
pub create_missing: bool, pub create_missing: bool,
pub google_analytics: Option<String>,
} }
impl MDBook { impl MDBook {
@ -84,6 +86,7 @@ impl MDBook {
livereload: None, livereload: None,
create_missing: true, create_missing: true,
google_analytics: None,
} }
} }

View file

@ -193,6 +193,11 @@ fn make_data(book: &MDBook) -> Result<serde_json::Map<String, serde_json::Value>
data.insert("livereload".to_owned(), json!(livereload)); data.insert("livereload".to_owned(), json!(livereload));
} }
// Add google analytics tag
if let Some(ref ga) = book.google_analytics {
data.insert("google_analytics".to_owned(), json!(ga));
}
let mut chapters = vec![]; let mut chapters = vec![];
for item in book.iter() { for item in book.iter() {

View file

@ -111,6 +111,19 @@
<!-- Livereload script (if served using the cli tool) --> <!-- Livereload script (if served using the cli tool) -->
{{{livereload}}} {{{livereload}}}
{{#if google_analytics}}
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
ga('create', '{{google_analytics}}', 'auto');
ga('send', 'pageview');
</script>
{{/if}}
<script src="highlight.js"></script> <script src="highlight.js"></script>
<script src="book.js"></script> <script src="book.js"></script>
</body> </body>