summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--theme/list_lib.js228
1 files changed, 50 insertions, 178 deletions
diff --git a/theme/list_lib.js b/theme/list_lib.js
index 92177dc41..23906b480 100644
--- a/theme/list_lib.js
+++ b/theme/list_lib.js
@@ -86,7 +86,9 @@ function view_in_range(start, end)
view_pagging(start, end);
}
-
+/**
+*Show the previous page, Will do nothing if no previous pages
+*/
function prev_page()
{
var end = start + sizeofpage - 1;
@@ -104,6 +106,9 @@ function prev_page()
updateView(start, end)
}
+/**
+*Show the next page, Will do nothing if no next pages
+*/
function next_page()
{
var end = start + sizeofpage - 1;
@@ -118,14 +123,15 @@ function next_page()
updateView(start, end)
}
-///////////////////////////////////////////////
-
function view_pagging(start, end)
{
var page = document.getElementById("pagging");
page.innerHTML = (start + 1) + ' to ' + (end + 1) + ' of ' + (itemsToShow.length) + ' dives';
}
+/**
+*Expand all dives in the view.
+*/
function expandAll()
{
for (var i = start; i < start + sizeofpage; i++) {
@@ -136,6 +142,9 @@ function expandAll()
}
}
+/**
+*Collapse all dives in the view.
+*/
function collapseAll()
{
for (var i = start; i < start + sizeofpage; i++) {
@@ -226,6 +235,10 @@ function putTags(tags)
return result;
}
+/**
+*@param {integer} rate out of 5
+*return HTML string of stars
+*/
function putRating(rating)
{
var result;
@@ -315,6 +328,10 @@ function list_sort(sortOn)
}
}
+/*
+*sorting interface for different coloumns
+*/
+
function cmpLocationAsc(j, iSmaller)
{
return items[j].location < items[iSmaller].location;
@@ -406,6 +423,7 @@ function sort_it(sortOn, function_)
// Searching
//
//////////////////////////////////////
+
function Set()
{
this.keys = new Array();
@@ -442,15 +460,13 @@ Set.prototype.Union = function(another_set)
};
};
-////////////////////////////////////////
-
function Node(value)
{
this.children = new Array();
this.value = value;
this.key = new Set();
}
-///////////////////////////////////////
+
function Search_list_Modules(searchfor)
{
document.getElementById("search_input").value = searchfor;
@@ -576,6 +592,10 @@ function searchin(value, node)
var tripsShown;
+
+/**
+*This is the main function called to show/hide trips
+*/
function toggleTrips()
{
var trip_button = document.getElementById('trip_button');
@@ -642,157 +662,12 @@ function getItems()
////////////////////////canvas///////////////////
/*
-Canvas Colors Constants
-*/
-var CAMARONE1 = rgb(0, 0.4, 0);
-var LIMENADE1 = rgb(0.4, 0.8, 0);
-var RIOGRANDE1 = rgb(0.8, 0.8, 0);
-var PIRATEGOLD1 = rgb(0.8, 0.5, 0);
-var RED1 = rgb(1, 0, 0);
-
-/*
Some Global variables that hold the current shown dive data.
*/
-var dive_id; //current shown ID
-var points; //reference to the samples array of the shown dive.
-var MAX_HEIGHT; //Maximum depth, then its the maximum height for canvas
-var MAX_WIDTH; //dive duration, then its the maximum width for canvas
-
-/**
-*Return RGB css color string.
-*/
-function rgb(r, g, b)
-{
- r = Math.floor(r * 255);
- g = Math.floor(g * 255);
- b = Math.floor(b * 255);
- return["rgb(", r, ",", g, ",", b, ")"].join("");
-}
-
-/**
-*This function returns the value scaled to the size of canvas
-*new scale = (old scale * height of canvas) / max height in dive
-*to ensure that the dive profile is filling the whole area available
-*/
-function scaleHeight(vari)
-{
- var height = document.getElementById("profileCanvas").height;
- max = MAX_HEIGHT;
- return (vari * height) / max;
-}
-
-/**
-*This function returns the value scaled to the size of canvas
-*new scale = (old scale * width of canvas) / max width in dive
-*to ensure that the dive profile is filling the whole area available
-*/
-function scaleWidth(vari)
-{
- var width = document.getElementById("profileCanvas").width;
- max = MAX_WIDTH;
- return (vari * width) / max;
-}
-
-/**
-*Show Axis information(Numbers on scale)
-*put a Number every 300 second scaled to canvas width.
-*/
-function canvas_showAxisInfo()
-{
- var c = document.getElementById("profileCanvas");
- var ctx = c.getContext("2d");
- ctx.font = "27px Georgia"; /*This is better be a variable scale*/
- for (var i = 0; i < MAX_WIDTH / scaleWidth(5); i++)
- ctx.fillText("" + i * 5 + "", scaleWidth(i * 5 * 60), scaleHeight(MAX_HEIGHT - 150));
-}
-
-/**
-*Draw the grid
-*with spacing = 5 * 60 = 300
-*draw line every 5 minutes
-*/
-function canvas_showGrid()
-{
- var cnv = document.getElementById("profileCanvas");
- var cnvWidth = cnv.width;
- var cnvHeight = cnv.height;
- var lineOptions = {
- separation : scaleWidth(300),
- color : '#AAAAAA'
- };
- var ctx = cnv.getContext('2d');
-
- ctx.strokeStyle = lineOptions.color;
- ctx.strokeWidth = 0.5;
- ctx.beginPath();
-
- var iCount = null;
- var i = null;
- var x = null;
- var y = null;
-
- //draw horizontal lines
- iCount = Math.floor(cnvWidth / lineOptions.separation);
- for (i = 1; i <= iCount; i++) {
- x = (i * lineOptions.separation);
- ctx.moveTo(x, 0);
- ctx.lineTo(x, cnvHeight);
- ctx.stroke();
- }
-
- //draw vertical lines
- iCount = Math.floor(cnvHeight / lineOptions.separation);
- for (i = 1; i <= iCount; i++) {
- y = (i * lineOptions.separation);
- ctx.moveTo(0, y);
- ctx.lineTo(cnvWidth, y);
- ctx.stroke();
- }
-
- ctx.closePath();
-}
-
-/**
-*The Main function used for drawing canvas lines
-*it automatically calcualte the slope of the line
-*and choose its color.
-*This is the function that should be used internally.
-*/
-function canvas_drawline(ctx, begin, end)
-{
- drawline(ctx, begin, end, getcolor(begin, end));
-}
-
-/**
-*Draw a line in the canvas with the given
-*starting point, ending point, and color.
-*/
-function drawline(ctx, begin, end, col)
-{
- ctx.strokeStyle = col;
- ctx.beginPath();
- ctx.moveTo(scaleWidth(begin[0]), scaleHeight(begin[1]));
- ctx.lineTo(scaleWidth(end[0]), scaleHeight(end[1]));
- ctx.stroke();
-}
-
-/**
-*Choose Color for different speeds.
-*this need to be fixed to go with subsurface conversion.
-*/
-function getcolor(begin, end)
-{
- var slope = (end[1] - begin[1]) / (end[0] - begin[0]);
- if (Math.abs(slope) > 300)
- return RED1;
- if (Math.abs(slope) > 180)
- return PIRATEGOLD1;
- if (Math.abs(slope) > 110)
- return RIOGRANDE1;
- if (Math.abs(slope) > 70)
- return LIMENADE1;
- return CAMARONE1;
-}
+var dive_id; //current shown ID
+var points; //reference to the samples array of the shown dive.
+var ZERO_C_IN_MKELVIN = 273150;
+var plot1;
/**
*Return the HTML string for a dive cylinder entry in the table.
@@ -861,8 +736,6 @@ function get_dive_HTML(dive)
'</td></tr></table><div style="margin:10px;"><p class="words">Notes: </p>' + dive.notes + '</div>';
};
-var ZERO_C_IN_MKELVIN = 273150;
-
function mkelvin_to_C(mkelvin)
{
return (mkelvin - ZERO_C_IN_MKELVIN) / 1000.0;
@@ -878,16 +751,16 @@ function mm_to_meter(mm)
return mm / (1000);
}
-function format_two_digit(n){
- return n > 9 ? "" + n: "0" + n;
+function format_two_digit(n)
+{
+ return n > 9 ? "" + n : "0" + n;
}
-function int_to_time (n){
- return Math.floor((n) /60) +":"+ format_two_digit((n) % (60))+" min";
+function int_to_time(n)
+{
+ return Math.floor((n) / 60) + ":" + format_two_digit((n) % (60)) + " min";
}
-var plot1;
-
/**
*Main canvas draw function
*this calls the axis and grid initialization functions.
@@ -895,11 +768,11 @@ var plot1;
function canvas_draw()
{
document.getElementById("chart1").innerHTML = "";
- var d1 = new Array();
- var d2 = new Array();
- var d3 = new Array();
- var d4 = new Array();
- var last = 0 ;
+ var d1 = new Array(); //depth
+ var d2 = new Array(); //pressure
+ var d3 = new Array(); //events
+ var d4 = new Array(); //temperature
+ var last = 0;
for (var i = 0; i < items[dive_id].samples.length; i++) {
d1.push([
items[dive_id].samples[i][0] / 60,
@@ -917,9 +790,8 @@ function canvas_draw()
mkelvin_to_C(items[dive_id].samples[i][3]),
]);
last = items[dive_id].samples[i][3];
- }
- else {
- if(last != 0) {
+ } else {
+ if (last != 0) {
d4.push([
items[dive_id].samples[i][0] / 60,
mkelvin_to_C(last),
@@ -932,8 +804,7 @@ function canvas_draw()
d3.push([
items[dive_id].events[i].time / 60,
0,
- //-1 * mm_to_meter(items[dive_id].samples[x][1])
- ]);
+ ]);
}
plot1 = $.jqplot('chart1', [
d1,
@@ -1040,8 +911,6 @@ function showDiveDetails(dive)
//set global variables
dive_id = dive;
points = items[dive_id].samples;
- MAX_HEIGHT = items[dive_id].maxdepth * 1.1;
- MAX_WIDTH = items[dive_id].duration;
//draw the canvas and initialize the view
document.getElementById("diveinfo").innerHTML = get_dive_HTML(items[dive_id]);
@@ -1089,14 +958,17 @@ function prevDetailedDive()
}
}
+/**
+*This function handles keyboard events
+*shift to next/prev dives by keyboard arrows.
+*/
function switchDives(e)
{
- if(document.getElementById("divePanel").style.display == 'block'){
+ if (document.getElementById("divePanel").style.display == 'block') {
e = e || window.event;
if (e.keyCode == '37') {
prevDetailedDive();
- }
- else if (e.keyCode == '39') {
+ } else if (e.keyCode == '39') {
nextDetailedDive();
}
}