Timeline design and timescale update
This commit is contained in:
		
							parent
							
								
									bfaed4deb4
								
							
						
					
					
						commit
						830eb8eb62
					
				
							
								
								
									
										15
									
								
								Gemfile.lock
								
								
								
								
							
							
						
						
									
										15
									
								
								Gemfile.lock
								
								
								
								
							|  | @ -1,3 +1,18 @@ | ||||||
|  | GIT | ||||||
|  |   remote: git://github.com/amatsuda/kaminari.git | ||||||
|  |   revision: 82a38e07db1ca1598c8daf073a8f6be22ae714d6 | ||||||
|  |   specs: | ||||||
|  |     kaminari (0.13.0) | ||||||
|  |       actionpack (>= 3.0.0) | ||||||
|  |       activesupport (>= 3.0.0) | ||||||
|  | 
 | ||||||
|  | PATH | ||||||
|  |   remote: vendor/impressionist | ||||||
|  |   specs: | ||||||
|  |     impressionist (1.1.1) | ||||||
|  |       httpclient (~> 2.2) | ||||||
|  |       nokogiri (~> 1.5) | ||||||
|  | 
 | ||||||
| GEM | GEM | ||||||
|   remote: http://rubygems.org/ |   remote: http://rubygems.org/ | ||||||
|   specs: |   specs: | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ | ||||||
| 
 | 
 | ||||||
