Beautifully crafted timelines that are easy and intuitive to use. http://timeline.knightlab.com/
221 lines
5.9 KiB
221 lines
5.9 KiB
/* Support Timeline Embed Generator web form (becomes storyjs-embed-generator.js) */ |
|
if(typeof generator_embed_path == 'undefined' || typeof generator_embed_path == 'undefined') { |
|
// REPLACE WITH YOUR BASEPATH IF YOU WANT OTHERWISE IT WILL TRY AND FIGURE IT OUT |
|
var generator_embed_path = getScriptPath("storyjs-embed-generator.js").split("js/")[0]; |
|
if (generator_embed_path.match("http")) { |
|
generator_embed_path = generator_embed_path; |
|
} else if (generator_embed_path == "/") { |
|
generator_embed_path = "index.html"; |
|
} else { |
|
generator_embed_path = generator_embed_path + "index.html"; |
|
} |
|
} |
|
function getScriptPath(scriptname) { |
|
var scriptTags = document.getElementsByTagName('script'), |
|
script_path = ""; |
|
for(var i = 0; i < scriptTags.length; i++) { |
|
if (scriptTags[i].src.match(scriptname)) { |
|
script_path = scriptTags[i].src; |
|
} |
|
} |
|
return script_path.split('?')[0].split('/').slice(0, -1).join('/') + '/'; |
|
} |
|
|
|
|
|
/* EXTRA |
|
================================================== */ |
|
function getUrlVars(string) { |
|
var vars = [], |
|
hash, |
|
hashes, |
|
str = string.toString(); |
|
|
|
if (str.match('&')) { |
|
str = str.replace("&", "&"); |
|
} else if (str.match('&')) { |
|
str = str.replace("&", "&"); |
|
} else if (str.match('&')) { |
|
str = str.replace("&", "&"); |
|
} |
|
if (str.match('#')) { |
|
str = str.split('#')[0]; |
|
} |
|
hashes = str.slice(str.indexOf('?') + 1).split('&'); |
|
|
|
for(var i = 0; i < hashes.length; i++) { |
|
hash = hashes[i].split('='); |
|
vars.push(hash[0]); |
|
vars[hash[0]] = hash[1]; |
|
} |
|
|
|
return vars; |
|
}; |
|
|
|
function getLinkAndIframe() { |
|
|
|
var theobj = {}, |
|
e_source = document.getElementById('embed-source-url'), |
|
e_width = document.getElementById('embed-width'), |
|
e_height = document.getElementById('embed-height'), |
|
e_maptype = document.getElementById('embed-maptype'), |
|
e_language = document.getElementById('embed-language'), |
|
e_embed = document.getElementById('embed_code'), |
|
e_font = document.getElementById('embed-font'), |
|
e_wordpress = document.getElementById('embed-wordpressplugin'), |
|
e_startatend = document.getElementById('embed-startatend'), |
|
e_hashbookmark = document.getElementById('embed-hashbookmark'), |
|
e_startzoomadjust = document.getElementById('embed-startzoomadjust'), |
|
e_startatslide = document.getElementById('embed-startatslide'), |
|
e_debug = document.getElementById('embed-debug'), |
|
e_googlemapkey = document.getElementById('embed-googlemapkey'), |
|
start_at_end = false, |
|
hash_bookmark = false, |
|
is_debug = false, |
|
iframe, |
|
link, |
|
vars, |
|
wp, |
|
source_key; |
|
|
|
/* SOURCE KEY |
|
================================================== */ |
|
if (e_source.value.match("docs.google.com")) { |
|
source_key = getUrlVars(e_source.value)["key"]; |
|
} else { |
|
if (e_source.value == "") { |
|
source_key = "0Agl_Dv6iEbDadHdKcHlHcTB5bzhvbF9iTWwyMmJHdkE" |
|
} else { |
|
source_key = e_source.value; |
|
} |
|
} |
|
|
|
/* START AT END |
|
================================================== */ |
|
if (e_startatend.checked) { |
|
start_at_end = true; |
|
} |
|
|
|
/* HASH BOOKMARK |
|
================================================== */ |
|
if (e_hashbookmark.checked) { |
|
hash_bookmark = true; |
|
} |
|
|
|
/* DEBUG |
|
================================================== */ |
|
if (e_debug.checked) { |
|
is_debug = true; |
|
} |
|
|
|
/* WORDPRESS |
|
================================================== */ |
|
wp = "[timeline "; |
|
if (e_width.value > 0) { |
|
wp += "width='" + e_width.value + "' "; |
|
} |
|
if (e_height.value > 0) { |
|
wp += "height='" + e_width.value + "' "; |
|
} |
|
|
|
wp += "font='" + e_font.value + "' "; |
|
wp += "maptype='" + e_maptype.value + "' "; |
|
wp += "lang='" + e_language.value + "' "; |
|
wp += "src='" + e_source.value + "' "; |
|
if (start_at_end) { |
|
wp += "start_at_end='" + start_at_end + "' "; |
|
} |
|
if (hash_bookmark) { |
|
wp += "hash_bookmark='" + hash_bookmark + "' "; |
|
} |
|
if (is_debug) { |
|
wp += "debug='" + is_debug + "' "; |
|
} |
|
|
|
if (e_googlemapkey.value != "") { |
|
wp += "gmap_key='" + e_googlemapkey.value + "' "; |
|
} |
|
|
|
if (parseInt(e_startatslide.value, 10) > 0) { |
|
wp += "start_at_slide='" + parseInt(e_startatslide.value, 10) + "' "; |
|
} |
|
if (parseInt(e_startzoomadjust.value, 10) > 0) { |
|
wp += "start_zoom_adjust='" + parseInt(e_startzoomadjust.value, 10) + "' "; |
|
} |
|
|
|
wp += "]"; |
|
|
|
theobj.wordpress = wp; |
|
|
|
/* IFRAME AND LINK |
|
================================================== */ |
|
vars = generator_embed_path + "?source=" + source_key; |
|
vars += "&font=" + e_font.value; |
|
vars += "&maptype=" + e_maptype.value; |
|
vars += "&lang=" + e_language.value; |
|
if (start_at_end) { |
|
vars += "&start_at_end=" + start_at_end; |
|
} |
|
if (hash_bookmark) { |
|
vars += "&hash_bookmark=" + hash_bookmark; |
|
} |
|
if (is_debug) { |
|
vars += "&debug=" + is_debug; |
|
} |
|
|
|
if (parseInt(e_startatslide.value, 10) > 0) { |
|
vars += "&start_at_slide=" + parseInt(e_startatslide.value, 10); |
|
} |
|
|
|
if (parseInt(e_startzoomadjust.value, 10) > 0) { |
|
vars += "&start_zoom_adjust=" + parseInt(e_startzoomadjust.value, 10); |
|
} |
|
|
|
if (e_googlemapkey.value != "") { |
|
vars += "&gmap_key=" + e_googlemapkey.value; |
|
} |
|
|
|
if (e_width.value > 0) { |
|
vars += "&width=" + e_width.value; |
|
} |
|
if (e_height.value > 0) { |
|
vars += "&height=" + e_height.value; |
|
} |
|
|
|
iframe = "<iframe src='" + vars + "'"; |
|
|
|
if (e_width.value > 0 || e_width.value.match("%")) { |
|
iframe += " width='" + e_width.value + "'"; |
|
} |
|
if (e_height.value > 0 || e_height.value.match("%")) { |
|
iframe += " height='" + e_height.value + "'"; |
|
} |
|
iframe += " frameborder='0'></iframe>"; |
|
|
|
theobj.iframe = iframe; |
|
theobj.link = vars; |
|
|
|
if (e_wordpress.checked) { |
|
theobj.copybox = wp; |
|
} else { |
|
theobj.copybox = iframe; |
|
} |
|
|
|
return theobj; |
|
}; |
|
|
|
/* EMBED GENERATOR |
|
================================================== */ |
|
function updateEmbedCode(element, options) { |
|
|
|
var e_embed = document.getElementById('embed_code'), |
|
el = getLinkAndIframe(); |
|
|
|
e_embed.value = el.copybox; |
|
jQuery("#preview-embed-link").attr('href', el.link); |
|
jQuery("#preview-embed-iframe").html(el.iframe); |
|
jQuery("#preview-embed").css("display","block"); |
|
|
|
} |
|
|
|
|
|
|
|
|