You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
281 lines
11 KiB
281 lines
11 KiB
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" |
|
"http://www.w3.org/TR/html4/loose.dtd"> |
|
|
|
<html> |
|
|
|
<head> |
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> |
|
<title>Web Browser</title> |
|
<link rel="stylesheet" type="text/css" href="css/main.css"> |
|
<script src="scripts/jquery-1.3.2.min.js" type="text/javascript"></script> |
|
<script type="text/javascript"> |
|
|
|
var loadingState = false; |
|
|
|
function changeLoadingState(){ |
|
loadingState = true; |
|
} |
|
|
|
$(document).ready(function(){ |
|
//var resizer; // Timer |
|
//var resizerIndex; |
|
$("body").css({height: $(window).height() - 40}); |
|
|
|
var popupFlag = false; |
|
var currentHistory = 0; |
|
var references = new Array(); |
|
var globalWidth = 850; |
|
var globalHeight = 700; |
|
var url = ""; |
|
var margins = { |
|
top: cssToInt($("body").css("margin-top")), |
|
right: cssToInt($("body").css("margin-right")), |
|
bottom: cssToInt($("body").css("margin-bottom")), |
|
left: cssToInt($("body").css("margin-left")) |
|
}; |
|
|
|
var resizer; // Timer |
|
var resizerIndex; |
|
|
|
var popupText = $("<div id='popupWordInfo' class='popupWordInfo'></div>").appendTo("body"); |
|
|
|
resizerIndex = 0; |
|
|
|
if(window.sankore){ |
|
url = window.sankore.preference("url", ""); |
|
if(sankore.preference("browserHistory", "")) |
|
references = sankore.preference("browserHistory", "").split(","); |
|
currentHistory = parseInt(sankore.preference("browserIndex", "0")); |
|
}else{ |
|
url = ""; |
|
}; |
|
|
|
$("#back-button") |
|
.click(function(){ |
|
loadingState = false; |
|
if((currentHistory - 1) > 0){ |
|
$("#textbox").val(references[--currentHistory-1]); |
|
$("#search-button").trigger("click"); |
|
} |
|
}); |
|
|
|
$("#forward-button") |
|
.click(function(){ |
|
loadingState = false; |
|
if(currentHistory < references.length) { |
|
$("#textbox").val(references[currentHistory++]); |
|
$("#search-button").trigger("click"); |
|
} |
|
}); |
|
|
|
$("#search-button").mouseover(function(evt){ |
|
popupFlag = true; |
|
popupText.css("top", evt.pageY + 5) |
|
.css("left", evt.pageX + 13) |
|
.css({width:"100px"}) |
|
.text("Go to the site") |
|
.show("fast", function(){ |
|
if(!popupFlag) |
|
popupText.hide(); |
|
}); |
|
}); |
|
|
|
$("#back-button").mouseover(function(evt){ |
|
popupFlag = true; |
|
popupText.css("top", evt.pageY + 5) |
|
.css("left", evt.pageX + 13) |
|
.css({width:"90px"}) |
|
.text("Previous site") |
|
.show("fast", function(){ |
|
if(!popupFlag) |
|
popupText.hide(); |
|
}); |
|
}); |
|
|
|
$("#forward-button").mouseover(function(evt){ |
|
popupFlag = true; |
|
popupText.css("top", evt.pageY + 5) |
|
.css("left", evt.pageX + 13) |
|
.css({width:"70px"}) |
|
.text("Next site") |
|
.show("fast", function(){ |
|
if(!popupFlag) |
|
popupText.hide(); |
|
}); |
|
}); |
|
|
|
$("#search-button, #back-button, #forward-button").mousemove(function(evt){ |
|
popupText.css("top", evt.pageY + 5) |
|
.css("left", evt.pageX + 13); |
|
}); |
|
|
|
$("#search-button, #back-button, #forward-button").mouseout(function(evt){ |
|
popupText.hide(); |
|
popupFlag = false; |
|
}); |
|
|
|
$("#textbox").keypress(function(e) { |
|
if(e.keyCode == 13) { |
|
$("#search-button").trigger("click"); |
|
} |
|
}); |
|
|
|
$("#search-button").click(function(){ |
|
if($("#textbox").val().length > 0){ |
|
loadingState = false; |
|
var url = $("#textbox").val(); |
|
var urlStart = url.split("://"); |
|
|
|
if(urlStart[0]!="http"){ |
|
url = "http://" + url; |
|
}; |
|
|
|
if(checkURLs(references, url)){ |
|
if(currentHistory == references.length) |
|
references[currentHistory++] = url; |
|
else |
|
references = insertInto(references, currentHistory++, url); |
|
} |
|
window.resizeTo(globalWidth, globalHeight); |
|
|
|
$("#container").removeClass("welcome").removeClass("change") |
|
.removeClass("error").addClass("load"); |
|
$("#container-shadow").hide(); |
|
$("#arrow").hide(); |
|
$("#embeded-content").hide(); |
|
$("#web-content").hide(); |
|
$('#web-content').attr('src',url); |
|
|
|
checkcontent(); |
|
checkLoading(); |
|
} else { |
|
$("#embeded-content").load("locales/" + "en" + "/howto.html"); // Welcome screen with some explanations |
|
$("#container") |
|
.addClass("welcome") |
|
.addClass("change") |
|
.addClass("error") |
|
.removeClass("load"); |
|
$("#container-shadow").show(); |
|
$("#arrow").show(); |
|
$("#embeded-content").show(); |
|
$("#web-content").hide(); |
|
window.resizeTo(550, 280); |
|
} |
|
}) |
|
.mouseenter(function(){ |
|
$(this) |
|
.addClass("over"); |
|
}) |
|
.mouseleave(function(){ |
|
$(this) |
|
.removeClass("over"); |
|
}); |
|
|
|
if(url.length > 0){ |
|
$("#textbox").val(url); |
|
$("#search-button").trigger("click"); |
|
}else{ |
|
$("#embeded-content").load("locales/" + "en" + "/howto.html"); // Welcome screen with some explanations |
|
}; |
|
|
|
$(window).resize(function(){ |
|
$("body").css({height: $(window).height() - 40}); |
|
globalWidth = $(window).width(); |
|
globalHeight = $(window).height(); |
|
$("#web-content") |
|
.attr("width", globalWidth - 60) |
|
.attr("height", globalHeight - 120); |
|
}); |
|
|
|
function checkcontent(){ |
|
|
|
if(window.sankore){ |
|
window.sankore.setPreference("url", $("#textbox").val()); |
|
window.sankore.setPreference("browserHistory", references.toString()); |
|
window.sankore.setPreference("browserIndex", currentHistory); |
|
}; |
|
|
|
$("#embeded-content").hide(); |
|
$("#container").removeClass("load").addClass("show"); |
|
}; |
|
|
|
function checkLoading(){ |
|
if(loadingState){ |
|
|
|
clearTimeout(resizer); |
|
resizerIndex = 0; |
|
$("#web-content") |
|
.attr("width", globalWidth - 25) |
|
.attr("height", globalHeight - 90); |
|
$("#web-content").show(); |
|
$(window).trigger("resize"); |
|
return false; |
|
}; |
|
if(resizerIndex > 100){ |
|
resizerIndex = 0; |
|
$("#textbox").val("http://www.google.com/search?q=" + $("#textbox").val().replace("http://", "")); |
|
$("#search-button").trigger("click"); |
|
}else{ |
|
resizer = setTimeout(function(){checkLoading()}, 100); |
|
resizerIndex++; |
|
}; |
|
}; |
|
|
|
function cssToInt(cssvalue){ |
|
return(parseInt(cssvalue.replace("px", ""))); |
|
} |
|
|
|
function checkURLs(arr, value){ |
|
for(var i = 0; i < arr.length; i++) |
|
if(arr[i] == value) |
|
return false; |
|
return true; |
|
} |
|
|
|
function insertInto(arr, index, url){ |
|
var newArr = new Array(); |
|
for(var i = 0, j = 0; i < arr.length; i++, j++) |
|
if(i == index - 1){ |
|
newArr[j] = arr[i]; |
|
newArr[++j] = url; |
|
} else |
|
newArr[j] = arr[i]; |
|
return newArr; |
|
} |
|
|
|
}); |
|
</script> |
|
</head> |
|
|
|
<body> |
|
<div id="ubwidget"> |
|
<div id="shadow"></div> |
|
|
|
<div id="inputfield"> |
|
<div id="back-button" class="button">Previous</div> |
|
<div id="forward-button" class="button">Next</div> |
|
<input id="textbox" type="text"> |
|
<div id="search-button" class="button">Show</div> |
|
</div> |
|
|
|
<div id="container" class="welcome"> |
|
<div id="arrow"><img src="imgs/arrow.png" alt="arrow-top"></div> |
|
|
|
<div id="show-container"> |
|
<div id="embeded-content"></div> |
|
<iframe id="web-content" name="web-content" src="" scrolling=auto frameborder=1 onload="changeLoadingState()"></iframe> |
|
</div> |
|
|
|
<table cellspacing="0" cellpadding="0" id="container-shadow"> |
|
<tr> |
|
<td id="shadow-left"></td> |
|
<td id="shadow-center"> </td> |
|
<td id="shadow-right"></td> |
|
</tr> |
|
</table> |
|
</div> |
|
|
|
</div> |
|
</body> |
|
|
|
</html> |