1 |
296 |
ahitrov |
/* |
2 |
|
|
Litebox JS by Alexander Shabuniewicz - http://aether.ru |
3 |
|
|
2006-08-18 |
4 |
|
|
|
5 |
|
|
inspired by Lightbox JS - Lokesh Dhakar - http://www.huddletogether.com |
6 |
|
|
and portfolio script of Cameron Adams - http://portfolio.themaninblue.com |
7 |
|
|
*/ |
8 |
|
|
|
9 |
|
|
var imgNext; |
10 |
|
|
var imgPrev; |
11 |
|
|
var nLiteboxActive = 0; |
12 |
|
|
|
13 |
|
|
function showBox(theTarget) { |
14 |
|
|
if ( nLiteboxActive == 1 ) { |
15 |
|
|
return; |
16 |
|
|
} else { |
17 |
|
|
nLiteboxActive = 1; |
18 |
|
|
} |
19 |
|
|
var theBody = document.getElementsByTagName('body')[0]; |
20 |
|
|
var pageCoords = getPageCoords(); |
21 |
|
|
|
22 |
|
|
var theShadow = document.createElement('div'); |
23 |
|
|
theShadow.id = 'shadow'; |
24 |
|
|
theShadow.style.height = (pageCoords[1] + 'px'); |
25 |
|
|
theShadow.className = 'on'; |
26 |
|
|
selects = document.getElementsByTagName("select"); |
27 |
|
|
for (i = 0; i != selects.length; i++) { |
28 |
|
|
selects[i].style.visibility = "hidden"; |
29 |
|
|
} |
30 |
|
|
theBody.insertBefore(theShadow, theBody.firstChild); |
31 |
|
|
|
32 |
|
|
var theLoading = document.createElement('div'); |
33 |
|
|
theLoading.id = 'loading'; |
34 |
|
|
theLoading.style.top = parseInt(pageCoords[2] + (pageCoords[0] - 55) / 2) + 'px'; |
35 |
|
|
theLoading.onclick = function() { closeBox(); } |
36 |
|
|
theShadow.appendChild(theLoading); |
37 |
|
|
|
38 |
|
|
var imgPreload = new Image(); |
39 |
|
|
imgPreload.onload = function() { |
40 |
|
|
var theBox = document.createElement('div'); |
41 |
|
|
theBox.id = 'litebox'; |
42 |
|
|
theBox.style.width = imgPreload.width + 10 + 'px'; |
43 |
|
|
theBox.style.marginTop = parseInt(pageCoords[2] + (pageCoords[0] - imgPreload.height - 50) / 2) + 'px'; |
44 |
|
|
|
45 |
|
|
var theImage = document.createElement('img'); |
46 |
|
|
theImage.src = theTarget.href; |
47 |
|
|
theImage.alt = theTarget.title; |
48 |
|
|
theImage.width = imgPreload.width; |
49 |
|
|
theImage.onclick = function() { closeBox(); } |
50 |
|
|
theImage.title = "Click to close this image"; |
51 |
|
|
|
52 |
|
|
|
53 |
|
|
var theCaption = document.createElement('p'); |
54 |
|
|
theCaption.className = 'litebox-caption'; |
55 |
|
|
theCaption.innerHTML = (theImage.alt) ? '<b>' + theImage.alt + '</b><br>' : ''; |
56 |
|
|
theCaption.innerHTML += '<span style="color:#a0a0a0">Щелкните указателем мыши по фотографии<br>или нажмите клавишу «Esc», чтобы завершить просмотр</span>'; |
57 |
|
|
|
58 |
|
|
var allThumbs = new Array(); |
59 |
|
|
var allLinks = document.getElementsByTagName('a'); |
60 |
|
|
var linkLen = allLinks.length; |
61 |
|
|
for (i=0,j=0; i<linkLen; i++) { |
62 |
|
|
if (allLinks[i].getAttribute('rel') == 'lightbox') { |
63 |
|
|
allThumbs[j++] = allLinks[i]; |
64 |
|
|
} |
65 |
|
|
} |
66 |
|
|
linkLen = allThumbs.length; |
67 |
|
|
for (i=0; i<linkLen; i++) { |
68 |
|
|
if (allThumbs[i].href == theTarget.href) { |
69 |
|
|
if (allThumbs[i-1]) { |
70 |
|
|
var thePrevLink = document.createElement('a'); |
71 |
|
|
thePrevLink.className = 'prev'; |
72 |
|
|
thePrevLink.title = allThumbs[i-1].title; |
73 |
|
|
thePrevLink.href = allThumbs[i-1].href; |
74 |
|
|
thePrevLink.onclick = function() { closeBox(); showBox(this); return false; } |
75 |
|
|
theCaption.insertBefore(thePrevLink, theCaption.firstChild); |
76 |
|
|
imgPrev = allThumbs[i-1]; |
77 |
|
|
} |
78 |
|
|
if (allThumbs[i+1]) { |
79 |
|
|
var theNextLink = document.createElement('a'); |
80 |
|
|
theNextLink.className = 'next'; |
81 |
|
|
theNextLink.title = allThumbs[i+1].title; |
82 |
|
|
theNextLink.href = allThumbs[i+1].href; |
83 |
|
|
theNextLink.onclick = function() { closeBox(); showBox(this); return false; } |
84 |
|
|
theCaption.insertBefore(theNextLink, theCaption.firstChild); |
85 |
|
|
imgNext = allThumbs[i+1]; |
86 |
|
|
} |
87 |
|
|
} |
88 |
|
|
} |
89 |
|
|
|
90 |
|
|
theShadow.removeChild(theLoading); |
91 |
|
|
theBox.appendChild(theImage); |
92 |
|
|
theBox.appendChild(theCaption); |
93 |
|
|
theShadow.appendChild(theBox); |
94 |
|
|
|
95 |
|
|
document.onkeypress = getKey; |
96 |
|
|
return false; |
97 |
|
|
} |
98 |
|
|
imgPreload.src = theTarget.href; |
99 |
|
|
} |
100 |
|
|
|
101 |
|
|
function getPageCoords() { |
102 |
|
|
var coords = [0, 0, 0]; // height of window, document, scroll pos |
103 |
|
|
// all except IE |
104 |
|
|
if (window.innerHeight) { |
105 |
|
|
coords[0] = window.innerHeight; |
106 |
|
|
coords[2] = window.pageYOffset; |
107 |
|
|
} |
108 |
|
|
// IE 6 Strict |
109 |
|
|
else if (document.documentElement && document.documentElement.clientHeight != 0) { |
110 |
|
|
coords[0] = document.documentElement.clientHeight; |
111 |
|
|
coords[2] = document.documentElement.scrollTop; |
112 |
|
|
} |
113 |
|
|
else if (document.body) { |
114 |
|
|
coords[0] = document.body.clientHeight; |
115 |
|
|
coords[2] = document.body.scrollTop; |
116 |
|
|
} |
117 |
|
|
|
118 |
|
|
var test1 = document.body.scrollHeight; |
119 |
|
|
var test2 = document.body.offsetHeight; |
120 |
|
|
if (test1 > test2) { |
121 |
|
|
coords[1] = document.body.scrollHeight; |
122 |
|
|
} else { |
123 |
|
|
coords[1] = document.body.offsetHeight; |
124 |
|
|
} |
125 |
|
|
if (coords[1] < coords[0]) coords[1] = coords[0]; |
126 |
|
|
|
127 |
|
|
return coords; |
128 |
|
|
} |
129 |
|
|
|
130 |
|
|
function closeBox() { |
131 |
|
|
var theBody = document.getElementsByTagName('body')[0]; |
132 |
|
|
var theBox = document.getElementById('litebox'); |
133 |
|
|
if (theBox) theBox.style.display = 'none'; |
134 |
|
|
var theShadow = document.getElementById('shadow'); |
135 |
|
|
if (theShadow) theShadow.style.display = 'none'; |
136 |
|
|
theBody.removeChild(theShadow); |
137 |
|
|
|
138 |
|
|
selects = document.getElementsByTagName('select'); |
139 |
|
|
for (i = 0; i != selects.length; i++) { |
140 |
|
|
selects[i].style.visibility = 'visible'; |
141 |
|
|
} |
142 |
|
|
document.onkeypress = ''; |
143 |
|
|
imgPrev = imgNext = ''; |
144 |
|
|
nLiteboxActive = 0; |
145 |
|
|
return false; |
146 |
|
|
} |
147 |
|
|
|
148 |
|
|
function getKey(e) { |
149 |
|
|
var arrowImg; |
150 |
|
|
|
151 |
|
|
if (!e) var e = window.event; |
152 |
|
|
var keycode = e.keyCode ? e.keyCode : e.which; |
153 |
|
|
|
154 |
|
|
switch (keycode) { |
155 |
|
|
case 27: // esc |
156 |
|
|
case 32: // spacebar |
157 |
|
|
closeBox(); |
158 |
|
|
break; |
159 |
|
|
case 37: // <- |
160 |
|
|
arrowImg = imgPrev ? imgPrev : ''; |
161 |
|
|
break; |
162 |
|
|
case 39: // -> |
163 |
|
|
arrowImg = imgNext ? imgNext : ''; |
164 |
|
|
} |
165 |
|
|
if (arrowImg) { closeBox(); showBox(arrowImg); } |
166 |
|
|
return false; |
167 |
|
|
} |
168 |
|
|
|
169 |
|
|
function initLitebox() { |
170 |
|
|
if (!document.getElementsByTagName) { return; } |
171 |
|
|
var anchors = document.getElementsByTagName('a'); |
172 |
|
|
|
173 |
|
|
for (i=0,len=anchors.length; i<len; i++){ |
174 |
|
|
var anchor = anchors[i]; |
175 |
|
|
if (anchor.getAttribute('href') && (anchor.getAttribute('rel') == 'lightbox')) { |
176 |
|
|
anchor.onclick = function() { showBox(this); return false; } |
177 |
|
|
} |
178 |
|
|
} |
179 |
|
|
anchor = null; |
180 |
|
|
} |
181 |
|
|
|
182 |
|
|
function addLoadEvent(func) { |
183 |
|
|
var oldonload = window.onload; |
184 |
|
|
if (typeof window.onload != 'function') { |
185 |
|
|
window.onload = func; |
186 |
|
|
} else { |
187 |
|
|
window.onload = function() { |
188 |
|
|
oldonload(); |
189 |
|
|
func(); |
190 |
|
|
} |
191 |
|
|
} |
192 |
|
|
} |
193 |
|
|
|
194 |
|
|
addLoadEvent(initLitebox); |