| var orbitTimeline = function(dom){ | var orbitTimeline = function(dom){ | ||||||
| 	t = this; | 	t = this; | ||||||
| 	this.dom = $("#"+dom); | 	this.dom = $(dom); | ||||||
| 	this.timelineHtml = $("<div class='t_bottom t_scale' id='timeline_scale'></div>"); | 	this.timelineHtml = $("<div class='t_bottom t_scale' id='timeline_scale'></div>"); | ||||||
| 	//this.marker = t.timelineHtml.find("#timline_marker");
 | 	//this.marker = t.timelineHtml.find("#timline_marker");
 | ||||||
| 	this.scale = ""; | 	this.scale = ""; | ||||||
|  | @ -18,9 +18,9 @@ var orbitTimeline = function(dom){ | ||||||
| 		$("div.scrollbar").hide(); | 		$("div.scrollbar").hide(); | ||||||
| 		t.constructTimeScale(function(timelineScale){ | 		t.constructTimeScale(function(timelineScale){ | ||||||
| 			$("#timeline_scale").html(timelineScale); | 			$("#timeline_scale").html(timelineScale); | ||||||
| 			var totalyearwidth =timelineScale.find(".year").length * 200; | 			var totalyearwidth =timelineScale.find(".year").length * timelineScale.find(".year").outerWidth(); | ||||||
| 			var totalul = 0; | 			var totalul = 0; | ||||||
| 			$(".t_scale").css({"min-width":$(".tinycanvas .viewport").width()+200 + "px"}) | 			$(".t_scale").css({"min-width":$(".tinycanvas .viewport").width()+500 + "px"}) | ||||||
| 			for(eve in t.events){ | 			for(eve in t.events){ | ||||||
| 				t.makeBubble(t.events[eve]); | 				t.makeBubble(t.events[eve]); | ||||||
| 				totalul = $("#scale_wrapper ul").length | 				totalul = $("#scale_wrapper ul").length | ||||||
|  | @ -30,7 +30,7 @@ var orbitTimeline = function(dom){ | ||||||
| 			$('.tinycanvas').tinyscrollbar({  | 			$('.tinycanvas').tinyscrollbar({  | ||||||
| 				axis: 'x', | 				axis: 'x', | ||||||
| 				onMove: function(x){ | 				onMove: function(x){ | ||||||
| 					var limit = $("#timeline_scale").width() - $(".tinycanvas .scrollbar").width(); | 					var limit = $("#timeline_scale").outerWidth() - $(".tinycanvas .scrollbar").outerWidth(); | ||||||
| 					if(t.ajaxload){ | 					if(t.ajaxload){ | ||||||
| 						if((limit - x) < 10){ | 						if((limit - x) < 10){ | ||||||
| 							t.eventAjaxLoad(function(){ | 							t.eventAjaxLoad(function(){ | ||||||
|  | @ -52,6 +52,16 @@ var orbitTimeline = function(dom){ | ||||||
| 	this.constructTimeScale = function(callbackFn){ | 	this.constructTimeScale = function(callbackFn){ | ||||||
| 		var mon ="",year="",formname; | 		var mon ="",year="",formname; | ||||||
| 		var scale = $("<div id='scale_wrapper'></div>"); | 		var scale = $("<div id='scale_wrapper'></div>"); | ||||||
|  | 		$.getJSON("desktop_orbit/gettimelinespan",{"get":"papers"},function(years){ | ||||||
|  | 			var $ul = $("<ul></ul>"); | ||||||
|  | 			var startyear = years.startyear, endyear = years.endyear,year = years.startyear; | ||||||
|  | 			$ul.append('<li><a href="'+startyear+'" class="wh3 hh3 admbg active" onclick="return false;">'+startyear+'</a></li>'); | ||||||
|  | 			while(year > endyear){ | ||||||
|  | 				year--; | ||||||
|  | 				$ul.append('<li><a href="'+year+'" class="wh3 hh3 admbg" onclick="return false;">'+year+'</a></li>'); | ||||||
|  | 			} | ||||||
|  | 			$("div#orbit div#year_navigation").html($ul); | ||||||
|  | 		}) | ||||||
| 		$.getJSON("desktop_orbit/eventajaxload",{"event":"papers","from":t.fromdate},function(papersArray){ | 		$.getJSON("desktop_orbit/eventajaxload",{"event":"papers","from":t.fromdate},function(papersArray){ | ||||||
| 			$.each(papersArray,function(i,pa){ | 			$.each(papersArray,function(i,pa){ | ||||||
| 					$.each(pa.papers,function(i,paper){ | 					$.each(pa.papers,function(i,paper){ | ||||||
|  | @ -64,7 +74,7 @@ var orbitTimeline = function(dom){ | ||||||
| 						t.events.push(bubbleData); | 						t.events.push(bubbleData); | ||||||
| 						if(cur_year != year){ | 						if(cur_year != year){ | ||||||
| 							year = cur_year; | 							year = cur_year; | ||||||
| 							scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+(year+1)+"</div><div class='region_year group' data-content='"+year+"'></div>")); | 							scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+year+"'></div>")); | ||||||
| 						}  | 						}  | ||||||
| 						if(cur_mon != mon){ | 						if(cur_mon != mon){ | ||||||
| 							mon = cur_mon; | 							mon = cur_mon; | ||||||
|  | @ -73,7 +83,7 @@ var orbitTimeline = function(dom){ | ||||||
| 						} | 						} | ||||||
| 					}); | 					}); | ||||||
| 				}); | 				}); | ||||||
| 				scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+(year-1)+"'></div>")); | 				//scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+(year-1)+"'></div>"));
 | ||||||
| 				t.fromdate = [year,formname-1]; | 				t.fromdate = [year,formname-1]; | ||||||
| 				if(typeof callbackFn == "function"){ | 				if(typeof callbackFn == "function"){ | ||||||
| 					callbackFn.call(this,scale); | 					callbackFn.call(this,scale); | ||||||
|  | @ -101,13 +111,31 @@ var orbitTimeline = function(dom){ | ||||||
| 		targetul.prepend(bubble); | 		targetul.prepend(bubble); | ||||||
| 		bubble.show(); | 		bubble.show(); | ||||||
| 		bubble.click(function(){ | 		bubble.click(function(){ | ||||||
|  | 			var thisbubble = $(this); | ||||||
|  | 			$(this).parents(dom) | ||||||
|  | 						.find('.bubble, .date') | ||||||
|  | 						.removeClass('thmc1 thmtxt'); | ||||||
|  | 					 | ||||||
| 			o.toolPopup({ | 			o.toolPopup({ | ||||||
| 				parent: $(this).parent(), | 				parent: $(this).parent(), | ||||||
| 				html : "<div class='bubble_content'><h2>"+bubbleData.jtitle+"</h2><h3>Co-Authors</h3><span class='context'>"+bubbleData.coauthors+"</span><h3>Abstract</h3><span class='context'>"+bubbleData.abstract+"</span></div>", | 				html : "<div class='bubble_content'><h2>"+bubbleData.jtitle+"</h2><h3>Co-Authors</h3><span class='context'>"+bubbleData.coauthors+"</span><h3>Abstract</h3><span class='context'>"+bubbleData.abstract+"</span></div>", | ||||||
| 				height: "392px", | 				height: "392px", | ||||||
| 				width:"310px" | 				width:"310px", | ||||||
|  | 				beforeClose : function(){ | ||||||
|  | 					$("div.bubble_arrow").remove(); | ||||||
|  | 					thisbubble.parents(dom) | ||||||
|  | 						.find('.bubble, .date') | ||||||
|  | 						.removeClass('thmc1 thmtxt'); | ||||||
|  | 				}, | ||||||
|  | 				onOpen : function(){ | ||||||
|  | 					thisbubble.append('<div class="bubble_arrow"/>'); | ||||||
|  | 				}, | ||||||
|  | 				beforeOpen : function(){ | ||||||
|  | 					thisbubble.addClass('thmc1 thmtxt'); | ||||||
|  | 					thisbubble.find('.date').addClass('thmtxt'); | ||||||
|  | 				} | ||||||
| 			}); | 			}); | ||||||
| 		})//.mouseout(function(){t.oapi.toolPopup("destroy");})
 | 		}) | ||||||
| 	} | 	} | ||||||
| 	this.eventAjaxLoad = function(callbackFn){ | 	this.eventAjaxLoad = function(callbackFn){ | ||||||
| 		t.events = []; | 		t.events = []; | ||||||
|  | @ -128,7 +156,7 @@ var orbitTimeline = function(dom){ | ||||||
| 						if(cur_year != year){ | 						if(cur_year != year){ | ||||||
| 							year = cur_year; | 							year = cur_year; | ||||||
| 							if(scale.find("div[data-content="+year+"]").length == 0){ | 							if(scale.find("div[data-content="+year+"]").length == 0){ | ||||||
| 								scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+(year+1)+"</div><div class='region_year group' data-content='"+year+"'></div>")); | 								scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+year+"'></div>")); | ||||||
| 							} | 							} | ||||||
| 						}  | 						}  | ||||||
| 						if(cur_mon != mon){ | 						if(cur_mon != mon){ | ||||||
|  | @ -139,8 +167,8 @@ var orbitTimeline = function(dom){ | ||||||
| 					}); | 					}); | ||||||
| 				}); | 				}); | ||||||
| 				if(papersArray.length != 0){ | 				if(papersArray.length != 0){ | ||||||
| 					if(scale.find("div[data-content="+(year-1)+"]").length == 0) | 					// if(scale.find("div[data-content="+(year-1)+"]").length == 0)
 | ||||||
| 						scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+(year-1)+"'></div>")); | 					// 	scale.append($("<div class='group year w1 h1 hp vp thmtxt thmc1'>"+year+"</div><div class='region_year group' data-content='"+(year-1)+"'></div>"));
 | ||||||
| 					t.ajaxload = true; | 					t.ajaxload = true; | ||||||
| 					t.fromdate = [year,formname-1]; | 					t.fromdate = [year,formname-1]; | ||||||
| 				} | 				} | ||||||
|  | @ -152,29 +180,16 @@ var orbitTimeline = function(dom){ | ||||||
| 	} | 	} | ||||||
| 	this.bubble_fx = function(){ | 	this.bubble_fx = function(){ | ||||||
| 		$('.bubble').on({ | 		$('.bubble').on({ | ||||||
| 				mouseover: function(){ | 			mouseover: function(){ | ||||||
| 					$(this) | 				$(this) | ||||||
| 						.addClass('hover') | 					.addClass('hover') | ||||||
| 						.append('<span class="icon-chevron-right" />'); | 					.append('<span class="icon-chevron-right" />'); | ||||||
| 				}, | 			}, | ||||||
| 				mouseout: function(){ | 			mouseout: function(){ | ||||||
| 					$(this) | 				$(this) | ||||||
| 						.removeClass('hover') | 					.removeClass('hover') | ||||||
| 						.find('.icon-chevron-right').remove(); | 					.find('.icon-chevron-right').remove(); | ||||||
| 				}, | 			}, | ||||||
| 				click: function(){ | 		}); | ||||||
| 					$(this) |  | ||||||
| 						.parents('#timeline') |  | ||||||
| 						.find('.bubble, .date') |  | ||||||
| 						.removeClass('thmc1 thmtxt'); |  | ||||||
| 					$(this) |  | ||||||
| 						.addClass('thmc1 thmtxt'); |  | ||||||
| 					$(this) |  | ||||||
| 						.find('.date') |  | ||||||
| 						.addClass('thmtxt'); |  | ||||||
| 					$(this) |  | ||||||
| 						.append('<div class="bubble_arrow"/>'); |  | ||||||
| 				} |  | ||||||
| 			}); |  | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -923,7 +923,7 @@ var orbitDesktop = function(dom){ | ||||||
| 		o.currenthtml = target; | 		o.currenthtml = target; | ||||||
| 		o.currentface = "orbit"; | 		o.currentface = "orbit"; | ||||||
| 		var bindHandlers = function(){ | 		var bindHandlers = function(){ | ||||||
| 			var timeline = new orbitTimeline("timeline"); | 			var timeline = new orbitTimeline("#timeline"); | ||||||
| 			timeline.initialize(); | 			timeline.initialize(); | ||||||
| 		} | 		} | ||||||
| 		if(!o.desktopData[o.currentface]){ | 		if(!o.desktopData[o.currentface]){ | ||||||
|  |  | ||||||
|  | @ -163,7 +163,6 @@ var orbitDesktopAPI = function(){ | ||||||
| 			$(".desktop_toolpopup").hide("fold",function(){ | 			$(".desktop_toolpopup").hide("fold",function(){ | ||||||
| 				$(this).remove(); | 				$(this).remove(); | ||||||
| 				$(this).parent().css("position",""); | 				$(this).parent().css("position",""); | ||||||
| 
 |  | ||||||
| 			}) | 			}) | ||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
|  | @ -172,6 +171,14 @@ var orbitDesktopAPI = function(){ | ||||||
| 				settings.height = (!settings.height ? "50px" : settings.height); | 				settings.height = (!settings.height ? "50px" : settings.height); | ||||||
| 				settings.width = (!settings.width ? "150px" : settings.width); | 				settings.width = (!settings.width ? "150px" : settings.width); | ||||||
| 				settings.html = (!settings.html ?  "" : settings.html); | 				settings.html = (!settings.html ?  "" : settings.html); | ||||||
|  | 
 | ||||||
|  | 				//Events
 | ||||||
|  | 				settings.onClose = (!settings.onClose ?  function(){} : settings.onClose); | ||||||
|  | 				settings.beforeOpen = (!settings.beforeOpen ?  function(){} : settings.beforeOpen); | ||||||
|  | 				settings.onOpen = (!settings.onOpen ?  function(){} : settings.onOpen); | ||||||
|  | 				settings.beforeClose = (!settings.beforeClose ?  function(){} : settings.beforeClose); | ||||||
|  | 				//Events end
 | ||||||
|  | 
 | ||||||
| 				var leftpos = settings.parent.outerWidth(); | 				var leftpos = settings.parent.outerWidth(); | ||||||
| 				var toolpopup = $("<div class='desktop_toolpopup' style='height:"+settings.height+";width:"+settings.width+"; left:"+leftpos+"px;'>"+settings.html+"</div>"); | 				var toolpopup = $("<div class='desktop_toolpopup' style='height:"+settings.height+";width:"+settings.width+"; left:"+leftpos+"px;'>"+settings.html+"</div>"); | ||||||
| 				settings.parent.css("position","relative"); | 				settings.parent.css("position","relative"); | ||||||
|  | @ -179,13 +186,16 @@ var orbitDesktopAPI = function(){ | ||||||
| 				toolpopup.click(function(event){ | 				toolpopup.click(function(event){ | ||||||
| 					event.stopPropagation(); | 					event.stopPropagation(); | ||||||
| 				}); | 				}); | ||||||
| 				 | 				settings.beforeOpen.call(this); | ||||||
| 				toolpopup.show("fold",function(){ | 				toolpopup.show("fold",function(){ | ||||||
|  | 					settings.onOpen.call(this); | ||||||
| 					$(document).unbind("click"); | 					$(document).unbind("click"); | ||||||
| 					$(document).one("click",function(e){ | 					$(document).one("click",function(e){ | ||||||
|  | 						settings.beforeClose.call(this); | ||||||
| 						toolpopup.hide("fold",function(){ | 						toolpopup.hide("fold",function(){ | ||||||
| 							toolpopup.remove(); | 							toolpopup.remove(); | ||||||
| 							settings.parent.css("position",""); | 							settings.parent.css("position",""); | ||||||
|  | 							settings.onClose.call(this); | ||||||
| 						});						 | 						});						 | ||||||
| 					}) | 					}) | ||||||
| 				});				 | 				});				 | ||||||
|  |  | ||||||
|  | @ -4,15 +4,16 @@ class DesktopOrbitController< ApplicationController | ||||||
| 		render "desktop/orbit", :layout => false | 		render "desktop/orbit", :layout => false | ||||||
| 	end | 	end | ||||||
| 
 | 
 | ||||||
| 	def getevents | 	def gettimelinespan | ||||||
| 		@event = params["event"] | 		@get = params['get'] | ||||||
| 		@data = Array.new | 		case @get | ||||||
| 		@fromdate = params["from"] | 			when "papers" | ||||||
| 		case @event | 				firstpaper = current_user.papers.all.first | ||||||
| 		when "papers" | 				lastpaper = current_user.papers.all.desc(:created_at).last | ||||||
| 			@data = current_user.papers.where(:created_at.gt => Date.new(Integer(@fromdate[0]),Integer(@fromdate[1])-1),:created_at.lt => Date.new(Integer(@fromdate[0]),Integer(@fromdate[1])+1)).desc(:created_at) | 				endyear = Integer(lastpaper.created_at.strftime("%Y")) | ||||||
|  | 				startyear = Integer(firstpaper.created_at.strftime("%Y")) | ||||||
| 		end | 		end | ||||||
| 		render :json=>@data.to_json | 		render :json=>{"startyear"=>startyear,"endyear"=>endyear}.to_json | ||||||
| 	end | 	end | ||||||
| 
 | 
 | ||||||
| 	def eventajaxload | 	def eventajaxload | ||||||
|  |  | ||||||
|  | @ -27,16 +27,16 @@ | ||||||
| 		</div> | 		</div> | ||||||
| 	</div> | 	</div> | ||||||
| 	<div id="holder"> | 	<div id="holder"> | ||||||
| 		<div class="time_nav"> | 		<div class="time_nav" id="year_navigation"> | ||||||
| 			<ul> | 			<ul> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg active">2013</a></li> | 				<!-- <li><a href="" class="wh3 hh3 admbg active">2013</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2012</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2012</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2011</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2011</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2010</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2010</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2009</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2009</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2008</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2008</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2007</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2007</a></li> | ||||||
| 				<li><a href="" class="wh3 hh3 admbg">2006</a></li> | 				<li><a href="" class="wh3 hh3 admbg">2006</a></li> --> | ||||||
| 			</ul> | 			</ul> | ||||||
| 		</div> | 		</div> | ||||||
| 		<div class="time_nav_c wh3 hh2"><a href=""><span class="icon-chevron-left"></span></a><a href=""><span class="icon-chevron-right"></span></a></div> | 		<div class="time_nav_c wh3 hh2"><a href=""><span class="icon-chevron-left"></span></a><a href=""><span class="icon-chevron-right"></span></a></div> | ||||||
|  | @ -44,7 +44,6 @@ | ||||||
| 			<div class="tinycanvas"> | 			<div class="tinycanvas"> | ||||||
| 			<div class="scrollbar sb_h vp"><div class="track"><div class="thumb thmc2"><div class="end"></div></div></div></div> | 			<div class="scrollbar sb_h vp"><div class="track"><div class="thumb thmc2"><div class="end"></div></div></div></div> | ||||||
| 			<div class="viewport"> | 			<div class="viewport"> | ||||||
| 			 |  | ||||||
| 				<div id="timeline" class="overview"> | 				<div id="timeline" class="overview"> | ||||||
| 				</div> | 				</div> | ||||||
| 			</div> | 			</div> | ||||||
|  |  | ||||||
|  | @ -205,7 +205,7 @@ Orbit::Application.routes.draw do | ||||||
| 
 | 
 | ||||||
|   match '/desktop_orbit/orbit' => 'desktop_orbit#orbit' |   match '/desktop_orbit/orbit' => 'desktop_orbit#orbit' | ||||||
|   match '/desktop_orbit/eventajaxload'=> 'desktop_orbit#eventajaxload' |   match '/desktop_orbit/eventajaxload'=> 'desktop_orbit#eventajaxload' | ||||||
|   match '/desktop_orbit/getevents' => 'desktop_orbit#getevents' |   match '/desktop_orbit/gettimelinespan' => 'desktop_orbit#gettimelinespan' | ||||||
| 
 | 
 | ||||||
|    #match '/desktop_orbit/eventajaxload' => 'desktop_publications#create_journal' |    #match '/desktop_orbit/eventajaxload' => 'desktop_publications#create_journal' | ||||||
|   #match '/desktop_orbit/eventajaxload' => 'desktop_publications#delete_journal' |   #match '/desktop_orbit/eventajaxload' => 'desktop_publications#delete_journal' | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue