kash_gateway - Version 0.1.4

Version Notes

v0.1.4 - Initial Release

Download this release

Release Info

Developer Kash Corp.
Extension kash_gateway
Version 0.1.4
Comparing to
See all releases


Code changes from version 0.1.1 to 0.1.4

app/code/local/Kash/Gateway/Model/Checkout.php CHANGED
@@ -275,18 +275,6 @@ class Kash_Gateway_Model_Checkout
275
  return;
276
  }
277
 
278
- switch ($order->getState()) {
279
- // even after placement payment can disallow to authorize/capture, but will wait until bank transfers money
280
- case Mage_Sales_Model_Order::STATE_PENDING_PAYMENT:
281
- // TODO
282
- break;
283
- // regular placement, when everything is ok
284
- case Mage_Sales_Model_Order::STATE_PROCESSING:
285
- case Mage_Sales_Model_Order::STATE_COMPLETE:
286
- case Mage_Sales_Model_Order::STATE_PAYMENT_REVIEW:
287
- $order->queueNewOrderEmail();
288
- break;
289
- }
290
  $this->_order = $order;
291
  }
292
 
275
  return;
276
  }
277
 
 
 
 
 
 
 
 
 
 
 
 
 
278
  $this->_order = $order;
279
  }
280
 
app/code/local/Kash/Gateway/Model/Observer.php CHANGED
@@ -42,27 +42,5 @@ class Kash_Gateway_Model_Observer extends Varien_Object
42
  }
43
  }
44
 
45
- /**
46
- * Add payment data to info block
47
- *
48
- * @param Varien_Object $observer
49
- * @return Mage_Centinel_Model_Observer
50
- */
51
- public function paymentInfoBlockPrepareSpecificInformation($observer)
52
- {
53
- if ($observer->getEvent()->getBlock()->getIsSecureMode()) {
54
- return;
55
- }
56
-
57
- $order = $observer->getEvent()->getPayment()->getOrder();
58
- $discountAmount = abs($order->getDiscountAmount());
59
- $subtotal = $order->getSubtotal();
60
-
61
- $percent = round($discountAmount * 100 / $subtotal, 2);
62
- $transport = $observer->getEvent()->getTransport();
63
- $transport->setData('Gateway percent', $percent . '%');
64
-
65
- return $this;
66
- }
67
  }
68
 
42
  }
43
  }
44
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
45
  }
46
 
app/code/local/Kash/Gateway/controllers/BbController.php CHANGED
@@ -282,6 +282,7 @@ class Kash_Gateway_BbController extends Mage_Core_Controller_Front_Action
282
  $invoice->getOrder()->setCustomerNoteNotify(false);
283
  $invoice->getOrder()->setIsInProcess(true);
284
  $order->addStatusHistoryComment('Automatically INVOICED by Kash Gateway.', false);
 
285
 
286
  $transactionSave = Mage::getModel('core/resource_transaction')
287
  ->addObject($invoice)
282
  $invoice->getOrder()->setCustomerNoteNotify(false);
283
  $invoice->getOrder()->setIsInProcess(true);
284
  $order->addStatusHistoryComment('Automatically INVOICED by Kash Gateway.', false);
285
+ $order->sendNewOrderEmail();
286
 
287
  $transactionSave = Mage::getModel('core/resource_transaction')
288
  ->addObject($invoice)
app/code/local/Kash/Gateway/etc/config.xml CHANGED
@@ -2,7 +2,7 @@
2
  <config>
3
  <modules>
4
  <Kash_Gateway>
5
- <version>0.1.1</version>
6
  </Kash_Gateway>
7
  </modules>
8
  <global>
@@ -67,15 +67,6 @@
67
  </kash_gateway>
68
  </observers>
69
  </core_collection_abstract_load_before>
70
- <payment_info_block_prepare_specific_information>
71
- <observers>
72
- <kash_gateway>
73
- <type>model</type>
74
- <class>kash_gateway/observer</class>
75
- <method>paymentInfoBlockPrepareSpecificInformation</method>
76
- </kash_gateway>
77
- </observers>
78
- </payment_info_block_prepare_specific_information>
79
  </events>
80
  </adminhtml>
81
 
2
  <config>
3
  <modules>
4
  <Kash_Gateway>
5
+ <version>0.1.4</version>
6
  </Kash_Gateway>
7
  </modules>
8
  <global>
67
  </kash_gateway>
68
  </observers>
69
  </core_collection_abstract_load_before>
 
 
 
 
 
 
 
 
 
70
  </events>
71
  </adminhtml>
72
 
app/code/local/Kash/Gateway/etc/system.xml CHANGED
@@ -66,7 +66,6 @@
66
  <show_in_default>1</show_in_default>
67
  <show_in_website>1</show_in_website>
68
  <show_in_store>1</show_in_store>
69
- <comment>Add a payment gateway with "Redirect URL" of https://offsite-gateway-sim.herokuapp.com/</comment>
70
  </post_url>
71
  <skip_order_review_step translate="label comment">
72
  <label>Order Review Step</label>
66
  <show_in_default>1</show_in_default>
67
  <show_in_website>1</show_in_website>
68
  <show_in_store>1</show_in_store>
 
69
  </post_url>
70
  <skip_order_review_step translate="label comment">
71
  <label>Order Review Step</label>
app/design/frontend/base/default/layout/kash/gateway.xml CHANGED
@@ -4,6 +4,22 @@
4
  <reference name="before_body_end">
5
  <block type="core/template" template="kash/js.phtml" before="-"/>
6
  </reference>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
7
  </default>
8
 
9
  <kash_gateway_bb_start>
4
  <reference name="before_body_end">
5
  <block type="core/template" template="kash/js.phtml" before="-"/>
6
  </reference>
7
+
8
+ <reference name="head">
9
+ <action method="addItem">
10
+ <type>skin_css</type>
11
+ <name>css/kash/start.css</name>
12
+ </action>
13
+ <action method="addItem">
14
+ <type>skin_css</type>
15
+ <name>css/kash/lightwindow.css</name>
16
+ </action>
17
+ <action method="addItem">
18
+ <type>skin_js</type>
19
+ <name>js/kash/lightwindow.js</name>
20
+ </action>
21
+ </reference>
22
+
23
  </default>
24
 
25
  <kash_gateway_bb_start>
app/design/frontend/base/default/template/kash/payment/mark.phtml CHANGED
@@ -4,4 +4,27 @@
4
  */
5
  ?>
6
  <?php echo $this->getMessage() ?>
 
 
 
 
 
 
 
 
 
 
 
 
7
 
 
 
 
 
 
 
 
 
 
 
 
4
  */
5
  ?>
6
  <?php echo $this->getMessage() ?>
7
+ <br />
8
+ <a id="kash_direct_debit_link"
9
+ href="//www.withkash.com/what-is-direct-debit"
10
+ title="What is Direct Debit"
11
+ style="float:none;margin:0px 0px;">
12
+ What is Direct Debit?
13
+ </a>
14
+ <script>
15
+ function getDimensions() {
16
+ var userAgent = navigator.userAgent || navigator.vendor || window.opera;
17
+ var width = parseInt(Math.max(document.documentElement.clientWidth, window.innerWidth || 0));
18
+ var height = parseInt(Math.max(document.documentElement.clientHeight, window.innerHeight || 0));
19
 
20
+ if (userAgent.match(/iPad|iPhone|iPod|Android/i)) {
21
+ return [width, height];
22
+ }
23
+ return [width*2/3, height*2/3]
24
+ }
25
+
26
+ document.getElementById("kash_direct_debit_link").setAttribute("class", "lightwindow");
27
+ document.getElementById("kash_direct_debit_link").setAttribute("params", "lightwindow_loading_animation=false,lightwindow_width="+getDimensions()[0]+",lightwindow_height="+getDimensions()[1]);
28
+
29
+
30
+ </script>
package.xml CHANGED
@@ -1,7 +1,7 @@
1
  <?xml version="1.0"?>
2
  <package>
3
  <name>kash_gateway</name>
4
- <version>0.1.1</version>
5
  <stability>stable</stability>
6
  <license>MITL</license>
7
  <channel>community</channel>
@@ -12,11 +12,11 @@
12
  Kash does this by offering customers the option to pay using their bank account. For customers that don't want to use their bank account to pay, they'll have the option of using credit card instead. You can choose to either charge the credit card processing fee to the customer, or pay for the fee yourself like you do currently.&#xD;
13
  &#xD;
14
  You will need a Kash account in order to use this gateway. Please contact info@withkash.com for any questions.</description>
15
- <notes>v0.1.1 - Initial Release</notes>
16
- <authors><author><name>Kash Corp.</name><user>withkash</user><email>info@withkash.com</email></author></authors>
17
- <date>2015-11-04</date>
18
- <time>06:56:24</time>
19
- <contents><target name="mageskin"><dir name="frontend"><dir name="base"><dir name="default"><dir name="css"><dir name="kash"><file name="start.css" hash="d310d178769035d366ebb2caff9bd4a3"/></dir></dir></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="Kash_Gateway.xml" hash="03365c54da611a023ea2a12c6404c455"/></dir></target><target name="magelocal"><dir name="Kash"><dir><dir name="Gateway"><dir name="Block"><dir name="Adminhtml"><file name="Info.php" hash="186ac575a69755543d649d2174f43474"/><dir name="Sales"><dir name="Order"><file name="Grid.php" hash="757f5028ff98d3c375cf3345675d55b7"/></dir></dir></dir><dir name="Form"><file name="Bb.php" hash="2516cb64469800cfc450710250317d72"/></dir><dir name="Review"><file name="Details.php" hash="9a077c6688f913bd4f9fee74fad68b7e"/></dir><file name="Review.php" hash="a2a24914d577262188c491898c77307e"/></dir><dir name="Helper"><file name="Checkout.php" hash="89863d74391a81e7336073a8c9634ce8"/><file name="Data.php" hash="cc0eb77c1be47e1d4e846033cc2aed9a"/></dir><dir name="Model"><dir name="Api"><file name="Abstract.php" hash="99ed019c3e8e13caf90fa248e608c9ea"/><file name="Bb.php" hash="f1605310d4042b4704577fe2925c2a86"/></dir><file name="Cart.php" hash="ced06fca31abf3fbe20e3e2eb430cfea"/><file name="Checkout.php" hash="cad380737617bc30c2d067d9f42a7b36"/><file name="Config.php" hash="5299275ecc589f56c9bc9c9123e39405"/><dir name="Method"><file name="Bb.php" hash="6cd0683fa597d31d830ae7787b0284cd"/></dir><file name="Observer.php" hash="d7b27c64189811ac66d82cf6dd3841ff"/><file name="Session.php" hash="1778fbe493d2ceb81d8a20b58a21ce3c"/></dir><dir name="controllers"><file name="BbController.php" hash="6349cf80569789e5cedb77370063046e"/></dir><dir name="data"><dir name="kash_gateway_setup"><file name="data-install-0.0.1.php" hash="5fe91e15bc5e6269eadcc50f8991250a"/><file name="data-upgrade-0.0.1-0.0.2.php" hash="632331f77e2238438e1bddfe4c2b82bf"/></dir></dir><dir name="etc"><file name="config.xml" hash="3b9b94e4fdbd9364d0c24fe7306104d5"/><file name="system.xml" hash="6c4da7f0fd0f07f0577fa1aeb0abee25"/></dir><dir name="sql"><dir name="kash_gateway_setup"><file name="install-0.0.1.php" hash="9ecb52ba48345cdbee9ce0fd92d2aff9"/></dir></dir></dir></dir></dir></target><target name="magedesign"><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="template"><dir name="kash"><dir name="info"><file name="default.phtml" hash="79bcf1003e40c03ec35c383ec4ca5236"/></dir></dir></dir></dir></dir></dir><dir name="frontend"><dir name="base"><dir name="default"><dir name="template"><dir name="kash"><file name="container.phtml" hash="9dafeab90d16b221ab8684990ef62ec3"/><file name="form.phtml" hash="0b4b05f427474b08d1c52cfc09fc3485"/><file name="js.phtml" hash="3a1b1a96fd25b4035f41dbe95633f229"/><dir><dir name="payment"><file name="mark.phtml" hash="01fa231a78eab8c435d6ea2ad508ef56"/><file name="redirect.phtml" hash="9cd530bec26cc5f76ab01cfb57095c32"/><dir name="review"><file name="details.phtml" hash="ff2ad65893e66920a4cc8b098dc397c1"/></dir><file name="review.phtml" hash="ef1d435a2bc0e9daff56594a715bed1a"/></dir></dir></dir></dir><dir name="layout"><dir name="kash"><file name="gateway.xml" hash="21bd19c6bc5830b2998afcc1bb1e1f27"/></dir></dir></dir></dir></dir></target></contents>
20
  <compatible/>
21
  <dependencies><required><php><min>5.4.45</min><max>5.6.15</max></php></required></dependencies>
22
  </package>
1
  <?xml version="1.0"?>
2
  <package>
3
  <name>kash_gateway</name>
4
+ <version>0.1.4</version>
5
  <stability>stable</stability>
6
  <license>MITL</license>
7
  <channel>community</channel>
12
  Kash does this by offering customers the option to pay using their bank account. For customers that don't want to use their bank account to pay, they'll have the option of using credit card instead. You can choose to either charge the credit card processing fee to the customer, or pay for the fee yourself like you do currently.&#xD;
13
  &#xD;
14
  You will need a Kash account in order to use this gateway. Please contact info@withkash.com for any questions.</description>
