/ * V e r i t e
* Verite JS Master
* Version : 0.1
* Date : December 12 , 2011
* Copyright 2011 Verite
* Designed and built by Zach Wise digitalartwork . net
* -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- -- - * /
/ * C o d e K i t I m p o r t
=== === === === === === === === === === === === === === === === == * /
/ * S i m p l e J a v a S c r i p t I n h e r i t a n c e
* By John Resig http : //ejohn.org/
* MIT Licensed .
=== === === === === === === === === === === === === === === === == * /
( function ( ) {
var initializing = false , fnTest = /xyz/ . test ( function ( ) { xyz ; } ) ? /\b_super\b/ : /.*/ ;
// The base Class implementation (does nothing)
this . Class = function ( ) { } ;
// Create a new Class that inherits from this class
Class . extend = function ( prop ) {
var _super = this . prototype ;
// Instantiate a base class (but only create the instance,
// don't run the init constructor)
initializing = true ;
var prototype = new this ( ) ;
initializing = false ;
// Copy the properties over onto the new prototype
for ( var name in prop ) {
// Check if we're overwriting an existing function
prototype [ name ] = typeof prop [ name ] == "function" &&
typeof _super [ name ] == "function" && fnTest . test ( prop [ name ] ) ?
( function ( name , fn ) {
return function ( ) {
var tmp = this . _super ;
// Add a new ._super() method that is the same method
// but on the super-class
this . _super = _super [ name ] ;
// The method only need to be bound temporarily, so we
// remove it when we're done executing
var ret = fn . apply ( this , arguments ) ;
this . _super = tmp ;
return ret ;
} ;
} ) ( name , prop [ name ] ) :
prop [ name ] ;
}
// The dummy class constructor
function Class ( ) {
// All construction is actually done in the init method
if ( ! initializing && this . init )
this . init . apply ( this , arguments ) ;
}
// Populate our constructed prototype object
Class . prototype = prototype ;
// Enforce the constructor to be what we expect
Class . prototype . constructor = Class ;
// And make this class extendable
Class . extend = arguments . callee ;
return Class ;
} ;
} ) ( ) ;
/ * C L A S S E X T E N D E X A M P L E
=== === === === === === === === === === === === === === === === == * /
/ *
var Person = Class . extend ( {
init : function ( isDancing ) {
this . dancing = isDancing ;
} ,
dance : function ( ) {
return this . dancing ;
}
} ) ;
var Ninja = Person . extend ( {
init : function ( ) {
this . _super ( false ) ;
} ,
dance : function ( ) {
// Call the inherited version of dance()
return this . _super ( ) ;
} ,
swingSword : function ( ) {
return true ;
}
} ) ;
var p = new Person ( true ) ;
p . dance ( ) ; // => true
var n = new Ninja ( ) ;
n . dance ( ) ; // => false
n . swingSword ( ) ; // => true
// Should all be true
p instanceof Person && p instanceof Class &&
n instanceof Ninja && n instanceof Person && n instanceof Class
* /
/ * A c c e s s t o t h e G l o b a l O b j e c t
* access the global object without hard - coding the identifier window
=== === === === === === === === === === === === === === === === == * /
var global = ( function ( ) {
return this || ( 1 , eval ) ( 'this' ) ;
} ( ) ) ;
/ * V M M
=== === === === === === === === === === === === === === === === == * /
if ( typeof VMM == 'undefined' ) {
/ * M a i n S c o p e C o n t a i n e r
=== === === === === === === === === === === === === === === === == * /
//var VMM = {};
var VMM = Class . extend ( {
} ) ;
/ * M a s t e r C o n f i g
=== === === === === === === === === === === === === === === === == * /
//VMM.master_config.youtube_array
VMM . master _config = ( {
init : function ( ) {
return this ;
} ,
youtube : {
active : false ,
array : [ ] ,
api _loaded : false
} ,
} ) . init ( ) ;
VMM . master _config = ( {
init : function ( ) {
return this ;
} ,
youtube : {
active : false ,
array : [ ] ,
api _loaded : false ,
que : [ ]
} ,
} ) . init ( ) ;
/ * A b s t r a c t o u t D O M e l e m e n t c r e a t i o n t o m a k e i n d e p e n d e n t o f l i b r a r y
=== === === === === === === === === === === === === === === === == * /
//VMM.createElement(tag, value, cName, attrs, styles);
VMM . createElement = function ( tag , value , cName , attrs , styles ) {
var ce = "" ;
if ( tag != null && tag != "" ) {
// TAG
ce += "<" + tag ;
if ( cName != null && cName != "" ) {
ce += " class='" + cName + "'" ;
} ;
if ( attrs != null && attrs != "" ) {
ce += " " + attrs ;
} ;
if ( styles != null && styles != "" ) {
ce += " " + styles ;
} ;
ce += ">" ;
if ( value != null && value != "" ) {
ce += value ;
}
// CLOSE TAG
ce = ce + "</" + tag + ">" ;
}
return ce ;
} ;
VMM . createMediaElement = function ( media , caption , credit ) {
var ce = "" ;
var _valid = false ;
ce += "<div class='media'>" ;
if ( media != null && media != "" ) {
valid = true ;
ce += "<img src='" + media + "'>" ;
// CREDIT
if ( credit != null && credit != "" ) {
ce += VMM . createElement ( "div" , credit , "credit" ) ;
}
// CAPTION
if ( caption != null && caption != "" ) {
ce += VMM . createElement ( "div" , caption , "caption" ) ;
}
}
ce += "</div>" ;
return ce ;
} ;
/ * L I B R A R Y A B S T R A C T I O N
=== === === === === === === === === === === === === === === === == * /
//VMM.attachElement(element, content);
VMM . attachElement = function ( element , content ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . html ( content ) ;
}
} ;
//VMM.appendElement(element, content);
VMM . appendElement = function ( element , content ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . append ( content ) ;
}
} ;
VMM . getHTML = function ( element ) {
var e ;
if ( typeof ( jQuery ) != 'undefined' ) {
e = $ ( element ) . html ( ) ;
return e ;
}
} ;
//VMM.getElement(element);
VMM . getElement = function ( element , p ) {
var e ;
if ( typeof ( jQuery ) != 'undefined' ) {
if ( p ) {
e = $ ( element ) . parent ( ) . get ( 0 ) ;
} else {
e = $ ( element ) . get ( 0 ) ;
}
return e ;
}
} ;
//VMM.bindEvent(element, the_handler, the_event_type, event_data);
//VMM.bindEvent(window, the_handler, "event type", {event_data});
VMM . bindEvent = function ( element , the _handler , the _event _type , event _data ) {
var e ;
var _event _type = "click" ;
var _event _data = { } ;
if ( the _event _type != null && the _event _type != "" ) {
_event _type = the _event _type ;
}
if ( _event _data != null && _event _data != "" ) {
_event _data = event _data ;
}
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . bind ( _event _type , _event _data , the _handler ) ;
//return e;
}
} ;
//VMM.unbindEvent(window, the_handler, "event type");
VMM . unbindEvent = function ( element , the _handler , the _event _type ) {
var e ;
var _event _type = "click" ;
var _event _data = { } ;
if ( the _event _type != null && the _event _type != "" ) {
_event _type = the _event _type ;
}
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . unbind ( _event _type , the _handler ) ;
//return e;
}
} ;
//VMM.fireEvent(element, "resize", [data]);
VMM . fireEvent = function ( element , the _event _type , the _data ) {
var e ;
var _event _type = "click" ;
var _data = [ ] ;
if ( the _event _type != null && the _event _type != "" ) {
_event _type = the _event _type ;
}
if ( the _data != null && the _data != "" ) {
_data = the _data ;
}
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . trigger ( _event _type , _data ) ;
//return e;
}
} ;
// VMM.getJSON(url, the_function);
VMM . getJSON = function ( url , the _function ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ . getJSON ( url , the _function ) ;
}
}
// VMM.parseJSON(the_json);
VMM . parseJSON = function ( the _json ) {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ . parseJSON ( the _json ) ;
}
}
// ADD ELEMENT AND RETURN IT
// VMM.appendAndGetElement(append_to_element, tag, cName, content, [attrib]);
VMM . appendAndGetElement = function ( append _to _element , tag , cName , content ) {
var e ;
var _tag = "<div>" ;
var _class = "" ;
var _content = "" ;
if ( tag != null && tag != "" ) {
_tag = tag ;
}
if ( cName != null && cName != "" ) {
_class = cName ;
}
if ( content != null && content != "" ) {
_content = content ;
}
if ( typeof ( jQuery ) != 'undefined' ) {
e = $ ( tag ) ;
e . addClass ( _class ) ;
e . html ( _content ) ;
$ ( append _to _element ) . append ( e ) ;
//$(e).appendTo(element);
}
return e ;
} ;
VMM . Element = ( {
init : function ( ) {
return this ;
} ,
// VMM.Element.hide(element);
hide : function ( element , duration ) {
if ( duration != null && duration != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . hide ( duration ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . hide ( ) ;
}
}
} ,
// VMM.Element.remove(element);
remove : function ( element ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . remove ( ) ;
}
} ,
// VMM.Element.detach(element);
detach : function ( element ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . detach ( ) ;
}
} ,
// VMM.Element.append(element, value);
append : function ( element , value ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . append ( value ) ;
}
} ,
// VMM.Element.show(element);
show : function ( element , duration ) {
if ( duration != null && duration != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . show ( duration ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . show ( ) ;
}
}
} ,
// VMM.Element.load(element, callback_function, event_data);
load : function ( element , callback _function , event _data ) {
var _event _data = { elem : element } ; // return element by default
if ( _event _data != null && _event _data != "" ) {
_event _data = event _data ;
}
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . load ( _event _data , callback _function ) ;
}
} ,
//VMM.Element.addClass(element, cName);
addClass : function ( element , cName ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . addClass ( cName ) ;
}
} ,
//VMM.Element.removeClass(element, cName);
removeClass : function ( element , cName ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . removeClass ( cName ) ;
}
} ,
//VMM.Element.attr(element, aName, value);
attr : function ( element , aName , value ) {
if ( value != null && value != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . attr ( aName , value ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . attr ( aName ) ;
}
}
} ,
//VMM.Element.prop(element, aName, value);
prop : function ( element , aName , value ) {
if ( typeof jQuery == 'undefined' || ! /[1-9]\.[3-9].[1-9]/ . test ( $ . fn . jquery ) ) {
VMM . Element . attribute ( element , aName , value ) ;
} else {
$ ( element ) . prop ( aName , value ) ;
}
} ,
//VMM.Element.attribute(element, aName, value);
attribute : function ( element , aName , value ) {
if ( value != null && value != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . attr ( aName , value ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . attr ( aName ) ;
}
}
} ,
/ * S e t s o r g e t s t h e v i s a b i l i t y o f a d o m e l e m e n t
=== === === === === === === === === === === === === === === === == * /
//VMM.Element.visible(element, show);
visible : function ( element , show ) {
if ( show != null ) {
if ( typeof ( jQuery ) != 'undefined' ) {
if ( show ) {
$ ( element ) . show ( 0 ) ;
} else {
$ ( element ) . hide ( 0 ) ;
}
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
if ( $ ( element ) . is ( ':visible' ) ) {
return true ;
} else {
return false ;
}
}
}
} ,
/ * S e t s a s t y l e f o r t h e s p e c i f i e d e l e m e n t o r g e t s t h e s t y l e
=== === === === === === === === === === === === === === === === == * /
//VMM.Element.css(element, prop, value);
css : function ( element , prop , value ) {
if ( value != null && value != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . css ( prop , value ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . css ( prop ) ;
}
}
} ,
cssmultiple : function ( element , propval ) {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . css ( propval ) ;
}
} ,
/ * G e t s o f f s e t
=== === === === === === === === === === === === === === === === == * /
//VMM.Element.offset(element);
offset : function ( element ) {
var p ;
if ( typeof ( jQuery ) != 'undefined' ) {
p = $ ( element ) . offset ( ) ;
}
return p ;
} ,
/ * G e t s p o s i t i o n
=== === === === === === === === === === === === === === === === == * /
//VMM.Element.position(element);
position : function ( element ) {
var p ;
if ( typeof ( jQuery ) != 'undefined' ) {
p = $ ( element ) . position ( ) ;
}
return p ;
} ,
/ * S e t s o r g e t s t h e w i d t h o f a d o m e l e m e n t
=== === === === === === === === === === === === === === === === == * /
//VMM.Element.width(element, s);
width : function ( element , s ) {
if ( s != null && s != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . width ( s ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . width ( ) ;
}
}
} ,
/ * S e t s o r g e t s t h e w i d t h o f a d o m e l e m e n t
=== === === === === === === === === === === === === === === === == * /
height : function ( element , s ) {
if ( s != null && s != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . height ( s ) ;
}
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . height ( ) ;
}
}
} ,
/ * T O G G L E C L A S S
=== === === === === === === === === === === === === === === === == * /
// VMM.Element.toggleClass(element, cName);
toggleClass : function ( element , cName ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . toggleClass ( cName ) ;
}
} ,
/ * E a c h
=== === === === === === === === === === === === === === === === == * /
// VMM.Element.each(element, return_function);
each : function ( element , return _function ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . each ( return _function ) ;
}
} ,
/ * E a c h
=== === === === === === === === === === === === === === === === == * /
// VMM.Element.html(element, str);
html : function ( element , str ) {
var e ;
if ( typeof ( jQuery ) != 'undefined' ) {
e = $ ( element ) . html ( ) ;
return e ;
}
if ( str != null && str != "" ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . html ( str ) ;
}
} else {
var e ;
if ( typeof ( jQuery ) != 'undefined' ) {
e = $ ( element ) . html ( ) ;
return e ;
}
}
} ,
/ * F i n d
=== === === === === === === === === === === === === === === === == * /
// VMM.Element.find(element, selec);
find : function ( element , selec ) {
if ( typeof ( jQuery ) != 'undefined' ) {
return $ ( element ) . find ( selec ) ;
}
} ,
/ * A n i m a t e
=== === === === === === === === === === === === === === === === == * /
// VMM.Element.stop(element);
stop : function ( element ) {
if ( typeof ( jQuery ) != 'undefined' ) {
$ ( element ) . stop ( ) ;
}
} ,
// VMM.Element.animate(element, duration, ease, att, callback_function);
animate : function ( element , duration , ease , att , callback _function ) {
var _ease = "easein" ;
var _duration = 1000 ;
var _att = { } ;
if ( duration != null ) {
if ( duration < 1 ) {
_duration = 1 ;
} else {
_duration = Math . round ( duration ) ;
}
}
if ( ease != null && ease != "" ) {
_ease = ease ;
}
if ( att != null ) {
_att = att
} else {
_att = { opacity : 0 }
}
if ( VMM . Browser . device == "mobile" || VMM . Browser . device == "tablet" ) {
var _tdd = Math . round ( ( _duration / 1500 ) * 10 ) / 10
var _ _duration = _tdd + 's' ;
VMM . Element . css ( element , '-webkit-transition' , 'all ' + _ _duration + ' ease' ) ;
VMM . Element . css ( element , '-moz-transition' , 'all ' + _ _duration + ' ease' ) ;
VMM . Element . css ( element , '-o-transition' , 'all ' + _ _duration + ' ease' ) ;
VMM . Element . css ( element , '-ms-transition' , 'all ' + _ _duration + ' ease' ) ;
VMM . Element . css ( element , 'transition' , 'all ' + _ _duration + ' ease' ) ;
VMM . Element . cssmultiple ( element , _att ) ;
//callback_function();
/ *
if ( typeof ( jQuery ) != 'undefined' ) {
if ( callback _function != null && callback _function != "" ) {
$ ( element ) . animate ( _att , { queue : false , duration : _duration , easing : "ease" , complete : callback _function } ) ;
} else {
$ ( element ) . animate ( _att , { queue : false , duration : _duration , easing : "ease" } ) ;
}
}
* /
} else {
if ( typeof ( jQuery ) != 'undefined' ) {
if ( callback _function != null && callback _function != "" ) {
$ ( element ) . animate ( _att , { queue : false , duration : _duration , easing : _ease , complete : callback _function } ) ;
} else {
$ ( element ) . animate ( _att , { queue : false , duration : _duration , easing : _ease } ) ;
}
}
}
/ *
VMM . Element . cssmultiple ( element , {
'-webkit-transition' : 'all 1s ease-in-out' ,
'-moz-transition' : 'all 1s ease-in-out' ,
'-o-transition' : 'all 1s ease-in-out' ,
'-ms-transition' : 'all 1s ease-in-out' ,
'transition' : 'all 1s ease-in-out' ,
} ) ;
* /
} ,
} ) . init ( ) ;
/ * T O U C H
=== === === === === === === === === === === === === === === === == * /
// VMM.TouchSlider.createSlidePanel(touch_object, move_object, w, padding, vertical, h) ;
VMM . TouchSlider = {
createPanel : function ( touch _object , move _object , w , padding , vertical , h ) {
VMM . TouchSlider . vertical = false ;
VMM . TouchSlider . vertical = vertical ;
var x = padding ;
VMM . TouchSlider . width = w ;
VMM . TouchSlider . height = h ;
VMM . TouchSlider . makeTouchable ( touch _object , move _object ) ;
/ *
if ( sticky != null && sticky != "" ) {
VMM . TouchSlider . sticky = sticky ;
} else {
VMM . TouchSlider . sticky = false ;
}
* /
// VMM.TouchSlider.sticky = sticky;
} ,
removePanel : function ( touch _object ) {
VMM . unbindEvent ( touch _object , VMM . TouchSlider . onTouchStart , "touchstart" ) ;
VMM . unbindEvent ( touch _object , VMM . TouchSlider . onTouchMove , "touchmove" ) ;
VMM . unbindEvent ( touch _object , VMM . TouchSlider . onTouchEnd , "touchend" ) ;
} ,
makeTouchable : function ( touch _object , move _object ) {
VMM . bindEvent ( touch _object , VMM . TouchSlider . onTouchStart , "touchstart" , { element : move _object } ) ;
VMM . bindEvent ( touch _object , VMM . TouchSlider . onTouchMove , "touchmove" , { element : move _object } ) ;
VMM . bindEvent ( touch _object , VMM . TouchSlider . onTouchEnd , "touchend" , { element : move _object } ) ;
} ,
onTouchStart : function ( e ) {
VMM . TouchSlider . touchStart ( e . data . element , e ) ;
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
return true ;
} ,
onTouchEnd : function ( e ) {
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
if ( VMM . TouchSlider . sliding ) {
VMM . TouchSlider . sliding = false ;
VMM . TouchSlider . touchEnd ( e . data . element , e ) ;
return false ;
} else {
return true ;
}
} ,
onTouchMove : function ( e ) {
VMM . TouchSlider . touchMove ( e . data . element , e ) ;
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
return false ;
} ,
getLeft : function ( elem ) {
return parseInt ( VMM . Element . css ( elem , 'left' ) . substring ( 0 , VMM . Element . css ( elem , 'left' ) . length - 2 ) , 10 ) ;
} ,
getTop : function ( elem ) {
return parseInt ( VMM . Element . css ( elem , 'top' ) . substring ( 0 , VMM . Element . css ( elem , 'top' ) . length - 2 ) , 10 ) ;
} ,
touchStart : function ( elem , e ) {
VMM . Element . css ( elem , '-webkit-transition-duration' , '0' ) ;
VMM . TouchSlider . startX = e . originalEvent . touches [ 0 ] . screenX ;
VMM . TouchSlider . startY = e . originalEvent . touches [ 0 ] . screenY ;
VMM . TouchSlider . startLeft = VMM . TouchSlider . getLeft ( elem ) ;
VMM . TouchSlider . startTop = VMM . TouchSlider . getTop ( elem ) ;
VMM . TouchSlider . touchStartTime = new Date ( ) . getTime ( ) ;
} ,
touchEnd : function ( elem , e ) {
if ( VMM . TouchSlider . getLeft ( elem ) > 0 ) {
//This means they dragged to the right past the first item
if ( VMM . TouchSlider . vertical ) {
VMM . Element . animate ( elem , 1000 , "" , { "top" : 0 } ) ;
} else {
VMM . Element . animate ( elem , 1000 , "" , { "left" : 0 } ) ;
}
VMM . TouchSlider . startX = null ;
VMM . TouchSlider . startY = null ;
VMM . fireEvent ( elem , "TOUCHUPDATE" , [ 0 ] ) ;
} else {
//This means they were just dragging within the bounds of the grid and we just need to handle the momentum and snap to the grid.
VMM . TouchSlider . slideMomentum ( elem , e ) ;
}
} ,
slideMomentum : function ( elem , e ) {
var slideAdjust = ( new Date ( ) . getTime ( ) - VMM . TouchSlider . touchStartTime ) * 10 ;
var timeAdjust = slideAdjust ;
var left = VMM . TouchSlider . getLeft ( elem ) ;
var top = VMM . TouchSlider . getTop ( elem ) ;
var changeX = 6000 * ( Math . abs ( VMM . TouchSlider . startLeft ) - Math . abs ( left ) ) ;
var changeY = 6000 * ( Math . abs ( VMM . TouchSlider . startTop ) - Math . abs ( top ) ) ;
slideAdjust = Math . round ( changeX / slideAdjust ) ;
slideAdjustY = Math . round ( changeY / slideAdjust ) ;
var newLeft = slideAdjust + left ;
var newTop = slideAdjustY + top ;
var y = newTop % VMM . TouchSlider . height ;
var t = newLeft % VMM . TouchSlider . width ;
var _r _object = {
top : Math . min ( 0 , newTop ) ,
left : Math . min ( 0 , newLeft ) ,
time : timeAdjust
}
VMM . fireEvent ( elem , "TOUCHUPDATE" , [ _r _object ] ) ;
/ *
if ( VMM . TouchSlider . sticky ) {
trace ( "sticky" ) ;
if ( ( Math . abs ( t ) ) > ( ( VMM . TouchSlider . width / 2 ) ) ) {
//Show the next cell
newLeft -= ( VMM . TouchSlider . width - Math . abs ( t ) ) ;
} else {
//Stay on the current cell
newLeft -= t ;
}
VMM . fireEvent ( elem , "TOUCHUPDATE" , [ Math . min ( 0 , newLeft ) ] ) ;
} else {
trace ( "not sticky" ) ;
//VMM.TouchSlider.doSlide(elem, Math.min(0, newLeft), '0.5s');
VMM . Element . animate ( elem , 500 , "" , { "left" : Math . min ( 0 , newLeft ) } ) ;
}
* /
VMM . TouchSlider . startX = null ;
VMM . TouchSlider . startY = null ;
} ,
doSlide : function ( elem , x , duration ) {
VMM . Element . css ( elem , '-webkit-transition-property' , 'left' ) ;
VMM . Element . css ( elem , '-webkit-transition-duration' , duration ) ;
VMM . Element . css ( elem , 'left' , x ) ;
} ,
touchMove : function ( elem , e ) {
if ( ! VMM . TouchSlider . sliding ) {
//elem.parent().addClass('sliding');
}
VMM . TouchSlider . sliding = true ;
if ( VMM . TouchSlider . vertical ) {
if ( VMM . TouchSlider . startY > e . originalEvent . touches [ 0 ] . screenY ) {
VMM . Element . css ( elem , 'top' , - ( VMM . TouchSlider . startY - e . originalEvent . touches [ 0 ] . screenY - VMM . TouchSlider . startTop ) ) ;
VMM . TouchSlider . slidingTop = true ;
} else {
var top = ( e . originalEvent . touches [ 0 ] . screenY - VMM . TouchSlider . startY + VMM . TouchSlider . startTop ) ;
VMM . Element . css ( elem , 'top' , - ( VMM . TouchSlider . startY - e . originalEvent . touches [ 0 ] . screenY - VMM . TouchSlider . startTop ) ) ;
VMM . TouchSlider . slidingTop = false ;
}
} else {
if ( VMM . TouchSlider . startX > e . originalEvent . touches [ 0 ] . screenX ) {
VMM . Element . css ( elem , 'left' , - ( VMM . TouchSlider . startX - e . originalEvent . touches [ 0 ] . screenX - VMM . TouchSlider . startLeft ) ) ;
VMM . TouchSlider . slidingLeft = true ;
} else {
var left = ( e . originalEvent . touches [ 0 ] . screenX - VMM . TouchSlider . startX + VMM . TouchSlider . startLeft ) ;
VMM . Element . css ( elem , 'left' , - ( VMM . TouchSlider . startX - e . originalEvent . touches [ 0 ] . screenX - VMM . TouchSlider . startLeft ) ) ;
VMM . TouchSlider . slidingLeft = false ;
}
}
}
}
// Hide URL Bar for iOS and Android by Scott Jehl
// https://gist.github.com/1183357
VMM . hideUrlBar = function ( ) {
var win = window ,
doc = win . document ;
// If there's a hash, or addEventListener is undefined, stop here
if ( ! location . hash || ! win . addEventListener ) {
//scroll to 1
window . scrollTo ( 0 , 1 ) ;
var scrollTop = 1 ,
//reset to 0 on bodyready, if needed
bodycheck = setInterval ( function ( ) {
if ( doc . body ) {
clearInterval ( bodycheck ) ;
scrollTop = "scrollTop" in doc . body ? doc . body . scrollTop : 1 ;
win . scrollTo ( 0 , scrollTop === 1 ? 0 : 1 ) ;
}
} , 15 ) ;
win . addEventListener ( "load" , function ( ) {
setTimeout ( function ( ) {
//reset to hide addr bar at onload
win . scrollTo ( 0 , scrollTop === 1 ? 0 : 1 ) ;
} , 0 ) ;
} , false ) ;
}
} ;
/ * D R A G
=== === === === === === === === === === === === === === === === == * /
// VMM.DragSlider.createSlidePanel(drag_object, move_object, w, padding, sticky);
// VMM.DragSlider.cancelSlide();
VMM . DragSlider = {
createPanel : function ( drag _object , move _object , w , padding , sticky ) {
var x = padding ;
VMM . DragSlider . width = w ;
VMM . DragSlider . makeDraggable ( drag _object , move _object ) ;
VMM . DragSlider . drag _elem = drag _object ;
/ *
if ( sticky != null && sticky != "" ) {
VMM . TouchSlider . sticky = sticky ;
} else {
VMM . TouchSlider . sticky = false ;
}
* /
VMM . DragSlider . sticky = sticky ;
} ,
makeDraggable : function ( drag _object , move _object ) {
VMM . bindEvent ( drag _object , VMM . DragSlider . onDragStart , "mousedown" , { element : move _object , delement : drag _object } ) ;
//VMM.bindEvent(drag_object, VMM.DragSlider.onDragMove, "mousemove", {element: move_object});
VMM . bindEvent ( drag _object , VMM . DragSlider . onDragEnd , "mouseup" , { element : move _object , delement : drag _object } ) ;
VMM . bindEvent ( drag _object , VMM . DragSlider . onDragLeave , "mouseleave" , { element : move _object , delement : drag _object } ) ;
} ,
cancelSlide : function ( e ) {
VMM . unbindEvent ( VMM . DragSlider . drag _elem , VMM . DragSlider . onDragMove , "mousemove" ) ;
//VMM.DragSlider.drag_elem.preventDefault();
//VMM.DragSlider.drag_elem.stopPropagation();
return true ;
} ,
onDragLeave : function ( e ) {
VMM . unbindEvent ( e . data . delement , VMM . DragSlider . onDragMove , "mousemove" ) ;
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
return true ;
} ,
onDragStart : function ( e ) {
VMM . DragSlider . dragStart ( e . data . element , e . data . delement , e ) ;
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
return true ;
} ,
onDragEnd : function ( e ) {
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
if ( VMM . DragSlider . sliding ) {
VMM . DragSlider . sliding = false ;
VMM . DragSlider . dragEnd ( e . data . element , e . data . delement , e ) ;
return false ;
} else {
return true ;
}
} ,
onDragMove : function ( e ) {
VMM . DragSlider . dragMove ( e . data . element , e ) ;
e . preventDefault ( ) ;
e . stopPropagation ( ) ;
return false ;
} ,
dragStart : function ( elem , delem , e ) {
VMM . DragSlider . startX = e . pageX ;
VMM . DragSlider . startLeft = VMM . DragSlider . getLeft ( elem ) ;
VMM . DragSlider . dragStartTime = new Date ( ) . getTime ( ) ;
VMM . DragSlider . dragWidth = VMM . Element . width ( delem ) ;
// CANCEL CURRENT ANIMATION IF ANIMATING
var _newx = Math . round ( VMM . DragSlider . startX - e . pageX - VMM . DragSlider . startLeft ) ;
VMM . Element . stop ( elem ) ;
VMM . bindEvent ( delem , VMM . DragSlider . onDragMove , "mousemove" , { element : elem } ) ;
} ,
dragEnd : function ( elem , delem , e ) {
VMM . unbindEvent ( delem , VMM . DragSlider . onDragMove , "mousemove" ) ;
//VMM.DragSlider.dragMomentum(elem, e);
if ( VMM . DragSlider . getLeft ( elem ) > 0 ) {
//(VMM.DragSlider.dragWidth/2)
//This means they dragged to the right past the first item
//VMM.Element.animate(elem, 1000, "linear", {"left": 0});
//VMM.fireEvent(elem, "DRAGUPDATE", [0]);
} else {
//This means they were just dragging within the bounds of the grid and we just need to handle the momentum and snap to the grid.
VMM . DragSlider . dragMomentum ( elem , e ) ;
}
} ,
dragMove : function ( elem , e ) {
if ( ! VMM . DragSlider . sliding ) {
//elem.parent().addClass('sliding');
}
VMM . DragSlider . sliding = true ;
if ( VMM . DragSlider . startX > e . pageX ) {
//Sliding to the left
VMM . Element . css ( elem , 'left' , - ( VMM . DragSlider . startX - e . pageX - VMM . DragSlider . startLeft ) ) ;
VMM . DragSlider . slidingLeft = true ;
} else {
//Sliding to the right
var left = ( e . pageX - VMM . DragSlider . startX + VMM . DragSlider . startLeft ) ;
VMM . Element . css ( elem , 'left' , - ( VMM . DragSlider . startX - e . pageX - VMM . DragSlider . startLeft ) ) ;
VMM . DragSlider . slidingLeft = false ;
}
} ,
dragMomentum : function ( elem , e ) {
var slideAdjust = ( new Date ( ) . getTime ( ) - VMM . DragSlider . dragStartTime ) * 10 ;
var timeAdjust = slideAdjust ;
var left = VMM . DragSlider . getLeft ( elem ) ;
var changeX = 6000 * ( Math . abs ( VMM . DragSlider . startLeft ) - Math . abs ( left ) ) ;
//var changeX = 6000 * (VMM.DragSlider.startLeft - left);
slideAdjust = Math . round ( changeX / slideAdjust ) ;
var newLeft = left + slideAdjust ;
var t = newLeft % VMM . DragSlider . width ;
//left: Math.min(0, newLeft),
var _r _object = {
left : Math . min ( newLeft ) ,
time : timeAdjust
}
VMM . fireEvent ( elem , "DRAGUPDATE" , [ _r _object ] ) ;
var _ease = "easeOutExpo" ;
if ( _r _object . time > 0 ) {
VMM . Element . animate ( elem , _r _object . time , _ease , { "left" : _r _object . left } ) ;
} ;
//VMM.DragSlider.startX = null;
} ,
getLeft : function ( elem ) {
return parseInt ( VMM . Element . css ( elem , 'left' ) . substring ( 0 , VMM . Element . css ( elem , 'left' ) . length - 2 ) , 10 ) ;
}
}
/ * D E V I C E
=== === === === === === === === === === === === === === === === == * /
VMM . Browser = {
init : function ( ) {
this . browser = this . searchString ( this . dataBrowser ) || "An unknown browser" ;
this . version = this . searchVersion ( navigator . userAgent )
|| this . searchVersion ( navigator . appVersion )
|| "an unknown version" ;
this . OS = this . searchString ( this . dataOS ) || "an unknown OS" ;
this . device = this . searchDevice ( navigator . userAgent ) ;
} ,
searchDevice : function ( d ) {
if ( d . match ( /Android/i ) || d . match ( /iPhone|iPod/i ) ) {
return "mobile" ;
} else if ( d . match ( /iPad/i ) ) {
return "tablet" ;
} else if ( d . match ( /BlackBerry/i ) || d . match ( /IEMobile/i ) ) {
return "other mobile" ;
} else {
return "desktop" ;
}
} ,
searchString : function ( data ) {
for ( var i = 0 ; i < data . length ; i ++ ) {
var dataString = data [ i ] . string ;
var dataProp = data [ i ] . prop ;
this . versionSearchString = data [ i ] . versionSearch || data [ i ] . identity ;
if ( dataString ) {
if ( dataString . indexOf ( data [ i ] . subString ) != - 1 )
return data [ i ] . identity ;
}
else if ( dataProp )
return data [ i ] . identity ;
}
} ,
searchVersion : function ( dataString ) {
var index = dataString . indexOf ( this . versionSearchString ) ;
if ( index == - 1 ) return ;
return parseFloat ( dataString . substring ( index + this . versionSearchString . length + 1 ) ) ;
} ,
dataBrowser : [
{
string : navigator . userAgent ,
subString : "Chrome" ,
identity : "Chrome"
} ,
{ string : navigator . userAgent ,
subString : "OmniWeb" ,
versionSearch : "OmniWeb/" ,
identity : "OmniWeb"
} ,
{
string : navigator . vendor ,
subString : "Apple" ,
identity : "Safari" ,
versionSearch : "Version"
} ,
{
prop : window . opera ,
identity : "Opera" ,
versionSearch : "Version"
} ,
{
string : navigator . vendor ,
subString : "iCab" ,
identity : "iCab"
} ,
{
string : navigator . vendor ,
subString : "KDE" ,
identity : "Konqueror"
} ,
{
string : navigator . userAgent ,
subString : "Firefox" ,
identity : "Firefox"
} ,
{
string : navigator . vendor ,
subString : "Camino" ,
identity : "Camino"
} ,
{ // for newer Netscapes (6+)
string : navigator . userAgent ,
subString : "Netscape" ,
identity : "Netscape"
} ,
{
string : navigator . userAgent ,
subString : "MSIE" ,
identity : "Explorer" ,
versionSearch : "MSIE"
} ,
{
string : navigator . userAgent ,
subString : "Gecko" ,
identity : "Mozilla" ,
versionSearch : "rv"
} ,
{ // for older Netscapes (4-)
string : navigator . userAgent ,
subString : "Mozilla" ,
identity : "Netscape" ,
versionSearch : "Mozilla"
}
] ,
dataOS : [
{
string : navigator . platform ,
subString : "Win" ,
identity : "Windows"
} ,
{
string : navigator . platform ,
subString : "Mac" ,
identity : "Mac"
} ,
{
string : navigator . userAgent ,
subString : "iPhone" ,
identity : "iPhone/iPod"
} ,
{
string : navigator . userAgent ,
subString : "iPad" ,
identity : "iPad"
} ,
{
string : navigator . platform ,
subString : "Linux" ,
identity : "Linux"
}
]
}
VMM . Browser . init ( ) ;
/ * M E D I A T Y P E
=== === === === === === === === === === === === === === === === == * /
VMM . MediaElement = ( {
init : function ( ) {
return this ;
} ,
// somestring = VMM.MediaElement.thumbnail(data);
thumbnail : function ( data , w , h ) {
_w = 32 ;
_h = 32 ;
if ( w != null && w != "" ) {
_w = w ;
}
if ( h != null && h != "" ) {
_h = h ;
}
if ( data . media != null && data . media != "" ) {
_valid = true ;
var mediaElem = "" ;
var m = { } ;
// MEDIA TYPE
m = VMM . MediaType ( data . media ) ; //returns an object with .type and .id
// CREATE MEDIA CODE
if ( m . type == "image" ) {
mediaElem = "<div class='thumbnail'><img src='" + m . id + "' width='" + _w + "px' height='" + _h + "px'></div>" ;
return mediaElem ;
} else if ( m . type == "flickr" ) {
mediaElem = "<div class='thumbnail'><img id='flickr_" + m . id + "_thumb' width='" + _w + "px' height='" + _h + "px'></div>" ;
return mediaElem ;
} else if ( m . type == "youtube" ) {
mediaElem = "<div class='thumbnail youtube'></div>" ;
return mediaElem ;
} else if ( m . type == "vimeo" ) {
mediaElem = "<div class='thumbnail vimeo'></div>" ;
return mediaElem ;
} else if ( m . type == "twitter" ) {
mediaElem = "<div class='thumbnail twitter'></div>" ;
return mediaElem ;
} else if ( m . type == "twitter-ready" ) {
mediaElem = "<div class='thumbnail twitter'></div>" ;
return mediaElem ;
} else if ( m . type == "soundcloud" ) {
mediaElem = "<div class='thumbnail soundcloud'></div>" ;
return mediaElem ;
} else if ( m . type == "google-map" ) {
mediaElem = "<div class='thumbnail map'></div>" ;
return mediaElem ;
} else if ( m . type == "unknown" ) {
mediaElem = "" ;
return mediaElem ;
} else if ( m . type == "website" ) {
mediaElem = "<div class='thumbnail website'></div>" ;
return mediaElem ;
} else {
mediaElem = "<div class='thumbnail'></div>" ;
return mediaElem ;
}
}
} ,
//VMM.MediaElement.create(element, data, returntrue);
create : function ( element , data , _ _return , w , h ) {
_return = _ _return ;
_w = 500 ;
_h = 400 ;
$mediacontainer = element ;
//VMM.MediaElement.container = element;
var _valid = false ;
if ( w != null && w != "" ) {
_w = w ;
}
if ( h != null && h != "" ) {
_h = h ;
}
if ( data . media != null && data . media != "" ) {
_valid = true ;
var mediaElem = "" ;
var captionElem = "" ;
var creditElem = "" ;
var m = { } ;
var media _height = ( _h - 50 ) ;
var isTextMedia = false ;
// CREDIT
if ( data . credit != null && data . credit != "" ) {
creditElem = "<div class='credit'>" + data . credit + "</div>" ;
}
// CAPTION
if ( data . caption != null && data . caption != "" ) {
captionElem = "<div class='caption'>" + data . caption + "</div>" ;
}
// MEDIA TYPE
m = VMM . MediaType ( data . media ) ; //returns an object with .type and .id
// CREATE MEDIA CODE
if ( m . type == "image" ) {
mediaElem = "<img src='" + m . id + "'>" ;
} else if ( m . type == "flickr" ) {
var flickr _id = "flickr_" + m . id ;
mediaElem = "<img id='" + flickr _id + "_large" + "'>" ;
VMM . ExternalAPI . flickr . getPhoto ( m . id , "#" + flickr _id ) ;
} else if ( m . type == "youtube" ) {
mediaElem = "<div class='media-frame video youtube' id='youtube_" + m . id + "'>Loading YouTube video...</div>" ;
VMM . ExternalAPI . youtube . init ( m . id ) ;
//mediaElem = "<iframe class='media-frame youtube' onload='timeline.iframeLoaded()' frameborder='0' width='100%' height='100%' src='http://www.youtube.com/embed/" + m.id + "?&rel=0&theme=light&showinfo=0&hd=1&autohide=0&color=white&enablejsapi=1' allowfullscreen></iframe>";
} else if ( m . type == "vimeo" ) {
mediaElem = "<iframe class='media-frame video vimeo' frameborder='0' width='100%' height='100%' src='http://player.vimeo.com/video/" + m . id + "?title=0&byline=0&portrait=0&color=ffffff'></iframe>" ;
} else if ( m . type == "twitter" ) {
mediaElem = "<div class='twitter' id='" + m . id + "'>Loading Tweet</div>" ;
//VMM.ExternalAPI.twitter.getHTML(m.id);
trace ( "TWITTER" ) ;
VMM . ExternalAPI . twitter . prettyHTML ( m . id ) ;
isTextMedia = true ;
} else if ( m . type == "twitter-ready" ) {
mediaElem = m . id ;
} else if ( m . type == "soundcloud" ) {
var soundcloud _id = "soundcloud_" + VMM . Util . unique _ID ( 5 ) ;
mediaElem = "<div class='media-frame soundcloud' id='" + soundcloud _id + "'>Loading Sound</div>" ;
VMM . ExternalAPI . soundcloud . getSound ( m . id , soundcloud _id )
} else if ( m . type == "google-map" ) {
mediaElem = "<iframe class='media-frame map' frameborder='0' width='100%' height='100%' scrolling='no' marginheight='0' marginwidth='0' src='" + m . id + "&output=embed'></iframe>"
} else if ( m . type == "unknown" ) {
trace ( "NO KNOWN MEDIA TYPE FOUND TRYING TO JUST PLACE THE HTML" ) ;
mediaElem = VMM . Util . properQuotes ( m . id ) ;
} else if ( m . type == "website" ) {
mediaElem = "<iframe class='media-frame' frameborder='0' width='100%' height='100%' scrolling='yes' marginheight='0' marginwidth='0' src='" + m . id + "'></iframe>"
} else {
trace ( "NO KNOWN MEDIA TYPE FOUND" ) ;
trace ( m . type ) ;
}
// WRAP THE MEDIA ELEMENT
mediaElem = "<div class='media-container' >" + mediaElem + creditElem + captionElem + "</div>" ;
if ( _return ) {
if ( isTextMedia ) {
return "<div class='media text-media'><div class='media-wrapper'>" + mediaElem + "</div></div>" ;
} else {
return "<div class='media'><div class='media-wrapper'>" + mediaElem + "</div></div>" ;
}
} else {
VMM . appendElement ( $mediacontainer , mediaElem ) ;
VMM . appendElement ( $mediacontainer , creditElem ) ;
VMM . appendElement ( $mediacontainer , captionElem ) ;
}
} ;
} ,
} ) . init ( ) ;
//VMM.mediaType.youtube(d); //should return a true or false
// VMM.MediaType(url); //returns an object with .type and .id
VMM . MediaType = function ( d ) {
var success = false ;
var media = { } ;
if ( d . match ( "div class='twitter'" ) ) {
media . type = "twitter-ready" ;
media . id = d ;
success = true ;
} else if ( d . match ( '(www.)?youtube|youtu\.be' ) ) {
if ( d . match ( 'embed' ) ) {
youtube _id = d . split ( /embed\// ) [ 1 ] . split ( '"' ) [ 0 ] ;
} else {
youtube _id = d . split ( /v\/|v=|youtu\.be\// ) [ 1 ] . split ( /[?&]/ ) [ 0 ] ;
}
//youtube_id = d.split(/v\/|v=|youtu\.be\//)[1].split(/[?&]/)[0];
media . type = "youtube" ;
media . id = youtube _id ;
success = true ;
} else if ( d . match ( '(player.)?vimeo\.com' ) ) {
//vimeo_id = d.split(/video\/|http:\/\/vimeo\.com\//)[1].split(/[?&]/)[0];
vimeo _id = d . split ( /video\/|\/\/vimeo\.com\// ) [ 1 ] . split ( /[?&]/ ) [ 0 ] ;
media . type = "vimeo" ;
media . id = vimeo _id ;
success = true ;
} else if ( d . match ( '(player.)?soundcloud\.com' ) ) {
//soundcloud_url = unescape(d.split(/value="/)[1].split(/["]/)[0]);
//soundcloud_id = soundcloud_url.split(/tracks\//)[1].split(/[&"]/)[0];
media . type = "soundcloud" ;
media . id = d ;
success = true ;
} else if ( d . match ( '(www.)?twitter\.com' ) ) {
trace ( "TWITTER MATCH" ) ;
// https://twitter.com/#!/twitterapi/statuses/133640144317198338
// https://twitter.com/#!/DeliciousHot/status/23189589820702720
if ( d . match ( "status\/" ) ) {
twitter _id = d . split ( "status\/" ) [ 1 ] ;
} else if ( d . match ( "statuses\/" ) ) {
twitter _id = d . split ( "statuses\/" ) [ 1 ] ;
} else {
twitter _id = "" ;
}
media . type = "twitter" ;
media . id = twitter _id ;
success = true ;
} else if ( d . match ( "maps.google.com" ) ) {
//maps.google.com
media . type = "google-map" ;
media . id = d . split ( /src=['|"][^'|"]*?['|"]/gi ) ;
trace ( "google map " + media . id ) ;
success = true ;
} else if ( d . match ( "flickr.com/photos" ) ) {
media . type = "flickr" ;
//media.id = d.split('/photos/[^/]+/([0-9]+)/gi');
media . id = d . split ( "photos\/" ) [ 1 ] . split ( "/" ) [ 1 ] ;
//media.id = media.id.split("/")[1];
trace ( "FLICKR " + media . id ) ;
success = true ;
} else if ( d . match ( /jpg|jpeg|png|gif/i ) ) {
media . type = "image" ;
media . id = d ;
success = true ;
} else if ( d . indexOf ( 'http://' ) == 0 ) {
media . type = "website" ;
media . id = d ;
success = true ;
} else {
trace ( "unknown media" ) ;
media . type = "unknown" ;
media . id = d ;
success = true ;
}
if ( success ) {
return media ;
} else {
trace ( "No valid media id detected" ) ;
trace ( d ) ;
}
return false ;
}
VMM . Keys = {
flickr : "6d6f59d8d30d79f4f402a7644d5073e3" ,
}
VMM . ExternalAPI = {
twitter : {
tweetArray : [ ] ,
// VMM.ExternalAPI.twitter.getHTML(id);
getHTML : function ( id ) {
var the _url = "https://api.twitter.com/1/statuses/oembed.json?id=" + id + "&callback=?" ;
VMM . getJSON ( the _url , function ( d ) {
VMM . ExternalAPI . twitter . onJSONLoaded ( d , id ) ;
} ) ;
} ,
onJSONLoaded : function ( d , id ) {
VMM . attachElement ( "#" + id , VMM . ExternalAPI . twitter . linkify ( d . html ) ) ;
} ,
//somestring = VMM.ExternalAPI.twitter.linkify(d);
linkify : function ( d ) {
return d . replace ( /[@]+[A-Za-z0-9-_]+/g , function ( u ) {
var username = u . replace ( "@" , "" ) ;
return u . link ( "http://twitter.com/" + username ) ;
} ) ;
} ,
// VMM.ExternalAPI.twitter.parseTwitterDate(date);
parseTwitterDate : function ( d ) {
var date = new Date ( Date . parse ( d ) ) ;
/ *
var t = d . replace ( /(\d{1,2}[:]\d{2}[:]\d{2}) (.*)/ , '$2 $1' ) ;
t = t . replace ( /(\+\S+) (.*)/ , '$2 $1' ) ;
var date = new Date ( Date . parse ( t ) ) . toLocaleDateString ( ) ;
var time = new Date ( Date . parse ( t ) ) . toLocaleTimeString ( ) ;
* /
return date ;
} ,
prettyParseTwitterDate : function ( d ) {
var date = new Date ( Date . parse ( d ) ) ;
return VMM . Util . date . prettyDate ( date , true ) ;
} ,
// VMM.ExternalAPI.twitter.getTweets(tweets_array);
getTweets : function ( tweets ) {
var tweetArray = [ ] ;
var number _of _tweets = tweets . length ;
for ( var i = 0 ; i < tweets . length ; i ++ ) {
var twitter _id = "" ;
/ * F I N D T H E T W I T T E R I D
=== === === === === === === === === === === === === === === === == * /
if ( tweets [ i ] . tweet . match ( "status\/" ) ) {
twitter _id = tweets [ i ] . tweet . split ( "status\/" ) [ 1 ] ;
} else if ( tweets [ i ] . tweet . match ( "statuses\/" ) ) {
twitter _id = tweets [ i ] . tweet . split ( "statuses\/" ) [ 1 ] ;
} else {
twitter _id = "" ;
}
/ * F E T C H T H E D A T A
=== === === === === === === === === === === === === === === === == * /
var the _url = "https://api.twitter.com/1/statuses/show.json?id=" + twitter _id + "&include_entities=true&callback=?" ;
VMM . getJSON ( the _url , function ( d ) {
var tweet = { }
/ * F O R M A T R E S P O N S E
=== === === === === === === === === === === === === === === === == * /
var twit = "<div class='twitter'><blockquote><p>" ;
var td = VMM . Util . linkify ( d . text ) ;
td = td . replace ( /(@([\w]+))/g , "<a href='http://twitter.com/$2'>$1</a>" ) ;
td = td . replace ( /(#([\w]+))/g , "<a href='http://twitter.com/#search?q=%23$2'>$1</a>" ) ;
//twit += VMM.Util.linkify(d.text);
twit += td ;
twit += "</p>" ;
twit += "— " + d . user . name + " (<a href='https://twitter.com/" + d . user . screen _name + "'>@" + d . user . screen _name + "</a>) <a href='https://twitter.com/" + d . user . screen _name + "/status/" + d . id + "'>" + VMM . ExternalAPI . twitter . prettyParseTwitterDate ( d . created _at ) + " </a></blockquote></div>" ;
tweet . content = twit ;
tweet . raw = d ;
tweetArray . push ( tweet ) ;
/ * C H E C K I F T H A T S A L L O F T H E M
=== === === === === === === === === === === === === === === === == * /
if ( tweetArray . length == number _of _tweets ) {
var the _tweets = { tweetdata : tweetArray }
VMM . fireEvent ( global , "TWEETSLOADED" , the _tweets ) ;
}
} ) ;
}
} ,
// VMM.ExternalAPI.twitter.getTweetSearch(search string);
getTweetSearch : function ( tweets , number _of _tweets ) {
var _number _of _tweets = 40 ;
if ( number _of _tweets != null && number _of _tweets != "" ) {
_number _of _tweets = number _of _tweets ;
}
var the _url = "http://search.twitter.com/search.json?q=" + tweets + "&rpp=" + _number _of _tweets + "&include_entities=true&result_type=mixed" ;
var tweetArray = [ ] ;
VMM . getJSON ( the _url , function ( d ) {
/ * F O R M A T R E S P O N S E
=== === === === === === === === === === === === === === === === == * /
for ( var i = 0 ; i < d . results . length ; i ++ ) {
var tweet = { }
var twit = "<div class='twitter'><blockquote><p>" ;
var td = VMM . Util . linkify ( d . results [ i ] . text ) ;
td = td . replace ( /(@([\w]+))/g , "<a href='http://twitter.com/$2'>$1</a>" ) ;
td = td . replace ( /(#([\w]+))/g , "<a href='http://twitter.com/#search?q=%23$2'>$1</a>" ) ;
twit += td ;
twit += "</p>" ;
twit += "— " + d . results [ i ] . from _user _name + " (<a href='https://twitter.com/" + d . results [ i ] . from _user + "'>@" + d . results [ i ] . from _user + "</a>) <a href='https://twitter.com/" + d . results [ i ] . from _user + "/status/" + d . id + "'>" + VMM . ExternalAPI . twitter . prettyParseTwitterDate ( d . results [ i ] . created _at ) + " </a></blockquote></div>" ;
tweet . content = twit ;
tweet . raw = d . results [ i ] ;
tweetArray . push ( tweet ) ;
}
var the _tweets = { tweetdata : tweetArray }
VMM . fireEvent ( global , "TWEETSLOADED" , the _tweets ) ;
} ) ;
} ,
// VMM.ExternalAPI.twitter.prettyHTML(id);
prettyHTML : function ( id ) {
// https://api.twitter.com/1/statuses/show.json?id=164165553810976768&include_entities=true
var the _url = "https://api.twitter.com/1/statuses/show.json?id=" + id + "&include_entities=true&callback=?" ;
VMM . getJSON ( the _url , function ( d ) {
VMM . ExternalAPI . twitter . formatJSON ( d , id ) ;
} ) ;
} ,
formatJSON : function ( d , id ) {
var twit = "<blockquote><p>" ;
var td = VMM . Util . linkify ( d . text ) ;
td = td . replace ( /(@([\w]+))/g , "<a href='http://twitter.com/$2'>$1</a>" ) ;
td = td . replace ( /(#([\w]+))/g , "<a href='http://twitter.com/#search?q=%23$2'>$1</a>" ) ;
//twit += VMM.Util.linkify(d.text);
twit += td ;
twit += "</p></blockquote>" ;
//twit += "— " + d.user.name + " (<a href='https://twitter.com/" + d.user.screen_name + "'>@" + d.user.screen_name + "</a>) <a href='https://twitter.com/" + d.user.screen_name + "/status/" + d.id + "'>" + d.created_at + " </a>";
//twit += "<a href='" + + "'>" + VMM.ExternalAPI.twitter.prettyParseTwitterDate(d.created_at);
//twit += "<span class='created-at'><a href='https://twitter.com/" + d.user.screen_name + "/status/" + d.id + "'>" + VMM.ExternalAPI.twitter.prettyParseTwitterDate(d.created_at) + " </a></span>";
//twit += "<span class='created-at'><a href='https://twitter.com/" + d.user.screen_name + "/status/" + d.id + "'>" + "Tweet Details" + " </a></span>";
twit += " <a href='https://twitter.com/" + d . user . screen _name + "/status/" + d . id + "' alt='link to original tweet' title='link to original tweet'>" + "<span class='created-at'></span>" + " </a>" ;
twit += "<div class='vcard author'>"
twit += "<a class='screen-name url' href='https://twitter.com/" + d . user . screen _name + "' data-screen-name='" + d . user . screen _name + "'>" ;
twit += "<span class='avatar'><img src=' " + d . user . profile _image _url + "' alt=''></span>" ;
twit += "<span class='fn'>" + d . user . name + "</span>" ;
twit += "<span class='nickname'>@" + d . user . screen _name + "</span>" ;
twit += "</a>"
twit += "</div>"
/ *
< blockquote class = "twitter-tweet" >
< p > Tom Brokaw asks < a href = "https://twitter.com/search/%2523Romney" > # Romney < /a> to remove from ads 1997 NBC report on <a href="https:/ / twitter . com / search / % 2523 Gingrich ">#Gingrich</a> legal troubles. Romney unmoved. <a href=" http : //t.co/re7vtLNt" title="http://thecaucus.blogs.nytimes.com/2012/01/28/nbc-news-asks-romney-campaign-to-remove-ad/?hp">thecaucus.blogs.nytimes.com/2012/01/28/nbc…</a></p>
— Jim Roberts ( < a href = "http://twitter.com/nytjim" > @ nytjim < /a>) <a href="https:/ / twitter . com / nytjim / status / 163461388193366016 " data-datetime=" 2012 - 01 - 29 T03 : 20 : 06 + 00 : 00 " > January 29 , 2012 < / a >
< / b l o c k q u o t e >
* /
VMM . attachElement ( "#" + id , twit ) ;
//VMM.attachElement("#"+id, VMM.ExternalAPI.twitter.linkify(twit) );
}
} ,
maps : {
} ,
flickr : {
getPhoto : function ( mid , id ) {
// http://soundcloud.com/oembed?iframe=true&url=http://soundcloud.com/erasedtapes/olafur-arnalds-poland
var the _url = "http://api.flickr.com/services/rest/?method=flickr.photos.getSizes&api_key=" + VMM . Keys . flickr + "&photo_id=" + mid + "&format=json&nojsoncallback=1" ;
VMM . getJSON ( the _url , function ( d ) {
var flickr _large _id = id + "_large" ;
var flickr _thumb _id = id + "_thumb" ;
var flickr _img _large = d . sizes . size [ d . sizes . size . length - 1 ] . source ;
var flickr _img _thumb = d . sizes . size [ 0 ] . source ;
VMM . Element . attr ( flickr _large _id , "src" , flickr _img _large ) ;
VMM . Element . attr ( flickr _thumb _id , "src" , flickr _img _thumb ) ;
} ) ;
} ,
} ,
soundcloud : {
// VMM.ExternalAPI.soundcloud.getSound(url, id)
getSound : function ( url , id ) {
// http://soundcloud.com/oembed?iframe=true&url=http://soundcloud.com/erasedtapes/olafur-arnalds-poland
var the _url = "http://soundcloud.com/oembed?iframe=true&url=" + url + "" ;
VMM . getJSON ( the _url , function ( d ) {
VMM . attachElement ( "#" + id , d . html ) ;
} ) ;
} ,
} ,
// VMM.ExternalAPI.youtube.init(id);
youtube : {
init : function ( id ) {
if ( VMM . master _config . youtube . active ) {
VMM . master _config . youtube . createPlayer ( id ) ;
} else {
VMM . master _config . youtube . que . push ( id ) ;
if ( VMM . master _config . youtube . api _loaded ) {
} else {
var tag = document . createElement ( 'script' ) ;
tag . src = "http://www.youtube.com/player_api" ;
var firstScriptTag = document . getElementsByTagName ( 'script' ) [ 0 ] ;
firstScriptTag . parentNode . insertBefore ( tag , firstScriptTag ) ;
VMM . master _config . youtube . api _loaded = true ;
}
}
} ,
onAPIReady : function ( ) {
VMM . master _config . youtube . active = true ;
for ( var i = 0 ; i < VMM . master _config . youtube . que . length ; i ++ ) {
VMM . ExternalAPI . youtube . createPlayer ( VMM . master _config . youtube . que [ i ] ) ;
}
} ,
// VMM.ExternalAPI.youtube.createPlayer(id);
createPlayer : function ( id ) {
var p = {
active : false ,
player : { } ,
name : 'youtube_' + id ,
playing : false
} ;
p . player [ 'youtube_' + id ] = new YT . Player ( 'youtube_' + id , {
height : '390' ,
width : '640' ,
playerVars : {
enablejsapi : 1 ,
color : 'white' ,
showinfo : 0 ,
theme : 'light' ,
rel : 0 ,
origin : 'http://dev.verite.co'
} ,
videoId : id ,
events : {
'onReady' : VMM . ExternalAPI . youtube . onPlayerReady ,
'onStateChange' : VMM . ExternalAPI . youtube . onStateChange
}
} ) ;
VMM . master _config . youtube . array . push ( p ) ;
} ,
//VMM.ExternalAPI.youtube.stopPlayers();
stopPlayers : function ( ) {
for ( var i = 0 ; i < VMM . master _config . youtube . array . length ; i ++ ) {
if ( VMM . master _config . youtube . array [ i ] . playing ) {
var the _name = VMM . master _config . youtube . array [ i ] . name ;
VMM . master _config . youtube . array [ i ] . player [ the _name ] . stopVideo ( ) ;
}
}
} ,
onStateChange : function ( e ) {
for ( var i = 0 ; i < VMM . master _config . youtube . array . length ; i ++ ) {
var the _name = VMM . master _config . youtube . array [ i ] . name ;
if ( VMM . master _config . youtube . array [ i ] . player [ the _name ] == e . target ) {
if ( e . data == YT . PlayerState . PLAYING ) {
VMM . master _config . youtube . array [ i ] . playing = true ;
}
}
}
} ,
onPlayerReady : function ( e ) {
}
}
}
/ * M E D I A
=== === === === === === === === === === === === === === === === == * /
// something = new VMM.Media(parent, w, h, {thedata});
VMM . Media = function ( parent , w , h , thedata ) {
/ * P R I V A T E V A R S
=== === === === === === === === === === === === === === === === == * /
var data = { } ; // HOLDS DATA
var _valid = false ;
var config = {
width : 720 ,
height : 400 ,
content _width : 720 ,
content _height : 400 ,
ease : "easeInOutExpo" ,
duration : 1000 ,
spacing : 15
} ;
/ * E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
var $media = "" ;
var $container = "" ;
var $mediacontainer = "" ;
var $mediaelement = "" ;
var layout = parent ; // expecting media div
if ( w != null && w != "" ) { config . width = w } ;
if ( h != null && h != "" ) { config . height = h } ;
/ *
if ( typeof thedata != "undefined" ) {
data = thedata ;
this . init ( data ) ;
}
* /
/ * P U B L I C F U N C T I O N S
=== === === === === === === === === === === === === === === === == * /
this . init = function ( d ) {
if ( typeof d != 'undefined' ) {
this . setData ( d ) ;
} else {
trace ( "WAITING ON DATA" ) ;
}
} ;
var build = function ( media , caption , credit ) {
$media = VMM . appendAndGetElement ( layout , "<div>" , "media" ) ;
$container = VMM . appendAndGetElement ( $media , "<div>" , "container" ) ;
$mediacontainer = VMM . appendAndGetElement ( $container , "<div>" , "media-container" ) ;
if ( data . media != null && data . media != "" ) {
_valid = true ;
var m = { } ;
m = VMM . MediaType ( data . media ) ; //returns an object with .type and .id
if ( m . type == "image" ) {
VMM . appendElement ( $mediacontainer , "<img src='" + m . id + "'>" ) ;
} else if ( m . type == "youtube" ) {
VMM . appendElement ( $mediacontainer , "<iframe frameborder='0' src='http://www.youtube.com/embed/" + m . id + "?&rel=0&theme=light&showinfo=0&hd=1&autohide=0&color=white' allowfullscreen>" ) ;
} else if ( m . type == "vimeo" ) {
VMM . appendElement ( $mediacontainer , "<iframe frameborder='0' src='http://player.vimeo.com/video/" + m . id + "?title=0&byline=0&portrait=0&color=ffffff'>" ) ;
} else {
}
// CREDIT
if ( data . credit != null && data . credit != "" ) {
VMM . appendElement ( $container , VMM . createElement ( "div" , data . credit , "credit" ) ) ;
}
// CAPTION
if ( data . caption != null && data . caption != "" ) {
VMM . appendElement ( $container , VMM . createElement ( "div" , data . caption , "caption" ) ) ;
}
}
} ;
/ * G E T T E R S A N D S E T T E R S
=== === === === === === === === === === === === === === === === == * /
this . setData = function ( d ) {
if ( typeof d != 'undefined' ) {
data = d ;
build ( ) ;
} else {
trace ( "NO DATA" ) ;
}
} ;
/ * R E S I Z E
=== === === === === === === === === === === === === === === === == * /
function reSize ( ) {
}
}
// Less expensive to use prototype
VMM . Media . prototype . height = function ( h ) {
if ( h != null && h != "" ) {
config . height = h ;
reSize ( ) ;
} else {
return config . height ;
}
} ;
VMM . Media . prototype . width = function ( w ) {
if ( w != null && w != "" ) {
config . width = w ;
reSize ( ) ;
} else {
return config . width ;
}
} ;
/ * G E T T E R S A N D S E T T E R S
=== === === === === === === === === === === === === === === === == * /
VMM . Media . prototype . getData = function ( ) {
return data ;
} ;
VMM . Media . prototype . setConfig = function ( d ) {
if ( typeof d != 'undefined' ) {
config = d ;
} else {
trace ( "NO CONFIG DATA" ) ;
}
} ;
VMM . Media . prototype . getConfig = function ( ) {
return config ;
} ;
VMM . Media . prototype . setSize = function ( w , h ) {
if ( w != null ) { config . width = w } ;
if ( h != null ) { config . height = h } ;
if ( _active ) {
reSize ( ) ;
}
}
VMM . Media . prototype . active = function ( ) {
return _active ;
} ;
}
/ * T r a c e ( c o n s o l e . l o g )
=== === === === === === === === === === === === === === === === == * /
function trace ( msg ) {
if ( window . console ) {
console . log ( msg ) ;
} else if ( typeof ( jsTrace ) != 'undefined' ) {
jsTrace . send ( msg ) ;
} else {
//alert(msg);
}
}
/ * E x t e n d i n g D a t e t o i n c l u d e W e e k
=== === === === === === === === === === === === === === === === == * /
Date . prototype . getWeek = function ( ) {
var onejan = new Date ( this . getFullYear ( ) , 0 , 1 ) ;
return Math . ceil ( ( ( ( this - onejan ) / 86400000 ) + onejan . getDay ( ) + 1 ) / 7 ) ;
}
/ * E x t e n d i n g D a t e t o i n c l u d e D a y o f Y e a r
=== === === === === === === === === === === === === === === === == * /
Date . prototype . getDayOfYear = function ( ) {
var onejan = new Date ( this . getFullYear ( ) , 0 , 1 ) ;
return Math . ceil ( ( this - onejan ) / 86400000 ) ;
}
/ * A M O R E S P E C I F I C T Y P E O F ( ) ;
// http://rolandog.com/archives/2007/01/18/typeof-a-more-specific-typeof/
=== === === === === === === === === === === === === === === === == * /
// type.of()
var is = {
Null : function ( a ) { return a === null ; } ,
Undefined : function ( a ) { return a === undefined ; } ,
nt : function ( a ) { return ( a === null || a === undefined ) ; } ,
Function : function ( a ) { return ( typeof ( a ) === "function" ) ? a . constructor . toString ( ) . match ( /Function/ ) !== null : false ; } ,
String : function ( a ) { return ( typeof ( a ) === "string" ) ? true : ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /string/i ) !== null : false ; } ,
Array : function ( a ) { return ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /array/i ) !== null || a . length !== undefined : false ; } ,
Boolean : function ( a ) { return ( typeof ( a ) === "boolean" ) ? true : ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /boolean/i ) !== null : false ; } ,
Date : function ( a ) { return ( typeof ( a ) === "date" ) ? true : ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /date/i ) !== null : false ; } ,
HTML : function ( a ) { return ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /html/i ) !== null : false ; } ,
Number : function ( a ) { return ( typeof ( a ) === "number" ) ? true : ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /Number/ ) !== null : false ; } ,
Object : function ( a ) { return ( typeof ( a ) === "object" ) ? a . constructor . toString ( ) . match ( /object/i ) !== null : false ; } ,
RegExp : function ( a ) { return ( typeof ( a ) === "function" ) ? a . constructor . toString ( ) . match ( /regexp/i ) !== null : false ; }
} ;
var type = {
of : function ( a ) {
for ( var i in is ) {
if ( is [ i ] ( a ) ) {
return i . toLowerCase ( ) ;
}
}
}
} ;
/ * Y O U T U B E A P I
=== === === === === === === === === === === === === === === === == * /
function onYouTubePlayerAPIReady ( ) {
VMM . ExternalAPI . youtube . onAPIReady ( ) ;
}
/ * j Q u e r y E a s i n g v 1 . 3
http : //gsgd.co.uk/sandbox/jquery/easing/
=== === === === === === === === === === === === === === === === == * /
if ( typeof ( jQuery ) != 'undefined' ) {
jQuery . easing [ 'jswing' ] = jQuery . easing [ 'swing' ] ;
jQuery . extend ( jQuery . easing , {
def : 'easeOutQuad' ,
swing : function ( x , t , b , c , d ) {
//alert(jQuery.easing.default);
return jQuery . easing [ jQuery . easing . def ] ( x , t , b , c , d ) ;
} ,
easeInExpo : function ( x , t , b , c , d ) {
return ( t == 0 ) ? b : c * Math . pow ( 2 , 10 * ( t / d - 1 ) ) + b ;
} ,
easeOutExpo : function ( x , t , b , c , d ) {
return ( t == d ) ? b + c : c * ( - Math . pow ( 2 , - 10 * t / d ) + 1 ) + b ;
} ,
easeInOutExpo : function ( x , t , b , c , d ) {
if ( t == 0 ) return b ;
if ( t == d ) return b + c ;
if ( ( t /= d / 2 ) < 1 ) return c / 2 * Math . pow ( 2 , 10 * ( t - 1 ) ) + b ;
return c / 2 * ( - Math . pow ( 2 , - 10 * -- t ) + 2 ) + b ;
} ,
easeInQuad : function ( x , t , b , c , d ) {
return c * ( t /= d ) * t + b ;
} ,
easeOutQuad : function ( x , t , b , c , d ) {
return - c * ( t /= d ) * ( t - 2 ) + b ;
} ,
easeInOutQuad : function ( x , t , b , c , d ) {
if ( ( t /= d / 2 ) < 1 ) return c / 2 * t * t + b ;
return - c / 2 * ( ( -- t ) * ( t - 2 ) - 1 ) + b ;
} ,
} ) ;
}
/ * C L O N E O B J E C T S
=== === === === === === === === === === === === === === === === == * /
/ *
Object . prototype . clone = function ( ) {
var newObj = ( this instanceof Array ) ? [ ] : { } ;
for ( i in this ) {
if ( i == 'clone' ) continue ;
if ( this [ i ] && typeof this [ i ] == "object" ) {
newObj [ i ] = this [ i ] . clone ( ) ;
} else newObj [ i ] = this [ i ]
} return newObj ;
} ;
* /
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Begin VMM . Core . js
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
/ * C o r e
=== === === === === === === === === === === === === === === === == * /
/ * S e q u e n c e
=== === === === === === === === === === === === === === === === == * /
if ( typeof VMM != 'undefined' && typeof VMM . Sequence == 'undefined' ) {
VMM . Sequence = Class . extend ( {
initialize : function ( length , index ) {
trace ( 'sequence init' ) ;
// PUBLIC
this . increment = 1 ;
this . decrement = 1 ;
this . wrap = false ;
// PRIVATE
this . length = ( length == null ) ? 0 : length ;
this . index = ( index == null ) ? ( ( length == 0 ) ? - 1 : 0 ) : ( index >= length ) ? length - 1 : index ;
this . synced = [ ] ;
} ,
setLength : function ( i ) {
this . length = i ;
this . setIndex ( this . index ) ;
} ,
getLength : function ( ) {
return this . length ;
} ,
setIndex : function ( i ) {
if ( this . length <= 0 ) {
this . index = - 1 ;
return ;
}
if ( i < 0 ) i = ( this . wrap ) ? this . length - ( i % this . length ) : 0 ;
else if ( i >= this . length ) i = ( this . wrap ) ? ( i % this . length ) : this . length - 1 ;
var pi = this . index ;
this . index = i ;
if ( pi != this . index ) {
// update sequences
for ( var j = 0 ; j < this . synced . length ; j ++ ) {
var s = this . synced [ j ] ;
if ( s . getIndex ( ) != this . index ) s . setIndex ( this . index ) ;
}
}
} ,
getIndex : function ( ) {
return this . index ;
} ,
next : function ( ) {
this . setIndex ( this . index + this . increment ) ;
} ,
prev : function ( ) {
this . setIndex ( this . index - this . decrement ) ;
} ,
sync : function ( s , bothWays ) {
if ( s instanceof NYTMM . Sequence && s != this ) {
this . synced . push ( s ) ;
if ( bothWays ) s . sync ( this ) ;
return true ;
}
return false ;
} ,
unsync : function ( s , bothWays ) {
// update sequences
for ( var i = 0 ; i < this . synced . length ; i ++ ) {
if ( this . synced [ i ] == s ) {
this . synced . splice ( i , 1 ) ;
if ( bothWays ) s . unsync ( this ) ;
return true ;
}
}
return false ;
}
} ) ;
}
/ * S l i d e r
=== === === === === === === === === === === === === === === === == * /
if ( typeof VMM != 'undefined' && typeof VMM . Slider == 'undefined' ) {
VMM . Slider = function ( parent , content _width , content _height , is _timeline ) {
/ * D E V I C E
=== === === === === === === === === === === === === === === === == * /
/ *
trace ( "VMM.Browser.OS" ) ;
trace ( VMM . Browser . browser ) ;
trace ( VMM . Browser . version ) ;
trace ( VMM . Browser . OS ) ;
trace ( VMM . Browser . device ) ;
* /
/ * P R I V A T E V A R S
=== === === === === === === === === === === === === === === === == * /
var _private _var = "private" ;
var events = { } ; // CUSTOM EVENT HOLDER
var data = [ ] ; // HOLDS SLIDE DATA
var slides _content = "" ;
var slides = [ ] ;
var medias = [ ] ;
var current _slide = 0 ;
var current _width = 960 ;
var touch = {
move : false ,
x : 10 ,
y : 0 ,
off : 0 ,
dampen : 48
} ;
var slide _positions = [ ] ;
var config = {
interval : 10 ,
something : 0 ,
width : 720 ,
height : 400 ,
content _width : 720 ,
content _height : 400 ,
content _padding : 130 ,
ease : "easeInOutExpo" ,
duration : 1000 ,
nav _width : 100 ,
nav _height : 200 ,
timeline : false ,
spacing : 15 ,
} ;
var slider _width = 1000 ;
if ( content _width != null && content _width != "" ) {
config . width = content _width ;
}
if ( content _height != null && content _height != "" ) {
config . height = content _height ;
}
if ( is _timeline != null && is _timeline != "" ) {
config . timeline = is _timeline ;
}
var content = "" ;
var _active = false ;
/ * E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
var $slider = "" ;
var $slider _mask = "" ;
var $slider _container = "" ;
var $slides _items = "" ;
//var $slide = "";
var navigation = { } ;
// Nav Items
navigation . nextBtn ;
navigation . prevBtn ;
navigation . nextDate ;
navigation . prevDate ;
navigation . nextTitle ;
navigation . prevTitle ;
/ * P U B L I C V A R S
=== === === === === === === === === === === === === === === === == * /
this . ver = "0.1" ;
var layout = parent ; // expecting slider div
/ * P U B L I C F U N C T I O N S
=== === === === === === === === === === === === === === === === == * /
this . init = function ( d ) {
if ( typeof d != 'undefined' ) {
this . setData ( d ) ;
} else {
trace ( "WAITING ON DATA" ) ;
}
} ;
this . width = function ( w ) {
if ( w != null && w != "" ) {
config . width = w ;
reSize ( ) ;
} else {
return config . width ;
}
}
this . height = function ( h ) {
if ( h != null && h != "" ) {
config . height = h ;
reSize ( ) ;
} else {
return config . height ;
}
}
/ * G E T T E R S A N D S E T T E R S
=== === === === === === === === === === === === === === === === == * /
this . setData = function ( d ) {
if ( typeof d != 'undefined' ) {
data = d ;
build ( ) ;
} else {
trace ( "NO DATA" ) ;
}
} ;
this . getData = function ( ) {
return data ;
} ;
this . setConfig = function ( d ) {
if ( typeof d != 'undefined' ) {
config = d ;
// TO DO
// FIRE AN EVENT ETC
} else {
trace ( "NO CONFIG DATA" ) ;
}
}
this . getConfig = function ( ) {
return config ;
} ;
this . setSize = function ( w , h ) {
if ( w != null ) { config . width = w } ;
if ( h != null ) { config . height = h } ;
if ( _active ) {
reSize ( ) ;
}
}
this . active = function ( ) {
return _active ;
} ;
this . getCurrentNumber = function ( ) {
return current _slide ;
} ;
this . setSlide = function ( n ) {
goToSlide ( n ) ;
} ;
/ * O N E V E N T
=== === === === === === === === === === === === === === === === == * /
function onConfigSet ( ) {
trace ( "onConfigSet" ) ;
} ;
function reSize ( go _to _slide , from _start ) {
var _go _to _slide = true ;
var _from _start = false ;
if ( go _to _slide != null ) { _go _to _slide = go _to _slide } ;
if ( from _start != null ) { _from _start = from _start } ;
current _width = config . width ;
config . nav _height = VMM . Element . height ( navigation . prevBtnContainer ) ;
config . content _width = current _width - ( config . content _padding * 2 ) ;
VMM . Element . width ( $slides _items , ( slides . length * config . content _width ) ) ;
if ( _from _start ) {
var _pos = VMM . Element . position ( slides [ current _slide ] ) ;
VMM . Element . css ( $slider _container , "left" , _pos . left ) ;
}
// Position slides
positionSlides ( ) ;
// Position Nav
VMM . Element . css ( navigation . nextBtn , "left" , ( current _width - config . nav _width ) ) ;
VMM . Element . height ( navigation . prevBtn , config . height ) ;
VMM . Element . height ( navigation . nextBtn , config . height ) ;
VMM . Element . css ( navigation . nextBtnContainer , "top" , ( ( config . height / 2 ) - ( config . nav _height / 2 ) ) ) ;
VMM . Element . css ( navigation . prevBtnContainer , "top" , ( ( config . height / 2 ) - ( config . nav _height / 2 ) ) ) ;
// Animate Changes
VMM . Element . height ( $slider _mask , config . height ) ;
VMM . Element . width ( $slider _mask , current _width ) ;
if ( _go _to _slide ) {
goToSlide ( current _slide , "linear" , 1 ) ;
} ;
if ( current _slide == 0 ) {
VMM . Element . visible ( navigation . prevBtn , false ) ;
}
}
function onNextClick ( e ) {
if ( current _slide == slides . length - 1 ) {
VMM . Element . animate ( $slider _container , config . duration , config . ease , { "left" : - ( VMM . Element . position ( slides [ current _slide ] ) . left ) } ) ;
} else {
goToSlide ( current _slide + 1 ) ;
upDate ( ) ;
}
}
function onPrevClick ( e ) {
if ( current _slide == 0 ) {
goToSlide ( current _slide ) ;
} else {
goToSlide ( current _slide - 1 ) ;
upDate ( ) ;
}
}
function onTouchUpdate ( e , b ) {
if ( slide _positions . length == 0 ) {
for ( var i = 0 ; i < slides . length ; i ++ ) {
var sp = VMM . Element . position ( slides [ i ] ) ;
slide _positions . push ( sp . left ) ;
}
}
if ( typeof b . left == "number" ) {
var _pos = b . left ;
if ( _pos < - ( VMM . Element . position ( slides [ current _slide ] ) . left ) - ( config . width / 3 ) ) {
onNextClick ( ) ;
} else if ( _pos > - ( VMM . Element . position ( slides [ current _slide ] ) . left ) + ( config . width / 3 ) ) {
onPrevClick ( ) ;
} else {
VMM . Element . animate ( $slider _container , config . duration , config . ease , { "left" : - ( VMM . Element . position ( slides [ current _slide ] ) . left ) } ) ;
}
} else {
VMM . Element . animate ( $slider _container , config . duration , config . ease , { "left" : - ( VMM . Element . position ( slides [ current _slide ] ) . left ) } ) ;
}
if ( typeof b . top == "number" ) {
VMM . Element . animate ( $slider _container , config . duration , config . ease , { "top" : - b . top } ) ;
//VMM.Element.animate(layout, _duration, _ease, {scrollTop: VMM.Element.prop(layout, "scrollHeight") + b.top });
//VMM.Element.animate(layout, _duration, _ease, {scrollTop: VMM.Element.prop(layout, "scrollHeight") + VMM.Element.height(layout) });
//VMM.Element.animate($slider_container, config.duration, config.ease, {"top": -400});
} else {
}
} ;
function upDate ( ) {
VMM . fireEvent ( layout , "UPDATE" ) ;
} ;
/ * P R I V A T E F U N C T I O N S
=== === === === === === === === === === === === === === === === == * /
var getData = function ( d ) {
data = d ;
} ;
/ * S L I D E S
=== === === === === === === === === === === === === === === === == * /
// BUILD SLIDES
var buildSlides = function ( d ) {
// Clear out existing content
VMM . attachElement ( $slides _items , "" ) ;
for ( var i = 0 ; i < d . length ; i ++ ) {
var bw = "" ;
var _slide ;
var _media ;
bw = VMM . createElement ( "div" , d [ i ] . content , "content" ) ;
_slide = VMM . appendAndGetElement ( $slides _items , "<div>" , "slider-item" , bw ) ;
slides . push ( _slide ) ;
}
}
// POSITION SLIDES AND SIZE THEM
var positionSlides = function ( ) {
/ * S I Z E S L I D E S
=== === === === === === === === === === === === === === === === == * /
VMM . Element . css ( ".slider-item" , "width" , config . content _width ) ;
VMM . Element . height ( ".slider-item" , config . height ) ;
VMM . Element . css ( ".slider-item .layout-text-media .media .media-container img" , "max-height" , config . height - 50 ) ;
VMM . Element . css ( ".slider-item .layout-media .media .media-container img" , "max-height" , config . height - 150 ) ;
VMM . Element . css ( ".slider-item .media .media-container .soundcloud" , "max-height" , 168 ) ;
/ * R E S I Z E I F R A M E M E D I A E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
//var _iframe_height = Math.round(config.height) - 60;
var _iframe _height _full = Math . round ( config . height ) - 160 ;
//var _iframe_width = Math.round((_iframe_height / 9) * 16);
var _iframe _width _full = Math . round ( ( _iframe _height _full / 9 ) * 16 ) ;
var _iframe _width = ( config . content _width / 100 ) * 60 ;
var _iframe _height = Math . round ( ( _iframe _width / 16 ) * 9 ) + 25 ;
// NORMAL
VMM . Element . height ( ".slider-item .media .media-container .media-frame" , _iframe _height ) ;
VMM . Element . width ( ".slider-item .media .media-container .media-frame" , _iframe _width ) ;
//VMM.Element.width(".slider-item .media .media-container .media-frame", _iframe_width);
//VMM.Element.css(".slider-item .media .media-container .media-frame", "max-width", config.content_width );
// IFRAME FULL SIZE VIDEO
VMM . Element . height ( ".slider-item .layout-media .media .media-container .media-frame" , _iframe _height _full ) ;
VMM . Element . width ( ".slider-item .layout-media .media .media-container .media-frame" , _iframe _width _full ) ;
// IFRAME FULL SIZE NON VIDEO
VMM . Element . height ( ".slider-item .layout-media .media .media-container .soundcloud" , config . height - 150 ) ;
VMM . Element . width ( ".slider-item .layout-media .media .media-container .soundcloud" , config . content _width ) ;
VMM . Element . width ( ".slider-item .layout-text-media .media .media-container .soundcloud" , _iframe _width ) ;
// MAPS
VMM . Element . height ( ".slider-item .media .media-container .map" , _iframe _height _full ) ;
// MAX WIDTH
VMM . Element . css ( ".slider-item .layout-text-media .media .media-container .media-frame" , "max-width" , config . content _width ) ;
//VMM.Element.width(".slider-item .layout-text-media .media .media-container .media-frame", _iframe_width);
//VMM.Element.css(".slider-item .layout-text-media .media .media-container .media-frame", "max-height", _iframe_height );
/ * P O S I T I O N S L I D E S
=== === === === === === === === === === === === === === === === == * /
var pos = 0 ;
for ( var i = 0 ; i < slides . length ; i ++ ) {
pos = i * ( config . width + config . spacing ) ;
VMM . Element . css ( slides [ i ] , "left" , pos ) ;
}
}
var opacitySlides = function ( n ) {
var _ease = "linear" ;
for ( var i = 0 ; i < slides . length ; i ++ ) {
if ( i == current _slide ) {
VMM . Element . animate ( slides [ i ] , config . duration , _ease , { "opacity" : 1 } ) ;
} else if ( i == current _slide - 1 ) {
VMM . Element . animate ( slides [ i ] , config . duration , _ease , { "opacity" : 0.1 } ) ;
} else if ( i == current _slide + 1 ) {
VMM . Element . animate ( slides [ i ] , config . duration , _ease , { "opacity" : 0.1 } ) ;
} else {
VMM . Element . css ( slides [ i ] , "opacity" , n ) ;
}
}
}
// Go to slide
//goToSlide(n, ease, duration);
var goToSlide = function ( n , ease , duration , fast , firstrun ) {
/ * S T O P A N Y V I D E O P L A Y E R S A C T I V E
=== === === === === === === === === === === === === === === === == * /
VMM . ExternalAPI . youtube . stopPlayers ( ) ;
// Set current slide
current _slide = n ;
var _ease = config . ease ;
var _duration = config . duration ;
var is _last = false ;
var is _first = false ;
if ( current _slide == 0 ) {
is _first = true ;
}
if ( current _slide + 1 == slides . length ) {
is _last = true
}
if ( ease != null && ease != "" ) { _ease = ease } ;
if ( duration != null && duration != "" ) { _duration = duration } ;
/ * g e t s l i d e p o s i t i o n
=== === === === === === === === === === === === === === === === == * /
var _pos = VMM . Element . position ( slides [ current _slide ] ) ;
/ * s e t p r o p e r n a v t i t l e s a n d d a t e s e t c .
=== === === === === === === === === === === === === === === === == * /
if ( is _first ) {
VMM . Element . visible ( navigation . prevBtn , false ) ;
} else {
VMM . Element . visible ( navigation . prevBtn , true ) ;
if ( config . timeline ) {
VMM . attachElement ( navigation . prevDate , data [ current _slide - 1 ] . date ) ;
}
VMM . attachElement ( navigation . prevTitle , VMM . Util . unlinkify ( data [ current _slide - 1 ] . title ) ) ;
}
if ( is _last ) {
VMM . Element . visible ( navigation . nextBtn , false ) ;
} else {
VMM . Element . visible ( navigation . nextBtn , true ) ;
if ( config . timeline ) {
VMM . attachElement ( navigation . nextDate , data [ current _slide + 1 ] . date ) ;
}
VMM . attachElement ( navigation . nextTitle , VMM . Util . unlinkify ( data [ current _slide + 1 ] . title ) ) ;
}
/ * A N I M A T E S L I D E
=== === === === === === === === === === === === === === === === == * /
if ( fast ) {
VMM . Element . css ( $slider _container , "left" , - ( _pos . left - config . content _padding ) ) ;
} else {
VMM . Element . stop ( $slider _container ) ;
VMM . Element . animate ( $slider _container , _duration , _ease , { "left" : - ( _pos . left - config . content _padding ) } ) ;
}
if ( firstrun ) {
VMM . fireEvent ( layout , "LOADED" ) ;
}
/ * S E T V e r t i c a l S c o l l
=== === === === === === === === === === === === === === === === == * /
//opacitySlides(0.85);
if ( VMM . Element . height ( slides [ current _slide ] ) > config . height ) {
VMM . Element . css ( ".slider" , "overflow-y" , "scroll" ) ;
} else {
VMM . Element . css ( layout , "overflow-y" , "hidden" ) ;
VMM . Element . animate ( layout , _duration , _ease , { scrollTop : VMM . Element . prop ( layout , "scrollHeight" ) - VMM . Element . height ( layout ) } ) ;
}
}
/ * N A V I G A T I O N
=== === === === === === === === === === === === === === === === == * /
var buildNavigation = function ( ) {
var temp _icon = "<div class='icon'> </div>" ;
navigation . nextBtn = VMM . appendAndGetElement ( $slider , "<div>" , "nav-next" ) ;
navigation . prevBtn = VMM . appendAndGetElement ( $slider , "<div>" , "nav-previous" ) ;
navigation . nextBtnContainer = VMM . appendAndGetElement ( navigation . nextBtn , "<div>" , "nav-container" , temp _icon ) ;
navigation . prevBtnContainer = VMM . appendAndGetElement ( navigation . prevBtn , "<div>" , "nav-container" , temp _icon ) ;
if ( config . timeline ) {
navigation . nextDate = VMM . appendAndGetElement ( navigation . nextBtnContainer , "<div>" , "date" , "1957" ) ;
navigation . prevDate = VMM . appendAndGetElement ( navigation . prevBtnContainer , "<div>" , "date" , "1957" ) ;
}
navigation . nextTitle = VMM . appendAndGetElement ( navigation . nextBtnContainer , "<div>" , "title" , "Title Goes Here" ) ;
navigation . prevTitle = VMM . appendAndGetElement ( navigation . prevBtnContainer , "<div>" , "title" , "Title Goes Here" ) ;
VMM . bindEvent ( ".nav-next" , onNextClick ) ;
VMM . bindEvent ( ".nav-previous" , onPrevClick ) ;
}
/ * B U I L D
=== === === === === === === === === === === === === === === === == * /
var build = function ( ) {
// Clear out existing content
VMM . attachElement ( layout , "" ) ;
// Get DOM Objects to local objects
$slider = VMM . getElement ( "div.slider" ) ;
$slider _mask = VMM . appendAndGetElement ( $slider , "<div>" , "slider-container-mask" ) ;
$slider _container = VMM . appendAndGetElement ( $slider _mask , "<div>" , "slider-container" ) ;
$slides _items = VMM . appendAndGetElement ( $slider _container , "<div>" , "slider-item-container" ) ;
// BUILD NAVIGATION
buildNavigation ( ) ;
// ATTACH SLIDES
buildSlides ( data ) ;
/ * M A K E S L I D E R T O U C H A B L E
=== === === === === === === === === === === === === === === === == * /
var _ _duration = 3000 ;
if ( VMM . Browser . device == "tablet" || VMM . Browser . device == "mobile" ) {
config . duration = 500 ;
_ _duration = 1000 ;
VMM . TouchSlider . createPanel ( $slider _container , $slider _container , VMM . Element . width ( slides [ 0 ] ) , config . spacing , true ) ;
VMM . bindEvent ( $slider _container , onTouchUpdate , "TOUCHUPDATE" ) ;
} else if ( VMM . Browser . device == "mobile" ) {
} else {
//VMM.DragSlider.createPanel($slider_container, $slider_container, VMM.Element.width(slides[0]), config.spacing, true);
}
reSize ( false , true ) ;
VMM . Element . visible ( navigation . prevBtn , false ) ;
// GO TO FIRST SLIDE
goToSlide ( 0 , "easeOutExpo" , _ _duration , true , true ) ;
_active = true ;
} ;
} ;
}
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Begin VMM . Util . js
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
/ * U t i l i t i e s a n d U s e f u l F u n c t i o n s
=== === === === === === === === === === === === === === === === == * /
if ( typeof VMM != 'undefined' && typeof VMM . Util == 'undefined' ) {
VMM . Util = ( {
init : function ( ) {
return this ;
} ,
/ * R A N D O M B E T W E E N
=== === === === === === === === === === === === === === === === == * /
//VMM.Util.randomBetween(1, 3)
randomBetween : function ( min , max ) {
return Math . floor ( Math . random ( ) * ( max - min + 1 ) + min ) ;
} ,
/ * C U S T O M S O R T
=== === === === === === === === === === === === === === === === == * /
customSort : function ( a , b ) {
var a1 = a , b1 = b ;
if ( a1 == b1 ) return 0 ;
return a1 > b1 ? 1 : - 1 ;
} ,
/ * G i v e n a n i n t o r d e c i m a l , t u r n t h a t i n t o s t r i n g i n $ x x x , x x x . x x f o r m a t .
=== === === === === === === === === === === === === === === === == * /
number2money : function ( n , symbol , padding ) {
var symbol = ( symbol !== null ) ? symbol : true ; // add $
var padding = ( padding !== null ) ? padding : false ; //pad with .00
var number = VMM . Math2 . floatPrecision ( n , 2 ) ; // rounded correctly to two digits, if decimals passed
var formatted = this . niceNumber ( number ) ;
// no decimal and padding is enabled
if ( ! formatted . split ( /\./g ) [ 1 ] && padding ) formatted = formatted + ".00" ;
// add money sign
if ( symbol ) formatted = "$" + formatted ;
return formatted ;
} ,
/ * R e t u r n s a w o r d c o u n t n u m b e r
=== === === === === === === === === === === === === === === === == * /
wordCount : function ( s ) {
var fullStr = s + " " ;
var initial _whitespace _rExp = /^[^A-Za-z0-9\'\-]+/gi ;
var left _trimmedStr = fullStr . replace ( initial _whitespace _rExp , "" ) ;
var non _alphanumerics _rExp = /[^A-Za-z0-9\'\-]+/gi ;
var cleanedStr = left _trimmedStr . replace ( non _alphanumerics _rExp , " " ) ;
var splitString = cleanedStr . split ( " " ) ;
var word _count = splitString . length - 1 ;
if ( fullStr . length < 2 ) {
word _count = 0 ;
}
return word _count ;
} ,
/ * P a r s e D a t e
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.parseDate(str)
parseDate : function ( d ) {
var _date ;
if ( d . match ( /,/gi ) ) {
var _d _array = d . split ( "," ) ;
for ( var i = 0 ; i < _d _array . length ; i ++ ) {
_d _array [ i ] = parseInt ( _d _array [ i ] ) ;
}
_date = new Date ( ) ;
if ( _d _array [ 0 ] ) { _date . setFullYear ( _d _array [ 0 ] ) ; }
if ( _d _array [ 1 ] > 1 ) { _date . setMonth ( _d _array [ 1 ] - 1 ) ; } else { _date . setMonth ( 0 ) ; }
if ( _d _array [ 2 ] > 1 ) { _date . setDate ( _d _array [ 2 ] ) ; } else { _date . setDate ( 1 ) ; }
if ( _d _array [ 3 ] > 1 ) { _date . setHours ( _d _array [ 3 ] ) ; } else { _date . setHours ( 0 ) ; }
if ( _d _array [ 4 ] > 1 ) { _date . setMinutes ( _d _array [ 4 ] ) ; } else { _date . setMinutes ( 0 ) ; }
if ( _d _array [ 5 ] > 1 ) { _date . setSeconds ( _d _array [ 5 ] ) ; } else { _date . setSeconds ( 0 ) ; }
if ( _d _array [ 6 ] > 1 ) { _date . setMilliseconds ( _d _array [ 6 ] ) ; } else { _date . setMilliseconds ( 0 ) ; }
} else if ( d . match ( "/" ) ) {
_date = new Date ( d ) ;
} else if ( d . length < 5 ) {
_date = new Date ( ) ;
_date . setFullYear ( parseInt ( d ) ) ;
_date . setMonth ( 0 ) ;
_date . setDate ( 1 ) ;
_date . setHours ( 0 ) ;
_date . setMinutes ( 0 ) ;
_date . setSeconds ( 0 ) ;
_date . setMilliseconds ( 0 ) ;
} else {
_date = new Date (
parseInt ( d . slice ( 0 , 4 ) ) ,
parseInt ( d . slice ( 4 , 6 ) ) - 1 ,
parseInt ( d . slice ( 6 , 8 ) ) ,
parseInt ( d . slice ( 8 , 10 ) ) ,
parseInt ( d . slice ( 10 , 12 ) )
) ;
}
return _date ;
} ,
/ * G e t t h e c o r r e s p o n d i n g r a t i o n u m b e r
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.ratio.r16_9(w, h) // Returns corresponding number
ratio : {
r16 _9 : function ( w , h ) {
if ( w !== null && w !== "" ) {
return Math . round ( ( h / 16 ) * 9 ) ;
} else if ( h !== null && h !== "" ) {
return Math . round ( ( w / 9 ) * 16 ) ;
}
} ,
r4 _3 : function ( w , h ) {
if ( w !== null && w !== "" ) {
return Math . round ( ( h / 4 ) * 3 ) ;
} else if ( h !== null && h !== "" ) {
return Math . round ( ( w / 3 ) * 4 ) ;
}
}
} ,
// VMM.Util.date.day[0];
// VMM.Util.date.get12HRTime(time, seconds_true);
date : {
// somestring = VMM.Util.date.month[2]; // Returns March
month : [ "January" , "February" , "March" , "April" , "May" , "June" , "July" , "August" , "September" , "October" , "November" , "December" ] ,
// somestring = VMM.Util.date.month_abbrev[1]; // Returns Feb.
month _abbr : [ "Jan." , "Feb." , "March" , "April" , "May" , "June" , "July" , "Aug." , "Sept." , "Oct." , "Nov." , "Dec." ] ,
day : [ "Sunday" , "Monday" , "Tuesday" , "Wednesday" , "Thursday" , "Friday" , "Saturday" ] ,
day _abbr : [ "Sun." , "Mon." , "Tues." , "Wed." , "Thurs." , "Fri." , "Sat." ] ,
hour : [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 10 , 11 , 12 ] ,
hour _suffix : [ "am" ] ,
//VMM.Util.date.prettyDate(d, is_abbr)
prettyDate : function ( d , is _abbr , date _type ) {
var _date = "" ;
if ( type . of ( d ) == "date" ) {
if ( d . getMonth ( ) === 0 && d . getDate ( ) == 1 && d . getHours ( ) === 0 && d . getMinutes ( ) === 0 ) {
// trace("YEAR ONLY");
_date = d . getFullYear ( ) ;
} else {
if ( d . getDate ( ) <= 1 && d . getHours ( ) === 0 && d . getMinutes ( ) === 0 ) {
// trace("YEAR MONTH");
if ( is _abbr ) {
_date = VMM . Util . date . month _abbr [ d . getMonth ( ) ] ;
} else {
_date = VMM . Util . date . month [ d . getMonth ( ) ] + " " + d . getFullYear ( ) ;
}
} else if ( d . getHours ( ) === 0 && d . getMinutes ( ) === 0 ) {
// trace("YEAR MONTH DAY");
if ( is _abbr ) {
_date = VMM . Util . date . month _abbr [ d . getMonth ( ) ] + " " + d . getDate ( ) ;
} else {
_date = VMM . Util . date . month [ d . getMonth ( ) ] + " " + d . getDate ( ) + ", " + d . getFullYear ( ) ;
}
} else if ( d . getMinutes ( ) === 0 ) {
// trace("YEAR MONTH DAY HOUR");
if ( is _abbr ) {
//_date = VMM.Util.date.get12HRTime(d) + " " + (d.getMonth()+1) + "/" + d.getDate() + "/" + d.getFullYear() ;
_date = VMM . Util . date . get12HRTime ( d ) ;
} else {
_date = VMM . Util . date . get12HRTime ( d ) + "<br/><small>" + VMM . Util . date . month [ d . getMonth ( ) ] + " " + d . getDate ( ) + ", " + d . getFullYear ( ) + " </small> " ;
}
} else {
// trace("YEAR MONTH DAY HOUR MINUTE");
if ( is _abbr ) {
_date = VMM . Util . date . day [ d . getDay ( ) ] + ", " + VMM . Util . date . month _abbr [ d . getMonth ( ) ] + " " + d . getDate ( ) + ", " + d . getFullYear ( ) + " at " + VMM . Util . date . get12HRTime ( d ) ;
} else {
_date = VMM . Util . date . get12HRTime ( d ) + "<br/><small>" + VMM . Util . date . day [ d . getDay ( ) ] + ", " + VMM . Util . date . month [ d . getMonth ( ) ] + " " + d . getDate ( ) + ", " + d . getFullYear ( ) + " </small> " ;
}
}
}
//_date = d.getFullYear();
} else {
trace ( "NOT A VALID DATE?" ) ;
trace ( d ) ;
}
return _date ;
} ,
prettyMonth : function ( m , is _year ) {
var _month = "" ;
if ( type . of ( t ) == "date" ) {
}
return _month ;
} ,
get12HRTime : function ( t , is _seconds ) {
var _time = "" ;
if ( type . of ( t ) == "date" ) {
_time = VMM . Util . date . theHour ( t . getHours ( ) ) + ":" + VMM . Util . date . minuteZeroFill ( t . getMinutes ( ) ) ;
if ( is _seconds ) {
_time = _time + ":" + VMM . Util . date . minuteZeroFill ( t . getSeconds ( ) ) ;
}
_time = _time + VMM . Util . date . hourSuffix ( t . getHours ( ) ) ;
}
return _time ;
} ,
theHour : function ( hr ) {
if ( hr > 0 && hr < 13 ) {
return ( hr ) ;
}
if ( hr == "0" ) {
hr = 12 ;
return ( hr ) ;
}
if ( hr === 0 ) {
return ( 12 ) ;
}
return ( hr - 12 ) ;
} ,
minuteZeroFill : function ( v ) {
if ( v > 9 ) {
return "" + v ;
}
return "0" + v ;
} ,
hourSuffix : function ( t ) {
if ( t < 12 ) {
return ( " am" ) ;
}
return ( " pm" ) ;
}
} ,
// VMM.Util.doubledigit(number).
doubledigit : function ( n ) {
return ( n < 10 ? '0' : '' ) + n ;
} ,
/ * R e t u r n s a t r u n c a t e d s e g e m e n t o f a l o n g s t r i n g o f b e t w e e n m i n a n d m a x w o r d s . I f p o s s i b l e , e n d s o n a p e r i o d ( o t h e r w i s e g o e s t o m a x ) .
=== === === === === === === === === === === === === === === === == * /
truncateWords : function ( s , min , max ) {
if ( ! min ) min = 30 ;
if ( ! max ) max = min ;
var initial _whitespace _rExp = /^[^A-Za-z0-9\'\-]+/gi ;
var left _trimmedStr = s . replace ( initial _whitespace _rExp , "" ) ;
var words = left _trimmedStr . split ( " " ) ;
var result = [ ] ;
min = Math . min ( words . length , min ) ;
max = Math . min ( words . length , max ) ;
for ( var i = 0 ; i < min ; i ++ ) {
result . push ( words [ i ] ) ;
}
for ( var j = min ; i < max ; i ++ ) {
var word = words [ i ] ;
result . push ( word ) ;
if ( word . charAt ( word . length - 1 ) == '.' ) {
break ;
}
}
return ( result . join ( ' ' ) ) ;
} ,
/ * T u r n s p l a i n t e x t l i n k s i n t o r e a l l i n k s
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.linkify();
linkify : function ( text , targets , is _touch ) {
if ( ! text ) return text ;
text = text . replace ( /((https?\:\/\/|ftp\:\/\/)|(www\.))(\S+)(\w{2,4})(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?/gi , function ( url ) {
var nice = url ;
var _touch = "" ;
if ( url . search ( '^https?:\/\/' ) < 0 ) url = 'http://' + url ;
_touch = "onclick = 'void(0)'" ;
if ( is _touch ) {
_touch = "onclick = 'void(0)'" ;
}
onclick = "void(0)" ;
if ( targets === null || targets === "" ) return '<a href="' + url + " " + _touch + '">' + url + '</a>' ;
else return "<a href='" + url + " " + _touch + " target='" + targets + "'>'" + url + "</a>" ;
} ) ;
return text ;
} ,
/ * T u r n s p l a i n t e x t l i n k s i n t o r e a l l i n k s
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.unlinkify();
unlinkify : function ( text ) {
if ( ! text ) return text ;
text = text . replace ( /<a\b[^>]*>/i , "" ) ;
text = text . replace ( /<\/a>/i , "" ) ;
return text ;
} ,
/ * T K
=== === === === === === === === === === === === === === === === == * /
nl2br : function ( text ) {
return text . replace ( /(\r\n|[\r\n]|\\n|\\r)/g , "<br/>" ) ;
} ,
/ * G e n e r a t e a U n i q u e I D
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.unique_ID(size);
unique _ID : function ( size ) {
var getRandomNumber = function ( range ) {
return Math . floor ( Math . random ( ) * range ) ;
} ;
var getRandomChar = function ( ) {
var chars = "abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ" ;
return chars . substr ( getRandomNumber ( 62 ) , 1 ) ;
} ;
var randomID = function ( size ) {
var str = "" ;
for ( var i = 0 ; i < size ; i ++ ) {
str += getRandomChar ( ) ;
}
return str ;
} ;
return randomID ( size ) ;
} ,
/ * T e l l s y o u i f a n u m b e r i s e v e n o r n o t
=== === === === === === === === === === === === === === === === == * /
// VMM.Util.isEven(n)
isEven : function ( n ) {
return ( n % 2 === 0 ) ? true : false ;
} ,
/ * G e t U R L V a r i a b l e s
=== === === === === === === === === === === === === === === === == * /
// var somestring = VMM.Util.getUrlVars(str_url)["varname"];
getUrlVars : function ( str ) {
var vars = [ ] , hash ;
var 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 ] ;
}
trace ( vars ) ;
return vars ;
} ,
/ * C l e a n s u p s t r i n g s t o b e c o m e r e a l H T M L
=== === === === === === === === === === === === === === === === == * /
toHTML : function ( text ) {
text = this . nl2br ( text ) ;
text = this . linkify ( text ) ;
return text . replace ( /\s\s/g , " " ) ;
} ,
/ * R e t u r n s t e x t s t r i n g s a s C a m e l C a s e
=== === === === === === === === === === === === === === === === == * /
toCamelCase : function ( s , forceLowerCase ) {
if ( forceLowerCase !== false ) forceLowerCase = true ;
var sps = ( ( forceLowerCase ) ? s . toLowerCase ( ) : s ) . split ( " " ) ;
for ( var i = 0 ; i < sps . length ; i ++ ) {
sps [ i ] = sps [ i ] . substr ( 0 , 1 ) . toUpperCase ( ) + sps [ i ] . substr ( 1 ) ;
}
return sps . join ( " " ) ;
} ,
/ * R e p l a c e s d u m b q u o t e m a r k s w i t h s m a r t o n e s
=== === === === === === === === === === === === === === === === == * /
properQuotes : function ( str ) {
return str . replace ( /\"([^\"]*)\"/gi , "“$1”" ) ;
} ,
/ * G i v e n a n i n t o r d e c i m a l , r e t u r n a s t r i n g w i t h p r e t t y c o m m a s i n t h e c o r r e c t s p o t .
=== === === === === === === === === === === === === === === === == * /
niceNumber : function ( n ) {
var amount = String ( Math . abs ( Number ( n ) ) ) ;
var leftOfDecimal = amount . split ( /\./g ) [ 0 ] ;
var rightOfDecimal = amount . split ( /\./g ) [ 1 ] ;
var formatted _text = '' ;
var num _a = leftOfDecimal . toArray ( ) ;
num _a . reverse ( ) ;
for ( var i = 1 ; i <= num _a . length ; i ++ ) {
if ( ( i % 3 == 0 ) && ( i < num _a . length ) ) {
formatted _text = "," + num _a [ i - 1 ] + formatted _text ;
} else {
formatted _text = num _a [ i - 1 ] + formatted _text ;
}
}
if ( rightOfDecimal != null && rightOfDecimal != '' && rightOfDecimal != undefined ) {
return formatted _text + "." + rightOfDecimal ;
} else {
return formatted _text ;
}
} ,
/ * T r a n s f o r m t e x t t o T i t l e C a s e
=== === === === === === === === === === === === === === === === == * /
toTitleCase : function ( t ) {
var _ _TitleCase = {
_ _smallWords : [ 'a' , 'an' , 'and' , 'as' , 'at' , 'but' , 'by' , 'en' , 'for' , 'if' , 'in' , 'of' , 'on' , 'or' , 'the' , 'to' , 'v[.]?' , 'via' , 'vs[.]?' ] ,
init : function ( ) {
this . _ _smallRE = this . _ _smallWords . join ( '|' ) ;
this . _ _lowerCaseWordsRE = new RegExp ( '\\b(' + this . _ _smallRE + ')\\b' , 'gi' ) ;
this . _ _firstWordRE = new RegExp ( '^([^a-zA-Z0-9 \\r\\n\\t]*)(' + this . _ _smallRE + ')\\b' , 'gi' ) ;
this . _ _lastWordRE = new RegExp ( '\\b(' + this . _ _smallRE + ')([^a-zA-Z0-9 \\r\\n\\t]*)$' , 'gi' ) ;
} ,
toTitleCase : function ( string ) {
var line = '' ;
var split = string . split ( /([:.;?!][ ]|(?:[ ]|^)["“])/ ) ;
for ( var i = 0 ; i < split . length ; ++ i ) {
var s = split [ i ] ;
s = s . replace ( /\b([a-zA-Z][a-z.'’]*)\b/g , this . _ _titleCaseDottedWordReplacer ) ;
// lowercase the list of small words
s = s . replace ( this . _ _lowerCaseWordsRE , this . _ _lowerReplacer ) ;
// if the first word in the title is a small word then capitalize it
s = s . replace ( this . _ _firstWordRE , this . _ _firstToUpperCase ) ;
// if the last word in the title is a small word, then capitalize it
s = s . replace ( this . _ _lastWordRE , this . _ _firstToUpperCase ) ;
line += s ;
}
// special cases
line = line . replace ( / V(s?)\. /g , ' v$1. ' ) ;
line = line . replace ( /(['’])S\b/g , '$1s' ) ;
line = line . replace ( /\b(AT&T|Q&A)\b/ig , this . _ _upperReplacer ) ;
return line ;
} ,
_ _titleCaseDottedWordReplacer : function ( w ) {
return ( w . match ( /[a-zA-Z][.][a-zA-Z]/ ) ) ? w : _ _TitleCase . _ _firstToUpperCase ( w ) ;
} ,
_ _lowerReplacer : function ( w ) { return w . toLowerCase ( ) } ,
_ _upperReplacer : function ( w ) { return w . toUpperCase ( ) } ,
_ _firstToUpperCase : function ( w ) {
var split = w . split ( /(^[^a-zA-Z0-9]*[a-zA-Z0-9])(.*)$/ ) ;
split [ 1 ] = split [ 1 ] . toUpperCase ( ) ;
return split . join ( '' ) ;
} ,
} ;
_ _TitleCase . init ( ) ;
t = t . replace ( /_/g , " " ) ;
t = _ _TitleCase . toTitleCase ( t ) ;
return t ;
} ,
} ) . init ( ) ;
}
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Begin bootstrap - tooltip . js
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
/ * = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
* bootstrap - tooltip . js v2 . 0.1
* http : //twitter.github.com/bootstrap/javascript.html#tooltips
* Inspired by the original jQuery . tipsy by Jason Frame
* === === === === === === === === === === === === === === === === === === === ==
* Copyright 2012 Twitter , Inc .
*
* Licensed under the Apache License , Version 2.0 ( the "License" ) ;
* you may not use this file except in compliance with the License .
* You may obtain a copy of the License at
*
* http : //www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing , software
* distributed under the License is distributed on an "AS IS" BASIS ,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND , either express or implied .
* See the License for the specific language governing permissions and
* limitations under the License .
* === === === === === === === === === === === === === === === === === === === = * /
! function ( $ ) {
"use strict"
/ * T O O L T I P P U B L I C C L A S S D E F I N I T I O N
* === === === === === === === === === === = * /
var Tooltip = function ( element , options ) {
this . init ( 'tooltip' , element , options )
}
Tooltip . prototype = {
constructor : Tooltip
, init : function ( type , element , options ) {
var eventIn
, eventOut
this . type = type
this . $element = $ ( element )
this . options = this . getOptions ( options )
this . enabled = true
if ( this . options . trigger != 'manual' ) {
eventIn = this . options . trigger == 'hover' ? 'mouseenter' : 'focus'
eventOut = this . options . trigger == 'hover' ? 'mouseleave' : 'blur'
this . $element . on ( eventIn , this . options . selector , $ . proxy ( this . enter , this ) )
this . $element . on ( eventOut , this . options . selector , $ . proxy ( this . leave , this ) )
}
this . options . selector ?
( this . _options = $ . extend ( { } , this . options , { trigger : 'manual' , selector : '' } ) ) :
this . fixTitle ( )
}
, getOptions : function ( options ) {
options = $ . extend ( { } , $ . fn [ this . type ] . defaults , options , this . $element . data ( ) )
if ( options . delay && typeof options . delay == 'number' ) {
options . delay = {
show : options . delay
, hide : options . delay
}
}
return options
}
, enter : function ( e ) {
var self = $ ( e . currentTarget ) [ this . type ] ( this . _options ) . data ( this . type )
if ( ! self . options . delay || ! self . options . delay . show ) {
self . show ( )
} else {
self . hoverState = 'in'
setTimeout ( function ( ) {
if ( self . hoverState == 'in' ) {
self . show ( )
}
} , self . options . delay . show )
}
}
, leave : function ( e ) {
var self = $ ( e . currentTarget ) [ this . type ] ( this . _options ) . data ( this . type )
if ( ! self . options . delay || ! self . options . delay . hide ) {
self . hide ( )
} else {
self . hoverState = 'out'
setTimeout ( function ( ) {
if ( self . hoverState == 'out' ) {
self . hide ( )
}
} , self . options . delay . hide )
}
}
, show : function ( ) {
var $tip
, inside
, pos
, actualWidth
, actualHeight
, placement
, tp
if ( this . hasContent ( ) && this . enabled ) {
$tip = this . tip ( )
this . setContent ( )
if ( this . options . animation ) {
$tip . addClass ( 'fade' )
}
placement = typeof this . options . placement == 'function' ?
this . options . placement . call ( this , $tip [ 0 ] , this . $element [ 0 ] ) :
this . options . placement
inside = /in/ . test ( placement )
$tip
. remove ( )
. css ( { top : 0 , left : 0 , display : 'block' } )
. appendTo ( inside ? this . $element : document . body )
pos = this . getPosition ( inside )
actualWidth = $tip [ 0 ] . offsetWidth
actualHeight = $tip [ 0 ] . offsetHeight
switch ( inside ? placement . split ( ' ' ) [ 1 ] : placement ) {
case 'bottom' :
tp = { top : pos . top + pos . height , left : pos . left + pos . width / 2 - actualWidth / 2 }
break
case 'top' :
tp = { top : pos . top - actualHeight , left : pos . left + pos . width / 2 - actualWidth / 2 }
break
case 'left' :
tp = { top : pos . top + pos . height / 2 - actualHeight / 2 , left : pos . left - actualWidth }
break
case 'right' :
tp = { top : pos . top + pos . height / 2 - actualHeight / 2 , left : pos . left + pos . width }
break
}
$tip
. css ( tp )
. addClass ( placement )
. addClass ( 'in' )
}
}
, setContent : function ( ) {
var $tip = this . tip ( )
$tip . find ( '.tooltip-inner' ) . html ( this . getTitle ( ) )
$tip . removeClass ( 'fade in top bottom left right' )
}
, hide : function ( ) {
var that = this
, $tip = this . tip ( )
$tip . removeClass ( 'in' )
function removeWithAnimation ( ) {
var timeout = setTimeout ( function ( ) {
$tip . off ( $ . support . transition . end ) . remove ( )
} , 500 )
$tip . one ( $ . support . transition . end , function ( ) {
clearTimeout ( timeout )
$tip . remove ( )
} )
}
$ . support . transition && this . $tip . hasClass ( 'fade' ) ?
removeWithAnimation ( ) :
$tip . remove ( )
}
, fixTitle : function ( ) {
var $e = this . $element
if ( $e . attr ( 'title' ) || typeof ( $e . attr ( 'data-original-title' ) ) != 'string' ) {
$e . attr ( 'data-original-title' , $e . attr ( 'title' ) || '' ) . removeAttr ( 'title' )
}
}
, hasContent : function ( ) {
return this . getTitle ( )
}
, getPosition : function ( inside ) {
return $ . extend ( { } , ( inside ? { top : 0 , left : 0 } : this . $element . offset ( ) ) , {
width : this . $element [ 0 ] . offsetWidth
, height : this . $element [ 0 ] . offsetHeight
} )
}
, getTitle : function ( ) {
var title
, $e = this . $element
, o = this . options
title = $e . attr ( 'data-original-title' )
|| ( typeof o . title == 'function' ? o . title . call ( $e [ 0 ] ) : o . title )
title = title . toString ( ) . replace ( /(^\s*|\s*$)/ , "" )
return title
}
, tip : function ( ) {
return this . $tip = this . $tip || $ ( this . options . template )
}
, validate : function ( ) {
if ( ! this . $element [ 0 ] . parentNode ) {
this . hide ( )
this . $element = null
this . options = null
}
}
, enable : function ( ) {
this . enabled = true
}
, disable : function ( ) {
this . enabled = false
}
, toggleEnabled : function ( ) {
this . enabled = ! this . enabled
}
, toggle : function ( ) {
this [ this . tip ( ) . hasClass ( 'in' ) ? 'hide' : 'show' ] ( )
}
}
/ * T O O L T I P P L U G I N D E F I N I T I O N
* === === === === === === === === = * /
$ . fn . tooltip = function ( option ) {
return this . each ( function ( ) {
var $this = $ ( this )
, data = $this . data ( 'tooltip' )
, options = typeof option == 'object' && option
if ( ! data ) $this . data ( 'tooltip' , ( data = new Tooltip ( this , options ) ) )
if ( typeof option == 'string' ) data [ option ] ( )
} )
}
$ . fn . tooltip . Constructor = Tooltip
$ . fn . tooltip . defaults = {
animation : true
, delay : 0
, selector : false
, placement : 'top'
, trigger : 'hover'
, title : ''
, template : '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
}
} ( window . jQuery ) ;
/ * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
Begin timeline . js
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * /
/ * !
Verite Timeline 0.85
Designed and built by Zach Wise digitalartwork . net
Date : March 30 , 2012
This program is free software : you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation , either version 3 of the License , or
( at your option ) any later version .
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
http : //www.gnu.org/licenses/
* /
/ * !
TODO
-
-
FUTURE PLANS
- Better iPhone usability
- Support feeds from popular sources
- Storify integration
- Code optimization
- Clean up config flow
- Possible tagging of events ( depends on usability factors )
* /
/ * C o d e K i t I m p o r t
http : //incident57.com/codekit/
=== === === === === === === === === === === === === === === === == * /
// @codekit-prepend "VMM.js";
// @codekit-prepend "VMM.Core.js";
// @codekit-prepend "VMM.Util.js";
// @codekit-prepend "bootstrap-tooltip.js";
/ * T i m e l i n e C l a s s c o n t a i n e d i n V M M ( v e r i t e ) n a m e s p a c e
=== === === === === === === === === === === === === === === === == * /
if ( typeof VMM != 'undefined' && typeof VMM . Timeline == 'undefined' ) {
VMM . Timeline = function ( w , h ) {
var $timeline = VMM . getElement ( "#timeline" ) ; // expecting name only for parent
var $feedback ;
var $messege ;
var html _string = VMM . getElement ( "#timeline" ) ;
/ * C R E A T E D O M S T R U C T U R E
=== === === === === === === === === === === === === === === === == * /
//VMM.attachElement($timeline, "");
$feedback = VMM . appendAndGetElement ( $timeline , "<div>" , "feedback" , "" ) ;
$messege = VMM . appendAndGetElement ( $feedback , "<div>" , "messege" , "Loading Timeline" ) ;
//VMM.appendElement($timeline, "<div class='container main'><div class='feature'><div class='slider'></div></div><div class='navigation'></div></div>");
/ * C R E A T E C O M P O N E N T S
=== === === === === === === === === === === === === === === === == * /
// SLIDER
var slider = new VMM . Slider ( "div.slider" , 720 , 400 , true ) ;
// TIMENAV
var timenav = new VMM . Timeline . TimeNav ( "div.navigation" , 720 , 400 , true ) ;
/ * P R I V A T E V A R S
=== === === === === === === === === === === === === === === === == * /
var _private _var = 'private' ;
var events = { } ; // CUSTOM EVENT HOLDER
var data = { } ; // HOLDS DATA
var _dates = [ ] ; // HOLDES PROCESSED DATES
/ * C O N F I G
=== === === === === === === === === === === === === === === === == * /
var config = { } ;
config . interval = 10 ;
config . something = 0 ;
config . width = 960 ;
config . height = 540 ;
config . spacing = 15 ;
config . loaded = { slider : false , timenav : false , percentloaded : 0 } ;
config . ease = "easeInOutExpo" ;
config . duration = 1000 ;
if ( w != null && w != "" ) {
config . width = w ;
VMM . Element . width ( $timeline , w ) ;
} else {
config . width = VMM . Element . width ( $timeline ) ;
}
if ( h != null && h != "" ) {
config . height = h ;
VMM . Element . height ( $timeline , h ) ;
} else {
config . height = VMM . Element . height ( $timeline ) ;
}
if ( VMM . Browser . device == "mobile" ) {
config . nav _width = config . width ;
config . nav _height = 200 ;
config . feature _width = config . width ;
config . feature _height = config . height ;
} else {
config . nav _width = config . width ;
config . nav _height = 200 ;
config . feature _width = config . width ;
config . feature _height = config . height - config . nav _height ;
}
/ * C H E C K F O R I E 7
=== === === === === === === === === === === === === === === === == * /
var ie7 = false ;
if ( VMM . Browser . browser == "MSIE" ) {
if ( parseInt ( VMM . Browser . version , 10 ) == 7 ) {
ie7 = true ;
}
}
/ * V E R
=== === === === === === === === === === === === === === === === == * /
this . ver = "0.85" ;
/ * O N E V E N T
=== === === === === === === === === === === === === === === === == * /
function onDataReady ( e , d ) {
data = d . timeline ;
if ( type . of ( data . era ) == "array" ) {
} else {
data . era = [ ] ;
}
buildDates ( ) ;
} ;
function onDatesProcessed ( ) {
build ( ) ;
}
function reSize ( ) {
updateSize ( ) ;
slider . setSize ( config . feature _width , config . feature _height ) ;
timenav . setSize ( config . width , config . height ) ;
resizeSlides ( ) ;
} ;
function onSliderLoaded ( e ) {
config . loaded . slider = true ;
onComponentLoaded ( ) ;
} ;
function onComponentLoaded ( e ) {
config . loaded . percentloaded = config . loaded . percentloaded + 25 ;
showMessege ( "Loading Timeline " + config . loaded . percentloaded ) ;
if ( config . loaded . slider && config . loaded . timenav ) {
hideMessege ( ) ;
}
}
function onTimeNavLoaded ( e ) {
config . loaded . timenav = true ;
onComponentLoaded ( ) ;
}
function onSlideUpdate ( e ) {
timenav . setMarker ( slider . getCurrentNumber ( ) , config . ease , config . duration ) ;
} ;
function onMarkerUpdate ( e ) {
slider . setSlide ( timenav . getCurrentNumber ( ) ) ;
} ;
/ * P U B L I C F U N C T I O N S
=== === === === === === === === === === === === === === === === == * /
this . init = function ( d ) {
trace ( 'init' ) ;
VMM . bindEvent ( global , onDataReady , "DATAREADY" ) ;
/ * G E T D A T A
=== === === === === === === === === === === === === === === === == * /
if ( ie7 ) {
$feedback = VMM . appendAndGetElement ( $timeline , "<div>" , "feedback" , "" ) ;
$messege = VMM . appendAndGetElement ( $feedback , "<div>" , "messege" , "Internet Explorer 7 is not supported by Timeline." ) ;
} else {
if ( type . of ( d ) == "string" ) {
VMM . Timeline . DataObj . getData ( d ) ;
} else if ( type . of ( d ) == 'object' && d . timeline . type == "default" ) { // we got a JSON object passed in, let's go!
VMM . fireEvent ( global , "DATAREADY" , d ) ;
} else {
VMM . Timeline . DataObj . getData ( html _string ) ;
//VMM.attachElement(element, content);
}
//VMM.attachElement($timeline, "");
$feedback = VMM . appendAndGetElement ( $timeline , "<div>" , "feedback" , "" ) ;
$messege = VMM . appendAndGetElement ( $feedback , "<div>" , "messege" , "Loading Timeline" ) ;
}
} ;
this . iframeLoaded = function ( ) {
trace ( "iframeLoaded" ) ;
} ;
/ * D A T A
=== === === === === === === === === === === === === === === === == * /
var getData = function ( url ) {
VMM . getJSON ( url , function ( d ) {
data = VMM . Timeline . DataObj . getData ( d ) ;
VMM . fireEvent ( global , "DATAREADY" ) ;
} ) ;
} ;
/ * M E S S E G E S
=== === === === === === === === === === === === === === === === == * /
var showMessege = function ( msg ) {
//VMM.Element.append($timeline, $feedback);
//VMM.attachElement($messege, msg);
//VMM.Element.animate($feedback, config.duration, config.ease, {"opacity": 1});
} ;
//VMM.Element.animate(element, duration, ease, att, callback_function);
var hideMessege = function ( ) {
VMM . Element . animate ( $feedback , config . duration , config . ease * 4 , { "opacity" : 0 } , detachMessege ) ;
} ;
var detachMessege = function ( ) {
VMM . Element . detach ( $feedback ) ;
}
/ * B U I L D D I S P L A Y
=== === === === === === === === === === === === === === === === == * /
var build = function ( ) {
/ * C R E A T E D O M S T R U C T U R E
=== === === === === === === === === === === === === === === === == * /
VMM . attachElement ( $timeline , "" ) ;
VMM . appendElement ( $timeline , "<div class='container main'><div class='feature'><div class='slider'></div></div><div class='navigation'></div></div>" ) ;
reSize ( ) ;
/ * I N I T T H E O B J E C T S
=== === === === === === === === === === === === === === === === == * /
VMM . bindEvent ( "div.slider" , onSliderLoaded , "LOADED" ) ;
VMM . bindEvent ( "div.navigation" , onTimeNavLoaded , "LOADED" ) ;
VMM . bindEvent ( "div.slider" , onSlideUpdate , "UPDATE" ) ;
VMM . bindEvent ( "div.navigation" , onMarkerUpdate , "UPDATE" ) ;
slider . init ( _dates ) ;
timenav . init ( _dates , data . era ) ;
/ * R E S I Z E E V E N T L I S T E N E R S
=== === === === === === === === === === === === === === === === == * /
VMM . bindEvent ( global , reSize , "resize" ) ;
VMM . bindEvent ( global , function ( e ) { e . preventDefault ( ) } , "touchmove" ) ;
} ;
// BUILD SLIDE CONTENT pass in json object
var buildSlide = function ( dd , d _date ) {
updateSize ( ) ;
var d = dd ;
var slide = "" ;
var c = { } ;
c . _text = "" ;
c . _media = "" ;
var _valid = false ;
var _hasmedia = false ;
var _hastext = false ;
// NEEDS DATE IN ORDER TO USE
// TEXT
//if (d_date != null && d_date != "") {
if ( type . of ( d _date ) == "date" ) {
_valid = true ;
if ( dd . type == "start" ) {
} else {
c . _text += VMM . createElement ( "h2" , VMM . Util . date . prettyDate ( d _date ) , "date" ) ;
}
//c._text += VMM.createElement("h2", d.strDate, "date");
if ( d . headline != null && d . headline != "" ) {
if ( d . type == "tweets" ) {
} else if ( dd . type == "start" ) {
c . _text += VMM . createElement ( "h2" , d . headline , "start" ) ;
} else {
c . _text += VMM . createElement ( "h3" , d . headline ) ;
}
}
if ( d . text != null && d . text != "" ) {
_hastext = true ;
c . _text += VMM . createElement ( "p" , d . text ) ;
}
c . _text = VMM . createElement ( "div" , c . _text , "container" ) ;
c . _text = VMM . createElement ( "div" , c . _text , "text" ) ;
//trace(c._text);
}
// MEDIA
if ( _valid ) {
if ( d . asset != null && d . asset != "" ) {
if ( d . asset . media != null && d . asset . media != "" ) {
_hasmedia = true ;
c . _media = VMM . MediaElement . create ( "" , d . asset , true , config . feature _width , config . feature _height ) ;
}
}
}
if ( _valid ) {
var _layout _class = "content-container layout" ;
if ( _hastext ) {
_layout _class += "-text"
}
if ( _hasmedia ) {
_layout _class += "-media" ;
}
//c._media = VMM.createElement("div", c._media, "media-wrapper");
slide = VMM . createElement ( "div" , c . _text + c . _media , _layout _class ) ;
//trace(slide);
}
return slide ;
}
var updateSize = function ( ) {
config . width = VMM . Element . width ( $timeline ) ;
config . height = VMM . Element . height ( $timeline ) ;
config . nav _width = config . width ;
config . feature _width = config . width ;
if ( VMM . Browser . device == "mobile" ) {
config . feature _height = config . height ;
} else {
config . feature _height = config . height - config . nav _height - 3 ;
}
} ;
var resizeSlides = function ( ) {
/ * C H E C K F O R M O B I L E
=== === === === === === === === === === === === === === === === == * /
if ( config . width < 500 ) {
// MOBILE
VMM . Element . hide ( "div.navigation" ) ;
VMM . Element . hide ( "div.nav-next" ) ;
VMM . Element . hide ( "div.nav-previous" ) ;
//VMM.Element.css(".slider-item .content", "max-width", "100%");
//VMM.Element.width(".slider-item .content", "90%");
VMM . Element . height ( ".slider-container-mask" , config . height ) ;
} else {
// DESKTOP OR TABLET
VMM . Element . show ( "div.navigation" ) ;
VMM . Element . show ( "div.nav-next" ) ;
VMM . Element . show ( "div.nav-previous" ) ;
VMM . Element . height ( ".slider-container-mask" , config . feature _height ) ;
}
/ * C H E C K F O R T A B L E T
=== === === === === === === === === === === === === === === === == * /
if ( config . width < 820 ) {
// TABLET OR MOBILE
//VMM.Element.width(".slider-item .media", "100%");
//VMM.Element.width(".slider-item .text", "100%");
//VMM.Element.css(".slider-item .container", "max-width", "100%");
//VMM.Element.width(".slider-item .media .media-container .media-frame", (config.feature_width - config.spacing) );
//VMM.Element.css(".slider-item .media .media-container", "margin-bottom", 5);
if ( config . width < 500 ) {
// MOBILE
//VMM.Element.height(".slider-item .media", Math.round(config.height/1.5));
//VMM.Element.css(".slider-item .media .media-container", "max-height", Math.round(config.height/1.5) - 50);
//VMM.Element.height(".slider-item .media .media-container .media-frame", Math.round(config.height/1.5) - 60);
} else {
// TABLET
//VMM.Element.height(".slider-item .media", Math.round(config.feature_height/1.5));
//VMM.Element.css(".slider-item .media .media-container", "max-height", Math.round(config.feature_height/1.5) - 50);
//VMM.Element.height(".slider-item .media .media-container .media-frame", Math.round(config.feature_height/1.5) - 60);
}
} else {
// DESKTOP
//VMM.Element.width(".slider-item .layout-media .media", "100%");
//VMM.Element.width(".slider-item .layout-text-media .media", "75%");
//VMM.Element.width(".slider-item .layout-text-media .text", "25%");
//VMM.Element.width(".slider-item .layout-text .text", "100%");
//VMM.Element.css(".slider-item .layout-text-media .container", "max-width", 200);
//VMM.Element.height(".slider-item .media", config.feature_height);
//VMM.Element.height(".slider-item .layout-text-media .media .media-container .media-frame", config.feature_height - 60);
//VMM.Element.height(".slider-item .layout-media .media .media-container .media-frame", config.feature_height - 160);
//VMM.Element.width(".slider-item .media .media-container .media-frame", Math.round(((config.feature_width/4) * 3) - config.spacing) );
//VMM.Element.css(".slider-item .media .media-container", "max-height", config.feature_height- 50);
//VMM.Element.css(".slider-item .media .media-container", "margin-bottom", 5);
}
} ;
// BUILD DATE OBJECTS
var buildDates = function ( ) {
updateSize ( ) ;
/ * C R E A T E S T A R T P A G E I F A V A I L A B L E
=== === === === === === === === === === === === === === === === == * /
if ( data . headline != null && data . headline != "" && data . text != null && data . text != "" ) {
trace ( "HAS STARTPAGE" ) ;
var _date = { } ;
if ( data . type == "google spreadsheet" ) {
trace ( "google spreadsheet startpage date" + data . startDate ) ;
_date . startdate = new Date ( Date . parse ( data . startDate ) ) ;
trace ( _date . startdate ) ;
} else {
_date . startdate = VMM . Util . parseDate ( data . startDate ) ;
}
_date . uniqueid = VMM . Util . unique _ID ( 5 ) ;
_date . enddate = _date . startdate ;
_date . title = data . headline ;
_date . headline = data . headline ;
_date . text = data . text ;
_date . type = "start" ;
_date . date = VMM . Util . date . prettyDate ( data . startDate ) ;
_date . asset = data . asset ;
_date . fulldate = _date . startdate . getTime ( ) ;
_date . content = buildSlide ( _date , _date . startdate ) ;
if ( _date . content != null && _date . content != "" ) {
_dates . push ( _date ) ;
}
}
for ( var i = 0 ; i < data . date . length ; i ++ ) {
if ( data . date [ i ] . startDate != null && data . date [ i ] . startDate != "" ) {
var _date = { } ;
// START DATE
if ( data . date [ i ] . type == "tweets" ) {
_date . startdate = VMM . ExternalAPI . twitter . parseTwitterDate ( data . date [ i ] . startDate ) ;
} else if ( data . date [ i ] . type == "google spreadsheet" ) {
_date . startdate = new Date ( Date . parse ( data . date [ i ] . startDate ) ) ;
trace ( _date . startdate ) ;
} else {
_date . startdate = VMM . Util . parseDate ( data . date [ i ] . startDate ) ;
}
_date . uniqueid = ( data . date [ i ] . startDate ) . toString ( ) + "-" + i . toString ( ) ;
// END DATE
if ( data . date [ i ] . endDate != null && data . date [ i ] . endDate != "" ) {
if ( data . date [ i ] . type == "tweets" ) {
_date . enddate = VMM . ExternalAPI . twitter . parseTwitterDate ( data . date [ i ] . endDate ) ;
} else if ( data . date [ i ] . type == "google spreadsheet" ) {
_date . enddate = new Date ( Date . parse ( data . date [ i ] . endDate ) ) ;
} else {
_date . enddate = VMM . Util . parseDate ( data . date [ i ] . endDate ) ;
}
} else {
_date . enddate = _date . startdate ;
}
// TITLE
_date . title = data . date [ i ] . headline ;
_date . type = data . date [ i ] . type ;
// DATE
_date . date = VMM . Util . date . prettyDate ( _date . startdate ) ;
// ASSET
_date . asset = data . date [ i ] . asset ;
/ * N E E D F U L L F R A C T I O N A L D A T E
=== === === === === === === === === === === === === === === === == * /
_date . fulldate = _date . startdate . getTime ( ) ;
// BUILD SLIDE CONTENT
// Won't be added unless there is content
_date . content = buildSlide ( data . date [ i ] , _date . startdate ) ;
if ( _date . content != null && _date . content != "" ) {
_dates . push ( _date ) ;
}
}
} ;
/ * C U S T O M S O R T
=== === === === === === === === === === === === === === === === == * /
//VMM.Util.customSort(a,b);
/ *
for ( var j = 0 ; j < _dates . length ; j ++ ) {
trace ( _dates [ j ] . startdate ) ;
}
trace ( "============================" ) ;
* /
//_dates.reverse(VMM.Util.customSort(_dates.fulldate,_dates.fulldate));
_dates . sort ( function ( a , b ) {
return a . fulldate - b . fulldate
} ) ;
//_dates.reverse()
/ *
for ( var k = 0 ; k < _dates . length ; k ++ ) {
trace ( _dates [ k ] . startdate ) ;
}
* /
onDatesProcessed ( ) ;
}
} ;
VMM . Timeline . TimeNav = function ( parent , content _width , content _height ) {
trace ( "VMM.Timeline.TimeNav" ) ;
var events = { } ; // CUSTOM EVENT HOLDER
var data = [ ] ; // HOLDS DATA
var eras ;
var era _markers = [ ] ;
var markers = [ ] ; // HOLDS MARKER DOM OBJECTS
var interval _array = [ ] ;
var timespan = { } ;
var current _marker = 0 ; // CURRENT MARKER
var _active = false ;
var timelookup = {
day : 24 ,
month : 12 ,
year : 10 ,
hour : 60 ,
minute : 60 ,
second : 1000 ,
decade : 10 ,
century : 100 ,
millenium : 1000 ,
week : 4.34812141 ,
days _in _month : 30.4368499 ,
days _in _week : 7 ,
weeks _in _month : 4.34812141 ,
weeks _in _year : 52.177457 ,
days _in _year : 365.242199 ,
hours _in _day : 24
} ;
var dateFractionBrowser = {
day : 86400000 ,
week : 7 ,
month : 30.4166666667 ,
year : 12 ,
hour : 24 ,
minute : 1440 ,
second : 86400 ,
decade : 10 ,
century : 100 ,
millenium : 1000
}
// somestring = VMM.Util.date.month[2]; // Returns March
// somestring = VMM.Util.date.month_abbrev[1]; // Returns Feb.
var interval = {
type : "year" ,
number : 10 ,
first : 1970 ,
last : 2011 ,
multiplier : 100
} ;
var interval _major = {
type : "year" ,
number : 10 ,
first : 1970 ,
last : 2011 ,
multiplier : 100
} ;
var interval _calc = {
day : { } ,
month : { } ,
year : { } ,
hour : { } ,
minute : { } ,
second : { } ,
decade : { } ,
century : { } ,
millenium : { } ,
week : { }
} ;
var config = {
interval : 10 ,
something : 0 ,
width : 900 ,
height : 150 ,
ease : "easeInOutExpo" ,
duration : 1000 ,
nav _width : 100 ,
nav _height : 200 ,
timeline : false ,
spacing : 15 ,
marker _width : 150 ,
marker _height : 48 ,
density : 2 ,
timeline _width : 900 ,
interval _width : 200 ,
rows : [ 1 , 1 , 1 ] ,
multiplier : 6 ,
max _multiplier : 16 ,
min _multiplier : 1 ,
has _start _page : false ,
} ;
//config.rows = [1, config.marker_height, config.marker_height*2];
config . rows = [ config . marker _height , config . marker _height * 2 , 1 ] ;
if ( content _width != null && content _width != "" ) {
config . width = content _width ;
}
if ( content _height != null && content _height != "" ) {
config . height = content _height ;
}
var content = "" ;
var _active = false ;
/ * E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
var $timenav = "" ;
//var $timenav_container_mask = "";
//var $timenav_container = "";
var $content = "" ;
var $time = "" ;
var $timeintervalminor = "" ;
var $timeinterval = "" ;
var $timeintervalmajor = "" ;
var $timebackground = "" ;
var $timeintervalbackground = "" ;
var $timenavline = "" ;
var $timeintervalminor _minor = "" ;
var $toolbar = "" ;
var $zoomin = "" ;
var $zoomout = "" ;
var navigation = { } ;
// Nav Items
navigation . nextBtn ;
navigation . prevBtn ;
navigation . nextDate ;
navigation . prevDate ;
navigation . nextTitle ;
navigation . prevTitle ;
/ * P U B L I C V A R S
=== === === === === === === === === === === === === === === === == * /
this . ver = "0.1" ;
var layout = parent ; // expecting slider div
/ * P U B L I C F U N C T I O N S
=== === === === === === === === === === === === === === === === == * /
this . init = function ( d , e ) {
trace ( 'VMM.Timeline.TimeNav init' ) ;
// need to evaluate d
// some function to determine type of data and prepare it
if ( typeof d != 'undefined' ) {
this . setData ( d , e ) ;
} else {
trace ( "WAITING ON DATA" ) ;
}
} ;
/ * G E T T E R S A N D S E T T E R S
=== === === === === === === === === === === === === === === === == * /
this . setData = function ( d , e ) {
if ( typeof d != 'undefined' ) {
data = d ;
eras = e ;
build ( ) ;
} else {
trace ( "NO DATA" ) ;
}
} ;
this . setSize = function ( w , h ) {
if ( w != null ) { config . width = w } ;
if ( h != null ) { config . height = h } ;
if ( _active ) {
reSize ( ) ;
}
}
this . setMarker = function ( n , ease , duration , fast ) {
goToMarker ( n , ease , duration ) ;
}
this . getCurrentNumber = function ( ) {
return current _marker ;
}
/ * O N E V E N T
=== === === === === === === === === === === === === === === === == * /
function onConfigSet ( ) {
trace ( "onConfigSet" ) ;
} ;
function reSize ( firstrun ) {
VMM . Element . css ( $timenavline , "left" , Math . round ( config . width / 2 ) + 2 ) ;
//VMM.Element.css($toolbar, "left", Math.round(config.width/2)-19);
goToMarker ( current _marker , config . ease , config . duration , true , firstrun ) ;
} ;
function upDate ( ) {
VMM . fireEvent ( layout , "UPDATE" ) ;
}
function onZoomIn ( ) {
trace ( "CLICK" ) ;
VMM . DragSlider . cancelSlide ( ) ;
if ( config . multiplier > config . min _multiplier ) {
config . multiplier = config . multiplier - 1 ;
if ( config . multiplier < 0 ) {
config . multiplier = config . min _multiplier ;
}
refreshTimeline ( ) ;
}
}
function onZoomOut ( ) {
trace ( "CLICK" ) ;
VMM . DragSlider . cancelSlide ( ) ;
if ( config . multiplier < config . max _multiplier ) {
config . multiplier = config . multiplier + 1 ;
if ( config . multiplier == config . max _multiplier ) {
}
refreshTimeline ( ) ;
}
}
function onBackHome ( e ) {
VMM . DragSlider . cancelSlide ( ) ;
goToMarker ( 0 ) ;
upDate ( ) ;
}
/ * M A R K E R E V E N T S
=== === === === === === === === === === === === === === === === == * /
function onMarkerClick ( e ) {
VMM . DragSlider . cancelSlide ( ) ;
goToMarker ( e . data . number ) ;
upDate ( ) ;
} ;
function onMarkerHover ( e ) {
VMM . Element . toggleClass ( e . data . elem , "zFront" ) ;
} ;
/ * T O U C H E V E N T S
=== === === === === === === === === === === === === === === === == * /
function onTouchUpdate ( e , b ) {
VMM . Element . animate ( $timenav , b . time / 2 , config . ease , { "left" : b . left } ) ;
} ;
/ * N A V I G A T I O N
=== === === === === === === === === === === === === === === === == * /
var buildMarkers = function ( ) {
var row = 2 ; //row
var lpos = 0 ; // last marker pos;
var row _depth = 0 ;
for ( var i = 0 ; i < data . length ; i ++ ) {
var bw = "" ;
var _marker ;
var _marker _flag ;
var _marker _content ;
var _marker _dot ;
var _marker _line ;
var _marker _line _event ;
/ * C R E A T E E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
_marker = VMM . appendAndGetElement ( $content , "<div>" , "marker" ) ;
_marker _flag = VMM . appendAndGetElement ( _marker , "<div>" , "flag" ) ;
_marker _content = VMM . appendAndGetElement ( _marker _flag , "<div>" , "flag-content" ) ;
_marker _dot = VMM . appendAndGetElement ( _marker , "<div>" , "dot" ) ;
_marker _line = VMM . appendAndGetElement ( _marker , "<div>" , "line" ) ;
_marker _line _event = VMM . appendAndGetElement ( _marker _line , "<div>" , "event-line" ) ;
/ * C R E A T E T H U M B N A I L
=== === === === === === === === === === === === === === === === == * /
if ( data [ i ] . asset != null && data [ i ] . asset != "" ) {
VMM . appendElement ( _marker _content , VMM . MediaElement . thumbnail ( data [ i ] . asset , 32 , 32 ) ) ;
}
/ * A D D D A T E A N D T I T L E
=== === === === === === === === === === === === === === === === == * /
VMM . appendElement ( _marker _content , "<h3>" + VMM . Util . unlinkify ( data [ i ] . title ) + "</h3><h4>" + data [ i ] . date + "</h4>" ) ;
/ * A D D I D
=== === === === === === === === === === === === === === === === == * /
VMM . Element . attr ( _marker , "id" , ( data [ i ] . uniqueid ) . toString ( ) ) ;
/ * M A R K E R C L I C K
=== === === === === === === === === === === === === === === === == * /
VMM . bindEvent ( _marker _flag , onMarkerClick , "" , { number : i } ) ;
VMM . bindEvent ( _marker _flag , onMarkerHover , "mouseenter mouseleave" , { number : i , elem : _marker _flag } ) ;
/ * A D D M A R K E R O B J T O A R R A Y F O R R E T R I E V A L L A T E R
=== === === === === === === === === === === === === === === === == * /
var _marker _obj = {
marker : _marker ,
flag : _marker _flag ,
lineevent : _marker _line _event ,
type : "marker"
} ;
if ( data [ i ] . type == "start" ) {
trace ( "BUILD MARKER HAS START PAGE" )
config . has _start _page = true ;
_marker _obj . type = "start" ;
}
markers . push ( _marker _obj ) ;
}
/ * C R E A T E E R A S
=== === === === === === === === === === === === === === === === == * /
for ( var j = 0 ; j < eras . length ; j ++ ) {
var bw = "" ;
var era = {
content : "" ,
startdate : "" ,
enddate : "" ,
headline : "" ,
uniqueid : "" ,
color : ""
} ;
era . title = eras [ j ] . headline ;
era . uniqueid = VMM . Util . unique _ID ( 4 ) ;
era . color = eras [ j ] . color ;
/ * C R E A T E E L E M E N T S
=== === === === === === === === === === === === === === === === == * /
era . content = VMM . appendAndGetElement ( $content , "<div>" , "era" ) ;
VMM . Element . attr ( era . content , "id" , era . uniqueid ) ;
VMM . Element . css ( era . content , "background" , era . color ) ;
/ * A D D D A T E A N D T I T L E
=== === === === === === === === === === === === === === === === == * /
VMM . appendElement ( era . content , "<h3>" + VMM . Util . unlinkify ( era . title ) + "</h3>" ) ;
era . startdate = VMM . Util . parseDate ( eras [ j ] . startDate ) ;
era . enddate = VMM . Util . parseDate ( eras [ j ] . endDate ) ;
era _markers . push ( era ) ;
}
positionMarkers ( ) ;
}
var positionOnTimeline = function ( the _interval , first , last ) {
var _type = the _interval . type ;
var _multiplier = the _interval . multiplier ;
var _first = getDateFractions ( first ) ;
var _last = getDateFractions ( last ) ;
/ * C A L C U L A T E P O S I T I O N O N T I M E L I N E
=== === === === === === === === === === === === === === === === == * /
var tsd = first . months ;
var ted = last . months ;
if ( _type == "millenium" ) {
tsd = first . milleniums ;
ted = last . milleniums ;
} else if ( _type == "century" ) {
tsd = _first . centuries ;
ted = _last . centuries ;
} else if ( _type == "decade" ) {
tsd = _first . decades ;
ted = _last . decades ;
} else if ( _type == "year" ) {
tsd = _first . years ;
ted = _last . years ;
} else if ( _type == "month" ) {
tsd = _first . months ;
ted = _last . months ;
} else if ( _type == "week" ) {
tsd = _first . weeks ;
ted = _last . weeks ;
} else if ( _type == "day" ) {
tsd = _first . days ;
ted = _last . days ;
} else if ( _type == "hour" ) {
tsd = _first . hours ;
ted = _last . hours ;
} else if ( _type == "minute" ) {
tsd = _first . minutes ;
ted = _last . minutes ;
}
_pos = ( tsd - interval . base ) * ( config . interval _width / config . multiplier ) ;
_pos _end = ( ted - interval . base ) * ( config . interval _width / config . multiplier ) ;
return pos = { begin : _pos , end : _pos _end } ;
}
var positionMarkers = function ( is _animated ) {
var _type = interval . type ;
var _multiplier = interval . multiplier ;
// ROWS
var row = 2 ; //row
var lpos = 0 ; // last marker pos;
var row _depth = 0 ;
var _line _last _height _pos = 150 ;
var _line _height = 6 ;
var cur _mark = 0 ;
VMM . Element . removeClass ( ".flag" , "row1" ) ;
VMM . Element . removeClass ( ".flag" , "row2" ) ;
VMM . Element . removeClass ( ".flag" , "row3" ) ;
for ( var i = 0 ; i < markers . length ; i ++ ) {
//var pos; // X POSITION OF BEGINNING OF EVENT
var _line ; // EVENT LENGTH
//var _pos_end; // X POSITION OF END OF EVENT
var _marker = markers [ i ] . marker ;
var _marker _flag = markers [ i ] . flag ;
var _marker _line _event = markers [ i ] . lineevent ;
var _pos = positionOnTimeline ( interval , data [ i ] . startdate , data [ i ] . enddate ) ;
pos = _pos . begin ;
_pos _end = _pos . end ;
/ * C O M P E N S A T E F O R D A T E S B E I N G P O I T I O N E D I N T H E M I D D L E
=== === === === === === === === === === === === === === === === == * /
var _pos _offset = - 2 ;
pos = Math . round ( pos + _pos _offset ) ;
_pos _end = Math . round ( _pos _end + _pos _offset ) ;
_line = Math . round ( _pos _end - pos ) ;
/ * A P P L Y P O S I T I O N T O M A R K E R
=== === === === === === === === === === === === === === === === == * /
if ( is _animated ) {
VMM . Element . stop ( _marker ) ;
VMM . Element . animate ( _marker , config . duration / 2 , config . ease , { "left" : pos } ) ;
} else {
VMM . Element . css ( _marker , "left" , pos ) ;
}
if ( i == current _marker ) {
cur _mark = pos ;
//trace("=========================== cur_mark " + cur_mark)
}
/ * E V E N T L E N G T H L I N E
=== === === === === === === === === === === === === === === === == * /
if ( _line > 5 ) {
VMM . Element . css ( _marker _line _event , "height" , _line _height ) ;
VMM . Element . css ( _marker _line _event , "width" , _line ) ;
VMM . Element . css ( _marker _line _event , "top" , _line _last _height _pos ) ;
//_line_last_height_pos = _line_last_height_pos - _line_height;
}
/ * C O N T R O L R O W P O S I T I O N
=== === === === === === === === === === === === === === === === == * /
if ( pos - lpos < ( config . marker _width + config . spacing ) ) {
if ( row < config . rows . length - 1 ) {
row ++ ;
} else {
row = 0 ;
row _depth ++ ;
}
} else {
row _depth = 0 ;
row = 0 ;
}
/ * S E T L A S T M A R K E R P O S I T I O N
=== === === === === === === === === === === === === === === === == * /
lpos = pos ;
if ( is _animated ) {
VMM . Element . stop ( _marker _flag ) ;
VMM . Element . animate ( _marker _flag , config . duration , config . ease , { "top" : config . rows [ row ] } ) ;
} else {
VMM . Element . css ( _marker _flag , "top" , config . rows [ row ] ) ;
}
/ * I S T H E M A R K E R A R E P R E S E N T A T I O N O F A S T A R T S C R E E N ?
=== === === === === === === === === === === === === === === === == * /
if ( config . has _start _page && markers [ i ] . type == "start" ) {
VMM . Element . visible ( _marker , false ) ;
}
}
for ( var j = 0 ; j < era _markers . length ; j ++ ) {
//var pos; // X POSITION OF BEGINNING OF EVENT
var _line ; // EVENT LENGTH
//var _pos_end; // X POSITION OF END OF EVENT
var era = era _markers [ j ] ;
var era _elem = era . content ;
var pos = positionOnTimeline ( interval , era . startdate , era . enddate ) ;
var era _length = pos . end - pos . begin ;
var era _height = 25 ;
/ * A P P L Y P O S I T I O N T O M A R K E R
=== === === === === === === === === === === === === === === === == * /
VMM . Element . css ( era _elem , "left" , pos . begin ) ;
VMM . Element . css ( era _elem , "width" , era _length ) ;
}
/ * A N I M A T E T H E T I M E L I N E T O A D J U S T T O C H A N G E S
=== === === === === === === === === === === === === === === === == * /
if ( is _animated ) {
VMM . Element . stop ( $timenav ) ;
VMM . Element . animate ( $timenav , config . duration / 2 , config . ease , { "left" : ( config . width / 2 ) - ( cur _mark ) } ) ;
}
}
var getDateFractions = function ( the _date , is _utc ) {
var _time = { } ;
_time . days = the _date / dateFractionBrowser . day ;
_time . weeks = _time . days / dateFractionBrowser . week ;
_time . months = _time . days / dateFractionBrowser . month ;
_time . years = _time . months / dateFractionBrowser . year ;
_time . hours = _time . days * dateFractionBrowser . hour ;
_time . minutes = _time . days * dateFractionBrowser . minute ;
_time . seconds = _time . days * dateFractionBrowser . second ;
_time . decades = _time . years / dateFractionBrowser . decade ;
_time . centuries = _time . years / dateFractionBrowser . century ;
_time . milleniums = _time . years / dateFractionBrowser . millenium ;
/ *
trace ( "MILLENIUMS " + _time . milleniums ) ;
trace ( "CENTURIES " + _time . centuries ) ;
trace ( "DECADES " + _time . decades ) ;
trace ( "YEARS " + _time . years ) ;
trace ( "MONTHS " + _time . months ) ;
trace ( "WEEKS " + _time . weeks ) ;
trace ( "DAYS " + _time . days ) ;
trace ( "HOURS " + _time . hours ) ;
trace ( "MINUTES " + _time . minutes ) ;
trace ( "SECONDS " + _time . seconds ) ;
* /
return _time ;
}
var calculateInterval = function ( ) {
var _first = getDateFractions ( data [ 0 ] . startdate ) ;
var _last = getDateFractions ( data [ data . length - 1 ] . enddate ) ;
/ * M I L L E N I U M
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . millenium . type = "millenium" ;
interval _calc . millenium . first = _first . milleniums ;
interval _calc . millenium . base = Math . floor ( _first . milleniums ) ;
interval _calc . millenium . last = _last . milleniums ;
interval _calc . millenium . number = timespan . milleniums ;
interval _calc . millenium . multiplier = timelookup . millenium ;
interval _calc . millenium . minor = timelookup . millenium ;
/ * C E N T U R Y
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . century . type = "century" ;
interval _calc . century . first = _first . centuries ;
interval _calc . century . base = Math . floor ( _first . centuries ) ;
interval _calc . century . last = _last . centuries ;
interval _calc . century . number = timespan . centuries ;
interval _calc . century . multiplier = timelookup . century ;
interval _calc . century . minor = timelookup . century ;
/ * D E C A D E
=== === === === === === === === === === === === === === === === == * /
interval _calc . decade . type = "decade" ;
interval _calc . decade . first = _first . decades ;
interval _calc . decade . base = Math . floor ( _first . decades ) ;
interval _calc . decade . last = _last . decades ;
interval _calc . decade . number = timespan . decades ;
interval _calc . decade . multiplier = timelookup . decade ;
interval _calc . decade . minor = timelookup . decade ;
/ * Y E A R
=== === === === === === === === === === === === === === === === == * /
interval _calc . year . type = "year" ;
interval _calc . year . first = _first . years ;
interval _calc . year . base = Math . floor ( _first . years ) ;
interval _calc . year . last = _last . years ;
interval _calc . year . number = timespan . years ;
interval _calc . year . multiplier = 1 ;
interval _calc . year . minor = timelookup . month ;
/ * M O N T H
=== === === === === === === === === === === === === === === === == * /
interval _calc . month . type = "month" ;
interval _calc . month . first = _first . months ;
interval _calc . month . base = Math . floor ( _first . months ) ;
interval _calc . month . last = _last . months ;
interval _calc . month . number = timespan . months ;
interval _calc . month . multiplier = 1 ;
interval _calc . month . minor = Math . round ( timelookup . week ) ;
/ * W E E K
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . week . type = "week" ;
interval _calc . week . first = _first . weeks ;
interval _calc . week . base = Math . floor ( _first . weeks ) ;
interval _calc . week . last = _last . weeks ;
interval _calc . week . number = timespan . weeks ;
interval _calc . week . multiplier = 1 ;
interval _calc . week . minor = 7 ;
/ * D A Y
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . day . type = "day" ;
interval _calc . day . first = _first . days ;
interval _calc . day . base = Math . floor ( _first . days ) ;
interval _calc . day . last = _last . days ;
interval _calc . day . number = timespan . days ;
interval _calc . day . multiplier = 1 ;
interval _calc . day . minor = 24 ;
/ * H O U R
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . hour . type = "hour" ;
interval _calc . hour . first = _first . hours ;
interval _calc . hour . base = Math . floor ( _first . hours ) ;
interval _calc . hour . last = _last . hours ;
interval _calc . hour . number = timespan . hours ;
interval _calc . hour . multiplier = 1 ;
interval _calc . hour . minor = 60 ;
/ * M I N U T E
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . minute . type = "minute" ;
interval _calc . minute . first = _first . minutes ;
interval _calc . minute . base = Math . floor ( _first . minutes ) ;
interval _calc . minute . last = _last . minutes ;
interval _calc . minute . number = timespan . minutes ;
interval _calc . minute . multiplier = 1 ;
interval _calc . minute . minor = 60 ;
/ * S E C O N D
=== === === === === === === === === === === === === === === === == * /
// NOT DONE
interval _calc . second . type = "decade" ;
interval _calc . second . first = _first . seconds ;
interval _calc . second . base = Math . floor ( _first . seconds ) ;
interval _calc . second . last = _last . seconds ;
interval _calc . second . number = timespan . seconds ;
interval _calc . second . multiplier = 1 ;
interval _calc . second . minor = 10 ;
}
var positionInterval = function ( ) {
VMM . attachElement ( $timeinterval , "" ) ;
VMM . attachElement ( $timeintervalmajor , "" ) ;
interval . date = new Date ( data [ 0 ] . startdate . getFullYear ( ) , 0 , 1 , 0 , 0 , 0 ) ;
interval _major . date = new Date ( data [ 0 ] . startdate . getFullYear ( ) , 0 , 1 , 0 , 0 , 0 ) ;
//interval.date_major_start = new Date(data[0].startdate.getFullYear(), 0, 1, 0,0,0);
//interval.date_major_end = new Date(data[0].startdate.getFullYear(), 0, 1, 0,0,0);
var inc _time = 0 ;
var inc _time _major = 0 ;
var _first _run = true ;
var _normal _first _pos = 0 ;
var _last _pos = 0 ;
var _last _pos _major = 0 ;
for ( var i = 0 ; i < interval . number + 1 ; i ++ ) {
var _idd ;
if ( interval . type == "century" ) {
if ( _first _run ) {
interval . date . setFullYear ( Math . floor ( data [ 0 ] . startdate . getFullYear ( ) / 100 ) * 100 ) ;
}
interval . date . setFullYear ( interval . date . getFullYear ( ) + ( inc _time * 100 ) ) ;
_idd = Math . floor ( interval . date . getFullYear ( ) / 100 ) * 100 ;
} else if ( interval . type == "decade" ) {
if ( _first _run ) {
interval . date . setFullYear ( Math . floor ( data [ 0 ] . startdate . getFullYear ( ) / 10 ) * 10 ) ;
}
interval . date . setFullYear ( interval . date . getFullYear ( ) + ( inc _time * 10 ) ) ;
_idd = Math . floor ( interval . date . getFullYear ( ) / 10 ) * 10 ;
} else if ( interval . type == "year" ) {
if ( _first _run ) {
}
interval . date . setFullYear ( interval . date . getFullYear ( ) + inc _time ) ;
//_idd = interval.date.getFullYear();
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
} else if ( interval . type == "month" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
}
interval . date . setMonth ( interval . date . getMonth ( ) + inc _time ) ;
//_idd = VMM.Util.date.month[interval.date.getMonth()] + ", " + interval.date.getFullYear() ;
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
} else if ( interval . type == "week" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval . date . setDate ( Math . floor ( data [ 0 ] . startdate . getDate ( ) * 7 ) ) ;
}
interval . date . setDate ( interval . date . getDate ( ) + ( inc _time * 7 ) ) ;
_idd = VMM . Util . date . day _abbr [ interval . date . getDay ( ) ] + " " + VMM . Util . date . month _abbr [ interval . date . getMonth ( ) ] + " " + interval . date . getDate ( ) ;
} else if ( interval . type == "day" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
}
interval . date . setDate ( interval . date . getDate ( ) + inc _time ) ;
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
//_idd = VMM.Util.date.day_abbr[interval.date.getDay()] + " " +VMM.Util.date.month[interval.date.getMonth()] + " " + interval.date.getDate();
} else if ( interval . type == "hour" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
}
interval . date . setHours ( interval . date . getHours ( ) + inc _time ) ;
//_idd = VMM.Util.date.get12HRTime(interval.date, false); //interval.date.getHours() + ":00";
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
} else if ( interval . type == "minute" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
interval . date . setMinutes ( data [ 0 ] . startdate . getMinutes ( ) ) ;
}
interval . date . setMinutes ( interval . date . getMinutes ( ) + inc _time ) ;
//_idd = interval.date.getHours() + ":" + VMM.Util.doubledigit(interval.date.getMinutes());
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
} else if ( interval . type == "second" ) {
if ( _first _run ) {
interval . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
interval . date . setMinutes ( data [ 0 ] . startdate . getMinutes ( ) ) ;
interval . date . setSeconds ( data [ 0 ] . startdate . getSeconds ( ) ) ;
}
interval . date . setSeconds ( interval . date . getSeconds ( ) + inc _time ) ;
//_idd = interval.date.getHours() + ":" + VMM.Util.doubledigit(interval.date.getMinutes()) + ":" + VMM.Util.doubledigit(interval.date.getSeconds());
_idd = VMM . Util . date . prettyDate ( interval . date , true , interval . type ) ;
}
inc _time = 1 ;
if ( _first _run ) {
_normal _first _pos = pos ;
}
_first _run = false ;
var _pos = positionOnTimeline ( interval , interval . date , interval . date ) ;
var pos = _pos . begin ;
$interval _date = VMM . appendAndGetElement ( $timeinterval , "<div>" , "_idd" ) ;
VMM . appendElement ( $interval _date , _idd ) ;
VMM . Element . css ( $interval _date , "left" , pos ) ;
VMM . Element . css ( $interval _date , "text-indent" , - ( VMM . Element . width ( $interval _date ) / 2 ) ) ;
if ( ( pos - _last _pos ) < 65 ) {
if ( ( pos - _last _pos ) < 35 ) {
if ( i % 4 == 0 ) {
if ( pos == 0 ) {
VMM . Element . css ( $interval _date , "display" , "none" ) ;
} else {
VMM . Element . css ( $interval _date , "display" , "" ) ;
}
} else {
VMM . Element . css ( $interval _date , "display" , "none" ) ;
}
} else {
if ( VMM . Util . isEven ( i ) ) {
VMM . Element . css ( $interval _date , "display" , "none" ) ;
} else {
VMM . Element . css ( $interval _date , "display" , "" ) ;
}
}
} else {
VMM . Element . css ( $interval _date , "display" , "" ) ;
}
_last _pos = pos ;
}
_first _run = true ;
_major _first _pos = 0 ;
_major _last _pos = 0 ;
for ( var i = 0 ; i < Math . ceil ( interval _major . number ) + 1 ; i ++ ) {
var _idd ;
if ( interval _major . type == "century" ) {
if ( _first _run ) {
interval _major . date . setFullYear ( Math . floor ( data [ 0 ] . startdate . getFullYear ( ) / 100 ) * 100 ) ;
}
interval _major . date . setFullYear ( interval _major . date . getFullYear ( ) + ( inc _time _major * 100 ) ) ;
_idd = Math . floor ( interval _major . date . getFullYear ( ) / 100 ) * 100 ;
} else if ( interval _major . type == "decade" ) {
if ( _first _run ) {
interval _major . date . setFullYear ( Math . floor ( data [ 0 ] . startdate . getFullYear ( ) / 10 ) * 10 ) ;
}
interval _major . date . setFullYear ( interval _major . date . getFullYear ( ) + ( inc _time _major * 10 ) ) ;
_idd = Math . floor ( interval _major . date . getFullYear ( ) / 10 ) * 10 ;
} else if ( interval _major . type == "year" ) {
if ( _first _run ) {
}
interval _major . date . setFullYear ( interval _major . date . getFullYear ( ) + inc _time _major ) ;
_idd = interval _major . date . getFullYear ( ) ;
//_idd = VMM.Util.date.prettyDate(interval_major.date, true, interval_major.type);
} else if ( interval _major . type == "month" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
}
interval _major . date . setMonth ( interval _major . date . getMonth ( ) + inc _time _major ) ;
_idd = VMM . Util . date . month [ interval _major . date . getMonth ( ) ] + " " + interval _major . date . getFullYear ( ) ;
//_idd = VMM.Util.date.prettyDate(interval_major.date, true, interval_major.type);
} else if ( interval _major . type == "week" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval _major . date . setDate ( Math . floor ( data [ 0 ] . startdate . getDate ( ) * 7 ) ) ;
}
interval _major . date . setDate ( interval _major . date . getDate ( ) + ( inc _time _major * 7 ) ) ;
_idd = VMM . Util . date . day _abbr [ interval _major . date . getDay ( ) ] + " " + VMM . Util . date . month _abbr [ interval _major . date . getMonth ( ) ] + " " + interval _major . date . getDate ( ) ;
} else if ( interval _major . type == "day" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval _major . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
}
interval _major . date . setDate ( interval _major . date . getDate ( ) + inc _time _major ) ;
//_idd = VMM.Util.date.prettyDate(interval_major.date, true, interval_major.type);
//_idd = VMM.Util.date.day[interval_major.date.getDay()] + " " + VMM.Util.date.month_abbr[interval_major.date.getMonth()] + " " + interval_major.date.getDate();
_idd = VMM . Util . date . prettyDate ( interval _major . date , true , interval _major . type ) ;
} else if ( interval _major . type == "hour" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval _major . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval _major . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
}
interval _major . date . setHours ( interval _major . date . getHours ( ) + inc _time _major ) ;
//_idd = VMM.Util.date.get12HRTime(interval_major.date, false); //interval_major.date.getHours() + ":00";
_idd = VMM . Util . date . prettyDate ( interval _major . date , true , interval _major . type ) ;
} else if ( interval _major . type == "minute" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval _major . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval _major . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
interval _major . date . setMinutes ( data [ 0 ] . startdate . getMinutes ( ) ) ;
}
interval _major . date . setMinutes ( interval _major . date . getMinutes ( ) + inc _time _major ) ;
//_idd = interval_major.date.getHours() + ":" + VMM.Util.doubledigit(interval_major.date.getMinutes());
_idd = VMM . Util . date . prettyDate ( interval _major . date , true , interval _major . type ) ;
} else if ( interval _major . type == "second" ) {
if ( _first _run ) {
interval _major . date . setMonth ( data [ 0 ] . startdate . getMonth ( ) ) ;
interval _major . date . setDate ( data [ 0 ] . startdate . getDate ( ) ) ;
interval _major . date . setHours ( data [ 0 ] . startdate . getHours ( ) ) ;
interval _major . date . setMinutes ( data [ 0 ] . startdate . getMinutes ( ) ) ;
interval _major . date . setSeconds ( data [ 0 ] . startdate . getSeconds ( ) ) ;
}
interval _major . date . setSeconds ( interval _major . date . getSeconds ( ) + inc _time _major ) ;
//_idd = interval_major.date.getHours() + ":" + VMM.Util.doubledigit(interval_major.date.getMinutes()) + ":" + VMM.Util.doubledigit(interval_major.date.getSeconds());
_idd = VMM . Util . date . prettyDate ( interval _major . date , true , interval _major . type ) ;
}
trace ( "interval_major.type " + interval _major . type ) ;
inc _time _major = 1 ;
/ * B U I L D D A T E U S I N G S A M E M E T H O D O L O G Y A S M A R K E R P O S I T O N
CREATE A DATE
//================================================== */
var _pos = positionOnTimeline ( interval , interval _major . date , interval _major . date ) ;
var pos = _pos . begin ;
$interval _date = VMM . appendAndGetElement ( $timeintervalmajor , "<div>" , "major" ) ;
VMM . appendElement ( $interval _date , _idd ) ;
VMM . Element . css ( $interval _date , "left" , pos ) ;
VMM . Element . css ( $interval _date , "left" , pos ) ;
VMM . Element . css ( $interval _date , "text-indent" , - ( VMM . Element . width ( $interval _date ) / 2 ) ) ;
if ( _first _run ) {
_major _first _pos = pos ;
}
_first _run = false ;
_last _pos _major = pos ;
_major _last _pos = pos ;
}
VMM . Element . width ( $content , interval . number * ( config . interval _width / config . multiplier ) ) ;
//VMM.Element.width($timeintervalminor_minor, (interval.number * (config.interval_width / config.multiplier)) + 200 );
_minor _pos _offset = 50 ;
var _minor _width = ( _major _last _pos - _major _first _pos ) + ( _minor _pos _offset * 6 ) ;
var _normal _width = ( _last _pos ) + ( _minor _pos _offset * 6 ) ;
if ( _minor _width < _normal _width ) {
VMM . Element . width ( $timeintervalminor _minor , _normal _width ) ;
} else {
VMM . Element . width ( $timeintervalminor _minor , _minor _width ) ;
}
VMM . Element . css ( $timeintervalminor _minor , "left" , _major _first _pos - _minor _pos _offset ) ;
config . timeline _width = VMM . Element . width ( $timeinterval ) ;
}
var buildInterval = function ( ) {
/ * C A L C U L A T E I N T E R V A L
=== === === === === === === === === === === === === === === === == * /
timespan = getDateFractions ( ( data [ data . length - 1 ] . enddate ) - ( data [ 0 ] . startdate ) , true ) ;
calculateInterval ( ) ;
/ * D E T E R M I N E D E F A U L T I N T E R V A L T Y P E
=== === === === === === === === === === === === === === === === == * /
if ( timespan . milleniums > data . length / config . density ) {
interval = interval _calc . millenium ;
//interval_major = interval_calc.millenium;
} else if ( timespan . centuries > data . length / config . density ) {
interval = Math . ceil ( interval _calc . century ) ;
//interval_major = interval_calc.millenium;
} else if ( timespan . decades > data . length / config . density ) {
interval = interval _calc . decade ;
//interval_major = Math.ceil(interval_calc.century);
} else if ( timespan . years > data . length / config . density ) {
interval = interval _calc . year ;
//interval_major = interval_calc.decade;
} else if ( timespan . months > data . length / config . density ) {
interval = interval _calc . month ;
//interval_major = interval_calc.year;
//} else if (timespan.weeks > data.length / config.density) {
//interval = interval_calc.week;
//interval = interval_calc.month;
//interval_major = interval_calc.month;
} else if ( timespan . days > data . length / config . density ) {
interval = interval _calc . day ;
//interval_major = interval_calc.month;
} else if ( timespan . hours > data . length / config . density ) {
interval = interval _calc . hour ;
//interval_major = interval_calc.day;
} else if ( timespan . minutes > data . length / config . density ) {
interval = interval _calc . minute ;
//interval_major = interval_calc.hour;
} else if ( timespan . seconds > data . length / config . density ) {
interval = interval _calc . second ;
//interval_major = interval_calc.minute;
} else {
trace ( "NO FUCKING IDEA WHAT THE TYPE SHOULD BE" ) ;
interval . type = "unknown" ;
}
/ * D E T E R M I N E M A J O R T Y P E
=== === === === === === === === === === === === === === === === == * /
if ( timespan . milleniums >= 1 ) {
interval _major = interval _calc . millenium ;
} else if ( timespan . centuries >= 1 ) {
interval _major = interval _calc . century ;
} else if ( timespan . decades >= 1 ) {
interval _major = interval _calc . decade ;
} else if ( timespan . years >= 1 ) {
interval _major = interval _calc . year ;
} else if ( timespan . months > 1 ) {
interval _major = interval _calc . month ;
} else if ( timespan . weeks > 1 ) {
interval _major = interval _calc . month ;
} else if ( timespan . days > 1 ) {
interval _major = interval _calc . day ;
} else if ( timespan . hours > 1 ) {
interval _major = interval _calc . hour ;
} else if ( timespan . minutes > 1 ) {
interval _major = interval _calc . minute ;
} else if ( timespan . seconds > 1 ) {
interval _major = interval _calc . minute ;
} else {
trace ( "NO FUCKING IDEA WHAT THE TYPE SHOULD BE" ) ;
interval _major . type = "unknown" ;
}
//trace(interval_major.type);
$timeintervalminor _minor = VMM . appendAndGetElement ( $timeintervalminor , "<div>" , "minor" ) ;
positionInterval ( ) ;
}
/ * G O T O T I M E M A R K E R
=== === === === === === === === === === === === === === === === == * /
var goToMarker = function ( n , ease , duration , fast , firstrun ) {
// Set current slide
current _marker = n ;
var _ease = config . ease ;
var _duration = config . duration ;
var is _last = false ;
var is _first = false ;
if ( current _marker == 0 ) {
is _first = true ;
}
if ( current _marker + 1 == markers . length ) {
is _last = true
}
if ( ease != null && ease != "" ) { _ease = ease } ;
if ( duration != null && duration != "" ) { _duration = duration } ;
/ * g e t m a r k e r p o s i t i o n
=== === === === === === === === === === === === === === === === == * /
var _pos = VMM . Element . position ( markers [ current _marker ] . marker ) ;
/ * s e t m a r k e r s t y l e
=== === === === === === === === === === === === === === === === == * /
for ( var i = 0 ; i < markers . length ; i ++ ) {
VMM . Element . removeClass ( markers [ i ] . marker , "active" ) ;
}
if ( config . has _start _page && markers [ current _marker ] . type == "start" ) {
VMM . Element . visible ( markers [ current _marker ] . marker , false ) ;
VMM . Element . addClass ( markers [ current _marker ] . marker , "start" ) ;
}
VMM . Element . addClass ( markers [ current _marker ] . marker , "active" ) ;
/ * s e t p r o p e r n a v t i t l e s a n d d a t e s e t c .
=== === === === === === === === === === === === === === === === == * /
if ( is _first ) {
//VMM.Element.visible(navigation.prevBtn, false);
} else {
//VMM.Element.visible(navigation.prevBtn, true);
}
if ( is _last ) {
//VMM.Element.visible(navigation.nextBtn, false);
} else {
//VMM.Element.visible(navigation.nextBtn, true);
}
/ * A N I M A T E M A R K E R
=== === === === === === === === === === === === === === === === == * /
VMM . Element . stop ( $timenav ) ;
VMM . Element . animate ( $timenav , _duration , _ease , { "left" : ( config . width / 2 ) - ( _pos . left ) } ) ;
}
/ * B U I L D
=== === === === === === === === === === === === === === === === == * /
var build = function ( ) {
// Clear out existing content
VMM . attachElement ( layout , "" ) ;
$timenav = VMM . appendAndGetElement ( layout , "<div>" , "timenav" ) ;
$content = VMM . appendAndGetElement ( $timenav , "<div>" , "content" ) ;
$time = VMM . appendAndGetElement ( $timenav , "<div>" , "time" ) ;
$timeintervalminor = VMM . appendAndGetElement ( $time , "<div>" , "time-interval-minor" ) ;
$timeintervalmajor = VMM . appendAndGetElement ( $time , "<div>" , "time-interval-major" ) ;
$timeinterval = VMM . appendAndGetElement ( $time , "<div>" , "time-interval" ) ;
$timebackground = VMM . appendAndGetElement ( layout , "<div>" , "timenav-background" ) ;
$timenavline = VMM . appendAndGetElement ( $timebackground , "<div>" , "timenav-line" ) ;
$timeintervalbackground = VMM . appendAndGetElement ( $timebackground , "<div>" , "timenav-interval-background" , "<div class='top-highlight'></div>" ) ;
buildInterval ( ) ;
buildMarkers ( ) ;
reSize ( true ) ;
VMM . fireEvent ( layout , "LOADED" ) ;
$toolbar = VMM . appendAndGetElement ( layout , "<div>" , "toolbar" ) ;
if ( config . has _start _page ) {
$backhome = VMM . appendAndGetElement ( $toolbar , "<div>" , "back-home" , "<div class='icon'></div>" ) ;
VMM . bindEvent ( ".back-home" , onBackHome , "click" ) ;
VMM . Element . css ( $toolbar , "top" , 27 ) ;
}
$zoomin = VMM . appendAndGetElement ( $toolbar , "<div>" , "zoom-in" , "<div class='icon'></div>" ) ;
$zoomout = VMM . appendAndGetElement ( $toolbar , "<div>" , "zoom-out" , "<div class='icon'></div>" ) ;
VMM . Element . attribute ( $backhome , "title" , "Return to Title" ) ;
VMM . Element . attribute ( $backhome , "rel" , "tooltip" ) ;
VMM . Element . attribute ( $zoomin , "title" , "Expand Timeline" ) ;
VMM . Element . attribute ( $zoomin , "rel" , "tooltip" ) ;
VMM . Element . attribute ( $zoomout , "title" , "Contract Timeline" ) ;
VMM . Element . attribute ( $zoomout , "rel" , "tooltip" ) ;
VMM . bindEvent ( ".zoom-in" , onZoomIn , "click" ) ;
VMM . bindEvent ( ".zoom-out" , onZoomOut , "click" ) ;
$toolbar . tooltip ( {
selector : "div[rel=tooltip]" ,
placement : "right"
} )
/ * M A K E T I M E L I N E T O U C H A B L E
=== === === === === === === === === === === === === === === === == * /
if ( VMM . Browser . device == "mobile" || VMM . Browser . device == "tablet" ) {
VMM . TouchSlider . createPanel ( $timebackground , $timenav , config . width , config . spacing , false ) ;
VMM . bindEvent ( $timenav , onTouchUpdate , "TOUCHUPDATE" ) ;
} else {
VMM . DragSlider . createPanel ( layout , $timenav , config . width , config . spacing , false ) ;
//VMM.bindEvent($timenav, onDragUpdate, "DRAGUPDATE");
}
_active = true ;
} ;
var refreshTimeline = function ( ) {
positionInterval ( ) ;
positionMarkers ( true ) ;
//reSize();
} ;
} ;
/ * S O U R C E D A T A P R O C E S S O R
=== === === === === === === === === === === === === === === === == * /
VMM . Timeline . DataObj = {
data _obj : { } ,
model _array : [ ] ,
getData : function ( raw _data ) {
data = VMM . Timeline . DataObj . data _obj ;
if ( type . of ( raw _data ) != "string" ) {
trace ( "DATA SOURCE: NOT JSON" ) ;
trace ( "TRYING HTML PARSE" ) ;
VMM . Timeline . DataObj . parseHTML ( raw _data ) ;
} else {
if ( raw _data . match ( "%23" ) ) {
trace ( "DATA SOURCE: TWITTER SEARCH" ) ;
VMM . Timeline . DataObj . model _Tweets . getData ( "%23medill" ) ;
} else if ( raw _data . match ( "spreadsheet" ) ) {
trace ( "DATA SOURCE: GOOGLE SPREADSHEET" ) ;
VMM . Timeline . DataObj . model _GoogleSpreadsheet . getData ( raw _data ) ;
} else {
trace ( "DATA SOURCE: JSON" ) ;
VMM . getJSON ( raw _data , VMM . Timeline . DataObj . parseJSON ) ;
}
}
} ,
parseHTML : function ( d ) {
trace ( "parseHTML" ) ;
var _data _obj = VMM . Timeline . DataObj . data _template _obj ;
/ * T i m e l i n e s t a r t s l i d e
=== === === === === === === === === === === === === === === === == * /
if ( VMM . Element . find ( "#timeline section" , "time" ) [ 0 ] ) {
_data _obj . timeline . startDate = VMM . Element . html ( VMM . Element . find ( "#timeline section" , "time" ) [ 0 ] ) ;
_data _obj . timeline . headline = VMM . Element . html ( VMM . Element . find ( "#timeline section" , "h2" ) ) ;
_data _obj . timeline . text = VMM . Element . html ( VMM . Element . find ( "#timeline section" , "article" ) ) ;
var found _main _media = false ;
if ( VMM . Element . find ( "#timeline section" , "figure img" ) . length != 0 ) {
found _main _media = true ;
_data _obj . timeline . asset . media = VMM . Element . attr ( VMM . Element . find ( "#timeline section" , "figure img" ) , "src" ) ;
} else if ( VMM . Element . find ( "#timeline section" , "figure a" ) . length != 0 ) {
found _main _media = true ;
_data _obj . timeline . asset . media = VMM . Element . attr ( VMM . Element . find ( "#timeline section" , "figure a" ) , "href" ) ;
} else {
//trace("NOT FOUND");
}
if ( found _main _media ) {
if ( VMM . Element . find ( "#timeline section" , "cite" ) . length != 0 ) {
_data _obj . timeline . asset . credit = VMM . Element . html ( VMM . Element . find ( "#timeline section" , "cite" ) ) ;
}
if ( VMM . Element . find ( this , "figcaption" ) . length != 0 ) {
_data _obj . timeline . asset . caption = VMM . Element . html ( VMM . Element . find ( "#timeline section" , "figcaption" ) ) ;
}
}
}
/ * T i m e l i n e D a t e S l i d e s
=== === === === === === === === === === === === === === === === == * /
VMM . Element . each ( "#timeline li" , function ( i , elem ) {
var valid _date = false ;
var _date = {
"type" : "default" ,
"startDate" : "" ,
"headline" : "" ,
"text" : "" ,
"asset" :
{
"media" : "" ,
"credit" : "" ,
"caption" : ""
} ,
"tags" : "Optional"
} ;
if ( VMM . Element . find ( this , "time" ) != 0 ) {
valid _date = true ;
_date . startDate = VMM . Element . html ( VMM . Element . find ( this , "time" ) [ 0 ] ) ;
if ( VMM . Element . find ( this , "time" ) [ 1 ] ) {
_date . endDate = VMM . Element . html ( VMM . Element . find ( this , "time" ) [ 0 ] ) ;
}
_date . headline = VMM . Element . html ( VMM . Element . find ( this , "h3" ) ) ;
_date . text = VMM . Element . html ( VMM . Element . find ( this , "article" ) ) ;
var found _media = false ;
if ( VMM . Element . find ( this , "figure img" ) . length != 0 ) {
found _media = true ;
_date . asset . media = VMM . Element . attr ( VMM . Element . find ( this , "figure img" ) , "src" ) ;
} else if ( VMM . Element . find ( this , "figure a" ) . length != 0 ) {
found _media = true ;
_date . asset . media = VMM . Element . attr ( VMM . Element . find ( this , "figure a" ) , "href" ) ;
} else {
//trace("NOT FOUND");
}
if ( found _media ) {
if ( VMM . Element . find ( this , "cite" ) . length != 0 ) {
_date . asset . credit = VMM . Element . html ( VMM . Element . find ( this , "cite" ) ) ;
}
if ( VMM . Element . find ( this , "figcaption" ) . length != 0 ) {
_date . asset . caption = VMM . Element . html ( VMM . Element . find ( this , "figcaption" ) ) ;
}
}
trace ( _date ) ;
_data _obj . timeline . date . push ( _date ) ;
}
} ) ;
VMM . fireEvent ( global , "DATAREADY" , _data _obj ) ;
} ,
parseJSON : function ( d ) {
if ( d . timeline . type == "default" ) {
trace ( "DATA SOURCE: JSON STANDARD TIMELINE" ) ;
VMM . fireEvent ( global , "DATAREADY" , d ) ;
//return _data_obj.timeline;
} else if ( d . timeline . type == "twitter" ) {
trace ( "DATA SOURCE: JSON TWEETS" ) ;
VMM . Timeline . DataObj . model _Tweets . buildData ( d ) ;
} else {
trace ( "DATA SOURCE: NO IDEA" ) ;
trace ( type . of ( d . timeline ) ) ;
} ;
} ,
/ * M O D E L O B J E C T S
New Types of Data can be formatted for the timeline here
=== === === === === === === === === === === === === === === === == * /
model _Tweets : {
type : "twitter" ,
buildData : function ( raw _data ) {
VMM . bindEvent ( global , VMM . Timeline . DataObj . model _Tweets . onTwitterDataReady , "TWEETSLOADED" ) ;
VMM . ExternalAPI . twitter . getTweets ( raw _data . timeline . tweets ) ;
} ,
getData : function ( raw _data ) {
VMM . bindEvent ( global , VMM . Timeline . DataObj . model _Tweets . onTwitterDataReady , "TWEETSLOADED" ) ;
VMM . ExternalAPI . twitter . getTweetSearch ( raw _data ) ;
} ,
onTwitterDataReady : function ( e , d ) {
var _data _obj = VMM . Timeline . DataObj . data _template _obj ;
for ( var i = 0 ; i < d . tweetdata . length ; i ++ ) {
var _date = {
"type" : "tweets" ,
"startDate" : "" ,
"headline" : "" ,
"text" : "" ,
"asset" :
{
"media" : "" ,
"credit" : "" ,
"caption" : ""
} ,
"tags" : "Optional"
} ;
// pass in the 'created_at' string returned from twitter //
// stamp arrives formatted as Tue Apr 07 22:52:51 +0000 2009 //
//var twit_date = VMM.ExternalAPI.twitter.parseTwitterDate(d.tweetdata[i].raw.created_at);
//trace(twit_date);
_date . startDate = d . tweetdata [ i ] . raw . created _at ;
if ( type . of ( d . tweetdata [ i ] . raw . from _user _name ) ) {
_date . headline = d . tweetdata [ i ] . raw . from _user _name + " (<a href='https://twitter.com/" + d . tweetdata [ i ] . raw . from _user + "'>" + "@" + d . tweetdata [ i ] . raw . from _user + "</a>)" ;
} else {
_date . headline = d . tweetdata [ i ] . raw . user . name + " (<a href='https://twitter.com/" + d . tweetdata [ i ] . raw . user . screen _name + "'>" + "@" + d . tweetdata [ i ] . raw . user . screen _name + "</a>)" ;
}
_date . asset . media = d . tweetdata [ i ] . content ;
_data _obj . timeline . date . push ( _date ) ;
} ;
VMM . fireEvent ( global , "DATAREADY" , _data _obj ) ;
}
} ,
model _GoogleSpreadsheet : {
/ *
TEMPLATE CAN BE FOUND HERE
https : //docs.google.com/previewtemplate?id=0AppSVxABhnltdEhzQjQ4MlpOaldjTmZLclQxQWFTOUE&mode=public
* /
type : "google spreadsheet" ,
getData : function ( raw _data ) {
var _key = VMM . Util . getUrlVars ( raw _data ) [ "key" ] ;
var _url = "https://spreadsheets.google.com/feeds/list/" + _key + "/od6/public/values?alt=json" ;
if ( VMM . Browser . browser == "Explorer" && parseInt ( VMM . Browser . version , 10 ) >= 8 && window . XDomainRequest ) {
// Use Microsoft XDR
// going to move this to VMM.getJSON
trace ( "it's ie" ) ;
var ie _xdr = new XDomainRequest ( ) ;
var _url = "//spreadsheets.google.com/feeds/list/" + _key + "/od6/public/values?alt=json" ;
ie _xdr . open ( "get" , _url ) ;
ie _xdr . onload = function ( ) {
var ie _j = { } ;
var ie _json = VMM . parseJSON ( ie _xdr . responseText ) ;
VMM . Timeline . DataObj . model _GoogleSpreadsheet . buildData ( ie _json ) ;
}
ie _xdr . send ( ) ;
} else {
trace ( "not ie" ) ;
VMM . getJSON ( _url , VMM . Timeline . DataObj . model _GoogleSpreadsheet . buildData ) ;
}
} ,
buildData : function ( d ) {
var _data _obj = VMM . Timeline . DataObj . data _template _obj ;
for ( var i = 0 ; i < d . feed . entry . length ; i ++ ) {
var dd = d . feed . entry [ i ] ;
if ( dd . gsx$titleslide . $t . match ( "start" ) ) {
_data _obj . timeline . startDate = dd . gsx$startdate . $t ;
_data _obj . timeline . headline = dd . gsx$headline . $t ;
_data _obj . timeline . asset . media = dd . gsx$media . $t ;
_data _obj . timeline . asset . caption = dd . gsx$mediacaption . $t ;
_data _obj . timeline . asset . credit = dd . gsx$mediacredit . $t ;
_data _obj . timeline . text = dd . gsx$text . $t ;
_data _obj . timeline . type = "google spreadsheet" ;
} else {
var _date = {
"type" : "google spreadsheet" ,
"startDate" : "" ,
"endDate" : "" ,
"headline" : "" ,
"text" : "" ,
"type" : "google spreadsheet" ,
"asset" :
{
"media" : "" ,
"credit" : "" ,
"caption" : ""
} ,
"tags" : "Optional"
} ;
_date . endDate = dd . gsx$enddate . $t ;
_date . startDate = dd . gsx$startdate . $t ;
_date . headline = dd . gsx$headline . $t ;
_date . asset . media = dd . gsx$media . $t ;
_date . asset . caption = dd . gsx$mediacaption . $t ;
_date . asset . credit = dd . gsx$mediacredit . $t ;
_date . text = dd . gsx$text . $t ;
_data _obj . timeline . date . push ( _date ) ;
}
} ;
VMM . fireEvent ( global , "DATAREADY" , _data _obj ) ;
}
} ,
/ * T E M P L A T E O B J E C T S
=== === === === === === === === === === === === === === === === == * /
data _template _obj : {
"timeline" : {
"headline" : "" ,
"description" : "" ,
"asset" : {
"media" : "" ,
"credit" : "" ,
"caption" : ""
} ,
"date" : [ ]
}
} ,
date _obj : {
"startDate" : "2012,2,2,11,30" ,
"headline" : "" ,
"text" : "" ,
"asset" :
{
"media" : "http://youtu.be/vjVfu8-Wp6s" ,
"credit" : "" ,
"caption" : ""
} ,
"tags" : "Optional"
}
} ;
} ;
/ *
$ ( document ) . ready ( function ( ) {
//Instantiate
timeline = new VMM . Timeline ( 960 , 550 ) ; // Pass in width and height or set it in your stylesheet;
// Initialize
timeline . init ( "example.json" ) ; // Pass in the data
} ) ;
* /