From 8a050d435329e91cf33fc12f56c82b7a4b479d0a Mon Sep 17 00:00:00 2001 From: Andreas Unterkircher Date: Sun, 4 May 2008 11:04:20 +0200 Subject: set everywhere the correct path to scripts, stylesheets, images, ... Signed-off-by: Andreas Unterkircher --- phpfspot.class.php | 30 +++++++------ phpfspot.js | 70 +++++++++++++++++++------------ themes/default/templates/export.tpl | 2 +- themes/default/templates/header.tpl | 22 +++++----- themes/default/templates/index.tpl | 10 ++--- themes/default/templates/photo_index.tpl | 20 ++++----- themes/default/templates/search.tpl | 12 +++--- themes/default/templates/single_photo.tpl | 42 +++++++++---------- themes/default/templates/slideshow.tpl | 16 +++---- themes/default/templates/tags.tpl | 4 +- themes/default/templates/welcome.tpl | 6 +-- 11 files changed, 124 insertions(+), 110 deletions(-) diff --git a/phpfspot.class.php b/phpfspot.class.php index 99b0d7b..8305ba5 100644 --- a/phpfspot.class.php +++ b/phpfspot.class.php @@ -201,6 +201,8 @@ class PHPFSPOT { require_once "phpfspot_tmpl.php"; $this->tmpl = new PHPFSPOT_TMPL(); + $this->tmpl->assign('web_path', $this->cfg->web_path); + /* check if all necessary indices exist */ $this->checkDbIndices(); @@ -2437,7 +2439,6 @@ class PHPFSPOT { public function whatToDo() { if(isset($_SESSION['current_photo']) && $_SESSION['start_action'] == 'showp') { - return "show_photo"; } elseif(isset($_SESSION['selected_tags']) && !empty($_SESSION['selected_tags'])) { return "showpi_tags"; @@ -2446,8 +2447,6 @@ class PHPFSPOT { return "showpi"; } - return "nothing special"; - } // whatToDo() /** @@ -2771,15 +2770,7 @@ class PHPFSPOT { */ private function get_phpfspot_url() { - if($this->cfg->web_path == "/") - $web_path = ""; - /* remove trailing slash */ - elseif(preg_match('/\/$/', $this->cfg->web_path)) - $web_path = preg_replace('/\/$/', '', $this->cfg->web_path); - else - $web_path = $this->cfg->web_path; - - return $this->get_web_protocol() ."://". $this->get_server_name() . $web_path; + return $this->get_web_protocol() ."://". $this->get_server_name() . $this->cfg->web_path; } // get_phpfspot_url() @@ -2973,9 +2964,11 @@ class PHPFSPOT { } - /* check for pending slash on web_path */ - if(!preg_match("/\/$/", $this->cfg->web_path)) - $this->cfg->web_path.= "/"; + /* remove trailing slash, if set */ + if($this->cfg->web_path == "/") + $this->cfg->web_path = ""; + elseif(preg_match('/\/$/', $this->cfg->web_path)) + $this->cfg->web_path = preg_replace('/\/$/', '', $this->cfg->web_path); return $this->runtime_error; @@ -3092,7 +3085,11 @@ class PHPFSPOT { } // get_tag_name() - + /** + * parse user friendly url which got rewritten by the websever + * @param string $request_uri + * @return string + */ private function parse_user_friendly_url($request_uri) { if(preg_match('/\/photoview\/|\/photo\/|\/tag\//', $request_uri)) { @@ -3105,6 +3102,7 @@ class PHPFSPOT { switch($options[1]) { case 'photoview': if(is_numeric($options[2])) { + $_GET['mode'] = 'showp'; return $this->showPhoto($options[2]); } break; diff --git a/phpfspot.js b/phpfspot.js index 47ebe32..7dfdcc8 100644 --- a/phpfspot.js +++ b/phpfspot.js @@ -42,7 +42,7 @@ function showImage(id, scrollup) } /* fetch single-photo view from server */ - HTML_AJAX.replace(content, encodeURI('rpc.php?action=showphoto&id=' + id)); + HTML_AJAX.replace(content, encodeURI(web_path + '/rpc.php?action=showphoto&id=' + id)); /* scroll the window up to the top */ if(scrollup != undefined) { @@ -101,7 +101,7 @@ function findPos(obj, direction) { function showCredits() { var credits = document.getElementById("content"); - credits.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=showcredits')); + credits.innerHTML = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=showcredits')); } // showCredits() @@ -136,7 +136,7 @@ function Tags(mode, id) objTemp['mode'] = id.value; } - var retr = HTML_AJAX.post('rpc.php', objTemp); + var retr = HTML_AJAX.post(web_path + '/rpc.php', objTemp); if(retr == "ok") { refreshAvailableTags(); refreshSelectedTags(); @@ -159,8 +159,10 @@ function refreshAvailableTags() { // update available tags var avail_tags = document.getElementById('available_tags'); - avail_tags.innerHTML = "Loading..."; - avail_tags.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=show_available_tags')); + if(avail_tags != undefined) { + avail_tags.innerHTML = "Loading..."; + avail_tags.innerHTML = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=show_available_tags')); + } } // refreshAvailableTags() @@ -174,8 +176,10 @@ function refreshSelectedTags() { // update selected tags var selected_tags = document.getElementById("selected_tags"); - selected_tags.innerHTML = "Loading..."; - selected_tags.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=show_selected_tags')); + if(selected_tags != undefined) { + selected_tags.innerHTML = "Loading..."; + selected_tags.innerHTML = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=show_selected_tags')); + } } // refreshSelectedTags() @@ -188,7 +192,7 @@ function refreshSelectedTags() */ function showPhotoIndex(begin_with, last_photo) { - var url = "rpc.php?action=show_photo_index"; + var url = web_path + "/rpc.php?action=show_photo_index"; if(begin_with != undefined) url = url + '&begin_with=' + begin_with; if(last_photo != undefined) @@ -284,7 +288,7 @@ function startSearch() objTemp['to'] = to; } - var retr = HTML_AJAX.post('rpc.php', objTemp); + var retr = HTML_AJAX.post(web_path + '/rpc.php', objTemp); if(retr == "ok") { refreshAvailableTags(); refreshSelectedTags(); @@ -329,7 +333,7 @@ function setViewMode(mode) { var exprt = document.getElementById('output'); exprt.innerHTML = "Loading..."; - exprt.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=get_export&mode=' + mode)); + exprt.innerHTML = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=get_export&mode=' + mode)); } // setViewMode() @@ -354,7 +358,8 @@ function clearSearch() */ function AskServerWhatToDo() { - return HTML_AJAX.grab(encodeURI('rpc.php?action=what_to_do')); + return HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=what_to_do')); + } // AskServerWhatToDo() /** @@ -364,9 +369,19 @@ function AskServerWhatToDo() * the first time. It will fetch the tag-lists and will then * switch to the right view, which the browser got told from * the server (maybe someone hit the refresh button...). + * + * as parameter the server can set the correct webpath. + * espacialley when using user-friendly url's, the browser + * does not know the correct URLs to address images, stylesheets, + * ... then. */ -function init_phpfspot(mode) +function init_phpfspot(srv_webpath) { + if(srv_webpath != undefined) + web_path = srv_webpath; + else + web_path = ''; + /* always load list of available tags */ refreshAvailableTags(); @@ -415,7 +430,7 @@ function setBackGrdColor(item, color) */ function getPhotoToShow() { - var photo_to_show = HTML_AJAX.grab(encodeURI('rpc.php?action=get_photo_to_show')); + var photo_to_show = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=get_photo_to_show')); // if no image needs to be shown, return false from here if(photo_to_show == "") @@ -525,7 +540,7 @@ function showCalendar(date_box, click_obj) if(calendar.style.visibility == "" || calendar.style.visibility == 'hidden') { calendar.style.visibility = 'visible'; calendar.innerHTML = "Loading..."; - calendar.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=get_calendar_matrix&year=' + year + '&month=' + month)); + calendar.innerHTML = HTML_AJAX.grab(encodeURI(web_path +'/rpc.php?action=get_calendar_matrix&year=' + year + '&month=' + month)); calendar_shown = 1; } else { @@ -553,7 +568,7 @@ function setMonth(year, month, day) { var calendar = document.getElementById('calendar'); calendar.innerHTML = "Loading..."; - calendar.innerHTML = HTML_AJAX.grab(encodeURI('rpc.php?action=get_calendar_matrix&year='+ year +'&month='+ month +'&day='+ day)); + calendar.innerHTML = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=get_calendar_matrix&year='+ year +'&month='+ month +'&day='+ day)); } /** @@ -574,7 +589,7 @@ function setCalendarDate(year, month, day) */ function resetAll() { - HTML_AJAX.grab(encodeURI('rpc.php?action=reset')); + HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=reset')); clearSearch(); refreshAvailableTags(); refreshSelectedTags(); @@ -652,15 +667,15 @@ function noop() {} function startSlideShow() { if(!sliding) { - HTML_AJAX.grab(encodeURI('rpc.php?action=reset_slideshow')); + HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=reset_slideshow')); nextSlide(); sliding = setInterval("nextSlide()", sliding_time*1000); - document.getElementById('stop_ico').src = "resources/32_stop.png"; + document.getElementById('stop_ico').src = web_path + "/resources/32_stop.png"; } else { clearInterval(sliding); sliding = 0; - document.getElementById('stop_ico').src = "resources/32_play.png"; + document.getElementById('stop_ico').src = web_path + "/resources/32_play.png"; } } // startSlideShow() @@ -670,7 +685,7 @@ function startSlideShow() */ function nextSlide() { - var next_img = HTML_AJAX.grab(encodeURI('rpc.php?action=get_next_slideshow_img')); + var next_img = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=get_next_slideshow_img')); document.getElementById('slide_img').src = next_img; } // nextSlide() @@ -680,7 +695,7 @@ function nextSlide() */ function prevSlide() { - var prev_img = HTML_AJAX.grab(encodeURI('rpc.php?action=get_prev_slideshow_img')); + var prev_img = HTML_AJAX.grab(encodeURI(web_path + '/rpc.php?action=get_prev_slideshow_img')); document.getElementById('slide_img').src = prev_img; } // prevSlide() @@ -693,12 +708,12 @@ function pauseSlideShow() if(!sliding_paused) { sliding_paused = 1; clearInterval(sliding); - document.getElementById('pause_ico').src = "resources/32_play.png"; + document.getElementById('pause_ico').src = web_path + "/resources/32_play.png"; } else { sliding_paused = 0; sliding = setInterval("nextSlide()", sliding_time*1000); - document.getElementById('pause_ico').src = "resources/32_pause.png"; + document.getElementById('pause_ico').src = web_path + "/resources/32_pause.png"; } } // pauseSlideShow() @@ -715,7 +730,7 @@ function startAutoBrowse() else { clearInterval(autobrowse); autobrowse = 0; - document.getElementById('autobrowse_ico').src = "resources/32_play.png"; + document.getElementById('autobrowse_ico').src = web_path + "/resources/32_play.png"; } } // startAutoBrowser() @@ -728,12 +743,12 @@ function autoBrowse() if(document.getElementById('next_link')) { var next_link = document.getElementById('next_link').href; window.location.href = next_link; - document.getElementById('autobrowse_ico').src = "resources/32_pause.png"; + document.getElementById('autobrowse_ico').src = web_path + "/resources/32_pause.png"; } /* we have reached the last photo */ else { if(ab_ico = document.getElementById('autobrowse_ico')) - ab_ico.src = "resources/32_play.png"; + ab_ico.src = web_path + "/resources/32_play.png"; clearInterval(autobrowse); } @@ -774,7 +789,7 @@ function update_sort_order(obj) var objTemp = new Object(); objTemp['value'] = obj.options[obj.selectedIndex].value; - var retr = HTML_AJAX.post('rpc.php?action=update_sort_order', objTemp); + var retr = HTML_AJAX.post(web_path + '/rpc.php?action=update_sort_order', objTemp); if(retr == "ok") { showPhotoIndex(); @@ -843,3 +858,4 @@ var origHeight; var origWidth; // position of the last shown photo in photo-index var photo_details_pos; +var web_path; diff --git a/themes/default/templates/export.tpl b/themes/default/templates/export.tpl index 3647863..7f6f2de 100644 --- a/themes/default/templates/export.tpl +++ b/themes/default/templates/export.tpl @@ -7,7 +7,7 @@ - +
diff --git a/themes/default/templates/header.tpl b/themes/default/templates/header.tpl index e946a5b..1cd9cb4 100644 --- a/themes/default/templates/header.tpl +++ b/themes/default/templates/header.tpl @@ -3,19 +3,19 @@ {$page_title} - - - - - + + + + + { if $use_lightbox } - - - - + + + + { /if } { if $use_autocomplete } - - + + { /if } diff --git a/themes/default/templates/index.tpl b/themes/default/templates/index.tpl index 59b4b56..468239a 100644 --- a/themes/default/templates/index.tpl +++ b/themes/default/templates/index.tpl @@ -1,10 +1,10 @@ {include file="header.tpl"} - +
-   Loading... +   Loading...
@@ -12,13 +12,13 @@
{if $slideshow_link } -  Slideshow +  Slideshow {/if} {if $extern_link } -  External Link +  External Link {/if} {if $export_link } -  Export +  Export {/if} {if $rss_link } -  RSS-Feed +  RSS-Feed {/if}
@@ -73,7 +73,7 @@ {$img_name[thumb]} { if $use_lightbox } - + { /if } @@ -89,11 +89,11 @@
{ if $next_url == "" } { if $count != 0 } - last page reached + last page reached { /if } { else } - next photo + next photo { /if}
@@ -102,11 +102,11 @@
{ if $previous_url == "" } { if $count != 0 } - first page reached + first page reached { /if } { else } - previous photo + previous photo { /if }
@@ -130,7 +130,7 @@ {section name="thumb" loop=$thumbs step=1} {if $images[thumb] } - image_urls[{counter}] = 'phpfspot_img.php?idx={$images[thumb]}&width={$width}'; + image_urls[{counter}] = '{$web_path}/phpfspot_img.php?idx={$images[thumb]}&width={$width}'; last_thumb = {$images[thumb]}; {/if} {/section} diff --git a/themes/default/templates/search.tpl b/themes/default/templates/search.tpl index f983c40..ca7042e 100644 --- a/themes/default/templates/search.tpl +++ b/themes/default/templates/search.tpl @@ -1,5 +1,5 @@ - loupeSearch: + loupeSearch:
@@ -25,7 +25,7 @@ { /if } - + @@ -34,7 +34,7 @@ - + @@ -51,15 +51,15 @@   - {$from_date} + {$from_date}   - {$to_date} + {$to_date} - + diff --git a/themes/default/templates/single_photo.tpl b/themes/default/templates/single_photo.tpl index 8526053..a9ecec4 100644 --- a/themes/default/templates/single_photo.tpl +++ b/themes/default/templates/single_photo.tpl @@ -15,50 +15,50 @@ {/if}
- - - -  Auto-Browse + + + +  Auto-Browse {if $extern_link } -  External Link +  External Link {/if} - original resolution Fullsize + original resolution Fullsize
{ if $ExifMadeWith } - camera icon Image taken with:
+ camera icon Image taken with:
{$ExifMadeWith}
{ /if } { if $ExifMadeOn } - calendar icon Image made on:
+ calendar icon Image made on:
{$ExifMadeOn}
{ /if } { if $ExifOrigResolution } - resolution icon Original resolution:
+ resolution icon Original resolution:
{$ExifOrigResolution}
{ /if } Size: {$ExifFileSize}
{ if $tags }
- available tags Tagged with:
+ available tags Tagged with:
{ foreach from=$tags key=id item=name } {$name}
{ /foreach } { /if }
{ if $prev_img } - photo icon Previous:
+ photo icon Previous:
-
+
{ /if} { if $next_img } - photo icon Next:
+ photo icon Next:
-
+
{ /if}
@@ -79,20 +79,20 @@
{ if $previous_url == "" } - first photo reached + first photo reached { else } - previous photo + previous photo { /if } - photo index + photo index { if $next_url == "" } - last photo reached + last photo reached { else } - next photo + next photo { /if}
@@ -104,9 +104,9 @@ /* lets preload to previous and the next image to speedup */ var image_next = new Image(); - image_next.src = "phpfspot_img.php?idx={$next_img}&width={$photo_width}"; + image_next.src = "{$web_path}/phpfspot_img.php?idx={$next_img}&width={$photo_width}"; var image_prev = new Image(); - image_prev.src = "phpfspot_img.php?idx={$prev_img}&width={$photo_width}"; + image_prev.src = "{$web_path}/phpfspot_img.php?idx={$prev_img}&width={$photo_width}"; --> diff --git a/themes/default/templates/slideshow.tpl b/themes/default/templates/slideshow.tpl index c5e8ba5..84b6a6b 100644 --- a/themes/default/templates/slideshow.tpl +++ b/themes/default/templates/slideshow.tpl @@ -1,14 +1,14 @@ {include file="header.tpl"} - - - - + + + +
- - - - + + + +
diff --git a/themes/default/templates/tags.tpl b/themes/default/templates/tags.tpl index 42a20ff..a4b1e0a 100644 --- a/themes/default/templates/tags.tpl +++ b/themes/default/templates/tags.tpl @@ -1,9 +1,9 @@ - available tagsAvailable Tags: + available tagsAvailable Tags:
- selected tagsSelected Tags: + selected tagsSelected Tags:   || diff --git a/themes/default/templates/welcome.tpl b/themes/default/templates/welcome.tpl index 4629fda..6e6613c 100644 --- a/themes/default/templates/welcome.tpl +++ b/themes/default/templates/welcome.tpl @@ -5,7 +5,7 @@