15
+ <notes>v0.1.4 - Initial Release</notes>
16
+ <authors><author><name>Kash Corp.</name><user>kash_corp</user><email>info@withkash.com</email></author></authors>
17
+ <date>2015-12-02</date>
18
+ <time>20:42:30</time>
19
+ <contents><target name="mageskin"><dir name="frontend"><dir name="base"><dir name="default"><dir name="css"><dir name="kash"><file name="lightwindow.css" hash="1addd9e2971e76af24c5eadf67fafc60"/><file name="start.css" hash="d310d178769035d366ebb2caff9bd4a3"/><file name="._lightwindow.css" hash="6bac7309b1e370cf137d882ba90d6510"/></dir></dir><dir name="js"><dir name="kash"><file name="lightwindow.js" hash="a63e1ae37ef7f727c97ffa0f4f0292d7"/><file name="._lightwindow.js" hash="6bac7309b1e370cf137d882ba90d6510"/></dir></dir></dir></dir></dir></target><target name="mageetc"><dir name="modules"><file name="Kash_Gateway.xml" hash="03365c54da611a023ea2a12c6404c455"/></dir></target><target name="magedesign"><dir name="frontend"><dir name="base"><dir name="default"><dir name="layout"><dir name="kash"><file name="gateway.xml" hash="62ce90320a5d09cc8334e512c3cda3b3"/></dir></dir><dir name="template"><dir name="kash"><file name="container.phtml" hash="9dafeab90d16b221ab8684990ef62ec3"/><file name="form.phtml" hash="0b4b05f427474b08d1c52cfc09fc3485"/><file name="js.phtml" hash="3a1b1a96fd25b4035f41dbe95633f229"/><dir name="payment"><file name="mark.phtml" hash="96ac85ef2f73ec0953dee53cd3d7d0a7"/><file name="redirect.phtml" hash="9cd530bec26cc5f76ab01cfb57095c32"/><dir name="review"><file name="details.phtml" hash="ff2ad65893e66920a4cc8b098dc397c1"/></dir><file name="review.phtml" hash="ef1d435a2bc0e9daff56594a715bed1a"/></dir></dir></dir></dir></dir></dir><dir name="adminhtml"><dir name="default"><dir name="default"><dir name="template"><dir name="kash"><dir name="info"><file name="default.phtml" hash="79bcf1003e40c03ec35c383ec4ca5236"/></dir></dir></dir></dir></dir></dir></target><target name="magelocal"><dir name="Kash"><dir name="Gateway"><dir name="Block"><dir name="Adminhtml"><file name="Info.php" hash="186ac575a69755543d649d2174f43474"/><dir name="Sales"><dir name="Order"><file name="Grid.php" hash="757f5028ff98d3c375cf3345675d55b7"/></dir></dir></dir><dir name="Form"><file name="Bb.php" hash="2516cb64469800cfc450710250317d72"/></dir><dir name="Review"><file name="Details.php" hash="9a077c6688f913bd4f9fee74fad68b7e"/></dir><file name="Review.php" hash="a2a24914d577262188c491898c77307e"/></dir><dir name="Helper"><file name="Checkout.php" hash="89863d74391a81e7336073a8c9634ce8"/><file name="Data.php" hash="cc0eb77c1be47e1d4e846033cc2aed9a"/></dir><dir name="Model"><dir name="Api"><file name="Abstract.php" hash="99ed019c3e8e13caf90fa248e608c9ea"/><file name="Bb.php" hash="f1605310d4042b4704577fe2925c2a86"/></dir><file name="Cart.php" hash="ced06fca31abf3fbe20e3e2eb430cfea"/><file name="Checkout.php" hash="bed98494d4bb1d93b6e6758555d98450"/><file name="Config.php" hash="5299275ecc589f56c9bc9c9123e39405"/><dir name="Method"><file name="Bb.php" hash="6cd0683fa597d31d830ae7787b0284cd"/></dir><file name="Observer.php" hash="eede09fb15543e8a535820612104e520"/><file name="Session.php" hash="1778fbe493d2ceb81d8a20b58a21ce3c"/></dir><dir name="controllers"><file name="BbController.php" hash="3ab8fcfabbc52474eb7f161fc91c5986"/></dir><dir name="data"><dir name="kash_gateway_setup"><file name="data-install-0.0.1.php" hash="5fe91e15bc5e6269eadcc50f8991250a"/><file name="data-upgrade-0.0.1-0.0.2.php" hash="632331f77e2238438e1bddfe4c2b82bf"/></dir></dir><dir name="etc"><file name="config.xml" hash="9538e1037a44f4280726f537f0a9d3e5"/><file name="system.xml" hash="3667ceed76bc0a905af96e7b4adbf2b0"/></dir><dir name="sql"><dir name="kash_gateway_setup"><file name="install-0.0.1.php" hash="9ecb52ba48345cdbee9ce0fd92d2aff9"/></dir></dir></dir></dir></target></contents>
20
  <compatible/>
21
  <dependencies><required><php><min>5.4.45</min><max>5.6.15</max></php></required></dependencies>
22
  </package>
skin/frontend/base/default/css/kash/lightwindow.css ADDED
@@ -0,0 +1,393 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ #lightwindow_overlay {
2
+ /* REQUIRED */
3
+ display: none;
4
+ visibility: hidden;
5
+ position: absolute;
6
+ top: 0;
7
+ left: 0;
8
+ width: 100%;
9
+ height: 100px;
10
+ z-index: 500;
11
+ /* REQUIRED */
12
+ }
13
+
14
+ #lightwindow {
15
+ /* REQUIRED */
16
+ /* Of Note - The height and width of this element are set to 0px */
17
+ display: none;
18
+ visibility: hidden;
19
+ position: absolute;
20
+ z-index: 999;
21
+ line-height: 0px;
22
+ /* REQUIRED */
23
+
24
+ /* otherwise conflicts with magento css */
25
+ -webkit-box-sizing: content-box;
26
+ -moz-box-sizing: content-box;
27
+ box-sizing: content-box;
28
+
29
+ }
30
+
31
+ #lightwindow_container {
32
+ /* REQUIRED */
33
+ display: none;
34
+ visibility: hidden;
35
+ position: absolute;
36
+ /* REQUIRED */
37
+ padding: 0 0 0 0;
38
+ margin: 0 0 0 0;
39
+
40
+ /* otherwise conflicts with magento css */
41
+ -webkit-box-sizing: content-box;
42
+ -moz-box-sizing: content-box;
43
+ box-sizing: content-box;
44
+ }
45
+
46
+ /* IE6 needs this or it messes with our positioning */
47
+ * html #lightwindow_container {
48
+ overflow: hidden;
49
+ }
50
+
51
+ #lightwindow_contents {
52
+ overflow: hidden;
53
+ z-index: 0;
54
+ position: relative;
55
+ border: 10px solid #ffffff;
56
+ background-color: #ffffff;
57
+ /* otherwise conflicts with magento css */
58
+ -webkit-box-sizing: content-box;
59
+ -moz-box-sizing: content-box;
60
+ box-sizing: content-box;
61
+ }
62
+
63
+ #lightwindow_loading {
64
+ /* REQUIRED */
65
+ height: 100%;
66
+ width: 100%;
67
+ top: 0px;
68
+ left: 0px;
69
+ z-index: 9999;
70
+ position: absolute;
71
+ /* REQUIRED */
72
+ background-color: #f0f0f0;
73
+ padding: 10px;
74
+ }
75
+
76
+ #lightwindow_loading_shim {
77
+ display: none;
78
+ left: 0px;
79
+ position: absolute;
80
+ top: 0px;
81
+ width: 100%;
82
+ height: 100%;
83
+ }
84
+
85
+ #lightwindow_loading span {
86
+ font-size: 12px;
87
+ line-height: 32px;
88
+ color: #444444;
89
+ float: left;
90
+ padding: 0 10px 0 0;
91
+ }
92
+
93
+ #lightwindow_loading span a,
94
+ #lightwindow_loading span a:link,
95
+ #lightwindow_loading span a:visited {
96
+ color: #09F;
97
+ text-decoration: none;
98
+ cursor: pointer;
99
+ }
100
+
101
+ #lightwindow_loading span a:hover,
102
+ #lightwindow_loading span a:active {
103
+ text-decoration: underline;
104
+ }
105
+
106
+
107
+ #lightwindow_loading img {
108
+ float: left;
109
+ margin: 0 10px 0 0;
110
+ }
111
+
112
+
113
+ /*-----------------------------------------------------------------------------------------------
114
+ I liked the Navigation so much from http://www.huddletogether.com/projects/lightbox2/
115
+ I mean let's face it, it works really well and is very easy to figure out.
116
+ -----------------------------------------------------------------------------------------------*/
117
+
118
+ #lightwindow_navigation {
119
+ /* REQUIRED */
120
+ position: absolute;
121
+ top: 0px;
122
+ left: 0px;
123
+ display: none;
124
+ /* REQUIRED */
125
+ }
126
+ /* We need to shim the navigation for IE, though its more of a sub-floor */
127
+ #lightwindow_navigation_shim {
128
+ /* REQUIRED */
129
+ display: none;
130
+ left: 0px;
131
+ position: absolute;
132
+ top: 0px;
133
+ width: 100%;
134
+ height: 100%;
135
+ /* REQUIRED */
136
+ }
137
+
138
+ #lightwindow_navigation a,
139
+ #lightwindow_navigation a:link,
140
+ #lightwindow_navigation a:visited,
141
+ #lightwindow_navigation a:hover,
142
+ #lightwindow_navigation a:active {
143
+ /* REQUIRED */
144
+ outline: none;
145
+ /* REQUIRED */
146
+ }
147
+
148
+ #lightwindow_previous,
149
+ #lightwindow_next {
150
+ width: 49%;
151
+ height: 100%;
152
+ background: transparent url(../images/blank.gif) no-repeat; /* Trick IE into showing hover */
153
+ display: block;
154
+ }
155
+
156
+ #lightwindow_previous {
157
+ float: left;
158
+ left: 0px;
159
+ }
160
+
161
+ #lightwindow_next {
162
+ float: right;
163
+ right: 0px;
164
+ }
165
+
166
+ #lightwindow_previous:hover,
167
+ #lightwindow_previous:active {
168
+ background: url(../images/prevlabel.gif) left 15% no-repeat;
169
+ }
170
+
171
+ #lightwindow_next:hover,
172
+ #lightwindow_next:active {
173
+ background: url(../images/nextlabel.gif) right 15% no-repeat;
174
+ }
175
+
176
+ #lightwindow_previous_title,
177
+ #lightwindow_next_title {
178
+ display: none;
179
+ }
180
+
181
+ #lightwindow_galleries {
182
+ width: 100%;
183
+ position: absolute;
184
+ z-index: 50;
185
+ display: none;
186
+ overflow: hidden;
187
+ margin: 0 0 0 10px;
188
+ bottom: 0px;
189
+ left: 0px;
190
+ }
191
+
192
+ #lightwindow_galleries_tab_container {
193
+ width: 100%;
194
+ height: 0px;
195
+ overflow: hidden;
196
+ }
197
+
198
+ a#lightwindow_galleries_tab,
199
+ a:link#lightwindow_galleries_tab,
200
+ a:visited#lightwindow_galleries_tab {
201
+ display: block;
202
+ height: 20px;
203
+ width: 77px;
204
+ float: right;
205
+ line-height: 22px;
206
+ color: #ffffff;
207
+ text-decoration: none;
208
+ font-weight: bold;
209
+ cursor: pointer;
210
+ font-size: 11px;
211
+ color: #ffffbe;
212
+ background: url() repeat 0 0 transparent;
213
+ /*background: url(../images/black-70.png) repeat 0 0 transparent; */
214
+ }
215
+
216
+ * html a#lightwindow_galleries_tab,
217
+ * html a:link#lightwindow_galleries_tab,
218
+ * html a:visited#lightwindow_galleries_tab {
219
+ background: none;
220
+ background-color: #000000;
221
+ opacity: .70;
222
+ filter: alpha(opacity=70);
223
+ }
224
+
225
+ a:hover#lightwindow_galleries_tab,
226
+ a:active#lightwindow_galleries_tab {
227
+ color: #ffffbe;
228
+
229
+ }
230
+
231
+ #lightwindow_galleries_tab_span {
232
+ display: block;
233
+ height: 20px;
234
+ width: 63px;
235
+ padding: 0 7px 0 7px;
236
+ }
237
+
238
+ #lightwindow_galleries_tab .up {
239
+ background: url(../images/arrow-up.gif) no-repeat 60px 5px transparent;
240
+ }
241
+
242
+ #lightwindow_galleries_tab .down {
243
+ background: url(../images/arrow-down.gif) no-repeat 60px 6px transparent;
244
+ }
245
+
246
+ #lightwindow_galleries_list {
247
+ /*background: url(../images/black-70.png) repeat 0 0 transparent;*/
248
+ background: url() repeat 0 0 transparent;
249
+ overflow: hidden;
250
+ height: 0px;
251
+ }
252
+
253
+ * html #lightwindow_galleries_list {
254
+ background: none;
255
+ background-color: #000000;
256
+ opacity: .70;
257
+ filter: alpha(opacity=70);
258
+ }
259
+
260
+ .lightwindow_galleries_list {
261
+ width: 200px;
262
+ float: left;
263
+ margin: 0 0 10px 0;
264
+ padding: 10px;
265
+ }
266
+
267
+ .lightwindow_galleries_list h1 {
268
+ color: #09F;
269
+ text-decoration: none;
270
+ font-weight: bold;
271
+ cursor: pointer;
272
+ padding: 10px 0 5px 0;
273
+ font-size: 16px;
274
+ }
275
+
276
+ .lightwindow_galleries_list li {
277
+ margin: 5px 0 5px 0;
278
+ list-style-type: none;
279
+ }
280
+
281
+ .lightwindow_galleries_list a,
282
+ .lightwindow_galleries_list a:link,
283
+ .lightwindow_galleries_list a:visited {
284
+ display: block;
285
+ line-height: 22px;
286
+ color: #ffffff;
287
+ text-decoration: none;
288
+ font-weight: bold;
289
+ cursor: pointer;
290
+ padding: 0 0 0 10px;
291
+ font-size: 11px;
292
+ }
293
+
294
+ .lightwindow_galleries_list a:hover,
295
+ .lightwindow_galleries_list a:active {
296
+ background: #000000;
297
+ color: #ffffbe;
298
+ border-left: 3px solid #ffffbe;
299
+ padding: 0 0 0 7px;
300
+ }
301
+
302
+ #lightwindow_data {
303
+ /* REQUIRED */
304
+ position: absolute;
305
+ /* REQUIRED */
306
+ }
307
+
308
+ #lightwindow_data_slide {
309
+ /* REQUIRED */
310
+ position: relative;
311
+ /* REQUIRED */
312
+ }
313
+
314
+ #lightwindow_data_slide_inner {
315
+ background-color: #ffffff;
316
+ padding: 0 10px 10px 10px;
317
+ }
318
+
319
+ #lightwindow_data_caption {
320
+ padding: 10px 0 0 0;
321
+ color: #666666;
322
+ line-height: 25px;
323
+ background-color: #ffffff;
324
+ clear: both;
325
+ }
326
+
327
+ #lightwindow_data_details {
328
+ background-color: #f0f0f0;
329
+ padding: 0 10px 0 10px;
330
+ height: 20px;
331
+ }
332
+
333
+ #lightwindow_data_author_container {
334
+ width: 40%;
335
+ text-align: right;
336
+ color: #666666;
337
+ font-style: italic;
338
+ font-size: 10px;
339
+ line-height: 20px;
340
+ float: right;
341
+ overflow: hidden;
342
+ }
343
+
344
+ #lightwindow_data_gallery_container {
345
+ font-size: 10px;
346
+ width: 40%;
347
+ text-align: left;
348
+ color: #666666;
349
+ line-height: 20px;
350
+ float: left;
351
+ overflow: hidden;
352
+ }
353
+
354
+ #lightwindow_title_bar {
355
+ height: 25px;
356
+ overflow: hidden;
357
+ }
358
+
359
+ #lightwindow_title_bar_title {
360
+ color: #ffffbe;
361
+ font-size: 14px;
362
+ line-height: 25px;
363
+ text-align: left;
364
+ float: left;
365
+ }
366
+
367
+ a#lightwindow_title_bar_close_link,
368
+ a:link#lightwindow_title_bar_close_link,
369
+ a:visited#lightwindow_title_bar_close_link {
370
+ float: right;
371
+ text-align: right;
372
+ cursor: pointer;
373
+ color: #ffffbe;
374
+ line-height: 25px;
375
+ padding: 0;
376
+ margin: 0;
377
+ }
378
+
379
+ a:hover#lightwindow_title_bar_close_link,
380
+ a:active#lightwindow_title_bar_close_link {
381
+ color: #ffffff;
382
+ }
383
+
384
+ /*-----------------------------------------------------------------------------------------------
385
+ Theme styling stuff
386
+ -----------------------------------------------------------------------------------------------*/
387
+
388
+ #lightwindow p {
389
+ color: #000000;
390
+ padding-right: 10px;
391
+ }
392
+
393
+
skin/frontend/base/default/js/kash/lightwindow.js ADDED
@@ -0,0 +1,1918 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ // lightwindow.js v2.0
2
+ //
3
+ // Copyright (c) 2007 stickmanlabs
4
+ // Author: Kevin P Miller | http://www.stickmanlabs.com
5
+ //
6
+ // LightWindow is freely distributable under the terms of an MIT-style license.
7
+ //
8
+ // I don't care what you think about the file size...
9
+ // Be a pro:
10
+ // http://www.thinkvitamin.com/features/webapps/serving-javascript-fast
11
+ // http://rakaz.nl/item/make_your_pages_load_faster_by_combining_and_compressing_javascript_and_css_files
12
+ //
13
+
14
+ /*-----------------------------------------------------------------------------------------------*/
15
+
16
+ if(typeof Effect == 'undefined')
17
+ throw("lightwindow.js requires including script.aculo.us' effects.js library!");
18
+
19
+ // This will stop image flickering in IE6 when elements with images are moved
20
+ try {
21
+ document.execCommand("BackgroundImageCache", false, true);
22
+ } catch(e) {}
23
+
24
+ var lightwindow = Class.create();
25
+ lightwindow.prototype = {
26
+ //
27
+ // Setup Variables
28
+ //
29
+ element : null,
30
+ contentToFetch : null,
31
+ windowActive : false,
32
+ dataEffects : [],
33
+ dimensions : {
34
+ cruft : null,
35
+ container : null,
36
+ viewport : {
37
+ height : null,
38
+ width : null,
39
+ offsetTop : null,
40
+ offsetLeft : null
41
+ }
42
+ },
43
+ pagePosition : {
44
+ x : 0,
45
+ y : 0
46
+ },
47
+ pageDimensions : {
48
+ width : null,
49
+ height : null
50
+ },
51
+ preloadImage : [],
52
+ preloadedImage : [],
53
+ galleries : [],
54
+ resizeTo : {
55
+ height : null,
56
+ heightPercent : null,
57
+ width : null,
58
+ widthPercent : null,
59
+ fixedTop : null,
60
+ fixedLeft : null
61
+ },
62
+ scrollbarOffset : 18,
63
+ navigationObservers : {
64
+ previous : null,
65
+ next : null
66
+ },
67
+ containerChange : {
68
+ height : 0,
69
+ width : 0
70
+ },
71
+ activeGallery : false,
72
+ galleryLocation : {
73
+ current : 0,
74
+ total : 0
75
+ },
76
+ //
77
+ // Initialize the lightwindow.
78
+ //
79
+ initialize : function(options) {
80
+ this.options = Object.extend({
81
+ resizeSpeed : 8,
82
+ contentOffset : {
83
+ height : 20,
84
+ width : 20
85
+ },
86
+ dimensions : {
87
+ image : {height : 250, width : 250},
88
+ page : {height : 250, width : 250},
89
+ inline : {height : 250, width : 250},
90
+ media : {height : 250, width : 250},
91
+ external : {height : 250, width : 250},
92
+ titleHeight : 25
93
+ },
94
+ classNames : {
95
+ standard : 'lightwindow',
96
+ action : 'lightwindow_action'
97
+ },
98
+ fileTypes : {
99
+ page : ['asp', 'aspx', 'cgi', 'cfm', 'htm', 'html', 'pl', 'php4', 'php3', 'php', 'php5', 'phtml', 'rhtml', 'shtml', 'txt', 'vbs', 'rb'],
100
+ media : ['aif', 'aiff', 'asf', 'avi', 'divx', 'm1v', 'm2a', 'm2v', 'm3u', 'mid', 'midi', 'mov', 'moov', 'movie', 'mp2', 'mp3', 'mpa', 'mpa', 'mpe', 'mpeg', 'mpg', 'mpg', 'mpga', 'pps', 'qt', 'rm', 'ram', 'swf', 'viv', 'vivo', 'wav'],
101
+ image : ['bmp', 'gif', 'jpg', 'png', 'tiff']
102
+ },
103
+ mimeTypes : {
104
+ avi : 'video/avi',
105
+ aif : 'audio/aiff',
106
+ aiff : 'audio/aiff',
107
+ gif : 'image/gif',
108
+ bmp : 'image/bmp',
109
+ jpeg : 'image/jpeg',
110
+ m1v : 'video/mpeg',
111
+ m2a : 'audio/mpeg',
112
+ m2v : 'video/mpeg',
113
+ m3u : 'audio/x-mpequrl',
114
+ mid : 'audio/x-midi',
115
+ midi : 'audio/x-midi',
116
+ mjpg : 'video/x-motion-jpeg',
117
+ moov : 'video/quicktime',
118
+ mov : 'video/quicktime',
119
+ movie : 'video/x-sgi-movie',
120
+ mp2 : 'audio/mpeg',
121
+ mp3 : 'audio/mpeg3',
122
+ mpa : 'audio/mpeg',
123
+ mpa : 'video/mpeg',
124
+ mpe : 'video/mpeg',
125
+ mpeg : 'video/mpeg',
126
+ mpg : 'audio/mpeg',
127
+ mpg : 'video/mpeg',
128
+ mpga : 'audio/mpeg',
129
+ pdf : 'application/pdf',
130
+ png : 'image/png',
131
+ pps : 'application/mspowerpoint',
132
+ qt : 'video/quicktime',
133
+ ram : 'audio/x-pn-realaudio-plugin',
134
+ rm : 'application/vnd.rn-realmedia',
135
+ swf : 'application/x-shockwave-flash',
136
+ tiff : 'image/tiff',
137
+ viv : 'video/vivo',
138
+ vivo : 'video/vivo',
139
+ wav : 'audio/wav',
140
+ wmv : 'application/x-mplayer2'
141
+ },
142
+ classids : {
143
+ mov : 'clsid:02BF25D5-8C17-4B23-BC80-D3488ABDDC6B',
144
+ swf : 'clsid:D27CDB6E-AE6D-11cf-96B8-444553540000',
145
+ wmv : 'clsid:6BF52A52-394A-11d3-B153-00C04F79FAA6'
146
+ },
147
+ codebases : {
148
+ mov : 'http://www.apple.com/qtactivex/qtplugin.cab#version=6,0,2,0',
149
+ swf : 'http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,0,0',
150
+ wmv : 'http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=6,4,5,715'
151
+ },
152
+ viewportPadding : 10,
153
+ EOLASFix : 'swf,wmv,fla,flv',
154
+ overlay : {
155
+ opacity : 0.7,
156
+ image : '',
157
+ presetImage : ''
158
+ },
159
+ skin : {
160
+ main : '<div id="lightwindow_container" >'+
161
+ '<div id="lightwindow_title_bar" >'+
162
+ '<div id="lightwindow_title_bar_inner" >'+
163
+ '<span id="lightwindow_title_bar_title"></span>'+
164
+ '<a id="lightwindow_title_bar_close_link" >close</a>'+
165
+ '</div>'+
166
+ '</div>'+
167
+ '<div id="lightwindow_stage" >'+
168
+ '<div id="lightwindow_contents" >'+
169
+ '</div>'+
170
+ '<div id="lightwindow_navigation" >'+
171
+ '<a href="#" id="lightwindow_previous" >'+
172
+ '<span id="lightwindow_previous_title"></span>'+
173
+ '</a>'+
174
+ '<a href="#" id="lightwindow_next" >'+
175
+ '<span id="lightwindow_next_title"></span>'+
176
+ '</a>'+
177
+ '<iframe name="lightwindow_navigation_shim" id="lightwindow_navigation_shim" src="javascript:false;" frameBorder="0" scrolling="no"></iframe>'+
178
+ '</div>'+
179
+ '<div id="lightwindow_galleries">'+
180
+ '<div id="lightwindow_galleries_tab_container" >'+
181
+ '<a href="#" id="lightwindow_galleries_tab" >'+
182
+ '<span id="lightwindow_galleries_tab_span" class="up" >Galleries</span>'+
183
+ '</a>'+
184
+ '</div>'+
185
+ '<div id="lightwindow_galleries_list" >'+
186
+ '</div>'+
187
+ '</div>'+
188
+ '</div>'+
189
+ '<div id="lightwindow_data_slide" >'+
190
+ '<div id="lightwindow_data_slide_inner" >'+
191
+ '<div id="lightwindow_data_details" >'+
192
+ '<div id="lightwindow_data_gallery_container" >'+
193
+ '<span id="lightwindow_data_gallery_current"></span>'+
194
+ ' of '+
195
+ '<span id="lightwindow_data_gallery_total"></span>'+
196
+ '</div>'+
197
+ '<div id="lightwindow_data_author_container" >'+
198
+ 'by <span id="lightwindow_data_author"></span>'+
199
+ '</div>'+
200
+ '</div>'+
201
+ '<div id="lightwindow_data_caption" >'+
202
+ '</div>'+
203
+ '</div>'+
204
+ '</div>'+
205
+ '</div>',
206
+ loading : '<div id="lightwindow_loading" >'+
207
+ '<img src="" alt="loading" />'+
208
+ '<span>Loading or <a href="javascript: myLightWindow.deactivate();">Cancel</a></span>'+
209
+ '<iframe name="lightwindow_loading_shim" id="lightwindow_loading_shim" src="javascript:false;" frameBorder="0" scrolling="no"></iframe>'+
210
+ '</div>',
211
+ iframe : '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">'+
212
+ '<html xmlns="http://www.w3.org/1999/xhtml">'+
213
+ '<body>'+
214
+ '{body_replace}'+
215
+ '</body>'+
216
+ '</html>',
217
+ gallery : {
218
+ top : '<div class="lightwindow_galleries_list">'+
219
+ '<h1>{gallery_title_replace}</h1>'+
220
+ '<ul>',
221
+ middle : '<li>'+
222
+ '{gallery_link_replace}'+
223
+ '</li>',
224
+ bottom : '</ul>'+
225
+ '</div>'
226
+ }
227
+ },
228
+ formMethod : 'get',
229
+ hideFlash : false,
230
+ hideGalleryTab : false,
231
+ showTitleBar : true,
232
+ animationHandler : false,
233
+ navigationHandler : false,
234
+ transitionHandler : false,
235
+ finalAnimationHandler : false,
236
+ formHandler : false,
237
+ galleryAnimationHandler : false,
238
+ showGalleryCount : true
239
+ }, options || {});
240
+ this.duration = ((11-this.options.resizeSpeed)*0.15);
241
+ this._setupLinks();
242
+ this._getScroll();
243
+ this._getPageDimensions();
244
+ this._browserDimensions();
245
+ this._addLightWindowMarkup(false);
246
+ this._setupDimensions();
247
+ this.buildGalleryList();
248
+ },
249
+ //
250
+ // Activate the lightwindow.
251
+ //
252
+ activate : function(e, link){
253
+ // Clear out the window Contents
254
+ this._clearWindowContents(true);
255
+
256
+ // Add back in out loading panel
257
+ this._addLoadingWindowMarkup();
258
+
259
+ // Setup the element properties
260
+ this._setupWindowElements(link);
261
+
262
+ // Setup everything
263
+ this._getScroll();
264
+ this._browserDimensions();
265
+ this._setupDimensions();
266
+ this._toggleTroubleElements('hidden', false);
267
+ this._displayLightWindow('block', 'hidden');
268
+ this._setStatus(true);
269
+ this._monitorKeyboard(true);
270
+ this._prepareIE(true);
271
+ this._loadWindow();
272
+ },
273
+ //
274
+ // Turn off the window
275
+ //
276
+ deactivate : function(){
277
+ // The window is not active
278
+ this.windowActive = false;
279
+
280
+ // There is no longer a gallery active
281
+ this.activeGallery = false;
282
+ if (!this.options.hideGalleryTab) {
283
+ this._handleGalleryAnimation(false);
284
+ }
285
+
286
+ // Kill the animation
287
+ this.animating = false;
288
+
289
+ // Clear our element
290
+ this.element = null;
291
+
292
+ // hide the window.
293
+ this._displayLightWindow('none', 'visible');
294
+
295
+ // Clear out the window Contents
296
+ this._clearWindowContents(false);
297
+
298
+ // Stop all animation
299
+ var queue = Effect.Queues.get('lightwindowAnimation').each(function(e){e.cancel();});
300
+
301
+ // Undo the setup
302
+ this._prepareIE(false);
303
+ this._setupDimensions();
304
+ this._toggleTroubleElements('visible', false);
305
+ this._monitorKeyboard(false);
306
+ },
307
+ //
308
+ // Initialize specific window
309
+ //
310
+ createWindow : function(element, attributes) {
311
+ this._processLink($(element));
312
+ },
313
+ //
314
+ // Open a Window from a hash of attributes
315
+ //
316
+ activateWindow : function(options) {
317
+ this.element = Object.extend({
318
+ href : null,
319
+ title : null,
320
+ author : null,
321
+ caption : null,
322
+ rel : null,
323
+ top : null,
324
+ left : null,
325
+ type : null,
326
+ showImages : null,
327
+ height : null,
328
+ width : null,
329
+ loadingAnimation : null,
330
+ iframeEmbed : null,
331
+ form : null
332
+ }, options || {});
333
+
334
+ // Set the window type
335
+ this.contentToFetch = this.element.href;
336
+ this.windowType = this.element.type ? this.element.type : this._fileType(this.element.href);
337
+
338
+ // Clear out the window Contents
339
+ this._clearWindowContents(true);
340
+
341
+ // Add back in out loading panel
342
+ this._addLoadingWindowMarkup();
343
+
344
+ // Setup everything
345
+ this._getScroll();
346
+ this._browserDimensions();
347
+ this._setupDimensions();
348
+ this._toggleTroubleElements('hidden', false);
349
+ this._displayLightWindow('block', 'hidden');
350
+ this._setStatus(true);
351
+ this._monitorKeyboard(true);
352
+ this._prepareIE(true);
353
+ this._loadWindow();
354
+ },
355
+ //
356
+ // Fire off our Form handler
357
+ //
358
+ submitForm : function(e) {
359
+ if (this.options.formHandler) {
360
+ this.options.formHandler(e);
361
+ } else {
362
+ this._defaultFormHandler(e);
363
+ }
364
+ },
365
+ //
366
+ // Reload the window with another location
367
+ //
368
+ openWindow : function(element) {
369
+ var element = $(element);
370
+
371
+ // The window is active
372
+ this.windowActive = true;
373
+
374
+ // Clear out the window Contents
375
+ this._clearWindowContents(true);
376
+
377
+ // Add back in out loading panel
378
+ this._addLoadingWindowMarkup();
379
+
380
+ // Setup the element properties
381
+ this._setupWindowElements(element);
382
+
383
+ this._setStatus(true);
384
+ this._handleTransition();
385
+ },
386
+ //
387
+ // Navigate the window
388
+ //
389
+ navigateWindow : function(direction) {
390
+ this._handleNavigation(false);
391
+ if (direction == 'previous') {
392
+ this.openWindow(this.navigationObservers.previous);
393
+ } else if (direction == 'next'){
394
+ this.openWindow(this.navigationObservers.next);
395
+ }
396
+ },
397
+ //
398
+ // Build the Gallery List and Load it
399
+ //
400
+ buildGalleryList : function() {
401
+ var output = '';
402
+ var galleryLink;
403
+ for (i in this.galleries) {
404
+ if (typeof this.galleries[i] == 'object') {
405
+ output += (this.options.skin.gallery.top).replace('{gallery_title_replace}', unescape(i));
406
+ for (j in this.galleries[i]) {
407
+ if (typeof this.galleries[i][j] == 'object') {
408
+ galleryLink = '<a href="#" id="lightwindow_gallery_'+i+'_'+j+'" >'+unescape(j)+'</a>';
409
+ output += (this.options.skin.gallery.middle).replace('{gallery_link_replace}', galleryLink);
410
+ }
411
+ }
412
+ output += this.options.skin.gallery.bottom;
413
+ }
414
+ }
415
+ new Insertion.Top('lightwindow_galleries_list', output);
416
+
417
+ // Attach Events
418
+ for (i in this.galleries) {
419
+ if (typeof this.galleries[i] == 'object') {
420
+ for (j in this.galleries[i]) {
421
+ if (typeof this.galleries[i][j] == 'object') {
422
+ Event.observe($('lightwindow_gallery_'+i+'_'+j), 'click', this.openWindow.bind(this, this.galleries[i][j][0]), false);
423
+ $('lightwindow_gallery_'+i+'_'+j).onclick = function() {return false;};
424
+ }
425
+ }
426
+ }
427
+ }
428
+ },
429
+ //
430
+ // Set Links Up
431
+ //
432
+ _setupLinks : function() {
433
+ var links = $$('.'+this.options.classNames.standard);
434
+ links.each(function(link) {
435
+ this._processLink(link);
436
+ }.bind(this));
437
+ },
438
+ //
439
+ // Process a Link
440
+ //
441
+ _processLink : function(link) {
442
+ if ((this._fileType(link.getAttribute('href')) == 'image' || this._fileType(link.getAttribute('href')) == 'media')) {
443
+ if (gallery = this._getGalleryInfo(link.rel)) {
444
+ if (!this.galleries[gallery[0]]) {
445
+ this.galleries[gallery[0]] = new Array();
446
+ }
447
+ if (!this.galleries[gallery[0]][gallery[1]]) {
448
+ this.galleries[gallery[0]][gallery[1]] = new Array();
449
+ }
450
+ this.galleries[gallery[0]][gallery[1]].push(link);
451
+ }
452
+ }
453
+
454
+ // Take care of our inline content
455
+ var url = link.getAttribute('href');
456
+ if (url.indexOf('?') > -1) {
457
+ url = url.substring(0, url.indexOf('?'));
458
+ }
459
+
460
+ var container = url.substring(url.indexOf('#')+1);
461
+ if($(container)) {
462
+ $(container).setStyle({
463
+ display : 'none'
464
+ });
465
+ }
466
+
467
+ Event.observe(link, 'click', this.activate.bindAsEventListener(this, link), false);
468
+ link.onclick = function() {return false;};
469
+ },
470
+ //
471
+ // Setup our actions
472
+ //
473
+ _setupActions : function() {
474
+ var links = $$('#lightwindow_container .'+this.options.classNames.action);
475
+ links.each(function(link) {
476
+ Event.observe(link, 'click', this[link.getAttribute('rel')].bindAsEventListener(this, link), false);
477
+ link.onclick = function() {return false;};
478
+ }.bind(this));
479
+ },
480
+ //
481
+ // Add the markup to the page.
482
+ //
483
+ _addLightWindowMarkup : function(rebuild) {
484
+ var overlay = Element.extend(document.createElement('div'));
485
+ overlay.setAttribute('id', 'lightwindow_overlay');
486
+ // FF Mac has a problem with putting Flash above a layer without a 100% opacity background, so we need to use a pre-made
487
+ if (Prototype.Browser.Gecko) {
488
+ overlay.setStyle({
489
+ backgroundImage: 'url('+this.options.overlay.presetImage+')',
490
+ backgroundRepeat: 'repeat',
491
+ height: this.pageDimensions.height+'px'
492
+ });
493
+ } else {
494
+ overlay.setStyle({
495
+ opacity: this.options.overlay.opacity,
496
+ backgroundImage: 'url('+this.options.overlay.image+')',
497
+ backgroundRepeat: 'repeat',
498
+ height: this.pageDimensions.height+'px'
499
+ });
500
+ }
501
+
502
+ var lw = document.createElement('div');
503
+ lw.setAttribute('id', 'lightwindow');
504
+ lw.innerHTML = this.options.skin.main;
505
+
506
+ var body = document.getElementsByTagName('body')[0];
507
+ body.appendChild(overlay);
508
+ body.appendChild(lw);
509
+
510
+ if ($('lightwindow_title_bar_close_link')) {
511
+ Event.observe('lightwindow_title_bar_close_link', 'click', this.deactivate.bindAsEventListener(this));
512
+ $('lightwindow_title_bar_close_link').onclick = function() {return false;};
513
+ }
514
+
515
+ Event.observe($('lightwindow_previous'), 'click', this.navigateWindow.bind(this, 'previous'), false);
516
+ $('lightwindow_previous').onclick = function() {return false;};
517
+ Event.observe($('lightwindow_next'), 'click', this.navigateWindow.bind(this, 'next'), false);
518
+ $('lightwindow_next').onclick = function() {return false;};
519
+
520
+ if (!this.options.hideGalleryTab) {
521
+ Event.observe($('lightwindow_galleries_tab'), 'click', this._handleGalleryAnimation.bind(this, true), false);
522
+ $('lightwindow_galleries_tab').onclick = function() {return false;};
523
+ }
524
+
525
+ // Because we use position absolute, kill the scroll Wheel on animations
526
+ if (Prototype.Browser.IE) {
527
+ Event.observe(document, 'mousewheel', this._stopScrolling.bindAsEventListener(this), false);
528
+ } else {
529
+ Event.observe(window, 'DOMMouseScroll', this._stopScrolling.bindAsEventListener(this), false);
530
+ }
531
+
532
+ Event.observe(overlay, 'click', this.deactivate.bindAsEventListener(this), false);
533
+ overlay.onclick = function() {return false;};
534
+ },
535
+ //
536
+ // Add loading window markup
537
+ //
538
+ _addLoadingWindowMarkup : function() {
539
+ $('lightwindow_contents').innerHTML += this.options.skin.loading;
540
+ },
541
+ //
542
+ // Setup the window elements
543
+ //
544
+ _setupWindowElements : function(link) {
545
+ this.element = link;
546
+ this.element.title = null ? '' : link.getAttribute('title');
547
+ this.element.author = null ? '' : link.getAttribute('author');
548
+ this.element.caption = null ? '' : link.getAttribute('caption');
549
+ this.element.rel = null ? '' : link.getAttribute('rel');
550
+ this.element.params = null ? '' : link.getAttribute('params');
551
+
552
+ // Set the window type
553
+ this.contentToFetch = this.element.href;
554
+ this.windowType = this._getParameter('lightwindow_type') ? this._getParameter('lightwindow_type') : this._fileType(this.contentToFetch);
555
+ },
556
+ //
557
+ // Clear the window contents out
558
+ //
559
+ _clearWindowContents : function(contents) {
560
+ // If there is an iframe, its got to go
561
+ if ($('lightwindow_iframe')) {
562
+ Element.remove($('lightwindow_iframe'));
563
+ }
564
+
565
+ // Stop playing an object if its still around
566
+ if ($('lightwindow_media_primary')) {
567
+ try {
568
+ $('lightwindow_media_primary').Stop();
569
+ } catch(e) {}
570
+ Element.remove($('lightwindow_media_primary'));
571
+ }
572
+
573
+ // Stop playing an object if its still around
574
+ if ($('lightwindow_media_secondary')) {
575
+ try {
576
+ $('lightwindow_media_secondary').Stop();
577
+ } catch(e) {}
578
+ Element.remove($('lightwindow_media_secondary'));
579
+ }
580
+
581
+ this.activeGallery = false;
582
+ this._handleNavigation(this.activeGallery);
583
+
584
+ if (contents) {
585
+ // Empty the contents
586
+ $('lightwindow_contents').innerHTML = '';
587
+
588
+ // Reset the scroll bars
589
+ $('lightwindow_contents').setStyle({
590
+ overflow: 'hidden'
591
+ });
592
+
593
+ if (!this.windowActive) {
594
+ $('lightwindow_data_slide_inner').setStyle({
595
+ display: 'none'
596
+ });
597
+
598
+ $('lightwindow_title_bar_title').innerHTML = '';
599
+ }
600
+
601
+ // Because of browser differences and to maintain flexible captions we need to reset this height at close
602
+ $('lightwindow_data_slide').setStyle({
603
+ height: 'auto'
604
+ });
605
+ }
606
+
607
+ this.resizeTo.height = null;
608
+ this.resizeTo.width = null;
609
+ },
610
+ //
611
+ // Set the status of our animation to keep things from getting clunky
612
+ //
613
+ _setStatus : function(status) {
614
+ this.animating = status;
615
+ if (status) {
616
+ Element.show('lightwindow_loading');
617
+ }
618
+ if (!(/MSIE 6./i.test(navigator.userAgent))) {
619
+ this._fixedWindow(status);
620
+ }
621
+ },
622
+ //
623
+ // Make this window Fixed
624
+ //
625
+ _fixedWindow : function(status) {
626
+ if (status) {
627
+ if (this.windowActive) {
628
+ this._getScroll();
629
+ $('lightwindow').setStyle({
630
+ position: 'absolute',
631
+ top: parseFloat($('lightwindow').getStyle('top'))+this.pagePosition.y+'px',
632
+ left: parseFloat($('lightwindow').getStyle('left'))+this.pagePosition.x+'px'
633
+ });
634
+ } else {
635
+ $('lightwindow').setStyle({
636
+ position: 'absolute'
637
+ });
638
+ }
639
+ } else {
640
+ if (this.windowActive) {
641
+ this._getScroll();
642
+ $('lightwindow').setStyle({
643
+ position: 'fixed',
644
+ top: parseFloat($('lightwindow').getStyle('top'))-this.pagePosition.y+'px',
645
+ left: parseFloat($('lightwindow').getStyle('left'))-this.pagePosition.x+'px'
646
+ });
647
+ } else {
648
+ if ($('lightwindow_iframe')) {
649
+ // Ideally here we would set a 50% value for top and left, but Safari rears it ugly head again and we need to do it by pixels
650
+ this._browserDimensions();
651
+ }
652
+ $('lightwindow').setStyle({
653
+ position: 'fixed',
654
+ top: (parseFloat(this._getParameter('lightwindow_top')) ? parseFloat(this._getParameter('lightwindow_top'))+'px' : this.dimensions.viewport.height/2+'px'),
655
+ left: (parseFloat(this._getParameter('lightwindow_left')) ? parseFloat(this._getParameter('lightwindow_left'))+'px' : this.dimensions.viewport.width/2+'px')
656
+ });
657
+ }
658
+ }
659
+ },
660
+ //
661
+ // Prepare the window for IE.
662
+ //
663
+ _prepareIE : function(setup) {
664
+ if (Prototype.Browser.IE) {
665
+ var height, overflowX, overflowY;
666
+ if (setup) {
667
+ var height = '100%';
668
+ } else {
669
+ var height = 'auto';
670
+ }
671
+ var body = document.getElementsByTagName('body')[0];
672
+ var html = document.getElementsByTagName('html')[0];
673
+ html.style.height = body.style.height = height;
674
+ }
675
+ },
676
+ _stopScrolling : function(e) {
677
+ if (this.animating) {
678
+ if (e.preventDefault) {
679
+ e.preventDefault();
680
+ }
681
+ e.returnValue = false;
682
+ }
683
+ },
684
+ //
685
+ // Get the scroll for the page.
686
+ //
687
+ _getScroll : function(){
688
+ if(typeof(window.pageYOffset) == 'number') {
689
+ this.pagePosition.x = window.pageXOffset;
690
+ this.pagePosition.y = window.pageYOffset;
691
+ } else if(document.body && (document.body.scrollLeft || document.body.scrollTop)) {
692
+ this.pagePosition.x = document.body.scrollLeft;
693
+ this.pagePosition.y = document.body.scrollTop;
694
+ } else if(document.documentElement) {
695
+ this.pagePosition.x = document.documentElement.scrollLeft;
696
+ this.pagePosition.y = document.documentElement.scrollTop;
697
+ }
698
+ },
699
+ //
700
+ // Reset the scroll.
701
+ //
702
+ _setScroll : function(x, y) {
703
+ document.documentElement.scrollLeft = x;
704
+ document.documentElement.scrollTop = y;
705
+ },
706
+ //
707
+ // Hide Selects from the page because of IE.
708
+ // We could use iframe shims instead here but why add all the extra markup for one browser when this is much easier and cleaner
709
+ //
710
+ _toggleTroubleElements : function(visibility, content){
711
+
712
+ if (content) {
713
+ var selects = $('lightwindow_contents').getElementsByTagName('select');
714
+ } else {
715
+ var selects = document.getElementsByTagName('select');
716
+ }
717
+
718
+ for(var i = 0; i < selects.length; i++) {
719
+ selects[i].style.visibility = visibility;
720
+ }
721
+
722
+ if (!content) {
723
+ if (this.options.hideFlash){
724
+ var objects = document.getElementsByTagName('object');
725
+ for (i = 0; i != objects.length; i++) {
726
+ objects[i].style.visibility = visibility;
727
+ }
728
+ var embeds = document.getElementsByTagName('embed');
729
+ for (i = 0; i != embeds.length; i++) {
730
+ embeds[i].style.visibility = visibility;
731
+ }
732
+ }
733
+ var iframes = document.getElementsByTagName('iframe');
734
+ for (i = 0; i != iframes.length; i++) {
735
+ iframes[i].style.visibility = visibility;
736
+ }
737
+ }
738
+ },
739
+ //
740
+ // Get the actual page size
741
+ //
742
+ _getPageDimensions : function() {
743
+ var xScroll, yScroll;
744
+ if (window.innerHeight && window.scrollMaxY) {
745
+ xScroll = document.body.scrollWidth;
746
+ yScroll = window.innerHeight + window.scrollMaxY;
747
+ } else if (document.body.scrollHeight > document.body.offsetHeight){
748
+ xScroll = document.body.scrollWidth;
749
+ yScroll = document.body.scrollHeight;
750
+ } else {
751
+ xScroll = document.body.offsetWidth;
752
+ yScroll = document.body.offsetHeight;
753
+ }
754
+
755
+ var windowWidth, windowHeight;
756
+ if (self.innerHeight) {
757
+ windowWidth = self.innerWidth;
758
+ windowHeight = self.innerHeight;
759
+ } else if (document.documentElement && document.documentElement.clientHeight) {
760
+ windowWidth = document.documentElement.clientWidth;
761
+ windowHeight = document.documentElement.clientHeight;
762
+ } else if (document.body) {
763
+ windowWidth = document.body.clientWidth;
764
+ windowHeight = document.body.clientHeight;
765
+ }
766
+
767
+ if(yScroll < windowHeight){
768
+ this.pageDimensions.height = windowHeight;
769
+ } else {
770
+ this.pageDimensions.height = yScroll;
771
+ }
772
+
773
+ if(xScroll < windowWidth){
774
+ this.pageDimensions.width = windowWidth;
775
+ } else {
776
+ this.pageDimensions.width = xScroll;
777
+ }
778
+ },
779
+ //
780
+ // Display the lightWindow.
781
+ //
782
+ _displayLightWindow : function(display, visibility) {
783
+ $('lightwindow_overlay').style.display = $('lightwindow').style.display = $('lightwindow_container').style.display = display;
784
+ $('lightwindow_overlay').style.visibility = $('lightwindow').style.visibility = $('lightwindow_container').style.visibility = visibility;
785
+ },
786
+ //
787
+ // Setup Dimensions of lightwindow.
788
+
789
+ //
790
+ _setupDimensions : function() {
791
+
792
+ var originalHeight, originalWidth;
793
+ switch (this.windowType) {
794
+ case 'page' :
795
+ originalHeight = this.options.dimensions.page.height;
796
+ originalWidth = this.options.dimensions.page.width;
797
+ break;
798
+
799
+ case 'image' :
800
+ originalHeight = this.options.dimensions.image.height;
801
+ originalWidth = this.options.dimensions.image.width;
802
+ break;
803
+
804
+ case 'media' :
805
+ originalHeight = this.options.dimensions.media.height;
806
+ originalWidth = this.options.dimensions.media.width;
807
+ break;
808
+
809
+ case 'external' :
810
+ originalHeight = this.options.dimensions.external.height;
811
+ originalWidth = this.options.dimensions.external.width;
812
+ break;
813
+
814
+ case 'inline' :
815
+ originalHeight = this.options.dimensions.inline.height;
816
+ originalWidth = this.options.dimensions.inline.width;
817
+ break;
818
+
819
+ default :
820
+ originalHeight = this.options.dimensions.page.height;
821
+ originalWidth = this.options.dimensions.page.width;
822
+ break;
823
+
824
+ }
825
+
826
+ var offsetHeight = this._getParameter('lightwindow_top') ? parseFloat(this._getParameter('lightwindow_top'))+this.pagePosition.y : this.dimensions.viewport.height/2+this.pagePosition.y;
827
+ var offsetWidth = this._getParameter('lightwindow_left') ? parseFloat(this._getParameter('lightwindow_left'))+this.pagePosition.x : this.dimensions.viewport.width/2+this.pagePosition.x;
828
+
829
+ // So if a theme has say shadowed edges, they should be consistant and take care of in the contentOffset
830
+ $('lightwindow').setStyle({
831
+ top: offsetHeight+'px',
832
+ left: offsetWidth+'px'
833
+ });
834
+ $('lightwindow_container').setStyle({
835
+ height: originalHeight+'px',
836
+ width: originalWidth+'px',
837
+ left: -(originalWidth/2)+'px',
838
+ top: -(originalHeight/2)+'px'
839
+ });
840
+ $('lightwindow_contents').setStyle({
841
+ height: originalHeight+'px',
842
+ width: originalWidth+'px'
843
+ });
844
+ },
845
+ //
846
+ // Get the type of file.
847
+ //
848
+ _fileType : function(url) {
849
+ var image = new RegExp("[^\.]\.("+this.options.fileTypes.image.join('|')+")\s*$", "i");
850
+ if (image.test(url)) return 'image';
851
+ if (url.indexOf('#') > -1 && (document.domain == this._getDomain(url))) return 'inline';
852
+ if (url.indexOf('?') > -1) url = url.substring(0, url.indexOf('?'));
853
+ var type = 'unknown';
854
+ var page = new RegExp("[^\.]\.("+this.options.fileTypes.page.join('|')+")\s*$", "i");
855
+ var media = new RegExp("[^\.]\.("+this.options.fileTypes.media.join('|')+")\s*$", "i");
856
+ if (document.domain != this._getDomain(url)) type = 'external';
857
+ if (media.test(url)) type = 'media';
858
+ if (type == 'external' || type == 'media') return type;
859
+ if (page.test(url) || url.substr((url.length-1), url.length) == '/') type = 'page';
860
+ return type;
861
+ },
862
+ //
863
+ // Get file Extension
864
+ //
865
+ _fileExtension : function(url) {
866
+ if (url.indexOf('?') > -1) {
867
+ url = url.substring(0, url.indexOf('?'));
868
+ }
869
+ var extenstion = '';
870
+ for (var x = (url.length-1); x > -1; x--) {
871
+ if (url.charAt(x) == '.') {
872
+ return extenstion;
873
+ }
874
+ extenstion = url.charAt(x)+extenstion;
875
+ }
876
+ },
877
+ //
878
+ // Monitor the keyboard while this lightwindow is up
879
+ //
880
+ _monitorKeyboard : function(status) {
881
+ if (status) document.onkeydown = this._eventKeypress.bind(this);
882
+ else document.onkeydown = '';
883
+ },
884
+ //
885
+ // Perform keyboard actions
886
+ //
887
+ _eventKeypress : function(e) {
888
+ if (e == null) {
889
+ var keycode = event.keyCode;
890
+ } else {
891
+ var keycode = e.which;
892
+ }
893
+
894
+ switch (keycode) {
895
+ case 27:
896
+ this.deactivate();
897
+ break;
898
+
899
+ case 13:
900
+ return;
901
+
902
+ default:
903
+ break;
904
+ }
905
+
906
+ // Gotta stop those quick fingers
907
+ if (this.animating) {
908
+ return false;
909
+ }
910
+
911
+ switch (String.fromCharCode(keycode).toLowerCase()) {
912
+ case 'p':
913
+ if (this.navigationObservers.previous) {
914
+ this.navigateWindow('previous');
915
+ }
916
+ break;
917
+
918
+ case 'n':
919
+ if (this.navigationObservers.next) {
920
+ this.navigateWindow('next');
921
+ }
922
+ break;
923
+
924
+ default:
925
+ break;
926
+ }
927
+ },
928
+ //
929
+ // Get Gallery Information
930
+ //
931
+ _getGalleryInfo : function(rel) {
932
+ if (!rel) return false;
933
+ if (rel.indexOf('[') > -1) {
934
+ return new Array(escape(rel.substring(0, rel.indexOf('['))), escape(rel.substring(rel.indexOf('[')+1, rel.indexOf(']'))));
935
+ } else {
936
+ return false;
937
+ }
938
+ },
939
+ //
940
+ // Get the domain from a string.
941
+ //
942
+ _getDomain : function(url) {
943
+ var leadSlashes = url.indexOf('//');
944
+ var domainStart = leadSlashes+2;
945
+ var withoutResource = url.substring(domainStart, url.length);
946
+ var nextSlash = withoutResource.indexOf('/');
947
+ var domain = withoutResource.substring(0, nextSlash);
948
+ if (domain.indexOf(':') > -1){
949
+ var portColon = domain.indexOf(':');
950
+ domain = domain.substring(0, portColon);
951
+ }
952
+ return domain;
953
+ },
954
+ //
955
+ // Get the value from the params attribute string.
956
+ //
957
+ _getParameter : function(parameter, parameters) {
958
+ if (!this.element) return false;
959
+ if (parameter == 'lightwindow_top' && this.element.top) {
960
+ return unescape(this.element.top);
961
+ } else if (parameter == 'lightwindow_left' && this.element.left) {
962
+ return unescape(this.element.left);
963
+ } else if (parameter == 'lightwindow_type' && this.element.type) {
964
+ return unescape(this.element.type);
965
+ } else if (parameter == 'lightwindow_show_images' && this.element.showImages) {
966
+ return unescape(this.element.showImages);
967
+ } else if (parameter == 'lightwindow_height' && this.element.height) {
968
+ return unescape(this.element.height);
969
+ } else if (parameter == 'lightwindow_width' && this.element.width) {
970
+ return unescape(this.element.width);
971
+ } else if (parameter == 'lightwindow_loading_animation' && this.element.loadingAnimation) {
972
+ return unescape(this.element.loadingAnimation);
973
+ } else if (parameter == 'lightwindow_iframe_embed' && this.element.iframeEmbed) {
974
+ return unescape(this.element.iframeEmbed);
975
+ } else if (parameter == 'lightwindow_form' && this.element.form) {
976
+ return unescape(this.element.form);
977
+ } else {
978
+ if (!parameters) {
979
+ if (this.element.params) parameters = this.element.params;
980
+ else return;
981
+ }
982
+ var value;
983
+ var parameterArray = parameters.split(',');
984
+ var compareString = parameter+'=';
985
+ var compareLength = compareString.length;
986
+ for (var i = 0; i < parameterArray.length; i++) {
987
+ if (parameterArray[i].substr(0, compareLength) == compareString) {
988
+ var currentParameter = parameterArray[i].split('=');
989
+ value = currentParameter[1];
990
+ break;
991
+ }
992
+ }
993
+ if (!value) return false;
994
+ else return unescape(value);
995
+ }
996
+ },
997
+ //
998
+ // Get the Browser Viewport Dimensions
999
+ //
1000
+ _browserDimensions : function() {
1001
+ if (Prototype.Browser.IE) {
1002
+ this.dimensions.viewport.height = document.documentElement.clientHeight;
1003
+ this.dimensions.viewport.width = document.documentElement.clientWidth;
1004
+ } else {
1005
+ this.dimensions.viewport.height = window.innerHeight;
1006
+ this.dimensions.viewport.width = document.width || document.body.offsetWidth;
1007
+ }
1008
+ },
1009
+ //
1010
+ // Get the scrollbar offset, I don't like this method but there is really no other way I can find.
1011
+ //
1012
+ _getScrollerWidth : function() {
1013
+ var scrollDiv = Element.extend(document.createElement('div'));
1014
+ scrollDiv.setAttribute('id', 'lightwindow_scroll_div');
1015
+ scrollDiv.setStyle({
1016
+ position: 'absolute',
1017
+ top: '-10000px',
1018
+ left: '-10000px',
1019
+ width: '100px',
1020
+ height: '100px',
1021
+ overflow: 'hidden'
1022
+ });
1023
+
1024
+
1025
+
1026
+ var contentDiv = Element.extend(document.createElement('div'));
1027
+ contentDiv.setAttribute('id', 'lightwindow_content_scroll_div');
1028
+ contentDiv.setStyle({
1029
+ width: '100%',
1030
+ height: '200px'
1031
+ });
1032
+
1033
+ scrollDiv.appendChild(contentDiv);
1034
+
1035
+ var body = document.getElementsByTagName('body')[0];
1036
+ body.appendChild(scrollDiv);
1037
+
1038
+ var noScroll = $('lightwindow_content_scroll_div').offsetWidth;
1039
+ scrollDiv.style.overflow = 'auto';
1040
+ var withScroll = $('lightwindow_content_scroll_div').offsetWidth;
1041
+
1042
+ Element.remove($('lightwindow_scroll_div'));
1043
+
1044
+ this.scrollbarOffset = noScroll-withScroll;
1045
+ },
1046
+
1047
+
1048
+ //
1049
+ // Add a param to an object dynamically created
1050
+ //
1051
+ _addParamToObject : function(name, value, object, id) {
1052
+ var param = document.createElement('param');
1053
+ param.setAttribute('value', value);
1054
+ param.setAttribute('name', name);
1055
+ if (id) {
1056
+ param.setAttribute('id', id);
1057
+ }
1058
+ object.appendChild(param);
1059
+ return object;
1060
+ },
1061
+ //
1062
+ // Get the outer HTML of an object CROSS BROWSER
1063
+ //
1064
+ _outerHTML : function(object) {
1065
+ if (Prototype.Browser.IE) {
1066
+ return object.outerHTML;
1067
+ } else {
1068
+ var clone = object.cloneNode(true);
1069
+ var cloneDiv = document.createElement('div');
1070
+ cloneDiv.appendChild(clone);
1071
+ return cloneDiv.innerHTML;
1072
+ }
1073
+ },
1074
+ //
1075
+ // Convert an object to markup
1076
+ //
1077
+ _convertToMarkup : function(object, closeTag) {
1078
+ var markup = this._outerHTML(object).replace('</'+closeTag+'>', '');
1079
+ if (Prototype.Browser.IE) {
1080
+ for (var i = 0; i < object.childNodes.length; i++){
1081
+ markup += this._outerHTML(object.childNodes[i]);
1082
+ }
1083
+ markup += '</'+closeTag+'>';
1084
+ }
1085
+ return markup;
1086
+ },
1087
+ //
1088
+ // Depending what type of browser it is we have to append the object differently... DAMN YOU IE!!
1089
+ //
1090
+ _appendObject : function(object, closeTag, appendTo) {
1091
+ if (Prototype.Browser.IE) {
1092
+ appendTo.innerHTML += this._convertToMarkup(object, closeTag);
1093
+
1094
+ // Fix the Eolas activate thing but only for specified media, for example doing this to a quicktime film breaks it.
1095
+ if (this.options.EOLASFix.indexOf(this._fileType(this.element.href)) > -1) {
1096
+ var objectElements = document.getElementsByTagName('object');
1097
+ for (var i = 0; i < objectElements.length; i++) {
1098
+ if (objectElements[i].getAttribute("data")) objectElements[i].removeAttribute('data');
1099
+ objectElements[i].outerHTML = objectElements[i].outerHTML;
1100
+ objectElements[i].style.visibility = "visible";
1101
+ }
1102
+ }
1103
+ } else {
1104
+ appendTo.appendChild(object);
1105
+ }
1106
+ },
1107
+ //
1108
+ // Add in iframe
1109
+ //
1110
+ _appendIframe : function(scroll) {
1111
+ var iframe = document.createElement('iframe');
1112
+ iframe.setAttribute('id', 'lightwindow_iframe');
1113
+ iframe.setAttribute('name', 'lightwindow_iframe');
1114
+ iframe.setAttribute('src', 'about:blank');
1115
+ iframe.setAttribute('height', '100%');
1116
+ iframe.setAttribute('width', '100%');
1117
+ iframe.setAttribute('frameborder', '0');
1118
+ iframe.setAttribute('marginwidth', '0');
1119
+ iframe.setAttribute('marginheight', '0');
1120
+ iframe.setAttribute('scrolling', scroll);
1121
+
1122
+ this._appendObject(iframe, 'iframe', $('lightwindow_contents'));
1123
+ },
1124
+ //
1125
+ // Write Content to the iframe using the skin
1126
+ //
1127
+ _writeToIframe : function(content) {
1128
+ var template = this.options.skin.iframe;
1129
+ template = template.replace('{body_replace}', content);
1130
+ if ($('lightwindow_iframe').contentWindow){
1131
+ $('lightwindow_iframe').contentWindow.document.open();
1132
+ $('lightwindow_iframe').contentWindow.document.write(template);
1133
+ $('lightwindow_iframe').contentWindow.document.close();
1134
+ } else {
1135
+ $('lightwindow_iframe').contentDocument.open();
1136
+ $('lightwindow_iframe').contentDocument.write(template);
1137
+ $('lightwindow_iframe').contentDocument.close();
1138
+ }
1139
+ },
1140
+ //
1141
+ // Load the window Information
1142
+ //
1143
+ _loadWindow : function() {
1144
+ switch (this.windowType) {
1145
+ case 'image' :
1146
+
1147
+ var current = 0;
1148
+ var images = [];
1149
+ this.checkImage = [];
1150
+ this.resizeTo.height = this.resizeTo.width = 0;
1151
+ this.imageCount = this._getParameter('lightwindow_show_images') ? parseInt(this._getParameter('lightwindow_show_images')) : 1;
1152
+
1153
+ // If there is a gallery get it
1154
+ if (gallery = this._getGalleryInfo(this.element.rel)) {
1155
+ for (current = 0; current < this.galleries[gallery[0]][gallery[1]].length; current++) {
1156
+ if (this.contentToFetch.indexOf(this.galleries[gallery[0]][gallery[1]][current].href) > -1) {
1157
+ break;
1158
+ }
1159
+ }
1160
+ if (this.galleries[gallery[0]][gallery[1]][current-this.imageCount]) {
1161
+ this.navigationObservers.previous = this.galleries[gallery[0]][gallery[1]][current-this.imageCount];
1162
+ } else {
1163
+ this.navigationObservers.previous = false;
1164
+ }
1165
+ if (this.galleries[gallery[0]][gallery[1]][current+this.imageCount]) {
1166
+ this.navigationObservers.next = this.galleries[gallery[0]][gallery[1]][current+this.imageCount];
1167
+ } else {
1168
+ this.navigationObservers.next = false;
1169
+ }
1170
+
1171
+ this.activeGallery = true;
1172
+ } else {
1173
+ this.navigationObservers.previous = false;
1174
+ this.navigationObservers.next = false;
1175
+
1176
+ this.activeGallery = false;
1177
+ }
1178
+
1179
+ for (var i = current; i < (current+this.imageCount); i++) {
1180
+
1181
+ if (gallery && this.galleries[gallery[0]][gallery[1]][i]) {
1182
+ this.contentToFetch = this.galleries[gallery[0]][gallery[1]][i].href;
1183
+
1184
+ this.galleryLocation = {current: (i+1)/this.imageCount, total: (this.galleries[gallery[0]][gallery[1]].length)/this.imageCount};
1185
+
1186
+ if (!this.galleries[gallery[0]][gallery[1]][i+this.imageCount]) {
1187
+ $('lightwindow_next').setStyle({
1188
+ display: 'none'
1189
+ });
1190
+ } else {
1191
+ $('lightwindow_next').setStyle({
1192
+ display: 'block'
1193
+ });
1194
+ $('lightwindow_next_title').innerHTML = this.galleries[gallery[0]][gallery[1]][i+this.imageCount].title;
1195
+ }
1196
+
1197
+ if (!this.galleries[gallery[0]][gallery[1]][i-this.imageCount]) {
1198
+ $('lightwindow_previous').setStyle({
1199
+ display: 'none'
1200
+ });
1201
+ } else {
1202
+ $('lightwindow_previous').setStyle({
1203
+ display: 'block'
1204
+ });
1205
+ $('lightwindow_previous_title').innerHTML = this.galleries[gallery[0]][gallery[1]][i-this.imageCount].title;
1206
+ }
1207
+ }
1208
+
1209
+ images[i] = document.createElement('img');
1210
+ images[i].setAttribute('id', 'lightwindow_image_'+i);
1211
+ images[i].setAttribute('border', '0');
1212
+ images[i].setAttribute('src', this.contentToFetch);
1213
+ $('lightwindow_contents').appendChild(images[i]);
1214
+
1215
+ // We have to do this instead of .onload
1216
+ this.checkImage[i] = new PeriodicalExecuter(function(i) {
1217
+ if (!(typeof $('lightwindow_image_'+i).naturalWidth != "undefined" && $('lightwindow_image_'+i).naturalWidth == 0)) {
1218
+
1219
+ this.checkImage[i].stop();
1220
+
1221
+ var imageHeight = $('lightwindow_image_'+i).getHeight();
1222
+ if (imageHeight > this.resizeTo.height) {
1223
+ this.resizeTo.height = imageHeight;
1224
+ }
1225
+ this.resizeTo.width += $('lightwindow_image_'+i).getWidth();
1226
+ this.imageCount--;
1227
+
1228
+ $('lightwindow_image_'+i).setStyle({
1229
+ height: '100%'
1230
+ });
1231
+
1232
+ if (this.imageCount == 0) {
1233
+ this._processWindow();
1234
+ }
1235
+ }
1236
+
1237
+ }.bind(this, i), 1);
1238
+ }
1239
+
1240
+
1241
+ break;
1242
+
1243
+ case 'media' :
1244
+
1245
+ var current = 0;
1246
+ this.resizeTo.height = this.resizeTo.width = 0;
1247
+
1248
+ // If there is a gallery get it
1249
+ if (gallery = this._getGalleryInfo(this.element.rel)) {
1250
+ for (current = 0; current < this.galleries[gallery[0]][gallery[1]].length; current++) {
1251
+ if (this.contentToFetch.indexOf(this.galleries[gallery[0]][gallery[1]][current].href) > -1) {
1252
+ break;
1253
+ }
1254
+ }
1255
+
1256
+ if (this.galleries[gallery[0]][gallery[1]][current-1]) {
1257
+ this.navigationObservers.previous = this.galleries[gallery[0]][gallery[1]][current-1];
1258
+ } else {
1259
+ this.navigationObservers.previous = false;
1260
+ }
1261
+ if (this.galleries[gallery[0]][gallery[1]][current+1]) {
1262
+ this.navigationObservers.next = this.galleries[gallery[0]][gallery[1]][current+1];
1263
+ } else {
1264
+ this.navigationObservers.next = false;
1265
+ }
1266
+
1267
+ this.activeGallery = true;
1268
+ } else {
1269
+ this.navigationObservers.previous = false;
1270
+ this.navigationObservers.next = false;
1271
+
1272
+ this.activeGallery = false;
1273
+ }
1274
+
1275
+
1276
+ if (gallery && this.galleries[gallery[0]][gallery[1]][current]) {
1277
+ this.contentToFetch = this.galleries[gallery[0]][gallery[1]][current].href;
1278
+
1279
+ this.galleryLocation = {current: current+1, total: this.galleries[gallery[0]][gallery[1]].length};
1280
+
1281
+ if (!this.galleries[gallery[0]][gallery[1]][current+1]) {
1282
+ $('lightwindow_next').setStyle({
1283
+ display: 'none'
1284
+ });
1285
+ } else {
1286
+ $('lightwindow_next').setStyle({
1287
+ display: 'block'
1288
+ });
1289
+ $('lightwindow_next_title').innerHTML = this.galleries[gallery[0]][gallery[1]][current+1].title;
1290
+ }
1291
+
1292
+ if (!this.galleries[gallery[0]][gallery[1]][current-1]) {
1293
+ $('lightwindow_previous').setStyle({
1294
+ display: 'none'
1295
+ });
1296
+ } else {
1297
+ $('lightwindow_previous').setStyle({
1298
+ display: 'block'
1299
+ });
1300
+ $('lightwindow_previous_title').innerHTML = this.galleries[gallery[0]][gallery[1]][current-1].title;
1301
+ }
1302
+ }
1303
+
1304
+ if (this._getParameter('lightwindow_iframe_embed')) {
1305
+ this.resizeTo.height = this.dimensions.viewport.height;
1306
+ this.resizeTo.width = this.dimensions.viewport.width;
1307
+ } else {
1308
+ this.resizeTo.height = this._getParameter('lightwindow_height');
1309
+ this.resizeTo.width = this._getParameter('lightwindow_width');
1310
+ }
1311
+
1312
+ this._processWindow();
1313
+
1314
+ break;
1315
+
1316
+ case 'external' :
1317
+
1318
+ this._appendIframe('auto');
1319
+
1320
+ this.resizeTo.height = this.dimensions.viewport.height;
1321
+ this.resizeTo.width = this.dimensions.viewport.width;
1322
+ this._processWindow();
1323
+
1324
+ break;
1325
+
1326
+ case 'page' :
1327
+
1328
+ var newAJAX = new Ajax.Request(
1329
+ this.contentToFetch, {
1330
+ method: 'get',
1331
+ parameters: '',
1332
+ onComplete: function(response) {
1333
+ $('lightwindow_contents').innerHTML += response.responseText;
1334
+ this.resizeTo.height = $('lightwindow_contents').scrollHeight+(this.options.contentOffset.height);
1335
+ this.resizeTo.width = $('lightwindow_contents').scrollWidth+(this.options.contentOffset.width);
1336
+ this._processWindow();
1337
+ }.bind(this)
1338
+ }
1339
+ );
1340
+
1341
+ break;
1342
+
1343
+ case 'inline' :
1344
+
1345
+ var content = this.contentToFetch;
1346
+ if (content.indexOf('?') > -1) {
1347
+ content = content.substring(0, content.indexOf('?'));
1348
+ }
1349
+ content = content.substring(content.indexOf('#')+1);
1350
+
1351
+ new Insertion.Top($('lightwindow_contents'), $(content).innerHTML);
1352
+
1353
+ this.resizeTo.height = $('lightwindow_contents').scrollHeight+(this.options.contentOffset.height);
1354
+ this.resizeTo.width = $('lightwindow_contents').scrollWidth+(this.options.contentOffset.width);
1355
+
1356
+ this._toggleTroubleElements('hidden', true);
1357
+ this._processWindow();
1358
+
1359
+ break;
1360
+
1361
+ default :
1362
+ throw("Page Type could not be determined, please amend this lightwindow URL "+this.contentToFetch);
1363
+ break;
1364
+ }
1365
+ },
1366
+ //
1367
+ // Resize the Window to fit the viewport if necessary
1368
+ //
1369
+ _resizeWindowToFit : function() {
1370
+ if (this.resizeTo.height+this.dimensions.cruft.height > this.dimensions.viewport.height) {
1371
+ var heightRatio = this.resizeTo.height/this.resizeTo.width;
1372
+ this.resizeTo.height = this.dimensions.viewport.height-this.dimensions.cruft.height-(2*this.options.viewportPadding);
1373
+ // We only care about ratio's with this window type
1374
+ if (this.windowType == 'image' || (this.windowType == 'media' && !this._getParameter('lightwindow_iframe_embed'))) {
1375
+ this.resizeTo.width = this.resizeTo.height/heightRatio;
1376
+ $('lightwindow_data_slide_inner').setStyle({
1377
+ width: this.resizeTo.width+'px'
1378
+ });
1379
+ }
1380
+ }
1381
+ if (this.resizeTo.width+this.dimensions.cruft.width > this.dimensions.viewport.width) {
1382
+ var widthRatio = this.resizeTo.width/this.resizeTo.height;
1383
+ this.resizeTo.width = this.dimensions.viewport.width-2*this.dimensions.cruft.width-(2*this.options.viewportPadding);
1384
+ // We only care about ratio's with this window type
1385
+ if (this.windowType == 'image' || (this.windowType == 'media' && !this._getParameter('lightwindow_iframe_embed'))) {
1386
+ this.resizeTo.height = this.resizeTo.width/widthRatio;
1387
+ $('lightwindow_data_slide_inner').setStyle({
1388
+ height: this.resizeTo.height+'px'
1389
+ });
1390
+ }
1391
+ }
1392
+
1393
+ },
1394
+ //
1395
+ // Set the Window to a preset size
1396
+ //
1397
+ _presetWindowSize : function() {
1398
+ if (this._getParameter('lightwindow_height')) {
1399
+ this.resizeTo.height = parseFloat(this._getParameter('lightwindow_height'));
1400
+ }
1401
+ if (this._getParameter('lightwindow_width')) {
1402
+ this.resizeTo.width = parseFloat(this._getParameter('lightwindow_width'));
1403
+ }
1404
+ },
1405
+ //
1406
+ // Process the Window
1407
+ //
1408
+ _processWindow : function() {
1409
+ // Clean out our effects
1410
+ this.dimensions.dataEffects = [];
1411
+
1412
+ // Set up the data-slide if we have caption information
1413
+ if (this.element.caption || this.element.author || (this.activeGallery && this.options.showGalleryCount)) {
1414
+ if (this.element.caption) {
1415
+ $('lightwindow_data_caption').innerHTML = this.element.caption;
1416
+ $('lightwindow_data_caption').setStyle({
1417
+ display: 'block'
1418
+ });
1419
+ } else {
1420
+ $('lightwindow_data_caption').setStyle({
1421
+ display: 'none'
1422
+ });
1423
+ }
1424
+ if (this.element.author) {
1425
+ $('lightwindow_data_author').innerHTML = this.element.author;
1426
+ $('lightwindow_data_author_container').setStyle({
1427
+ display: 'block'
1428
+ });
1429
+ } else {
1430
+ $('lightwindow_data_author_container').setStyle({
1431
+ display: 'none'
1432
+ });
1433
+ }
1434
+ if (this.activeGallery && this.options.showGalleryCount) {
1435
+ $('lightwindow_data_gallery_current').innerHTML = this.galleryLocation.current;
1436
+ $('lightwindow_data_gallery_total').innerHTML = this.galleryLocation.total;
1437
+ $('lightwindow_data_gallery_container').setStyle({
1438
+ display: 'block'
1439
+ });
1440
+ } else {
1441
+ $('lightwindow_data_gallery_container').setStyle({
1442
+ display: 'none'
1443
+ });
1444
+ }
1445
+
1446
+ $('lightwindow_data_slide_inner').setStyle({
1447
+ width: this.resizeTo.width+'px',
1448
+ height: 'auto',
1449
+ visibility: 'visible',
1450
+ display: 'block'
1451
+ });
1452
+ $('lightwindow_data_slide').setStyle({
1453
+ height: $('lightwindow_data_slide').getHeight()+'px',
1454
+ width: '1px',
1455
+ overflow: 'hidden',
1456
+ display: 'block'
1457
+ });
1458
+ } else {
1459
+ $('lightwindow_data_slide').setStyle({
1460
+ display: 'none',
1461
+ width: 'auto'
1462
+ });
1463
+ $('lightwindow_data_slide_inner').setStyle({
1464
+ display: 'none',
1465
+ visibility: 'hidden',
1466
+ width: this.resizeTo.width+'px',
1467
+ height: '0px'
1468
+ });
1469
+ }
1470
+
1471
+ if (this.element.title != 'null') {
1472
+ $('lightwindow_title_bar_title').innerHTML = this.element.title;
1473
+ } else {
1474
+ $('lightwindow_title_bar_title').innerHTML = '';
1475
+ }
1476
+
1477
+ var originalContainerDimensions = {height: $('lightwindow_container').getHeight(), width: $('lightwindow_container').getWidth()};
1478
+ // Position the window
1479
+ $('lightwindow_container').setStyle({
1480
+ height: 'auto',
1481
+ // We need to set the width to a px not auto as opera has problems with it
1482
+ width: $('lightwindow_container').getWidth()+this.options.contentOffset.width-(this.windowActive ? this.options.contentOffset.width : 0)+'px'
1483
+ });
1484
+ var newContainerDimensions = {height: $('lightwindow_container').getHeight(), width: $('lightwindow_container').getWidth()};
1485
+
1486
+ // We need to record the container dimension changes
1487
+ this.containerChange = {height: originalContainerDimensions.height-newContainerDimensions.height, width: originalContainerDimensions.width-newContainerDimensions.width};
1488
+
1489
+ // Get out general dimensions
1490
+ this.dimensions.container = {height: $('lightwindow_container').getHeight(), width: $('lightwindow_container').getWidth()};
1491
+ this.dimensions.cruft = {height: this.dimensions.container.height-$('lightwindow_contents').getHeight()+this.options.contentOffset.height, width: this.dimensions.container.width-$('lightwindow_contents').getWidth()+this.options.contentOffset.width};
1492
+
1493
+ // Set Sizes if we need too
1494
+ this._presetWindowSize();
1495
+ this._resizeWindowToFit(); // Even if the window is preset we still don't want it to go outside of the viewport
1496
+
1497
+ if (!this.windowActive) {
1498
+ // Position the window
1499
+ $('lightwindow_container').setStyle({
1500
+ left: -(this.dimensions.container.width/2)+'px',
1501
+ top: -(this.dimensions.container.height/2)+'px'
1502
+ });
1503
+ }
1504
+ $('lightwindow_container').setStyle({
1505
+ height: this.dimensions.container.height+'px',
1506
+ width: this.dimensions.container.width+'px'
1507
+ });
1508
+
1509
+ // We are ready, lets show this puppy off!
1510
+ this._displayLightWindow('block', 'visible');
1511
+ this._animateLightWindow();
1512
+ },
1513
+ //
1514
+ // Fire off our animation handler
1515
+ //
1516
+ _animateLightWindow : function() {
1517
+ if (this.options.animationHandler) {
1518
+ this.options.animationHandler().bind(this);
1519
+ } else {
1520
+ this._defaultAnimationHandler();
1521
+ }
1522
+ },
1523
+ //
1524
+ // Fire off our transition handler
1525
+ //
1526
+ _handleNavigation : function(display) {
1527
+ if (this.options.navigationHandler) {
1528
+ this.options.navigationHandler().bind(this, display);
1529
+ } else {
1530
+ this._defaultDisplayNavigation(display);
1531
+ }
1532
+ },
1533
+ //
1534
+ // Fire off our transition handler
1535
+ //
1536
+ _handleTransition : function() {
1537
+ if (this.options.transitionHandler) {
1538
+ this.options.transitionHandler().bind(this);
1539
+ } else {
1540
+ this._defaultTransitionHandler();
1541
+ }
1542
+ },
1543
+ //
1544
+ // Handle the finish of the window animation
1545
+ //
1546
+ _handleFinalWindowAnimation : function(delay) {
1547
+ if (this.options.finalAnimationHandler) {
1548
+ this.options.finalAnimationHandler().bind(this, delay);
1549
+ } else {
1550
+ this._defaultfinalWindowAnimationHandler(delay);
1551
+ }
1552
+ },
1553
+ //
1554
+ // Handle the gallery Animation
1555
+ //
1556
+ _handleGalleryAnimation : function(list) {
1557
+ if (this.options.galleryAnimationHandler) {
1558
+ this.options.galleryAnimationHandler().bind(this, list);
1559
+ } else {
1560
+ this._defaultGalleryAnimationHandler(list);
1561
+ }
1562
+ },
1563
+ //
1564
+ // Display the navigation
1565
+ //
1566
+ _defaultDisplayNavigation : function(display) {
1567
+ if (display) {
1568
+ $('lightwindow_navigation').setStyle({
1569
+ display: 'block',
1570
+ height: $('lightwindow_contents').getHeight()+'px',
1571
+ width: '100%',
1572
+ marginTop: this.options.dimensions.titleHeight+'px'
1573
+ });
1574
+ } else {
1575
+ $('lightwindow_navigation').setStyle({
1576
+ display: 'none',
1577
+ height: 'auto',
1578
+ width: 'auto'
1579
+ });
1580
+ }
1581
+ },
1582
+ //
1583
+ // This is the default animation handler for LightWindow
1584
+ //
1585
+ _defaultAnimationHandler : function() {
1586
+ // Now that we have figures out the cruft lets make the caption go away and add its effects
1587
+ if (this.element.caption || this.element.author || (this.activeGallery && this.options.showGalleryCount)) {
1588
+ $('lightwindow_data_slide').setStyle({
1589
+ display: 'none',
1590
+ width: 'auto'
1591
+ });
1592
+ this.dimensions.dataEffects.push(
1593
+ new Effect.SlideDown('lightwindow_data_slide', {sync: true}),
1594
+ new Effect.Appear('lightwindow_data_slide', {sync: true, from: 0.0, to: 1.0})
1595
+ );
1596
+ }
1597
+
1598
+ // Set up the Title if we have one
1599
+ $('lightwindow_title_bar_inner').setStyle({
1600
+ height: '0px',
1601
+ marginTop: this.options.dimensions.titleHeight+'px'
1602
+ });
1603
+
1604
+ // We always want the title bar as well
1605
+ this.dimensions.dataEffects.push(
1606
+ new Effect.Morph('lightwindow_title_bar_inner', {sync: true, style: {height: this.options.dimensions.titleHeight+'px', marginTop: '0px'}}),
1607
+ new Effect.Appear('lightwindow_title_bar_inner', {sync: true, from: 0.0, to: 1.0})
1608
+ );
1609
+
1610
+ if (!this.options.hideGalleryTab) {
1611
+ this._handleGalleryAnimation(false);
1612
+ if ($('lightwindow_galleries_tab_container').getHeight() == 0) {
1613
+ this.dimensions.dataEffects.push(
1614
+ new Effect.Morph('lightwindow_galleries_tab_container', {sync: true, style: {height: '20px', marginTop: '0px'}})
1615
+ );
1616
+ $('lightwindow_galleries').setStyle({
1617
+ width: '0px'
1618
+ });
1619
+ }
1620
+ }
1621
+
1622
+ var resized = false;
1623
+ var ratio = this.dimensions.container.width-$('lightwindow_contents').getWidth()+this.resizeTo.width+this.options.contentOffset.width;
1624
+ if (ratio != $('lightwindow_container').getWidth()) {
1625
+ new Effect.Parallel([
1626
+ new Effect.Scale('lightwindow_contents', 100*(this.resizeTo.width/$('lightwindow_contents').getWidth()), {scaleFrom: 100*($('lightwindow_contents').getWidth()/($('lightwindow_contents').getWidth()+(this.options.contentOffset.width))), sync: true, scaleY: false, scaleContent: false}),
1627
+ new Effect.Scale('lightwindow_container', 100*(ratio/(this.dimensions.container.width)), {sync: true, scaleY: false, scaleFromCenter: true, scaleContent: false})
1628
+ ], {
1629
+ duration: this.duration,
1630
+ delay: 0.25,
1631
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1632
+ }
1633
+ );
1634
+ }
1635
+
1636
+ ratio = this.dimensions.container.height-$('lightwindow_contents').getHeight()+this.resizeTo.height+this.options.contentOffset.height;
1637
+ if (ratio != $('lightwindow_container').getHeight()) {
1638
+ new Effect.Parallel([
1639
+ new Effect.Scale('lightwindow_contents', 100*(this.resizeTo.height/$('lightwindow_contents').getHeight()), {scaleFrom: 100*($('lightwindow_contents').getHeight()/($('lightwindow_contents').getHeight()+(this.options.contentOffset.height))), sync: true, scaleX: false, scaleContent: false}),
1640
+ new Effect.Scale('lightwindow_container', 100*(ratio/(this.dimensions.container.height)), {sync: true, scaleX: false, scaleFromCenter: true, scaleContent: false})
1641
+ ], {
1642
+ duration: this.duration,
1643
+ afterFinish: function() {
1644
+ if (this.dimensions.dataEffects.length > 0) {
1645
+ if (!this.options.hideGalleryTab) {
1646
+ $('lightwindow_galleries').setStyle({
1647
+ width: this.resizeTo.width+'px'
1648
+ });
1649
+ }
1650
+ new Effect.Parallel(this.dimensions.dataEffects, {
1651
+ duration: this.duration,
1652
+ afterFinish: function() {
1653
+ this._finishWindow();
1654
+ }.bind(this),
1655
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1656
+ }
1657
+ );
1658
+ }
1659
+ }.bind(this),
1660
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1661
+ }
1662
+ );
1663
+ resized = true;
1664
+ }
1665
+
1666
+ // We need to do our data effect since there was no resizing
1667
+ if (!resized && this.dimensions.dataEffects.length > 0) {
1668
+ new Effect.Parallel(this.dimensions.dataEffects, {
1669
+ duration: this.duration,
1670
+ beforeStart: function() {
1671
+ if (!this.options.hideGalleryTab) {
1672
+ $('lightwindow_galleries').setStyle({
1673
+ width: this.resizeTo.width+'px'
1674
+ });
1675
+ }
1676
+ if (this.containerChange.height != 0 || this.containerChange.width != 0) {
1677
+ new Effect.MoveBy('lightwindow_container', this.containerChange.height, this.containerChange.width, {transition: Effect.Transitions.sinoidal});
1678
+ }
1679
+ }.bind(this),
1680
+ afterFinish: function() {
1681
+ this._finishWindow();
1682
+ }.bind(this),
1683
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1684
+ }
1685
+ );
1686
+ }
1687
+
1688
+ },
1689
+ //
1690
+ // Finish up Window Animation
1691
+ //
1692
+ _defaultfinalWindowAnimationHandler : function(delay) {
1693
+ if (this.windowType == 'media' || this._getParameter('lightwindow_loading_animation')) {
1694
+ // Because of major flickering with the overlay we just hide it in this case
1695
+ Element.hide('lightwindow_loading');
1696
+ this._handleNavigation(this.activeGallery);
1697
+ this._setStatus(false);
1698
+ } else {
1699
+ Effect.Fade('lightwindow_loading', {
1700
+ duration: 0.75,
1701
+ delay: 1.0,
1702
+ afterFinish: function() {
1703
+ // Just in case we need some scroll goodness (this also avoids the swiss cheese effect)
1704
+ if (this.windowType != 'image' && this.windowType != 'media' && this.windowType != 'external') {
1705
+ $('lightwindow_contents').setStyle({
1706
+ overflow: 'auto'
1707
+ });
1708
+ }
1709
+ this._handleNavigation(this.activeGallery);
1710
+ this._defaultGalleryAnimationHandler();
1711
+ this._setStatus(false);
1712
+ }.bind(this),
1713
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1714
+ });
1715
+ }
1716
+ },
1717
+ //
1718
+ // Handle the gallery Animation
1719
+ //
1720
+ _defaultGalleryAnimationHandler : function(list) {
1721
+ if (this.activeGallery) {
1722
+ $('lightwindow_galleries').setStyle({
1723
+ display: 'block',
1724
+ marginBottom: $('lightwindow_data_slide').getHeight()+this.options.contentOffset.height/2+'px'
1725
+ });
1726
+ $('lightwindow_navigation').setStyle({
1727
+ height: $('lightwindow_contents').getHeight()-20+'px'
1728
+ });
1729
+ } else {
1730
+ $('lightwindow_galleries').setStyle({
1731
+ display: 'none'
1732
+ });
1733
+ $('lightwindow_galleries_tab_container').setStyle({
1734
+ height: '0px',
1735
+ marginTop: '20px'
1736
+ });
1737
+ $('lightwindow_galleries_list').setStyle({
1738
+ height: '0px'
1739
+ });
1740
+ return false;
1741
+ }
1742
+
1743
+ if (list) {
1744
+ if ($('lightwindow_galleries_list').getHeight() == 0) {
1745
+ var height = $('lightwindow_contents').getHeight()*0.80;
1746
+ $('lightwindow_galleries_tab_span').className = 'down';
1747
+ } else {
1748
+ var height = 0;
1749
+ $('lightwindow_galleries_tab_span').className = 'up';
1750
+ }
1751
+
1752
+ new Effect.Morph('lightwindow_galleries_list', {
1753
+ duration: this.duration,
1754
+ transition: Effect.Transitions.sinoidal,
1755
+ style: {height: height+'px'},
1756
+ beforeStart: function() {
1757
+ $('lightwindow_galleries_list').setStyle({
1758
+ overflow: 'hidden'
1759
+ });
1760
+ },
1761
+ afterFinish: function() {
1762
+ $('lightwindow_galleries_list').setStyle({
1763
+ overflow: 'auto'
1764
+ });
1765
+ },
1766
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1767
+ });
1768
+ }
1769
+
1770
+
1771
+ },
1772
+ //
1773
+ // Default Transition Handler
1774
+ //
1775
+ _defaultTransitionHandler : function() {
1776
+ // Clean out our effects
1777
+ this.dimensions.dataEffects = [];
1778
+
1779
+ // Now that we have figures out the cruft lets make the caption go away and add its effects
1780
+ if ($('lightwindow_data_slide').getStyle('display') != 'none') {
1781
+ this.dimensions.dataEffects.push(
1782
+ new Effect.SlideUp('lightwindow_data_slide', {sync: true}),
1783
+ new Effect.Fade('lightwindow_data_slide', {sync: true, from: 1.0, to: 0.0})
1784
+ );
1785
+ }
1786
+
1787
+ if (!this.options.hideGalleryTab) {
1788
+ if ($('lightwindow_galleries').getHeight() != 0 && !this.options.hideGalleryTab) {
1789
+ this.dimensions.dataEffects.push(
1790
+ new Effect.Morph('lightwindow_galleries_tab_container', {sync: true, style: {height: '0px', marginTop: '20px'}})
1791
+ );
1792
+ }
1793
+
1794
+ if ($('lightwindow_galleries_list').getHeight() != 0) {
1795
+ $('lightwindow_galleries_tab_span').className = 'up';
1796
+ this.dimensions.dataEffects.push(
1797
+ new Effect.Morph('lightwindow_galleries_list', {
1798
+ sync: true,
1799
+ style: {height: '0px'},
1800
+ transition: Effect.Transitions.sinoidal,
1801
+ beforeStart: function() {
1802
+ $('lightwindow_galleries_list').setStyle({
1803
+ overflow: 'hidden'
1804
+ });
1805
+ },
1806
+ afterFinish: function() {
1807
+ $('lightwindow_galleries_list').setStyle({
1808
+ overflow: 'auto'
1809
+ });
1810
+ }
1811
+ })
1812
+ );
1813
+ }
1814
+ }
1815
+
1816
+ // We always want the title bar as well
1817
+ this.dimensions.dataEffects.push(
1818
+ new Effect.Morph('lightwindow_title_bar_inner', {sync: true, style: {height: '0px', marginTop: this.options.dimensions.titleHeight+'px'}}),
1819
+ new Effect.Fade('lightwindow_title_bar_inner', {sync: true, from: 1.0, to: 0.0})
1820
+ );
1821
+
1822
+ new Effect.Parallel(this.dimensions.dataEffects, {
1823
+ duration: this.duration,
1824
+ afterFinish: function() {
1825
+ this._loadWindow();
1826
+ }.bind(this),
1827
+ queue: {position: 'end', scope: 'lightwindowAnimation'}
1828
+ }
1829
+ );
1830
+ },
1831
+ //
1832
+ // Default Form handler for LightWindow
1833
+ //
1834
+ _defaultFormHandler : function(e) {
1835
+ var element = Event.element(e).parentNode;
1836
+ var parameterString = Form.serialize(this._getParameter('lightwindow_form', element.getAttribute('params')));
1837
+ if (this.options.formMethod == 'post') {
1838
+ var newAJAX = new Ajax.Request(element.href, {
1839
+ method: 'post',
1840
+ postBody: parameterString,
1841
+ onComplete: this.openWindow.bind(this, element)
1842
+ });
1843
+ } else if (this.options.formMethod == 'get') {
1844
+ var newAJAX = new Ajax.Request(element.href, {
1845
+ method: 'get',
1846
+ parameters: parameterString,
1847
+ onComplete: this.openWindow.bind(this, element)
1848
+ });
1849
+ }
1850
+ },
1851
+ //
1852
+ // Wrap everything up
1853
+ //
1854
+ _finishWindow : function() {
1855
+ if (this.windowType == 'external') {
1856
+ // We set the externals source here because it allows for a much smoother animation
1857
+ $('lightwindow_iframe').setAttribute('src', this.element.href);
1858
+ this._handleFinalWindowAnimation(1);
1859
+ } else if (this.windowType == 'media') {
1860
+
1861
+ var outerObject = document.createElement('object');
1862
+ outerObject.setAttribute('classid', this.options.classids[this._fileExtension(this.contentToFetch)]);
1863
+ outerObject.setAttribute('codebase', this.options.codebases[this._fileExtension(this.contentToFetch)]);
1864
+ outerObject.setAttribute('id', 'lightwindow_media_primary');
1865
+ outerObject.setAttribute('name', 'lightwindow_media_primary');
1866
+ outerObject.setAttribute('width', this.resizeTo.width);
1867
+ outerObject.setAttribute('height', this.resizeTo.height);
1868
+ outerObject = this._addParamToObject('movie', this.contentToFetch, outerObject);
1869
+ outerObject = this._addParamToObject('src', this.contentToFetch, outerObject);
1870
+ outerObject = this._addParamToObject('controller', 'true', outerObject);
1871
+ outerObject = this._addParamToObject('wmode', 'transparent', outerObject);
1872
+ outerObject = this._addParamToObject('cache', 'false', outerObject);
1873
+ outerObject = this._addParamToObject('quality', 'high', outerObject);
1874
+
1875
+ if (!Prototype.Browser.IE) {
1876
+ var innerObject = document.createElement('object');
1877
+ innerObject.setAttribute('type', this.options.mimeTypes[this._fileExtension(this.contentToFetch)]);
1878
+ innerObject.setAttribute('data', this.contentToFetch);
1879
+ innerObject.setAttribute('id', 'lightwindow_media_secondary');
1880
+ innerObject.setAttribute('name', 'lightwindow_media_secondary');
1881
+ innerObject.setAttribute('width', this.resizeTo.width);
1882
+ innerObject.setAttribute('height', this.resizeTo.height);
1883
+ innerObject = this._addParamToObject('controller', 'true', innerObject);
1884
+ innerObject = this._addParamToObject('wmode', 'transparent', innerObject);
1885
+ innerObject = this._addParamToObject('cache', 'false', innerObject);
1886
+ innerObject = this._addParamToObject('quality', 'high', innerObject);
1887
+
1888
+ outerObject.appendChild(innerObject);
1889
+ }
1890
+
1891
+ if (this._getParameter('lightwindow_iframe_embed')) {
1892
+ this._appendIframe('no');
1893
+ this._writeToIframe(this._convertToMarkup(outerObject, 'object'));
1894
+ } else {
1895
+ this._appendObject(outerObject, 'object', $('lightwindow_contents'));
1896
+ }
1897
+
1898
+ this._handleFinalWindowAnimation(0);
1899
+ } else {
1900
+ this._handleFinalWindowAnimation(0);
1901
+ }
1902
+
1903
+ // Initialize any actions
1904
+ this._setupActions();
1905
+ }
1906
+ }
1907
+
1908
+ /*-----------------------------------------------------------------------------------------------*/
1909
+
1910
+ Event.observe(window, 'load', lightwindowInit, false);
1911
+
1912
+ //
1913
+ // Set up all of our links
1914
+ //
1915
+ var myLightWindow = null;
1916
+ function lightwindowInit() {
1917
+ myLightWindow = new lightwindow();
1918
+ }